diff mbox series

media: staging: ipu3-imgu: Initialise height_per_slice in the stripes

Message ID 20210916172504.677919-1-jeanmichel.hautbois@ideasonboard.com
State Accepted
Commit e2d3e77d0e7d3caf676cb0eb707f8c7b0a4d41b9
Headers show
Series media: staging: ipu3-imgu: Initialise height_per_slice in the stripes | expand

Commit Message

Jean-Michel Hautbois Sept. 16, 2021, 5:25 p.m. UTC
While playing with low resolutions for the grid, it appeared that
height_per_slice is not initialised if we are not using both stripes for
the calculations. This pattern occurs three times:
- for the awb_fr processing block
- for the af processing block
- for the awb processing block

The idea of this small portion of code is to reduce complexity in
loading the statistics, it could be done also when only one stripe is
used. Fix it by getting this initialisation code outside of the else()
test case.

Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>
---
 drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------
 1 file changed, 22 insertions(+), 22 deletions(-)

Comments

Sakari Ailus Sept. 21, 2021, 11:07 a.m. UTC | #1
Hi Jean-Michel --- and Bingbu and Tianshu,

On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:
> While playing with low resolutions for the grid, it appeared that

> height_per_slice is not initialised if we are not using both stripes for

> the calculations. This pattern occurs three times:

> - for the awb_fr processing block

> - for the af processing block

> - for the awb processing block

> 

> The idea of this small portion of code is to reduce complexity in

> loading the statistics, it could be done also when only one stripe is

> used. Fix it by getting this initialisation code outside of the else()

> test case.

> 

> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> ---

>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------

>  1 file changed, 22 insertions(+), 22 deletions(-)

> 

> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c b/drivers/staging/media/ipu3/ipu3-css-params.c

> index e9d6bd9e9332..05da7dbdca78 100644

> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>  					acc->awb_fr.stripes[1].grid_cfg.width,

>  					b_w_log2);

>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> -

> -		/*

> -		 * To reduce complexity of debubbling and loading

> -		 * statistics fix grid_height_per_slice to 1 for both

> -		 * stripes.

> -		 */

> -		for (i = 0; i < stripes; i++)

> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>  	}

>  

> +	/*

> +	 * To reduce complexity of debubbling and loading

> +	 * statistics fix grid_height_per_slice to 1 for both

> +	 * stripes.

> +	 */

> +	for (i = 0; i < stripes; i++)

> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> +

>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

>  		return -EINVAL;

>  

> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

>  					  acc->af.stripes[1].grid_cfg.width,

>  					  b_w_log2);

> -

> -		/*

> -		 * To reduce complexity of debubbling and loading statistics

> -		 * fix grid_height_per_slice to 1 for both stripes

> -		 */

> -		for (i = 0; i < stripes; i++)

> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>  	}

>  

> +	/*

> +	 * To reduce complexity of debubbling and loading statistics

> +	 * fix grid_height_per_slice to 1 for both stripes

> +	 */

> +	for (i = 0; i < stripes; i++)

> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> +

>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

>  		return -EINVAL;

>  

> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

>  					  acc->awb.stripes[1].grid.width,

>  					  b_w_log2);

> -

> -		/*

> -		 * To reduce complexity of debubbling and loading statistics

> -		 * fix grid_height_per_slice to 1 for both stripes

> -		 */

> -		for (i = 0; i < stripes; i++)

> -			acc->awb.stripes[i].grid.height_per_slice = 1;

>  	}

>  

> +	/*

> +	 * To reduce complexity of debubbling and loading statistics

> +	 * fix grid_height_per_slice to 1 for both stripes

> +	 */

> +	for (i = 0; i < stripes; i++)

> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> +

>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

>  		return -EINVAL;

>  


While it seems like a sensible idea to initialise arguments to firmware, does this have an
effect on the statistics format? If so, can the existing user space cope
with that?

Bingbu, Tianshu, any insights on this?

-- 
Kind regards,

Sakari Ailus
Jean-Michel Hautbois Sept. 21, 2021, 1:04 p.m. UTC | #2
Hi Sakari, and Tomasz as I have a remark/question for you :-)

On 21/09/2021 13:07, Sakari Ailus wrote:
> Hi Jean-Michel --- and Bingbu and Tianshu,

> 

> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

>> While playing with low resolutions for the grid, it appeared that

>> height_per_slice is not initialised if we are not using both stripes for

>> the calculations. This pattern occurs three times:

>> - for the awb_fr processing block

>> - for the af processing block

>> - for the awb processing block

>>

>> The idea of this small portion of code is to reduce complexity in

>> loading the statistics, it could be done also when only one stripe is

>> used. Fix it by getting this initialisation code outside of the else()

>> test case.

>>

>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

>> ---

>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------

>>  1 file changed, 22 insertions(+), 22 deletions(-)

>>

>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c b/drivers/staging/media/ipu3/ipu3-css-params.c

>> index e9d6bd9e9332..05da7dbdca78 100644

>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>  					acc->awb_fr.stripes[1].grid_cfg.width,

>>  					b_w_log2);

>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

>> -

>> -		/*

>> -		 * To reduce complexity of debubbling and loading

>> -		 * statistics fix grid_height_per_slice to 1 for both

>> -		 * stripes.

>> -		 */

>> -		for (i = 0; i < stripes; i++)

>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>  	}

>>  

>> +	/*

>> +	 * To reduce complexity of debubbling and loading

>> +	 * statistics fix grid_height_per_slice to 1 for both

>> +	 * stripes.

>> +	 */

>> +	for (i = 0; i < stripes; i++)

>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>> +

>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

>>  		return -EINVAL;

>>  

>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

>>  					  acc->af.stripes[1].grid_cfg.width,

>>  					  b_w_log2);

>> -

>> -		/*

>> -		 * To reduce complexity of debubbling and loading statistics

>> -		 * fix grid_height_per_slice to 1 for both stripes

>> -		 */

>> -		for (i = 0; i < stripes; i++)

>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>  	}

>>  

>> +	/*

>> +	 * To reduce complexity of debubbling and loading statistics

>> +	 * fix grid_height_per_slice to 1 for both stripes

>> +	 */

>> +	for (i = 0; i < stripes; i++)

>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>> +

>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

>>  		return -EINVAL;

>>  

>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

>>  					  acc->awb.stripes[1].grid.width,

>>  					  b_w_log2);

>> -

>> -		/*

>> -		 * To reduce complexity of debubbling and loading statistics

>> -		 * fix grid_height_per_slice to 1 for both stripes

>> -		 */

>> -		for (i = 0; i < stripes; i++)

>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

>>  	}

>>  

>> +	/*

>> +	 * To reduce complexity of debubbling and loading statistics

>> +	 * fix grid_height_per_slice to 1 for both stripes

>> +	 */

>> +	for (i = 0; i < stripes; i++)

>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

>> +

>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

>>  		return -EINVAL;

>>  

> 

> While it seems like a sensible idea to initialise arguments to firmware, does this have an

> effect on the statistics format? If so, can the existing user space cope

> with that?


To try and figure that out, we have tested several grid configurations
and inspected the captured statistics. We have converted the statistics
in an image, rendering each cell as a pixel whose red, green and blue
components are the cell's red, green and blue averages. This turned out
to be a very effectice tool to quickly visualize AWB statistics.
We have made a lot of tests with different output resolutions, from a
small one up to the full-scale one.

Here is one example of a statistics output with a ViewFinder configured
as 1920x1280, with a BDS output configuration set to 2304x1536 (sensor
is 2592x1944).

Without the patch, configuring a 79x45 grid of 16x16 cells we obtain the
image: https://pasteboard.co/g4nC4fHjbVER.png.
We can notice a weird padding every two lines and it seems to be missing
half of the frame.

With the patch applied, the same configuration gives us the image:
https://pasteboard.co/rzap6axIvVdu.png

We can clearly see the one padding pixel on the right, and the frame is
all there, as expected.

Tomasz: We're concerned that this patch may have an impact on the
ChromeOS Intel Camera HAL with the IPU3. Is it possible for someone to
review and test this please?

Thanks,
JM
Laurent Pinchart Sept. 21, 2021, 2:33 p.m. UTC | #3
On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:
> Hi Sakari, and Tomasz as I have a remark/question for you :-)

> 

> On 21/09/2021 13:07, Sakari Ailus wrote:

> > Hi Jean-Michel --- and Bingbu and Tianshu,

> > 

> > On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

> >> While playing with low resolutions for the grid, it appeared that

> >> height_per_slice is not initialised if we are not using both stripes for

> >> the calculations. This pattern occurs three times:

> >> - for the awb_fr processing block

> >> - for the af processing block

> >> - for the awb processing block

> >>

> >> The idea of this small portion of code is to reduce complexity in

> >> loading the statistics, it could be done also when only one stripe is

> >> used. Fix it by getting this initialisation code outside of the else()

> >> test case.

> >>

> >> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> >> ---

> >>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------

> >>  1 file changed, 22 insertions(+), 22 deletions(-)

> >>

> >> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c b/drivers/staging/media/ipu3/ipu3-css-params.c

> >> index e9d6bd9e9332..05da7dbdca78 100644

> >> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> >> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> >> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> >>  					acc->awb_fr.stripes[1].grid_cfg.width,

> >>  					b_w_log2);

> >>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> >> -

> >> -		/*

> >> -		 * To reduce complexity of debubbling and loading

> >> -		 * statistics fix grid_height_per_slice to 1 for both

> >> -		 * stripes.

> >> -		 */

> >> -		for (i = 0; i < stripes; i++)

> >> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>  	}

> >>  

> >> +	/*

> >> +	 * To reduce complexity of debubbling and loading

> >> +	 * statistics fix grid_height_per_slice to 1 for both

> >> +	 * stripes.

> >> +	 */

> >> +	for (i = 0; i < stripes; i++)

> >> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >> +

> >>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> >>  		return -EINVAL;

> >>  

> >> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> >>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

> >>  					  acc->af.stripes[1].grid_cfg.width,

> >>  					  b_w_log2);

> >> -

> >> -		/*

> >> -		 * To reduce complexity of debubbling and loading statistics

> >> -		 * fix grid_height_per_slice to 1 for both stripes

> >> -		 */

> >> -		for (i = 0; i < stripes; i++)

> >> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >>  	}

> >>  

> >> +	/*

> >> +	 * To reduce complexity of debubbling and loading statistics

> >> +	 * fix grid_height_per_slice to 1 for both stripes

> >> +	 */

> >> +	for (i = 0; i < stripes; i++)

> >> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >> +

> >>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> >>  		return -EINVAL;

> >>  

> >> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> >>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

> >>  					  acc->awb.stripes[1].grid.width,

> >>  					  b_w_log2);

> >> -

> >> -		/*

> >> -		 * To reduce complexity of debubbling and loading statistics

> >> -		 * fix grid_height_per_slice to 1 for both stripes

> >> -		 */

> >> -		for (i = 0; i < stripes; i++)

> >> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> >>  	}

> >>  

> >> +	/*

> >> +	 * To reduce complexity of debubbling and loading statistics

> >> +	 * fix grid_height_per_slice to 1 for both stripes

> >> +	 */

> >> +	for (i = 0; i < stripes; i++)

> >> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> >> +

> >>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> >>  		return -EINVAL;

> >>  

> > 

> > While it seems like a sensible idea to initialise arguments to firmware, does this have an

> > effect on the statistics format? If so, can the existing user space cope

> > with that?

> 

> To try and figure that out, we have tested several grid configurations

> and inspected the captured statistics. We have converted the statistics

> in an image, rendering each cell as a pixel whose red, green and blue

> components are the cell's red, green and blue averages. This turned out

> to be a very effectice tool to quickly visualize AWB statistics.

> We have made a lot of tests with different output resolutions, from a

> small one up to the full-scale one.

> 

> Here is one example of a statistics output with a ViewFinder configured

> as 1920x1280, with a BDS output configuration set to 2304x1536 (sensor

> is 2592x1944).

> 

> Without the patch, configuring a 79x45 grid of 16x16 cells we obtain the

> image: https://pasteboard.co/g4nC4fHjbVER.png.

> We can notice a weird padding every two lines and it seems to be missing

> half of the frame.

> 

> With the patch applied, the same configuration gives us the image:

> https://pasteboard.co/rzap6axIvVdu.png

> 

> We can clearly see the one padding pixel on the right, and the frame is

> all there, as expected.

> 

> Tomasz: We're concerned that this patch may have an impact on the

> ChromeOS Intel Camera HAL with the IPU3. Is it possible for someone to

> review and test this please?


As shown by the images above, this is a real fix. It only affects grid
configurations that use a single stripe (left or right), so either
"small" resolutions (less than 1280 pixels at the BDS output if I recall
correctly), or grid configurations that span the left part of the image
with higher resolutions. The latter is probably unlikely. For the
former, it may affect the binary library, especially if it includes a
workaround for the bug.

Still, this change is good I believe, so it should be upstreamed.

-- 
Regards,

Laurent Pinchart
Cao, Bingbu Sept. 22, 2021, 4:33 a.m. UTC | #4
Jean-Michel,

Thanks for you patch.
What is the value of .config.grid_cfg.width for your low resolutions?

________________________
BRs,  
Bingbu Cao 

> -----Original Message-----

> From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> Sent: Tuesday, September 21, 2021 10:34 PM

> To: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> Cc: Sakari Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>; Cao,

> Bingbu <bingbu.cao@intel.com>

> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> height_per_slice in the stripes

> 

> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

> > Hi Sakari, and Tomasz as I have a remark/question for you :-)

> >

> > On 21/09/2021 13:07, Sakari Ailus wrote:

> > > Hi Jean-Michel --- and Bingbu and Tianshu,

> > >

> > > On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

> > >> While playing with low resolutions for the grid, it appeared that

> > >> height_per_slice is not initialised if we are not using both

> > >> stripes for the calculations. This pattern occurs three times:

> > >> - for the awb_fr processing block

> > >> - for the af processing block

> > >> - for the awb processing block

> > >>

> > >> The idea of this small portion of code is to reduce complexity in

> > >> loading the statistics, it could be done also when only one stripe

> > >> is used. Fix it by getting this initialisation code outside of the

> > >> else() test case.

> > >>

> > >> Signed-off-by: Jean-Michel Hautbois

> > >> <jeanmichel.hautbois@ideasonboard.com>

> > >> ---

> > >>  drivers/staging/media/ipu3/ipu3-css-params.c | 44

> > >> ++++++++++----------

> > >>  1 file changed, 22 insertions(+), 22 deletions(-)

> > >>

> > >> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> > >> b/drivers/staging/media/ipu3/ipu3-css-params.c

> > >> index e9d6bd9e9332..05da7dbdca78 100644

> > >> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> > >> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> > >> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css,

> unsigned int pipe,

> > >>  					acc->awb_fr.stripes[1].grid_cfg.width,

> > >>  					b_w_log2);

> > >>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> > >> -

> > >> -		/*

> > >> -		 * To reduce complexity of debubbling and loading

> > >> -		 * statistics fix grid_height_per_slice to 1 for both

> > >> -		 * stripes.

> > >> -		 */

> > >> -		for (i = 0; i < stripes; i++)

> > >> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > >>  	}

> > >>

> > >> +	/*

> > >> +	 * To reduce complexity of debubbling and loading

> > >> +	 * statistics fix grid_height_per_slice to 1 for both

> > >> +	 * stripes.

> > >> +	 */

> > >> +	for (i = 0; i < stripes; i++)

> > >> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > >> +

> > >>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> > >>  		return -EINVAL;

> > >>

> > >> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css,

> unsigned int pipe,

> > >>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

> > >>  					  acc->af.stripes[1].grid_cfg.width,

> > >>  					  b_w_log2);

> > >> -

> > >> -		/*

> > >> -		 * To reduce complexity of debubbling and loading statistics

> > >> -		 * fix grid_height_per_slice to 1 for both stripes

> > >> -		 */

> > >> -		for (i = 0; i < stripes; i++)

> > >> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > >>  	}

> > >>

> > >> +	/*

> > >> +	 * To reduce complexity of debubbling and loading statistics

> > >> +	 * fix grid_height_per_slice to 1 for both stripes

> > >> +	 */

> > >> +	for (i = 0; i < stripes; i++)

> > >> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > >> +

> > >>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> > >>  		return -EINVAL;

> > >>

> > >> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css,

> unsigned int pipe,

> > >>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

> > >>  					  acc->awb.stripes[1].grid.width,

> > >>  					  b_w_log2);

> > >> -

> > >> -		/*

> > >> -		 * To reduce complexity of debubbling and loading statistics

> > >> -		 * fix grid_height_per_slice to 1 for both stripes

> > >> -		 */

> > >> -		for (i = 0; i < stripes; i++)

> > >> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> > >>  	}

> > >>

> > >> +	/*

> > >> +	 * To reduce complexity of debubbling and loading statistics

> > >> +	 * fix grid_height_per_slice to 1 for both stripes

> > >> +	 */

> > >> +	for (i = 0; i < stripes; i++)

> > >> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> > >> +

> > >>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> > >>  		return -EINVAL;

> > >>

> > >

> > > While it seems like a sensible idea to initialise arguments to

> > > firmware, does this have an effect on the statistics format? If so,

> > > can the existing user space cope with that?

> >

> > To try and figure that out, we have tested several grid configurations

> > and inspected the captured statistics. We have converted the

> > statistics in an image, rendering each cell as a pixel whose red,

> > green and blue components are the cell's red, green and blue averages.

> > This turned out to be a very effectice tool to quickly visualize AWB

> statistics.

> > We have made a lot of tests with different output resolutions, from a

> > small one up to the full-scale one.

> >

> > Here is one example of a statistics output with a ViewFinder

> > configured as 1920x1280, with a BDS output configuration set to

> > 2304x1536 (sensor is 2592x1944).

> >

> > Without the patch, configuring a 79x45 grid of 16x16 cells we obtain

> > the

> > image: https://pasteboard.co/g4nC4fHjbVER.png.

> > We can notice a weird padding every two lines and it seems to be

> > missing half of the frame.

> >

> > With the patch applied, the same configuration gives us the image:

> > https://pasteboard.co/rzap6axIvVdu.png

> >

> > We can clearly see the one padding pixel on the right, and the frame

> > is all there, as expected.

> >

> > Tomasz: We're concerned that this patch may have an impact on the

> > ChromeOS Intel Camera HAL with the IPU3. Is it possible for someone to

> > review and test this please?

> 

> As shown by the images above, this is a real fix. It only affects grid

> configurations that use a single stripe (left or right), so either

> "small" resolutions (less than 1280 pixels at the BDS output if I recall

> correctly), or grid configurations that span the left part of the image

> with higher resolutions. The latter is probably unlikely. For the former,

> it may affect the binary library, especially if it includes a workaround

> for the bug.

> 

> Still, this change is good I believe, so it should be upstreamed.

> 

> --

> Regards,

> 

> Laurent Pinchart
Jean-Michel Hautbois Sept. 22, 2021, 5:54 a.m. UTC | #5
Hi Bingbu,

On 22/09/2021 06:33, Cao, Bingbu wrote:
> Jean-Michel,

> 

> Thanks for you patch.

> What is the value of .config.grid_cfg.width for your low resolutions?


I don't know if a 1920x1280 output is a low resolution, but the grid is
configured as:
- grid_cfg.width = 79
- grid_cfg.height = 24
- grid_cfg.block_width_log2 = 4
- grid_cfg.block_height_log2 = 6

Here is a full debug output of the AWB part in imgu_css_cfg_acc():

acc->stripe.down_scaled_stripes[0].width: 1280
acc->stripe.down_scaled_stripes[0].height: 1536
acc->stripe.down_scaled_stripes[0].offset: 0
acc->stripe.bds_out_stripes[0].width: 1280
acc->stripe.bds_out_stripes[0].height: 1536
acc->stripe.bds_out_stripes[0].offset: 0
acc->acc->awb.stripes[0].grid.width: 79
acc->awb.stripes[0].grid.block_width_log2: 4
acc->acc->awb.stripes[0].grid.height: 24
acc->awb.stripes[0].grid.block_height_log2: 6
acc->awb.stripes[0].grid.x_start: 0
acc->awb.stripes[0].grid.x_end: 1263
acc->awb.stripes[0].grid.y_start: 0
acc->awb.stripes[0].grid.y_end: 1535
acc->stripe.down_scaled_stripes[1].width: 1280
acc->stripe.down_scaled_stripes[1].height: 1536
acc->stripe.down_scaled_stripes[1].offset: 1024
acc->stripe.bds_out_stripes[1].width: 1280
acc->stripe.bds_out_stripes[1].height: 1536
acc->stripe.bds_out_stripes[1].offset: 1024
acc->acc->awb.stripes[1].grid.width: 79
acc->awb.stripes[1].grid.block_width_log2: 4
acc->acc->awb.stripes[1].grid.height: 24
acc->awb.stripes[1].grid.block_height_log2: 6
acc->awb.stripes[1].grid.x_start: 0
acc->awb.stripes[1].grid.x_end: 1263
acc->awb.stripes[1].grid.y_start: 0
acc->awb.stripes[1].grid.y_end: 1535

This has been outputted with: https://paste.debian.net/1212791/

The examples I gave before were 1280x720 output and not 1920x1080, here
are they:
- without the patch: https://pasteboard.co/hHo4QkVUSk8e.png
- with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

As you can see we have the same behaviour.

Thanks,
JM

> 

> ________________________

> BRs,  

> Bingbu Cao 

> 

>> -----Original Message-----

>> From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

>> Sent: Tuesday, September 21, 2021 10:34 PM

>> To: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

>> Cc: Sakari Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

>> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>; Cao,

>> Bingbu <bingbu.cao@intel.com>

>> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

>> height_per_slice in the stripes

>>

>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

>>> Hi Sakari, and Tomasz as I have a remark/question for you :-)

>>>

>>> On 21/09/2021 13:07, Sakari Ailus wrote:

>>>> Hi Jean-Michel --- and Bingbu and Tianshu,

>>>>

>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

>>>>> While playing with low resolutions for the grid, it appeared that

>>>>> height_per_slice is not initialised if we are not using both

>>>>> stripes for the calculations. This pattern occurs three times:

>>>>> - for the awb_fr processing block

>>>>> - for the af processing block

>>>>> - for the awb processing block

>>>>>

>>>>> The idea of this small portion of code is to reduce complexity in

>>>>> loading the statistics, it could be done also when only one stripe

>>>>> is used. Fix it by getting this initialisation code outside of the

>>>>> else() test case.

>>>>>

>>>>> Signed-off-by: Jean-Michel Hautbois

>>>>> <jeanmichel.hautbois@ideasonboard.com>

>>>>> ---

>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44

>>>>> ++++++++++----------

>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

>>>>>

>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>> index e9d6bd9e9332..05da7dbdca78 100644

>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css,

>> unsigned int pipe,

>>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,

>>>>>  					b_w_log2);

>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

>>>>> -

>>>>> -		/*

>>>>> -		 * To reduce complexity of debubbling and loading

>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

>>>>> -		 * stripes.

>>>>> -		 */

>>>>> -		for (i = 0; i < stripes; i++)

>>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>  	}

>>>>>

>>>>> +	/*

>>>>> +	 * To reduce complexity of debubbling and loading

>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

>>>>> +	 * stripes.

>>>>> +	 */

>>>>> +	for (i = 0; i < stripes; i++)

>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>> +

>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

>>>>>  		return -EINVAL;

>>>>>

>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css,

>> unsigned int pipe,

>>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

>>>>>  					  acc->af.stripes[1].grid_cfg.width,

