Symbol: adau1372
sound/soc/codecs/adau1372.c
576
struct adau1372 *adau1372 = snd_soc_dai_get_drvdata(dai);
sound/soc/codecs/adau1372.c
582
adau1372->clock_provider = true;
sound/soc/codecs/adau1372.c
586
adau1372->clock_provider = false;
sound/soc/codecs/adau1372.c
630
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI0, ADAU1372_SAI0_DELAY_MASK, sai0);
sound/soc/codecs/adau1372.c
631
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI1,
sound/soc/codecs/adau1372.c
641
struct adau1372 *adau1372 = snd_soc_dai_get_drvdata(dai);
sound/soc/codecs/adau1372.c
657
slot_width = adau1372->slot_width;
sound/soc/codecs/adau1372.c
673
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI0, ADAU1372_SAI0_FS_MASK, sai0);
sound/soc/codecs/adau1372.c
674
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI1, ADAU1372_SAI1_BCLKRATE, sai1);
sound/soc/codecs/adau1372.c
682
struct adau1372 *adau1372 = snd_soc_dai_get_drvdata(dai);
sound/soc/codecs/adau1372.c
688
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI0,
sound/soc/codecs/adau1372.c
690
adau1372->rate_constraints.mask = ADAU1372_RATE_MASK_TDM2;
sound/soc/codecs/adau1372.c
691
adau1372->slot_width = 0;
sound/soc/codecs/adau1372.c
714
adau1372->rate_constraints.mask = ADAU1372_RATE_MASK_TDM2;
sound/soc/codecs/adau1372.c
718
if (adau1372->clock_provider)
sound/soc/codecs/adau1372.c
719
adau1372->rate_constraints.mask = ADAU1372_RATE_MASK_TDM4_MASTER;
sound/soc/codecs/adau1372.c
721
adau1372->rate_constraints.mask = ADAU1372_RATE_MASK_TDM4;
sound/soc/codecs/adau1372.c
725
adau1372->rate_constraints.mask = ADAU1372_RATE_MASK_TDM8;
sound/soc/codecs/adau1372.c
731
adau1372->slot_width = width;
sound/soc/codecs/adau1372.c
733
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI0, ADAU1372_SAI0_SAI_MASK, sai0);
sound/soc/codecs/adau1372.c
734
regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI1, ADAU1372_SAI1_BCLK_TDMC, sai1);
sound/soc/codecs/adau1372.c
737
regmap_write(adau1372->regmap, ADAU1372_REG_SOUT_CTRL, ~tx_mask);
sound/soc/codecs/adau1372.c
744
struct adau1372 *adau1372 = snd_soc_dai_get_drvdata(dai);
sound/soc/codecs/adau1372.c
752
return regmap_update_bits(adau1372->regmap, ADAU1372_REG_SAI1, ADAU1372_SAI1_TDM_TS, sai1);
sound/soc/codecs/adau1372.c
757
struct adau1372 *adau1372 = snd_soc_dai_get_drvdata(dai);
sound/soc/codecs/adau1372.c
760
&adau1372->rate_constraints);
sound/soc/codecs/adau1372.c
765
static int adau1372_enable_pll(struct adau1372 *adau1372)
sound/soc/codecs/adau1372.c
770
regmap_update_bits(adau1372->regmap, ADAU1372_REG_CLK_CTRL,
sound/soc/codecs/adau1372.c
775
ret = regmap_read(adau1372->regmap, ADAU1372_REG_PLL(5), &val);
sound/soc/codecs/adau1372.c
782
dev_err(adau1372->dev, "Failed to lock PLL\n");
sound/soc/codecs/adau1372.c
789
static int adau1372_set_power(struct adau1372 *adau1372, bool enable)
sound/soc/codecs/adau1372.c
791
if (adau1372->enabled == enable)
sound/soc/codecs/adau1372.c
798
ret = clk_prepare_enable(adau1372->mclk);
sound/soc/codecs/adau1372.c
801
if (adau1372->pd_gpio)
sound/soc/codecs/adau1372.c
802
gpiod_set_value(adau1372->pd_gpio, 0);
sound/soc/codecs/adau1372.c
804
if (adau1372->switch_mode)
sound/soc/codecs/adau1372.c
805
adau1372->switch_mode(adau1372->dev);
sound/soc/codecs/adau1372.c
807
regcache_cache_only(adau1372->regmap, false);
sound/soc/codecs/adau1372.c
813
if (adau1372->use_pll) {
sound/soc/codecs/adau1372.c
814
ret = adau1372_enable_pll(adau1372);
sound/soc/codecs/adau1372.c
816
regcache_cache_only(adau1372->regmap, true);
sound/soc/codecs/adau1372.c
817
if (adau1372->pd_gpio)
sound/soc/codecs/adau1372.c
818
gpiod_set_value(adau1372->pd_gpio, 1);
sound/soc/codecs/adau1372.c
819
clk_disable_unprepare(adau1372->mclk);
sound/soc/codecs/adau1372.c
825
regmap_update_bits(adau1372->regmap, ADAU1372_REG_CLK_CTRL,
sound/soc/codecs/adau1372.c
827
regcache_sync(adau1372->regmap);
sound/soc/codecs/adau1372.c
829
if (adau1372->pd_gpio) {
sound/soc/codecs/adau1372.c
835
gpiod_set_value(adau1372->pd_gpio, 1);
sound/soc/codecs/adau1372.c
836
regcache_mark_dirty(adau1372->regmap);
sound/soc/codecs/adau1372.c
838
regmap_update_bits(adau1372->regmap, ADAU1372_REG_CLK_CTRL,
sound/soc/codecs/adau1372.c
841
clk_disable_unprepare(adau1372->mclk);
sound/soc/codecs/adau1372.c
842
regcache_cache_only(adau1372->regmap, true);
sound/soc/codecs/adau1372.c
845
adau1372->enabled = enable;
sound/soc/codecs/adau1372.c
853
struct adau1372 *adau1372 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/adau1372.c
861
return adau1372_set_power(adau1372, true);
sound/soc/codecs/adau1372.c
863
return adau1372_set_power(adau1372, false);
sound/soc/codecs/adau1372.c
914
static int adau1372_setup_pll(struct adau1372 *adau1372, unsigned int rate)
sound/soc/codecs/adau1372.c
925
regmap_write(adau1372->regmap, ADAU1372_REG_PLL(i), regs[i]);
sound/soc/codecs/adau1372.c
933
struct adau1372 *adau1372;
sound/soc/codecs/adau1372.c
941
adau1372 = devm_kzalloc(dev, sizeof(*adau1372), GFP_KERNEL);
sound/soc/codecs/adau1372.c
942
if (!adau1372)
sound/soc/codecs/adau1372.c
945
adau1372->mclk = devm_clk_get(dev, "mclk");
sound/soc/codecs/adau1372.c
946
if (IS_ERR(adau1372->mclk))
sound/soc/codecs/adau1372.c
947
return PTR_ERR(adau1372->mclk);
sound/soc/codecs/adau1372.c
949
adau1372->pd_gpio = devm_gpiod_get_optional(dev, "powerdown", GPIOD_OUT_HIGH);
sound/soc/codecs/adau1372.c
950
if (IS_ERR(adau1372->pd_gpio))
sound/soc/codecs/adau1372.c
951
return PTR_ERR(adau1372->pd_gpio);
sound/soc/codecs/adau1372.c
953
adau1372->regmap = regmap;
sound/soc/codecs/adau1372.c
954
adau1372->switch_mode = switch_mode;
sound/soc/codecs/adau1372.c
955
adau1372->dev = dev;
sound/soc/codecs/adau1372.c
956
adau1372->rate_constraints.list = adau1372_rates;
sound/soc/codecs/adau1372.c
957
adau1372->rate_constraints.count = ARRAY_SIZE(adau1372_rates);
sound/soc/codecs/adau1372.c
958
adau1372->rate_constraints.mask = ADAU1372_RATE_MASK_TDM2;
sound/soc/codecs/adau1372.c
960
dev_set_drvdata(dev, adau1372);
sound/soc/codecs/adau1372.c
967
rate = clk_get_rate(adau1372->mclk);
sound/soc/codecs/adau1372.c
978
ret = adau1372_setup_pll(adau1372, rate);
sound/soc/codecs/adau1372.c
981
adau1372->use_pll = true;