diff options
| author | Mark Brown <broonie@kernel.org> | 2015-01-15 06:57:23 -0500 |
|---|---|---|
| committer | Mark Brown <broonie@kernel.org> | 2015-01-15 06:57:23 -0500 |
| commit | 5f7201d5d6738790bf8179083e7a92347f1c4a23 (patch) | |
| tree | 0822b83df5931892bfb0b1328e904d4fcb5452f8 | |
| parent | 8eee1468eebdcef3e094bb8abc846fa101a9a961 (diff) | |
| parent | 9913b9f549330e9b72945ec94cb9c7fe57d78cce (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.h | 3 | ||||
| -rw-r--r-- | sound/soc/codecs/rt5677.c | 219 |
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 | ||
| 924 | static 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 | |||
| 1007 | static 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 */ |
| 925 | static const struct snd_kcontrol_new rt5677_sto1_adc_l_mix[] = { | 1020 | static 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 | ||
| 2723 | static const struct snd_soc_dapm_route rt5677_dapm_routes[] = { | 2865 | static 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 | ||