>>>>>  					  b_w_log2);

>>>>> -

>>>>> -		/*

>>>>> -		 * To reduce complexity of debubbling and loading statistics

>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>> -		 */

>>>>> -		for (i = 0; i < stripes; i++)

>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>  	}

>>>>>

>>>>> +	/*

>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>> +	 */

>>>>> +	for (i = 0; i < stripes; i++)

>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>> +

>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

>>>>>  		return -EINVAL;

>>>>>

>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css,

>> unsigned int pipe,

>>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

>>>>>  					  acc->awb.stripes[1].grid.width,

>>>>>  					  b_w_log2);

>>>>> -

>>>>> -		/*

>>>>> -		 * To reduce complexity of debubbling and loading statistics

>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>> -		 */

>>>>> -		for (i = 0; i < stripes; i++)

>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>  	}

>>>>>

>>>>> +	/*

>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>> +	 */

>>>>> +	for (i = 0; i < stripes; i++)

>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>> +

>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

>>>>>  		return -EINVAL;

>>>>>

>>>>

>>>> While it seems like a sensible idea to initialise arguments to

>>>> firmware, does this have an effect on the statistics format? If so,

>>>> can the existing user space cope with that?

>>>

>>> To try and figure that out, we have tested several grid configurations

>>> and inspected the captured statistics. We have converted the

>>> statistics in an image, rendering each cell as a pixel whose red,

>>> green and blue components are the cell's red, green and blue averages.

>>> This turned out to be a very effectice tool to quickly visualize AWB

>> statistics.

>>> We have made a lot of tests with different output resolutions, from a

>>> small one up to the full-scale one.

>>>

>>> Here is one example of a statistics output with a ViewFinder

>>> configured as 1920x1280, with a BDS output configuration set to

>>> 2304x1536 (sensor is 2592x1944).

>>>

>>> Without the patch, configuring a 79x45 grid of 16x16 cells we obtain

>>> the

>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

>>> We can notice a weird padding every two lines and it seems to be

>>> missing half of the frame.

>>>

>>> With the patch applied, the same configuration gives us the image:

>>> https://pasteboard.co/rzap6axIvVdu.png

>>>

>>> We can clearly see the one padding pixel on the right, and the frame

>>> is all there, as expected.

>>>

>>> Tomasz: We're concerned that this patch may have an impact on the

>>> ChromeOS Intel Camera HAL with the IPU3. Is it possible for someone to

>>> review and test this please?

>>

>> As shown by the images above, this is a real fix. It only affects grid

>> configurations that use a single stripe (left or right), so either

>> "small" resolutions (less than 1280 pixels at the BDS output if I recall

>> correctly), or grid configurations that span the left part of the image

>> with higher resolutions. The latter is probably unlikely. For the former,

>> it may affect the binary library, especially if it includes a workaround

>> for the bug.

>>

>> Still, this change is good I believe, so it should be upstreamed.

>>

>> --

>> Regards,

>>

>> Laurent Pinchart
Cao, Bingbu Sept. 23, 2021, 9:06 a.m. UTC | #6
Jean-Michel,

Firstly, the .height_per_slice could be 0 if your .grid.width larger than 32.

From your configuration, looks like something wrong in the stripe configuration
cause not entering the 2 stripes branch.

________________________
BRs,  
Bingbu Cao 

> -----Original Message-----

> From: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> Sent: Wednesday, September 22, 2021 1:54 PM

> To: Cao, Bingbu <bingbu.cao@intel.com>; Laurent Pinchart

> <laurent.pinchart@ideasonboard.com>

> Cc: Sakari Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>

> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> height_per_slice in the stripes

> 

> Hi Bingbu,

> 

> On 22/09/2021 06:33, Cao, Bingbu wrote:

> > Jean-Michel,

> >

> > Thanks for you patch.

> > What is the value of .config.grid_cfg.width for your low resolutions?

> 

> I don't know if a 1920x1280 output is a low resolution, but the grid is

> configured as:

> - grid_cfg.width = 79

> - grid_cfg.height = 24

> - grid_cfg.block_width_log2 = 4

> - grid_cfg.block_height_log2 = 6

> 

> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> 

> acc->stripe.down_scaled_stripes[0].width: 1280

> acc->stripe.down_scaled_stripes[0].height: 1536

> acc->stripe.down_scaled_stripes[0].offset: 0

> acc->stripe.bds_out_stripes[0].width: 1280

> acc->stripe.bds_out_stripes[0].height: 1536

> acc->stripe.bds_out_stripes[0].offset: 0

> acc->acc->awb.stripes[0].grid.width: 79

> acc->awb.stripes[0].grid.block_width_log2: 4

> acc->acc->awb.stripes[0].grid.height: 24

> acc->awb.stripes[0].grid.block_height_log2: 6

> acc->awb.stripes[0].grid.x_start: 0

> acc->awb.stripes[0].grid.x_end: 1263

> acc->awb.stripes[0].grid.y_start: 0

> acc->awb.stripes[0].grid.y_end: 1535

> acc->stripe.down_scaled_stripes[1].width: 1280

> acc->stripe.down_scaled_stripes[1].height: 1536

> acc->stripe.down_scaled_stripes[1].offset: 1024

> acc->stripe.bds_out_stripes[1].width: 1280

> acc->stripe.bds_out_stripes[1].height: 1536

> acc->stripe.bds_out_stripes[1].offset: 1024

> acc->acc->awb.stripes[1].grid.width: 79

> acc->awb.stripes[1].grid.block_width_log2: 4

> acc->acc->awb.stripes[1].grid.height: 24

> acc->awb.stripes[1].grid.block_height_log2: 6

> acc->awb.stripes[1].grid.x_start: 0

> acc->awb.stripes[1].grid.x_end: 1263

> acc->awb.stripes[1].grid.y_start: 0

> acc->awb.stripes[1].grid.y_end: 1535

> 

> This has been outputted with: https://paste.debian.net/1212791/

> 

> The examples I gave before were 1280x720 output and not 1920x1080, here

> are they:

> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> 

> As you can see we have the same behaviour.

> 

> Thanks,

> JM

> 

> >

> > ________________________

> > BRs,

> > Bingbu Cao

> >

> >> -----Original Message-----

> >> From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> >> Sent: Tuesday, September 21, 2021 10:34 PM

> >> To: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> >> Cc: Sakari Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com;

> >> linux- media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>;

> >> Cao, Bingbu <bingbu.cao@intel.com>

> >> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> >> height_per_slice in the stripes

> >>

> >> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

> >>> Hi Sakari, and Tomasz as I have a remark/question for you :-)

> >>>

> >>> On 21/09/2021 13:07, Sakari Ailus wrote:

> >>>> Hi Jean-Michel --- and Bingbu and Tianshu,

> >>>>

> >>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

> >>>>> While playing with low resolutions for the grid, it appeared that

> >>>>> height_per_slice is not initialised if we are not using both

> >>>>> stripes for the calculations. This pattern occurs three times:

> >>>>> - for the awb_fr processing block

> >>>>> - for the af processing block

> >>>>> - for the awb processing block

> >>>>>

> >>>>> The idea of this small portion of code is to reduce complexity in

> >>>>> loading the statistics, it could be done also when only one stripe

> >>>>> is used. Fix it by getting this initialisation code outside of the

> >>>>> else() test case.

> >>>>>

> >>>>> Signed-off-by: Jean-Michel Hautbois

> >>>>> <jeanmichel.hautbois@ideasonboard.com>

> >>>>> ---

> >>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44

> >>>>> ++++++++++----------

> >>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> >>>>>

> >>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>> index e9d6bd9e9332..05da7dbdca78 100644

> >>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css,

> >> unsigned int pipe,

> >>>>>  					acc-

> >awb_fr.stripes[1].grid_cfg.width,

> >>>>>  					b_w_log2);

> >>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> >>>>> -

> >>>>> -		/*

> >>>>> -		 * To reduce complexity of debubbling and loading

> >>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> >>>>> -		 * stripes.

> >>>>> -		 */

> >>>>> -		for (i = 0; i < stripes; i++)

> >>>>> -			acc-

> >awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>  	}

> >>>>>

> >>>>> +	/*

> >>>>> +	 * To reduce complexity of debubbling and loading

> >>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> >>>>> +	 * stripes.

> >>>>> +	 */

> >>>>> +	for (i = 0; i < stripes; i++)

> >>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>> +

> >>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> >>>>>  		return -EINVAL;

> >>>>>

> >>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css,

> >> unsigned int pipe,

> >>>>>  			imgu_css_grid_end(acc-

> >af.stripes[1].grid_cfg.x_start,

> >>>>>  					  acc-

> >af.stripes[1].grid_cfg.width,

> >>>>>  					  b_w_log2);

> >>>>> -

> >>>>> -		/*

> >>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>> -		 */

> >>>>> -		for (i = 0; i < stripes; i++)

> >>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice =

> 1;

> >>>>>  	}

> >>>>>

> >>>>> +	/*

> >>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>> +	 */

> >>>>> +	for (i = 0; i < stripes; i++)

> >>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>> +

> >>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> >>>>>  		return -EINVAL;

> >>>>>

> >>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css,

> >> unsigned int pipe,

> >>>>>  			imgu_css_grid_end(acc-

> >awb.stripes[1].grid.x_start,

> >>>>>  					  acc->awb.stripes[1].grid.width,

> >>>>>  					  b_w_log2);

> >>>>> -

> >>>>> -		/*

> >>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>> -		 */

> >>>>> -		for (i = 0; i < stripes; i++)

> >>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>  	}

> >>>>>

> >>>>> +	/*

> >>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>> +	 */

> >>>>> +	for (i = 0; i < stripes; i++)

> >>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>> +

> >>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> >>>>>  		return -EINVAL;

> >>>>>

> >>>>

> >>>> While it seems like a sensible idea to initialise arguments to

> >>>> firmware, does this have an effect on the statistics format? If so,

> >>>> can the existing user space cope with that?

> >>>

> >>> To try and figure that out, we have tested several grid

> >>> configurations and inspected the captured statistics. We have

> >>> converted the statistics in an image, rendering each cell as a pixel

> >>> whose red, green and blue components are the cell's red, green and

> blue averages.

> >>> This turned out to be a very effectice tool to quickly visualize AWB

> >> statistics.

> >>> We have made a lot of tests with different output resolutions, from

> >>> a small one up to the full-scale one.

> >>>

> >>> Here is one example of a statistics output with a ViewFinder

> >>> configured as 1920x1280, with a BDS output configuration set to

> >>> 2304x1536 (sensor is 2592x1944).

> >>>

> >>> Without the patch, configuring a 79x45 grid of 16x16 cells we obtain

> >>> the

> >>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> >>> We can notice a weird padding every two lines and it seems to be

> >>> missing half of the frame.

> >>>

> >>> With the patch applied, the same configuration gives us the image:

> >>> https://pasteboard.co/rzap6axIvVdu.png

> >>>

> >>> We can clearly see the one padding pixel on the right, and the frame

> >>> is all there, as expected.

> >>>

> >>> Tomasz: We're concerned that this patch may have an impact on the

> >>> ChromeOS Intel Camera HAL with the IPU3. Is it possible for someone

> >>> to review and test this please?

> >>

> >> As shown by the images above, this is a real fix. It only affects

> >> grid configurations that use a single stripe (left or right), so

> >> either "small" resolutions (less than 1280 pixels at the BDS output

> >> if I recall correctly), or grid configurations that span the left

> >> part of the image with higher resolutions. The latter is probably

> >> unlikely. For the former, it may affect the binary library,

> >> especially if it includes a workaround for the bug.

> >>

> >> Still, this change is good I believe, so it should be upstreamed.

> >>

> >> --

> >> Regards,

> >>

> >> Laurent Pinchart
Laurent Pinchart Sept. 23, 2021, 9:45 a.m. UTC | #7
Hi Bingbu,

On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:
> Jean-Michel,

> 

> Firstly, the .height_per_slice could be 0 if your .grid.width larger than 32.


Which .height_per_slice are you talking about ? A field of that name
exists in both ipu3_uapi_acc_param.awb.config.grid and 
struct ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

They are both computed by the driver, in imgu_css_cfg_acc(). The former
is set to

	acc->awb.config.grid.height_per_slice =
		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0 if
grid.width > 160, which is invalid.

> From your configuration, looks like something wrong in the stripe configuration

> cause not entering the 2 stripes branch.


Why is that ? Isn't it valid for a grid configuration to use a single
stripe, if the image is small enough, or if the grid only covers the
left part of the image ?

> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

> > On 22/09/2021 06:33, Cao, Bingbu wrote:

> > > Jean-Michel,

> > >

> > > Thanks for you patch.

> > > What is the value of .config.grid_cfg.width for your low resolutions?

> > 

> > I don't know if a 1920x1280 output is a low resolution, but the grid is

> > configured as:

> > - grid_cfg.width = 79

> > - grid_cfg.height = 24

> > - grid_cfg.block_width_log2 = 4

> > - grid_cfg.block_height_log2 = 6

> > 

> > Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> > 

> > acc->stripe.down_scaled_stripes[0].width: 1280

> > acc->stripe.down_scaled_stripes[0].height: 1536

> > acc->stripe.down_scaled_stripes[0].offset: 0

> > acc->stripe.bds_out_stripes[0].width: 1280

> > acc->stripe.bds_out_stripes[0].height: 1536

> > acc->stripe.bds_out_stripes[0].offset: 0

> > acc->acc->awb.stripes[0].grid.width: 79

> > acc->awb.stripes[0].grid.block_width_log2: 4

> > acc->acc->awb.stripes[0].grid.height: 24

> > acc->awb.stripes[0].grid.block_height_log2: 6

> > acc->awb.stripes[0].grid.x_start: 0

> > acc->awb.stripes[0].grid.x_end: 1263

> > acc->awb.stripes[0].grid.y_start: 0

> > acc->awb.stripes[0].grid.y_end: 1535

> > acc->stripe.down_scaled_stripes[1].width: 1280

> > acc->stripe.down_scaled_stripes[1].height: 1536

> > acc->stripe.down_scaled_stripes[1].offset: 1024

> > acc->stripe.bds_out_stripes[1].width: 1280

> > acc->stripe.bds_out_stripes[1].height: 1536

> > acc->stripe.bds_out_stripes[1].offset: 1024

> > acc->acc->awb.stripes[1].grid.width: 79

> > acc->awb.stripes[1].grid.block_width_log2: 4

> > acc->acc->awb.stripes[1].grid.height: 24

> > acc->awb.stripes[1].grid.block_height_log2: 6

> > acc->awb.stripes[1].grid.x_start: 0

> > acc->awb.stripes[1].grid.x_end: 1263

> > acc->awb.stripes[1].grid.y_start: 0

> > acc->awb.stripes[1].grid.y_end: 1535

> > 

> > This has been outputted with: https://paste.debian.net/1212791/

> > 

> > The examples I gave before were 1280x720 output and not 1920x1080, here

> > are they:

> > - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> > - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> > 

> > As you can see we have the same behaviour.

> > 

> > > On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

> > >> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

> > >>> Hi Sakari, and Tomasz as I have a remark/question for you :-)

> > >>>

> > >>> On 21/09/2021 13:07, Sakari Ailus wrote:

> > >>>> Hi Jean-Michel --- and Bingbu and Tianshu,

> > >>>>

> > >>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

> > >>>>> While playing with low resolutions for the grid, it appeared that

> > >>>>> height_per_slice is not initialised if we are not using both

> > >>>>> stripes for the calculations. This pattern occurs three times:

> > >>>>> - for the awb_fr processing block

> > >>>>> - for the af processing block

> > >>>>> - for the awb processing block

> > >>>>>

> > >>>>> The idea of this small portion of code is to reduce complexity in

> > >>>>> loading the statistics, it could be done also when only one stripe

> > >>>>> is used. Fix it by getting this initialisation code outside of the

> > >>>>> else() test case.

> > >>>>>

> > >>>>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> > >>>>> ---

> > >>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------

> > >>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> > >>>>>

> > >>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c b/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>> index e9d6bd9e9332..05da7dbdca78 100644

> > >>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> > >>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,

> > >>>>>  					b_w_log2);

> > >>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> > >>>>> -

> > >>>>> -		/*

> > >>>>> -		 * To reduce complexity of debubbling and loading

> > >>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> > >>>>> -		 * stripes.

> > >>>>> -		 */

> > >>>>> -		for (i = 0; i < stripes; i++)

> > >>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>>  	}

> > >>>>>

> > >>>>> +	/*

> > >>>>> +	 * To reduce complexity of debubbling and loading

> > >>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> > >>>>> +	 * stripes.

> > >>>>> +	 */

> > >>>>> +	for (i = 0; i < stripes; i++)

> > >>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>> +

> > >>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> > >>>>>  		return -EINVAL;

> > >>>>>

> > >>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> > >>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

> > >>>>>  					  acc->af.stripes[1].grid_cfg.width,

> > >>>>>  					  b_w_log2);

> > >>>>> -

> > >>>>> -		/*

> > >>>>> -		 * To reduce complexity of debubbling and loading statistics

> > >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> > >>>>> -		 */

> > >>>>> -		for (i = 0; i < stripes; i++)

> > >>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>>  	}

> > >>>>>

> > >>>>> +	/*

> > >>>>> +	 * To reduce complexity of debubbling and loading statistics

> > >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > >>>>> +	 */

> > >>>>> +	for (i = 0; i < stripes; i++)

> > >>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>> +

> > >>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> > >>>>>  		return -EINVAL;

> > >>>>>

> > >>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> > >>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

> > >>>>>  					  acc->awb.stripes[1].grid.width,

> > >>>>>  					  b_w_log2);

> > >>>>> -

> > >>>>> -		/*

> > >>>>> -		 * To reduce complexity of debubbling and loading statistics

> > >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> > >>>>> -		 */

> > >>>>> -		for (i = 0; i < stripes; i++)

> > >>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> > >>>>>  	}

> > >>>>>

> > >>>>> +	/*

> > >>>>> +	 * To reduce complexity of debubbling and loading statistics

> > >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > >>>>> +	 */

> > >>>>> +	for (i = 0; i < stripes; i++)

> > >>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> > >>>>> +

> > >>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> > >>>>>  		return -EINVAL;

> > >>>>>

> > >>>>

> > >>>> While it seems like a sensible idea to initialise arguments to

> > >>>> firmware, does this have an effect on the statistics format? If so,

> > >>>> can the existing user space cope with that?

> > >>>

> > >>> To try and figure that out, we have tested several grid

> > >>> configurations and inspected the captured statistics. We have

> > >>> converted the statistics in an image, rendering each cell as a pixel

> > >>> whose red, green and blue components are the cell's red, green and blue averages.

> > >>> This turned out to be a very effectice tool to quickly visualize AWB

> > >> statistics.

> > >>> We have made a lot of tests with different output resolutions, from

> > >>> a small one up to the full-scale one.

> > >>>

> > >>> Here is one example of a statistics output with a ViewFinder

> > >>> configured as 1920x1280, with a BDS output configuration set to

> > >>> 2304x1536 (sensor is 2592x1944).

> > >>>

> > >>> Without the patch, configuring a 79x45 grid of 16x16 cells we obtain

> > >>> the

> > >>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> > >>> We can notice a weird padding every two lines and it seems to be

> > >>> missing half of the frame.

> > >>>

> > >>> With the patch applied, the same configuration gives us the image:

> > >>> https://pasteboard.co/rzap6axIvVdu.png

> > >>>

> > >>> We can clearly see the one padding pixel on the right, and the frame

> > >>> is all there, as expected.

> > >>>

> > >>> Tomasz: We're concerned that this patch may have an impact on the

> > >>> ChromeOS Intel Camera HAL with the IPU3. Is it possible for someone

> > >>> to review and test this please?

> > >>

> > >> As shown by the images above, this is a real fix. It only affects

> > >> grid configurations that use a single stripe (left or right), so

> > >> either "small" resolutions (less than 1280 pixels at the BDS output

> > >> if I recall correctly), or grid configurations that span the left

> > >> part of the image with higher resolutions. The latter is probably

> > >> unlikely. For the former, it may affect the binary library,

> > >> especially if it includes a workaround for the bug.

> > >>

> > >> Still, this change is good I believe, so it should be upstreamed.


-- 
Regards,

Laurent Pinchart
Cao, Bingbu Sept. 23, 2021, 10:29 a.m. UTC | #8
Hi Laurent,

________________________
BRs,  
Bingbu Cao 

> -----Original Message-----

> From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> Sent: Thursday, September 23, 2021 5:46 PM

> To: Cao, Bingbu <bingbu.cao@intel.com>

> Cc: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>; Sakari

> Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>

> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> height_per_slice in the stripes

> 

> Hi Bingbu,

> 

> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

> > Jean-Michel,

> >

> > Firstly, the .height_per_slice could be 0 if your .grid.width larger

> than 32.

> 

> Which .height_per_slice are you talking about ? A field of that name

> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

> 

> They are both computed by the driver, in imgu_css_cfg_acc(). The former

> is set to

> 

> 	acc->awb.config.grid.height_per_slice =

> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

> 

> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0 if

> grid.width > 160, which is invalid.


For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

> 

> > From your configuration, looks like something wrong in the stripe

> > configuration cause not entering the 2 stripes branch.

> 

> Why is that ? Isn't it valid for a grid configuration to use a single

> stripe, if the image is small enough, or if the grid only covers the left

> part of the image ?

> 

> > On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

> > > On 22/09/2021 06:33, Cao, Bingbu wrote:

> > > > Jean-Michel,

> > > >

> > > > Thanks for you patch.

> > > > What is the value of .config.grid_cfg.width for your low

> resolutions?

> > >

> > > I don't know if a 1920x1280 output is a low resolution, but the grid

> > > is configured as:

> > > - grid_cfg.width = 79

> > > - grid_cfg.height = 24

> > > - grid_cfg.block_width_log2 = 4

> > > - grid_cfg.block_height_log2 = 6

> > >

> > > Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> > >

> > > acc->stripe.down_scaled_stripes[0].width: 1280

> > > acc->stripe.down_scaled_stripes[0].height: 1536

> > > acc->stripe.down_scaled_stripes[0].offset: 0

> > > acc->stripe.bds_out_stripes[0].width: 1280

> > > acc->stripe.bds_out_stripes[0].height: 1536

> > > acc->stripe.bds_out_stripes[0].offset: 0

> > > acc->acc->awb.stripes[0].grid.width: 79

> > > acc->awb.stripes[0].grid.block_width_log2: 4

> > > acc->acc->awb.stripes[0].grid.height: 24

> > > acc->awb.stripes[0].grid.block_height_log2: 6

> > > acc->awb.stripes[0].grid.x_start: 0

> > > acc->awb.stripes[0].grid.x_end: 1263

> > > acc->awb.stripes[0].grid.y_start: 0

> > > acc->awb.stripes[0].grid.y_end: 1535

> > > acc->stripe.down_scaled_stripes[1].width: 1280

> > > acc->stripe.down_scaled_stripes[1].height: 1536

> > > acc->stripe.down_scaled_stripes[1].offset: 1024

> > > acc->stripe.bds_out_stripes[1].width: 1280

> > > acc->stripe.bds_out_stripes[1].height: 1536

> > > acc->stripe.bds_out_stripes[1].offset: 1024

> > > acc->acc->awb.stripes[1].grid.width: 79

> > > acc->awb.stripes[1].grid.block_width_log2: 4

> > > acc->acc->awb.stripes[1].grid.height: 24

> > > acc->awb.stripes[1].grid.block_height_log2: 6

