iio: adc: at91-sama5d2_adc: fix up casting in at91_adc_read_info_raw()
authorDan Carpenter <dan.carpenter@oracle.com>
Mon, 9 Jul 2018 11:06:59 +0000 (14:06 +0300)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Mon, 23 Jul 2018 18:18:12 +0000 (19:18 +0100)
This code is problematic because we're supposed to be writing an int but
we instead write to only the high 16 bits.  This doesn't work on big
endian systems, and there is a potential that the bottom 16 bits are
used without being initialized.

Fixes: 23ec2774f1cc ("iio: adc: at91-sama5d2_adc: add support for position and pressure channels")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Tested-by: Eugen Hristev <eugen.hristev@microchip.com>
Acked-by: Ludovic Desroches <ludovic.desroches@microchip.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/adc/at91-sama5d2_adc.c

index e02f7d1c86bc89d1d94799f5c542ab6ee5a7f6b6..d5ea84cf6460c6bf3e7bd6cc9409977dd0390738 100644 (file)
@@ -1296,6 +1296,7 @@ static int at91_adc_read_info_raw(struct iio_dev *indio_dev,
 {
        struct at91_adc_state *st = iio_priv(indio_dev);
        u32 cor = 0;
+       u16 tmp_val;
        int ret;
 
        /*
@@ -1309,7 +1310,8 @@ static int at91_adc_read_info_raw(struct iio_dev *indio_dev,
                mutex_lock(&st->lock);
 
                ret = at91_adc_read_position(st, chan->channel,
-                                            (u16 *)val);
+                                            &tmp_val);
+               *val = tmp_val;
                mutex_unlock(&st->lock);
                iio_device_release_direct_mode(indio_dev);
 
@@ -1322,7 +1324,8 @@ static int at91_adc_read_info_raw(struct iio_dev *indio_dev,
                mutex_lock(&st->lock);
 
                ret = at91_adc_read_pressure(st, chan->channel,
-                                            (u16 *)val);
+                                            &tmp_val);
+               *val = tmp_val;
                mutex_unlock(&st->lock);
                iio_device_release_direct_mode(indio_dev);