media: si2157: ensure wait_status is initialized
authorSean Young <sean@mess.org>
Wed, 22 Apr 2020 19:16:46 +0000 (21:16 +0200)
committerMauro Carvalho Chehab <mchehab+huawei@kernel.org>
Wed, 29 Apr 2020 09:59:57 +0000 (11:59 +0200)
smatch reports wait_status is uninitialized, because smatch cannot assume
the loop body is ever executed.

Clarify the code so that wait_status is retrieved at least once.

Signed-off-by: Sean Young <sean@mess.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
drivers/media/tuners/si2157.c

index 6b45256..fefb262 100644 (file)
@@ -327,7 +327,7 @@ static int si2157_tune_wait(struct i2c_client *client, u8 is_digital)
        /* wait tuner command complete */
        start_time = jiffies;
        timeout = start_time + msecs_to_jiffies(TUN_TIMEOUT);
-       while (!time_after(jiffies, timeout)) {
+       while (1) {
                ret = i2c_master_recv(client, &wait_status,
                                      sizeof(wait_status));
                if (ret < 0) {
@@ -337,6 +337,9 @@ static int si2157_tune_wait(struct i2c_client *client, u8 is_digital)
                        goto err_mutex_unlock;
                }
 
+               if (time_after(jiffies, timeout))
+                       break;
+
                /* tuner done? */
                if ((wait_status & 0x81) == 0x81)
                        break;