Lines Matching +full:boost +full:- +full:bypass
2 * wm8990.c -- WM8990 ALSA Soc Audio driver
50 { 1, 0x0000 }, /* R1 - Power Management (1) */
51 { 2, 0x6000 }, /* R2 - Power Management (2) */
52 { 3, 0x0000 }, /* R3 - Power Management (3) */
53 { 4, 0x4050 }, /* R4 - Audio Interface (1) */
54 { 5, 0x4000 }, /* R5 - Audio Interface (2) */
55 { 6, 0x01C8 }, /* R6 - Clocking (1) */
56 { 7, 0x0000 }, /* R7 - Clocking (2) */
57 { 8, 0x0040 }, /* R8 - Audio Interface (3) */
58 { 9, 0x0040 }, /* R9 - Audio Interface (4) */
59 { 10, 0x0004 }, /* R10 - DAC CTRL */
60 { 11, 0x00C0 }, /* R11 - Left DAC Digital Volume */
61 { 12, 0x00C0 }, /* R12 - Right DAC Digital Volume */
62 { 13, 0x0000 }, /* R13 - Digital Side Tone */
63 { 14, 0x0100 }, /* R14 - ADC CTRL */
64 { 15, 0x00C0 }, /* R15 - Left ADC Digital Volume */
65 { 16, 0x00C0 }, /* R16 - Right ADC Digital Volume */
67 { 18, 0x0000 }, /* R18 - GPIO CTRL 1 */
68 { 19, 0x1000 }, /* R19 - GPIO1 & GPIO2 */
69 { 20, 0x1010 }, /* R20 - GPIO3 & GPIO4 */
70 { 21, 0x1010 }, /* R21 - GPIO5 & GPIO6 */
71 { 22, 0x8000 }, /* R22 - GPIOCTRL 2 */
72 { 23, 0x0800 }, /* R23 - GPIO_POL */
73 { 24, 0x008B }, /* R24 - Left Line Input 1&2 Volume */
74 { 25, 0x008B }, /* R25 - Left Line Input 3&4 Volume */
75 { 26, 0x008B }, /* R26 - Right Line Input 1&2 Volume */
76 { 27, 0x008B }, /* R27 - Right Line Input 3&4 Volume */
77 { 28, 0x0000 }, /* R28 - Left Output Volume */
78 { 29, 0x0000 }, /* R29 - Right Output Volume */
79 { 30, 0x0066 }, /* R30 - Line Outputs Volume */
80 { 31, 0x0022 }, /* R31 - Out3/4 Volume */
81 { 32, 0x0079 }, /* R32 - Left OPGA Volume */
82 { 33, 0x0079 }, /* R33 - Right OPGA Volume */
83 { 34, 0x0003 }, /* R34 - Speaker Volume */
84 { 35, 0x0003 }, /* R35 - ClassD1 */
86 { 37, 0x0100 }, /* R37 - ClassD3 */
87 { 38, 0x0079 }, /* R38 - ClassD4 */
88 { 39, 0x0000 }, /* R39 - Input Mixer1 */
89 { 40, 0x0000 }, /* R40 - Input Mixer2 */
90 { 41, 0x0000 }, /* R41 - Input Mixer3 */
91 { 42, 0x0000 }, /* R42 - Input Mixer4 */
92 { 43, 0x0000 }, /* R43 - Input Mixer5 */
93 { 44, 0x0000 }, /* R44 - Input Mixer6 */
94 { 45, 0x0000 }, /* R45 - Output Mixer1 */
95 { 46, 0x0000 }, /* R46 - Output Mixer2 */
96 { 47, 0x0000 }, /* R47 - Output Mixer3 */
97 { 48, 0x0000 }, /* R48 - Output Mixer4 */
98 { 49, 0x0000 }, /* R49 - Output Mixer5 */
99 { 50, 0x0000 }, /* R50 - Output Mixer6 */
100 { 51, 0x0180 }, /* R51 - Out3/4 Mixer */
101 { 52, 0x0000 }, /* R52 - Line Mixer1 */
102 { 53, 0x0000 }, /* R53 - Line Mixer2 */
103 { 54, 0x0000 }, /* R54 - Speaker Mixer */
104 { 55, 0x0000 }, /* R55 - Additional Control */
105 { 56, 0x0000 }, /* R56 - AntiPOP1 */
106 { 57, 0x0000 }, /* R57 - AntiPOP2 */
107 { 58, 0x0000 }, /* R58 - MICBIAS */
109 { 60, 0x0008 }, /* R60 - PLL1 */
110 { 61, 0x0031 }, /* R61 - PLL2 */
111 { 62, 0x0026 }, /* R62 - PLL3 */
116 static const DECLARE_TLV_DB_SCALE(rec_mix_tlv, -1500, 600, 0);
118 static const DECLARE_TLV_DB_SCALE(in_pga_tlv, -1650, 3000, 0);
120 static const DECLARE_TLV_DB_SCALE(out_mix_tlv, 0, -2100, 0);
122 static const DECLARE_TLV_DB_SCALE(out_pga_tlv, -7300, 600, 0);
124 static const DECLARE_TLV_DB_SCALE(out_omix_tlv, -600, 0, 0);
126 static const DECLARE_TLV_DB_SCALE(out_dac_tlv, -7163, 0, 0);
128 static const DECLARE_TLV_DB_SCALE(in_adc_tlv, -7163, 1763, 0);
130 static const DECLARE_TLV_DB_SCALE(out_sidetone_tlv, -3600, 0, 0);
137 (struct soc_mixer_control *)kcontrol->private_value; in wm899x_outpga_put_volsw_vu()
138 int reg = mc->reg; in wm899x_outpga_put_volsw_vu()
171 {"Hi-fi mode", "Voice mode 1", "Voice mode 2", "Voice mode 3"};
180 SOC_SINGLE("LIN12 PGA Boost", WM8990_INPUT_MIXER3, WM8990_L12MNBST_BIT, 1, 0),
181 SOC_SINGLE("LIN34 PGA Boost", WM8990_INPUT_MIXER3, WM8990_L34MNBST_BIT, 1, 0),
183 SOC_SINGLE("RIN12 PGA Boost", WM8990_INPUT_MIXER3, WM8990_R12MNBST_BIT, 1, 0),
184 SOC_SINGLE("RIN34 PGA Boost", WM8990_INPUT_MIXER3, WM8990_R34MNBST_BIT, 1, 0),
187 SOC_SINGLE_TLV("LOMIX LIN3 Bypass Volume", WM8990_OUTPUT_MIXER3,
189 SOC_SINGLE_TLV("LOMIX RIN12 PGA Bypass Volume", WM8990_OUTPUT_MIXER3,
191 SOC_SINGLE_TLV("LOMIX LIN12 PGA Bypass Volume", WM8990_OUTPUT_MIXER3,
193 SOC_SINGLE_TLV("LOMIX RIN3 Bypass Volume", WM8990_OUTPUT_MIXER5,
195 SOC_SINGLE_TLV("LOMIX AINRMUX Bypass Volume", WM8990_OUTPUT_MIXER5,
197 SOC_SINGLE_TLV("LOMIX AINLMUX Bypass Volume", WM8990_OUTPUT_MIXER5,
201 SOC_SINGLE_TLV("ROMIX RIN3 Bypass Volume", WM8990_OUTPUT_MIXER4,
203 SOC_SINGLE_TLV("ROMIX LIN12 PGA Bypass Volume", WM8990_OUTPUT_MIXER4,
205 SOC_SINGLE_TLV("ROMIX RIN12 PGA Bypass Volume", WM8990_OUTPUT_MIXER4,
207 SOC_SINGLE_TLV("ROMIX LIN3 Bypass Volume", WM8990_OUTPUT_MIXER6,
209 SOC_SINGLE_TLV("ROMIX AINLMUX Bypass Volume", WM8990_OUTPUT_MIXER6,
211 SOC_SINGLE_TLV("ROMIX AINRMUX Bypass Volume", WM8990_OUTPUT_MIXER6,
264 SOC_SINGLE("Speaker DC Boost Volume", WM8990_CLASSD3,
266 SOC_SINGLE("Speaker AC Boost Volume", WM8990_CLASSD3,
377 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in outmixer_event()
378 u32 reg_shift = kcontrol->private_value & 0xfff; in outmixer_event()
388 ret = -1; in outmixer_event()
396 ret = -1; in outmixer_event()
404 ret = -1; in outmixer_event()
412 ret = -1; in outmixer_event()
421 static const DECLARE_TLV_DB_SCALE(in_mix_tlv, -1200, 600, 0);
503 SOC_DAPM_SINGLE("LOMIX Right ADC Bypass Switch", WM8990_OUTPUT_MIXER1,
505 SOC_DAPM_SINGLE("LOMIX Left ADC Bypass Switch", WM8990_OUTPUT_MIXER1,
507 SOC_DAPM_SINGLE("LOMIX RIN3 Bypass Switch", WM8990_OUTPUT_MIXER1,
509 SOC_DAPM_SINGLE("LOMIX LIN3 Bypass Switch", WM8990_OUTPUT_MIXER1,
511 SOC_DAPM_SINGLE("LOMIX RIN12 PGA Bypass Switch", WM8990_OUTPUT_MIXER1,
513 SOC_DAPM_SINGLE("LOMIX LIN12 PGA Bypass Switch", WM8990_OUTPUT_MIXER1,
521 SOC_DAPM_SINGLE("ROMIX Left ADC Bypass Switch", WM8990_OUTPUT_MIXER2,
523 SOC_DAPM_SINGLE("ROMIX Right ADC Bypass Switch", WM8990_OUTPUT_MIXER2,
525 SOC_DAPM_SINGLE("ROMIX LIN3 Bypass Switch", WM8990_OUTPUT_MIXER2,
527 SOC_DAPM_SINGLE("ROMIX RIN3 Bypass Switch", WM8990_OUTPUT_MIXER2,
529 SOC_DAPM_SINGLE("ROMIX LIN12 PGA Bypass Switch", WM8990_OUTPUT_MIXER2,
531 SOC_DAPM_SINGLE("ROMIX RIN12 PGA Bypass Switch", WM8990_OUTPUT_MIXER2,
549 SOC_DAPM_SINGLE("LOPMIX Right Mic Bypass Switch", WM8990_LINE_MIXER1,
551 SOC_DAPM_SINGLE("LOPMIX Left Mic Bypass Switch", WM8990_LINE_MIXER1,
569 SOC_DAPM_SINGLE("ROPMIX Left Mic Bypass Switch", WM8990_LINE_MIXER2,
571 SOC_DAPM_SINGLE("ROPMIX Right Mic Bypass Switch", WM8990_LINE_MIXER2,
579 SOC_DAPM_SINGLE("OUT3MIX LIN4/RXP Bypass Switch", WM8990_OUT3_4_MIXER,
589 SOC_DAPM_SINGLE("OUT4MIX RIN4/RXP Bypass Switch", WM8990_OUT3_4_MIXER,
595 SOC_DAPM_SINGLE("SPKMIX LIN2 Bypass Switch", WM8990_SPEAKER_MIXER,
597 SOC_DAPM_SINGLE("SPKMIX LADC Bypass Switch", WM8990_SPEAKER_MIXER,
607 SOC_DAPM_SINGLE("SPKMIX RADC Bypass Switch", WM8990_SPEAKER_MIXER,
609 SOC_DAPM_SINGLE("SPKMIX RIN2 Bypass Switch", WM8990_SPEAKER_MIXER,
812 {"LOMIX", "LOMIX RIN3 Bypass Switch", "RIN3"},
813 {"LOMIX", "LOMIX LIN3 Bypass Switch", "LIN3"},
814 {"LOMIX", "LOMIX LIN12 PGA Bypass Switch", "LIN12 PGA"},
815 {"LOMIX", "LOMIX RIN12 PGA Bypass Switch", "RIN12 PGA"},
816 {"LOMIX", "LOMIX Right ADC Bypass Switch", "AINRMUX"},
817 {"LOMIX", "LOMIX Left ADC Bypass Switch", "AINLMUX"},
821 {"ROMIX", "ROMIX RIN3 Bypass Switch", "RIN3"},
822 {"ROMIX", "ROMIX LIN3 Bypass Switch", "LIN3"},
823 {"ROMIX", "ROMIX LIN12 PGA Bypass Switch", "LIN12 PGA"},
824 {"ROMIX", "ROMIX RIN12 PGA Bypass Switch", "RIN12 PGA"},
825 {"ROMIX", "ROMIX Right ADC Bypass Switch", "AINRMUX"},
826 {"ROMIX", "ROMIX Left ADC Bypass Switch", "AINLMUX"},
830 {"SPKMIX", "SPKMIX LIN2 Bypass Switch", "LIN2"},
831 {"SPKMIX", "SPKMIX RIN2 Bypass Switch", "RIN2"},
832 {"SPKMIX", "SPKMIX LADC Bypass Switch", "AINLMUX"},
833 {"SPKMIX", "SPKMIX RADC Bypass Switch", "AINRMUX"},
845 {"LOPMIX", "LOPMIX Right Mic Bypass Switch", "RIN12 PGA"},
846 {"LOPMIX", "LOPMIX Left Mic Bypass Switch", "LIN12 PGA"},
850 {"OUT3MIX", "OUT3MIX LIN4/RXP Bypass Switch", "LIN4/RXN"},
855 {"OUT4MIX", "OUT4MIX RIN4/RXP Bypass Switch", "RIN4/RXP"},
863 {"ROPMIX", "ROPMIX Left Mic Bypass Switch", "LIN12 PGA"},
864 {"ROPMIX", "ROPMIX Right Mic Bypass Switch", "RIN12 PGA"},
907 pll_div->div2 = 1; in pll_factors()
910 pll_div->div2 = 0; in pll_factors()
916 pll_div->n = Ndiv; in pll_factors()
931 pll_div->k = K; in pll_factors()
937 struct snd_soc_component *component = codec_dai->component; in wm8990_set_dai_pll()
951 /* set up N , fractional mode and pre-divisor if necessary */ in wm8990_set_dai_pll()
970 struct snd_soc_component *component = codec_dai->component; in wm8990_set_dai_sysclk()
973 wm8990->sysclk = freq; in wm8990_set_dai_sysclk()
983 struct snd_soc_component *component = codec_dai->component; in wm8990_set_dai_fmt()
998 return -EINVAL; in wm8990_set_dai_fmt()
1025 return -EINVAL; in wm8990_set_dai_fmt()
1036 struct snd_soc_component *component = codec_dai->component; in wm8990_set_dai_clkdiv()
1056 return -EINVAL; in wm8990_set_dai_clkdiv()
1069 struct snd_soc_component *component = dai->component; in wm8990_hw_params()
1094 struct snd_soc_component *component = dai->component; in wm8990_mute()
1125 ret = regcache_sync(wm8990->regmap); in wm8990_set_bias_level()
1127 dev_err(component->dev, "Failed to sync cache: %d\n", ret); in wm8990_set_bias_level()
1223 regcache_mark_dirty(wm8990->regmap); in wm8990_set_bias_level()
1255 .name = "wm8990-hifi",
1330 wm8990 = devm_kzalloc(&i2c->dev, sizeof(struct wm8990_priv), in wm8990_i2c_probe()
1333 return -ENOMEM; in wm8990_i2c_probe()
1337 ret = devm_snd_soc_register_component(&i2c->dev, in wm8990_i2c_probe()