> > > acc->awb.stripes[1].grid.x_start: 0

> > > acc->awb.stripes[1].grid.x_end: 1263

> > > acc->awb.stripes[1].grid.y_start: 0

> > > acc->awb.stripes[1].grid.y_end: 1535


Are these dumps from 1920x1280 output?

> > >

> > > This has been outputted with: https://paste.debian.net/1212791/

> > >

> > > The examples I gave before were 1280x720 output and not 1920x1080,

> > > here are they:

> > > - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> > > - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> > >

> > > As you can see we have the same behaviour.

> > >

> > > > On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

> > > >> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois

> wrote:

> > > >>> Hi Sakari, and Tomasz as I have a remark/question for you :-)

> > > >>>

> > > >>> On 21/09/2021 13:07, Sakari Ailus wrote:

> > > >>>> Hi Jean-Michel --- and Bingbu and Tianshu,

> > > >>>>

> > > >>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois

> wrote:

> > > >>>>> While playing with low resolutions for the grid, it appeared

> > > >>>>> that height_per_slice is not initialised if we are not using

> > > >>>>> both stripes for the calculations. This pattern occurs three

> times:

> > > >>>>> - for the awb_fr processing block

> > > >>>>> - for the af processing block

> > > >>>>> - for the awb processing block

> > > >>>>>

> > > >>>>> The idea of this small portion of code is to reduce complexity

> > > >>>>> in loading the statistics, it could be done also when only one

> > > >>>>> stripe is used. Fix it by getting this initialisation code

> > > >>>>> outside of the

> > > >>>>> else() test case.

> > > >>>>>

> > > >>>>> Signed-off-by: Jean-Michel Hautbois

> > > >>>>> <jeanmichel.hautbois@ideasonboard.com>

> > > >>>>> ---

> > > >>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44

> > > >>>>> ++++++++++----------

> > > >>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> > > >>>>>

> > > >>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> > > >>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> > > >>>>> index e9d6bd9e9332..05da7dbdca78 100644

> > > >>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> > > >>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> > > >>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> > > >>>>>  					acc-

> >awb_fr.stripes[1].grid_cfg.width,

> > > >>>>>  					b_w_log2);

> > > >>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> > > >>>>> -

> > > >>>>> -		/*

> > > >>>>> -		 * To reduce complexity of debubbling and loading

> > > >>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> > > >>>>> -		 * stripes.

> > > >>>>> -		 */

> > > >>>>> -		for (i = 0; i < stripes; i++)

> > > >>>>> -			acc-

> >awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > > >>>>>  	}

> > > >>>>>

> > > >>>>> +	/*

> > > >>>>> +	 * To reduce complexity of debubbling and loading

> > > >>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> > > >>>>> +	 * stripes.

> > > >>>>> +	 */

> > > >>>>> +	for (i = 0; i < stripes; i++)

> > > >>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > > >>>>> +

> > > >>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> > > >>>>>  		return -EINVAL;

> > > >>>>>

> > > >>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> > > >>>>>  			imgu_css_grid_end(acc-

> >af.stripes[1].grid_cfg.x_start,

> > > >>>>>  					  acc-

> >af.stripes[1].grid_cfg.width,

> > > >>>>>  					  b_w_log2);

> > > >>>>> -

> > > >>>>> -		/*

> > > >>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> > > >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> > > >>>>> -		 */

> > > >>>>> -		for (i = 0; i < stripes; i++)

> > > >>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice =

> 1;

> > > >>>>>  	}

> > > >>>>>

> > > >>>>> +	/*

> > > >>>>> +	 * To reduce complexity of debubbling and loading statistics

> > > >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > > >>>>> +	 */

> > > >>>>> +	for (i = 0; i < stripes; i++)

> > > >>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > > >>>>> +

> > > >>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> > > >>>>>  		return -EINVAL;

> > > >>>>>

> > > >>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> > > >>>>>  			imgu_css_grid_end(acc-

> >awb.stripes[1].grid.x_start,

> > > >>>>>  					  acc->awb.stripes[1].grid.width,

> > > >>>>>  					  b_w_log2);

> > > >>>>> -

> > > >>>>> -		/*

> > > >>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> > > >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> > > >>>>> -		 */

> > > >>>>> -		for (i = 0; i < stripes; i++)

> > > >>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> > > >>>>>  	}

> > > >>>>>

> > > >>>>> +	/*

> > > >>>>> +	 * To reduce complexity of debubbling and loading statistics

> > > >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > > >>>>> +	 */

> > > >>>>> +	for (i = 0; i < stripes; i++)

> > > >>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> > > >>>>> +

> > > >>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> > > >>>>>  		return -EINVAL;

> > > >>>>>

> > > >>>>

> > > >>>> While it seems like a sensible idea to initialise arguments to

> > > >>>> firmware, does this have an effect on the statistics format? If

> > > >>>> so, can the existing user space cope with that?

> > > >>>

> > > >>> To try and figure that out, we have tested several grid

> > > >>> configurations and inspected the captured statistics. We have

> > > >>> converted the statistics in an image, rendering each cell as a

> > > >>> pixel whose red, green and blue components are the cell's red,

> green and blue averages.

> > > >>> This turned out to be a very effectice tool to quickly visualize

> > > >>> AWB

> > > >> statistics.

> > > >>> We have made a lot of tests with different output resolutions,

> > > >>> from a small one up to the full-scale one.

> > > >>>

> > > >>> Here is one example of a statistics output with a ViewFinder

> > > >>> configured as 1920x1280, with a BDS output configuration set to

> > > >>> 2304x1536 (sensor is 2592x1944).

> > > >>>

> > > >>> Without the patch, configuring a 79x45 grid of 16x16 cells we

> > > >>> obtain the

> > > >>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> > > >>> We can notice a weird padding every two lines and it seems to be

> > > >>> missing half of the frame.

> > > >>>

> > > >>> With the patch applied, the same configuration gives us the image:

> > > >>> https://pasteboard.co/rzap6axIvVdu.png

> > > >>>

> > > >>> We can clearly see the one padding pixel on the right, and the

> > > >>> frame is all there, as expected.

> > > >>>

> > > >>> Tomasz: We're concerned that this patch may have an impact on

> > > >>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

> > > >>> someone to review and test this please?

> > > >>

> > > >> As shown by the images above, this is a real fix. It only affects

> > > >> grid configurations that use a single stripe (left or right), so

> > > >> either "small" resolutions (less than 1280 pixels at the BDS

> > > >> output if I recall correctly), or grid configurations that span

> > > >> the left part of the image with higher resolutions. The latter is

> > > >> probably unlikely. For the former, it may affect the binary

> > > >> library, especially if it includes a workaround for the bug.

> > > >>

> > > >> Still, this change is good I believe, so it should be upstreamed.

> 

> --

> Regards,

> 

> Laurent Pinchart
Laurent Pinchart Sept. 23, 2021, 10:49 a.m. UTC | #9
Hi Bingbu,

On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:
> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

> > On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

> > > Jean-Michel,

> > >

> > > Firstly, the .height_per_slice could be 0 if your .grid.width larger

> > > than 32.

> > 

> > Which .height_per_slice are you talking about ? A field of that name

> > exists in both ipu3_uapi_acc_param.awb.config.grid and struct

> > ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

> > 

> > They are both computed by the driver, in imgu_css_cfg_acc(). The former

> > is set to

> > 

> > 	acc->awb.config.grid.height_per_slice =

> > 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

> > 

> > IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0 if

> > grid.width > 160, which is invalid.

> 

> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.


Indeed, my bad. I was focussing on the AWB statistics.

What are the implications of a height_per_slice value of 0 ?

While we are on this topic, what is a "slice" ? Does it matter for the
user, as in does it have an impact on the statistics values, or on how
they're arranged in memory, or is it an implementation detail of the
firmware that has no consequence on what can be seen by the user ? (The
"user" here is the code that reads the statistics in userspace).

> > > From your configuration, looks like something wrong in the stripe

> > > configuration cause not entering the 2 stripes branch.

> > 

> > Why is that ? Isn't it valid for a grid configuration to use a single

> > stripe, if the image is small enough, or if the grid only covers the left

> > part of the image ?

> > 

> > > On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

> > > > On 22/09/2021 06:33, Cao, Bingbu wrote:

> > > > > Jean-Michel,

> > > > >

> > > > > Thanks for you patch.

> > > > > What is the value of .config.grid_cfg.width for your low resolutions?

> > > >

> > > > I don't know if a 1920x1280 output is a low resolution, but the grid

> > > > is configured as:

> > > > - grid_cfg.width = 79

> > > > - grid_cfg.height = 24

> > > > - grid_cfg.block_width_log2 = 4

> > > > - grid_cfg.block_height_log2 = 6

> > > >

> > > > Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> > > >

> > > > acc->stripe.down_scaled_stripes[0].width: 1280

> > > > acc->stripe.down_scaled_stripes[0].height: 1536

> > > > acc->stripe.down_scaled_stripes[0].offset: 0

> > > > acc->stripe.bds_out_stripes[0].width: 1280

> > > > acc->stripe.bds_out_stripes[0].height: 1536

> > > > acc->stripe.bds_out_stripes[0].offset: 0

> > > > acc->acc->awb.stripes[0].grid.width: 79

> > > > acc->awb.stripes[0].grid.block_width_log2: 4

> > > > acc->acc->awb.stripes[0].grid.height: 24

> > > > acc->awb.stripes[0].grid.block_height_log2: 6

> > > > acc->awb.stripes[0].grid.x_start: 0

> > > > acc->awb.stripes[0].grid.x_end: 1263

> > > > acc->awb.stripes[0].grid.y_start: 0

> > > > acc->awb.stripes[0].grid.y_end: 1535

> > > > acc->stripe.down_scaled_stripes[1].width: 1280

> > > > acc->stripe.down_scaled_stripes[1].height: 1536

> > > > acc->stripe.down_scaled_stripes[1].offset: 1024

> > > > acc->stripe.bds_out_stripes[1].width: 1280

> > > > acc->stripe.bds_out_stripes[1].height: 1536

> > > > acc->stripe.bds_out_stripes[1].offset: 1024

> > > > acc->acc->awb.stripes[1].grid.width: 79

> > > > acc->awb.stripes[1].grid.block_width_log2: 4

> > > > acc->acc->awb.stripes[1].grid.height: 24

> > > > acc->awb.stripes[1].grid.block_height_log2: 6

> > > > acc->awb.stripes[1].grid.x_start: 0

> > > > acc->awb.stripes[1].grid.x_end: 1263

> > > > acc->awb.stripes[1].grid.y_start: 0

> > > > acc->awb.stripes[1].grid.y_end: 1535

> 

> Are these dumps from 1920x1280 output?


Jean-Michel, could you comment on this ?

Note that the grid is configured with 79 cells of 16 pixels, covering
1264 pixels horizontally. That's not the full image for a 1920 pixels
output, and will probably not be done in practice, but there's nothing
preventing the grid from covering part of the image only.

> > > > This has been outputted with: https://paste.debian.net/1212791/

> > > >

> > > > The examples I gave before were 1280x720 output and not 1920x1080,

> > > > here are they:

> > > > - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> > > > - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> > > >

> > > > As you can see we have the same behaviour.

> > > >

> > > > > On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

> > > > >> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

> > > > >>> On 21/09/2021 13:07, Sakari Ailus wrote:

> > > > >>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

> > > > >>>>> While playing with low resolutions for the grid, it appeared

> > > > >>>>> that height_per_slice is not initialised if we are not using

> > > > >>>>> both stripes for the calculations. This pattern occurs three times:

> > > > >>>>> - for the awb_fr processing block

> > > > >>>>> - for the af processing block

> > > > >>>>> - for the awb processing block

> > > > >>>>>

> > > > >>>>> The idea of this small portion of code is to reduce complexity

> > > > >>>>> in loading the statistics, it could be done also when only one

> > > > >>>>> stripe is used. Fix it by getting this initialisation code

> > > > >>>>> outside of the

> > > > >>>>> else() test case.

> > > > >>>>>

> > > > >>>>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> > > > >>>>> ---

> > > > >>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>> ++++++++++----------

> > > > >>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> > > > >>>>>

> > > > >>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> > > > >>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> > > > >>>>> index e9d6bd9e9332..05da7dbdca78 100644

> > > > >>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> > > > >>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> > > > >>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> > > > >>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,

> > > > >>>>>  					b_w_log2);

> > > > >>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> > > > >>>>> -

> > > > >>>>> -		/*

> > > > >>>>> -		 * To reduce complexity of debubbling and loading

> > > > >>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> > > > >>>>> -		 * stripes.

> > > > >>>>> -		 */

> > > > >>>>> -		for (i = 0; i < stripes; i++)

> > > > >>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > > > >>>>>  	}

> > > > >>>>>

> > > > >>>>> +	/*

> > > > >>>>> +	 * To reduce complexity of debubbling and loading

> > > > >>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> > > > >>>>> +	 * stripes.

> > > > >>>>> +	 */

> > > > >>>>> +	for (i = 0; i < stripes; i++)

> > > > >>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > > > >>>>> +

> > > > >>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> > > > >>>>>  		return -EINVAL;

> > > > >>>>>

> > > > >>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> > > > >>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

> > > > >>>>>  					  acc->af.stripes[1].grid_cfg.width,

> > > > >>>>>  					  b_w_log2);

> > > > >>>>> -

> > > > >>>>> -		/*

> > > > >>>>> -		 * To reduce complexity of debubbling and loading statistics

> > > > >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> > > > >>>>> -		 */

> > > > >>>>> -		for (i = 0; i < stripes; i++)

> > > > >>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > > > >>>>>  	}

> > > > >>>>>

> > > > >>>>> +	/*

> > > > >>>>> +	 * To reduce complexity of debubbling and loading statistics

> > > > >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > > > >>>>> +	 */

> > > > >>>>> +	for (i = 0; i < stripes; i++)

> > > > >>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> > > > >>>>> +

> > > > >>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> > > > >>>>>  		return -EINVAL;

> > > > >>>>>

> > > > >>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> > > > >>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

> > > > >>>>>  					  acc->awb.stripes[1].grid.width,

> > > > >>>>>  					  b_w_log2);

> > > > >>>>> -

> > > > >>>>> -		/*

> > > > >>>>> -		 * To reduce complexity of debubbling and loading statistics

> > > > >>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> > > > >>>>> -		 */

> > > > >>>>> -		for (i = 0; i < stripes; i++)

> > > > >>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> > > > >>>>>  	}

> > > > >>>>>

> > > > >>>>> +	/*

> > > > >>>>> +	 * To reduce complexity of debubbling and loading statistics

> > > > >>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > > > >>>>> +	 */

> > > > >>>>> +	for (i = 0; i < stripes; i++)

> > > > >>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> > > > >>>>> +

> > > > >>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> > > > >>>>>  		return -EINVAL;

> > > > >>>>>

> > > > >>>>

> > > > >>>> While it seems like a sensible idea to initialise arguments to

> > > > >>>> firmware, does this have an effect on the statistics format? If

> > > > >>>> so, can the existing user space cope with that?

> > > > >>>

> > > > >>> To try and figure that out, we have tested several grid

> > > > >>> configurations and inspected the captured statistics. We have

> > > > >>> converted the statistics in an image, rendering each cell as a

> > > > >>> pixel whose red, green and blue components are the cell's red, green and blue averages.

> > > > >>> This turned out to be a very effectice tool to quickly visualize

> > > > >>> AWB statistics.

> > > > >>> We have made a lot of tests with different output resolutions,

> > > > >>> from a small one up to the full-scale one.

> > > > >>>

> > > > >>> Here is one example of a statistics output with a ViewFinder

> > > > >>> configured as 1920x1280, with a BDS output configuration set to

> > > > >>> 2304x1536 (sensor is 2592x1944).

> > > > >>>

> > > > >>> Without the patch, configuring a 79x45 grid of 16x16 cells we

> > > > >>> obtain the

> > > > >>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> > > > >>> We can notice a weird padding every two lines and it seems to be

> > > > >>> missing half of the frame.

> > > > >>>

> > > > >>> With the patch applied, the same configuration gives us the image:

> > > > >>> https://pasteboard.co/rzap6axIvVdu.png

> > > > >>>

> > > > >>> We can clearly see the one padding pixel on the right, and the

> > > > >>> frame is all there, as expected.

> > > > >>>

> > > > >>> Tomasz: We're concerned that this patch may have an impact on

> > > > >>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

> > > > >>> someone to review and test this please?

> > > > >>

> > > > >> As shown by the images above, this is a real fix. It only affects

> > > > >> grid configurations that use a single stripe (left or right), so

> > > > >> either "small" resolutions (less than 1280 pixels at the BDS

> > > > >> output if I recall correctly), or grid configurations that span

> > > > >> the left part of the image with higher resolutions. The latter is

> > > > >> probably unlikely. For the former, it may affect the binary

> > > > >> library, especially if it includes a workaround for the bug.

> > > > >>

> > > > >> Still, this change is good I believe, so it should be upstreamed.


-- 
Regards,

Laurent Pinchart
Jean-Michel Hautbois Sept. 23, 2021, 11:56 a.m. UTC | #10
Hi Bingbu, Laurent,

On 23/09/2021 12:49, Laurent Pinchart wrote:
> Hi Bingbu,

> 

> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

>>>> Jean-Michel,

>>>>

>>>> Firstly, the .height_per_slice could be 0 if your .grid.width larger

>>>> than 32.

>>>

>>> Which .height_per_slice are you talking about ? A field of that name

>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

>>>

>>> They are both computed by the driver, in imgu_css_cfg_acc(). The former

>>> is set to

>>>

>>> 	acc->awb.config.grid.height_per_slice =

>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

>>>

>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0 if

>>> grid.width > 160, which is invalid.

>>

>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

> 

> Indeed, my bad. I was focussing on the AWB statistics.

> 

> What are the implications of a height_per_slice value of 0 ?

> 

> While we are on this topic, what is a "slice" ? Does it matter for the

> user, as in does it have an impact on the statistics values, or on how

> they're arranged in memory, or is it an implementation detail of the

> firmware that has no consequence on what can be seen by the user ? (The

> "user" here is the code that reads the statistics in userspace).

> 

>>>> From your configuration, looks like something wrong in the stripe

>>>> configuration cause not entering the 2 stripes branch.

>>>

>>> Why is that ? Isn't it valid for a grid configuration to use a single

>>> stripe, if the image is small enough, or if the grid only covers the left

>>> part of the image ?

>>>

>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

>>>>>> Jean-Michel,

>>>>>>

>>>>>> Thanks for you patch.

>>>>>> What is the value of .config.grid_cfg.width for your low resolutions?

>>>>>

>>>>> I don't know if a 1920x1280 output is a low resolution, but the grid

>>>>> is configured as:

>>>>> - grid_cfg.width = 79

>>>>> - grid_cfg.height = 24

>>>>> - grid_cfg.block_width_log2 = 4

>>>>> - grid_cfg.block_height_log2 = 6

>>>>>

>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

>>>>>

>>>>> acc->stripe.down_scaled_stripes[0].width: 1280

>>>>> acc->stripe.down_scaled_stripes[0].height: 1536

>>>>> acc->stripe.down_scaled_stripes[0].offset: 0

>>>>> acc->stripe.bds_out_stripes[0].width: 1280

>>>>> acc->stripe.bds_out_stripes[0].height: 1536

>>>>> acc->stripe.bds_out_stripes[0].offset: 0

>>>>> acc->acc->awb.stripes[0].grid.width: 79

>>>>> acc->awb.stripes[0].grid.block_width_log2: 4

>>>>> acc->acc->awb.stripes[0].grid.height: 24

>>>>> acc->awb.stripes[0].grid.block_height_log2: 6

>>>>> acc->awb.stripes[0].grid.x_start: 0

>>>>> acc->awb.stripes[0].grid.x_end: 1263

>>>>> acc->awb.stripes[0].grid.y_start: 0

>>>>> acc->awb.stripes[0].grid.y_end: 1535

>>>>> acc->stripe.down_scaled_stripes[1].width: 1280

>>>>> acc->stripe.down_scaled_stripes[1].height: 1536

>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

>>>>> acc->stripe.bds_out_stripes[1].width: 1280

>>>>> acc->stripe.bds_out_stripes[1].height: 1536

>>>>> acc->stripe.bds_out_stripes[1].offset: 1024

>>>>> acc->acc->awb.stripes[1].grid.width: 79

>>>>> acc->awb.stripes[1].grid.block_width_log2: 4

>>>>> acc->acc->awb.stripes[1].grid.height: 24

>>>>> acc->awb.stripes[1].grid.block_height_log2: 6

>>>>> acc->awb.stripes[1].grid.x_start: 0

>>>>> acc->awb.stripes[1].grid.x_end: 1263

>>>>> acc->awb.stripes[1].grid.y_start: 0

>>>>> acc->awb.stripes[1].grid.y_end: 1535

>>

>> Are these dumps from 1920x1280 output?

> 

> Jean-Michel, could you comment on this ?

> 

> Note that the grid is configured with 79 cells of 16 pixels, covering

> 1264 pixels horizontally. That's not the full image for a 1920 pixels

> output, and will probably not be done in practice, but there's nothing

> preventing the grid from covering part of the image only.

> 


It is a dump for a 1920x1280 output.
If it can help, the configuration set in ImgU is:
  IF: 2592x1728
  BDS: 2304x1536
  GDC: 1920x1280


>>>>> This has been outputted with: https://paste.debian.net/1212791/

>>>>>

>>>>> The examples I gave before were 1280x720 output and not 1920x1080,

>>>>> here are they:

>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

>>>>>

>>>>> As you can see we have the same behaviour.

>>>>>

>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

>>>>>>>>>> While playing with low resolutions for the grid, it appeared

>>>>>>>>>> that height_per_slice is not initialised if we are not using

>>>>>>>>>> both stripes for the calculations. This pattern occurs three times:

>>>>>>>>>> - for the awb_fr processing block

>>>>>>>>>> - for the af processing block

>>>>>>>>>> - for the awb processing block

>>>>>>>>>>

>>>>>>>>>> The idea of this small portion of code is to reduce complexity

>>>>>>>>>> in loading the statistics, it could be done also when only one

>>>>>>>>>> stripe is used. Fix it by getting this initialisation code

>>>>>>>>>> outside of the

>>>>>>>>>> else() test case.

>>>>>>>>>>

>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

>>>>>>>>>> ---

>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>> ++++++++++----------

>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

>>>>>>>>>>

>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>>>>>>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,

>>>>>>>>>>  					b_w_log2);

>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

>>>>>>>>>> -

>>>>>>>>>> -		/*

>>>>>>>>>> -		 * To reduce complexity of debubbling and loading

>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

>>>>>>>>>> -		 * stripes.

>>>>>>>>>> -		 */

>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>  	}

>>>>>>>>>>

>>>>>>>>>> +	/*

>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

>>>>>>>>>> +	 * stripes.

>>>>>>>>>> +	 */

>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>> +

>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>

>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>>>>>>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

>>>>>>>>>>  					  acc->af.stripes[1].grid_cfg.width,

>>>>>>>>>>  					  b_w_log2);

>>>>>>>>>> -

>>>>>>>>>> -		/*

>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> -		 */

>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>  	}

>>>>>>>>>>

>>>>>>>>>> +	/*

>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> +	 */

>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>> +

>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>

>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>>>>>>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,

>>>>>>>>>>  					  b_w_log2);

>>>>>>>>>> -

>>>>>>>>>> -		/*

>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> -		 */

>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>>>>>>  	}

>>>>>>>>>>

