ASoC: core: only flush inited work during free
authorCurtis Malainey <cujomalainey@chromium.org>
Thu, 28 Nov 2019 01:13:58 +0000 (17:13 -0800)
committerMark Brown <broonie@kernel.org>
Mon, 9 Dec 2019 10:55:42 +0000 (10:55 +0000)
There are many paths to soc_free_pcm_runtime which can both have and
have not yet inited the workqueue yet. When we flush the queue when we
have not yet inited the queue we cause warnings to be printed.

An example is soc_cleanup_card_resources which is called by
snd_soc_bind_card which has multiple failure points before and after
soc_link_init -> soc_new_pcm which is where the queue is inited.

Signed-off-by: Curtis Malainey <cujomalainey@chromium.org>
Link: https://lore.kernel.org/r/20191128011358.39234-1-cujomalainey@chromium.org
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/soc-core.c

index 0e2e628302f1d21dce1969c9c0c2e8fb85364b7e..1c84ff1a5bf96b09e303ec08d5d4c6e1e565aad9 100644 (file)
@@ -419,7 +419,8 @@ static void soc_free_pcm_runtime(struct snd_soc_pcm_runtime *rtd)
 
        list_del(&rtd->list);
 
-       flush_delayed_work(&rtd->delayed_work);
+       if (delayed_work_pending(&rtd->delayed_work))
+               flush_delayed_work(&rtd->delayed_work);
        snd_soc_pcm_component_free(rtd);
 
        /*