Current dpcm_add_paths() is checking fe condition in loop (= A),
but fe condition (X) is not related to the loop (B).
(X)	static int dpcm_add_paths(fe, stream, ...)
	{
		...
(B)		for_each_dapm_widgets(list, i, widget) {
			...
(A)			if (!fe->dpcm[stream].runtime && !fe->fe_compr)
				continue;
			...
		}
		...
	}
This patch checks fe condition at out of loop
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Link: https://lore.kernel.org/r/87pmgi4dz4.wl-kuninori.morimoto.gx@renesas.com
Signed-off-by: Mark Brown <broonie@kernel.org>
        struct snd_soc_dapm_widget *widget;
        int i, new = 0, err;
 
+       /* don't connect if FE is not running */
+       if (!fe->dpcm[stream].runtime && !fe->fe_compr)
+               return new;
+
        /* Create any new FE <--> BE connections */
        for_each_dapm_widgets(list, i, widget) {
 
                        continue;
                }
 
-               /* don't connect if FE is not running */
-               if (!fe->dpcm[stream].runtime && !fe->fe_compr)
-                       continue;
-
                /*
                 * Filter for systems with 'component_chaining' enabled.
                 * This helps to avoid unnecessary re-configuration of an