>>>>>>>>>> +	/*

>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> +	 */

>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>>>>>> +

>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>

>>>>>>>>>

>>>>>>>>> While it seems like a sensible idea to initialise arguments to

>>>>>>>>> firmware, does this have an effect on the statistics format? If

>>>>>>>>> so, can the existing user space cope with that?

>>>>>>>>

>>>>>>>> To try and figure that out, we have tested several grid

>>>>>>>> configurations and inspected the captured statistics. We have

>>>>>>>> converted the statistics in an image, rendering each cell as a

>>>>>>>> pixel whose red, green and blue components are the cell's red, green and blue averages.

>>>>>>>> This turned out to be a very effectice tool to quickly visualize

>>>>>>>> AWB statistics.

>>>>>>>> We have made a lot of tests with different output resolutions,

>>>>>>>> from a small one up to the full-scale one.

>>>>>>>>

>>>>>>>> Here is one example of a statistics output with a ViewFinder

>>>>>>>> configured as 1920x1280, with a BDS output configuration set to

>>>>>>>> 2304x1536 (sensor is 2592x1944).

>>>>>>>>

>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we

>>>>>>>> obtain the

>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

>>>>>>>> We can notice a weird padding every two lines and it seems to be

>>>>>>>> missing half of the frame.

>>>>>>>>

>>>>>>>> With the patch applied, the same configuration gives us the image:

>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

>>>>>>>>

>>>>>>>> We can clearly see the one padding pixel on the right, and the

>>>>>>>> frame is all there, as expected.

>>>>>>>>

>>>>>>>> Tomasz: We're concerned that this patch may have an impact on

>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

>>>>>>>> someone to review and test this please?

>>>>>>>

>>>>>>> As shown by the images above, this is a real fix. It only affects

>>>>>>> grid configurations that use a single stripe (left or right), so

>>>>>>> either "small" resolutions (less than 1280 pixels at the BDS

>>>>>>> output if I recall correctly), or grid configurations that span

>>>>>>> the left part of the image with higher resolutions. The latter is

>>>>>>> probably unlikely. For the former, it may affect the binary

>>>>>>> library, especially if it includes a workaround for the bug.

>>>>>>>

>>>>>>> Still, this change is good I believe, so it should be upstreamed.

>
Cao, Bingbu Sept. 28, 2021, 1:21 a.m. UTC | #11
________________________
BRs,  
Bingbu Cao 

> -----Original Message-----

> From: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> Sent: Thursday, September 23, 2021 7:57 PM

> To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>; Cao, Bingbu

> <bingbu.cao@intel.com>

> Cc: Sakari Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>

> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> height_per_slice in the stripes

> 

> Hi Bingbu, Laurent,

> 

> On 23/09/2021 12:49, Laurent Pinchart wrote:

> > Hi Bingbu,

> >

> > On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

> >> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

> >>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

> >>>> Jean-Michel,

> >>>>

> >>>> Firstly, the .height_per_slice could be 0 if your .grid.width

> >>>> larger than 32.

> >>>

> >>> Which .height_per_slice are you talking about ? A field of that name

> >>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

> >>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

> >>>

> >>> They are both computed by the driver, in imgu_css_cfg_acc(). The

> >>> former is set to

> >>>

> >>> 	acc->awb.config.grid.height_per_slice =

> >>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

> >>>

> >>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0

> >>> if grid.width > 160, which is invalid.

> >>

> >> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

> >

> > Indeed, my bad. I was focussing on the AWB statistics.

> >

> > What are the implications of a height_per_slice value of 0 ?

> >

> > While we are on this topic, what is a "slice" ? Does it matter for the

> > user, as in does it have an impact on the statistics values, or on how

> > they're arranged in memory, or is it an implementation detail of the

> > firmware that has no consequence on what can be seen by the user ?

> > (The "user" here is the code that reads the statistics in userspace).

> >

> >>>> From your configuration, looks like something wrong in the stripe

> >>>> configuration cause not entering the 2 stripes branch.

> >>>

> >>> Why is that ? Isn't it valid for a grid configuration to use a

> >>> single stripe, if the image is small enough, or if the grid only

> >>> covers the left part of the image ?

> >>>

> >>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

> >>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

> >>>>>> Jean-Michel,

> >>>>>>

> >>>>>> Thanks for you patch.

> >>>>>> What is the value of .config.grid_cfg.width for your low

> resolutions?

> >>>>>

> >>>>> I don't know if a 1920x1280 output is a low resolution, but the

> >>>>> grid is configured as:

> >>>>> - grid_cfg.width = 79

> >>>>> - grid_cfg.height = 24

> >>>>> - grid_cfg.block_width_log2 = 4

> >>>>> - grid_cfg.block_height_log2 = 6

> >>>>>

> >>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> >>>>>

> >>>>> acc->stripe.down_scaled_stripes[0].width: 1280

> >>>>> acc->stripe.down_scaled_stripes[0].height: 1536

> >>>>> acc->stripe.down_scaled_stripes[0].offset: 0

> >>>>> acc->stripe.bds_out_stripes[0].width: 1280

> >>>>> acc->stripe.bds_out_stripes[0].height: 1536

> >>>>> acc->stripe.bds_out_stripes[0].offset: 0

> >>>>> acc->acc->awb.stripes[0].grid.width: 79

> >>>>> acc->awb.stripes[0].grid.block_width_log2: 4

> >>>>> acc->acc->awb.stripes[0].grid.height: 24

> >>>>> acc->awb.stripes[0].grid.block_height_log2: 6

> >>>>> acc->awb.stripes[0].grid.x_start: 0

> >>>>> acc->awb.stripes[0].grid.x_end: 1263

> >>>>> acc->awb.stripes[0].grid.y_start: 0

> >>>>> acc->awb.stripes[0].grid.y_end: 1535

> >>>>> acc->stripe.down_scaled_stripes[1].width: 1280

> >>>>> acc->stripe.down_scaled_stripes[1].height: 1536

> >>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

> >>>>> acc->stripe.bds_out_stripes[1].width: 1280

> >>>>> acc->stripe.bds_out_stripes[1].height: 1536

> >>>>> acc->stripe.bds_out_stripes[1].offset: 1024

> >>>>> acc->acc->awb.stripes[1].grid.width: 79

> >>>>> acc->awb.stripes[1].grid.block_width_log2: 4

> >>>>> acc->acc->awb.stripes[1].grid.height: 24

> >>>>> acc->awb.stripes[1].grid.block_height_log2: 6

> >>>>> acc->awb.stripes[1].grid.x_start: 0

> >>>>> acc->awb.stripes[1].grid.x_end: 1263

> >>>>> acc->awb.stripes[1].grid.y_start: 0

> >>>>> acc->awb.stripes[1].grid.y_end: 1535

> >>

> >> Are these dumps from 1920x1280 output?

> >

> > Jean-Michel, could you comment on this ?

> >

> > Note that the grid is configured with 79 cells of 16 pixels, covering

> > 1264 pixels horizontally. That's not the full image for a 1920 pixels

> > output, and will probably not be done in practice, but there's nothing

> > preventing the grid from covering part of the image only.

> >

> 

> It is a dump for a 1920x1280 output.

> If it can help, the configuration set in ImgU is:

>   IF: 2592x1728

>   BDS: 2304x1536

>   GDC: 1920x1280


Jean-Michel,

It looks you are trying to use 2 stripes and the grid size is 2528x1536, and
the awb.config.grid.x_end should be larger than the 
bds_out_stripes[0].width - 10, it would not hit any 1 stripe condition.

could you also share your awb.config.grid?

> 

> 

> >>>>> This has been outputted with: https://paste.debian.net/1212791/

> >>>>>

> >>>>> The examples I gave before were 1280x720 output and not 1920x1080,

> >>>>> here are they:

> >>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> >>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> >>>>>

> >>>>> As you can see we have the same behaviour.

> >>>>>

> >>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

> >>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois

> wrote:

> >>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

> >>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois

> wrote:

> >>>>>>>>>> While playing with low resolutions for the grid, it appeared

> >>>>>>>>>> that height_per_slice is not initialised if we are not using

> >>>>>>>>>> both stripes for the calculations. This pattern occurs three

> times:

> >>>>>>>>>> - for the awb_fr processing block

> >>>>>>>>>> - for the af processing block

> >>>>>>>>>> - for the awb processing block

> >>>>>>>>>>

> >>>>>>>>>> The idea of this small portion of code is to reduce

> >>>>>>>>>> complexity in loading the statistics, it could be done also

> >>>>>>>>>> when only one stripe is used. Fix it by getting this

> >>>>>>>>>> initialisation code outside of the

> >>>>>>>>>> else() test case.

> >>>>>>>>>>

> >>>>>>>>>> Signed-off-by: Jean-Michel Hautbois

> >>>>>>>>>> <jeanmichel.hautbois@ideasonboard.com>

> >>>>>>>>>> ---

> >>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>>

> >>>>>>>>>> ++++++++++----------

> >>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> >>>>>>>>>>

> >>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

> >>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> >>>>>>>>>>  					acc-

> >awb_fr.stripes[1].grid_cfg.width,

> >>>>>>>>>>  					b_w_log2);

> >>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> >>>>>>>>>> -

> >>>>>>>>>> -		/*

> >>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> >>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> >>>>>>>>>> -		 * stripes.

> >>>>>>>>>> -		 */

> >>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>> -			acc-

> >awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>>  	}

> >>>>>>>>>>

> >>>>>>>>>> +	/*

> >>>>>>>>>> +	 * To reduce complexity of debubbling and loading

> >>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> >>>>>>>>>> +	 * stripes.

> >>>>>>>>>> +	 */

> >>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>> +

> >>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> >>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>

> >>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> >>>>>>>>>>  			imgu_css_grid_end(acc-

> >af.stripes[1].grid_cfg.x_start,

> >>>>>>>>>>  					  acc-

> >af.stripes[1].grid_cfg.width,

> >>>>>>>>>>  					  b_w_log2);

> >>>>>>>>>> -

> >>>>>>>>>> -		/*

> >>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> >>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> -		 */

> >>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice =

> 1;

> >>>>>>>>>>  	}

> >>>>>>>>>>

> >>>>>>>>>> +	/*

> >>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> +	 */

> >>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>> +

> >>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> >>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>

> >>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> >>>>>>>>>>  			imgu_css_grid_end(acc-

> >awb.stripes[1].grid.x_start,

> >>>>>>>>>>  					  acc->awb.stripes[1].grid.width,

> >>>>>>>>>>  					  b_w_log2);

> >>>>>>>>>> -

> >>>>>>>>>> -		/*

> >>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> >>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> -		 */

> >>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>>>>>>  	}

> >>>>>>>>>>

> >>>>>>>>>> +	/*

> >>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> +	 */

> >>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>>>>>> +

> >>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> >>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>

> >>>>>>>>>

> >>>>>>>>> While it seems like a sensible idea to initialise arguments to

> >>>>>>>>> firmware, does this have an effect on the statistics format?

> >>>>>>>>> If so, can the existing user space cope with that?

> >>>>>>>>

> >>>>>>>> To try and figure that out, we have tested several grid

> >>>>>>>> configurations and inspected the captured statistics. We have

> >>>>>>>> converted the statistics in an image, rendering each cell as a

> >>>>>>>> pixel whose red, green and blue components are the cell's red,

> green and blue averages.

> >>>>>>>> This turned out to be a very effectice tool to quickly

> >>>>>>>> visualize AWB statistics.

> >>>>>>>> We have made a lot of tests with different output resolutions,

> >>>>>>>> from a small one up to the full-scale one.

> >>>>>>>>

> >>>>>>>> Here is one example of a statistics output with a ViewFinder

> >>>>>>>> configured as 1920x1280, with a BDS output configuration set to

> >>>>>>>> 2304x1536 (sensor is 2592x1944).

> >>>>>>>>

> >>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we

> >>>>>>>> obtain the

> >>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> >>>>>>>> We can notice a weird padding every two lines and it seems to

> >>>>>>>> be missing half of the frame.

> >>>>>>>>

> >>>>>>>> With the patch applied, the same configuration gives us the

> image:

> >>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

> >>>>>>>>

> >>>>>>>> We can clearly see the one padding pixel on the right, and the

> >>>>>>>> frame is all there, as expected.

> >>>>>>>>

> >>>>>>>> Tomasz: We're concerned that this patch may have an impact on

> >>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

> >>>>>>>> someone to review and test this please?

> >>>>>>>

> >>>>>>> As shown by the images above, this is a real fix. It only

> >>>>>>> affects grid configurations that use a single stripe (left or

> >>>>>>> right), so either "small" resolutions (less than 1280 pixels at

> >>>>>>> the BDS output if I recall correctly), or grid configurations

> >>>>>>> that span the left part of the image with higher resolutions.

> >>>>>>> The latter is probably unlikely. For the former, it may affect

> >>>>>>> the binary library, especially if it includes a workaround for

> the bug.

> >>>>>>>

> >>>>>>> Still, this change is good I believe, so it should be upstreamed.

> >
Jean-Michel Hautbois Sept. 28, 2021, 5:41 a.m. UTC | #12
Hi Bingbu,

On 28/09/2021 03:21, Cao, Bingbu wrote:
> 

> 

> ________________________

> BRs,  

> Bingbu Cao 

> 

>> -----Original Message-----

>> From: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

>> Sent: Thursday, September 23, 2021 7:57 PM

>> To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>; Cao, Bingbu

>> <bingbu.cao@intel.com>

>> Cc: Sakari Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

>> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>

>> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

>> height_per_slice in the stripes

>>

>> Hi Bingbu, Laurent,

>>

>> On 23/09/2021 12:49, Laurent Pinchart wrote:

>>> Hi Bingbu,

>>>

>>> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

>>>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

>>>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

>>>>>> Jean-Michel,

>>>>>>

>>>>>> Firstly, the .height_per_slice could be 0 if your .grid.width

>>>>>> larger than 32.

>>>>>

>>>>> Which .height_per_slice are you talking about ? A field of that name

>>>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

>>>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

>>>>>

>>>>> They are both computed by the driver, in imgu_css_cfg_acc(). The

>>>>> former is set to

>>>>>

>>>>> 	acc->awb.config.grid.height_per_slice =

>>>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

>>>>>

>>>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0

>>>>> if grid.width > 160, which is invalid.

>>>>

>>>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

>>>

>>> Indeed, my bad. I was focussing on the AWB statistics.

>>>

>>> What are the implications of a height_per_slice value of 0 ?

>>>

>>> While we are on this topic, what is a "slice" ? Does it matter for the

>>> user, as in does it have an impact on the statistics values, or on how

>>> they're arranged in memory, or is it an implementation detail of the

>>> firmware that has no consequence on what can be seen by the user ?

>>> (The "user" here is the code that reads the statistics in userspace).

>>>

>>>>>> From your configuration, looks like something wrong in the stripe

>>>>>> configuration cause not entering the 2 stripes branch.

>>>>>

>>>>> Why is that ? Isn't it valid for a grid configuration to use a

>>>>> single stripe, if the image is small enough, or if the grid only

>>>>> covers the left part of the image ?

>>>>>

>>>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

>>>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

>>>>>>>> Jean-Michel,

>>>>>>>>

>>>>>>>> Thanks for you patch.

>>>>>>>> What is the value of .config.grid_cfg.width for your low

>> resolutions?

>>>>>>>

>>>>>>> I don't know if a 1920x1280 output is a low resolution, but the

>>>>>>> grid is configured as:

>>>>>>> - grid_cfg.width = 79

>>>>>>> - grid_cfg.height = 24

>>>>>>> - grid_cfg.block_width_log2 = 4

>>>>>>> - grid_cfg.block_height_log2 = 6

>>>>>>>

>>>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

>>>>>>>

>>>>>>> acc->stripe.down_scaled_stripes[0].width: 1280

>>>>>>> acc->stripe.down_scaled_stripes[0].height: 1536

>>>>>>> acc->stripe.down_scaled_stripes[0].offset: 0

>>>>>>> acc->stripe.bds_out_stripes[0].width: 1280

>>>>>>> acc->stripe.bds_out_stripes[0].height: 1536

>>>>>>> acc->stripe.bds_out_stripes[0].offset: 0

>>>>>>> acc->acc->awb.stripes[0].grid.width: 79

>>>>>>> acc->awb.stripes[0].grid.block_width_log2: 4

>>>>>>> acc->acc->awb.stripes[0].grid.height: 24

>>>>>>> acc->awb.stripes[0].grid.block_height_log2: 6

>>>>>>> acc->awb.stripes[0].grid.x_start: 0

>>>>>>> acc->awb.stripes[0].grid.x_end: 1263

>>>>>>> acc->awb.stripes[0].grid.y_start: 0

>>>>>>> acc->awb.stripes[0].grid.y_end: 1535

>>>>>>> acc->stripe.down_scaled_stripes[1].width: 1280

>>>>>>> acc->stripe.down_scaled_stripes[1].height: 1536

>>>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

>>>>>>> acc->stripe.bds_out_stripes[1].width: 1280

>>>>>>> acc->stripe.bds_out_stripes[1].height: 1536

>>>>>>> acc->stripe.bds_out_stripes[1].offset: 1024

>>>>>>> acc->acc->awb.stripes[1].grid.width: 79

>>>>>>> acc->awb.stripes[1].grid.block_width_log2: 4

>>>>>>> acc->acc->awb.stripes[1].grid.height: 24

>>>>>>> acc->awb.stripes[1].grid.block_height_log2: 6

>>>>>>> acc->awb.stripes[1].grid.x_start: 0

>>>>>>> acc->awb.stripes[1].grid.x_end: 1263

>>>>>>> acc->awb.stripes[1].grid.y_start: 0

>>>>>>> acc->awb.stripes[1].grid.y_end: 1535

>>>>

>>>> Are these dumps from 1920x1280 output?

>>>

>>> Jean-Michel, could you comment on this ?

>>>

>>> Note that the grid is configured with 79 cells of 16 pixels, covering

>>> 1264 pixels horizontally. That's not the full image for a 1920 pixels

>>> output, and will probably not be done in practice, but there's nothing

>>> preventing the grid from covering part of the image only.

>>>

>>

>> It is a dump for a 1920x1280 output.

>> If it can help, the configuration set in ImgU is:

>>   IF: 2592x1728

>>   BDS: 2304x1536

>>   GDC: 1920x1280

> 

> Jean-Michel,

> 

> It looks you are trying to use 2 stripes and the grid size is 2528x1536, and

> the awb.config.grid.x_end should be larger than the 

> bds_out_stripes[0].width - 10, it would not hit any 1 stripe condition.

> 

> could you also share your awb.config.grid?


I already shared it:
- grid_cfg.width = 79
- grid_cfg.height = 24
- grid_cfg.block_width_log2 = 4
- grid_cfg.block_height_log2 = 6
start_x and start_y are set to 0.


> 

>>

>>

>>>>>>> This has been outputted with: https://paste.debian.net/1212791/

>>>>>>>

>>>>>>> The examples I gave before were 1280x720 output and not 1920x1080,

>>>>>>> here are they:

>>>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

>>>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

>>>>>>>

>>>>>>> As you can see we have the same behaviour.

>>>>>>>

>>>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

>>>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois

>> wrote:

>>>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

>>>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois

>> wrote:

>>>>>>>>>>>> While playing with low resolutions for the grid, it appeared

>>>>>>>>>>>> that height_per_slice is not initialised if we are not using

>>>>>>>>>>>> both stripes for the calculations. This pattern occurs three

>> times:

>>>>>>>>>>>> - for the awb_fr processing block

>>>>>>>>>>>> - for the af processing block

>>>>>>>>>>>> - for the awb processing block

>>>>>>>>>>>>

>>>>>>>>>>>> The idea of this small portion of code is to reduce

>>>>>>>>>>>> complexity in loading the statistics, it could be done also

>>>>>>>>>>>> when only one stripe is used. Fix it by getting this

>>>>>>>>>>>> initialisation code outside of the

>>>>>>>>>>>> else() test case.

>>>>>>>>>>>>

>>>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois

>>>>>>>>>>>> <jeanmichel.hautbois@ideasonboard.com>

>>>>>>>>>>>> ---

>>>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>>

>>>>>>>>>>>> ++++++++++----------

>>>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

>>>>>>>>>>>>

>>>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

>>>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css

>> *css, unsigned int pipe,

>>>>>>>>>>>>  					acc-

>>> awb_fr.stripes[1].grid_cfg.width,

>>>>>>>>>>>>  					b_w_log2);

>>>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

>>>>>>>>>>>> -

>>>>>>>>>>>> -		/*

>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading

>>>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

>>>>>>>>>>>> -		 * stripes.

>>>>>>>>>>>> -		 */

>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>>>> -			acc-

>>> awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>>>  	}

>>>>>>>>>>>>

>>>>>>>>>>>> +	/*

>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

>>>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

>>>>>>>>>>>> +	 * stripes.

>>>>>>>>>>>> +	 */

>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>>> +

>>>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

>>>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>>>

>>>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css

>> *css, unsigned int pipe,

>>>>>>>>>>>>  			imgu_css_grid_end(acc-

>>> af.stripes[1].grid_cfg.x_start,

>>>>>>>>>>>>  					  acc-

>>> af.stripes[1].grid_cfg.width,

>>>>>>>>>>>>  					  b_w_log2);

>>>>>>>>>>>> -

>>>>>>>>>>>> -		/*

>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading

>> statistics

>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>>>> -		 */

>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice =

>> 1;

>>>>>>>>>>>>  	}

>>>>>>>>>>>>

>>>>>>>>>>>> +	/*

>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>>>> +	 */

>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>>> +

>>>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

>>>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>>>

>>>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css

>> *css, unsigned int pipe,

>>>>>>>>>>>>  			imgu_css_grid_end(acc-

>>> awb.stripes[1].grid.x_start,

>>>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,

>>>>>>>>>>>>  					  b_w_log2);

>>>>>>>>>>>> -

>>>>>>>>>>>> -		/*

>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading

>> statistics

>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>>>> -		 */

>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>>>>>>>>  	}

>>>>>>>>>>>>

>>>>>>>>>>>> +	/*

>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>>>> +	 */

>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>>>>>>>> +

>>>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

>>>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>>>

>>>>>>>>>>>

>>>>>>>>>>> While it seems like a sensible idea to initialise arguments to

>>>>>>>>>>> firmware, does this have an effect on the statistics format?

>>>>>>>>>>> If so, can the existing user space cope with that?

>>>>>>>>>>

>>>>>>>>>> To try and figure that out, we have tested several grid

>>>>>>>>>> configurations and inspected the captured statistics. We have

>>>>>>>>>> converted the statistics in an image, rendering each cell as a

>>>>>>>>>> pixel whose red, green and blue components are the cell's red,

>> green and blue averages.

>>>>>>>>>> This turned out to be a very effectice tool to quickly

>>>>>>>>>> visualize AWB statistics.

>>>>>>>>>> We have made a lot of tests with different output resolutions,

>>>>>>>>>> from a small one up to the full-scale one.

>>>>>>>>>>

>>>>>>>>>> Here is one example of a statistics output with a ViewFinder

>>>>>>>>>> configured as 1920x1280, with a BDS output configuration set to

>>>>>>>>>> 2304x1536 (sensor is 2592x1944).

>>>>>>>>>>

>>>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we

>>>>>>>>>> obtain the

>>>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

>>>>>>>>>> We can notice a weird padding every two lines and it seems to

>>>>>>>>>> be missing half of the frame.

>>>>>>>>>>

