[libcamera-devel] [PATCH 2/2] pipeline: raspberrypi: Use a default format for ISP::Output0
Naushir Patuck
naush at raspberrypi.com
Sat Mar 13 22:58:43 CET 2021
Hi Laurent,
On Sat, 13 Mar 2021 at 20:16, Laurent Pinchart <
laurent.pinchart at ideasonboard.com> wrote:
> Hi Naush,
>
> Thank you for the patch.
>
> On Sat, Mar 13, 2021 at 10:27:41AM +0000, Naushir Patuck wrote:
> > If the ISP::Output1 stream has not been configured, we must enable it
>
> Did you mean Output0 ?
>
> > with a default format and resolution for internal use. This is to allow
> > the pipeline handler data flow to be consistent, and allow the IPA to
> > receive statistics for the frame.
> >
> > Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
> > ---
> > .../pipeline/raspberrypi/raspberrypi.cpp | 30 ++++++++++++++++++-
> > 1 file changed, 29 insertions(+), 1 deletion(-)
> >
> > diff --git a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > index 9847e926b048..5cc04ce4eb92 100644
> > --- a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > +++ b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > @@ -625,7 +625,7 @@ int PipelineHandlerRPi::configure(Camera *camera,
> CameraConfiguration *config)
> > * StreamConfiguration appropriately.
> > */
> > V4L2DeviceFormat format;
> > - bool output1Set = false;
> > + bool output0Set = false, output1Set = false;
> > for (unsigned i = 0; i < config->size(); i++) {
> > StreamConfiguration &cfg = config->at(i);
> >
> > @@ -662,6 +662,34 @@ int PipelineHandlerRPi::configure(Camera *camera,
> CameraConfiguration *config)
> >
> > if (i != maxIndex)
> > output1Set = true;
> > + else
> > + output0Set = true;
> > + }
> > +
> > + /*
> > + * If ISP::Output0 stream has not been configured by the
> application,
> > + * we must allow the hardware to generate an output so that the
> data
> > + * flow in the pipeline handler remains consistent, and we still
> generate
> > + * statistics for the IPA to use. So enable the output at a very
> low
> > + * resolution for internal use.
> > + *
> > + * \todo Allow the pipeline to work correctly without Output0 and
> only
> > + * statistics coming from the hardware.
> > + */
> > + if (!output0Set) {
> > + maxSize = Size(320, 240);
> > + format = {};
> > + format.size = maxSize;
> > + format.fourcc =
> V4L2PixelFormat::fromPixelFormat(formats::YUV420, false);
> > + ret = data->isp_[Isp::Output0].dev()->setFormat(&format);
> > + if (ret) {
> > + LOG(RPI, Error) << "Failed to set default format
> on ISP Output0: "
> > + << ret;
>
> Minor comment, to shorten the lines,
>
> LOG(RPI, Error)
> << "Failed to set default format on ISP
> Output0: "
> << ret;
>
> Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
>
> I'll apply this after a confirmation that the commit message should
> mention Ouput0.
>
Quite right, that should be Output0. Thank you for correcting that!
Regards,
Naush
>
> > + return -EINVAL;
> > + }
> > +
> > + LOG(RPI, Debug) << "Defaulting ISP Output0 format to "
> > + << format.toString();
> > }
> >
> > /*
>
> --
> Regards,
>
> Laurent Pinchart
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.libcamera.org/pipermail/libcamera-devel/attachments/20210313/31215e64/attachment-0001.htm>
More information about the libcamera-devel
mailing list