ASoC: simple-card: fix possible uninitialized single_cpu local variable
authorKrzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
Wed, 7 Apr 2021 09:20:27 +0000 (11:20 +0200)
committerMark Brown <broonie@kernel.org>
Wed, 7 Apr 2021 15:58:30 +0000 (16:58 +0100)
The 'single_cpu' local variable is assigned by asoc_simple_parse_dai()
and later used in a asoc_simple_canonicalize_cpu() call, assuming the
entire function did not exit on errors.

However the first function returns 0 if passed device_node is NULL,
thus leaving the variable uninitialized and reporting success.

Addresses-Coverity: Uninitialized scalar variable
Fixes: 8f7f298a3337 ("ASoC: simple-card-utils: separate asoc_simple_card_parse_dai()")
Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
Acked-by: Sameer Pujar <spujar@nvidia.com>
Link: https://lore.kernel.org/r/20210407092027.60769-1-krzysztof.kozlowski@canonical.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/generic/audio-graph-card.c
sound/soc/generic/simple-card.c

index ee1d924d68e55303b2a63f880ff4cddcf324d064..76036ea377a92138a77f94c856e0153c0001e7b5 100644 (file)
@@ -367,7 +367,7 @@ static int graph_dai_link_of(struct asoc_simple_priv *priv,
        struct device_node *top = dev->of_node;
        struct asoc_simple_dai *cpu_dai;
        struct asoc_simple_dai *codec_dai;
-       int ret, single_cpu;
+       int ret, single_cpu = 0;
 
        dev_dbg(dev, "link_of (%pOF)\n", cpu_ep);
 
index 41aa40765a8d3b3e18c52aaeb3acb5dd2ee73725..9a05f44fc3a962e58a629c03acd6b8a688d6787b 100644 (file)
@@ -249,7 +249,7 @@ static int simple_dai_link_of(struct asoc_simple_priv *priv,
        struct device_node *plat = NULL;
        char prop[128];
        char *prefix = "";
-       int ret, single_cpu;
+       int ret, single_cpu = 0;
 
        cpu  = np;
        node = of_get_parent(np);