>>>>>>>>>> With the patch applied, the same configuration gives us the

>> image:

>>>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

>>>>>>>>>>

>>>>>>>>>> We can clearly see the one padding pixel on the right, and the

>>>>>>>>>> frame is all there, as expected.

>>>>>>>>>>

>>>>>>>>>> Tomasz: We're concerned that this patch may have an impact on

>>>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

>>>>>>>>>> someone to review and test this please?

>>>>>>>>>

>>>>>>>>> As shown by the images above, this is a real fix. It only

>>>>>>>>> affects grid configurations that use a single stripe (left or

>>>>>>>>> right), so either "small" resolutions (less than 1280 pixels at

>>>>>>>>> the BDS output if I recall correctly), or grid configurations

>>>>>>>>> that span the left part of the image with higher resolutions.

>>>>>>>>> The latter is probably unlikely. For the former, it may affect

>>>>>>>>> the binary library, especially if it includes a workaround for

>> the bug.

>>>>>>>>>

>>>>>>>>> Still, this change is good I believe, so it should be upstreamed.

>>>
Jean-Michel Hautbois Sept. 30, 2021, 9:31 a.m. UTC | #13
Hi Bingbu,

On 23/09/2021 12:49, Laurent Pinchart wrote:
> Hi Bingbu,

> 

> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

>>>> Jean-Michel,

>>>>

>>>> Firstly, the .height_per_slice could be 0 if your .grid.width larger

>>>> than 32.

>>>

>>> Which .height_per_slice are you talking about ? A field of that name

>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

>>>

>>> They are both computed by the driver, in imgu_css_cfg_acc(). The former

>>> is set to

>>>

>>> 	acc->awb.config.grid.height_per_slice =

>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

>>>

>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0 if

>>> grid.width > 160, which is invalid.

>>

>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

> 

> Indeed, my bad. I was focussing on the AWB statistics.

> 

> What are the implications of a height_per_slice value of 0 ?

> 

> While we are on this topic, what is a "slice" ? Does it matter for the

> user, as in does it have an impact on the statistics values, or on how

> they're arranged in memory, or is it an implementation detail of the

> firmware that has no consequence on what can be seen by the user ? (The

> "user" here is the code that reads the statistics in userspace).

> 


Gentle ping on these specific questions from Laurent :-) ?

>>>> From your configuration, looks like something wrong in the stripe

>>>> configuration cause not entering the 2 stripes branch.

>>>

>>> Why is that ? Isn't it valid for a grid configuration to use a single

>>> stripe, if the image is small enough, or if the grid only covers the left

>>> part of the image ?

>>>

>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

>>>>>> Jean-Michel,

>>>>>>

>>>>>> Thanks for you patch.

>>>>>> What is the value of .config.grid_cfg.width for your low resolutions?

>>>>>

>>>>> I don't know if a 1920x1280 output is a low resolution, but the grid

>>>>> is configured as:

>>>>> - grid_cfg.width = 79

>>>>> - grid_cfg.height = 24

>>>>> - grid_cfg.block_width_log2 = 4

>>>>> - grid_cfg.block_height_log2 = 6

>>>>>

>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

>>>>>

>>>>> acc->stripe.down_scaled_stripes[0].width: 1280

>>>>> acc->stripe.down_scaled_stripes[0].height: 1536

>>>>> acc->stripe.down_scaled_stripes[0].offset: 0

>>>>> acc->stripe.bds_out_stripes[0].width: 1280

>>>>> acc->stripe.bds_out_stripes[0].height: 1536

>>>>> acc->stripe.bds_out_stripes[0].offset: 0

>>>>> acc->acc->awb.stripes[0].grid.width: 79

>>>>> acc->awb.stripes[0].grid.block_width_log2: 4

>>>>> acc->acc->awb.stripes[0].grid.height: 24

>>>>> acc->awb.stripes[0].grid.block_height_log2: 6

>>>>> acc->awb.stripes[0].grid.x_start: 0

>>>>> acc->awb.stripes[0].grid.x_end: 1263

>>>>> acc->awb.stripes[0].grid.y_start: 0

>>>>> acc->awb.stripes[0].grid.y_end: 1535

>>>>> acc->stripe.down_scaled_stripes[1].width: 1280

>>>>> acc->stripe.down_scaled_stripes[1].height: 1536

>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

>>>>> acc->stripe.bds_out_stripes[1].width: 1280

>>>>> acc->stripe.bds_out_stripes[1].height: 1536

>>>>> acc->stripe.bds_out_stripes[1].offset: 1024

>>>>> acc->acc->awb.stripes[1].grid.width: 79

>>>>> acc->awb.stripes[1].grid.block_width_log2: 4

>>>>> acc->acc->awb.stripes[1].grid.height: 24

>>>>> acc->awb.stripes[1].grid.block_height_log2: 6

>>>>> acc->awb.stripes[1].grid.x_start: 0

>>>>> acc->awb.stripes[1].grid.x_end: 1263

>>>>> acc->awb.stripes[1].grid.y_start: 0

>>>>> acc->awb.stripes[1].grid.y_end: 1535

>>

>> Are these dumps from 1920x1280 output?

> 

> Jean-Michel, could you comment on this ?

> 

> Note that the grid is configured with 79 cells of 16 pixels, covering

> 1264 pixels horizontally. That's not the full image for a 1920 pixels

> output, and will probably not be done in practice, but there's nothing

> preventing the grid from covering part of the image only.

> 

>>>>> This has been outputted with: https://paste.debian.net/1212791/

>>>>>

>>>>> The examples I gave before were 1280x720 output and not 1920x1080,

>>>>> here are they:

>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

>>>>>

>>>>> As you can see we have the same behaviour.

>>>>>

>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

>>>>>>>>>> While playing with low resolutions for the grid, it appeared

>>>>>>>>>> that height_per_slice is not initialised if we are not using

>>>>>>>>>> both stripes for the calculations. This pattern occurs three times:

>>>>>>>>>> - for the awb_fr processing block

>>>>>>>>>> - for the af processing block

>>>>>>>>>> - for the awb processing block

>>>>>>>>>>

>>>>>>>>>> The idea of this small portion of code is to reduce complexity

>>>>>>>>>> in loading the statistics, it could be done also when only one

>>>>>>>>>> stripe is used. Fix it by getting this initialisation code

>>>>>>>>>> outside of the

>>>>>>>>>> else() test case.

>>>>>>>>>>

>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

>>>>>>>>>> ---

>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>> ++++++++++----------

>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

>>>>>>>>>>

>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>>>>>>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,

>>>>>>>>>>  					b_w_log2);

>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

>>>>>>>>>> -

>>>>>>>>>> -		/*

>>>>>>>>>> -		 * To reduce complexity of debubbling and loading

>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

>>>>>>>>>> -		 * stripes.

>>>>>>>>>> -		 */

>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>  	}

>>>>>>>>>>

>>>>>>>>>> +	/*

>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

>>>>>>>>>> +	 * stripes.

>>>>>>>>>> +	 */

>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>> +

>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>

>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>>>>>>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

>>>>>>>>>>  					  acc->af.stripes[1].grid_cfg.width,

>>>>>>>>>>  					  b_w_log2);

>>>>>>>>>> -

>>>>>>>>>> -		/*

>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> -		 */

>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>>  	}

>>>>>>>>>>

>>>>>>>>>> +	/*

>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> +	 */

>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

>>>>>>>>>> +

>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>

>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

>>>>>>>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,

>>>>>>>>>>  					  b_w_log2);

>>>>>>>>>> -

>>>>>>>>>> -		/*

>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> -		 */

>>>>>>>>>> -		for (i = 0; i < stripes; i++)

>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>>>>>>  	}

>>>>>>>>>>

>>>>>>>>>> +	/*

>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

>>>>>>>>>> +	 */

>>>>>>>>>> +	for (i = 0; i < stripes; i++)

>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

>>>>>>>>>> +

>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

>>>>>>>>>>  		return -EINVAL;

>>>>>>>>>>

>>>>>>>>>

>>>>>>>>> While it seems like a sensible idea to initialise arguments to

>>>>>>>>> firmware, does this have an effect on the statistics format? If

>>>>>>>>> so, can the existing user space cope with that?

>>>>>>>>

>>>>>>>> To try and figure that out, we have tested several grid

>>>>>>>> configurations and inspected the captured statistics. We have

>>>>>>>> converted the statistics in an image, rendering each cell as a

>>>>>>>> pixel whose red, green and blue components are the cell's red, green and blue averages.

>>>>>>>> This turned out to be a very effectice tool to quickly visualize

>>>>>>>> AWB statistics.

>>>>>>>> We have made a lot of tests with different output resolutions,

>>>>>>>> from a small one up to the full-scale one.

>>>>>>>>

>>>>>>>> Here is one example of a statistics output with a ViewFinder

>>>>>>>> configured as 1920x1280, with a BDS output configuration set to

>>>>>>>> 2304x1536 (sensor is 2592x1944).

>>>>>>>>

>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we

>>>>>>>> obtain the

>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

>>>>>>>> We can notice a weird padding every two lines and it seems to be

>>>>>>>> missing half of the frame.

>>>>>>>>

>>>>>>>> With the patch applied, the same configuration gives us the image:

>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

>>>>>>>>

>>>>>>>> We can clearly see the one padding pixel on the right, and the

>>>>>>>> frame is all there, as expected.

>>>>>>>>

>>>>>>>> Tomasz: We're concerned that this patch may have an impact on

>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

>>>>>>>> someone to review and test this please?

>>>>>>>

>>>>>>> As shown by the images above, this is a real fix. It only affects

>>>>>>> grid configurations that use a single stripe (left or right), so

>>>>>>> either "small" resolutions (less than 1280 pixels at the BDS

>>>>>>> output if I recall correctly), or grid configurations that span

>>>>>>> the left part of the image with higher resolutions. The latter is

>>>>>>> probably unlikely. For the former, it may affect the binary

>>>>>>> library, especially if it includes a workaround for the bug.

>>>>>>>

>>>>>>> Still, this change is good I believe, so it should be upstreamed.

>
Laurent Pinchart Oct. 4, 2021, 11:58 p.m. UTC | #14
On Tue, Sep 28, 2021 at 07:41:01AM +0200, Jean-Michel Hautbois wrote:
> On 28/09/2021 03:21, Cao, Bingbu wrote:

> > On Thursday, September 23, 2021 7:57 PM, Jean-Michel Hautbois wrote:

> >> On 23/09/2021 12:49, Laurent Pinchart wrote:

> >>> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

> >>>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

> >>>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

> >>>>>> Jean-Michel,

> >>>>>>

> >>>>>> Firstly, the .height_per_slice could be 0 if your .grid.width

> >>>>>> larger than 32.

> >>>>>

> >>>>> Which .height_per_slice are you talking about ? A field of that name

> >>>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

> >>>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

> >>>>>

> >>>>> They are both computed by the driver, in imgu_css_cfg_acc(). The

> >>>>> former is set to

> >>>>>

> >>>>> 	acc->awb.config.grid.height_per_slice =

> >>>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

> >>>>>

> >>>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0

> >>>>> if grid.width > 160, which is invalid.

> >>>>

> >>>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

> >>>

> >>> Indeed, my bad. I was focussing on the AWB statistics.

> >>>

> >>> What are the implications of a height_per_slice value of 0 ?

> >>>

> >>> While we are on this topic, what is a "slice" ? Does it matter for the

> >>> user, as in does it have an impact on the statistics values, or on how

> >>> they're arranged in memory, or is it an implementation detail of the

> >>> firmware that has no consequence on what can be seen by the user ?

> >>> (The "user" here is the code that reads the statistics in userspace).

> >>>

> >>>>>> From your configuration, looks like something wrong in the stripe

> >>>>>> configuration cause not entering the 2 stripes branch.

> >>>>>

> >>>>> Why is that ? Isn't it valid for a grid configuration to use a

> >>>>> single stripe, if the image is small enough, or if the grid only

> >>>>> covers the left part of the image ?

> >>>>>

> >>>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

> >>>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

> >>>>>>>> Jean-Michel,

> >>>>>>>>

> >>>>>>>> Thanks for you patch.

> >>>>>>>> What is the value of .config.grid_cfg.width for your low resolutions?

> >>>>>>>

> >>>>>>> I don't know if a 1920x1280 output is a low resolution, but the

> >>>>>>> grid is configured as:

> >>>>>>> - grid_cfg.width = 79

> >>>>>>> - grid_cfg.height = 24

> >>>>>>> - grid_cfg.block_width_log2 = 4

> >>>>>>> - grid_cfg.block_height_log2 = 6

> >>>>>>>

> >>>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> >>>>>>>

> >>>>>>> acc->stripe.down_scaled_stripes[0].width: 1280

> >>>>>>> acc->stripe.down_scaled_stripes[0].height: 1536

> >>>>>>> acc->stripe.down_scaled_stripes[0].offset: 0

> >>>>>>> acc->stripe.bds_out_stripes[0].width: 1280

> >>>>>>> acc->stripe.bds_out_stripes[0].height: 1536

> >>>>>>> acc->stripe.bds_out_stripes[0].offset: 0

> >>>>>>> acc->acc->awb.stripes[0].grid.width: 79

> >>>>>>> acc->awb.stripes[0].grid.block_width_log2: 4

> >>>>>>> acc->acc->awb.stripes[0].grid.height: 24

> >>>>>>> acc->awb.stripes[0].grid.block_height_log2: 6

> >>>>>>> acc->awb.stripes[0].grid.x_start: 0

> >>>>>>> acc->awb.stripes[0].grid.x_end: 1263

> >>>>>>> acc->awb.stripes[0].grid.y_start: 0

> >>>>>>> acc->awb.stripes[0].grid.y_end: 1535

> >>>>>>> acc->stripe.down_scaled_stripes[1].width: 1280

> >>>>>>> acc->stripe.down_scaled_stripes[1].height: 1536

> >>>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

> >>>>>>> acc->stripe.bds_out_stripes[1].width: 1280

> >>>>>>> acc->stripe.bds_out_stripes[1].height: 1536

> >>>>>>> acc->stripe.bds_out_stripes[1].offset: 1024

> >>>>>>> acc->acc->awb.stripes[1].grid.width: 79

> >>>>>>> acc->awb.stripes[1].grid.block_width_log2: 4

> >>>>>>> acc->acc->awb.stripes[1].grid.height: 24

> >>>>>>> acc->awb.stripes[1].grid.block_height_log2: 6

> >>>>>>> acc->awb.stripes[1].grid.x_start: 0

> >>>>>>> acc->awb.stripes[1].grid.x_end: 1263

> >>>>>>> acc->awb.stripes[1].grid.y_start: 0

> >>>>>>> acc->awb.stripes[1].grid.y_end: 1535

> >>>>

> >>>> Are these dumps from 1920x1280 output?

> >>>

> >>> Jean-Michel, could you comment on this ?

> >>>

> >>> Note that the grid is configured with 79 cells of 16 pixels, covering

> >>> 1264 pixels horizontally. That's not the full image for a 1920 pixels

> >>> output, and will probably not be done in practice, but there's nothing

> >>> preventing the grid from covering part of the image only.

> >>

> >> It is a dump for a 1920x1280 output.

> >> If it can help, the configuration set in ImgU is:

> >>   IF: 2592x1728

> >>   BDS: 2304x1536

> >>   GDC: 1920x1280

> > 

> > Jean-Michel,

> > 

> > It looks you are trying to use 2 stripes and the grid size is 2528x1536, and

> > the awb.config.grid.x_end should be larger than the 

> > bds_out_stripes[0].width - 10, it would not hit any 1 stripe condition.

> > 

> > could you also share your awb.config.grid?

> 

> I already shared it:

> - grid_cfg.width = 79

> - grid_cfg.height = 24

> - grid_cfg.block_width_log2 = 4

> - grid_cfg.block_height_log2 = 6

> start_x and start_y are set to 0.


As an additional note, we know this is an unusual grid configuration in
the sense that it spans 79*16 = 1264 pixels, much less than the BDS
output width, but I don't see why that would be invalid.

> >>>>>>> This has been outputted with: https://paste.debian.net/1212791/

> >>>>>>>

> >>>>>>> The examples I gave before were 1280x720 output and not 1920x1080,

> >>>>>>> here are they:

> >>>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> >>>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> >>>>>>>

> >>>>>>> As you can see we have the same behaviour.

> >>>>>>>

> >>>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

> >>>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:

> >>>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

> >>>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:

> >>>>>>>>>>>> While playing with low resolutions for the grid, it appeared

> >>>>>>>>>>>> that height_per_slice is not initialised if we are not using

> >>>>>>>>>>>> both stripes for the calculations. This pattern occurs three times:

> >>>>>>>>>>>> - for the awb_fr processing block

> >>>>>>>>>>>> - for the af processing block

> >>>>>>>>>>>> - for the awb processing block

> >>>>>>>>>>>>

> >>>>>>>>>>>> The idea of this small portion of code is to reduce

> >>>>>>>>>>>> complexity in loading the statistics, it could be done also

> >>>>>>>>>>>> when only one stripe is used. Fix it by getting this

> >>>>>>>>>>>> initialisation code outside of the

> >>>>>>>>>>>> else() test case.

> >>>>>>>>>>>>

> >>>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois

> >>>>>>>>>>>> <jeanmichel.hautbois@ideasonboard.com>

> >>>>>>>>>>>> ---

> >>>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>>

> >>>>>>>>>>>> ++++++++++----------

> >>>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> >>>>>>>>>>>>

> >>>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

> >>>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> >>>>>>>>>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,

> >>>>>>>>>>>>  					b_w_log2);

> >>>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> >>>>>>>>>>>> -

> >>>>>>>>>>>> -		/*

> >>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> >>>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> >>>>>>>>>>>> -		 * stripes.

> >>>>>>>>>>>> -		 */

> >>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>>>>  	}

> >>>>>>>>>>>>

> >>>>>>>>>>>> +	/*

> >>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

> >>>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> >>>>>>>>>>>> +	 * stripes.

> >>>>>>>>>>>> +	 */

> >>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>>>> +

> >>>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> >>>>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>>>

> >>>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> >>>>>>>>>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,

> >>>>>>>>>>>>  					  acc->af.stripes[1].grid_cfg.width,

> >>>>>>>>>>>>  					  b_w_log2);

> >>>>>>>>>>>> -

> >>>>>>>>>>>> -		/*

> >>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>>>> -		 */

> >>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>>>>  	}

> >>>>>>>>>>>>

> >>>>>>>>>>>> +	/*

> >>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>>>> +	 */

> >>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>>>> +

> >>>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> >>>>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>>>

> >>>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,

> >>>>>>>>>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,

> >>>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,

> >>>>>>>>>>>>  					  b_w_log2);

> >>>>>>>>>>>> -

> >>>>>>>>>>>> -		/*

> >>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>>>> -		 */

> >>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>>>>>>>>  	}

> >>>>>>>>>>>>

> >>>>>>>>>>>> +	/*

> >>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>>>> +	 */

> >>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>>>>>>>> +

> >>>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> >>>>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>>>

> >>>>>>>>>>>

> >>>>>>>>>>> While it seems like a sensible idea to initialise arguments to

> >>>>>>>>>>> firmware, does this have an effect on the statistics format?

> >>>>>>>>>>> If so, can the existing user space cope with that?

> >>>>>>>>>>

> >>>>>>>>>> To try and figure that out, we have tested several grid

> >>>>>>>>>> configurations and inspected the captured statistics. We have

> >>>>>>>>>> converted the statistics in an image, rendering each cell as a

> >>>>>>>>>> pixel whose red, green and blue components are the cell's red, green and blue averages.

> >>>>>>>>>> This turned out to be a very effectice tool to quickly

> >>>>>>>>>> visualize AWB statistics.

> >>>>>>>>>> We have made a lot of tests with different output resolutions,

> >>>>>>>>>> from a small one up to the full-scale one.

> >>>>>>>>>>

> >>>>>>>>>> Here is one example of a statistics output with a ViewFinder

> >>>>>>>>>> configured as 1920x1280, with a BDS output configuration set to

> >>>>>>>>>> 2304x1536 (sensor is 2592x1944).

> >>>>>>>>>>

> >>>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we

> >>>>>>>>>> obtain the

> >>>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> >>>>>>>>>> We can notice a weird padding every two lines and it seems to

> >>>>>>>>>> be missing half of the frame.

> >>>>>>>>>>

> >>>>>>>>>> With the patch applied, the same configuration gives us the image:

> >>>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

> >>>>>>>>>>

> >>>>>>>>>> We can clearly see the one padding pixel on the right, and the

> >>>>>>>>>> frame is all there, as expected.

> >>>>>>>>>>

> >>>>>>>>>> Tomasz: We're concerned that this patch may have an impact on

> >>>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

> >>>>>>>>>> someone to review and test this please?

> >>>>>>>>>

> >>>>>>>>> As shown by the images above, this is a real fix. It only

> >>>>>>>>> affects grid configurations that use a single stripe (left or

> >>>>>>>>> right), so either "small" resolutions (less than 1280 pixels at

> >>>>>>>>> the BDS output if I recall correctly), or grid configurations

> >>>>>>>>> that span the left part of the image with higher resolutions.

> >>>>>>>>> The latter is probably unlikely. For the former, it may affect

> >>>>>>>>> the binary library, especially if it includes a workaround for the bug.

> >>>>>>>>>

> >>>>>>>>> Still, this change is good I believe, so it should be upstreamed.


-- 
Regards,

Laurent Pinchart
Cao, Bingbu Oct. 11, 2021, 1:05 a.m. UTC | #15
Laurent,

________________________
BRs,  
Bingbu Cao 

> -----Original Message-----

> From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

> Sent: Tuesday, October 5, 2021 7:59 AM

> To: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>

> Cc: Cao, Bingbu <bingbu.cao@intel.com>; Sakari Ailus

> <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>

> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> height_per_slice in the stripes

> 

> On Tue, Sep 28, 2021 at 07:41:01AM +0200, Jean-Michel Hautbois wrote:

> > On 28/09/2021 03:21, Cao, Bingbu wrote:

> > > On Thursday, September 23, 2021 7:57 PM, Jean-Michel Hautbois wrote:

> > >> On 23/09/2021 12:49, Laurent Pinchart wrote:

> > >>> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

> > >>>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

> > >>>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

> > >>>>>> Jean-Michel,

> > >>>>>>

> > >>>>>> Firstly, the .height_per_slice could be 0 if your .grid.width

> > >>>>>> larger than 32.

> > >>>>>

> > >>>>> Which .height_per_slice are you talking about ? A field of that

> > >>>>> name exists in both ipu3_uapi_acc_param.awb.config.grid and

> > >>>>> struct ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

> > >>>>>

> > >>>>> They are both computed by the driver, in imgu_css_cfg_acc(). The

> > >>>>> former is set to

> > >>>>>

> > >>>>> 	acc->awb.config.grid.height_per_slice =

> > >>>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc-

> >awb.config.grid.width,

> > >>>>>

> > >>>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only

> > >>>>> be 0 if grid.width > 160, which is invalid.

> > >>>>

> > >>>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width >

> 32.

> > >>>

> > >>> Indeed, my bad. I was focussing on the AWB statistics.

> > >>>

> > >>> What are the implications of a height_per_slice value of 0 ?

> > >>>

> > >>> While we are on this topic, what is a "slice" ? Does it matter for

> > >>> the user, as in does it have an impact on the statistics values,

> > >>> or on how they're arranged in memory, or is it an implementation

> > >>> detail of the firmware that has no consequence on what can be seen

> by the user ?

