Lines Matching refs:iio_dev
37 struct iio_dev;
50 ssize_t (*read)(struct iio_dev *, uintptr_t private,
52 ssize_t (*write)(struct iio_dev *, uintptr_t private,
77 int (*set)(struct iio_dev *, const struct iio_chan_spec *, unsigned int);
78 int (*get)(struct iio_dev *, const struct iio_chan_spec *);
81 ssize_t iio_enum_available_read(struct iio_dev *indio_dev,
83 ssize_t iio_enum_read(struct iio_dev *indio_dev,
85 ssize_t iio_enum_write(struct iio_dev *indio_dev,
131 ssize_t iio_show_mount_matrix(struct iio_dev *indio_dev, uintptr_t priv,
137 (iio_get_mount_matrix_t)(const struct iio_dev *indio_dev,
318 s64 iio_get_time_ns(const struct iio_dev *indio_dev);
319 unsigned int iio_get_time_res(const struct iio_dev *indio_dev);
400 int (*read_raw)(struct iio_dev *indio_dev,
406 int (*read_raw_multi)(struct iio_dev *indio_dev,
413 int (*read_avail)(struct iio_dev *indio_dev,
420 int (*write_raw)(struct iio_dev *indio_dev,
426 int (*write_raw_get_fmt)(struct iio_dev *indio_dev,
430 int (*read_event_config)(struct iio_dev *indio_dev,
435 int (*write_event_config)(struct iio_dev *indio_dev,
441 int (*read_event_value)(struct iio_dev *indio_dev,
447 int (*write_event_value)(struct iio_dev *indio_dev,
453 int (*validate_trigger)(struct iio_dev *indio_dev,
455 int (*update_scan_mode)(struct iio_dev *indio_dev,
457 int (*debugfs_reg_access)(struct iio_dev *indio_dev,
460 int (*of_xlate)(struct iio_dev *indio_dev,
462 int (*hwfifo_set_watermark)(struct iio_dev *indio_dev, unsigned val);
463 int (*hwfifo_flush_to_buffer)(struct iio_dev *indio_dev,
478 int (*preenable)(struct iio_dev *);
479 int (*postenable)(struct iio_dev *);
480 int (*predisable)(struct iio_dev *);
481 int (*postdisable)(struct iio_dev *);
482 bool (*validate_scan_mask)(struct iio_dev *indio_dev,
528 struct iio_dev { struct
576 *iio_find_channel_from_si(struct iio_dev *indio_dev, int si); argument
583 int __iio_device_register(struct iio_dev *indio_dev, struct module *this_mod);
584 void iio_device_unregister(struct iio_dev *indio_dev);
603 int __devm_iio_device_register(struct device *dev, struct iio_dev *indio_dev,
605 void devm_iio_device_unregister(struct device *dev, struct iio_dev *indio_dev);
606 int iio_push_event(struct iio_dev *indio_dev, u64 ev_code, s64 timestamp);
607 int iio_device_claim_direct_mode(struct iio_dev *indio_dev);
608 void iio_device_release_direct_mode(struct iio_dev *indio_dev);
616 static inline void iio_device_put(struct iio_dev *indio_dev) in iio_device_put()
626 static inline clockid_t iio_device_get_clock(const struct iio_dev *indio_dev) in iio_device_get_clock()
637 static inline struct iio_dev *dev_to_iio_dev(struct device *dev) in dev_to_iio_dev()
639 return container_of(dev, struct iio_dev, dev); in dev_to_iio_dev()
648 static inline struct iio_dev *iio_device_get(struct iio_dev *indio_dev) in iio_device_get()
662 static inline void iio_device_set_drvdata(struct iio_dev *indio_dev, void *data) in iio_device_set_drvdata()
673 static inline void *iio_device_get_drvdata(struct iio_dev *indio_dev) in iio_device_get_drvdata()
680 struct iio_dev *iio_device_alloc(int sizeof_priv);
682 static inline void *iio_priv(const struct iio_dev *indio_dev) in iio_priv()
684 return (char *)indio_dev + ALIGN(sizeof(struct iio_dev), IIO_ALIGN); in iio_priv()
687 static inline struct iio_dev *iio_priv_to_dev(void *priv) in iio_priv_to_dev()
689 return (struct iio_dev *)((char *)priv - in iio_priv_to_dev()
690 ALIGN(sizeof(struct iio_dev), IIO_ALIGN)); in iio_priv_to_dev()
693 void iio_device_free(struct iio_dev *indio_dev);
695 struct iio_dev *devm_iio_device_alloc(struct device *dev, int sizeof_priv);
696 void devm_iio_device_free(struct device *dev, struct iio_dev *indio_dev);
705 static inline bool iio_buffer_enabled(struct iio_dev *indio_dev) in iio_buffer_enabled()
717 static inline struct dentry *iio_get_debugfs_dentry(struct iio_dev *indio_dev) in iio_get_debugfs_dentry()
722 static inline struct dentry *iio_get_debugfs_dentry(struct iio_dev *indio_dev) in iio_get_debugfs_dentry()