From: Mark Brown Date: Mon, 31 Jul 2023 10:47:02 +0000 (+0100) Subject: ASoC: wm8960: Read initial MCLK rate from clock API X-Git-Tag: v6.6.7~1940^2^2~168^2~1 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0169cc3f200cbd737a57592fc478b24ff3cec3c5;p=platform%2Fkernel%2Flinux-starfive.git ASoC: wm8960: Read initial MCLK rate from clock API When we have a MCLK provided by the clock API read the rate at startup and store it so that there's something set before the machine driver has done clocking configuration (eg, if it only configures clocking based on sample rate). Acked-by: Charles Keepax Signed-off-by: Mark Brown Link: https://lore.kernel.org/r/20230731-asoc-wm8960-clk-v1-1-69f9ffa2b10a@kernel.org Signed-off-by: Mark Brown --- diff --git a/sound/soc/codecs/wm8960.c b/sound/soc/codecs/wm8960.c index c2bd9ef..d4bc970 100644 --- a/sound/soc/codecs/wm8960.c +++ b/sound/soc/codecs/wm8960.c @@ -1429,6 +1429,14 @@ static int wm8960_i2c_probe(struct i2c_client *i2c) if (IS_ERR(wm8960->mclk)) { if (PTR_ERR(wm8960->mclk) == -EPROBE_DEFER) return -EPROBE_DEFER; + } else { + ret = clk_get_rate(wm8960->mclk); + if (ret >= 0) { + wm8960->freq_in = ret; + } else { + dev_err(&i2c->dev, "Failed to read MCLK rate: %d\n", + ret); + } } wm8960->regmap = devm_regmap_init_i2c(i2c, &wm8960_regmap);