aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/iio/adc
diff options
context:
space:
mode:
authorLars-Peter Clausen <lars@metafoo.de>2014-11-26 12:55:12 -0500
committerJonathan Cameron <jic23@kernel.org>2014-12-12 07:28:31 -0500
commit3e1b6c95b990c93f4aa3b17e9f66221e2fa44bee (patch)
treef71fc2dbca8356559cb805b022ad5202f386e72b /drivers/iio/adc
parent4ae03019923f7dd5785b69a513b74ccc1c3f7766 (diff)
iio: Move buffer registration to the core
Originally device and buffer registration were kept as separate operations in IIO to allow to register two distinct sets of channels for buffered and non-buffered operations. This has since already been further restricted and the channel set registered for the buffer needs to be a subset of the channel set registered for the device. Additionally the possibility to not have a raw (or processed) attribute for a channel which was registered for the device was added a while ago. This means it is possible to not register any device level attributes for a channel even if it is registered for the device. Also if a channel's scan_index is set to -1 and the channel is registered for the buffer it is ignored. So in summary it means it is possible to register the same channel array for both the device and the buffer yet still end up with distinctive sets of channels for both of them. This makes the argument for having to have to manually register the channels for both the device and the buffer invalid. Considering that the vast majority of all drivers want to register the same set of channels for both the buffer and the device it makes sense to move the buffer registration into the core to avoid some boiler-plate code in the device driver setup path. Signed-off-by: Lars-Peter Clausen <lars@metafoo.de> Signed-off-by: Jonathan Cameron <jic23@kernel.org>
Diffstat (limited to 'drivers/iio/adc')
-rw-r--r--drivers/iio/adc/ti_am335x_adc.c9
1 files changed, 0 insertions, 9 deletions
diff --git a/drivers/iio/adc/ti_am335x_adc.c b/drivers/iio/adc/ti_am335x_adc.c
index b730864731e8..d550ac7d2365 100644
--- a/drivers/iio/adc/ti_am335x_adc.c
+++ b/drivers/iio/adc/ti_am335x_adc.c
@@ -264,16 +264,8 @@ static int tiadc_iio_buffered_hardware_setup(struct iio_dev *indio_dev,
264 indio_dev->setup_ops = setup_ops; 264 indio_dev->setup_ops = setup_ops;
265 indio_dev->modes |= INDIO_BUFFER_HARDWARE; 265 indio_dev->modes |= INDIO_BUFFER_HARDWARE;
266 266
267 ret = iio_buffer_register(indio_dev,
268 indio_dev->channels,
269 indio_dev->num_channels);
270 if (ret)
271 goto error_free_irq;
272
273 return 0; 267 return 0;
274 268
275error_free_irq:
276 free_irq(irq, indio_dev);
277error_kfifo_free: 269error_kfifo_free:
278 iio_kfifo_free(indio_dev->buffer); 270 iio_kfifo_free(indio_dev->buffer);
279 return ret; 271 return ret;
@@ -285,7 +277,6 @@ static void tiadc_iio_buffered_hardware_remove(struct iio_dev *indio_dev)
285 277
286 free_irq(adc_dev->mfd_tscadc->irq, indio_dev); 278 free_irq(adc_dev->mfd_tscadc->irq, indio_dev);
287 iio_kfifo_free(indio_dev->buffer); 279 iio_kfifo_free(indio_dev->buffer);
288 iio_buffer_unregister(indio_dev);
289} 280}
290 281
291 282