未验证 提交 4a8191aa 编写于 作者: Y Yizhuo 提交者: Mark Brown

ASoC: rt274: Variable "buf" in function rt274_jack_detect() could be uninitialized

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: NYizhuo <yzhai003@ucr.edu>
Signed-off-by: NMark Brown <broonie@kernel.org>
上级 7b57085a
...@@ -353,6 +353,7 @@ static void rt274_index_sync(struct snd_soc_component *component) ...@@ -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) static int rt274_jack_detect(struct rt274_priv *rt274, bool *hp, bool *mic)
{ {
unsigned int buf; unsigned int buf;
int ret;
*hp = false; *hp = false;
*mic = false; *mic = false;
...@@ -360,9 +361,15 @@ static int rt274_jack_detect(struct rt274_priv *rt274, bool *hp, bool *mic) ...@@ -360,9 +361,15 @@ static int rt274_jack_detect(struct rt274_priv *rt274, bool *hp, bool *mic)
if (!rt274->component) if (!rt274->component)
return -EINVAL; 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; *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; *mic = buf & 0x80000000;
pr_debug("*hp = %d *mic = %d\n", *hp, *mic); pr_debug("*hp = %d *mic = %d\n", *hp, *mic);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册