[PATCH 03/10] drm/exynos/mixer: move resolution configuration to single function

Tobias Jakobi tjakobi at math.uni-bielefeld.de
Tue Sep 12 12:29:41 UTC 2017


Hello Andrzej,


Andrzej Hajda wrote:
> Screen resolution configuration depends on HW version, let put it into
> single function to make it consistent and simplify the code.
"...let's put it into..."

Reviewed-by: Tobias Jakobi <tjakobi at math.uni-bielefeld.de>


> Signed-off-by: Andrzej Hajda <a.hajda at samsung.com>
> ---
>  drivers/gpu/drm/exynos/exynos_mixer.c | 17 +++++++----------
>  1 file changed, 7 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/gpu/drm/exynos/exynos_mixer.c b/drivers/gpu/drm/exynos/exynos_mixer.c
> index ae89e53..a87f60b 100644
> --- a/drivers/gpu/drm/exynos/exynos_mixer.c
> +++ b/drivers/gpu/drm/exynos/exynos_mixer.c
> @@ -367,7 +367,7 @@ static void mixer_vsync_set_update(struct mixer_context *ctx, bool enable)
>  			VP_SHADOW_UPDATE_ENABLE : 0);
>  }
>  
> -static void mixer_cfg_scan(struct mixer_context *ctx, unsigned int height)
> +static void mixer_cfg_scan(struct mixer_context *ctx, int width, int height)
>  {
>  	struct mixer_resources *res = &ctx->mixer_res;
>  	u32 val;
> @@ -376,7 +376,11 @@ static void mixer_cfg_scan(struct mixer_context *ctx, unsigned int height)
>  	val = test_bit(MXR_BIT_INTERLACE, &ctx->flags) ?
>  		MXR_CFG_SCAN_INTERLACE : MXR_CFG_SCAN_PROGRESSIVE;
>  
> -	if (ctx->mxr_ver != MXR_VER_128_0_0_184) {
> +	/* setup display size */
> +	if (ctx->mxr_ver == MXR_VER_128_0_0_184) {
> +		mixer_reg_write(&ctx->mixer_res, MXR_RESOLUTION,
> +			MXR_MXR_RES_HEIGHT(height) | MXR_MXR_RES_WIDTH(width));
> +	} else {
>  		/* choosing between proper HD and SD mode */
>  		if (height <= 480)
>  			val |= MXR_CFG_SCAN_NTSC | MXR_CFG_SCAN_SD;
> @@ -482,14 +486,7 @@ static void mixer_commit(struct mixer_context *ctx)
>  	else
>  		__clear_bit(MXR_BIT_INTERLACE, &ctx->flags);
>  
> -	/* setup display size */
> -	if (ctx->mxr_ver == MXR_VER_128_0_0_184) {
> -		u32 val  = MXR_MXR_RES_HEIGHT(mode->vdisplay)
> -			 | MXR_MXR_RES_WIDTH(mode->hdisplay);
> -		mixer_reg_write(&ctx->mixer_res, MXR_RESOLUTION, val);
> -	}
> -
> -	mixer_cfg_scan(ctx, mode->vdisplay);
> +	mixer_cfg_scan(ctx, mode->hdisplay, mode->vdisplay);
>  	mixer_cfg_rgb_fmt(ctx, mode->vdisplay);
>  	mixer_run(ctx);
>  }
> 



More information about the dri-devel mailing list