ASoC: cs42l43: Only restrict 44.1kHz for the ASP
authorCharles Keepax <ckeepax@opensource.cirrus.com>
Mon, 27 May 2024 10:08:40 +0000 (11:08 +0100)
committerMark Brown <broonie@kernel.org>
Mon, 27 May 2024 12:59:40 +0000 (13:59 +0100)
The SoundWire interface can always support 44.1kHz using flow controlled
mode, and whether the ASP is in master mode should obviously only affect
the ASP. Update cs42l43_startup() to only restrict the rates for the ASP
DAI.

Fixes: fc918cbe874e ("ASoC: cs42l43: Add support for the cs42l43")
Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://msgid.link/r/20240527100840.439832-1-ckeepax@opensource.cirrus.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/cs42l43.c

index 94685449f0f48c9b7bd534b1947da07ab26fad53..92674314227c4623af36a6b1642e83c8a33572d6 100644 (file)
@@ -310,8 +310,9 @@ static int cs42l43_startup(struct snd_pcm_substream *substream, struct snd_soc_d
        struct snd_soc_component *component = dai->component;
        struct cs42l43_codec *priv = snd_soc_component_get_drvdata(component);
        struct cs42l43 *cs42l43 = priv->core;
-       int provider = !!regmap_test_bits(cs42l43->regmap, CS42L43_ASP_CLK_CONFIG2,
-                                         CS42L43_ASP_MASTER_MODE_MASK);
+       int provider = !dai->id || !!regmap_test_bits(cs42l43->regmap,
+                                                     CS42L43_ASP_CLK_CONFIG2,
+                                                     CS42L43_ASP_MASTER_MODE_MASK);
 
        if (provider)
                priv->constraint.mask = CS42L43_PROVIDER_RATE_MASK;