summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2024-02-29 02:32:34 +0200
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>2024-09-30 11:15:28 +0300
commitfa1b18e919beb8796809c3b25954993ac12c3255 (patch)
treed5cb8f7b1bf6fdc4fbe65a00cd91327e4a00e33c /src
parent0f6cbfe0ab8bee04180539164942f6841db5efa7 (diff)
pipeline: raspberrypi: common: Configure sensor embedded data
Now that the CameraSensor class implements support for embedded data, use the corresponding API to enable or disable the embedded data stream. This changes requires sensor kernel drivers that implement the upstream embedded data API based on V4L2 streams. As the API is under development and not merged in the upstream kernel yet, this breaks compatibility with the downstream Raspberry Pi kernel. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Diffstat (limited to 'src')
-rw-r--r--src/libcamera/pipeline/rpi/common/pipeline_base.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/src/libcamera/pipeline/rpi/common/pipeline_base.cpp b/src/libcamera/pipeline/rpi/common/pipeline_base.cpp
index 4f56bd33..496f35cc 100644
--- a/src/libcamera/pipeline/rpi/common/pipeline_base.cpp
+++ b/src/libcamera/pipeline/rpi/common/pipeline_base.cpp
@@ -530,6 +530,18 @@ int PipelineHandlerBase::configure(Camera *camera, CameraConfiguration *config)
return ret;
/*
+ * Configure embedded data on the sensor. Only check for errors when
+ * enabling embedded data, as some sensors don't support disabling it,
+ * and Unicam will simply drop the embedded data packets if we don't
+ * capture them.
+ */
+ ret = data->sensor_->setEmbeddedDataEnabled(data->sensorMetadata_);
+ if (ret && data->sensorMetadata_) {
+ LOG(RPI, Error) << "Unable to enable embedded data: " << ret;
+ return ret;
+ }
+
+ /*
* Platform specific internal stream configuration. This also assigns
* external streams which get configured below.
*/