Re: [PATCH] media: i2c: ccs: Fix link frequency control range update

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Laurent,

On Sat, Jun 29, 2024 at 01:52:22PM +0300, Laurent Pinchart wrote:
> On Sat, Jun 29, 2024 at 08:56:09AM +0000, Sakari Ailus wrote:
> > Hi Laurent,
> > 
> > Thanks for the patch.
> > 
> > On Sat, Jun 29, 2024 at 12:26:03AM +0300, Laurent Pinchart wrote:
> > > When updating the link frequency control range in response to a format
> > > change, the minimum value passed to the __v4l2_ctrl_modify_range()
> > > function is hardcoded to 0, while there's no guarantee that the first
> > > link frequency in the menu is valid for the selected format. Fix it by
> > > getting using the index of the first bit set in the valid link
> > > frequencies mask.
> > 
> > Is this a problem? The bitmask does tell which ones are valid, doesn't it?
> 
> I noticed that the new range wasn't applied in my sensor driver when the
> minimum was set to 0 and the mask didn't include that bit. However,
> that's because I had the default value wrong, which caused
> __v4l2_ctrl_modify_range() to error out. I thought the same applied to
> the minimum, but that doesn't seem to be the case. Isn't it still
> clearer to set the correct minimum, given that it is already computed
> anyway, to be used as a default value ?

I guess from user space point of view this could be helpful, yes. I'm fine
with changing this.

> 
> > The minimum value will also be zero after control initialisation before
> > this function gets called. This should be also taken into account.
> > 
> > > Signed-off-by: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx>
> > > ---
> > > I noticed this issue in the CCS driver while working on a different
> > > sensor driver. I haven't tested this patch.
> > > ---
> > >  drivers/media/i2c/ccs/ccs-core.c | 12 ++++++++----
> > >  1 file changed, 8 insertions(+), 4 deletions(-)
> > > 
> > > diff --git a/drivers/media/i2c/ccs/ccs-core.c b/drivers/media/i2c/ccs/ccs-core.c
> > > index e1ae0f9fad43..5257dc4912ae 100644
> > > --- a/drivers/media/i2c/ccs/ccs-core.c
> > > +++ b/drivers/media/i2c/ccs/ccs-core.c
> > > @@ -2143,6 +2143,7 @@ static int ccs_set_format_source(struct v4l2_subdev *subdev,
> > >  		*old_csi_format = sensor->csi_format;
> > >  	unsigned long *valid_link_freqs;
> > >  	u32 code = fmt->format.code;
> > > +	unsigned int min, max;
> > >  	unsigned int i;
> > >  	int rval;
> > >  
> > > @@ -2179,10 +2180,13 @@ static int ccs_set_format_source(struct v4l2_subdev *subdev,
> > >  		&sensor->valid_link_freqs[sensor->csi_format->compressed
> > >  					  - sensor->compressed_min_bpp];
> > >  
> > > -	__v4l2_ctrl_modify_range(
> > > -		sensor->link_freq, 0,
> > > -		__fls(*valid_link_freqs), ~*valid_link_freqs,
> > > -		__ffs(*valid_link_freqs));
> > > +	min = __ffs(*valid_link_freqs);
> > > +	man = __fls(*valid_link_freqs);
> > > +
> > > +	ret = __v4l2_ctrl_modify_range(sensor->link_freq, min, max,
> > > +				       ~*valid_link_freqs, min);
> > 
> > As this doesn't effect any actual change the applying of which could fail,
> > you'd have to have an issue with the argument values themselves. I wouldn't
> > add a check here. Although if you do, the sensor configuration should be
> > returned to the state before the call which would probably be worth a new
> > patch.
> 
> The lack of a similar check caused my driver to silently keep the
> current range, and it took me a while to debug that. I however agree
> that, if the arguments are right, the check isn't needed. Maybe it can
> be dropped, as the arguments are correct.

Alternatively there should be a dev_warn(), too, that this is a driver bug.

> 
> > > +	if (ret)
> > > +		return ret;
> > >  
> > >  	return ccs_pll_update(sensor);
> > >  }
> > > 
> > > base-commit: afcd48134c58d6af45fb3fdb648f1260b20f2326
> 

-- 
Kind regards,

Sakari Ailus




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux