diff options
author | Crestez Dan Leonard <[email protected]> | 2016-05-13 21:43:34 +0300 |
---|---|---|
committer | Jonathan Cameron <[email protected]> | 2016-05-29 20:27:16 +0100 |
commit | 99147606155f09feccac67c65387dc62260b749b (patch) | |
tree | c3150c481f141675816479713a48016137038eea | |
parent | ff05916f94f912b25e8efcf9b02c10d481977bab (diff) |
iio: st_sensors: Disable DRDY at init time
This fixes odd behavior after reboot.
The fact that we set the device to powerdown mode is not sufficient to
prevent DRDY being active because we might still have an unread sample.
Even if powerdown was sufficient keeping DRDY disabled while trigger is
not active is a good idea.
Cc: Giuseppe Barba <[email protected]>
Cc: Denis Ciocca <[email protected]>
Signed-off-by: Crestez Dan Leonard <[email protected]>
Reviewed-by: Linus Walleij <[email protected]>
Signed-off-by: Jonathan Cameron <[email protected]>
-rw-r--r-- | drivers/iio/common/st_sensors/st_sensors_core.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/iio/common/st_sensors/st_sensors_core.c b/drivers/iio/common/st_sensors/st_sensors_core.c index 928ee68fcc5f..9e59c90f6a8d 100644 --- a/drivers/iio/common/st_sensors/st_sensors_core.c +++ b/drivers/iio/common/st_sensors/st_sensors_core.c @@ -363,6 +363,11 @@ int st_sensors_init_sensor(struct iio_dev *indio_dev, if (err < 0) return err; + /* Disable DRDY, this might be still be enabled after reboot. */ + err = st_sensors_set_dataready_irq(indio_dev, false); + if (err < 0) + return err; + if (sdata->current_fullscale) { err = st_sensors_set_fullscale(indio_dev, sdata->current_fullscale->num); |