| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | /* The industrial I/O core - generic buffer interfaces.
 | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2008 Jonathan Cameron | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify it | 
					
						
							|  |  |  |  * under the terms of the GNU General Public License version 2 as published by | 
					
						
							|  |  |  |  * the Free Software Foundation. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:56 +01:00
										 |  |  | #ifndef _IIO_BUFFER_GENERIC_H_
 | 
					
						
							|  |  |  | #define _IIO_BUFFER_GENERIC_H_
 | 
					
						
							| 
									
										
										
										
											2011-09-02 17:14:40 +01:00
										 |  |  | #include <linux/sysfs.h>
 | 
					
						
							| 
									
										
										
										
											2012-04-25 15:54:58 +01:00
										 |  |  | #include <linux/iio/iio.h>
 | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:55 +01:00
										 |  |  | #ifdef CONFIG_IIO_BUFFER
 | 
					
						
							| 
									
										
										
										
											2010-07-11 16:39:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | struct iio_buffer; | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * struct iio_buffer_access_funcs - access functions for buffers. | 
					
						
							|  |  |  |  * @store_to:		actually store stuff to the buffer | 
					
						
							| 
									
										
										
										
											2011-12-12 09:33:14 +01:00
										 |  |  |  * @read_first_n:	try to get a specified number of bytes (must exist) | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  * @request_update:	if a parameter change has been marked, update underlying | 
					
						
							|  |  |  |  *			storage. | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  * @get_bytes_per_datum:get current bytes per datum | 
					
						
							|  |  |  |  * @set_bytes_per_datum:set number of bytes per datum | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * @get_length:		get number of datums in buffer | 
					
						
							|  |  |  |  * @set_length:		set number of datums in buffer | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * The purpose of this structure is to make the buffer element | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  * modular as event for a given driver, different usecases may require | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * different buffer designs (space efficiency vs speed for example). | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * It is worth noting that a given buffer implementation may only support a | 
					
						
							|  |  |  |  * small proportion of these functions.  The core code 'should' cope fine with | 
					
						
							|  |  |  |  * any of them not existing. | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | struct iio_buffer_access_funcs { | 
					
						
							| 
									
										
										
										
											2012-09-04 13:38:00 +01:00
										 |  |  | 	int (*store_to)(struct iio_buffer *buffer, u8 *data); | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | 	int (*read_first_n)(struct iio_buffer *buffer, | 
					
						
							| 
									
										
										
										
											2011-04-15 18:55:55 +01:00
										 |  |  | 			    size_t n, | 
					
						
							| 
									
										
										
										
											2011-05-18 14:41:02 +01:00
										 |  |  | 			    char __user *buf); | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | 	int (*request_update)(struct iio_buffer *buffer); | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | 	int (*get_bytes_per_datum)(struct iio_buffer *buffer); | 
					
						
							|  |  |  | 	int (*set_bytes_per_datum)(struct iio_buffer *buffer, size_t bpd); | 
					
						
							|  |  |  | 	int (*get_length)(struct iio_buffer *buffer); | 
					
						
							|  |  |  | 	int (*set_length)(struct iio_buffer *buffer, int length); | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * struct iio_buffer - general buffer structure | 
					
						
							|  |  |  |  * @length:		[DEVICE] number of datums in buffer | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  * @bytes_per_datum:	[DEVICE] size of individual datum including timestamp | 
					
						
							| 
									
										
										
										
											2010-08-31 11:32:52 +02:00
										 |  |  |  * @scan_el_attrs:	[DRIVER] control of scan elements if that scan mode | 
					
						
							|  |  |  |  *			control method is used | 
					
						
							|  |  |  |  * @scan_mask:		[INTERN] bitmask used in masking scan mode elements | 
					
						
							|  |  |  |  * @scan_timestamp:	[INTERN] does the scan mode include a timestamp | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * @access:		[DRIVER] buffer access functions associated with the | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  |  *			implementation. | 
					
						
							| 
									
										
										
										
											2011-12-05 22:18:30 +00:00
										 |  |  |  * @scan_el_dev_attr_list:[INTERN] list of scan element related attributes. | 
					
						
							|  |  |  |  * @scan_el_group:	[DRIVER] attribute group for those attributes not | 
					
						
							|  |  |  |  *			created from the iio_chan_info array. | 
					
						
							|  |  |  |  * @pollq:		[INTERN] wait queue to allow for polling on the buffer. | 
					
						
							|  |  |  |  * @stufftoread:	[INTERN] flag to indicate new data. | 
					
						
							| 
									
										
										
										
											2011-12-05 21:37:14 +00:00
										 |  |  |  * @demux_list:		[INTERN] list of operations required to demux the scan. | 
					
						
							|  |  |  |  * @demux_bounce:	[INTERN] buffer for doing gather from incoming scan. | 
					
						
							| 
									
										
										
										
											2012-06-30 20:06:00 +01:00
										 |  |  |  * @buffer_list:	[INTERN] entry in the devices list of current buffers. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | struct iio_buffer { | 
					
						
							| 
									
										
										
										
											2011-05-18 14:42:34 +01:00
										 |  |  | 	int					length; | 
					
						
							|  |  |  | 	int					bytes_per_datum; | 
					
						
							|  |  |  | 	struct attribute_group			*scan_el_attrs; | 
					
						
							| 
									
										
										
										
											2011-09-02 17:14:38 +01:00
										 |  |  | 	long					*scan_mask; | 
					
						
							| 
									
										
										
										
											2011-05-18 14:42:34 +01:00
										 |  |  | 	bool					scan_timestamp; | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | 	const struct iio_buffer_access_funcs	*access; | 
					
						
							| 
									
										
										
										
											2011-05-18 14:42:34 +01:00
										 |  |  | 	struct list_head			scan_el_dev_attr_list; | 
					
						
							| 
									
										
										
										
											2011-09-02 17:14:40 +01:00
										 |  |  | 	struct attribute_group			scan_el_group; | 
					
						
							| 
									
										
										
										
											2011-05-18 14:42:34 +01:00
										 |  |  | 	wait_queue_head_t			pollq; | 
					
						
							|  |  |  | 	bool					stufftoread; | 
					
						
							| 
									
										
										
										
											2011-08-30 12:32:47 +01:00
										 |  |  | 	const struct attribute_group *attrs; | 
					
						
							| 
									
										
										
										
											2011-12-05 21:37:14 +00:00
										 |  |  | 	struct list_head			demux_list; | 
					
						
							|  |  |  | 	unsigned char				*demux_bounce; | 
					
						
							| 
									
										
										
										
											2012-06-30 20:06:00 +01:00
										 |  |  | 	struct list_head			buffer_list; | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-30 20:06:00 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * iio_update_buffers() - add or remove buffer from active list | 
					
						
							|  |  |  |  * @indio_dev:		device to add buffer to | 
					
						
							|  |  |  |  * @insert_buffer:	buffer to insert | 
					
						
							|  |  |  |  * @remove_buffer:	buffer_to_remove | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Note this will tear down the all buffering and build it up again | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int iio_update_buffers(struct iio_dev *indio_dev, | 
					
						
							|  |  |  | 		       struct iio_buffer *insert_buffer, | 
					
						
							|  |  |  | 		       struct iio_buffer *remove_buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_init() - Initialize the buffer structure | 
					
						
							| 
									
										
										
										
											2012-07-01 00:47:43 +02:00
										 |  |  |  * @buffer:		buffer to be initialized | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-12-05 22:18:29 +00:00
										 |  |  | void iio_buffer_init(struct iio_buffer *buffer); | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 22:18:29 +00:00
										 |  |  | int iio_scan_mask_query(struct iio_dev *indio_dev, | 
					
						
							|  |  |  | 			struct iio_buffer *buffer, int bit); | 
					
						
							| 
									
										
										
										
											2010-08-31 11:32:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * iio_scan_mask_set() - set particular bit in the scan mask | 
					
						
							| 
									
										
										
										
											2012-07-01 00:47:43 +02:00
										 |  |  |  * @indio_dev		IIO device structure | 
					
						
							|  |  |  |  * @buffer:		the buffer whose scan mask we are interested in | 
					
						
							|  |  |  |  * @bit:		the bit to be set. | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-12-05 22:18:29 +00:00
										 |  |  | int iio_scan_mask_set(struct iio_dev *indio_dev, | 
					
						
							|  |  |  | 		      struct iio_buffer *buffer, int bit); | 
					
						
							| 
									
										
										
										
											2010-08-31 11:32:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 21:37:14 +00:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2012-06-30 20:06:00 +01:00
										 |  |  |  * iio_push_to_buffers() - push to a registered buffer. | 
					
						
							|  |  |  |  * @indio_dev:		iio_dev structure for device. | 
					
						
							|  |  |  |  * @data:		Full scan. | 
					
						
							| 
									
										
										
										
											2011-12-05 21:37:14 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-06-30 20:06:00 +01:00
										 |  |  | int iio_push_to_buffers(struct iio_dev *indio_dev, unsigned char *data); | 
					
						
							| 
									
										
										
										
											2011-12-05 21:37:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | int iio_update_demux(struct iio_dev *indio_dev); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_register() - register the buffer with IIO core | 
					
						
							| 
									
										
										
										
											2012-07-01 00:47:43 +02:00
										 |  |  |  * @indio_dev:		device with the buffer to be registered | 
					
						
							|  |  |  |  * @channels:		the channel descriptions used to construct buffer | 
					
						
							|  |  |  |  * @num_channels:	the number of channels | 
					
						
							| 
									
										
										
										
											2011-05-18 14:40:51 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | int iio_buffer_register(struct iio_dev *indio_dev, | 
					
						
							|  |  |  | 			const struct iio_chan_spec *channels, | 
					
						
							|  |  |  | 			int num_channels); | 
					
						
							| 
									
										
										
										
											2011-05-18 14:40:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_unregister() - unregister the buffer from IIO core | 
					
						
							| 
									
										
										
										
											2012-07-01 00:47:43 +02:00
										 |  |  |  * @indio_dev:		the device with the buffer to be unregistered | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | void iio_buffer_unregister(struct iio_dev *indio_dev); | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_read_length() - attr func to get number of datums in the buffer | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | ssize_t iio_buffer_read_length(struct device *dev, | 
					
						
							|  |  |  | 			       struct device_attribute *attr, | 
					
						
							|  |  |  | 			       char *buf); | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_write_length() - attr func to set number of datums in the buffer | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | ssize_t iio_buffer_write_length(struct device *dev, | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 			      struct device_attribute *attr, | 
					
						
							|  |  |  | 			      const char *buf, | 
					
						
							|  |  |  | 			      size_t len); | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_store_enable() - attr to turn the buffer on | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | ssize_t iio_buffer_store_enable(struct device *dev, | 
					
						
							|  |  |  | 				struct device_attribute *attr, | 
					
						
							|  |  |  | 				const char *buf, | 
					
						
							|  |  |  | 				size_t len); | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  |  * iio_buffer_show_enable() - attr to see if the buffer is on | 
					
						
							| 
									
										
										
										
											2010-09-04 17:54:45 +01:00
										 |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | ssize_t iio_buffer_show_enable(struct device *dev, | 
					
						
							|  |  |  | 			       struct device_attribute *attr, | 
					
						
							|  |  |  | 			       char *buf); | 
					
						
							|  |  |  | #define IIO_BUFFER_LENGTH_ATTR DEVICE_ATTR(length, S_IRUGO | S_IWUSR,	\
 | 
					
						
							|  |  |  | 					   iio_buffer_read_length,	\ | 
					
						
							|  |  |  | 					   iio_buffer_write_length) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define IIO_BUFFER_ENABLE_ATTR DEVICE_ATTR(enable, S_IRUGO | S_IWUSR,	\
 | 
					
						
							|  |  |  | 					   iio_buffer_show_enable,	\ | 
					
						
							|  |  |  | 					   iio_buffer_store_enable) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int iio_sw_buffer_preenable(struct iio_dev *indio_dev); | 
					
						
							| 
									
										
										
										
											2011-05-18 14:42:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-09 10:00:00 +01:00
										 |  |  | bool iio_validate_scan_mask_onehot(struct iio_dev *indio_dev, | 
					
						
							|  |  |  | 	const unsigned long *mask); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:55 +01:00
										 |  |  | #else /* CONFIG_IIO_BUFFER */
 | 
					
						
							| 
									
										
										
										
											2011-05-18 14:40:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | static inline int iio_buffer_register(struct iio_dev *indio_dev, | 
					
						
							| 
									
										
										
										
											2012-11-13 11:48:00 +00:00
										 |  |  | 					   const struct iio_chan_spec *channels, | 
					
						
							| 
									
										
										
										
											2011-08-30 12:41:14 +01:00
										 |  |  | 					   int num_channels) | 
					
						
							| 
									
										
										
										
											2011-05-18 14:40:51 +01:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:57 +01:00
										 |  |  | static inline void iio_buffer_unregister(struct iio_dev *indio_dev) | 
					
						
							| 
									
										
										
										
											2012-06-18 20:33:03 +02:00
										 |  |  | {} | 
					
						
							| 
									
										
										
										
											2010-07-11 16:39:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:55 +01:00
										 |  |  | #endif /* CONFIG_IIO_BUFFER */
 | 
					
						
							| 
									
										
										
										
											2009-08-18 18:06:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 11:15:56 +01:00
										 |  |  | #endif /* _IIO_BUFFER_GENERIC_H_ */
 |