[libcamera-devel] [PATCH] libcamera: camera_sensor: Do not initialise unsupported test patterns

Kieran Bingham kieran.bingham at ideasonboard.com
Sun May 29 00:52:47 CEST 2022


Quoting Naushir Patuck (2022-05-25 12:05:49)
> Hi all,
> 
> On Tue, 22 Feb 2022 at 06:11, Laurent Pinchart <
> laurent.pinchart at ideasonboard.com> wrote:
> 
> > Hi Kieran,
> >
> > Thank you for the patch.
> >
> > On Sat, Feb 12, 2022 at 11:34:07PM +0000, Kieran Bingham wrote:
> > > After the CameraSensor class has initialised properties, a default
> > > setting is applied to ensure that test pattern modes are disabled unless
> > > explicitly requested.
> > >
> > > This does not currently check to see if test patterns are supported on
> > > the CameraSensor and the applyTestPatternMode call will report a failure
> > > if it attempts to set a mode when not supported.
> > >
> > > Move the initialisation of the test pattern mode to the implementation
> > > of the control mappings to ensure that it is correctly reset at start
> > > up, while the code path will have already completed early if not
> > > supported.
> > >
> > > Bug: https://github.com/raspberrypi/libcamera-apps/issues/249
> > > Signed-off-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
> > > ---
> > >  src/libcamera/camera_sensor.cpp | 5 ++++-
> > >  1 file changed, 4 insertions(+), 1 deletion(-)
> > >
> > > diff --git a/src/libcamera/camera_sensor.cpp
> > b/src/libcamera/camera_sensor.cpp
> > > index 345b4a170d47..3a6a1a6bca77 100644
> > > --- a/src/libcamera/camera_sensor.cpp
> > > +++ b/src/libcamera/camera_sensor.cpp
> > > @@ -172,7 +172,7 @@ int CameraSensor::init()
> > >       if (ret)
> > >               return ret;
> > >
> > > -     return
> > applyTestPatternMode(controls::draft::TestPatternModeEnum::TestPatternModeOff);
> > > +     return 0;
> > >  }
> > >
> > >  int CameraSensor::validateSensorDriver()
> > > @@ -372,6 +372,9 @@ void CameraSensor::initTestPatternModes()
> > >
> > >               testPatternModes_.push_back(it->second);
> > >       }
> > > +
> > > +     /* Initialise the sensor with test patterns disabled. */
> > > +
> >  applyTestPatternMode(controls::draft::TestPatternModeEnum::TestPatternModeOff);
> >
> > Errors when applyting the test pattern are not propagated up anymore.
> >
> > A different approach if you don't want to turn all void functions in the
> > call stack to return an int is to move the error message when
> > testPatternModes_.empty() from CameraSensor::applyTestPatternMode() to
> > CameraSensor::setTestPatternMode(). You will need to keep the check in
> > CameraSensor::applyTestPatternMode() in order to return 0, but
> > CameraSensor::setTestPatternMode() could return a proper error code.
> >
> 
> Have we come to a resolution on this?  It's winding up some of our users,
> and we could do with suppressing these warnings :-)

I have pretty low availabilty for the next couple of weeks with
holiday.

Would you be able to send a patch with Laurents suggestion above?
Hopefully that could be merged quicker.

Of course adding the test pattern controls to the IMX477 is another
option too?
--
Regards

Kieran


> 
> Regards,
> Naush
> 
> 
> 
> >
> > >  }
> > >
> > >  int CameraSensor::initProperties()
> >
> > --
> > Regards,
> >
> > Laurent Pinchart
> >


More information about the libcamera-devel mailing list