blob: 4bedc65c9fe3b046e75c6bab4870dbcd58989132 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001// SPDX-License-Identifier: GPL-2.0-or-later
Vladimir Barinov735ad072015-08-20 22:37:39 +03002/*
3 * Copyright (C) 2015 Cogent Embedded, Inc.
Vladimir Barinov735ad072015-08-20 22:37:39 +03004 */
5
6#include <linux/kernel.h>
7#include <linux/export.h>
8#include <linux/module.h>
9#include <linux/iio/iio.h>
10#include <linux/iio/triggered_event.h>
11#include <linux/iio/trigger_consumer.h>
12
13/**
14 * iio_triggered_event_setup() - Setup pollfunc_event for triggered event
15 * @indio_dev: IIO device structure
16 * @h: Function which will be used as pollfunc_event top half
17 * @thread: Function which will be used as pollfunc_event bottom half
18 *
19 * This function combines some common tasks which will normally be performed
20 * when setting up a triggered event. It will allocate the pollfunc_event and
21 * set mode to use it for triggered event.
22 *
23 * Before calling this function the indio_dev structure should already be
24 * completely initialized, but not yet registered. In practice this means that
25 * this function should be called right before iio_device_register().
26 *
27 * To free the resources allocated by this function call
28 * iio_triggered_event_cleanup().
29 */
30int iio_triggered_event_setup(struct iio_dev *indio_dev,
31 irqreturn_t (*h)(int irq, void *p),
32 irqreturn_t (*thread)(int irq, void *p))
33{
34 indio_dev->pollfunc_event = iio_alloc_pollfunc(h,
35 thread,
36 IRQF_ONESHOT,
37 indio_dev,
38 "%s_consumer%d",
39 indio_dev->name,
Jonathan Cameron15ea28782021-04-26 18:49:03 +010040 iio_device_id(indio_dev));
Vladimir Barinov735ad072015-08-20 22:37:39 +030041 if (indio_dev->pollfunc_event == NULL)
42 return -ENOMEM;
43
44 /* Flag that events polling is possible */
45 indio_dev->modes |= INDIO_EVENT_TRIGGERED;
46
47 return 0;
48}
49EXPORT_SYMBOL(iio_triggered_event_setup);
50
51/**
52 * iio_triggered_event_cleanup() - Free resources allocated by iio_triggered_event_setup()
53 * @indio_dev: IIO device structure
54 */
55void iio_triggered_event_cleanup(struct iio_dev *indio_dev)
56{
57 indio_dev->modes &= ~INDIO_EVENT_TRIGGERED;
58 iio_dealloc_pollfunc(indio_dev->pollfunc_event);
59}
60EXPORT_SYMBOL(iio_triggered_event_cleanup);
61
62MODULE_AUTHOR("Vladimir Barinov");
63MODULE_DESCRIPTION("IIO helper functions for setting up triggered events");
64MODULE_LICENSE("GPL");