> > >>> (The "user" here is the code that reads the statistics in

> userspace).

> > >>>

> > >>>>>> From your configuration, looks like something wrong in the

> > >>>>>> stripe configuration cause not entering the 2 stripes branch.

> > >>>>>

> > >>>>> Why is that ? Isn't it valid for a grid configuration to use a

> > >>>>> single stripe, if the image is small enough, or if the grid only

> > >>>>> covers the left part of the image ?

> > >>>>>

> > >>>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois

> wrote:

> > >>>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

> > >>>>>>>> Jean-Michel,

> > >>>>>>>>

> > >>>>>>>> Thanks for you patch.

> > >>>>>>>> What is the value of .config.grid_cfg.width for your low

> resolutions?

> > >>>>>>>

> > >>>>>>> I don't know if a 1920x1280 output is a low resolution, but

> > >>>>>>> the grid is configured as:

> > >>>>>>> - grid_cfg.width = 79

> > >>>>>>> - grid_cfg.height = 24

> > >>>>>>> - grid_cfg.block_width_log2 = 4

> > >>>>>>> - grid_cfg.block_height_log2 = 6

> > >>>>>>>

> > >>>>>>> Here is a full debug output of the AWB part in

> imgu_css_cfg_acc():

> > >>>>>>>

> > >>>>>>> acc->stripe.down_scaled_stripes[0].width: 1280

> > >>>>>>> acc->stripe.down_scaled_stripes[0].height: 1536

> > >>>>>>> acc->stripe.down_scaled_stripes[0].offset: 0

> > >>>>>>> acc->stripe.bds_out_stripes[0].width: 1280

> > >>>>>>> acc->stripe.bds_out_stripes[0].height: 1536

> > >>>>>>> acc->stripe.bds_out_stripes[0].offset: 0

> > >>>>>>> acc->acc->awb.stripes[0].grid.width: 79

> > >>>>>>> acc->awb.stripes[0].grid.block_width_log2: 4

> > >>>>>>> acc->acc->awb.stripes[0].grid.height: 24

> > >>>>>>> acc->awb.stripes[0].grid.block_height_log2: 6

> > >>>>>>> acc->awb.stripes[0].grid.x_start: 0

> > >>>>>>> acc->awb.stripes[0].grid.x_end: 1263

> > >>>>>>> acc->awb.stripes[0].grid.y_start: 0

> > >>>>>>> acc->awb.stripes[0].grid.y_end: 1535

> > >>>>>>> acc->stripe.down_scaled_stripes[1].width: 1280

> > >>>>>>> acc->stripe.down_scaled_stripes[1].height: 1536

> > >>>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

> > >>>>>>> acc->stripe.bds_out_stripes[1].width: 1280

> > >>>>>>> acc->stripe.bds_out_stripes[1].height: 1536

> > >>>>>>> acc->stripe.bds_out_stripes[1].offset: 1024

> > >>>>>>> acc->acc->awb.stripes[1].grid.width: 79

> > >>>>>>> acc->awb.stripes[1].grid.block_width_log2: 4

> > >>>>>>> acc->acc->awb.stripes[1].grid.height: 24

> > >>>>>>> acc->awb.stripes[1].grid.block_height_log2: 6

> > >>>>>>> acc->awb.stripes[1].grid.x_start: 0

> > >>>>>>> acc->awb.stripes[1].grid.x_end: 1263

> > >>>>>>> acc->awb.stripes[1].grid.y_start: 0

> > >>>>>>> acc->awb.stripes[1].grid.y_end: 1535

> > >>>>

> > >>>> Are these dumps from 1920x1280 output?

> > >>>

> > >>> Jean-Michel, could you comment on this ?

> > >>>

> > >>> Note that the grid is configured with 79 cells of 16 pixels,

> > >>> covering

> > >>> 1264 pixels horizontally. That's not the full image for a 1920

> > >>> pixels output, and will probably not be done in practice, but

> > >>> there's nothing preventing the grid from covering part of the image

> only.

> > >>

> > >> It is a dump for a 1920x1280 output.

> > >> If it can help, the configuration set in ImgU is:

> > >>   IF: 2592x1728

> > >>   BDS: 2304x1536

> > >>   GDC: 1920x1280

> > >

> > > Jean-Michel,

> > >

> > > It looks you are trying to use 2 stripes and the grid size is

> > > 2528x1536, and the awb.config.grid.x_end should be larger than the

> > > bds_out_stripes[0].width - 10, it would not hit any 1 stripe

> condition.

> > >

> > > could you also share your awb.config.grid?

> >

> > I already shared it:

> > - grid_cfg.width = 79

> > - grid_cfg.height = 24

> > - grid_cfg.block_width_log2 = 4

> > - grid_cfg.block_height_log2 = 6

> > start_x and start_y are set to 0.

> 

> As an additional note, we know this is an unusual grid configuration in

> the sense that it spans 79*16 = 1264 pixels, much less than the BDS

> output width, but I don't see why that would be invalid.


My point is not that the grid config, I mean the awb/af_stripe_config should be
correct, from the configure dump, it was using 2 stripes for awb, right?


> 

> > >>>>>>> This has been outputted with:

> > >>>>>>> https://paste.debian.net/1212791/

> > >>>>>>>

> > >>>>>>> The examples I gave before were 1280x720 output and not

> > >>>>>>> 1920x1080, here are they:

> > >>>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> > >>>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> > >>>>>>>

> > >>>>>>> As you can see we have the same behaviour.

> > >>>>>>>

> > >>>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart

> wrote:

> > >>>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel

> Hautbois wrote:

> > >>>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

> > >>>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel

> Hautbois wrote:

> > >>>>>>>>>>>> While playing with low resolutions for the grid, it

> > >>>>>>>>>>>> appeared that height_per_slice is not initialised if we

> > >>>>>>>>>>>> are not using both stripes for the calculations. This

> pattern occurs three times:

> > >>>>>>>>>>>> - for the awb_fr processing block

> > >>>>>>>>>>>> - for the af processing block

> > >>>>>>>>>>>> - for the awb processing block

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> The idea of this small portion of code is to reduce

> > >>>>>>>>>>>> complexity in loading the statistics, it could be done

> > >>>>>>>>>>>> also when only one stripe is used. Fix it by getting this

> > >>>>>>>>>>>> initialisation code outside of the

> > >>>>>>>>>>>> else() test case.

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois

> > >>>>>>>>>>>> <jeanmichel.hautbois@ideasonboard.com>

> > >>>>>>>>>>>> ---

> > >>>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>>

> > >>>>>>>>>>>> ++++++++++----------

> > >>>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

> > >>>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> > >>>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct

> imgu_css *css, unsigned int pipe,

> > >>>>>>>>>>>>  					acc-

> >awb_fr.stripes[1].grid_cfg.width,

> > >>>>>>>>>>>>  					b_w_log2);

> > >>>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> > >>>>>>>>>>>> -

> > >>>>>>>>>>>> -		/*

> > >>>>>>>>>>>> -		 * To reduce complexity of debubbling and

> loading

> > >>>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1

> for both

> > >>>>>>>>>>>> -		 * stripes.

> > >>>>>>>>>>>> -		 */

> > >>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

> > >>>>>>>>>>>> -			acc-

> >awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>>>>>>>>>  	}

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> +	/*

> > >>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

> > >>>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> > >>>>>>>>>>>> +	 * stripes.

> > >>>>>>>>>>>> +	 */

> > >>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

> > >>>>>>>>>>>> +		acc-

> >awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>>>>>>>>> +

> > >>>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> > >>>>>>>>>>>>  		return -EINVAL;

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct

> imgu_css *css, unsigned int pipe,

> > >>>>>>>>>>>>  			imgu_css_grid_end(acc-

> >af.stripes[1].grid_cfg.x_start,

> > >>>>>>>>>>>>  					  acc-

> >af.stripes[1].grid_cfg.width,

> > >>>>>>>>>>>>  					  b_w_log2);

> > >>>>>>>>>>>> -

> > >>>>>>>>>>>> -		/*

> > >>>>>>>>>>>> -		 * To reduce complexity of debubbling and

> loading statistics

> > >>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both

> stripes

> > >>>>>>>>>>>> -		 */

> > >>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

> > >>>>>>>>>>>> -			acc-

> >af.stripes[i].grid_cfg.height_per_slice = 1;

> > >>>>>>>>>>>>  	}

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> +	/*

> > >>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

> statistics

> > >>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > >>>>>>>>>>>> +	 */

> > >>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

> > >>>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice =

> 1;

> > >>>>>>>>>>>> +

> > >>>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> > >>>>>>>>>>>>  		return -EINVAL;

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct

> imgu_css *css, unsigned int pipe,

> > >>>>>>>>>>>>  			imgu_css_grid_end(acc-

> >awb.stripes[1].grid.x_start,

> > >>>>>>>>>>>>  					  acc-

> >awb.stripes[1].grid.width,

> > >>>>>>>>>>>>  					  b_w_log2);

> > >>>>>>>>>>>> -

> > >>>>>>>>>>>> -		/*

> > >>>>>>>>>>>> -		 * To reduce complexity of debubbling and

> loading statistics

> > >>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both

> stripes

> > >>>>>>>>>>>> -		 */

> > >>>>>>>>>>>> -		for (i = 0; i < stripes; i++)

> > >>>>>>>>>>>> -			acc-

> >awb.stripes[i].grid.height_per_slice = 1;

> > >>>>>>>>>>>>  	}

> > >>>>>>>>>>>>

> > >>>>>>>>>>>> +	/*

> > >>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading

> statistics

> > >>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> > >>>>>>>>>>>> +	 */

> > >>>>>>>>>>>> +	for (i = 0; i < stripes; i++)

> > >>>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> > >>>>>>>>>>>> +

> > >>>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> > >>>>>>>>>>>>  		return -EINVAL;

> > >>>>>>>>>>>>

> > >>>>>>>>>>>

> > >>>>>>>>>>> While it seems like a sensible idea to initialise

> > >>>>>>>>>>> arguments to firmware, does this have an effect on the

> statistics format?

> > >>>>>>>>>>> If so, can the existing user space cope with that?

> > >>>>>>>>>>

> > >>>>>>>>>> To try and figure that out, we have tested several grid

> > >>>>>>>>>> configurations and inspected the captured statistics. We

> > >>>>>>>>>> have converted the statistics in an image, rendering each

> > >>>>>>>>>> cell as a pixel whose red, green and blue components are the

> cell's red, green and blue averages.

> > >>>>>>>>>> This turned out to be a very effectice tool to quickly

> > >>>>>>>>>> visualize AWB statistics.

> > >>>>>>>>>> We have made a lot of tests with different output

> > >>>>>>>>>> resolutions, from a small one up to the full-scale one.

> > >>>>>>>>>>

> > >>>>>>>>>> Here is one example of a statistics output with a

> > >>>>>>>>>> ViewFinder configured as 1920x1280, with a BDS output

> > >>>>>>>>>> configuration set to

> > >>>>>>>>>> 2304x1536 (sensor is 2592x1944).

> > >>>>>>>>>>

> > >>>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells

> > >>>>>>>>>> we obtain the

> > >>>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> > >>>>>>>>>> We can notice a weird padding every two lines and it seems

> > >>>>>>>>>> to be missing half of the frame.

> > >>>>>>>>>>

> > >>>>>>>>>> With the patch applied, the same configuration gives us the

> image:

> > >>>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

> > >>>>>>>>>>

> > >>>>>>>>>> We can clearly see the one padding pixel on the right, and

> > >>>>>>>>>> the frame is all there, as expected.

> > >>>>>>>>>>

> > >>>>>>>>>> Tomasz: We're concerned that this patch may have an impact

> > >>>>>>>>>> on the ChromeOS Intel Camera HAL with the IPU3. Is it

> > >>>>>>>>>> possible for someone to review and test this please?

> > >>>>>>>>>

> > >>>>>>>>> As shown by the images above, this is a real fix. It only

> > >>>>>>>>> affects grid configurations that use a single stripe (left

> > >>>>>>>>> or right), so either "small" resolutions (less than 1280

> > >>>>>>>>> pixels at the BDS output if I recall correctly), or grid

> > >>>>>>>>> configurations that span the left part of the image with

> higher resolutions.

> > >>>>>>>>> The latter is probably unlikely. For the former, it may

> > >>>>>>>>> affect the binary library, especially if it includes a

> workaround for the bug.

> > >>>>>>>>>

> > >>>>>>>>> Still, this change is good I believe, so it should be

> upstreamed.

> 

> --

> Regards,

> 

> Laurent Pinchart
Cao, Bingbu Oct. 11, 2021, 2:42 a.m. UTC | #16
Hi, Jean-Michel and Laurent,

Sorry for reply late as I am just back from holiday.

________________________
BRs,  
Bingbu Cao 

> -----Original Message-----

> From: Jean-Michel Hautbois <jeanmichel.hautbois@gmail.com>

> Sent: Thursday, September 30, 2021 5:31 PM

> To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>; Cao, Bingbu

> <bingbu.cao@intel.com>

> Cc: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>; Sakari

> Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-

> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>

> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise

> height_per_slice in the stripes

> 

> Hi Bingbu,

> 

> On 23/09/2021 12:49, Laurent Pinchart wrote:

> > Hi Bingbu,

> >

> > On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:

> >> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:

> >>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:

> >>>> Jean-Michel,

> >>>>

> >>>> Firstly, the .height_per_slice could be 0 if your .grid.width

> >>>> larger than 32.

> >>>

> >>> Which .height_per_slice are you talking about ? A field of that name

> >>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct

> >>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.

> >>>

> >>> They are both computed by the driver, in imgu_css_cfg_acc(). The

> >>> former is set to

> >>>

> >>> 	acc->awb.config.grid.height_per_slice =

> >>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,

> >>>

> >>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0

> >>> if grid.width > 160, which is invalid.

> >>

> >> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.

> >

> > Indeed, my bad. I was focussing on the AWB statistics.

> >

> > What are the implications of a height_per_slice value of 0 ?

> >

> > While we are on this topic, what is a "slice" ? Does it matter for the

> > user, as in does it have an impact on the statistics values, or on how

> > they're arranged in memory, or is it an implementation detail of the

> > firmware that has no consequence on what can be seen by the user ?

> > (The "user" here is the code that reads the statistics in userspace).

> >

> 

> Gentle ping on these specific questions from Laurent :-) ?


I am not an expert on this statistics algo.

My understanding:
height_per_slice means number of blocks in vertical axis per Metadata slice.
ImgU divide grid-based Metadata into slices, each slice refers to 
grid_width * height_per_slice blocks, if height_per_slice is 0, that means
the grid_width is too large to use. IOW, it is an invalid parameter, we
need check this invalid value instead of just setting to 1.

> 

> >>>> From your configuration, looks like something wrong in the stripe

> >>>> configuration cause not entering the 2 stripes branch.

> >>>

> >>> Why is that ? Isn't it valid for a grid configuration to use a

> >>> single stripe, if the image is small enough, or if the grid only

> >>> covers the left part of the image ?

> >>>

> >>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:

> >>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:

> >>>>>> Jean-Michel,

> >>>>>>

> >>>>>> Thanks for you patch.

> >>>>>> What is the value of .config.grid_cfg.width for your low

> resolutions?

> >>>>>

> >>>>> I don't know if a 1920x1280 output is a low resolution, but the

> >>>>> grid is configured as:

> >>>>> - grid_cfg.width = 79

> >>>>> - grid_cfg.height = 24

> >>>>> - grid_cfg.block_width_log2 = 4

> >>>>> - grid_cfg.block_height_log2 = 6

> >>>>>

> >>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():

> >>>>>

> >>>>> acc->stripe.down_scaled_stripes[0].width: 1280

> >>>>> acc->stripe.down_scaled_stripes[0].height: 1536

> >>>>> acc->stripe.down_scaled_stripes[0].offset: 0

> >>>>> acc->stripe.bds_out_stripes[0].width: 1280

> >>>>> acc->stripe.bds_out_stripes[0].height: 1536

> >>>>> acc->stripe.bds_out_stripes[0].offset: 0

> >>>>> acc->acc->awb.stripes[0].grid.width: 79

> >>>>> acc->awb.stripes[0].grid.block_width_log2: 4

> >>>>> acc->acc->awb.stripes[0].grid.height: 24

> >>>>> acc->awb.stripes[0].grid.block_height_log2: 6

> >>>>> acc->awb.stripes[0].grid.x_start: 0

> >>>>> acc->awb.stripes[0].grid.x_end: 1263

> >>>>> acc->awb.stripes[0].grid.y_start: 0

> >>>>> acc->awb.stripes[0].grid.y_end: 1535

> >>>>> acc->stripe.down_scaled_stripes[1].width: 1280

> >>>>> acc->stripe.down_scaled_stripes[1].height: 1536

> >>>>> acc->stripe.down_scaled_stripes[1].offset: 1024

> >>>>> acc->stripe.bds_out_stripes[1].width: 1280

> >>>>> acc->stripe.bds_out_stripes[1].height: 1536

> >>>>> acc->stripe.bds_out_stripes[1].offset: 1024

> >>>>> acc->acc->awb.stripes[1].grid.width: 79

> >>>>> acc->awb.stripes[1].grid.block_width_log2: 4

> >>>>> acc->acc->awb.stripes[1].grid.height: 24

> >>>>> acc->awb.stripes[1].grid.block_height_log2: 6

> >>>>> acc->awb.stripes[1].grid.x_start: 0

> >>>>> acc->awb.stripes[1].grid.x_end: 1263

> >>>>> acc->awb.stripes[1].grid.y_start: 0

> >>>>> acc->awb.stripes[1].grid.y_end: 1535

> >>

> >> Are these dumps from 1920x1280 output?

> >

> > Jean-Michel, could you comment on this ?

> >

> > Note that the grid is configured with 79 cells of 16 pixels, covering

> > 1264 pixels horizontally. That's not the full image for a 1920 pixels

> > output, and will probably not be done in practice, but there's nothing

> > preventing the grid from covering part of the image only.

> >

> >>>>> This has been outputted with: https://paste.debian.net/1212791/

> >>>>>

> >>>>> The examples I gave before were 1280x720 output and not 1920x1080,

> >>>>> here are they:

> >>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png

> >>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png

> >>>>>

> >>>>> As you can see we have the same behaviour.

> >>>>>

> >>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:

> >>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois

> wrote:

> >>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:

> >>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois

> wrote:

> >>>>>>>>>> While playing with low resolutions for the grid, it appeared

> >>>>>>>>>> that height_per_slice is not initialised if we are not using

> >>>>>>>>>> both stripes for the calculations. This pattern occurs three

> times:

> >>>>>>>>>> - for the awb_fr processing block

> >>>>>>>>>> - for the af processing block

> >>>>>>>>>> - for the awb processing block

> >>>>>>>>>>

> >>>>>>>>>> The idea of this small portion of code is to reduce

> >>>>>>>>>> complexity in loading the statistics, it could be done also

> >>>>>>>>>> when only one stripe is used. Fix it by getting this

> >>>>>>>>>> initialisation code outside of the

> >>>>>>>>>> else() test case.

> >>>>>>>>>>

> >>>>>>>>>> Signed-off-by: Jean-Michel Hautbois

> >>>>>>>>>> <jeanmichel.hautbois@ideasonboard.com>

> >>>>>>>>>> ---

> >>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>>

> >>>>>>>>>> ++++++++++----------

> >>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)

> >>>>>>>>>>

> >>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644

> >>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c

> >>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> >>>>>>>>>>  					acc-

> >awb_fr.stripes[1].grid_cfg.width,

> >>>>>>>>>>  					b_w_log2);

> >>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;

> >>>>>>>>>> -

> >>>>>>>>>> -		/*

> >>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> >>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both

> >>>>>>>>>> -		 * stripes.

> >>>>>>>>>> -		 */

> >>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>> -			acc-

> >awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>>  	}

> >>>>>>>>>>

> >>>>>>>>>> +	/*

> >>>>>>>>>> +	 * To reduce complexity of debubbling and loading

> >>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both

> >>>>>>>>>> +	 * stripes.

> >>>>>>>>>> +	 */

> >>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>> +

> >>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))

> >>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>

> >>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> >>>>>>>>>>  			imgu_css_grid_end(acc-

> >af.stripes[1].grid_cfg.x_start,

> >>>>>>>>>>  					  acc-

> >af.stripes[1].grid_cfg.width,

> >>>>>>>>>>  					  b_w_log2);

> >>>>>>>>>> -

> >>>>>>>>>> -		/*

> >>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> >>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> -		 */

> >>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice =

> 1;

> >>>>>>>>>>  	}

> >>>>>>>>>>

> >>>>>>>>>> +	/*

> >>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> +	 */

> >>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;

> >>>>>>>>>> +

> >>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))

> >>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>

> >>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css

> *css, unsigned int pipe,

> >>>>>>>>>>  			imgu_css_grid_end(acc-

> >awb.stripes[1].grid.x_start,

> >>>>>>>>>>  					  acc->awb.stripes[1].grid.width,

> >>>>>>>>>>  					  b_w_log2);

> >>>>>>>>>> -

> >>>>>>>>>> -		/*

> >>>>>>>>>> -		 * To reduce complexity of debubbling and loading

> statistics

> >>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> -		 */

> >>>>>>>>>> -		for (i = 0; i < stripes; i++)

> >>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>>>>>>  	}

> >>>>>>>>>>

> >>>>>>>>>> +	/*

> >>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics

> >>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes

> >>>>>>>>>> +	 */

> >>>>>>>>>> +	for (i = 0; i < stripes; i++)

> >>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;

> >>>>>>>>>> +

> >>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))

> >>>>>>>>>>  		return -EINVAL;

> >>>>>>>>>>

> >>>>>>>>>

> >>>>>>>>> While it seems like a sensible idea to initialise arguments to

> >>>>>>>>> firmware, does this have an effect on the statistics format?

> >>>>>>>>> If so, can the existing user space cope with that?

> >>>>>>>>

> >>>>>>>> To try and figure that out, we have tested several grid

> >>>>>>>> configurations and inspected the captured statistics. We have

> >>>>>>>> converted the statistics in an image, rendering each cell as a

> >>>>>>>> pixel whose red, green and blue components are the cell's red,

> green and blue averages.

> >>>>>>>> This turned out to be a very effectice tool to quickly

> >>>>>>>> visualize AWB statistics.

> >>>>>>>> We have made a lot of tests with different output resolutions,

> >>>>>>>> from a small one up to the full-scale one.

> >>>>>>>>

> >>>>>>>> Here is one example of a statistics output with a ViewFinder

> >>>>>>>> configured as 1920x1280, with a BDS output configuration set to

> >>>>>>>> 2304x1536 (sensor is 2592x1944).

> >>>>>>>>

> >>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we

> >>>>>>>> obtain the

> >>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.

> >>>>>>>> We can notice a weird padding every two lines and it seems to

> >>>>>>>> be missing half of the frame.

> >>>>>>>>

> >>>>>>>> With the patch applied, the same configuration gives us the

> image:

> >>>>>>>> https://pasteboard.co/rzap6axIvVdu.png

> >>>>>>>>

> >>>>>>>> We can clearly see the one padding pixel on the right, and the

> >>>>>>>> frame is all there, as expected.

> >>>>>>>>

> >>>>>>>> Tomasz: We're concerned that this patch may have an impact on

> >>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for

> >>>>>>>> someone to review and test this please?

> >>>>>>>

> >>>>>>> As shown by the images above, this is a real fix. It only

