ASoC: rt274: Variable "buf" in function rt274_jack_detect() could be uninitialized
authorYizhuo <yzhai003@ucr.edu>
Mon, 7 Jan 2019 20:12:32 +0000 (12:12 -0800)
committerMark Brown <broonie@kernel.org>
Tue, 8 Jan 2019 13:05:48 +0000 (13:05 +0000)
In function rt274_jack_detect(), local variable "buf" could
be uninitialized if function regmap_read() returns -EINVAL.
However, it will be used to calculate "hp" and "mic" and
make their value unpredictable while those value are used
in the caller. This is potentially unsafe.

Signed-off-by: Yizhuo <yzhai003@ucr.edu>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/rt274.c

index 9e88f7b25d380897ac24d229013ff20812ded972..adf59039a3b6ba1d277c0bbfa8dc04af86ca13e5 100644 (file)
@@ -353,6 +353,7 @@ static void rt274_index_sync(struct snd_soc_component *component)
 static int rt274_jack_detect(struct rt274_priv *rt274, bool *hp, bool *mic)
 {
        unsigned int buf;
+       int ret;
 
        *hp = false;
        *mic = false;
@@ -360,9 +361,15 @@ static int rt274_jack_detect(struct rt274_priv *rt274, bool *hp, bool *mic)
        if (!rt274->component)
                return -EINVAL;
 
-       regmap_read(rt274->regmap, RT274_GET_HP_SENSE, &buf);
+       ret = regmap_read(rt274->regmap, RT274_GET_HP_SENSE, &buf);
+       if (ret)
+               return ret;
+
        *hp = buf & 0x80000000;
-       regmap_read(rt274->regmap, RT274_GET_MIC_SENSE, &buf);
+       ret = regmap_read(rt274->regmap, RT274_GET_MIC_SENSE, &buf);
+       if (ret)
+               return ret;
+
        *mic = buf & 0x80000000;
 
        pr_debug("*hp = %d *mic = %d\n", *hp, *mic);