iio: sensors-core: st: Check st_sensors_set_drdy_int_pin()'s return value
authorLee Jones <lee.jones@linaro.org>
Wed, 13 Aug 2014 10:27:34 +0000 (11:27 +0100)
committerLee Jones <lee.jones@linaro.org>
Fri, 26 Sep 2014 07:15:27 +0000 (08:15 +0100)
Value from st_sensors_set_drdy_int_pin() is assigned to err here,
but that stored value is not used before it is overwritten.  To fix
this we're enforcing a check on st_sensors_set_drdy_int_pin()'s
return value and if it's an error, we're returning right away.

Cc: jic23@kernel.org
Cc: linux-iio@vger.kernel.org
Signed-off-by: Lee Jones <lee.jones@linaro.org>
drivers/iio/common/st_sensors/st_sensors_core.c

index 8a4ec00a91a0c44166aa7f9c57be378e87b768ff..24cfe4e044f9b21ed5224f906602ea2c5898b54c 100644 (file)
@@ -306,8 +306,11 @@ int st_sensors_init_sensor(struct iio_dev *indio_dev,
        if (of_pdata)
                pdata = of_pdata;
 
-       if (pdata)
+       if (pdata) {
                err = st_sensors_set_drdy_int_pin(indio_dev, pdata);
+               if (err < 0)
+                       return err;
+       }
 
        err = st_sensors_set_enable(indio_dev, false);
        if (err < 0)