2019-06-04 11:11:33 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2011-08-12 20:56:03 +04:00
/* The industrial I/O core function defs.
*
* Copyright ( c ) 2008 Jonathan Cameron
*
2011-08-30 15:41:10 +04:00
* These definitions are meant for use only within the IIO core , not individual
2011-08-12 20:56:03 +04:00
* drivers .
*/
2011-08-30 15:32:47 +04:00
# ifndef _IIO_CORE_H_
# define _IIO_CORE_H_
2012-04-13 13:24:20 +04:00
# include <linux/kernel.h>
# include <linux/device.h>
struct iio_chan_spec ;
struct iio_dev ;
2013-02-07 21:09:00 +04:00
extern struct device_type iio_device_type ;
2011-08-30 15:32:47 +04:00
2011-08-12 20:56:03 +04:00
int __iio_add_chan_devattr ( const char * postfix ,
struct iio_chan_spec const * chan ,
ssize_t ( * func ) ( struct device * dev ,
struct device_attribute * attr ,
char * buf ) ,
ssize_t ( * writefunc ) ( struct device * dev ,
struct device_attribute * attr ,
const char * buf ,
size_t len ) ,
2011-09-02 20:14:41 +04:00
u64 mask ,
2013-09-08 17:57:00 +04:00
enum iio_shared_by shared_by ,
2011-08-12 20:56:03 +04:00
struct device * dev ,
struct list_head * attr_list ) ;
2013-10-07 15:50:00 +04:00
void iio_free_chan_devattr_list ( struct list_head * attr_list ) ;
2011-08-12 20:56:03 +04:00
2014-04-29 03:51:00 +04:00
ssize_t iio_format_value ( char * buf , unsigned int type , int size , int * vals ) ;
2013-10-07 18:11:00 +04:00
2011-08-12 20:56:03 +04:00
/* Event interface flags */
# define IIO_BUSY_BIT_POS 1
2011-08-30 15:32:47 +04:00
2011-09-21 14:15:55 +04:00
# ifdef CONFIG_IIO_BUFFER
2011-08-30 15:32:47 +04:00
struct poll_table_struct ;
2017-07-03 13:39:46 +03:00
__poll_t iio_buffer_poll ( struct file * filp ,
2011-09-21 14:15:57 +04:00
struct poll_table_struct * wait ) ;
2019-12-11 13:43:00 +03:00
ssize_t iio_buffer_read_outer ( struct file * filp , char __user * buf ,
size_t n , loff_t * f_ps ) ;
2011-08-30 15:32:47 +04:00
2014-11-26 20:55:12 +03:00
int iio_buffer_alloc_sysfs_and_mask ( struct iio_dev * indio_dev ) ;
void iio_buffer_free_sysfs_and_mask ( struct iio_dev * indio_dev ) ;
2011-08-30 15:32:47 +04:00
2011-09-21 14:15:57 +04:00
# define iio_buffer_poll_addr (&iio_buffer_poll)
2019-12-11 13:43:00 +03:00
# define iio_buffer_read_outer_addr (&iio_buffer_read_outer)
2011-08-30 15:32:47 +04:00
2013-09-19 00:02:00 +04:00
void iio_disable_all_buffers ( struct iio_dev * indio_dev ) ;
2013-10-04 15:07:00 +04:00
void iio_buffer_wakeup_poll ( struct iio_dev * indio_dev ) ;
2013-09-19 00:02:00 +04:00
2011-08-30 15:32:47 +04:00
# else
2011-09-21 14:15:57 +04:00
# define iio_buffer_poll_addr NULL
2019-12-11 13:43:00 +03:00
# define iio_buffer_read_outer_addr NULL
2011-08-30 15:32:47 +04:00
2014-11-26 20:55:12 +03:00
static inline int iio_buffer_alloc_sysfs_and_mask ( struct iio_dev * indio_dev )
{
return 0 ;
}
static inline void iio_buffer_free_sysfs_and_mask ( struct iio_dev * indio_dev ) { }
2013-09-19 00:02:00 +04:00
static inline void iio_disable_all_buffers ( struct iio_dev * indio_dev ) { }
2013-10-04 15:07:00 +04:00
static inline void iio_buffer_wakeup_poll ( struct iio_dev * indio_dev ) { }
2013-09-19 00:02:00 +04:00
2011-08-30 15:32:47 +04:00
# endif
2012-01-03 17:59:38 +04:00
int iio_device_register_eventset ( struct iio_dev * indio_dev ) ;
void iio_device_unregister_eventset ( struct iio_dev * indio_dev ) ;
2013-10-04 15:07:00 +04:00
void iio_device_wakeup_eventset ( struct iio_dev * indio_dev ) ;
2012-01-03 17:59:38 +04:00
int iio_event_getfd ( struct iio_dev * indio_dev ) ;
2016-03-09 21:05:49 +03:00
struct iio_event_interface ;
bool iio_event_enabled ( const struct iio_event_interface * ev_int ) ;
2011-08-30 15:32:47 +04:00
# endif