[libcamera-devel] [PATCH 4/9] libcamera: camera_sensor: Verify flips support
Jacopo Mondi
jacopo at jmondi.org
Thu Nov 24 13:12:15 CET 2022
During the camera sensor driver validation, verify if the sensor
supports horizontal and vertical flips and store a flag as
CameraSensor::supportFlips_ class member.
The flag will be later inspected when applying flips.
Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>
---
include/libcamera/internal/camera_sensor.h | 1 +
src/libcamera/camera_sensor.cpp | 15 ++++++++++++++-
2 files changed, 15 insertions(+), 1 deletion(-)
diff --git a/include/libcamera/internal/camera_sensor.h b/include/libcamera/internal/camera_sensor.h
index b9f4d7867854..878f3c28a3c9 100644
--- a/include/libcamera/internal/camera_sensor.h
+++ b/include/libcamera/internal/camera_sensor.h
@@ -101,6 +101,7 @@ private:
Size pixelArraySize_;
Rectangle activeArea_;
const BayerFormat *bayerFormat_;
+ bool supportFlips_;
ControlList properties_;
diff --git a/src/libcamera/camera_sensor.cpp b/src/libcamera/camera_sensor.cpp
index cbac9e7801ae..3afcbc482095 100644
--- a/src/libcamera/camera_sensor.cpp
+++ b/src/libcamera/camera_sensor.cpp
@@ -57,7 +57,8 @@ LOG_DEFINE_CATEGORY(CameraSensor)
*/
CameraSensor::CameraSensor(const MediaEntity *entity)
: entity_(entity), pad_(UINT_MAX), staticProps_(nullptr),
- bayerFormat_(nullptr), properties_(properties::properties)
+ bayerFormat_(nullptr), supportFlips_(false),
+ properties_(properties::properties)
{
}
@@ -271,6 +272,18 @@ int CameraSensor::validateSensorDriver()
}
}
+ /* Verify if sensor supports horizontal/vertical flips. */
+ const struct v4l2_query_ext_ctrl *hflipInfo = subdev_->controlInfo(V4L2_CID_HFLIP);
+ const struct v4l2_query_ext_ctrl *vflipInfo = subdev_->controlInfo(V4L2_CID_VFLIP);
+ if (hflipInfo && vflipInfo &&
+ !(hflipInfo->flags & V4L2_CTRL_FLAG_READ_ONLY) &&
+ !(vflipInfo->flags & V4L2_CTRL_FLAG_READ_ONLY))
+ supportFlips_ = true;
+
+ if (!supportFlips_)
+ LOG(CameraSensor, Warning)
+ << "Camera sensor does not support horizontal/vertical flip";
+
/*
* Make sure the required selection targets are supported.
*
--
2.38.1
More information about the libcamera-devel
mailing list