iio: cros_ec_sensors_core: fix unsigned compared less than zero on status
authorColin Ian King <colin.king@canonical.com>
Wed, 9 Nov 2016 23:12:31 +0000 (23:12 +0000)
committerJonathan Cameron <jic23@kernel.org>
Sat, 12 Nov 2016 14:38:38 +0000 (14:38 +0000)
status is a u8 hence the check if status is less than zero has no effect.
Fix this by replacing status with int ret so the less than zero compare
will correctly detect errors.

Issue found with static analysis with CoverityScan, CID 1375919

Signed-off-by: Colin Ian King <colin.king@canonical.com>
Fixes: 974e6f02e27e ("iio: cros_ec_sensors_core: Add common functions for the ChromeOS EC Sensor Hub")
Reviewed-by: Guenter Roeck <groeck@chromium.org>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c

index a3be7991355ef05eff70db6db6cf9dd35ea8495c..416cae5ebbd07edd33506422ce6ae4fef53622dd 100644 (file)
@@ -291,15 +291,15 @@ int cros_ec_sensors_read_lpc(struct iio_dev *indio_dev,
                        return -EIO;
 
                /* Read status byte until EC is not busy. */
-               status = cros_ec_sensors_read_until_not_busy(st);
-               if (status < 0)
-                       return status;
+               ret = cros_ec_sensors_read_until_not_busy(st);
+               if (ret < 0)
+                       return ret;
 
                /*
                 * Store the current sample id so that we can compare to the
                 * sample id after reading the data.
                 */
-               samp_id = status & EC_MEMMAP_ACC_STATUS_SAMPLE_ID_MASK;
+               samp_id = ret & EC_MEMMAP_ACC_STATUS_SAMPLE_ID_MASK;
 
                /* Read all EC data, format it, and store it into data. */
                ret = cros_ec_sensors_read_data_unsafe(indio_dev, scan_mask,