[libcamera-devel] [PATCH v3 3/3] libcamera: pipeline: raspberrypi: Update sensor's V4L2_CID_NOTIFY_GAINS control

David Plowman david.plowman at raspberrypi.com
Thu Jan 6 15:26:13 CET 2022


Hi Laurent

Thanks for the review.

On Wed, 5 Jan 2022 at 19:47, Laurent Pinchart
<laurent.pinchart at ideasonboard.com> wrote:
>
> Hi David,
>
> Thank you for the patch.
>
> On Wed, Jan 05, 2022 at 03:55:39PM +0000, David Plowman wrote:
> > If the sensor exposes the V4L2_CID_NOTIFY_GAINS control, assume it
> > means the sensor wants to be told the latest colour gains.
> >
> > We store whether the control exists and if so its default value, to
> > save us checking for it on every frame.
> >
> > Signed-off-by: David Plowman <david.plowman at raspberrypi.com>
> > ---
> >  .../pipeline/raspberrypi/raspberrypi.cpp      | 31 +++++++++++++++++++
> >  1 file changed, 31 insertions(+)
> >
> > diff --git a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > index b5c687da..4adef952 100644
> > --- a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > +++ b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > @@ -264,6 +264,12 @@ public:
> >
> >       unsigned int dropFrameCount_;
> >
> > +     /*
> > +      * If set, this stores the value that represets a gain of one for
> > +      * the V4L2_CID_NOTIFY_GAINS control.
> > +      */
> > +     std::optional<int32_t> notifyGainsUnity_;
>
> A plain int32_t would be enough, as a zero value isn't valid. Up to
> you.

And I was trying so hard to avoid using the value 0 to have a
"special" meaning... :)

I think at this point I'm inclined to leave it as it is, unless anyone
else objects, or I might change it if I need to do another revision.

>
> > +
> >  private:
> >       void checkRequestCompleted();
> >       void fillRequestMetadata(const ControlList &bufferControls,
> > @@ -1191,6 +1197,15 @@ int PipelineHandlerRPi::registerCamera(MediaDevice *unicam, MediaDevice *isp)
> >       /* Initialize the camera properties. */
> >       data->properties_ = data->sensor_->properties();
> >
> > +     /*
> > +      * The V4L2_CID_NOTIFY_GAINS control, if present, is used to inform the
> > +      * sensor of the colour gains. It is defined to be a linear gain where
> > +      * the default value represents a gain of exactly one.
> > +      */
> > +     auto it = data->sensor_->controls().find(V4L2_CID_NOTIFY_GAINS);
> > +     if (it != data->sensor_->controls().end())
> > +             data->notifyGainsUnity_ = it->second.def().get<int32_t>();
> > +
> >       /*
> >        * Set a default value for the ScalerCropMaximum property to show
> >        * that we support its use, however, initialise it to zero because
> > @@ -1495,6 +1510,22 @@ void RPiCameraData::statsMetadataComplete(uint32_t bufferId, const ControlList &
> >       Request *request = requestQueue_.front();
> >       request->metadata().merge(controls);
> >
> > +     /*
> > +      * Inform the sensor of the latest colour gains if it has the
> > +      * V4L2_CID_NOTIFY_GAINS control (which means notifyGainsUnity_ is set).
> > +      */
> > +     if (notifyGainsUnity_ && controls.contains(libcamera::controls::ColourGains)) {
> > +             libcamera::Span<const float> colourGains = controls.get(libcamera::controls::ColourGains);
> > +             /* The control wants linear gains in the order B, Gb, Gr, R. */
> > +             ControlList ctrls(sensor_->controls());
> > +             std::array<int32_t, 4> gains = { static_cast<int32_t>(colourGains[1] * *notifyGainsUnity_),
> > +                                              *notifyGainsUnity_, *notifyGainsUnity_,
> > +                                              static_cast<int32_t>(colourGains[0] * *notifyGainsUnity_) };
>
> Let's shorten the lines a bit:
>
>                 std::array<int32_t, 4> gains{
>                         static_cast<int32_t>(colourGains[1] * *notifyGainsUnity_),
>                         *notifyGainsUnity_,
>                         *notifyGainsUnity_,
>                         static_cast<int32_t>(colourGains[0] * *notifyGainsUnity_)
>                 };

Is that fix-while-applying-able, do you think? Otherwise I'll do
another version.

Thanks again!
David

>
> Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
>
> > +             ctrls.set(V4L2_CID_NOTIFY_GAINS, Span<const int32_t>{ gains });
> > +
> > +             sensor_->setControls(&ctrls);
> > +     }
> > +
> >       state_ = State::IpaComplete;
> > +             ctrls.set(V4L2_CID_NOTIFY_GAINS, Span<const int32_t>{ gains });
> > +
> > +             sensor_->setControls(&ctrls);
> > +     }
> > +
> >       state_ = State::IpaComplete;
> >       handleState();
> >  }
>
> --
> Regards,
>
> Laurent Pinchart


More information about the libcamera-devel mailing list