/** * iio_triggered_buffer_setup_ext() - Setup triggered buffer and pollfunc * @indio_dev: IIO device structure * @h: Function which will be used as pollfunc top half * @thread: Function which will be used as pollfunc bottom half * @direction: Direction of the data stream (in/out). * @setup_ops: Buffer setup functions to use for this device. * If NULL the default setup functions for triggered * buffers will be used. * @buffer_attrs: Extra sysfs buffer attributes for this IIO buffer * * This function combines some common tasks which will normally be performed * when setting up a triggered buffer. It will allocate the buffer and the * pollfunc. * * Before calling this function the indio_dev structure should already be * completely initialized, but not yet registered. In practice this means that * this function should be called right before iio_device_register(). * * To free the resources allocated by this function call * iio_triggered_buffer_cleanup().
*/ int iio_triggered_buffer_setup_ext(struct iio_dev *indio_dev,
irqreturn_t (*h)(int irq, void *p),
irqreturn_t (*thread)(int irq, void *p), enum iio_buffer_direction direction, conststruct iio_buffer_setup_ops *setup_ops, conststruct iio_dev_attr **buffer_attrs)
{ struct iio_buffer *buffer; int ret;
/* * iio_triggered_buffer_cleanup() assumes that the buffer allocated here * is assigned to indio_dev->buffer but this is only the case if this * function is the first caller to iio_device_attach_buffer(). If * indio_dev->buffer is already set then we can't proceed otherwise the * cleanup function will try to free a buffer that was not allocated here.
*/ if (indio_dev->buffer) return -EADDRINUSE;
buffer = iio_kfifo_allocate(); if (!buffer) {
ret = -ENOMEM; goto error_ret;
}
indio_dev->pollfunc = iio_alloc_pollfunc(h,
thread,
IRQF_ONESHOT,
indio_dev, "%s_consumer%d",
indio_dev->name,
iio_device_id(indio_dev)); if (indio_dev->pollfunc == NULL) {
ret = -ENOMEM; goto error_kfifo_free;
}
/* Ring buffer functions - here trigger setup related */
indio_dev->setup_ops = setup_ops;
/* Flag that polled ring buffering is possible */
indio_dev->modes |= INDIO_BUFFER_TRIGGERED;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.