Commit 1dc34590 authored by Srinivas Kandagatla's avatar Srinivas Kandagatla Committed by Mark Brown

ASoC: codecs: lpass: register mclk after runtime pm

move mclk out registration after runtime pm is enabled so that the
clk framework can resume the codec if it requires to enable the mclk out.

Fixes: c96baa29 ("ASoC: codecs: wsa-macro: add runtime pm support")
Fixes: 72ad25ea ("ASoC: codecs: va-macro: add runtime pm support")
Fixes: 366ff79e ("ASoC: codecs: rx-macro: add runtime pm support")
Fixes: 1fb83bc5 ("ASoC: codecs: tx-macro: add runtime pm support")
Signed-off-by: default avatarSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
Link: https://lore.kernel.org/r/20230209122806.18923-6-srinivas.kandagatla@linaro.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent dd33c2e7
...@@ -3601,10 +3601,6 @@ static int rx_macro_probe(struct platform_device *pdev) ...@@ -3601,10 +3601,6 @@ static int rx_macro_probe(struct platform_device *pdev)
if (ret) if (ret)
goto err_fsgen; goto err_fsgen;
ret = rx_macro_register_mclk_output(rx);
if (ret)
goto err_clkout;
ret = devm_snd_soc_register_component(dev, &rx_macro_component_drv, ret = devm_snd_soc_register_component(dev, &rx_macro_component_drv,
rx_macro_dai, rx_macro_dai,
ARRAY_SIZE(rx_macro_dai)); ARRAY_SIZE(rx_macro_dai));
...@@ -3618,6 +3614,10 @@ static int rx_macro_probe(struct platform_device *pdev) ...@@ -3618,6 +3614,10 @@ static int rx_macro_probe(struct platform_device *pdev)
pm_runtime_set_active(dev); pm_runtime_set_active(dev);
pm_runtime_enable(dev); pm_runtime_enable(dev);
ret = rx_macro_register_mclk_output(rx);
if (ret)
goto err_clkout;
return 0; return 0;
err_clkout: err_clkout:
......
...@@ -2036,10 +2036,6 @@ static int tx_macro_probe(struct platform_device *pdev) ...@@ -2036,10 +2036,6 @@ static int tx_macro_probe(struct platform_device *pdev)
if (ret) if (ret)
goto err_fsgen; goto err_fsgen;
ret = tx_macro_register_mclk_output(tx);
if (ret)
goto err_clkout;
ret = devm_snd_soc_register_component(dev, &tx_macro_component_drv, ret = devm_snd_soc_register_component(dev, &tx_macro_component_drv,
tx_macro_dai, tx_macro_dai,
ARRAY_SIZE(tx_macro_dai)); ARRAY_SIZE(tx_macro_dai));
...@@ -2052,6 +2048,10 @@ static int tx_macro_probe(struct platform_device *pdev) ...@@ -2052,6 +2048,10 @@ static int tx_macro_probe(struct platform_device *pdev)
pm_runtime_set_active(dev); pm_runtime_set_active(dev);
pm_runtime_enable(dev); pm_runtime_enable(dev);
ret = tx_macro_register_mclk_output(tx);
if (ret)
goto err_clkout;
return 0; return 0;
err_clkout: err_clkout:
......
...@@ -1524,16 +1524,6 @@ static int va_macro_probe(struct platform_device *pdev) ...@@ -1524,16 +1524,6 @@ static int va_macro_probe(struct platform_device *pdev)
if (ret) if (ret)
goto err_mclk; goto err_mclk;
ret = va_macro_register_fsgen_output(va);
if (ret)
goto err_clkout;
va->fsgen = clk_hw_get_clk(&va->hw, "fsgen");
if (IS_ERR(va->fsgen)) {
ret = PTR_ERR(va->fsgen);
goto err_clkout;
}
if (va->has_swr_master) { if (va->has_swr_master) {
/* Set default CLK div to 1 */ /* Set default CLK div to 1 */
regmap_update_bits(va->regmap, CDC_VA_TOP_CSR_SWR_MIC_CTL0, regmap_update_bits(va->regmap, CDC_VA_TOP_CSR_SWR_MIC_CTL0,
...@@ -1560,6 +1550,16 @@ static int va_macro_probe(struct platform_device *pdev) ...@@ -1560,6 +1550,16 @@ static int va_macro_probe(struct platform_device *pdev)
pm_runtime_set_active(dev); pm_runtime_set_active(dev);
pm_runtime_enable(dev); pm_runtime_enable(dev);
ret = va_macro_register_fsgen_output(va);
if (ret)
goto err_clkout;
va->fsgen = clk_hw_get_clk(&va->hw, "fsgen");
if (IS_ERR(va->fsgen)) {
ret = PTR_ERR(va->fsgen);
goto err_clkout;
}
return 0; return 0;
err_clkout: err_clkout:
......
...@@ -2451,11 +2451,6 @@ static int wsa_macro_probe(struct platform_device *pdev) ...@@ -2451,11 +2451,6 @@ static int wsa_macro_probe(struct platform_device *pdev)
if (ret) if (ret)
goto err_fsgen; goto err_fsgen;
ret = wsa_macro_register_mclk_output(wsa);
if (ret)
goto err_clkout;
ret = devm_snd_soc_register_component(dev, &wsa_macro_component_drv, ret = devm_snd_soc_register_component(dev, &wsa_macro_component_drv,
wsa_macro_dai, wsa_macro_dai,
ARRAY_SIZE(wsa_macro_dai)); ARRAY_SIZE(wsa_macro_dai));
...@@ -2468,6 +2463,10 @@ static int wsa_macro_probe(struct platform_device *pdev) ...@@ -2468,6 +2463,10 @@ static int wsa_macro_probe(struct platform_device *pdev)
pm_runtime_set_active(dev); pm_runtime_set_active(dev);
pm_runtime_enable(dev); pm_runtime_enable(dev);
ret = wsa_macro_register_mclk_output(wsa);
if (ret)
goto err_clkout;
return 0; return 0;
err_clkout: err_clkout:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment