[libcamera-devel] [PATCH v2 1/4] ipa: raspberrypi: Add sensor mode limits to CameraMode

David Plowman david.plowman at raspberrypi.com
Mon Mar 27 15:18:33 CEST 2023


Hi Naush

Thanks for the patch.

On Mon, 27 Mar 2023 at 10:34, Naushir Patuck via libcamera-devel
<libcamera-devel at lists.libcamera.org> wrote:
>
> Add fields in the CameraMode structure to capture the mode specific
> limits for analogue gain and shutter speed. For convenience, also add
> fields for minimum and maximum frame durations.
>
> Populate these new fields when setting up the CameraMode structure.
>
> Signed-off-by: Naushir Patuck <naush at raspberrypi.com>

Reviewed-by: David Plowman <david.plowman at raspberrypi.com>

Thanks!
David

> ---
>  src/ipa/raspberrypi/controller/camera_mode.h | 10 +++++++++-
>  src/ipa/raspberrypi/raspberrypi.cpp          | 16 ++++++++++++++++
>  2 files changed, 25 insertions(+), 1 deletion(-)
>
> diff --git a/src/ipa/raspberrypi/controller/camera_mode.h b/src/ipa/raspberrypi/controller/camera_mode.h
> index 94c51ddf1686..63b1177852d0 100644
> --- a/src/ipa/raspberrypi/controller/camera_mode.h
> +++ b/src/ipa/raspberrypi/controller/camera_mode.h
> @@ -36,9 +36,11 @@ struct CameraMode {
>         double scaleY;
>         /* scaling of the noise compared to the native sensor mode */
>         double noiseFactor;
> -       /* minimum and maximum line time */
> +       /* minimum and maximum line time and frame durations */
>         libcamera::utils::Duration minLineLength;
>         libcamera::utils::Duration maxLineLength;
> +       libcamera::utils::Duration minFrameDuration;
> +       libcamera::utils::Duration maxFrameDuration;
>         /* any camera transform *not* reflected already in the camera tuning */
>         libcamera::Transform transform;
>         /* minimum and maximum frame lengths in units of lines */
> @@ -48,4 +50,10 @@ struct CameraMode {
>         double sensitivity;
>         /* pixel clock rate */
>         uint64_t pixelRate;
> +       /* Mode specific shutter speed limits */
> +       libcamera::utils::Duration minShutter;
> +       libcamera::utils::Duration maxShutter;
> +       /* Mode specific analogue gain limits */
> +       double minAnalogueGain;
> +       double maxAnalogueGain;
>  };
> diff --git a/src/ipa/raspberrypi/raspberrypi.cpp b/src/ipa/raspberrypi/raspberrypi.cpp
> index 1375795568e2..3f1afb846420 100644
> --- a/src/ipa/raspberrypi/raspberrypi.cpp
> +++ b/src/ipa/raspberrypi/raspberrypi.cpp
> @@ -407,11 +407,27 @@ void IPARPi::setMode(const IPACameraSensorInfo &sensorInfo)
>         mode_.minFrameLength = sensorInfo.minFrameLength;
>         mode_.maxFrameLength = sensorInfo.maxFrameLength;
>
> +       /* Store these for convenience. */
> +       mode_.minFrameDuration = mode_.minFrameLength * mode_.minLineLength;
> +       mode_.maxFrameDuration = mode_.maxFrameLength * mode_.maxLineLength;
> +
>         /*
>          * Some sensors may have different sensitivities in different modes;
>          * the CamHelper will know the correct value.
>          */
>         mode_.sensitivity = helper_->getModeSensitivity(mode_);
> +
> +       const ControlInfo &gainCtrl = sensorCtrls_.at(V4L2_CID_ANALOGUE_GAIN);
> +       const ControlInfo &shutterCtrl = sensorCtrls_.at(V4L2_CID_EXPOSURE);
> +
> +       mode_.minAnalogueGain = helper_->gain(gainCtrl.min().get<int32_t>());
> +       mode_.maxAnalogueGain = helper_->gain(gainCtrl.max().get<int32_t>());
> +
> +       /* Shutter speed is calculated based on the limits of the frame durations. */
> +       mode_.minShutter = helper_->exposure(shutterCtrl.min().get<int32_t>(), mode_.minLineLength);
> +       mode_.maxShutter = Duration::max();
> +       helper_->getBlanking(mode_.maxShutter,
> +                            mode_.minFrameDuration, mode_.maxFrameDuration);
>  }
>
>  int IPARPi::configure(const IPACameraSensorInfo &sensorInfo, const IPAConfig &ipaConfig,
> --
> 2.34.1
>


More information about the libcamera-devel mailing list