Lines Matching +full:rates +full:- +full:mcs

1 // SPDX-License-Identifier: GPL-2.0-only
6 * Author: Lars-Peter Clausen <lars@metafoo.de>
26 #include <dt-bindings/sound/adi,adau1977.h>
157 static const DECLARE_TLV_DB_MINMAX_MUTE(adau1977_adc_gain, -3562, 6000);
197 ADAU1977_REG_POST_ADC_GAIN((x) - 1), \
201 SOC_SINGLE("ADC" #x " Highpass-Filter Capture Switch", \
202 ADAU1977_REG_DC_HPF_CAL, (x) - 1, 1, 0)
235 regcache_cache_bypass(adau1977->regmap, true); in adau1977_reset()
236 ret = regmap_write(adau1977->regmap, ADAU1977_REG_POWER, in adau1977_reset()
238 regcache_cache_bypass(adau1977->regmap, false); in adau1977_reset()
260 return -EINVAL; in adau1977_lookup_fs()
266 unsigned int mcs; in adau1977_lookup_mcs() local
269 * rate = sysclk / (512 * mcs_lut[mcs]) * 2**fs in adau1977_lookup_mcs()
270 * => mcs_lut[mcs] = sysclk / (512 * rate) * 2**fs in adau1977_lookup_mcs()
271 * => mcs_lut[mcs] = sysclk / ((512 / 2**fs) * rate) in adau1977_lookup_mcs()
276 if (adau1977->sysclk % rate != 0) in adau1977_lookup_mcs()
277 return -EINVAL; in adau1977_lookup_mcs()
279 mcs = adau1977->sysclk / rate; in adau1977_lookup_mcs()
281 /* The factors configured by MCS are 1, 2, 3, 4, 6 */ in adau1977_lookup_mcs()
282 if (mcs < 1 || mcs > 6 || mcs == 5) in adau1977_lookup_mcs()
283 return -EINVAL; in adau1977_lookup_mcs()
285 mcs = mcs - 1; in adau1977_lookup_mcs()
286 if (mcs == 5) in adau1977_lookup_mcs()
287 mcs = 4; in adau1977_lookup_mcs()
289 return mcs; in adau1977_lookup_mcs()
295 struct snd_soc_component *component = dai->component; in adau1977_hw_params()
301 int mcs, fs; in adau1977_hw_params() local
308 if (adau1977->sysclk_src == ADAU1977_SYSCLK_SRC_MCLK) { in adau1977_hw_params()
309 mcs = adau1977_lookup_mcs(adau1977, rate, fs); in adau1977_hw_params()
310 if (mcs < 0) in adau1977_hw_params()
311 return mcs; in adau1977_hw_params()
313 mcs = 0; in adau1977_hw_params()
319 if (adau1977->right_j) { in adau1977_hw_params()
328 return -EINVAL; in adau1977_hw_params()
333 if (adau1977->clock_provider) { in adau1977_hw_params()
345 return -EINVAL; in adau1977_hw_params()
349 if (adau1977->slot_width) in adau1977_hw_params()
350 slot_width = adau1977->slot_width; in adau1977_hw_params()
357 ret = regmap_update_bits(adau1977->regmap, in adau1977_hw_params()
366 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_CTRL0, in adau1977_hw_params()
371 return regmap_update_bits(adau1977->regmap, ADAU1977_REG_PLL, in adau1977_hw_params()
372 ADAU1977_PLL_MCS_MASK, mcs); in adau1977_hw_params()
379 if (!adau1977->enabled) in adau1977_power_disable()
382 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_POWER, in adau1977_power_disable()
387 regcache_mark_dirty(adau1977->regmap); in adau1977_power_disable()
389 gpiod_set_value_cansleep(adau1977->reset_gpio, 0); in adau1977_power_disable()
391 regcache_cache_only(adau1977->regmap, true); in adau1977_power_disable()
393 regulator_disable(adau1977->avdd_reg); in adau1977_power_disable()
394 if (adau1977->dvdd_reg) in adau1977_power_disable()
395 regulator_disable(adau1977->dvdd_reg); in adau1977_power_disable()
397 adau1977->enabled = false; in adau1977_power_disable()
407 if (adau1977->enabled) in adau1977_power_enable()
410 ret = regulator_enable(adau1977->avdd_reg); in adau1977_power_enable()
414 if (adau1977->dvdd_reg) { in adau1977_power_enable()
415 ret = regulator_enable(adau1977->dvdd_reg); in adau1977_power_enable()
420 gpiod_set_value_cansleep(adau1977->reset_gpio, 1); in adau1977_power_enable()
422 regcache_cache_only(adau1977->regmap, false); in adau1977_power_enable()
424 if (adau1977->switch_mode) in adau1977_power_enable()
425 adau1977->switch_mode(adau1977->dev); in adau1977_power_enable()
431 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_POWER, in adau1977_power_enable()
436 ret = regcache_sync(adau1977->regmap); in adau1977_power_enable()
447 ret = regmap_read(adau1977->regmap, ADAU1977_REG_PLL, &val); in adau1977_power_enable()
452 regcache_cache_bypass(adau1977->regmap, true); in adau1977_power_enable()
453 ret = regmap_write(adau1977->regmap, ADAU1977_REG_PLL, in adau1977_power_enable()
457 regcache_cache_bypass(adau1977->regmap, false); in adau1977_power_enable()
460 adau1977->enabled = true; in adau1977_power_enable()
465 if (adau1977->dvdd_reg) in adau1977_power_enable()
466 regulator_disable(adau1977->dvdd_reg); in adau1977_power_enable()
468 regulator_disable(adau1977->avdd_reg); in adau1977_power_enable()
498 struct adau1977 *adau1977 = snd_soc_component_get_drvdata(dai->component); in adau1977_set_tdm_slot()
506 adau1977->slot_width = 0; in adau1977_set_tdm_slot()
507 adau1977->max_clock_provider_fs = 192000; in adau1977_set_tdm_slot()
508 return regmap_update_bits(adau1977->regmap, in adau1977_set_tdm_slot()
514 return -EINVAL; in adau1977_set_tdm_slot()
522 return -EINVAL; in adau1977_set_tdm_slot()
528 return -EINVAL; in adau1977_set_tdm_slot()
536 if (adau1977->clock_provider) in adau1977_set_tdm_slot()
537 return -EINVAL; in adau1977_set_tdm_slot()
544 return -EINVAL; in adau1977_set_tdm_slot()
561 return -EINVAL; in adau1977_set_tdm_slot()
564 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_OVERTEMP, in adau1977_set_tdm_slot()
572 ret = regmap_write(adau1977->regmap, ADAU1977_REG_CMAP12, in adau1977_set_tdm_slot()
578 ret = regmap_write(adau1977->regmap, ADAU1977_REG_CMAP34, in adau1977_set_tdm_slot()
584 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_CTRL0, in adau1977_set_tdm_slot()
589 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_CTRL1, in adau1977_set_tdm_slot()
594 adau1977->slot_width = width; in adau1977_set_tdm_slot()
597 adau1977->max_clock_provider_fs = min(192000, 24576000 / width / slots); in adau1977_set_tdm_slot()
604 struct adau1977 *adau1977 = snd_soc_component_get_drvdata(dai->component); in adau1977_mute()
612 return regmap_update_bits(adau1977->regmap, ADAU1977_REG_MISC_CONTROL, in adau1977_mute()
618 struct adau1977 *adau1977 = snd_soc_component_get_drvdata(dai->component); in adau1977_set_dai_fmt()
625 adau1977->clock_provider = false; in adau1977_set_dai_fmt()
629 adau1977->clock_provider = true; in adau1977_set_dai_fmt()
632 return -EINVAL; in adau1977_set_dai_fmt()
651 return -EINVAL; in adau1977_set_dai_fmt()
654 adau1977->right_j = false; in adau1977_set_dai_fmt()
665 adau1977->right_j = true; in adau1977_set_dai_fmt()
679 return -EINVAL; in adau1977_set_dai_fmt()
685 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_BLOCK_POWER_SAI, in adau1977_set_dai_fmt()
691 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_CTRL0, in adau1977_set_dai_fmt()
697 return regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_CTRL1, in adau1977_set_dai_fmt()
705 struct adau1977 *adau1977 = snd_soc_component_get_drvdata(dai->component); in adau1977_startup()
708 if (adau1977->slot_width == 16) in adau1977_startup()
710 else if (adau1977->right_j || adau1977->slot_width == 24) in adau1977_startup()
714 snd_pcm_hw_constraint_list(substream->runtime, 0, in adau1977_startup()
715 SNDRV_PCM_HW_PARAM_RATE, &adau1977->constraints); in adau1977_startup()
717 if (adau1977->clock_provider) in adau1977_startup()
718 snd_pcm_hw_constraint_minmax(substream->runtime, in adau1977_startup()
720 adau1977->max_clock_provider_fs); in adau1977_startup()
723 snd_pcm_hw_constraint_mask64(substream->runtime, in adau1977_startup()
731 struct adau1977 *adau1977 = snd_soc_component_get_drvdata(dai->component); in adau1977_set_tristate()
739 return regmap_update_bits(adau1977->regmap, ADAU1977_REG_SAI_OVERTEMP, in adau1977_set_tristate()
753 .name = "adau1977-hifi",
758 .rates = SNDRV_PCM_RATE_KNOT,
775 /* All rates >= 32000 */
780 unsigned int mcs; in adau1977_check_sysclk() local
785 mcs = mclk / (128 * base_freq); in adau1977_check_sysclk()
786 if (mcs < 1 || mcs > 6 || mcs == 5) in adau1977_check_sysclk()
801 return -EINVAL; in adau1977_set_sysclk()
804 return -EINVAL; in adau1977_set_sysclk()
814 return -EINVAL; in adau1977_set_sysclk()
819 return -EINVAL; in adau1977_set_sysclk()
829 return -EINVAL; in adau1977_set_sysclk()
834 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_PLL, in adau1977_set_sysclk()
839 adau1977->constraints.mask = mask; in adau1977_set_sysclk()
840 adau1977->sysclk_src = source; in adau1977_set_sysclk()
841 adau1977->sysclk = freq; in adau1977_set_sysclk()
852 switch (adau1977->type) { in adau1977_component_probe()
885 if (device_property_read_u32(adau1977->dev, "adi,micbias", &micbias)) in adau1977_setup_micbias()
889 dev_err(adau1977->dev, "Invalid value for 'adi,micbias'\n"); in adau1977_setup_micbias()
890 return -EINVAL; in adau1977_setup_micbias()
893 return regmap_update_bits(adau1977->regmap, ADAU1977_REG_MICBIAS, in adau1977_setup_micbias()
910 return -ENOMEM; in adau1977_probe()
912 adau1977->dev = dev; in adau1977_probe()
913 adau1977->type = type; in adau1977_probe()
914 adau1977->regmap = regmap; in adau1977_probe()
915 adau1977->switch_mode = switch_mode; in adau1977_probe()
916 adau1977->max_clock_provider_fs = 192000; in adau1977_probe()
918 adau1977->constraints.list = adau1977_rates; in adau1977_probe()
919 adau1977->constraints.count = ARRAY_SIZE(adau1977_rates); in adau1977_probe()
921 adau1977->avdd_reg = devm_regulator_get(dev, "AVDD"); in adau1977_probe()
922 if (IS_ERR(adau1977->avdd_reg)) in adau1977_probe()
923 return PTR_ERR(adau1977->avdd_reg); in adau1977_probe()
925 adau1977->dvdd_reg = devm_regulator_get_optional(dev, "DVDD"); in adau1977_probe()
926 if (IS_ERR(adau1977->dvdd_reg)) { in adau1977_probe()
927 if (PTR_ERR(adau1977->dvdd_reg) != -ENODEV) in adau1977_probe()
928 return PTR_ERR(adau1977->dvdd_reg); in adau1977_probe()
929 adau1977->dvdd_reg = NULL; in adau1977_probe()
932 adau1977->reset_gpio = devm_gpiod_get_optional(dev, "reset", in adau1977_probe()
934 if (IS_ERR(adau1977->reset_gpio)) in adau1977_probe()
935 return PTR_ERR(adau1977->reset_gpio); in adau1977_probe()
939 if (adau1977->reset_gpio) in adau1977_probe()
952 if (adau1977->dvdd_reg) in adau1977_probe()
957 ret = regmap_update_bits(adau1977->regmap, ADAU1977_REG_BLOCK_POWER_SAI, in adau1977_probe()
1001 MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");