> >>>>>>> affects grid configurations that use a single stripe (left or

> >>>>>>> right), so either "small" resolutions (less than 1280 pixels at

> >>>>>>> the BDS output if I recall correctly), or grid configurations

> >>>>>>> that span the left part of the image with higher resolutions.

> >>>>>>> The latter is probably unlikely. For the former, it may affect

> >>>>>>> the binary library, especially if it includes a workaround for

> the bug.

> >>>>>>>

> >>>>>>> Still, this change is good I believe, so it should be upstreamed.

> >
Bingbu Cao Aug. 9, 2023, 4:11 a.m. UTC | #17
Jean-Michel,

I remember you resolved the problem about awb in libcamhal, so is this
patch still necessary or valid for Imgu? :)

On 10/14/21 2:57 PM, Jean-Michel Hautbois wrote:
> Hi Bingbu (and Tomasz),
> 
> On 11/10/2021 04:42, Cao, Bingbu wrote:
>> Hi, Jean-Michel and Laurent,
>>
>> Sorry for reply late as I am just back from holiday.
>>
>> ________________________
>> BRs,  
>> Bingbu Cao 
>>
>>> -----Original Message-----
>>> From: Jean-Michel Hautbois <jeanmichel.hautbois@gmail.com>
>>> Sent: Thursday, September 30, 2021 5:31 PM
>>> To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>; Cao, Bingbu
>>> <bingbu.cao@intel.com>
>>> Cc: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>; Sakari
>>> Ailus <sakari.ailus@linux.intel.com>; tfiga@google.com; linux-
>>> media@vger.kernel.org; Qiu, Tian Shu <tian.shu.qiu@intel.com>
>>> Subject: Re: [PATCH] media: staging: ipu3-imgu: Initialise
>>> height_per_slice in the stripes
>>>
>>> Hi Bingbu,
>>>
>>> On 23/09/2021 12:49, Laurent Pinchart wrote:
>>>> Hi Bingbu,
>>>>
>>>> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:
>>>>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:
>>>>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:
>>>>>>> Jean-Michel,
>>>>>>>
>>>>>>> Firstly, the .height_per_slice could be 0 if your .grid.width
>>>>>>> larger than 32.
>>>>>>
>>>>>> Which .height_per_slice are you talking about ? A field of that name
>>>>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct
>>>>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.
>>>>>>
>>>>>> They are both computed by the driver, in imgu_css_cfg_acc(). The
>>>>>> former is set to
>>>>>>
>>>>>> 	acc->awb.config.grid.height_per_slice =
>>>>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,
>>>>>>
>>>>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0
>>>>>> if grid.width > 160, which is invalid.
>>>>>
>>>>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.
>>>>
>>>> Indeed, my bad. I was focussing on the AWB statistics.
>>>>
>>>> What are the implications of a height_per_slice value of 0 ?
>>>>
>>>> While we are on this topic, what is a "slice" ? Does it matter for the
>>>> user, as in does it have an impact on the statistics values, or on how
>>>> they're arranged in memory, or is it an implementation detail of the
>>>> firmware that has no consequence on what can be seen by the user ?
>>>> (The "user" here is the code that reads the statistics in userspace).
>>>>
>>>
>>> Gentle ping on these specific questions from Laurent :-) ?
>>
>> I am not an expert on this statistics algo.
>>
>> My understanding:
>> height_per_slice means number of blocks in vertical axis per Metadata slice.
>> ImgU divide grid-based Metadata into slices, each slice refers to 
>> grid_width * height_per_slice blocks, if height_per_slice is 0, that means
>> the grid_width is too large to use. IOW, it is an invalid parameter, we
>> need check this invalid value instead of just setting to 1.
>>
> 
> Is it true only for awb_fr and af, or also for awb ?
> If it is not for awb, the patch could be only for awb, as it really
> solves an issue ?
> 
> Tomasz, do you think it may introduce a regression in the binary library
> ? Would it be possible to test it ? I can send a v2 with only awb if it
> is needed.
> 
>>>
>>>>>>> From your configuration, looks like something wrong in the stripe
>>>>>>> configuration cause not entering the 2 stripes branch.
>>>>>>
>>>>>> Why is that ? Isn't it valid for a grid configuration to use a
>>>>>> single stripe, if the image is small enough, or if the grid only
>>>>>> covers the left part of the image ?
>>>>>>
>>>>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:
>>>>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:
>>>>>>>>> Jean-Michel,
>>>>>>>>>
>>>>>>>>> Thanks for you patch.
>>>>>>>>> What is the value of .config.grid_cfg.width for your low
>>> resolutions?
>>>>>>>>
>>>>>>>> I don't know if a 1920x1280 output is a low resolution, but the
>>>>>>>> grid is configured as:
>>>>>>>> - grid_cfg.width = 79
>>>>>>>> - grid_cfg.height = 24
>>>>>>>> - grid_cfg.block_width_log2 = 4
>>>>>>>> - grid_cfg.block_height_log2 = 6
>>>>>>>>
>>>>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():
>>>>>>>>
>>>>>>>> acc->stripe.down_scaled_stripes[0].width: 1280
>>>>>>>> acc->stripe.down_scaled_stripes[0].height: 1536
>>>>>>>> acc->stripe.down_scaled_stripes[0].offset: 0
>>>>>>>> acc->stripe.bds_out_stripes[0].width: 1280
>>>>>>>> acc->stripe.bds_out_stripes[0].height: 1536
>>>>>>>> acc->stripe.bds_out_stripes[0].offset: 0
>>>>>>>> acc->acc->awb.stripes[0].grid.width: 79
>>>>>>>> acc->awb.stripes[0].grid.block_width_log2: 4
>>>>>>>> acc->acc->awb.stripes[0].grid.height: 24
>>>>>>>> acc->awb.stripes[0].grid.block_height_log2: 6
>>>>>>>> acc->awb.stripes[0].grid.x_start: 0
>>>>>>>> acc->awb.stripes[0].grid.x_end: 1263
>>>>>>>> acc->awb.stripes[0].grid.y_start: 0
>>>>>>>> acc->awb.stripes[0].grid.y_end: 1535
>>>>>>>> acc->stripe.down_scaled_stripes[1].width: 1280
>>>>>>>> acc->stripe.down_scaled_stripes[1].height: 1536
>>>>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024
>>>>>>>> acc->stripe.bds_out_stripes[1].width: 1280
>>>>>>>> acc->stripe.bds_out_stripes[1].height: 1536
>>>>>>>> acc->stripe.bds_out_stripes[1].offset: 1024
>>>>>>>> acc->acc->awb.stripes[1].grid.width: 79
>>>>>>>> acc->awb.stripes[1].grid.block_width_log2: 4
>>>>>>>> acc->acc->awb.stripes[1].grid.height: 24
>>>>>>>> acc->awb.stripes[1].grid.block_height_log2: 6
>>>>>>>> acc->awb.stripes[1].grid.x_start: 0
>>>>>>>> acc->awb.stripes[1].grid.x_end: 1263
>>>>>>>> acc->awb.stripes[1].grid.y_start: 0
>>>>>>>> acc->awb.stripes[1].grid.y_end: 1535
>>>>>
>>>>> Are these dumps from 1920x1280 output?
>>>>
>>>> Jean-Michel, could you comment on this ?
>>>>
>>>> Note that the grid is configured with 79 cells of 16 pixels, covering
>>>> 1264 pixels horizontally. That's not the full image for a 1920 pixels
>>>> output, and will probably not be done in practice, but there's nothing
>>>> preventing the grid from covering part of the image only.
>>>>
>>>>>>>> This has been outputted with: https://paste.debian.net/1212791/
>>>>>>>>
>>>>>>>> The examples I gave before were 1280x720 output and not 1920x1080,
>>>>>>>> here are they:
>>>>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png
>>>>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png
>>>>>>>>
>>>>>>>> As you can see we have the same behaviour.
>>>>>>>>
>>>>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:
>>>>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois
>>> wrote:
>>>>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:
>>>>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois
>>> wrote:
>>>>>>>>>>>>> While playing with low resolutions for the grid, it appeared
>>>>>>>>>>>>> that height_per_slice is not initialised if we are not using
>>>>>>>>>>>>> both stripes for the calculations. This pattern occurs three
>>> times:
>>>>>>>>>>>>> - for the awb_fr processing block
>>>>>>>>>>>>> - for the af processing block
>>>>>>>>>>>>> - for the awb processing block
>>>>>>>>>>>>>
>>>>>>>>>>>>> The idea of this small portion of code is to reduce
>>>>>>>>>>>>> complexity in loading the statistics, it could be done also
>>>>>>>>>>>>> when only one stripe is used. Fix it by getting this
>>>>>>>>>>>>> initialisation code outside of the
>>>>>>>>>>>>> else() test case.
>>>>>>>>>>>>>
>>>>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois
>>>>>>>>>>>>> <jeanmichel.hautbois@ideasonboard.com>
>>>>>>>>>>>>> ---
>>>>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 >>>>>
>>>>>>>>>>>>> ++++++++++----------
>>>>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)
>>>>>>>>>>>>>
>>>>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644
>>>>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css
>>> *css, unsigned int pipe,
>>>>>>>>>>>>>  					acc-
>>>> awb_fr.stripes[1].grid_cfg.width,
>>>>>>>>>>>>>  					b_w_log2);
>>>>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;
>>>>>>>>>>>>> -
>>>>>>>>>>>>> -		/*
>>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading
>>>>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both
>>>>>>>>>>>>> -		 * stripes.
>>>>>>>>>>>>> -		 */
>>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
>>>>>>>>>>>>> -			acc-
>>>> awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>>  	}
>>>>>>>>>>>>>
>>>>>>>>>>>>> +	/*
>>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading
>>>>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both
>>>>>>>>>>>>> +	 * stripes.
>>>>>>>>>>>>> +	 */
>>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
>>>>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>> +
>>>>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))
>>>>>>>>>>>>>  		return -EINVAL;
>>>>>>>>>>>>>
>>>>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css
>>> *css, unsigned int pipe,
>>>>>>>>>>>>>  			imgu_css_grid_end(acc-
>>>> af.stripes[1].grid_cfg.x_start,
>>>>>>>>>>>>>  					  acc-
>>>> af.stripes[1].grid_cfg.width,
>>>>>>>>>>>>>  					  b_w_log2);
>>>>>>>>>>>>> -
>>>>>>>>>>>>> -		/*
>>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading
>>> statistics
>>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>> -		 */
>>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
>>>>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice =
>>> 1;
>>>>>>>>>>>>>  	}
>>>>>>>>>>>>>
>>>>>>>>>>>>> +	/*
>>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics
>>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>> +	 */
>>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
>>>>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>> +
>>>>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))
>>>>>>>>>>>>>  		return -EINVAL;
>>>>>>>>>>>>>
>>>>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css
>>> *css, unsigned int pipe,
>>>>>>>>>>>>>  			imgu_css_grid_end(acc-
>>>> awb.stripes[1].grid.x_start,
>>>>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,
>>>>>>>>>>>>>  					  b_w_log2);
>>>>>>>>>>>>> -
>>>>>>>>>>>>> -		/*
>>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading
>>> statistics
>>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>> -		 */
>>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
>>>>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;
>>>>>>>>>>>>>  	}
>>>>>>>>>>>>>
>>>>>>>>>>>>> +	/*
>>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics
>>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>> +	 */
>>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
>>>>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;
>>>>>>>>>>>>> +
>>>>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))
>>>>>>>>>>>>>  		return -EINVAL;
>>>>>>>>>>>>>
>>>>>>>>>>>>
>>>>>>>>>>>> While it seems like a sensible idea to initialise arguments to
>>>>>>>>>>>> firmware, does this have an effect on the statistics format?
>>>>>>>>>>>> If so, can the existing user space cope with that?
>>>>>>>>>>>
>>>>>>>>>>> To try and figure that out, we have tested several grid
>>>>>>>>>>> configurations and inspected the captured statistics. We have
>>>>>>>>>>> converted the statistics in an image, rendering each cell as a
>>>>>>>>>>> pixel whose red, green and blue components are the cell's red,
>>> green and blue averages.
>>>>>>>>>>> This turned out to be a very effectice tool to quickly
>>>>>>>>>>> visualize AWB statistics.
>>>>>>>>>>> We have made a lot of tests with different output resolutions,
>>>>>>>>>>> from a small one up to the full-scale one.
>>>>>>>>>>>
>>>>>>>>>>> Here is one example of a statistics output with a ViewFinder
>>>>>>>>>>> configured as 1920x1280, with a BDS output configuration set to
>>>>>>>>>>> 2304x1536 (sensor is 2592x1944).
>>>>>>>>>>>
>>>>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we
>>>>>>>>>>> obtain the
>>>>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.
>>>>>>>>>>> We can notice a weird padding every two lines and it seems to
>>>>>>>>>>> be missing half of the frame.
>>>>>>>>>>>
>>>>>>>>>>> With the patch applied, the same configuration gives us the
>>> image:
>>>>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png
>>>>>>>>>>>
>>>>>>>>>>> We can clearly see the one padding pixel on the right, and the
>>>>>>>>>>> frame is all there, as expected.
>>>>>>>>>>>
>>>>>>>>>>> Tomasz: We're concerned that this patch may have an impact on
>>>>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for
>>>>>>>>>>> someone to review and test this please?
>>>>>>>>>>
>>>>>>>>>> As shown by the images above, this is a real fix. It only
>>>>>>>>>> affects grid configurations that use a single stripe (left or
>>>>>>>>>> right), so either "small" resolutions (less than 1280 pixels at
>>>>>>>>>> the BDS output if I recall correctly), or grid configurations
>>>>>>>>>> that span the left part of the image with higher resolutions.
>>>>>>>>>> The latter is probably unlikely. For the former, it may affect
>>>>>>>>>> the binary library, especially if it includes a workaround for
>>> the bug.
>>>>>>>>>>
>>>>>>>>>> Still, this change is good I believe, so it should be upstreamed.
>>>>
>>
Laurent Pinchart Aug. 14, 2023, 1:28 p.m. UTC | #18
Hi Bingbu,

On Wed, Aug 09, 2023 at 12:11:40PM +0800, Bingbu Cao wrote:
> Jean-Michel,
> 
> I remember you resolved the problem about awb in libcamhal, so is this
> patch still necessary or valid for Imgu? :)

If I recall correctly, we don't trigger this issue on Soraka with the
latest libcamera version (I'd need to retest though), but I think the
patch is nonetheless a good bug fix. The current code passes an
uninitialized value to the firmware, which is wrong.

> On 10/14/21 2:57 PM, Jean-Michel Hautbois wrote:
> > On 11/10/2021 04:42, Cao, Bingbu wrote:
> >> On Thursday, September 30, 2021 5:31 PM, Jean-Michel Hautbois wrote:
> >>> On 23/09/2021 12:49, Laurent Pinchart wrote:
> >>>> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:
> >>>>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:
> >>>>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:
> >>>>>>> Jean-Michel,
> >>>>>>>
> >>>>>>> Firstly, the .height_per_slice could be 0 if your .grid.width
> >>>>>>> larger than 32.
> >>>>>>
> >>>>>> Which .height_per_slice are you talking about ? A field of that name
> >>>>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct
> >>>>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.
> >>>>>>
> >>>>>> They are both computed by the driver, in imgu_css_cfg_acc(). The
> >>>>>> former is set to
> >>>>>>
> >>>>>> 	acc->awb.config.grid.height_per_slice =
> >>>>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,
> >>>>>>
> >>>>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0
> >>>>>> if grid.width > 160, which is invalid.
> >>>>>
> >>>>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.
> >>>>
> >>>> Indeed, my bad. I was focussing on the AWB statistics.
> >>>>
> >>>> What are the implications of a height_per_slice value of 0 ?
> >>>>
> >>>> While we are on this topic, what is a "slice" ? Does it matter for the
> >>>> user, as in does it have an impact on the statistics values, or on how
> >>>> they're arranged in memory, or is it an implementation detail of the
> >>>> firmware that has no consequence on what can be seen by the user ?
> >>>> (The "user" here is the code that reads the statistics in userspace).
> >>>
> >>> Gentle ping on these specific questions from Laurent :-) ?
> >>
> >> I am not an expert on this statistics algo.
> >>
> >> My understanding:
> >> height_per_slice means number of blocks in vertical axis per Metadata slice.
> >> ImgU divide grid-based Metadata into slices, each slice refers to 
> >> grid_width * height_per_slice blocks, if height_per_slice is 0, that means
> >> the grid_width is too large to use. IOW, it is an invalid parameter, we
> >> need check this invalid value instead of just setting to 1.
> > 
> > Is it true only for awb_fr and af, or also for awb ?
> > If it is not for awb, the patch could be only for awb, as it really
> > solves an issue ?
> > 
> > Tomasz, do you think it may introduce a regression in the binary library
> > ? Would it be possible to test it ? I can send a v2 with only awb if it
> > is needed.
> > 
> >>>>>>> From your configuration, looks like something wrong in the stripe
> >>>>>>> configuration cause not entering the 2 stripes branch.
> >>>>>>
> >>>>>> Why is that ? Isn't it valid for a grid configuration to use a
> >>>>>> single stripe, if the image is small enough, or if the grid only
> >>>>>> covers the left part of the image ?
> >>>>>>
> >>>>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:
> >>>>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:
> >>>>>>>>> Jean-Michel,
> >>>>>>>>>
> >>>>>>>>> Thanks for you patch.
> >>>>>>>>> What is the value of .config.grid_cfg.width for your low resolutions?
> >>>>>>>>
> >>>>>>>> I don't know if a 1920x1280 output is a low resolution, but the
> >>>>>>>> grid is configured as:
> >>>>>>>> - grid_cfg.width = 79
> >>>>>>>> - grid_cfg.height = 24
> >>>>>>>> - grid_cfg.block_width_log2 = 4
> >>>>>>>> - grid_cfg.block_height_log2 = 6
> >>>>>>>>
> >>>>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():
> >>>>>>>>
> >>>>>>>> acc->stripe.down_scaled_stripes[0].width: 1280
> >>>>>>>> acc->stripe.down_scaled_stripes[0].height: 1536
> >>>>>>>> acc->stripe.down_scaled_stripes[0].offset: 0
> >>>>>>>> acc->stripe.bds_out_stripes[0].width: 1280
> >>>>>>>> acc->stripe.bds_out_stripes[0].height: 1536
> >>>>>>>> acc->stripe.bds_out_stripes[0].offset: 0
> >>>>>>>> acc->acc->awb.stripes[0].grid.width: 79
> >>>>>>>> acc->awb.stripes[0].grid.block_width_log2: 4
> >>>>>>>> acc->acc->awb.stripes[0].grid.height: 24
> >>>>>>>> acc->awb.stripes[0].grid.block_height_log2: 6
> >>>>>>>> acc->awb.stripes[0].grid.x_start: 0
> >>>>>>>> acc->awb.stripes[0].grid.x_end: 1263
> >>>>>>>> acc->awb.stripes[0].grid.y_start: 0
> >>>>>>>> acc->awb.stripes[0].grid.y_end: 1535
> >>>>>>>> acc->stripe.down_scaled_stripes[1].width: 1280
> >>>>>>>> acc->stripe.down_scaled_stripes[1].height: 1536
> >>>>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024
> >>>>>>>> acc->stripe.bds_out_stripes[1].width: 1280
> >>>>>>>> acc->stripe.bds_out_stripes[1].height: 1536
> >>>>>>>> acc->stripe.bds_out_stripes[1].offset: 1024
> >>>>>>>> acc->acc->awb.stripes[1].grid.width: 79
> >>>>>>>> acc->awb.stripes[1].grid.block_width_log2: 4
> >>>>>>>> acc->acc->awb.stripes[1].grid.height: 24
> >>>>>>>> acc->awb.stripes[1].grid.block_height_log2: 6
> >>>>>>>> acc->awb.stripes[1].grid.x_start: 0
> >>>>>>>> acc->awb.stripes[1].grid.x_end: 1263
> >>>>>>>> acc->awb.stripes[1].grid.y_start: 0
> >>>>>>>> acc->awb.stripes[1].grid.y_end: 1535
> >>>>>
> >>>>> Are these dumps from 1920x1280 output?
> >>>>
> >>>> Jean-Michel, could you comment on this ?
> >>>>
> >>>> Note that the grid is configured with 79 cells of 16 pixels, covering
> >>>> 1264 pixels horizontally. That's not the full image for a 1920 pixels
> >>>> output, and will probably not be done in practice, but there's nothing
> >>>> preventing the grid from covering part of the image only.
> >>>>
> >>>>>>>> This has been outputted with: https://paste.debian.net/1212791/
> >>>>>>>>
> >>>>>>>> The examples I gave before were 1280x720 output and not 1920x1080,
> >>>>>>>> here are they:
> >>>>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png
> >>>>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png
> >>>>>>>>
> >>>>>>>> As you can see we have the same behaviour.
> >>>>>>>>
> >>>>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:
> >>>>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:
> >>>>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:
> >>>>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:
> >>>>>>>>>>>>> While playing with low resolutions for the grid, it appeared
> >>>>>>>>>>>>> that height_per_slice is not initialised if we are not using
> >>>>>>>>>>>>> both stripes for the calculations. This pattern occurs three times:
> >>>>>>>>>>>>> - for the awb_fr processing block
> >>>>>>>>>>>>> - for the af processing block
> >>>>>>>>>>>>> - for the awb processing block
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> The idea of this small portion of code is to reduce
> >>>>>>>>>>>>> complexity in loading the statistics, it could be done also
> >>>>>>>>>>>>> when only one stripe is used. Fix it by getting this
> >>>>>>>>>>>>> initialisation code outside of the
> >>>>>>>>>>>>> else() test case.
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>
> >>>>>>>>>>>>> ---
> >>>>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------
> >>>>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c
> >>>>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c
> >>>>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644
> >>>>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c
> >>>>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c
> >>>>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
> >>>>>>>>>>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,
> >>>>>>>>>>>>>  					b_w_log2);
> >>>>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;
> >>>>>>>>>>>>> -
> >>>>>>>>>>>>> -		/*
> >>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading
> >>>>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both
> >>>>>>>>>>>>> -		 * stripes.
> >>>>>>>>>>>>> -		 */
> >>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
> >>>>>>>>>>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
> >>>>>>>>>>>>>  	}
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> +	/*
> >>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading
> >>>>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both
> >>>>>>>>>>>>> +	 * stripes.
> >>>>>>>>>>>>> +	 */
> >>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
> >>>>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
> >>>>>>>>>>>>> +
> >>>>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))
> >>>>>>>>>>>>>  		return -EINVAL;
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
> >>>>>>>>>>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,
> >>>>>>>>>>>>>  					  acc->af.stripes[1].grid_cfg.width,
> >>>>>>>>>>>>>  					  b_w_log2);
> >>>>>>>>>>>>> -
> >>>>>>>>>>>>> -		/*
> >>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics
> >>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes
> >>>>>>>>>>>>> -		 */
> >>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
> >>>>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;
> >>>>>>>>>>>>>  	}
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> +	/*
> >>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics
> >>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes
> >>>>>>>>>>>>> +	 */
> >>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
> >>>>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;
> >>>>>>>>>>>>> +
> >>>>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))
> >>>>>>>>>>>>>  		return -EINVAL;
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
> >>>>>>>>>>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,
> >>>>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,
> >>>>>>>>>>>>>  					  b_w_log2);
> >>>>>>>>>>>>> -
> >>>>>>>>>>>>> -		/*
> >>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics
> >>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes
> >>>>>>>>>>>>> -		 */
> >>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
> >>>>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;
> >>>>>>>>>>>>>  	}
> >>>>>>>>>>>>>
> >>>>>>>>>>>>> +	/*
> >>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics
> >>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes
> >>>>>>>>>>>>> +	 */
> >>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
> >>>>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;
> >>>>>>>>>>>>> +
> >>>>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))
> >>>>>>>>>>>>>  		return -EINVAL;
> >>>>>>>>>>>>>
> >>>>>>>>>>>>
> >>>>>>>>>>>> While it seems like a sensible idea to initialise arguments to
> >>>>>>>>>>>> firmware, does this have an effect on the statistics format?
> >>>>>>>>>>>> If so, can the existing user space cope with that?
> >>>>>>>>>>>
> >>>>>>>>>>> To try and figure that out, we have tested several grid
> >>>>>>>>>>> configurations and inspected the captured statistics. We have
> >>>>>>>>>>> converted the statistics in an image, rendering each cell as a
> >>>>>>>>>>> pixel whose red, green and blue components are the cell's
> >>>>>>>>>>> red, green and blue averages.
> >>>>>>>>>>> This turned out to be a very effectice tool to quickly
> >>>>>>>>>>> visualize AWB statistics.
> >>>>>>>>>>> We have made a lot of tests with different output resolutions,
> >>>>>>>>>>> from a small one up to the full-scale one.
> >>>>>>>>>>>
> >>>>>>>>>>> Here is one example of a statistics output with a ViewFinder
> >>>>>>>>>>> configured as 1920x1280, with a BDS output configuration set to
> >>>>>>>>>>> 2304x1536 (sensor is 2592x1944).
> >>>>>>>>>>>
> >>>>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we
> >>>>>>>>>>> obtain the
> >>>>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.
> >>>>>>>>>>> We can notice a weird padding every two lines and it seems to
> >>>>>>>>>>> be missing half of the frame.
> >>>>>>>>>>>
> >>>>>>>>>>> With the patch applied, the same configuration gives us the image:
> >>>>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png
> >>>>>>>>>>>
> >>>>>>>>>>> We can clearly see the one padding pixel on the right, and the
> >>>>>>>>>>> frame is all there, as expected.
> >>>>>>>>>>>
> >>>>>>>>>>> Tomasz: We're concerned that this patch may have an impact on
> >>>>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for
> >>>>>>>>>>> someone to review and test this please?
> >>>>>>>>>>
> >>>>>>>>>> As shown by the images above, this is a real fix. It only
> >>>>>>>>>> affects grid configurations that use a single stripe (left or
> >>>>>>>>>> right), so either "small" resolutions (less than 1280 pixels at
> >>>>>>>>>> the BDS output if I recall correctly), or grid configurations
> >>>>>>>>>> that span the left part of the image with higher resolutions.
> >>>>>>>>>> The latter is probably unlikely. For the former, it may affect
> >>>>>>>>>> the binary library, especially if it includes a workaround for the bug.
> >>>>>>>>>>
> >>>>>>>>>> Still, this change is good I believe, so it should be upstreamed.
Bingbu Cao Aug. 15, 2023, 2:48 a.m. UTC | #19
Hi Laurent and Jean-Michel,

