Lines Matching +full:switch +full:- +full:freq +full:- +full:select

1 // SPDX-License-Identifier: GPL-2.0-or-later
7 * Author: Lars-Peter Clausen <lars@metafoo.de>
113 #define ADAV80X_PLL_OUTE_SYSCLKPD(x) BIT(2 - (x))
196 ADAV80X_MUX("Aux Capture Select", &adav80x_aux_capture_mux_ctrl),
197 ADAV80X_MUX("Capture Select", &adav80x_capture_mux_ctrl),
198 ADAV80X_MUX("DAC Select", &adav80x_dac_mux_ctrl),
214 struct snd_soc_component *component = snd_soc_dapm_to_component(source->dapm); in adav80x_dapm_sysclk_check()
218 switch (adav80x->clk_src) { in adav80x_dapm_sysclk_check()
238 struct snd_soc_component *component = snd_soc_dapm_to_component(source->dapm); in adav80x_dapm_pll_check()
241 return adav80x->pll_src == ADAV80X_PLL_SRC_XTAL; in adav80x_dapm_pll_check()
246 { "DAC Select", "ADC", "ADC" },
247 { "DAC Select", "Playback", "AIFIN" },
248 { "DAC Select", "Aux Playback", "AIFAUXIN" },
249 { "DAC", NULL, "DAC Select" },
251 { "Capture Select", "ADC", "ADC" },
252 { "Capture Select", "Playback", "AIFIN" },
253 { "Capture Select", "Aux Playback", "AIFAUXIN" },
254 { "AIFOUT", NULL, "Capture Select" },
256 { "Aux Capture Select", "ADC", "ADC" },
257 { "Aux Capture Select", "Playback", "AIFIN" },
258 { "Aux Capture Select", "Aux Playback", "AIFAUXIN" },
259 { "AIFAUXOUT", NULL, "Aux Capture Select" },
288 if (adav80x->deemph) { in adav80x_set_deemph()
289 switch (adav80x->rate) { in adav80x_set_deemph()
310 return regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL2, in adav80x_set_deemph()
319 unsigned int deemph = ucontrol->value.integer.value[0]; in adav80x_put_deemph()
322 return -EINVAL; in adav80x_put_deemph()
324 adav80x->deemph = deemph; in adav80x_put_deemph()
335 ucontrol->value.integer.value[0] = adav80x->deemph; in adav80x_get_deemph()
340 static const DECLARE_TLV_DB_MINMAX(adav80x_digital_tlv, -9563, 0);
351 SOC_DOUBLE("Master Playback Switch", ADAV80X_DAC_CTRL1, 0, 1, 1, 0),
352 SOC_DOUBLE("Master Capture Switch", ADAV80X_ADC_CTRL1, 2, 3, 1, 1),
354 SOC_SINGLE("ADC High Pass Filter Switch", ADAV80X_ADC_CTRL1, 6, 1, 0),
356 SOC_SINGLE_BOOL_EXT("Playback De-emphasis Switch", 0,
367 struct snd_soc_component *component = dai->component; in adav80x_set_dai_fmt()
372 switch (fmt & SND_SOC_DAIFMT_CLOCK_PROVIDER_MASK) { in adav80x_set_dai_fmt()
380 return -EINVAL; in adav80x_set_dai_fmt()
383 switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) { in adav80x_set_dai_fmt()
397 return -EINVAL; in adav80x_set_dai_fmt()
400 switch (fmt & SND_SOC_DAIFMT_INV_MASK) { in adav80x_set_dai_fmt()
404 return -EINVAL; in adav80x_set_dai_fmt()
407 regmap_update_bits(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][0], in adav80x_set_dai_fmt()
410 regmap_write(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][1], in adav80x_set_dai_fmt()
413 adav80x->dai_fmt[dai->id] = fmt & SND_SOC_DAIFMT_FORMAT_MASK; in adav80x_set_dai_fmt()
429 regmap_update_bits(adav80x->regmap, ADAV80X_ADC_CTRL1, in adav80x_set_adc_clock()
446 regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL2, in adav80x_set_dac_clock()
459 switch (params_width(params)) { in adav80x_set_capture_pcm_format()
473 return -EINVAL; in adav80x_set_capture_pcm_format()
476 regmap_update_bits(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][0], in adav80x_set_capture_pcm_format()
488 if (adav80x->dai_fmt[dai->id] != SND_SOC_DAIFMT_RIGHT_J) in adav80x_set_playback_pcm_format()
491 switch (params_width(params)) { in adav80x_set_playback_pcm_format()
505 return -EINVAL; in adav80x_set_playback_pcm_format()
508 regmap_update_bits(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][1], in adav80x_set_playback_pcm_format()
517 struct snd_soc_component *component = dai->component; in adav80x_hw_params()
521 if (rate * 256 != adav80x->sysclk) in adav80x_hw_params()
522 return -EINVAL; in adav80x_hw_params()
524 if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) { in adav80x_hw_params()
531 adav80x->rate = rate; in adav80x_hw_params()
539 unsigned int freq, int dir) in adav80x_set_sysclk() argument
545 switch (clk_id) { in adav80x_set_sysclk()
553 return -EINVAL; in adav80x_set_sysclk()
556 adav80x->sysclk = freq; in adav80x_set_sysclk()
558 if (adav80x->clk_src != clk_id) { in adav80x_set_sysclk()
561 adav80x->clk_src = clk_id; in adav80x_set_sysclk()
570 regmap_write(adav80x->regmap, ADAV80X_ICLK_CTRL1, in adav80x_set_sysclk()
572 regmap_write(adav80x->regmap, ADAV80X_ICLK_CTRL2, in adav80x_set_sysclk()
580 switch (clk_id) { in adav80x_set_sysclk()
586 return -EINVAL; in adav80x_set_sysclk()
589 clk_id -= ADAV80X_CLK_SYSCLK1; in adav80x_set_sysclk()
592 if (freq == 0) { in adav80x_set_sysclk()
593 regmap_update_bits(adav80x->regmap, ADAV80X_PLL_OUTE, in adav80x_set_sysclk()
595 adav80x->sysclk_pd[clk_id] = true; in adav80x_set_sysclk()
597 regmap_update_bits(adav80x->regmap, ADAV80X_PLL_OUTE, in adav80x_set_sysclk()
599 adav80x->sysclk_pd[clk_id] = false; in adav80x_set_sysclk()
604 if (adav80x->sysclk_pd[0]) in adav80x_set_sysclk()
609 if (adav80x->sysclk_pd[1] || adav80x->sysclk_pd[2]) in adav80x_set_sysclk()
631 switch (source) { in adav80x_set_pll()
637 return -EINVAL; in adav80x_set_pll()
643 switch (freq_in) { in adav80x_set_pll()
653 return -EINVAL; in adav80x_set_pll()
662 switch (freq_out) { in adav80x_set_pll()
673 return -EINVAL; in adav80x_set_pll()
676 regmap_update_bits(adav80x->regmap, ADAV80X_PLL_CTRL1, in adav80x_set_pll()
678 regmap_update_bits(adav80x->regmap, ADAV80X_PLL_CTRL2, in adav80x_set_pll()
681 if (source != adav80x->pll_src) { in adav80x_set_pll()
687 regmap_update_bits(adav80x->regmap, ADAV80X_PLL_CLK_SRC, in adav80x_set_pll()
690 adav80x->pll_src = source; in adav80x_set_pll()
704 switch (level) { in adav80x_set_bias_level()
710 regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL1, mask, in adav80x_set_bias_level()
714 regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL1, mask, in adav80x_set_bias_level()
726 struct snd_soc_component *component = dai->component; in adav80x_dai_startup()
729 if (!snd_soc_component_active(component) || !adav80x->rate) in adav80x_dai_startup()
732 return snd_pcm_hw_constraint_single(substream->runtime, in adav80x_dai_startup()
733 SNDRV_PCM_HW_PARAM_RATE, adav80x->rate); in adav80x_dai_startup()
739 struct snd_soc_component *component = dai->component; in adav80x_dai_shutdown()
743 adav80x->rate = 0; in adav80x_dai_shutdown()
764 .name = "adav80x-hifi",
783 .name = "adav80x-aux",
813 regmap_write(adav80x->regmap, ADAV80X_PLL_OUTE, 0x20); in adav80x_probe()
815 regmap_write(adav80x->regmap, ADAV80X_DAC_CTRL3, 0x6); in adav80x_probe()
824 regcache_sync(adav80x->regmap); in adav80x_resume()
856 return -ENOMEM; in adav80x_bus_probe()
859 adav80x->regmap = regmap; in adav80x_bus_probe()
880 MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");