]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
iio: gyro: itg3200: Fix unchecked return value in read_raw
authorAntoniu Miclaus <antoniu.miclaus@analog.com>
Thu, 29 Jan 2026 15:01:45 +0000 (17:01 +0200)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Thu, 29 Jan 2026 17:07:07 +0000 (17:07 +0000)
The return value from itg3200_read_reg_s16() is stored in ret but
never checked. The function unconditionally returns IIO_VAL_INT,
ignoring potential I2C read failures. This causes garbage data to
be returned to userspace when the read fails, with no error reported.

Add proper error checking to propagate the failure to callers.

Fixes: 9dbf091da080 ("iio: gyro: Add itg3200")
Signed-off-by: Antoniu Miclaus <antoniu.miclaus@analog.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@intel.com>
Cc: <Stable@vger.kernel.org>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/gyro/itg3200_core.c

index cd8a2dae56cd90b9436a581d93f557f145ea128a..bfe95ec1abda9ba692f4ac8969f3d04b8fe04a77 100644 (file)
@@ -93,6 +93,8 @@ static int itg3200_read_raw(struct iio_dev *indio_dev,
        case IIO_CHAN_INFO_RAW:
                reg = (u8)chan->address;
                ret = itg3200_read_reg_s16(indio_dev, reg, val);
+               if (ret)
+                       return ret;
                return IIO_VAL_INT;
        case IIO_CHAN_INFO_SCALE:
                *val = 0;