Thanks for your reply.

On 8/14/23 9:28 PM, Laurent Pinchart wrote:
> Hi Bingbu,
> 
> On Wed, Aug 09, 2023 at 12:11:40PM +0800, Bingbu Cao wrote:
>> Jean-Michel,
>>
>> I remember you resolved the problem about awb in libcamhal, so is this
>> patch still necessary or valid for Imgu? :)
> 
> If I recall correctly, we don't trigger this issue on Soraka with the
> latest libcamera version (I'd need to retest though), but I think the
> patch is nonetheless a good bug fix. The current code passes an
> uninitialized value to the firmware, which is wrong.

Yes for af.strips[], it needs. But I am wondering why the code didn't
initialize the value.

	acc->awb_fr.config.grid_cfg.height_per_slice =
		IMGU_ABI_AWB_FR_MAX_CELLS_PER_SET /
		acc->awb_fr.config.grid_cfg.width;

	for (i = 0; i < stripes; i++)
		acc->awb_fr.stripes[i] = acc->awb_fr.config;

...
	acc->awb.config.grid.height_per_slice =
		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,
	imgu_css_grid_end_calc(&acc->awb.config.grid);

	for (i = 0; i < stripes; i++)
		acc->awb.stripes[i] = acc->awb.config;

I think we need add missing initialization for af. Which incorrect
configuration did you meet before?

> 
>> On 10/14/21 2:57 PM, Jean-Michel Hautbois wrote:
>>> On 11/10/2021 04:42, Cao, Bingbu wrote:
>>>> On Thursday, September 30, 2021 5:31 PM, Jean-Michel Hautbois wrote:
>>>>> On 23/09/2021 12:49, Laurent Pinchart wrote:
>>>>>> On Thu, Sep 23, 2021 at 10:29:33AM +0000, Cao, Bingbu wrote:
>>>>>>> On Thursday, September 23, 2021 5:46 PM, Laurent Pinchart wrote:
>>>>>>>> On Thu, Sep 23, 2021 at 09:06:32AM +0000, Cao, Bingbu wrote:
>>>>>>>>> Jean-Michel,
>>>>>>>>>
>>>>>>>>> Firstly, the .height_per_slice could be 0 if your .grid.width
>>>>>>>>> larger than 32.
>>>>>>>>
>>>>>>>> Which .height_per_slice are you talking about ? A field of that name
>>>>>>>> exists in both ipu3_uapi_acc_param.awb.config.grid and struct
>>>>>>>> ipu3_uapi_grid_config and imgu_abi_awb_config.stripes.grid.
>>>>>>>>
>>>>>>>> They are both computed by the driver, in imgu_css_cfg_acc(). The
>>>>>>>> former is set to
>>>>>>>>
>>>>>>>> 	acc->awb.config.grid.height_per_slice =
>>>>>>>> 		IMGU_ABI_AWB_MAX_CELLS_PER_SET / acc->awb.config.grid.width,
>>>>>>>>
>>>>>>>> IMGU_ABI_AWB_MAX_CELLS_PER_SET is equal to 160, so it can only be 0
>>>>>>>> if grid.width > 160, which is invalid.
>>>>>>>
>>>>>>> For awb_fr and af, it could be 0 if the .config.grid_cfg.width > 32.
>>>>>>
>>>>>> Indeed, my bad. I was focussing on the AWB statistics.
>>>>>>
>>>>>> What are the implications of a height_per_slice value of 0 ?
>>>>>>
>>>>>> While we are on this topic, what is a "slice" ? Does it matter for the
>>>>>> user, as in does it have an impact on the statistics values, or on how
>>>>>> they're arranged in memory, or is it an implementation detail of the
>>>>>> firmware that has no consequence on what can be seen by the user ?
>>>>>> (The "user" here is the code that reads the statistics in userspace).
>>>>>
>>>>> Gentle ping on these specific questions from Laurent :-) ?
>>>>
>>>> I am not an expert on this statistics algo.
>>>>
>>>> My understanding:
>>>> height_per_slice means number of blocks in vertical axis per Metadata slice.
>>>> ImgU divide grid-based Metadata into slices, each slice refers to 
>>>> grid_width * height_per_slice blocks, if height_per_slice is 0, that means
>>>> the grid_width is too large to use. IOW, it is an invalid parameter, we
>>>> need check this invalid value instead of just setting to 1.
>>>
>>> Is it true only for awb_fr and af, or also for awb ?
>>> If it is not for awb, the patch could be only for awb, as it really
>>> solves an issue ?
>>>
>>> Tomasz, do you think it may introduce a regression in the binary library
>>> ? Would it be possible to test it ? I can send a v2 with only awb if it
>>> is needed.
>>>
>>>>>>>>> From your configuration, looks like something wrong in the stripe
>>>>>>>>> configuration cause not entering the 2 stripes branch.
>>>>>>>>
>>>>>>>> Why is that ? Isn't it valid for a grid configuration to use a
>>>>>>>> single stripe, if the image is small enough, or if the grid only
>>>>>>>> covers the left part of the image ?
>>>>>>>>
>>>>>>>>> On Wednesday, September 22, 2021 1:54 PM, Jean-Michel Hautbois wrote:
>>>>>>>>>> On 22/09/2021 06:33, Cao, Bingbu wrote:
>>>>>>>>>>> Jean-Michel,
>>>>>>>>>>>
>>>>>>>>>>> Thanks for you patch.
>>>>>>>>>>> What is the value of .config.grid_cfg.width for your low resolutions?
>>>>>>>>>>
>>>>>>>>>> I don't know if a 1920x1280 output is a low resolution, but the
>>>>>>>>>> grid is configured as:
>>>>>>>>>> - grid_cfg.width = 79
>>>>>>>>>> - grid_cfg.height = 24
>>>>>>>>>> - grid_cfg.block_width_log2 = 4
>>>>>>>>>> - grid_cfg.block_height_log2 = 6
>>>>>>>>>>
>>>>>>>>>> Here is a full debug output of the AWB part in imgu_css_cfg_acc():
>>>>>>>>>>
>>>>>>>>>> acc->stripe.down_scaled_stripes[0].width: 1280
>>>>>>>>>> acc->stripe.down_scaled_stripes[0].height: 1536
>>>>>>>>>> acc->stripe.down_scaled_stripes[0].offset: 0
>>>>>>>>>> acc->stripe.bds_out_stripes[0].width: 1280
>>>>>>>>>> acc->stripe.bds_out_stripes[0].height: 1536
>>>>>>>>>> acc->stripe.bds_out_stripes[0].offset: 0
>>>>>>>>>> acc->acc->awb.stripes[0].grid.width: 79
>>>>>>>>>> acc->awb.stripes[0].grid.block_width_log2: 4
>>>>>>>>>> acc->acc->awb.stripes[0].grid.height: 24
>>>>>>>>>> acc->awb.stripes[0].grid.block_height_log2: 6
>>>>>>>>>> acc->awb.stripes[0].grid.x_start: 0
>>>>>>>>>> acc->awb.stripes[0].grid.x_end: 1263
>>>>>>>>>> acc->awb.stripes[0].grid.y_start: 0
>>>>>>>>>> acc->awb.stripes[0].grid.y_end: 1535
>>>>>>>>>> acc->stripe.down_scaled_stripes[1].width: 1280
>>>>>>>>>> acc->stripe.down_scaled_stripes[1].height: 1536
>>>>>>>>>> acc->stripe.down_scaled_stripes[1].offset: 1024
>>>>>>>>>> acc->stripe.bds_out_stripes[1].width: 1280
>>>>>>>>>> acc->stripe.bds_out_stripes[1].height: 1536
>>>>>>>>>> acc->stripe.bds_out_stripes[1].offset: 1024
>>>>>>>>>> acc->acc->awb.stripes[1].grid.width: 79
>>>>>>>>>> acc->awb.stripes[1].grid.block_width_log2: 4
>>>>>>>>>> acc->acc->awb.stripes[1].grid.height: 24
>>>>>>>>>> acc->awb.stripes[1].grid.block_height_log2: 6
>>>>>>>>>> acc->awb.stripes[1].grid.x_start: 0
>>>>>>>>>> acc->awb.stripes[1].grid.x_end: 1263
>>>>>>>>>> acc->awb.stripes[1].grid.y_start: 0
>>>>>>>>>> acc->awb.stripes[1].grid.y_end: 1535
>>>>>>>
>>>>>>> Are these dumps from 1920x1280 output?
>>>>>>
>>>>>> Jean-Michel, could you comment on this ?
>>>>>>
>>>>>> Note that the grid is configured with 79 cells of 16 pixels, covering
>>>>>> 1264 pixels horizontally. That's not the full image for a 1920 pixels
>>>>>> output, and will probably not be done in practice, but there's nothing
>>>>>> preventing the grid from covering part of the image only.
>>>>>>
>>>>>>>>>> This has been outputted with: https://paste.debian.net/1212791/
>>>>>>>>>>
>>>>>>>>>> The examples I gave before were 1280x720 output and not 1920x1080,
>>>>>>>>>> here are they:
>>>>>>>>>> - without the patch: https://pasteboard.co/hHo4QkVUSk8e.png
>>>>>>>>>> - with the patch: https://pasteboard.co/YUGUvS5tD0bo.png
>>>>>>>>>>
>>>>>>>>>> As you can see we have the same behaviour.
>>>>>>>>>>
>>>>>>>>>>> On Tuesday, September 21, 2021 10:34 PM, Laurent Pinchart wrote:
>>>>>>>>>>>> On Tue, Sep 21, 2021 at 03:04:37PM +0200, Jean-Michel Hautbois wrote:
>>>>>>>>>>>>> On 21/09/2021 13:07, Sakari Ailus wrote:
>>>>>>>>>>>>>> On Thu, Sep 16, 2021 at 07:25:04PM +0200, Jean-Michel Hautbois wrote:
>>>>>>>>>>>>>>> While playing with low resolutions for the grid, it appeared
>>>>>>>>>>>>>>> that height_per_slice is not initialised if we are not using
>>>>>>>>>>>>>>> both stripes for the calculations. This pattern occurs three times:
>>>>>>>>>>>>>>> - for the awb_fr processing block
>>>>>>>>>>>>>>> - for the af processing block
>>>>>>>>>>>>>>> - for the awb processing block
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> The idea of this small portion of code is to reduce
>>>>>>>>>>>>>>> complexity in loading the statistics, it could be done also
>>>>>>>>>>>>>>> when only one stripe is used. Fix it by getting this
>>>>>>>>>>>>>>> initialisation code outside of the
>>>>>>>>>>>>>>> else() test case.
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com>
>>>>>>>>>>>>>>> ---
>>>>>>>>>>>>>>>  drivers/staging/media/ipu3/ipu3-css-params.c | 44 ++++++++++----------
>>>>>>>>>>>>>>>  1 file changed, 22 insertions(+), 22 deletions(-)
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>>>> b/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>>>> index e9d6bd9e9332..05da7dbdca78 100644
>>>>>>>>>>>>>>> --- a/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>>>> +++ b/drivers/staging/media/ipu3/ipu3-css-params.c
>>>>>>>>>>>>>>> @@ -2428,16 +2428,16 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
>>>>>>>>>>>>>>>  					acc->awb_fr.stripes[1].grid_cfg.width,
>>>>>>>>>>>>>>>  					b_w_log2);
>>>>>>>>>>>>>>>  		acc->awb_fr.stripes[1].grid_cfg.x_end = end;
>>>>>>>>>>>>>>> -
>>>>>>>>>>>>>>> -		/*
>>>>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading
>>>>>>>>>>>>>>> -		 * statistics fix grid_height_per_slice to 1 for both
>>>>>>>>>>>>>>> -		 * stripes.
>>>>>>>>>>>>>>> -		 */
>>>>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
>>>>>>>>>>>>>>> -			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>>>>  	}
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> +	/*
>>>>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading
>>>>>>>>>>>>>>> +	 * statistics fix grid_height_per_slice to 1 for both
>>>>>>>>>>>>>>> +	 * stripes.
>>>>>>>>>>>>>>> +	 */
>>>>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
>>>>>>>>>>>>>>> +		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>>>> +
>>>>>>>>>>>>>>>  	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))
>>>>>>>>>>>>>>>  		return -EINVAL;
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> @@ -2591,15 +2591,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
>>>>>>>>>>>>>>>  			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,
>>>>>>>>>>>>>>>  					  acc->af.stripes[1].grid_cfg.width,
>>>>>>>>>>>>>>>  					  b_w_log2);
>>>>>>>>>>>>>>> -
>>>>>>>>>>>>>>> -		/*
>>>>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics
>>>>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>>>> -		 */
>>>>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
>>>>>>>>>>>>>>> -			acc->af.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>>>>  	}
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> +	/*
>>>>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics
>>>>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>>>> +	 */
>>>>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
>>>>>>>>>>>>>>> +		acc->af.stripes[i].grid_cfg.height_per_slice = 1;
>>>>>>>>>>>>>>> +
>>>>>>>>>>>>>>>  	if (imgu_css_af_ops_calc(css, pipe, &acc->af))
>>>>>>>>>>>>>>>  		return -EINVAL;
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> @@ -2660,15 +2660,15 @@ int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
>>>>>>>>>>>>>>>  			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,
>>>>>>>>>>>>>>>  					  acc->awb.stripes[1].grid.width,
>>>>>>>>>>>>>>>  					  b_w_log2);
>>>>>>>>>>>>>>> -
>>>>>>>>>>>>>>> -		/*
>>>>>>>>>>>>>>> -		 * To reduce complexity of debubbling and loading statistics
>>>>>>>>>>>>>>> -		 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>>>> -		 */
>>>>>>>>>>>>>>> -		for (i = 0; i < stripes; i++)
>>>>>>>>>>>>>>> -			acc->awb.stripes[i].grid.height_per_slice = 1;
>>>>>>>>>>>>>>>  	}
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>> +	/*
>>>>>>>>>>>>>>> +	 * To reduce complexity of debubbling and loading statistics
>>>>>>>>>>>>>>> +	 * fix grid_height_per_slice to 1 for both stripes
>>>>>>>>>>>>>>> +	 */
>>>>>>>>>>>>>>> +	for (i = 0; i < stripes; i++)
>>>>>>>>>>>>>>> +		acc->awb.stripes[i].grid.height_per_slice = 1;
>>>>>>>>>>>>>>> +
>>>>>>>>>>>>>>>  	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))
>>>>>>>>>>>>>>>  		return -EINVAL;
>>>>>>>>>>>>>>>
>>>>>>>>>>>>>>
>>>>>>>>>>>>>> While it seems like a sensible idea to initialise arguments to
>>>>>>>>>>>>>> firmware, does this have an effect on the statistics format?
>>>>>>>>>>>>>> If so, can the existing user space cope with that?
>>>>>>>>>>>>>
>>>>>>>>>>>>> To try and figure that out, we have tested several grid
>>>>>>>>>>>>> configurations and inspected the captured statistics. We have
>>>>>>>>>>>>> converted the statistics in an image, rendering each cell as a
>>>>>>>>>>>>> pixel whose red, green and blue components are the cell's
>>>>>>>>>>>>> red, green and blue averages.
>>>>>>>>>>>>> This turned out to be a very effectice tool to quickly
>>>>>>>>>>>>> visualize AWB statistics.
>>>>>>>>>>>>> We have made a lot of tests with different output resolutions,
>>>>>>>>>>>>> from a small one up to the full-scale one.
>>>>>>>>>>>>>
>>>>>>>>>>>>> Here is one example of a statistics output with a ViewFinder
>>>>>>>>>>>>> configured as 1920x1280, with a BDS output configuration set to
>>>>>>>>>>>>> 2304x1536 (sensor is 2592x1944).
>>>>>>>>>>>>>
>>>>>>>>>>>>> Without the patch, configuring a 79x45 grid of 16x16 cells we
>>>>>>>>>>>>> obtain the
>>>>>>>>>>>>> image: https://pasteboard.co/g4nC4fHjbVER.png.
>>>>>>>>>>>>> We can notice a weird padding every two lines and it seems to
>>>>>>>>>>>>> be missing half of the frame.
>>>>>>>>>>>>>
>>>>>>>>>>>>> With the patch applied, the same configuration gives us the image:
>>>>>>>>>>>>> https://pasteboard.co/rzap6axIvVdu.png
>>>>>>>>>>>>>
>>>>>>>>>>>>> We can clearly see the one padding pixel on the right, and the
>>>>>>>>>>>>> frame is all there, as expected.
>>>>>>>>>>>>>
>>>>>>>>>>>>> Tomasz: We're concerned that this patch may have an impact on
>>>>>>>>>>>>> the ChromeOS Intel Camera HAL with the IPU3. Is it possible for
>>>>>>>>>>>>> someone to review and test this please?
>>>>>>>>>>>>
>>>>>>>>>>>> As shown by the images above, this is a real fix. It only
>>>>>>>>>>>> affects grid configurations that use a single stripe (left or
>>>>>>>>>>>> right), so either "small" resolutions (less than 1280 pixels at
>>>>>>>>>>>> the BDS output if I recall correctly), or grid configurations
>>>>>>>>>>>> that span the left part of the image with higher resolutions.
>>>>>>>>>>>> The latter is probably unlikely. For the former, it may affect
>>>>>>>>>>>> the binary library, especially if it includes a workaround for the bug.
>>>>>>>>>>>>
>>>>>>>>>>>> Still, this change is good I believe, so it should be upstreamed.
>
diff mbox series

Patch

diff --git a/drivers/staging/media/ipu3/ipu3-css-params.c b/drivers/staging/media/ipu3/ipu3-css-params.c
index e9d6bd9e9332..05da7dbdca78 100644
--- a/drivers/staging/media/ipu3/ipu3-css-params.c
+++ b/drivers/staging/media/ipu3/ipu3-css-params.c
@@ -2428,16 +2428,16 @@  int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
 					acc->awb_fr.stripes[1].grid_cfg.width,
 					b_w_log2);
 		acc->awb_fr.stripes[1].grid_cfg.x_end = end;
-
-		/*
-		 * To reduce complexity of debubbling and loading
-		 * statistics fix grid_height_per_slice to 1 for both
-		 * stripes.
-		 */
-		for (i = 0; i < stripes; i++)
-			acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
 	}
 
+	/*
+	 * To reduce complexity of debubbling and loading
+	 * statistics fix grid_height_per_slice to 1 for both
+	 * stripes.
+	 */
+	for (i = 0; i < stripes; i++)
+		acc->awb_fr.stripes[i].grid_cfg.height_per_slice = 1;
+
 	if (imgu_css_awb_fr_ops_calc(css, pipe, &acc->awb_fr))
 		return -EINVAL;
 
@@ -2591,15 +2591,15 @@  int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
 			imgu_css_grid_end(acc->af.stripes[1].grid_cfg.x_start,
 					  acc->af.stripes[1].grid_cfg.width,
 					  b_w_log2);
-
-		/*
-		 * To reduce complexity of debubbling and loading statistics
-		 * fix grid_height_per_slice to 1 for both stripes
-		 */
-		for (i = 0; i < stripes; i++)
-			acc->af.stripes[i].grid_cfg.height_per_slice = 1;
 	}
 
+	/*
+	 * To reduce complexity of debubbling and loading statistics
+	 * fix grid_height_per_slice to 1 for both stripes
+	 */
+	for (i = 0; i < stripes; i++)
+		acc->af.stripes[i].grid_cfg.height_per_slice = 1;
+
 	if (imgu_css_af_ops_calc(css, pipe, &acc->af))
 		return -EINVAL;
 
@@ -2660,15 +2660,15 @@  int imgu_css_cfg_acc(struct imgu_css *css, unsigned int pipe,
 			imgu_css_grid_end(acc->awb.stripes[1].grid.x_start,
 					  acc->awb.stripes[1].grid.width,
 					  b_w_log2);
-
-		/*
-		 * To reduce complexity of debubbling and loading statistics
-		 * fix grid_height_per_slice to 1 for both stripes
-		 */
-		for (i = 0; i < stripes; i++)
-			acc->awb.stripes[i].grid.height_per_slice = 1;
 	}
 
+	/*
+	 * To reduce complexity of debubbling and loading statistics
+	 * fix grid_height_per_slice to 1 for both stripes
+	 */
+	for (i = 0; i < stripes; i++)
+		acc->awb.stripes[i].grid.height_per_slice = 1;
+
 	if (imgu_css_awb_ops_calc(css, pipe, &acc->awb))
 		return -EINVAL;