[libcamera-devel] [PATCH v2 4/4] libcamera: rkisp1: Fix enumeration of RAW formats
Jacopo Mondi
jacopo.mondi at ideasonboard.com
Wed Feb 22 16:19:17 CET 2023
The current implementation enumerates a single RAW format (the sensor's
resolution) and does that regardless of what role the
CameraConfiguration has been generated for.
Fix this by:
- Enumerate RAW StreamFormats only when the requested role is
StreamRole::Raw
- Add all the sensor's provided resolutions that fit the video device
output maximum size
Signed-off-by: Jacopo Mondi <jacopo.mondi at ideasonboard.com>
---
src/libcamera/pipeline/rkisp1/rkisp1_path.cpp | 19 +++++++++++++++++--
1 file changed, 17 insertions(+), 2 deletions(-)
diff --git a/src/libcamera/pipeline/rkisp1/rkisp1_path.cpp b/src/libcamera/pipeline/rkisp1/rkisp1_path.cpp
index a27ac6fc35cb..0e4d76677732 100644
--- a/src/libcamera/pipeline/rkisp1/rkisp1_path.cpp
+++ b/src/libcamera/pipeline/rkisp1/rkisp1_path.cpp
@@ -150,18 +150,33 @@ RkISP1Path::generateConfiguration(const CameraSensor *sensor,
for (const auto &format : streamFormats_) {
const PixelFormatInfo &info = PixelFormatInfo::info(format);
+ /* Populate stream formats for non-RAW configurations. */
if (info.colourEncoding != PixelFormatInfo::ColourEncodingRAW) {
+ if (role == StreamRole::Raw)
+ continue;
+
streamFormats[format] = { { minResolution, maxResolution } };
continue;
}
- /* Skip raw formats not supported by the sensor. */
+ /* Skip RAW formats for non-raw roles. */
+ if (role != StreamRole::Raw)
+ continue;
+
+ /* Populate stream formats for RAW configurations. */
uint32_t mbusCode = formatToMediaBus.at(format);
if (std::find(mbusCodes.begin(), mbusCodes.end(), mbusCode) ==
mbusCodes.end())
+ /* Skip formats not supported by sensor. */
continue;
- streamFormats[format] = { { resolution, resolution } };
+ /* Add all the RAW sizes the sensor can produce for this code. */
+ for (const auto &rawSize : sensor->sizes(mbusCode)) {
+ if (rawSize > maxResolution_)
+ continue;
+
+ streamFormats[format].push_back({ rawSize, rawSize });
+ }
/*
* Store the raw format with the highest bits per pixel for
--
2.39.0
More information about the libcamera-devel
mailing list