]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
iio: imu: st_lsm6dsx: check return value from st_lsm6dsx_sensor_set_enable
authorLorenzo Bianconi <lorenzo@kernel.org>
Thu, 2 Jan 2020 08:36:29 +0000 (09:36 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 24 Feb 2020 07:38:05 +0000 (08:38 +0100)
[ Upstream commit a2dd9bd9334efb8dc0bdc0109abff3a7b57effb1 ]

Add missing return value check in st_lsm6dsx_read_oneshot disabling the
sensor. The issue is reported by coverity with the following error:

Unchecked return value:
If the function returns an error value, the error value may be mistaken
for a normal value.

Addresses-Coverity-ID: 1446733 ("Unchecked return value")
Fixes: b5969abfa8b8 ("iio: imu: st_lsm6dsx: add motion events")
Fixes: 290a6ce11d93 ("iio: imu: add support to lsm6dsx driver")
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx_core.c

index b921dd9e108faa5bfd017a1a7550c5095ff0c924..e45123d8d28120fa939f410b48aad88fec4ae74d 100644 (file)
@@ -1506,8 +1506,11 @@ static int st_lsm6dsx_read_oneshot(struct st_lsm6dsx_sensor *sensor,
        if (err < 0)
                return err;
 
-       if (!hw->enable_event)
-               st_lsm6dsx_sensor_set_enable(sensor, false);
+       if (!hw->enable_event) {
+               err = st_lsm6dsx_sensor_set_enable(sensor, false);
+               if (err < 0)
+                       return err;
+       }
 
        *val = (s16)le16_to_cpu(data);