Commit 14ee64f4 authored by Octavian Purdila's avatar Octavian Purdila Committed by Jonathan Cameron

iio: bmc150: exit early if event / trigger state is not changed

Previous of this patch the check was only done if we enabled the event
and it was already enabled. We can do the same if the event is
disabled and we want to disable it.

The patch also adds the same check on the trigger code.
Signed-off-by: default avatarOctavian Purdila <octavian.purdila@intel.com>
Acked-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent 8e22f477
...@@ -748,7 +748,7 @@ static int bmc150_accel_write_event_config(struct iio_dev *indio_dev, ...@@ -748,7 +748,7 @@ static int bmc150_accel_write_event_config(struct iio_dev *indio_dev,
struct bmc150_accel_data *data = iio_priv(indio_dev); struct bmc150_accel_data *data = iio_priv(indio_dev);
int ret; int ret;
if (state && data->ev_enable_state) if (state == data->ev_enable_state)
return 0; return 0;
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
...@@ -984,6 +984,18 @@ static int bmc150_accel_data_rdy_trigger_set_state(struct iio_trigger *trig, ...@@ -984,6 +984,18 @@ static int bmc150_accel_data_rdy_trigger_set_state(struct iio_trigger *trig,
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
if (data->motion_trig == trig) {
if (data->motion_trigger_on == state) {
mutex_unlock(&data->mutex);
return 0;
}
} else {
if (data->dready_trigger_on == state) {
mutex_unlock(&data->mutex);
return 0;
}
}
if (!state && data->ev_enable_state && data->motion_trigger_on) { if (!state && data->ev_enable_state && data->motion_trigger_on) {
data->motion_trigger_on = false; data->motion_trigger_on = false;
mutex_unlock(&data->mutex); mutex_unlock(&data->mutex);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment