[libcamera-devel] [PATCH] libcamera: pipeline: raspberrypi: Add StreamFormats to StreamConfiguration

Naushir Patuck naush at raspberrypi.com
Thu Jun 25 09:47:36 CEST 2020


Hi all,

On Thu, 25 Jun 2020 at 08:35, Jacopo Mondi <jacopo at jmondi.org> wrote:
>
> Hi Laurent, Naush
>
> On Thu, Jun 25, 2020 at 05:37:46AM +0300, Laurent Pinchart wrote:
> > Hi Naush,
> >
> > On Thu, Jun 25, 2020 at 05:21:26AM +0300, Laurent Pinchart wrote:
> > > On Tue, Jun 23, 2020 at 08:59:49AM +0100, Naushir Patuck wrote:
> > > > On Tue, 23 Jun 2020 at 00:46, Laurent Pinchart wrote:
> > > >> On Mon, Jun 22, 2020 at 11:25:47AM +0100, Naushir Patuck wrote:
> > > >>> On Mon, 22 Jun 2020 at 05:59, Laurent Pinchart wrote:
> > > >>>> On Thu, Jun 18, 2020 at 10:18:38AM +0100, Naushir Patuck wrote:
> > > >>>>> On Thu, 18 Jun 2020 at 10:03, Kieran Bingham wrote:
> > > >>>>>> On 18/06/2020 09:41, Jacopo Mondi wrote:
> > > >>>>>>> On Wed, Jun 10, 2020 at 03:26:40PM +0100, Naushir Patuck wrote:
> > > >>>>>>>> In generateConfiguration(), add the device node specific formats to the
> > > >>>>>>>> StreamConfiguration for each StreamRole requested.
> > > >>>>>>>>
> > > >>>>>>>> Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
> > > >>>>>>>> ---
> > > >>>>>>>>  .../pipeline/raspberrypi/raspberrypi.cpp      | 52 +++++++++++++------
> > > >>>>>>>>  1 file changed, 36 insertions(+), 16 deletions(-)
> > > >>>>>>>>
> > > >>>>>>>> diff --git a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > > >>>>>>>> index e16a9c7f..03a1e641 100644
> > > >>>>>>>> --- a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > > >>>>>>>> +++ b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> > > >>>>>>>> @@ -518,41 +518,45 @@ CameraConfiguration *PipelineHandlerRPi::generateConfiguration(Camera *camera,
> > > >>>>>>>>      RPiCameraData *data = cameraData(camera);
> > > >>>>>>>>      CameraConfiguration *config = new RPiCameraConfiguration(data);
> > > >>>>>>>>      V4L2DeviceFormat sensorFormat;
> > > >>>>>>>> +    unsigned int bufferCount;
> > > >>>>>>>> +    PixelFormat pixelFormat;
> > > >>>>>>>>      V4L2PixFmtMap fmts;
> > > >>>>>>>> +    Size size;
> > > >>>>>>>>
> > > >>>>>>>>      if (roles.empty())
> > > >>>>>>>>              return config;
> > > >>>>>>>>
> > > >>>>>>>>      for (const StreamRole role : roles) {
> > > >>>>>>>> -            StreamConfiguration cfg{};
> > > >>>>>>>> -
> > > >>>>>>>>              switch (role) {
> > > >>>>>>>>              case StreamRole::StillCaptureRaw:
> > > >>>>>>>> -                    cfg.size = data->sensor_->resolution();
> > > >>>>>>>> +                    size = data->sensor_->resolution();
> > > >>>>>>>>                      fmts = data->unicam_[Unicam::Image].dev()->formats();
> > > >>>>>>>> -                    sensorFormat = findBestMode(fmts, cfg.size);
> > > >>>>>>>> -                    cfg.pixelFormat = sensorFormat.fourcc.toPixelFormat();
> > > >>>>>>>> -                    ASSERT(cfg.pixelFormat.isValid());
> > > >>>>>>>> -                    cfg.bufferCount = 1;
> > > >>>>>>>> +                    sensorFormat = findBestMode(fmts, size);
> > > >>>>>>>> +                    pixelFormat = sensorFormat.fourcc.toPixelFormat();
> > > >>>>>>>> +                    ASSERT(pixelFormat.isValid());
> > > >>>>>>>> +                    bufferCount = 1;
> > > >>>>>>>>                      break;
> > > >>>>>>>>
> > > >>>>>>>>              case StreamRole::StillCapture:
> > > >>>>>>>> -                    cfg.pixelFormat = PixelFormat(DRM_FORMAT_NV12);
> > > >>>>>>>> +                    fmts = data->isp_[Isp::Output0].dev()->formats();
> > > >>>>>>>> +                    pixelFormat = PixelFormat(DRM_FORMAT_NV12);
> > > >>>>
> > > >>>> This conflicts with recent rework of format handling, this line should
> > > >>>> now be
> > > >>>>
> > > >>>> +                       pixelFormat = formats::NV12;
> > > >>>>
> > > >>>> Same for the other formats below.
> > > >>>
> > > >>> Will update in the next patch.
> > > >>>
> > > >>>>>>>>                      /* Return the largest sensor resolution. */
> > > >>>>>>>> -                    cfg.size = data->sensor_->resolution();
> > > >>>>>>>> -                    cfg.bufferCount = 1;
> > > >>>>>>>> +                    size = data->sensor_->resolution();
> > > >>>>>>>> +                    bufferCount = 1;
> > > >>>>>>>>                      break;
> > > >>>>>>>>
> > > >>>>>>>>              case StreamRole::VideoRecording:
> > > >>>>>>>> -                    cfg.pixelFormat = PixelFormat(DRM_FORMAT_NV12);
> > > >>>>>>>> -                    cfg.size = { 1920, 1080 };
> > > >>>>>>>> -                    cfg.bufferCount = 4;
> > > >>>>>>>> +                    fmts = data->isp_[Isp::Output0].dev()->formats();
> > > >>>>>>>> +                    pixelFormat = PixelFormat(DRM_FORMAT_NV12);
> > > >>>>>>>> +                    size = { 1920, 1080 };
> > > >>>>>>>> +                    bufferCount = 4;
> > > >>>>>>>>                      break;
> > > >>>>>>>>
> > > >>>>>>>>              case StreamRole::Viewfinder:
> > > >>>>>>>> -                    cfg.pixelFormat = PixelFormat(DRM_FORMAT_ARGB8888);
> > > >>>>>>>> -                    cfg.size = { 800, 600 };
> > > >>>>>>>> -                    cfg.bufferCount = 4;
> > > >>>>>>>> +                    fmts = data->isp_[Isp::Output0].dev()->formats();
> > > >>>>>>>> +                    pixelFormat = PixelFormat(DRM_FORMAT_ARGB8888);
> > > >>>>>>>> +                    size = { 800, 600 };
> > > >>>>>>>> +                    bufferCount = 4;
> > > >>>>>>>>                      break;
> > > >>>>>>>>
> > > >>>>>>>>              default:
> > > >>>>>>>> @@ -561,6 +565,22 @@ CameraConfiguration *PipelineHandlerRPi::generateConfiguration(Camera *camera,
> > > >>>>>>>>                      break;
> > > >>>>>>>>              }
> > > >>>>>>>>
> > > >>>>>>>> +            /* Translate the V4L2PixelFormat to PixelFormat. */
> > > >>>>>>>> +            std::map<PixelFormat, std::vector<SizeRange>> deviceFormats;
> > > >>>>>>>> +            std::transform(fmts.begin(), fmts.end(), std::inserter(deviceFormats, deviceFormats.begin()),
> >
> > One additional comment, should this be deviceFormats.end(), to insert
> > the new entries at the end of the map ? It will make a difference in
>
> Shouldn't this be handled by using back_inserter() if that's what we
> want ?

>From my understanding, yes, this is probably cleaner.  However, they
should be both equivalent?

Regards,
Naush


More information about the libcamera-devel mailing list