[PATCH RFC 8/9] iio: trigger: Add new API iio_trigger_store_time()

From: Gyeyoung Baek
Date: Mon May 19 2025 - 10:28:05 EST


Now the trigger can simply call `iio_trigger_store_time()`
to pass a timestamp to the consumer.

Signed-off-by: Gyeyoung Baek <gye976@xxxxxxxxx>
---
drivers/iio/industrialio-trigger.c | 16 ++++++++++++++++
include/linux/iio/trigger.h | 2 ++
2 files changed, 18 insertions(+)

diff --git a/drivers/iio/industrialio-trigger.c b/drivers/iio/industrialio-trigger.c
index f394933b9d0a..a961156f0eeb 100644
--- a/drivers/iio/industrialio-trigger.c
+++ b/drivers/iio/industrialio-trigger.c
@@ -288,6 +288,22 @@ static void iio_trigger_put_irq(struct iio_trigger *trig, int irq)
clear_bit(irq - trig->subirq_base, trig->pool);
}

+void iio_trigger_store_time(struct iio_trigger *trig)
+{
+ WARN_ON(!trig->early_timestamp);
+
+ for (int i = 0; i < CONFIG_IIO_CONSUMERS_PER_TRIGGER; i++) {
+ struct iio_poll_func *pf = trig->consumer_pf[i];
+
+ if (pf) {
+ WARN_ON(pf->timestamp_type != IIO_TIMESTAMP_TYPE_TRIGGER);
+
+ pf->timestamp = iio_get_time_ns(pf->indio_dev);
+ }
+ }
+}
+EXPORT_SYMBOL(iio_trigger_store_time);
+
static int iio_trigger_attach_timestamp(struct iio_trigger *trig,
struct iio_poll_func *pf)
{
diff --git a/include/linux/iio/trigger.h b/include/linux/iio/trigger.h
index f3b89a1e0318..8048a2c69971 100644
--- a/include/linux/iio/trigger.h
+++ b/include/linux/iio/trigger.h
@@ -187,6 +187,8 @@ int iio_validate_own_trigger(struct iio_dev *idev, struct iio_trigger *trig);
int iio_trigger_validate_own_device(struct iio_trigger *trig,
struct iio_dev *indio_dev);

+void iio_trigger_store_time(struct iio_trigger *trig);
+
#else
struct iio_trigger;
struct iio_trigger_ops;

--
2.43.0