]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ASoC: rt712-sdca: fix speaker route missing issue
authorShuming Fan <shumingf@realtek.com>
Mon, 30 Oct 2023 10:36:44 +0000 (18:36 +0800)
committerMark Brown <broonie@kernel.org>
Mon, 30 Oct 2023 15:42:35 +0000 (15:42 +0000)
Sometimes the codec probe would be called earlier than the hardware initialization.
Therefore, the speaker route should be added before the the first_hw_init check.

Signed-off-by: Shuming Fan <shumingf@realtek.com>
Fixes: f3da2ed110e2 ("ASoC: rt1712-sdca: enable pm_runtime in probe, keep status as 'suspended'")?
Link: https://lore.kernel.org/r/20231030103644.1787948-1-shumingf@realtek.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/rt712-sdca.c

index 7077ff6ba1f4bc30cbde0b69ff147c349f8ea710..6954fbe7ec5f3bb79f8693c23f302a7a1003e11e 100644 (file)
@@ -963,13 +963,6 @@ static int rt712_sdca_probe(struct snd_soc_component *component)
        rt712_sdca_parse_dt(rt712, &rt712->slave->dev);
        rt712->component = component;
 
-       if (!rt712->first_hw_init)
-               return 0;
-
-       ret = pm_runtime_resume(component->dev);
-       if (ret < 0 && ret != -EACCES)
-               return ret;
-
        /* add SPK route */
        if (rt712->hw_id != RT712_DEV_ID_713) {
                snd_soc_add_component_controls(component,
@@ -980,6 +973,13 @@ static int rt712_sdca_probe(struct snd_soc_component *component)
                        rt712_sdca_spk_dapm_routes, ARRAY_SIZE(rt712_sdca_spk_dapm_routes));
        }
 
+       if (!rt712->first_hw_init)
+               return 0;
+
+       ret = pm_runtime_resume(component->dev);
+       if (ret < 0 && ret != -EACCES)
+               return ret;
+
        return 0;
 }