staging: iio: ad7606: fix improper setting of oversampling pins
authorEva Rachel Retuya <eraretuya@gmail.com>
Sat, 8 Oct 2016 16:05:39 +0000 (00:05 +0800)
committerJonathan Cameron <jic23@kernel.org>
Sat, 8 Oct 2016 16:42:34 +0000 (17:42 +0100)
The oversampling ratio is controlled using the oversampling pins,
OS [2:0] with OS2 being the MSB control bit, and OS0 the LSB control
bit.

The gpio connected to the OS2 pin is not being set correctly, only OS0
and OS1 pins are being set. Fix the typo to allow proper control of the
oversampling pins.

Signed-off-by: Eva Rachel Retuya <eraretuya@gmail.com>
Fixes: b9618c0 ("staging: IIO: ADC: New driver for AD7606/AD7606-6/AD7606-4")
Acked-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
drivers/staging/iio/adc/ad7606_core.c

index f79ee61851f6024994e9fe201c2ffde1755e3c0f..cbd6bc52050f1618d87acc7bd00a960f974dbaa4 100644 (file)
@@ -189,7 +189,7 @@ static ssize_t ad7606_store_oversampling_ratio(struct device *dev,
        mutex_lock(&indio_dev->mlock);
        gpio_set_value(st->pdata->gpio_os0, (ret >> 0) & 1);
        gpio_set_value(st->pdata->gpio_os1, (ret >> 1) & 1);
-       gpio_set_value(st->pdata->gpio_os1, (ret >> 2) & 1);
+       gpio_set_value(st->pdata->gpio_os2, (ret >> 2) & 1);
        st->oversampling = lval;
        mutex_unlock(&indio_dev->mlock);