[libcamera-devel] [PATCH 2/7] qcam: viewfinder_gl: Keep fragment shader when format doesn't change

Kieran Bingham kieran.bingham at ideasonboard.com
Tue Nov 3 23:47:23 CET 2020


Hi Laurent,

On 03/11/2020 15:50, Laurent Pinchart wrote:
> When ViewFinderGL::setFormat() is called, the fragment shader is deleted
> and recreated for the new format. This results in unnecessary shader
> recompilation if only the size is changed and the pixel format remains
> the same. Keep the existing shader in that case.
> 
> The null test for fragmentShader_ can be removed, as if the shader
> program is linked, the fragment shader is guaranteed to exist.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

Reviewed-by: Kieran Bingham <kieran.bingham at ideasonboard.com>

> ---
>  src/qcam/viewfinder_gl.cpp | 16 ++++++++++------
>  1 file changed, 10 insertions(+), 6 deletions(-)
> 
> diff --git a/src/qcam/viewfinder_gl.cpp b/src/qcam/viewfinder_gl.cpp
> index 03a576ba89d2..c07292523504 100644
> --- a/src/qcam/viewfinder_gl.cpp
> +++ b/src/qcam/viewfinder_gl.cpp
> @@ -53,19 +53,23 @@ const QList<libcamera::PixelFormat> &ViewFinderGL::nativeFormats() const
>  int ViewFinderGL::setFormat(const libcamera::PixelFormat &format,
>  			    const QSize &size)
>  {
> -	/* If the fragment is created remove it and create a new one. */
> -	if (fragmentShader_) {
> +	if (format != format_) {
> +		/*
> +		 * If the fragment already exists, remove it and create a new
> +		 * one for the new format.
> +		 */
>  		if (shaderProgram_.isLinked()) {
>  			shaderProgram_.release();
>  			shaderProgram_.removeShader(fragmentShader_.get());
>  			fragmentShader_.reset();
>  		}
> +
> +		if (!selectFormat(format))
> +			return -1;
> +
> +		format_ = format;
>  	}
>  
> -	if (!selectFormat(format))
> -		return -1;
> -
> -	format_ = format;
>  	size_ = size;
>  
>  	updateGeometry();
> 

-- 
Regards
--
Kieran


More information about the libcamera-devel mailing list