aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brown <broonie@kernel.org>2015-01-15 06:57:23 -0500
committerMark Brown <broonie@kernel.org>2015-01-15 06:57:23 -0500
commit5f7201d5d6738790bf8179083e7a92347f1c4a23 (patch)
tree0822b83df5931892bfb0b1328e904d4fcb5452f8
parent8eee1468eebdcef3e094bb8abc846fa101a9a961 (diff)
parent9913b9f549330e9b72945ec94cb9c7fe57d78cce (diff)
Merge branch 'topic/rt5677' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into asoc-w-codec
-rw-r--r--include/sound/rt5677.h3
-rw-r--r--sound/soc/codecs/rt5677.c219
2 files changed, 202 insertions, 20 deletions
diff --git a/include/sound/rt5677.h b/include/sound/rt5677.h
index d9eb7d861cd0..a6207043ac3c 100644
--- a/include/sound/rt5677.h
+++ b/include/sound/rt5677.h
@@ -37,6 +37,9 @@ struct rt5677_platform_data {
37 OFF, GPIO4, GPIO5 and GPIO6 respectively */ 37 OFF, GPIO4, GPIO5 and GPIO6 respectively */
38 unsigned int jd2_gpio; 38 unsigned int jd2_gpio;
39 unsigned int jd3_gpio; 39 unsigned int jd3_gpio;
40
41 /* Set MICBIAS1 VDD 1v8 or 3v3 */
42 bool micbias1_vdd_3v3;
40}; 43};
41 44
42#endif 45#endif
diff --git a/sound/soc/codecs/rt5677.c b/sound/soc/codecs/rt5677.c
index 81fe1464d268..88de759fb7fc 100644
--- a/sound/soc/codecs/rt5677.c
+++ b/sound/soc/codecs/rt5677.c
@@ -921,6 +921,101 @@ static int is_sys_clk_from_pll(struct snd_soc_dapm_widget *source,
921 return 0; 921 return 0;
922} 922}
923 923
924static int is_using_asrc(struct snd_soc_dapm_widget *source,
925 struct snd_soc_dapm_widget *sink)
926{
927 struct snd_soc_codec *codec = source->codec;
928 struct rt5677_priv *rt5677 = snd_soc_codec_get_drvdata(codec);
929 unsigned int reg, shift, val;
930
931 if (source->reg == RT5677_ASRC_1) {
932 switch (source->shift) {
933 case 12:
934 reg = RT5677_ASRC_4;
935 shift = 0;
936 break;
937 case 13:
938 reg = RT5677_ASRC_4;
939 shift = 4;
940 break;
941 case 14:
942 reg = RT5677_ASRC_4;
943 shift = 8;
944 break;
945 case 15:
946 reg = RT5677_ASRC_4;
947 shift = 12;
948 break;
949 default:
950 return 0;
951 }
952 } else {
953 switch (source->shift) {
954 case 0:
955 reg = RT5677_ASRC_6;
956 shift = 8;
957 break;
958 case 1:
959 reg = RT5677_ASRC_6;
960 shift = 12;
961 break;
962 case 2:
963 reg = RT5677_ASRC_5;
964 shift = 0;
965 break;
966 case 3:
967 reg = RT5677_ASRC_5;
968 shift = 4;
969 break;
970 case 4:
971 reg = RT5677_ASRC_5;
972 shift = 8;
973 break;
974 case 5:
975 reg = RT5677_ASRC_5;
976 shift = 12;
977 break;
978 case 12:
979 reg = RT5677_ASRC_3;
980 shift = 0;
981 break;
982 case 13:
983 reg = RT5677_ASRC_3;
984 shift = 4;
985 break;
986 case 14:
987 reg = RT5677_ASRC_3;
988 shift = 12;
989 break;
990 default:
991 return 0;
992 }
993 }
994
995 regmap_read(rt5677->regmap, reg, &val);
996 val = (val >> shift) & 0xf;
997
998 switch (val) {
999 case 1 ... 6:
1000 return 1;
1001 default:
1002 return 0;
1003 }
1004
1005}
1006
1007static int can_use_asrc(struct snd_soc_dapm_widget *source,
1008 struct snd_soc_dapm_widget *sink)
1009{
1010 struct snd_soc_codec *codec = snd_soc_dapm_to_codec(source->dapm);
1011 struct rt5677_priv *rt5677 = snd_soc_codec_get_drvdata(codec);
1012
1013 if (rt5677->sysclk > rt5677->lrck[RT5677_AIF1] * 384)
1014 return 1;
1015
1016 return 0;
1017}
1018
924/* Digital Mixer */ 1019/* Digital Mixer */
925static const struct snd_kcontrol_new rt5677_sto1_adc_l_mix[] = { 1020static const struct snd_kcontrol_new rt5677_sto1_adc_l_mix[] = {
926 SOC_DAPM_SINGLE("ADC1 Switch", RT5677_STO1_ADC_MIXER, 1021 SOC_DAPM_SINGLE("ADC1 Switch", RT5677_STO1_ADC_MIXER,
@@ -2215,6 +2310,45 @@ static const struct snd_soc_dapm_widget rt5677_dapm_widgets[] = {
2215 SND_SOC_DAPM_SUPPLY("PLL2", RT5677_PWR_ANLG2, RT5677_PWR_PLL2_BIT, 2310 SND_SOC_DAPM_SUPPLY("PLL2", RT5677_PWR_ANLG2, RT5677_PWR_PLL2_BIT,
2216 0, rt5677_set_pll2_event, SND_SOC_DAPM_POST_PMU), 2311 0, rt5677_set_pll2_event, SND_SOC_DAPM_POST_PMU),
2217 2312
2313 /* ASRC */
2314 SND_SOC_DAPM_SUPPLY_S("I2S1 ASRC", 1, RT5677_ASRC_1, 0, 0, NULL, 0),
2315 SND_SOC_DAPM_SUPPLY_S("I2S2 ASRC", 1, RT5677_ASRC_1, 1, 0, NULL, 0),
2316 SND_SOC_DAPM_SUPPLY_S("I2S3 ASRC", 1, RT5677_ASRC_1, 2, 0, NULL, 0),
2317 SND_SOC_DAPM_SUPPLY_S("I2S4 ASRC", 1, RT5677_ASRC_1, 3, 0, NULL, 0),
2318 SND_SOC_DAPM_SUPPLY_S("DAC STO ASRC", 1, RT5677_ASRC_2, 14, 0, NULL, 0),
2319 SND_SOC_DAPM_SUPPLY_S("DAC MONO2 L ASRC", 1, RT5677_ASRC_2, 13, 0, NULL,
2320 0),
2321 SND_SOC_DAPM_SUPPLY_S("DAC MONO2 R ASRC", 1, RT5677_ASRC_2, 12, 0, NULL,
2322 0),
2323 SND_SOC_DAPM_SUPPLY_S("DAC MONO3 L ASRC", 1, RT5677_ASRC_1, 15, 0, NULL,
2324 0),
2325 SND_SOC_DAPM_SUPPLY_S("DAC MONO3 R ASRC", 1, RT5677_ASRC_1, 14, 0, NULL,
2326 0),
2327 SND_SOC_DAPM_SUPPLY_S("DAC MONO4 L ASRC", 1, RT5677_ASRC_1, 13, 0, NULL,
2328 0),
2329 SND_SOC_DAPM_SUPPLY_S("DAC MONO4 R ASRC", 1, RT5677_ASRC_1, 12, 0, NULL,
2330 0),
2331 SND_SOC_DAPM_SUPPLY_S("DMIC STO1 ASRC", 1, RT5677_ASRC_2, 11, 0, NULL,
2332 0),
2333 SND_SOC_DAPM_SUPPLY_S("DMIC STO2 ASRC", 1, RT5677_ASRC_2, 10, 0, NULL,
2334 0),
2335 SND_SOC_DAPM_SUPPLY_S("DMIC STO3 ASRC", 1, RT5677_ASRC_2, 9, 0, NULL,
2336 0),
2337 SND_SOC_DAPM_SUPPLY_S("DMIC STO4 ASRC", 1, RT5677_ASRC_2, 8, 0, NULL,
2338 0),
2339 SND_SOC_DAPM_SUPPLY_S("DMIC MONO L ASRC", 1, RT5677_ASRC_2, 7, 0, NULL,
2340 0),
2341 SND_SOC_DAPM_SUPPLY_S("DMIC MONO R ASRC", 1, RT5677_ASRC_2, 6, 0, NULL,
2342 0),
2343 SND_SOC_DAPM_SUPPLY_S("ADC STO1 ASRC", 1, RT5677_ASRC_2, 5, 0, NULL, 0),
2344 SND_SOC_DAPM_SUPPLY_S("ADC STO2 ASRC", 1, RT5677_ASRC_2, 4, 0, NULL, 0),
2345 SND_SOC_DAPM_SUPPLY_S("ADC STO3 ASRC", 1, RT5677_ASRC_2, 3, 0, NULL, 0),
2346 SND_SOC_DAPM_SUPPLY_S("ADC STO4 ASRC", 1, RT5677_ASRC_2, 2, 0, NULL, 0),
2347 SND_SOC_DAPM_SUPPLY_S("ADC MONO L ASRC", 1, RT5677_ASRC_2, 1, 0, NULL,
2348 0),
2349 SND_SOC_DAPM_SUPPLY_S("ADC MONO R ASRC", 1, RT5677_ASRC_2, 0, 0, NULL,
2350 0),
2351
2218 /* Input Side */ 2352 /* Input Side */
2219 /* micbias */ 2353 /* micbias */
2220 SND_SOC_DAPM_SUPPLY("MICBIAS1", RT5677_PWR_ANLG2, RT5677_PWR_MB1_BIT, 2354 SND_SOC_DAPM_SUPPLY("MICBIAS1", RT5677_PWR_ANLG2, RT5677_PWR_MB1_BIT,
@@ -2645,10 +2779,18 @@ static const struct snd_soc_dapm_widget rt5677_dapm_widgets[] = {
2645 /* DAC Mixer */ 2779 /* DAC Mixer */
2646 SND_SOC_DAPM_SUPPLY("dac stereo1 filter", RT5677_PWR_DIG2, 2780 SND_SOC_DAPM_SUPPLY("dac stereo1 filter", RT5677_PWR_DIG2,
2647 RT5677_PWR_DAC_S1F_BIT, 0, NULL, 0), 2781 RT5677_PWR_DAC_S1F_BIT, 0, NULL, 0),
2648 SND_SOC_DAPM_SUPPLY("dac mono left filter", RT5677_PWR_DIG2, 2782 SND_SOC_DAPM_SUPPLY("dac mono2 left filter", RT5677_PWR_DIG2,
2649 RT5677_PWR_DAC_M2F_L_BIT, 0, NULL, 0), 2783 RT5677_PWR_DAC_M2F_L_BIT, 0, NULL, 0),
2650 SND_SOC_DAPM_SUPPLY("dac mono right filter", RT5677_PWR_DIG2, 2784 SND_SOC_DAPM_SUPPLY("dac mono2 right filter", RT5677_PWR_DIG2,
2651 RT5677_PWR_DAC_M2F_R_BIT, 0, NULL, 0), 2785 RT5677_PWR_DAC_M2F_R_BIT, 0, NULL, 0),
2786 SND_SOC_DAPM_SUPPLY("dac mono3 left filter", RT5677_PWR_DIG2,
2787 RT5677_PWR_DAC_M3F_L_BIT, 0, NULL, 0),
2788 SND_SOC_DAPM_SUPPLY("dac mono3 right filter", RT5677_PWR_DIG2,
2789 RT5677_PWR_DAC_M3F_R_BIT, 0, NULL, 0),
2790 SND_SOC_DAPM_SUPPLY("dac mono4 left filter", RT5677_PWR_DIG2,
2791 RT5677_PWR_DAC_M4F_L_BIT, 0, NULL, 0),
2792 SND_SOC_DAPM_SUPPLY("dac mono4 right filter", RT5677_PWR_DIG2,
2793 RT5677_PWR_DAC_M4F_R_BIT, 0, NULL, 0),
2652 2794
2653 SND_SOC_DAPM_MIXER("Stereo DAC MIXL", SND_SOC_NOPM, 0, 0, 2795 SND_SOC_DAPM_MIXER("Stereo DAC MIXL", SND_SOC_NOPM, 0, 0,
2654 rt5677_sto1_dac_l_mix, ARRAY_SIZE(rt5677_sto1_dac_l_mix)), 2796 rt5677_sto1_dac_l_mix, ARRAY_SIZE(rt5677_sto1_dac_l_mix)),
@@ -2721,6 +2863,31 @@ static const struct snd_soc_dapm_widget rt5677_dapm_widgets[] = {
2721}; 2863};
2722 2864
2723static const struct snd_soc_dapm_route rt5677_dapm_routes[] = { 2865static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
2866 { "Stereo1 DMIC Mux", NULL, "DMIC STO1 ASRC", can_use_asrc },
2867 { "Stereo2 DMIC Mux", NULL, "DMIC STO2 ASRC", can_use_asrc },
2868 { "Stereo3 DMIC Mux", NULL, "DMIC STO3 ASRC", can_use_asrc },
2869 { "Stereo4 DMIC Mux", NULL, "DMIC STO4 ASRC", can_use_asrc },
2870 { "Mono DMIC L Mux", NULL, "DMIC MONO L ASRC", can_use_asrc },
2871 { "Mono DMIC R Mux", NULL, "DMIC MONO R ASRC", can_use_asrc },
2872 { "I2S1", NULL, "I2S1 ASRC", can_use_asrc},
2873 { "I2S2", NULL, "I2S2 ASRC", can_use_asrc},
2874 { "I2S3", NULL, "I2S3 ASRC", can_use_asrc},
2875 { "I2S4", NULL, "I2S4 ASRC", can_use_asrc},
2876
2877 { "dac stereo1 filter", NULL, "DAC STO ASRC", is_using_asrc },
2878 { "dac mono2 left filter", NULL, "DAC MONO2 L ASRC", is_using_asrc },
2879 { "dac mono2 right filter", NULL, "DAC MONO2 R ASRC", is_using_asrc },
2880 { "dac mono3 left filter", NULL, "DAC MONO3 L ASRC", is_using_asrc },
2881 { "dac mono3 right filter", NULL, "DAC MONO3 R ASRC", is_using_asrc },
2882 { "dac mono4 left filter", NULL, "DAC MONO4 L ASRC", is_using_asrc },
2883 { "dac mono4 right filter", NULL, "DAC MONO4 R ASRC", is_using_asrc },
2884 { "adc stereo1 filter", NULL, "ADC STO1 ASRC", is_using_asrc },
2885 { "adc stereo2 filter", NULL, "ADC STO2 ASRC", is_using_asrc },
2886 { "adc stereo3 filter", NULL, "ADC STO3 ASRC", is_using_asrc },
2887 { "adc stereo4 filter", NULL, "ADC STO4 ASRC", is_using_asrc },
2888 { "adc mono left filter", NULL, "ADC MONO L ASRC", is_using_asrc },
2889 { "adc mono right filter", NULL, "ADC MONO R ASRC", is_using_asrc },
2890
2724 { "DMIC1", NULL, "DMIC L1" }, 2891 { "DMIC1", NULL, "DMIC L1" },
2725 { "DMIC1", NULL, "DMIC R1" }, 2892 { "DMIC1", NULL, "DMIC R1" },
2726 { "DMIC2", NULL, "DMIC L2" }, 2893 { "DMIC2", NULL, "DMIC L2" },
@@ -2851,8 +3018,6 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
2851 3018
2852 { "Stereo1 ADC MIXL", NULL, "Sto1 ADC MIXL" }, 3019 { "Stereo1 ADC MIXL", NULL, "Sto1 ADC MIXL" },
2853 { "Stereo1 ADC MIXL", NULL, "adc stereo1 filter" }, 3020 { "Stereo1 ADC MIXL", NULL, "adc stereo1 filter" },
2854 { "adc stereo1 filter", NULL, "PLL1", is_sys_clk_from_pll },
2855
2856 { "Stereo1 ADC MIXR", NULL, "Sto1 ADC MIXR" }, 3021 { "Stereo1 ADC MIXR", NULL, "Sto1 ADC MIXR" },
2857 { "Stereo1 ADC MIXR", NULL, "adc stereo1 filter" }, 3022 { "Stereo1 ADC MIXR", NULL, "adc stereo1 filter" },
2858 { "adc stereo1 filter", NULL, "PLL1", is_sys_clk_from_pll }, 3023 { "adc stereo1 filter", NULL, "PLL1", is_sys_clk_from_pll },
@@ -2873,8 +3038,6 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
2873 3038
2874 { "Stereo2 ADC MIXL", NULL, "Stereo2 ADC LR Mux" }, 3039 { "Stereo2 ADC MIXL", NULL, "Stereo2 ADC LR Mux" },
2875 { "Stereo2 ADC MIXL", NULL, "adc stereo2 filter" }, 3040 { "Stereo2 ADC MIXL", NULL, "adc stereo2 filter" },
2876 { "adc stereo2 filter", NULL, "PLL1", is_sys_clk_from_pll },
2877
2878 { "Stereo2 ADC MIXR", NULL, "Sto2 ADC MIXR" }, 3041 { "Stereo2 ADC MIXR", NULL, "Sto2 ADC MIXR" },
2879 { "Stereo2 ADC MIXR", NULL, "adc stereo2 filter" }, 3042 { "Stereo2 ADC MIXR", NULL, "adc stereo2 filter" },
2880 { "adc stereo2 filter", NULL, "PLL1", is_sys_clk_from_pll }, 3043 { "adc stereo2 filter", NULL, "PLL1", is_sys_clk_from_pll },
@@ -2889,8 +3052,6 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
2889 3052
2890 { "Stereo3 ADC MIXL", NULL, "Sto3 ADC MIXL" }, 3053 { "Stereo3 ADC MIXL", NULL, "Sto3 ADC MIXL" },
2891 { "Stereo3 ADC MIXL", NULL, "adc stereo3 filter" }, 3054 { "Stereo3 ADC MIXL", NULL, "adc stereo3 filter" },
2892 { "adc stereo3 filter", NULL, "PLL1", is_sys_clk_from_pll },
2893
2894 { "Stereo3 ADC MIXR", NULL, "Sto3 ADC MIXR" }, 3055 { "Stereo3 ADC MIXR", NULL, "Sto3 ADC MIXR" },
2895 { "Stereo3 ADC MIXR", NULL, "adc stereo3 filter" }, 3056 { "Stereo3 ADC MIXR", NULL, "adc stereo3 filter" },
2896 { "adc stereo3 filter", NULL, "PLL1", is_sys_clk_from_pll }, 3057 { "adc stereo3 filter", NULL, "PLL1", is_sys_clk_from_pll },
@@ -2905,8 +3066,6 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
2905 3066
2906 { "Stereo4 ADC MIXL", NULL, "Sto4 ADC MIXL" }, 3067 { "Stereo4 ADC MIXL", NULL, "Sto4 ADC MIXL" },
2907 { "Stereo4 ADC MIXL", NULL, "adc stereo4 filter" }, 3068 { "Stereo4 ADC MIXL", NULL, "adc stereo4 filter" },
2908 { "adc stereo4 filter", NULL, "PLL1", is_sys_clk_from_pll },
2909
2910 { "Stereo4 ADC MIXR", NULL, "Sto4 ADC MIXR" }, 3069 { "Stereo4 ADC MIXR", NULL, "Sto4 ADC MIXR" },
2911 { "Stereo4 ADC MIXR", NULL, "adc stereo4 filter" }, 3070 { "Stereo4 ADC MIXR", NULL, "adc stereo4 filter" },
2912 { "adc stereo4 filter", NULL, "PLL1", is_sys_clk_from_pll }, 3071 { "adc stereo4 filter", NULL, "PLL1", is_sys_clk_from_pll },
@@ -3455,10 +3614,8 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
3455 3614
3456 { "DAC1 MIXL", "Stereo ADC Switch", "ADDA1 Mux" }, 3615 { "DAC1 MIXL", "Stereo ADC Switch", "ADDA1 Mux" },
3457 { "DAC1 MIXL", "DAC1 Switch", "DAC1 Mux" }, 3616 { "DAC1 MIXL", "DAC1 Switch", "DAC1 Mux" },
3458 { "DAC1 MIXL", NULL, "dac stereo1 filter" },
3459 { "DAC1 MIXR", "Stereo ADC Switch", "ADDA1 Mux" }, 3617 { "DAC1 MIXR", "Stereo ADC Switch", "ADDA1 Mux" },
3460 { "DAC1 MIXR", "DAC1 Switch", "DAC1 Mux" }, 3618 { "DAC1 MIXR", "DAC1 Switch", "DAC1 Mux" },
3461 { "DAC1 MIXR", NULL, "dac stereo1 filter" },
3462 3619
3463 { "DAC1 FS", NULL, "DAC1 MIXL" }, 3620 { "DAC1 FS", NULL, "DAC1 MIXL" },
3464 { "DAC1 FS", NULL, "DAC1 MIXR" }, 3621 { "DAC1 FS", NULL, "DAC1 MIXR" },
@@ -3525,35 +3682,46 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
3525 { "Stereo DAC MIXR", "DAC2 R Switch", "DAC2 R Mux" }, 3682 { "Stereo DAC MIXR", "DAC2 R Switch", "DAC2 R Mux" },
3526 { "Stereo DAC MIXR", "DAC1 L Switch", "DAC1 MIXL" }, 3683 { "Stereo DAC MIXR", "DAC1 L Switch", "DAC1 MIXL" },
3527 { "Stereo DAC MIXR", NULL, "dac stereo1 filter" }, 3684 { "Stereo DAC MIXR", NULL, "dac stereo1 filter" },
3685 { "dac stereo1 filter", NULL, "PLL1", is_sys_clk_from_pll },
3528 3686
3529 { "Mono DAC MIXL", "ST L Switch", "Sidetone Mux" }, 3687 { "Mono DAC MIXL", "ST L Switch", "Sidetone Mux" },
3530 { "Mono DAC MIXL", "DAC1 L Switch", "DAC1 MIXL" }, 3688 { "Mono DAC MIXL", "DAC1 L Switch", "DAC1 MIXL" },
3531 { "Mono DAC MIXL", "DAC2 L Switch", "DAC2 L Mux" }, 3689 { "Mono DAC MIXL", "DAC2 L Switch", "DAC2 L Mux" },
3532 { "Mono DAC MIXL", "DAC2 R Switch", "DAC2 R Mux" }, 3690 { "Mono DAC MIXL", "DAC2 R Switch", "DAC2 R Mux" },
3533 { "Mono DAC MIXL", NULL, "dac mono left filter" }, 3691 { "Mono DAC MIXL", NULL, "dac mono2 left filter" },
3692 { "dac mono2 left filter", NULL, "PLL1", is_sys_clk_from_pll },
3534 { "Mono DAC MIXR", "ST R Switch", "Sidetone Mux" }, 3693 { "Mono DAC MIXR", "ST R Switch", "Sidetone Mux" },
3535 { "Mono DAC MIXR", "DAC1 R Switch", "DAC1 MIXR" }, 3694 { "Mono DAC MIXR", "DAC1 R Switch", "DAC1 MIXR" },
3536 { "Mono DAC MIXR", "DAC2 R Switch", "DAC2 R Mux" }, 3695 { "Mono DAC MIXR", "DAC2 R Switch", "DAC2 R Mux" },
3537 { "Mono DAC MIXR", "DAC2 L Switch", "DAC2 L Mux" }, 3696 { "Mono DAC MIXR", "DAC2 L Switch", "DAC2 L Mux" },
3538 { "Mono DAC MIXR", NULL, "dac mono right filter" }, 3697 { "Mono DAC MIXR", NULL, "dac mono2 right filter" },
3698 { "dac mono2 right filter", NULL, "PLL1", is_sys_clk_from_pll },
3539 3699
3540 { "DD1 MIXL", "Sto DAC Mix L Switch", "Stereo DAC MIXL" }, 3700 { "DD1 MIXL", "Sto DAC Mix L Switch", "Stereo DAC MIXL" },
3541 { "DD1 MIXL", "Mono DAC Mix L Switch", "Mono DAC MIXL" }, 3701 { "DD1 MIXL", "Mono DAC Mix L Switch", "Mono DAC MIXL" },
3542 { "DD1 MIXL", "DAC3 L Switch", "DAC3 L Mux" }, 3702 { "DD1 MIXL", "DAC3 L Switch", "DAC3 L Mux" },
3543 { "DD1 MIXL", "DAC3 R Switch", "DAC3 R Mux" }, 3703 { "DD1 MIXL", "DAC3 R Switch", "DAC3 R Mux" },
3704 { "DD1 MIXL", NULL, "dac mono3 left filter" },
3705 { "dac mono3 left filter", NULL, "PLL1", is_sys_clk_from_pll },
3544 { "DD1 MIXR", "Sto DAC Mix R Switch", "Stereo DAC MIXR" }, 3706 { "DD1 MIXR", "Sto DAC Mix R Switch", "Stereo DAC MIXR" },
3545 { "DD1 MIXR", "Mono DAC Mix R Switch", "Mono DAC MIXR" }, 3707 { "DD1 MIXR", "Mono DAC Mix R Switch", "Mono DAC MIXR" },
3546 { "DD1 MIXR", "DAC3 L Switch", "DAC3 L Mux" }, 3708 { "DD1 MIXR", "DAC3 L Switch", "DAC3 L Mux" },
3547 { "DD1 MIXR", "DAC3 R Switch", "DAC3 R Mux" }, 3709 { "DD1 MIXR", "DAC3 R Switch", "DAC3 R Mux" },
3710 { "DD1 MIXR", NULL, "dac mono3 right filter" },
3711 { "dac mono3 right filter", NULL, "PLL1", is_sys_clk_from_pll },
3548 3712
3549 { "DD2 MIXL", "Sto DAC Mix L Switch", "Stereo DAC MIXL" }, 3713 { "DD2 MIXL", "Sto DAC Mix L Switch", "Stereo DAC MIXL" },
3550 { "DD2 MIXL", "Mono DAC Mix L Switch", "Mono DAC MIXL" }, 3714 { "DD2 MIXL", "Mono DAC Mix L Switch", "Mono DAC MIXL" },
3551 { "DD2 MIXL", "DAC4 L Switch", "DAC4 L Mux" }, 3715 { "DD2 MIXL", "DAC4 L Switch", "DAC4 L Mux" },
3552 { "DD2 MIXL", "DAC4 R Switch", "DAC4 R Mux" }, 3716 { "DD2 MIXL", "DAC4 R Switch", "DAC4 R Mux" },
3717 { "DD2 MIXL", NULL, "dac mono4 left filter" },
3718 { "dac mono4 left filter", NULL, "PLL1", is_sys_clk_from_pll },
3553 { "DD2 MIXR", "Sto DAC Mix R Switch", "Stereo DAC MIXR" }, 3719 { "DD2 MIXR", "Sto DAC Mix R Switch", "Stereo DAC MIXR" },
3554 { "DD2 MIXR", "Mono DAC Mix R Switch", "Mono DAC MIXR" }, 3720 { "DD2 MIXR", "Mono DAC Mix R Switch", "Mono DAC MIXR" },
3555 { "DD2 MIXR", "DAC4 L Switch", "DAC4 L Mux" }, 3721 { "DD2 MIXR", "DAC4 L Switch", "DAC4 L Mux" },
3556 { "DD2 MIXR", "DAC4 R Switch", "DAC4 R Mux" }, 3722 { "DD2 MIXR", "DAC4 R Switch", "DAC4 R Mux" },
3723 { "DD2 MIXR", NULL, "dac mono4 right filter" },
3724 { "dac mono4 right filter", NULL, "PLL1", is_sys_clk_from_pll },
3557 3725
3558 { "Stereo DAC MIX", NULL, "Stereo DAC MIXL" }, 3726 { "Stereo DAC MIX", NULL, "Stereo DAC MIXL" },
3559 { "Stereo DAC MIX", NULL, "Stereo DAC MIXR" }, 3727 { "Stereo DAC MIX", NULL, "Stereo DAC MIXR" },
@@ -3575,11 +3743,8 @@ static const struct snd_soc_dapm_route rt5677_dapm_routes[] = {
3575 { "DAC3 SRC Mux", "DD MIX2L", "DD2 MIXL" }, 3743 { "DAC3 SRC Mux", "DD MIX2L", "DD2 MIXL" },
3576 3744
3577 { "DAC 1", NULL, "DAC12 SRC Mux" }, 3745 { "DAC 1", NULL, "DAC12 SRC Mux" },
3578 { "DAC 1", NULL, "PLL1", is_sys_clk_from_pll },
3579 { "DAC 2", NULL, "DAC12 SRC Mux" }, 3746 { "DAC 2", NULL, "DAC12 SRC Mux" },
3580 { "DAC 2", NULL, "PLL1", is_sys_clk_from_pll },
3581 { "DAC 3", NULL, "DAC3 SRC Mux" }, 3747 { "DAC 3", NULL, "DAC3 SRC Mux" },
3582 { "DAC 3", NULL, "PLL1", is_sys_clk_from_pll },
3583 3748
3584 { "PDM1 L Mux", "STO1 DAC MIX", "Stereo DAC MIXL" }, 3749 { "PDM1 L Mux", "STO1 DAC MIX", "Stereo DAC MIXL" },
3585 { "PDM1 L Mux", "MONO DAC MIX", "Mono DAC MIXL" }, 3750 { "PDM1 L Mux", "MONO DAC MIX", "Mono DAC MIXL" },
@@ -3926,7 +4091,8 @@ static int rt5677_set_tdm_slot(struct snd_soc_dai *dai, unsigned int tx_mask,
3926 unsigned int rx_mask, int slots, int slot_width) 4091 unsigned int rx_mask, int slots, int slot_width)
3927{ 4092{
3928 struct snd_soc_codec *codec = dai->codec; 4093 struct snd_soc_codec *codec = dai->codec;
3929 unsigned int val = 0; 4094 struct rt5677_priv *rt5677 = snd_soc_codec_get_drvdata(codec);
4095 unsigned int val = 0, slot_width_25 = 0;
3930 4096
3931 if (rx_mask || tx_mask) 4097 if (rx_mask || tx_mask)
3932 val |= (1 << 12); 4098 val |= (1 << 12);
@@ -3950,6 +4116,8 @@ static int rt5677_set_tdm_slot(struct snd_soc_dai *dai, unsigned int tx_mask,
3950 case 20: 4116 case 20:
3951 val |= (1 << 8); 4117 val |= (1 << 8);
3952 break; 4118 break;
4119 case 25:
4120 slot_width_25 = 0x8080;
3953 case 24: 4121 case 24:
3954 val |= (2 << 8); 4122 val |= (2 << 8);
3955 break; 4123 break;
@@ -3963,10 +4131,16 @@ static int rt5677_set_tdm_slot(struct snd_soc_dai *dai, unsigned int tx_mask,
3963 4131
3964 switch (dai->id) { 4132 switch (dai->id) {
3965 case RT5677_AIF1: 4133 case RT5677_AIF1:
3966 snd_soc_update_bits(codec, RT5677_TDM1_CTRL1, 0x1f00, val); 4134 regmap_update_bits(rt5677->regmap, RT5677_TDM1_CTRL1, 0x1f00,
4135 val);
4136 regmap_update_bits(rt5677->regmap, RT5677_DIG_MISC, 0x8000,
4137 slot_width_25);
3967 break; 4138 break;
3968 case RT5677_AIF2: 4139 case RT5677_AIF2:
3969 snd_soc_update_bits(codec, RT5677_TDM2_CTRL1, 0x1f00, val); 4140 regmap_update_bits(rt5677->regmap, RT5677_TDM2_CTRL1, 0x1f00,
4141 val);
4142 regmap_update_bits(rt5677->regmap, RT5677_DIG_MISC, 0x80,
4143 slot_width_25);
3970 break; 4144 break;
3971 default: 4145 default:
3972 break; 4146 break;
@@ -4751,6 +4925,11 @@ static int rt5677_i2c_probe(struct i2c_client *i2c,
4751 RT5677_GPIO5_DIR_OUT); 4925 RT5677_GPIO5_DIR_OUT);
4752 } 4926 }
4753 4927
4928 if (rt5677->pdata.micbias1_vdd_3v3)
4929 regmap_update_bits(rt5677->regmap, RT5677_MICBIAS,
4930 RT5677_MICBIAS1_CTRL_VDD_MASK,
4931 RT5677_MICBIAS1_CTRL_VDD_3_3V);
4932
4754 rt5677_init_gpio(i2c); 4933 rt5677_init_gpio(i2c);
4755 rt5677_init_irq(i2c); 4934 rt5677_init_irq(i2c);
4756 4935