diff options
Diffstat (limited to 'drivers/iio/industrialio-buffer.c')
-rw-r--r-- | drivers/iio/industrialio-buffer.c | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/drivers/iio/industrialio-buffer.c b/drivers/iio/industrialio-buffer.c index e73033f3839a..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) |
@@ -528,8 +547,15 @@ int iio_update_buffers(struct iio_dev *indio_dev, | |||
528 | * Note can only occur when adding a buffer. | 547 | * Note can only occur when adding a buffer. |
529 | */ | 548 | */ |
530 | list_del(&insert_buffer->buffer_list); | 549 | list_del(&insert_buffer->buffer_list); |
531 | indio_dev->active_scan_mask = old_mask; | 550 | if (old_mask) { |
532 | success = -EINVAL; | 551 | indio_dev->active_scan_mask = old_mask; |
552 | success = -EINVAL; | ||
553 | } | ||
554 | else { | ||
555 | kfree(compound_mask); | ||
556 | ret = -EINVAL; | ||
557 | goto error_ret; | ||
558 | } | ||
533 | } | 559 | } |
534 | } else { | 560 | } else { |
535 | indio_dev->active_scan_mask = compound_mask; | 561 | indio_dev->active_scan_mask = compound_mask; |