xref: /openbmc/linux/drivers/iio/iio_core.h (revision 03ab8e6297acd1bc0eedaa050e2a1635c576fd11)
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