[PATCH v3 4/7] pipeline: rpi:: Add wallclock timestamp support
Kieran Bingham
kieran.bingham at ideasonboard.com
Thu Jan 9 17:17:22 CET 2025
Quoting David Plowman (2025-01-09 14:32:08)
> A ClockRecovery object is added for derived classes to use, and
> wallclock timetamps are copied into the request metadata for
> applications.
>
> In the derived class, wallclock timestamps are derived corresponding
> to the sensor timestamp, and made available to the base pipeline
> handler class.
Thanks, this looks like a clear and easy way to use this and to
facilitate implementing the same in all pipeline handlers.
But we'll deal with other pipeline handlers on top.
Reviewed-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
>
> Signed-off-by: David Plowman <david.plowman at raspberrypi.com>
> ---
> src/libcamera/pipeline/rpi/common/pipeline_base.cpp | 5 +++++
> src/libcamera/pipeline/rpi/common/pipeline_base.h | 3 +++
> src/libcamera/pipeline/rpi/vc4/vc4.cpp | 10 ++++++++--
> 3 files changed, 16 insertions(+), 2 deletions(-)
>
> diff --git a/src/libcamera/pipeline/rpi/common/pipeline_base.cpp b/src/libcamera/pipeline/rpi/common/pipeline_base.cpp
> index 4b147fdb..56f3c4df 100644
> --- a/src/libcamera/pipeline/rpi/common/pipeline_base.cpp
> +++ b/src/libcamera/pipeline/rpi/common/pipeline_base.cpp
> @@ -686,6 +686,9 @@ int PipelineHandlerBase::start(Camera *camera, const ControlList *controls)
> return ret;
> }
>
> + /* A good moment to add an initial clock sample. */
> + data->wallClockRecovery_.addSample();
> +
> /*
> * Reset the delayed controls with the gain and exposure values set by
> * the IPA.
> @@ -1510,6 +1513,8 @@ void CameraData::fillRequestMetadata(const ControlList &bufferControls, Request
> {
> request->metadata().set(controls::SensorTimestamp,
> bufferControls.get(controls::SensorTimestamp).value_or(0));
> + request->metadata().set(controls::FrameWallClock,
> + bufferControls.get(controls::FrameWallClock).value_or(0));
>
> if (cropParams_.size()) {
> std::vector<Rectangle> crops;
> diff --git a/src/libcamera/pipeline/rpi/common/pipeline_base.h b/src/libcamera/pipeline/rpi/common/pipeline_base.h
> index aae0c2f3..ca706bf3 100644
> --- a/src/libcamera/pipeline/rpi/common/pipeline_base.h
> +++ b/src/libcamera/pipeline/rpi/common/pipeline_base.h
> @@ -20,6 +20,7 @@
> #include "libcamera/internal/bayer_format.h"
> #include "libcamera/internal/camera.h"
> #include "libcamera/internal/camera_sensor.h"
> +#include "libcamera/internal/clock_recovery.h"
> #include "libcamera/internal/framebuffer.h"
> #include "libcamera/internal/media_device.h"
> #include "libcamera/internal/media_object.h"
> @@ -177,6 +178,8 @@ public:
>
> Config config_;
>
> + ClockRecovery wallClockRecovery_;
> +
> protected:
> void fillRequestMetadata(const ControlList &bufferControls,
> Request *request);
> diff --git a/src/libcamera/pipeline/rpi/vc4/vc4.cpp b/src/libcamera/pipeline/rpi/vc4/vc4.cpp
> index fd8d84b1..3d8c65c6 100644
> --- a/src/libcamera/pipeline/rpi/vc4/vc4.cpp
> +++ b/src/libcamera/pipeline/rpi/vc4/vc4.cpp
> @@ -781,9 +781,15 @@ void Vc4CameraData::unicamBufferDequeue(FrameBuffer *buffer)
> auto [ctrl, delayContext] = delayedCtrls_->get(buffer->metadata().sequence);
> /*
> * Add the frame timestamp to the ControlList for the IPA to use
> - * as it does not receive the FrameBuffer object.
> + * as it does not receive the FrameBuffer object. Also derive a
> + * corresponding wallclock value.
> */
> - ctrl.set(controls::SensorTimestamp, buffer->metadata().timestamp);
> + wallClockRecovery_.addSample();
> + uint64_t sensorTimestamp = buffer->metadata().timestamp;
> + uint64_t wallClockTimestamp = wallClockRecovery_.getOutput(sensorTimestamp / 1000);
> +
> + ctrl.set(controls::SensorTimestamp, sensorTimestamp);
> + ctrl.set(controls::FrameWallClock, wallClockTimestamp);
> bayerQueue_.push({ buffer, std::move(ctrl), delayContext });
> } else {
> embeddedQueue_.push(buffer);
> --
> 2.39.5
>
More information about the libcamera-devel
mailing list