diff mbox series

[1/1] ipu3-cio2: Fix pixel-rate derived link frequency

Message ID 20210215075742.12434-1-sakari.ailus@linux.intel.com
State Accepted
Commit a7de6eac6f6f73d48d97a6c93032107775f4593b
Headers show
Series [1/1] ipu3-cio2: Fix pixel-rate derived link frequency | expand

Commit Message

Sakari Ailus Feb. 15, 2021, 7:57 a.m. UTC
The driver uses v4l2_get_link_freq() helper to obtain the link frequency
using the LINK_FREQ but also the PIXEL_RATE control. The divisor for the
pixel rate derived link frequency was wrong, missing the bus uses double
data rate. Fix this.

Reported-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Fixes: 4b6c129e87a3 ("media: ipu3-cio2: Use v4l2_get_link_freq helper")
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
---
 drivers/media/pci/intel/ipu3/ipu3-cio2-main.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Laurent Pinchart Feb. 15, 2021, 11:25 a.m. UTC | #1
Hi Sakari,

Thank you for the patch.

On Mon, Feb 15, 2021 at 09:57:42AM +0200, Sakari Ailus wrote:
> The driver uses v4l2_get_link_freq() helper to obtain the link frequency
> using the LINK_FREQ but also the PIXEL_RATE control. The divisor for the
> pixel rate derived link frequency was wrong, missing the bus uses double
> data rate. Fix this.
> 
> Reported-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> Fixes: 4b6c129e87a3 ("media: ipu3-cio2: Use v4l2_get_link_freq helper")
> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>

Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> ---
>  drivers/media/pci/intel/ipu3/ipu3-cio2-main.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c
> index 6e8c0c230e11..fecef85bd62e 100644
> --- a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c
> +++ b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c
> @@ -302,7 +302,7 @@ static int cio2_csi2_calc_timing(struct cio2_device *cio2, struct cio2_queue *q,
>  	if (!q->sensor)
>  		return -ENODEV;
>  
> -	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes);
> +	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes * 2);
>  	if (freq < 0) {
>  		dev_err(dev, "error %lld, invalid link_freq\n", freq);
>  		return freq;
Bingbu Cao Feb. 16, 2021, 10:34 a.m. UTC | #2
Laurent and Sakari, thanks.

On 2/15/21 3:57 PM, Sakari Ailus wrote:
> The driver uses v4l2_get_link_freq() helper to obtain the link frequency

> using the LINK_FREQ but also the PIXEL_RATE control. The divisor for the

> pixel rate derived link frequency was wrong, missing the bus uses double

> data rate. Fix this.

> 

> Reported-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> Fixes: 4b6c129e87a3 ("media: ipu3-cio2: Use v4l2_get_link_freq helper")

> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>

> ---

>  drivers/media/pci/intel/ipu3/ipu3-cio2-main.c | 2 +-

>  1 file changed, 1 insertion(+), 1 deletion(-)

> 

> diff --git a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

> index 6e8c0c230e11..fecef85bd62e 100644

> --- a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

> +++ b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

> @@ -302,7 +302,7 @@ static int cio2_csi2_calc_timing(struct cio2_device *cio2, struct cio2_queue *q,

>  	if (!q->sensor)

>  		return -ENODEV;

>  

> -	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes);

> +	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes * 2);

>  	if (freq < 0) {

>  		dev_err(dev, "error %lld, invalid link_freq\n", freq);

>  		return freq;

> 


Reviewed-by: Bingbu Cao <bingbu.cao@intel.com>


-- 
Best regards,
Bingbu Cao
Laurent Pinchart March 23, 2021, 3:27 p.m. UTC | #3
Hi Sakari,

Do you plan to send a pull request for this ? I don't see the patch in
neither the master nor fixes branches of Mauro's tree.

On Mon, Feb 15, 2021 at 01:25:45PM +0200, Laurent Pinchart wrote:
> Hi Sakari,

> 

> Thank you for the patch.

> 

> On Mon, Feb 15, 2021 at 09:57:42AM +0200, Sakari Ailus wrote:

> > The driver uses v4l2_get_link_freq() helper to obtain the link frequency

> > using the LINK_FREQ but also the PIXEL_RATE control. The divisor for the

> > pixel rate derived link frequency was wrong, missing the bus uses double

> > data rate. Fix this.

> > 

> > Reported-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> > Fixes: 4b6c129e87a3 ("media: ipu3-cio2: Use v4l2_get_link_freq helper")

> > Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>

> 

> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> 

> > ---

> >  drivers/media/pci/intel/ipu3/ipu3-cio2-main.c | 2 +-

> >  1 file changed, 1 insertion(+), 1 deletion(-)

> > 

> > diff --git a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

> > index 6e8c0c230e11..fecef85bd62e 100644

> > --- a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

> > +++ b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

> > @@ -302,7 +302,7 @@ static int cio2_csi2_calc_timing(struct cio2_device *cio2, struct cio2_queue *q,

> >  	if (!q->sensor)

> >  		return -ENODEV;

> >  

> > -	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes);

> > +	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes * 2);

> >  	if (freq < 0) {

> >  		dev_err(dev, "error %lld, invalid link_freq\n", freq);

> >  		return freq;


-- 
Regards,

Laurent Pinchart
diff mbox series

Patch

diff --git a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c
index 6e8c0c230e11..fecef85bd62e 100644
--- a/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c
+++ b/drivers/media/pci/intel/ipu3/ipu3-cio2-main.c
@@ -302,7 +302,7 @@  static int cio2_csi2_calc_timing(struct cio2_device *cio2, struct cio2_queue *q,
 	if (!q->sensor)
 		return -ENODEV;
 
-	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes);
+	freq = v4l2_get_link_freq(q->sensor->ctrl_handler, bpp, lanes * 2);
 	if (freq < 0) {
 		dev_err(dev, "error %lld, invalid link_freq\n", freq);
 		return freq;