Lines Matching +full:mt8188 +full:- +full:pinctrl

1 // SPDX-License-Identifier: GPL-2.0
3 * mt8188-mt6359.c -- MT8188-MT6359 ALSA SoC machine driver
17 #include "mt8188-afe-common.h"
21 #include "../common/mtk-afe-platform-driver.h"
22 #include "../common/mtk-soundcard-driver.h"
23 #include "../common/mtk-dsp-sof-common.h"
24 #include "../common/mtk-soc-card.h"
42 #define MAX98390_CODEC_DAI "max98390-aif1"
43 #define MAX98390_DEV0_NAME "max98390.0-0038" /* rear right */
44 #define MAX98390_DEV1_NAME "max98390.0-0039" /* rear left */
45 #define MAX98390_DEV2_NAME "max98390.0-003a" /* front right */
46 #define MAX98390_DEV3_NAME "max98390.0-003b" /* front left */
51 #define NAU8825_CODEC_DAI "nau8825-hifi"
63 #define RT5682S_CODEC_DAI "rt5682s-aif1"
149 DAILINK_COMP_ARRAY(COMP_CODEC("mt6359-sound",
150 "mt6359-snd-codec-aif1")),
190 DAILINK_COMP_ARRAY(COMP_CODEC("mt6359-sound",
191 "mt6359-snd-codec-aif1")),
307 /* dynamic pinctrl */
344 snd_soc_rtd_to_codec(rtd, 0)->component; in mt8188_mt6359_mtkaif_calibration()
363 return -EINVAL; in mt8188_mt6359_mtkaif_calibration()
366 afe_priv = afe->platform_priv; in mt8188_mt6359_mtkaif_calibration()
367 param = &afe_priv->mtkaif_params; in mt8188_mt6359_mtkaif_calibration()
369 dev_dbg(afe->dev, "%s(), start\n", __func__); in mt8188_mt6359_mtkaif_calibration()
371 param->mtkaif_calibration_ok = false; in mt8188_mt6359_mtkaif_calibration()
373 param->mtkaif_chosen_phase[i] = -1; in mt8188_mt6359_mtkaif_calibration()
374 param->mtkaif_phase_cycle[i] = 0; in mt8188_mt6359_mtkaif_calibration()
375 mtkaif_chosen_phase[i] = -1; in mt8188_mt6359_mtkaif_calibration()
379 if (IS_ERR(afe_priv->topckgen)) { in mt8188_mt6359_mtkaif_calibration()
380 dev_info(afe->dev, "%s() Cannot find topckgen controller\n", in mt8188_mt6359_mtkaif_calibration()
385 for_each_card_widgets(rtd->card, w) { in mt8188_mt6359_mtkaif_calibration()
386 if (!strcmp(w->name, "MTKAIF_PIN")) { in mt8188_mt6359_mtkaif_calibration()
395 dev_dbg(afe->dev, "%s(), no pinmux widget, please check if default on\n", __func__); in mt8188_mt6359_mtkaif_calibration()
397 pm_runtime_get_sync(afe->dev); in mt8188_mt6359_mtkaif_calibration()
401 regmap_write(afe_priv->topckgen, CKSYS_AUD_TOP_CFG, RG_TEST_TYPE); in mt8188_mt6359_mtkaif_calibration()
411 regmap_set_bits(afe_priv->topckgen, CKSYS_AUD_TOP_CFG, RG_TEST_ON); in mt8188_mt6359_mtkaif_calibration()
416 cycle_1 = -1; in mt8188_mt6359_mtkaif_calibration()
417 cycle_2 = -1; in mt8188_mt6359_mtkaif_calibration()
421 regmap_read(afe_priv->topckgen, in mt8188_mt6359_mtkaif_calibration()
434 dev_err(afe->dev, "%s(), test fail, cycle_1 %d, cycle_2 %d, monitor 0x%x\n", in mt8188_mt6359_mtkaif_calibration()
448 mtkaif_chosen_phase[MT8188_MTKAIF_MISO_0] = phase - 1; in mt8188_mt6359_mtkaif_calibration()
454 mtkaif_chosen_phase[MT8188_MTKAIF_MISO_1] = phase - 1; in mt8188_mt6359_mtkaif_calibration()
458 regmap_clear_bits(afe_priv->topckgen, CKSYS_AUD_TOP_CFG, RG_TEST_ON); in mt8188_mt6359_mtkaif_calibration()
485 pm_runtime_put(afe->dev); in mt8188_mt6359_mtkaif_calibration()
487 param->mtkaif_calibration_ok = mtkaif_calibration_ok; in mt8188_mt6359_mtkaif_calibration()
488 param->mtkaif_chosen_phase[MT8188_MTKAIF_MISO_0] = chosen_phase_1; in mt8188_mt6359_mtkaif_calibration()
489 param->mtkaif_chosen_phase[MT8188_MTKAIF_MISO_1] = chosen_phase_2; in mt8188_mt6359_mtkaif_calibration()
492 param->mtkaif_phase_cycle[i] = mtkaif_phase_cycle[i]; in mt8188_mt6359_mtkaif_calibration()
497 dev_dbg(afe->dev, "%s(), end, calibration ok %d\n", in mt8188_mt6359_mtkaif_calibration()
498 __func__, param->mtkaif_calibration_ok); in mt8188_mt6359_mtkaif_calibration()
506 snd_soc_rtd_to_codec(rtd, 0)->component; in mt8188_mt6359_init()
585 struct mtk_soc_card_data *soc_card_data = snd_soc_card_get_drvdata(rtd->card); in mt8188_hdmi_codec_init()
586 struct snd_soc_jack *jack = &soc_card_data->card_data->jacks[MT8188_JACK_HDMI]; in mt8188_hdmi_codec_init()
587 struct snd_soc_component *component = snd_soc_rtd_to_codec(rtd, 0)->component; in mt8188_hdmi_codec_init()
590 ret = snd_soc_card_jack_new_pins(rtd->card, "HDMI Jack", in mt8188_hdmi_codec_init()
595 dev_err(rtd->dev, "%s, new jack failed: %d\n", __func__, ret); in mt8188_hdmi_codec_init()
601 dev_err(rtd->dev, "%s, set jack failed on %s (ret=%d)\n", in mt8188_hdmi_codec_init()
602 __func__, component->name, ret); in mt8188_hdmi_codec_init()
611 struct mtk_soc_card_data *soc_card_data = snd_soc_card_get_drvdata(rtd->card); in mt8188_dptx_codec_init()
612 struct snd_soc_jack *jack = &soc_card_data->card_data->jacks[MT8188_JACK_DP]; in mt8188_dptx_codec_init()
613 struct snd_soc_component *component = snd_soc_rtd_to_codec(rtd, 0)->component; in mt8188_dptx_codec_init()
616 ret = snd_soc_card_jack_new_pins(rtd->card, "DP Jack", SND_JACK_LINEOUT, in mt8188_dptx_codec_init()
620 dev_err(rtd->dev, "%s, new jack failed: %d\n", __func__, ret); in mt8188_dptx_codec_init()
626 dev_err(rtd->dev, "%s, set jack failed on %s (ret=%d)\n", in mt8188_dptx_codec_init()
627 __func__, component->name, ret); in mt8188_dptx_codec_init()
636 struct snd_soc_card *card = rtd->card; in mt8188_dumb_amp_init()
639 ret = snd_soc_dapm_new_controls(&card->dapm, mt8188_dumb_spk_widgets, in mt8188_dumb_amp_init()
642 dev_err(rtd->dev, "unable to add Dumb Speaker dapm, ret %d\n", ret); in mt8188_dumb_amp_init()
649 dev_err(rtd->dev, "unable to add Dumb card controls, ret %d\n", ret); in mt8188_dumb_amp_init()
668 if (!strcmp(codec_dai->component->name, MAX98390_DEV0_NAME)) in mt8188_max98390_hw_params()
671 if (!strcmp(codec_dai->component->name, MAX98390_DEV1_NAME)) in mt8188_max98390_hw_params()
674 if (!strcmp(codec_dai->component->name, MAX98390_DEV2_NAME)) in mt8188_max98390_hw_params()
677 if (!strcmp(codec_dai->component->name, MAX98390_DEV3_NAME)) in mt8188_max98390_hw_params()
689 struct snd_soc_card *card = rtd->card; in mt8188_max98390_codec_init()
693 ret = snd_soc_dapm_new_controls(&card->dapm, mt8188_dual_spk_widgets, in mt8188_max98390_codec_init()
696 dev_err(rtd->dev, "unable to add Left/Right Speaker widget, ret %d\n", ret); in mt8188_max98390_codec_init()
703 dev_err(rtd->dev, "unable to add Left/Right card controls, ret %d\n", ret); in mt8188_max98390_codec_init()
707 if (rtd->dai_link->num_codecs <= 2) in mt8188_max98390_codec_init()
711 ret = snd_soc_dapm_new_controls(&card->dapm, mt8188_rear_spk_widgets, in mt8188_max98390_codec_init()
714 dev_err(rtd->dev, "unable to add Rear Speaker widget, ret %d\n", ret); in mt8188_max98390_codec_init()
722 dev_err(rtd->dev, "unable to add Rear card controls, ret %d\n", ret); in mt8188_max98390_codec_init()
731 struct snd_soc_card *card = rtd->card; in mt8188_headset_codec_init()
732 struct mtk_soc_card_data *soc_card_data = snd_soc_card_get_drvdata(rtd->card); in mt8188_headset_codec_init()
733 struct snd_soc_jack *jack = &soc_card_data->card_data->jacks[MT8188_JACK_HEADSET]; in mt8188_headset_codec_init()
734 struct snd_soc_component *component = snd_soc_rtd_to_codec(rtd, 0)->component; in mt8188_headset_codec_init()
735 struct mtk_platform_card_data *card_data = soc_card_data->card_data; in mt8188_headset_codec_init()
738 ret = snd_soc_dapm_new_controls(&card->dapm, mt8188_nau8825_widgets, in mt8188_headset_codec_init()
741 dev_err(rtd->dev, "unable to add nau8825 card widget, ret %d\n", ret); in mt8188_headset_codec_init()
748 dev_err(rtd->dev, "unable to add nau8825 card controls, ret %d\n", ret); in mt8188_headset_codec_init()
752 ret = snd_soc_card_jack_new_pins(rtd->card, "Headset Jack", in mt8188_headset_codec_init()
760 dev_err(rtd->dev, "Headset Jack creation failed: %d\n", ret); in mt8188_headset_codec_init()
764 if (card_data->flags & ES8326_HS_PRESENT) { in mt8188_headset_codec_init()
765 snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_PLAYPAUSE); in mt8188_headset_codec_init()
766 snd_jack_set_key(jack->jack, SND_JACK_BTN_1, KEY_VOLUMEUP); in mt8188_headset_codec_init()
767 snd_jack_set_key(jack->jack, SND_JACK_BTN_2, KEY_VOLUMEDOWN); in mt8188_headset_codec_init()
768 snd_jack_set_key(jack->jack, SND_JACK_BTN_3, KEY_VOICECOMMAND); in mt8188_headset_codec_init()
770 snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_PLAYPAUSE); in mt8188_headset_codec_init()
771 snd_jack_set_key(jack->jack, SND_JACK_BTN_1, KEY_VOICECOMMAND); in mt8188_headset_codec_init()
772 snd_jack_set_key(jack->jack, SND_JACK_BTN_2, KEY_VOLUMEUP); in mt8188_headset_codec_init()
773 snd_jack_set_key(jack->jack, SND_JACK_BTN_3, KEY_VOLUMEDOWN); in mt8188_headset_codec_init()
779 dev_err(rtd->dev, "Headset Jack call-back failed: %d\n", ret); in mt8188_headset_codec_init()
788 struct snd_soc_component *component = snd_soc_rtd_to_codec(rtd, 0)->component; in mt8188_headset_codec_exit()
809 dev_err(codec_dai->dev, "can't set BCLK clock %d\n", ret); in mt8188_nau8825_hw_params()
817 dev_err(codec_dai->dev, "can't set BCLK: %d\n", ret); in mt8188_nau8825_hw_params()
832 struct snd_soc_card *card = rtd->card; in mt8188_rt5682s_i2s_hw_params()
841 dev_err(card->dev, "invalid bit width: %d\n", bitwidth); in mt8188_rt5682s_i2s_hw_params()
847 dev_err(card->dev, "failed to set tdm slot\n"); in mt8188_rt5682s_i2s_hw_params()
854 dev_err(card->dev, "failed to set pll\n"); in mt8188_rt5682s_i2s_hw_params()
861 dev_err(card->dev, "failed to set sysclk\n"); in mt8188_rt5682s_i2s_hw_params()
881 for_each_card_rtds(rtd->card, runtime) { in mt8188_sof_be_hw_params()
887 if (cmpnt_afe && !pm_runtime_active(cmpnt_afe->dev)) { in mt8188_sof_be_hw_params()
888 dev_err(rtd->dev, "afe pm runtime is not active!!\n"); in mt8188_sof_be_hw_params()
889 return -EINVAL; in mt8188_sof_be_hw_params()
911 dev_err(codec_dai->dev, "can't set MCLK %d\n", ret); in mt8188_es8326_hw_params()
1226 struct mtk_platform_card_data *card_data = soc_card_data->card_data; in mt8188_fixup_controls()
1229 if (card_data->flags & (NAU8825_HS_PRESENT | RT5682S_HS_PRESENT | ES8326_HS_PRESENT)) { in mt8188_fixup_controls()
1233 if (strcmp(w->name, "Headphone")) in mt8188_fixup_controls()
1239 kctl = snd_ctl_find_id_mixer(card->snd_card, "Headphone Switch"); in mt8188_fixup_controls()
1241 snd_ctl_remove(card->snd_card, kctl); in mt8188_fixup_controls()
1243 dev_warn(card->dev, "Cannot find ctl : Headphone Switch\n"); in mt8188_fixup_controls()
1262 struct mtk_platform_card_data *card_data = soc_card_data->card_data; in mt8188_mt6359_soc_card_probe()
1263 struct snd_soc_card *card = soc_card_data->card_data->card; in mt8188_mt6359_soc_card_probe()
1274 return -EINVAL; in mt8188_mt6359_soc_card_probe()
1277 if (strcmp(dai_link->name, "DPTX_BE") == 0) { in mt8188_mt6359_soc_card_probe()
1278 if (dai_link->num_codecs && in mt8188_mt6359_soc_card_probe()
1279 strcmp(dai_link->codecs->dai_name, "snd-soc-dummy-dai")) in mt8188_mt6359_soc_card_probe()
1280 dai_link->init = mt8188_dptx_codec_init; in mt8188_mt6359_soc_card_probe()
1281 } else if (strcmp(dai_link->name, "ETDM3_OUT_BE") == 0) { in mt8188_mt6359_soc_card_probe()
1282 if (dai_link->num_codecs && in mt8188_mt6359_soc_card_probe()
1283 strcmp(dai_link->codecs->dai_name, "snd-soc-dummy-dai")) in mt8188_mt6359_soc_card_probe()
1284 dai_link->init = mt8188_hdmi_codec_init; in mt8188_mt6359_soc_card_probe()
1285 } else if (strcmp(dai_link->name, "DL_SRC_BE") == 0 || in mt8188_mt6359_soc_card_probe()
1286 strcmp(dai_link->name, "UL_SRC_BE") == 0) { in mt8188_mt6359_soc_card_probe()
1288 dai_link->init = mt8188_mt6359_init; in mt8188_mt6359_soc_card_probe()
1291 } else if (strcmp(dai_link->name, "ETDM1_OUT_BE") == 0 || in mt8188_mt6359_soc_card_probe()
1292 strcmp(dai_link->name, "ETDM2_OUT_BE") == 0 || in mt8188_mt6359_soc_card_probe()
1293 strcmp(dai_link->name, "ETDM1_IN_BE") == 0 || in mt8188_mt6359_soc_card_probe()
1294 strcmp(dai_link->name, "ETDM2_IN_BE") == 0) { in mt8188_mt6359_soc_card_probe()
1295 if (!dai_link->num_codecs) in mt8188_mt6359_soc_card_probe()
1298 if (!strcmp(dai_link->codecs->dai_name, MAX98390_CODEC_DAI)) { in mt8188_mt6359_soc_card_probe()
1304 if (!(card_data->flags & MAX98390_TWO_AMP)) { in mt8188_mt6359_soc_card_probe()
1305 dai_link->ops = &mt8188_max98390_ops; in mt8188_mt6359_soc_card_probe()
1308 dai_link->init = mt8188_max98390_codec_init; in mt8188_mt6359_soc_card_probe()
1311 } else if (!strcmp(dai_link->codecs->dai_name, NAU8825_CODEC_DAI)) { in mt8188_mt6359_soc_card_probe()
1312 dai_link->ops = &mt8188_nau8825_ops; in mt8188_mt6359_soc_card_probe()
1314 dai_link->init = mt8188_headset_codec_init; in mt8188_mt6359_soc_card_probe()
1315 dai_link->exit = mt8188_headset_codec_exit; in mt8188_mt6359_soc_card_probe()
1318 } else if (!strcmp(dai_link->codecs->dai_name, RT5682S_CODEC_DAI)) { in mt8188_mt6359_soc_card_probe()
1319 dai_link->ops = &mt8188_rt5682s_i2s_ops; in mt8188_mt6359_soc_card_probe()
1321 dai_link->init = mt8188_headset_codec_init; in mt8188_mt6359_soc_card_probe()
1322 dai_link->exit = mt8188_headset_codec_exit; in mt8188_mt6359_soc_card_probe()
1325 } else if (!strcmp(dai_link->codecs->dai_name, ES8326_CODEC_DAI)) { in mt8188_mt6359_soc_card_probe()
1326 dai_link->ops = &mt8188_es8326_ops; in mt8188_mt6359_soc_card_probe()
1328 dai_link->init = mt8188_headset_codec_init; in mt8188_mt6359_soc_card_probe()
1329 dai_link->exit = mt8188_headset_codec_exit; in mt8188_mt6359_soc_card_probe()
1333 if (strcmp(dai_link->codecs->dai_name, "snd-soc-dummy-dai")) { in mt8188_mt6359_soc_card_probe()
1335 dai_link->init = mt8188_dumb_amp_init; in mt8188_mt6359_soc_card_probe()
1395 { .compatible = "mediatek,mt8188-mt6359-evb", .data = &mt8188_evb_card, },
1396 { .compatible = "mediatek,mt8188-nau8825", .data = &mt8188_nau8825_card, },
1397 { .compatible = "mediatek,mt8188-rt5682s", .data = &mt8188_rt5682s_card, },
1398 { .compatible = "mediatek,mt8188-es8326", .data = &mt8188_es8326_card, },
1415 MODULE_DESCRIPTION("MT8188-MT6359 ALSA SoC machine driver");
1418 MODULE_ALIAS("mt8188 mt6359 soc card");