diff options
| author | Lars-Peter Clausen <lars@metafoo.de> | 2013-09-18 16:02:00 -0400 |
|---|---|---|
| committer | Jonathan Cameron <jic23@kernel.org> | 2013-09-21 07:36:30 -0400 |
| commit | a87c82e454f184a9473f8cdfd4d304205f585f65 (patch) | |
| tree | 5f158830b28d740e6782dac2683fd46cde7b23fb | |
| parent | d66e0452bf6b0d98cd1a478918c92f2baffcb413 (diff) | |
iio: Stop sampling when the device is removed
Make sure to stop sampling when the device is removed, otherwise it will
continue to sample forever.
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
| -rw-r--r-- | drivers/iio/iio_core.h | 4 | ||||
| -rw-r--r-- | drivers/iio/industrialio-buffer.c | 19 | ||||
| -rw-r--r-- | drivers/iio/industrialio-core.c | 6 |
3 files changed, 28 insertions, 1 deletions
diff --git a/drivers/iio/iio_core.h b/drivers/iio/iio_core.h index 05c1b74502a3..9b32253b824b 100644 --- a/drivers/iio/iio_core.h +++ b/drivers/iio/iio_core.h | |||
| @@ -49,11 +49,15 @@ ssize_t iio_buffer_read_first_n_outer(struct file *filp, char __user *buf, | |||
| 49 | #define iio_buffer_poll_addr (&iio_buffer_poll) | 49 | #define iio_buffer_poll_addr (&iio_buffer_poll) |
| 50 | #define iio_buffer_read_first_n_outer_addr (&iio_buffer_read_first_n_outer) | 50 | #define iio_buffer_read_first_n_outer_addr (&iio_buffer_read_first_n_outer) |
| 51 | 51 | ||
| 52 | void iio_disable_all_buffers(struct iio_dev *indio_dev); | ||
| 53 | |||
| 52 | #else | 54 | #else |
| 53 | 55 | ||
| 54 | #define iio_buffer_poll_addr NULL | 56 | #define iio_buffer_poll_addr NULL |
| 55 | #define iio_buffer_read_first_n_outer_addr NULL | 57 | #define iio_buffer_read_first_n_outer_addr NULL |
| 56 | 58 | ||
| 59 | static inline void iio_disable_all_buffers(struct iio_dev *indio_dev) {} | ||
| 60 | |||
| 57 | #endif | 61 | #endif |
| 58 | 62 | ||
| 59 | int iio_device_register_eventset(struct iio_dev *indio_dev); | 63 | int iio_device_register_eventset(struct iio_dev *indio_dev); |
diff --git a/drivers/iio/industrialio-buffer.c b/drivers/iio/industrialio-buffer.c index 5862c88ed5ad..2710f7245c3b 100644 --- a/drivers/iio/industrialio-buffer.c +++ b/drivers/iio/industrialio-buffer.c | |||
| @@ -460,6 +460,25 @@ static int iio_compute_scan_bytes(struct iio_dev *indio_dev, const long *mask, | |||
| 460 | return bytes; | 460 | return bytes; |
| 461 | } | 461 | } |
| 462 | 462 | ||
| 463 | void iio_disable_all_buffers(struct iio_dev *indio_dev) | ||
| 464 | { | ||
| 465 | struct iio_buffer *buffer, *_buffer; | ||
| 466 | |||
| 467 | if (list_empty(&indio_dev->buffer_list)) | ||
| 468 | return; | ||
| 469 | |||
| 470 | if (indio_dev->setup_ops->predisable) | ||
| 471 | indio_dev->setup_ops->predisable(indio_dev); | ||
| 472 | |||
| 473 | list_for_each_entry_safe(buffer, _buffer, | ||
| 474 | &indio_dev->buffer_list, buffer_list) | ||
| 475 | list_del_init(&buffer->buffer_list); | ||
| 476 | |||
| 477 | indio_dev->currentmode = INDIO_DIRECT_MODE; | ||
| 478 | if (indio_dev->setup_ops->postdisable) | ||
| 479 | indio_dev->setup_ops->postdisable(indio_dev); | ||
| 480 | } | ||
| 481 | |||
| 463 | int iio_update_buffers(struct iio_dev *indio_dev, | 482 | int iio_update_buffers(struct iio_dev *indio_dev, |
| 464 | struct iio_buffer *insert_buffer, | 483 | struct iio_buffer *insert_buffer, |
| 465 | struct iio_buffer *remove_buffer) | 484 | struct iio_buffer *remove_buffer) |
diff --git a/drivers/iio/industrialio-core.c b/drivers/iio/industrialio-core.c index 97f0297b120f..2cc0778a7328 100644 --- a/drivers/iio/industrialio-core.c +++ b/drivers/iio/industrialio-core.c | |||
| @@ -1078,9 +1078,13 @@ EXPORT_SYMBOL(iio_device_register); | |||
| 1078 | void iio_device_unregister(struct iio_dev *indio_dev) | 1078 | void iio_device_unregister(struct iio_dev *indio_dev) |
| 1079 | { | 1079 | { |
| 1080 | mutex_lock(&indio_dev->info_exist_lock); | 1080 | mutex_lock(&indio_dev->info_exist_lock); |
| 1081 | |||
| 1082 | device_del(&indio_dev->dev); | ||
| 1083 | |||
| 1084 | iio_disable_all_buffers(indio_dev); | ||
| 1085 | |||
| 1081 | indio_dev->info = NULL; | 1086 | indio_dev->info = NULL; |
| 1082 | mutex_unlock(&indio_dev->info_exist_lock); | 1087 | mutex_unlock(&indio_dev->info_exist_lock); |
| 1083 | device_del(&indio_dev->dev); | ||
| 1084 | } | 1088 | } |
| 1085 | EXPORT_SYMBOL(iio_device_unregister); | 1089 | EXPORT_SYMBOL(iio_device_unregister); |
| 1086 | subsys_initcall(iio_init); | 1090 | subsys_initcall(iio_init); |
