Lines Matching +full:break +full:- +full:control

1 // SPDX-License-Identifier: GPL-2.0-only
3 * wm8940.c -- WM8940 ALSA Soc Audio driver
12 * Notch filter control
109 { 0x4, 0x0010 }, /* Interface Control */
110 { 0x5, 0x0000 }, /* Companding Control */
111 { 0x6, 0x0140 }, /* Clock Control */
113 { 0x8, 0x0000 }, /* GPIO Control */
114 { 0x9, 0x0002 }, /* Auto Increment Control */
115 { 0xa, 0x0000 }, /* DAC Control */
118 { 0xe, 0x0100 }, /* ADC Control */
120 { 0x10, 0x0000 }, /* Notch Filter 1 Control 1 */
121 { 0x11, 0x0000 }, /* Notch Filter 1 Control 2 */
122 { 0x12, 0x0000 }, /* Notch Filter 2 Control 1 */
123 { 0x13, 0x0000 }, /* Notch Filter 2 Control 2 */
124 { 0x14, 0x0000 }, /* Notch Filter 3 Control 1 */
125 { 0x15, 0x0000 }, /* Notch Filter 3 Control 2 */
126 { 0x16, 0x0000 }, /* Notch Filter 4 Control 1 */
127 { 0x17, 0x0000 }, /* Notch Filter 4 Control 2 */
128 { 0x18, 0x0032 }, /* DAC Limit Control 1 */
129 { 0x19, 0x0000 }, /* DAC Limit Control 2 */
131 { 0x20, 0x0038 }, /* ALC Control 1 */
132 { 0x21, 0x000B }, /* ALC Control 2 */
133 { 0x22, 0x0032 }, /* ALC Control 3 */
140 { 0x2a, 0x0030 }, /* ALC Control 4 */
142 { 0x2c, 0x0002 }, /* Input Control */
145 { 0x2f, 0x0002 }, /* ADC Boost Control */
147 { 0x31, 0x0002 }, /* Output Control */
148 { 0x32, 0x0000 }, /* Speaker Mixer Control */
152 { 0x38, 0x0000 }, /* Mono Mixer Control */
155 static const char *wm8940_companding[] = { "Off", "NC", "u-law", "A-law" };
173 static DECLARE_TLV_DB_SCALE(wm8940_spk_vol_tlv, -5700, 100, 1);
174 static DECLARE_TLV_DB_SCALE(wm8940_att_tlv, -1000, 1000, 0);
175 static DECLARE_TLV_DB_SCALE(wm8940_pga_vol_tlv, -1200, 75, 0);
176 static DECLARE_TLV_DB_SCALE(wm8940_alc_min_tlv, -1200, 600, 0);
178 static DECLARE_TLV_DB_SCALE(wm8940_alc_tar_tlv, -2250, 50, 0);
180 static DECLARE_TLV_DB_SCALE(wm8940_lim_thresh_tlv, -600, 100, 0);
181 static DECLARE_TLV_DB_SCALE(wm8940_adc_tlv, -12750, 50, 1);
258 static DECLARE_TLV_DB_SCALE(wm8940_boost_vol_tlv, -1500, 300, 1);
341 struct snd_soc_component *component = codec_dai->component; in wm8940_set_dai_fmt()
348 break; in wm8940_set_dai_fmt()
350 break; in wm8940_set_dai_fmt()
352 return -EINVAL; in wm8940_set_dai_fmt()
359 break; in wm8940_set_dai_fmt()
362 break; in wm8940_set_dai_fmt()
364 break; in wm8940_set_dai_fmt()
367 break; in wm8940_set_dai_fmt()
370 break; in wm8940_set_dai_fmt()
375 break; in wm8940_set_dai_fmt()
378 break; in wm8940_set_dai_fmt()
381 break; in wm8940_set_dai_fmt()
384 break; in wm8940_set_dai_fmt()
397 struct snd_soc_component *component = dai->component; in wm8940_i2s_hw_params()
405 priv->fs = params_rate(params); in wm8940_i2s_hw_params()
410 /* LoutR control */ in wm8940_i2s_hw_params()
411 if (substream->stream == SNDRV_PCM_STREAM_CAPTURE in wm8940_i2s_hw_params()
418 break; in wm8940_i2s_hw_params()
421 break; in wm8940_i2s_hw_params()
424 break; in wm8940_i2s_hw_params()
427 break; in wm8940_i2s_hw_params()
430 break; in wm8940_i2s_hw_params()
433 break; in wm8940_i2s_hw_params()
442 break; in wm8940_i2s_hw_params()
444 break; in wm8940_i2s_hw_params()
447 break; in wm8940_i2s_hw_params()
450 break; in wm8940_i2s_hw_params()
453 break; in wm8940_i2s_hw_params()
466 struct snd_soc_component *component = dai->component; in wm8940_mute()
491 break; in wm8940_set_bias_level()
494 break; in wm8940_set_bias_level()
499 break; in wm8940_set_bias_level()
502 ret = regcache_sync(wm8940->regmap); in wm8940_set_bias_level()
504 dev_err(component->dev, "Failed to sync cache: %d\n", ret); in wm8940_set_bias_level()
513 break; in wm8940_set_bias_level()
516 break; in wm8940_set_bias_level()
585 struct snd_soc_component *component = codec_dai->component; in wm8940_set_dai_pll()
626 struct snd_soc_component *component = codec_dai->component; in wm8940_set_dai_clkdiv()
634 break; in wm8940_set_dai_clkdiv()
638 break; in wm8940_set_dai_clkdiv()
642 break; in wm8940_set_dai_clkdiv()
681 struct snd_soc_component *codec = dai->component; in wm8940_update_clocks()
688 if (!priv->mclk || !priv->fs) in wm8940_update_clocks()
691 fs256 = 256 * priv->fs; in wm8940_update_clocks()
693 f = wm8940_get_mclkdiv(priv->mclk, fs256, &mclkdiv); in wm8940_update_clocks()
694 if (f != priv->mclk) { in wm8940_update_clocks()
699 wm8940_set_dai_pll(dai, 0, 0, priv->mclk, fpll); in wm8940_update_clocks()
708 struct snd_soc_component *codec = dai->component; in wm8940_set_dai_sysclk()
712 return -EINVAL; in wm8940_set_dai_sysclk()
714 priv->mclk = freq; in wm8940_set_dai_sysclk()
738 .name = "wm8940-hifi",
759 struct wm8940_setup_data *pdata = component->dev->platform_data; in wm8940_probe()
764 * Check chip ID for wm8940 - value of 0x00 offset in wm8940_probe()
770 dev_err(component->dev, "Wrong wm8940 chip ID: 0x%x\n", reg); in wm8940_probe()
771 return -ENODEV; in wm8940_probe()
776 dev_err(component->dev, "Failed to issue reset\n"); in wm8940_probe()
788 ret = snd_soc_component_write(component, WM8940_OUTPUTCTL, reg | pdata->vroi); in wm8940_probe()
829 wm8940 = devm_kzalloc(&i2c->dev, sizeof(struct wm8940_priv), in wm8940_i2c_probe()
832 return -ENOMEM; in wm8940_i2c_probe()
834 wm8940->regmap = devm_regmap_init_i2c(i2c, &wm8940_regmap); in wm8940_i2c_probe()
835 if (IS_ERR(wm8940->regmap)) in wm8940_i2c_probe()
836 return PTR_ERR(wm8940->regmap); in wm8940_i2c_probe()
840 ret = devm_snd_soc_register_component(&i2c->dev, in wm8940_i2c_probe()