[libcamera-devel] [PATCH v2 4/5] libcamera: pipeline: simple: Store sensor resolution in configuration

Kieran Bingham kieran.bingham at ideasonboard.com
Thu Jun 16 01:07:30 CEST 2022


Quoting Laurent Pinchart via libcamera-devel (2022-06-12 16:23:10)
> When enumerating the supported configurations, store the corresponding
> sensor resolution in the SimpleCameraData::Configuration structure and
> use it when configuring the camera, instead of hardcoding the sensor
> full resolution. This prepares for support of downscaling in the camera
> sensor.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

Sounds reasonable too, ... So the final patch probably has the magic I'm
looking for...

Reviewed-by: Kieran Bingham <kieran.bingham at ideasonboard.com>

> ---
>  src/libcamera/pipeline/simple/simple.cpp | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 
> diff --git a/src/libcamera/pipeline/simple/simple.cpp b/src/libcamera/pipeline/simple/simple.cpp
> index 3c90bdec60e0..8c48162d7ff0 100644
> --- a/src/libcamera/pipeline/simple/simple.cpp
> +++ b/src/libcamera/pipeline/simple/simple.cpp
> @@ -225,6 +225,7 @@ public:
>  
>         struct Configuration {
>                 uint32_t code;
> +               Size sensorSize;
>                 PixelFormat captureFormat;
>                 Size captureSize;
>                 std::vector<PixelFormat> outputFormats;
> @@ -542,6 +543,7 @@ void SimpleCameraData::tryPipeline(unsigned int code, const Size &size)
>  
>                 Configuration config;
>                 config.code = code;
> +               config.sensorSize = size;
>                 config.captureFormat = pixelFormat;
>                 config.captureSize = format.size;
>  
> @@ -943,7 +945,7 @@ int SimplePipelineHandler::configure(Camera *camera, CameraConfiguration *c)
>         const SimpleCameraData::Configuration *pipeConfig = config->pipeConfig();
>         V4L2SubdeviceFormat format{};
>         format.mbus_code = pipeConfig->code;
> -       format.size = data->sensor_->resolution();
> +       format.size = pipeConfig->sensorSize;
>  
>         ret = data->setupFormats(&format, V4L2Subdevice::ActiveFormat);
>         if (ret < 0)
> -- 
> Regards,
> 
> Laurent Pinchart
>


More information about the libcamera-devel mailing list