1d2912cb1SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
2a980e046SJonathan Cameron /* The industrial I/O core function defs.
3a980e046SJonathan Cameron *
4a980e046SJonathan Cameron * Copyright (c) 2008 Jonathan Cameron
5a980e046SJonathan Cameron *
6a980e046SJonathan Cameron * These definitions are meant for use only within the IIO core, not individual
7a980e046SJonathan Cameron * drivers.
8a980e046SJonathan Cameron */
9a980e046SJonathan Cameron
10a980e046SJonathan Cameron #ifndef _IIO_CORE_H_
11a980e046SJonathan Cameron #define _IIO_CORE_H_
12a980e046SJonathan Cameron #include <linux/kernel.h>
13a980e046SJonathan Cameron #include <linux/device.h>
14a980e046SJonathan Cameron
153e3d11b2SAlexandru Ardelean struct iio_buffer;
16a980e046SJonathan Cameron struct iio_chan_spec;
17a980e046SJonathan Cameron struct iio_dev;
18a980e046SJonathan Cameron
19*3c33b7b8SLars-Peter Clausen extern const struct device_type iio_device_type;
20a980e046SJonathan Cameron
21be24dcb1SAlexandru Ardelean struct iio_dev_buffer_pair {
22be24dcb1SAlexandru Ardelean struct iio_dev *indio_dev;
23be24dcb1SAlexandru Ardelean struct iio_buffer *buffer;
24be24dcb1SAlexandru Ardelean };
25be24dcb1SAlexandru Ardelean
268dedcc3eSAlexandru Ardelean #define IIO_IOCTL_UNHANDLED 1
278dedcc3eSAlexandru Ardelean struct iio_ioctl_handler {
288dedcc3eSAlexandru Ardelean struct list_head entry;
298dedcc3eSAlexandru Ardelean long (*ioctl)(struct iio_dev *indio_dev, struct file *filp,
308dedcc3eSAlexandru Ardelean unsigned int cmd, unsigned long arg);
318dedcc3eSAlexandru Ardelean };
328dedcc3eSAlexandru Ardelean
338dedcc3eSAlexandru Ardelean long iio_device_ioctl(struct iio_dev *indio_dev, struct file *filp,
348dedcc3eSAlexandru Ardelean unsigned int cmd, unsigned long arg);
358dedcc3eSAlexandru Ardelean
368dedcc3eSAlexandru Ardelean void iio_device_ioctl_handler_register(struct iio_dev *indio_dev,
378dedcc3eSAlexandru Ardelean struct iio_ioctl_handler *h);
388dedcc3eSAlexandru Ardelean void iio_device_ioctl_handler_unregister(struct iio_ioctl_handler *h);
398dedcc3eSAlexandru Ardelean
40a980e046SJonathan Cameron int __iio_add_chan_devattr(const char *postfix,
41a980e046SJonathan Cameron struct iio_chan_spec const *chan,
42a980e046SJonathan Cameron ssize_t (*func)(struct device *dev,
43a980e046SJonathan Cameron struct device_attribute *attr,
44a980e046SJonathan Cameron char *buf),
45a980e046SJonathan Cameron ssize_t (*writefunc)(struct device *dev,
46a980e046SJonathan Cameron struct device_attribute *attr,
47a980e046SJonathan Cameron const char *buf,
48a980e046SJonathan Cameron size_t len),
49a980e046SJonathan Cameron u64 mask,
503704432fSJonathan Cameron enum iio_shared_by shared_by,
51a980e046SJonathan Cameron struct device *dev,
523e3d11b2SAlexandru Ardelean struct iio_buffer *buffer,
53a980e046SJonathan Cameron struct list_head *attr_list);
5484088ebdSLars-Peter Clausen void iio_free_chan_devattr_list(struct list_head *attr_list);
55a980e046SJonathan Cameron
5632f17172SAlexandru Ardelean int iio_device_register_sysfs_group(struct iio_dev *indio_dev,
5732f17172SAlexandru Ardelean const struct attribute_group *group);
5832f17172SAlexandru Ardelean
599fbfb4b3SSrinivas Pandruvada ssize_t iio_format_value(char *buf, unsigned int type, int size, int *vals);
603661f3f5SLars-Peter Clausen
61a980e046SJonathan Cameron /* Event interface flags */
62a980e046SJonathan Cameron #define IIO_BUSY_BIT_POS 1
63a980e046SJonathan Cameron
64a980e046SJonathan Cameron #ifdef CONFIG_IIO_BUFFER
65a980e046SJonathan Cameron struct poll_table_struct;
66a980e046SJonathan Cameron
67f73f7f4dSAlexandru Ardelean __poll_t iio_buffer_poll_wrapper(struct file *filp,
68a980e046SJonathan Cameron struct poll_table_struct *wait);
69f73f7f4dSAlexandru Ardelean ssize_t iio_buffer_read_wrapper(struct file *filp, char __user *buf,
70a980e046SJonathan Cameron size_t n, loff_t *f_ps);
719eeee3b0SMihail Chindris ssize_t iio_buffer_write_wrapper(struct file *filp, const char __user *buf,
729eeee3b0SMihail Chindris size_t n, loff_t *f_ps);
73a980e046SJonathan Cameron
74ee708e6bSAlexandru Ardelean int iio_buffers_alloc_sysfs_and_mask(struct iio_dev *indio_dev);
75ee708e6bSAlexandru Ardelean void iio_buffers_free_sysfs_and_mask(struct iio_dev *indio_dev);
76a980e046SJonathan Cameron
77f73f7f4dSAlexandru Ardelean #define iio_buffer_poll_addr (&iio_buffer_poll_wrapper)
78f73f7f4dSAlexandru Ardelean #define iio_buffer_read_outer_addr (&iio_buffer_read_wrapper)
799eeee3b0SMihail Chindris #define iio_buffer_write_outer_addr (&iio_buffer_write_wrapper)
80a980e046SJonathan Cameron
81a87c82e4SLars-Peter Clausen void iio_disable_all_buffers(struct iio_dev *indio_dev);
82d2f0a48fSLars-Peter Clausen void iio_buffer_wakeup_poll(struct iio_dev *indio_dev);
83218bc53dSAlexandru Ardelean void iio_device_detach_buffers(struct iio_dev *indio_dev);
84a87c82e4SLars-Peter Clausen
85a980e046SJonathan Cameron #else
86a980e046SJonathan Cameron
87a980e046SJonathan Cameron #define iio_buffer_poll_addr NULL
88f6d4033dSLars-Peter Clausen #define iio_buffer_read_outer_addr NULL
899eeee3b0SMihail Chindris #define iio_buffer_write_outer_addr NULL
90a980e046SJonathan Cameron
iio_buffers_alloc_sysfs_and_mask(struct iio_dev * indio_dev)91ee708e6bSAlexandru Ardelean static inline int iio_buffers_alloc_sysfs_and_mask(struct iio_dev *indio_dev)
923e1b6c95SLars-Peter Clausen {
933e1b6c95SLars-Peter Clausen return 0;
943e1b6c95SLars-Peter Clausen }
953e1b6c95SLars-Peter Clausen
iio_buffers_free_sysfs_and_mask(struct iio_dev * indio_dev)96ee708e6bSAlexandru Ardelean static inline void iio_buffers_free_sysfs_and_mask(struct iio_dev *indio_dev) {}
973e1b6c95SLars-Peter Clausen
iio_disable_all_buffers(struct iio_dev * indio_dev)98a87c82e4SLars-Peter Clausen static inline void iio_disable_all_buffers(struct iio_dev *indio_dev) {}
iio_buffer_wakeup_poll(struct iio_dev * indio_dev)99d2f0a48fSLars-Peter Clausen static inline void iio_buffer_wakeup_poll(struct iio_dev *indio_dev) {}
iio_device_detach_buffers(struct iio_dev * indio_dev)100218bc53dSAlexandru Ardelean static inline void iio_device_detach_buffers(struct iio_dev *indio_dev) {}
101a87c82e4SLars-Peter Clausen
102a980e046SJonathan Cameron #endif
103a980e046SJonathan Cameron
104a980e046SJonathan Cameron int iio_device_register_eventset(struct iio_dev *indio_dev);
105a980e046SJonathan Cameron void iio_device_unregister_eventset(struct iio_dev *indio_dev);
106d2f0a48fSLars-Peter Clausen void iio_device_wakeup_eventset(struct iio_dev *indio_dev);
107a980e046SJonathan Cameron
108bc2b7dabSGregor Boirie struct iio_event_interface;
109bc2b7dabSGregor Boirie bool iio_event_enabled(const struct iio_event_interface *ev_int);
110bc2b7dabSGregor Boirie
111a980e046SJonathan Cameron #endif
112