[libcamera-devel] [PATCH v1 6/9] ipa: raspberrypi: Add line length to DeviceStatus
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Tue Oct 4 19:07:13 CEST 2022
Hi Naush,
Thank you for the patch.
On Mon, Oct 03, 2022 at 09:39:32AM +0100, Naushir Patuck via libcamera-devel wrote:
> Add a lineLength field to the DeviceStatus structure to store the line length
> used for a particular frame.
>
> Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
> src/ipa/raspberrypi/controller/device_status.cpp | 1 +
> src/ipa/raspberrypi/controller/device_status.h | 4 +++-
> src/ipa/raspberrypi/raspberrypi.cpp | 2 ++
> 3 files changed, 6 insertions(+), 1 deletion(-)
>
> diff --git a/src/ipa/raspberrypi/controller/device_status.cpp b/src/ipa/raspberrypi/controller/device_status.cpp
> index 2360a77bf1ea..c907efdd7511 100644
> --- a/src/ipa/raspberrypi/controller/device_status.cpp
> +++ b/src/ipa/raspberrypi/controller/device_status.cpp
> @@ -12,6 +12,7 @@ std::ostream &operator<<(std::ostream &out, const DeviceStatus &d)
> {
> out << "Exposure: " << d.shutterSpeed
> << " Frame length: " << d.frameLength
> + << " Line length: " << d.lineLength
> << " Gain: " << d.analogueGain;
>
> if (d.aperture)
> diff --git a/src/ipa/raspberrypi/controller/device_status.h b/src/ipa/raspberrypi/controller/device_status.h
> index 8f74e21b0c6e..4384c2149589 100644
> --- a/src/ipa/raspberrypi/controller/device_status.h
> +++ b/src/ipa/raspberrypi/controller/device_status.h
> @@ -19,7 +19,7 @@
> struct DeviceStatus {
> DeviceStatus()
> : shutterSpeed(std::chrono::seconds(0)), frameLength(0),
> - analogueGain(0.0)
> + lineLength(std::chrono::seconds(0)), analogueGain(0.0)
> {
> }
>
> @@ -29,6 +29,8 @@ struct DeviceStatus {
> libcamera::utils::Duration shutterSpeed;
> /* frame length given in number of lines */
> uint32_t frameLength;
> + /* line length for the current frame */
> + libcamera::utils::Duration lineLength;
> double analogueGain;
> /* 1.0/distance-in-metres, or 0 if unknown */
> std::optional<double> lensPosition;
> diff --git a/src/ipa/raspberrypi/raspberrypi.cpp b/src/ipa/raspberrypi/raspberrypi.cpp
> index b6289f151677..5d6b22ef6813 100644
> --- a/src/ipa/raspberrypi/raspberrypi.cpp
> +++ b/src/ipa/raspberrypi/raspberrypi.cpp
> @@ -1108,7 +1108,9 @@ void IPARPi::fillDeviceStatus(const ControlList &sensorControls)
> int32_t exposureLines = sensorControls.get(V4L2_CID_EXPOSURE).get<int32_t>();
> int32_t gainCode = sensorControls.get(V4L2_CID_ANALOGUE_GAIN).get<int32_t>();
> int32_t vblank = sensorControls.get(V4L2_CID_VBLANK).get<int32_t>();
> + int32_t hblank = sensorControls.get(V4L2_CID_HBLANK).get<int32_t>();
>
> + deviceStatus.lineLength = (mode_.width + hblank) * (1.0s / mode_.pixelRate);
> deviceStatus.shutterSpeed = helper_->exposure(exposureLines, mode_.minLineLength);
> deviceStatus.analogueGain = helper_->gain(gainCode);
> deviceStatus.frameLength = mode_.height + vblank;
--
Regards,
Laurent Pinchart
More information about the libcamera-devel
mailing list