42
42
* struct ade7759_state - device instance specific data
43
43
* @us: actual spi_device
44
* @work_trigger_to_ring: bh for triggered event handling
45
* @inter: used to check if new interrupt has been triggered
46
* @last_timestamp: passing timestamp from th to bh of interrupt handler
47
44
* @indio_dev: industrial I/O device structure
48
* @trig: data ready trigger registered with iio
49
45
* @tx: transmit buffer
51
47
* @buf_lock: mutex to protect tx and rx
53
49
struct ade7759_state {
54
50
struct spi_device *us;
55
struct work_struct work_trigger_to_ring;
57
51
struct iio_dev *indio_dev;
58
struct iio_trigger *trig;
61
54
struct mutex buf_lock;
63
#if defined(CONFIG_IIO_RING_BUFFER) && defined(THIS_HAS_RING_BUFFER_SUPPORT)
64
/* At the moment triggers are only used for ring buffer
65
* filling. This may change!
69
ADE7759_SCAN_ACTIVE_POWER,
75
void ade7759_remove_trigger(struct iio_dev *indio_dev);
76
int ade7759_probe_trigger(struct iio_dev *indio_dev);
78
ssize_t ade7759_read_data_from_ring(struct device *dev,
79
struct device_attribute *attr,
83
int ade7759_configure_ring(struct iio_dev *indio_dev);
84
void ade7759_unconfigure_ring(struct iio_dev *indio_dev);
86
int ade7759_initialize_ring(struct iio_ring_buffer *ring);
87
void ade7759_uninitialize_ring(struct iio_ring_buffer *ring);
88
#else /* CONFIG_IIO_RING_BUFFER */
90
static inline void ade7759_remove_trigger(struct iio_dev *indio_dev)
93
static inline int ade7759_probe_trigger(struct iio_dev *indio_dev)
99
ade7759_read_data_from_ring(struct device *dev,
100
struct device_attribute *attr,
106
static int ade7759_configure_ring(struct iio_dev *indio_dev)
110
static inline void ade7759_unconfigure_ring(struct iio_dev *indio_dev)
113
static inline int ade7759_initialize_ring(struct iio_ring_buffer *ring)
117
static inline void ade7759_uninitialize_ring(struct iio_ring_buffer *ring)
120
#endif /* CONFIG_IIO_RING_BUFFER */