[PATCH 6/6] gpu: ipu-v3: Use videomode in struct ipu_di_signal_cfg

Philipp Zabel p.zabel at pengutronix.de
Wed Dec 17 06:02:56 PST 2014


Hi Steve,

I think this is a good idea. Two small comments below.

Am Montag, den 15.12.2014, 16:29 -0800 schrieb slongerbeam at gmail.com:
> From: Steve Longerbeam <steve_longerbeam at mentor.com>
> 
> This patch changes struct ipu_di_signal_cfg to use struct videomode
> to define video timings and flags.
> 
> Signed-off-by: Steve Longerbeam <steve_longerbeam at mentor.com>
> ---
>  drivers/gpu/drm/imx/ipuv3-crtc.c |   27 +++---------
>  drivers/gpu/ipu-v3/ipu-di.c      |   89 ++++++++++++++++++++------------------
>  include/video/imx-ipu-v3.h       |   19 ++------
>  3 files changed, 57 insertions(+), 78 deletions(-)
> 
> diff --git a/drivers/gpu/drm/imx/ipuv3-crtc.c b/drivers/gpu/drm/imx/ipuv3-crtc.c
> index fb16026..0a50129 100644
> --- a/drivers/gpu/drm/imx/ipuv3-crtc.c
> +++ b/drivers/gpu/drm/imx/ipuv3-crtc.c
> @@ -158,35 +158,20 @@ static int ipu_crtc_mode_set(struct drm_crtc *crtc,
>  
>  	out_pixel_fmt = ipu_crtc->interface_pix_fmt;
>  
> -	if (mode->flags & DRM_MODE_FLAG_INTERLACE)
> -		sig_cfg.interlaced = 1;
> -	if (mode->flags & DRM_MODE_FLAG_PHSYNC)
> -		sig_cfg.Hsync_pol = 1;
> -	if (mode->flags & DRM_MODE_FLAG_PVSYNC)
> -		sig_cfg.Vsync_pol = 1;
> -
>  	sig_cfg.enable_pol = 1;
>  	sig_cfg.clk_pol = 0;
> -	sig_cfg.width = mode->hdisplay;
> -	sig_cfg.height = mode->vdisplay;
>  	sig_cfg.pixel_fmt = out_pixel_fmt;
> -	sig_cfg.h_start_width = mode->htotal - mode->hsync_end;
> -	sig_cfg.h_sync_width = mode->hsync_end - mode->hsync_start;
> -	sig_cfg.h_end_width = mode->hsync_start - mode->hdisplay;
> -
> -	sig_cfg.v_start_width = mode->vtotal - mode->vsync_end;
> -	sig_cfg.v_sync_width = mode->vsync_end - mode->vsync_start;
> -	sig_cfg.v_end_width = mode->vsync_start - mode->vdisplay;
> -	sig_cfg.pixelclock = mode->clock * 1000;
>  	sig_cfg.clkflags = ipu_crtc->di_clkflags;
> -
>  	sig_cfg.v_to_h_sync = 0;
> -
>  	sig_cfg.hsync_pin = ipu_crtc->di_hsync_pin;
>  	sig_cfg.vsync_pin = ipu_crtc->di_vsync_pin;
>  
> -	ret = ipu_dc_init_sync(ipu_crtc->dc, ipu_crtc->di, sig_cfg.interlaced,
> -			out_pixel_fmt, mode->hdisplay);
> +	videomode_from_drm_display_mode(mode, &sig_cfg.mode);
> +
> +	ret = ipu_dc_init_sync(ipu_crtc->dc, ipu_crtc->di,
> +			       (mode->flags & DRM_MODE_FLAG_INTERLACE) ?
> +			       true : false,

The interlaced parameter to ipu_dc_init_sync is of type bool, so the
()?true:false is superfluous.

[...]
> @@ -433,10 +437,11 @@ static void ipu_di_config_clock(struct ipu_di *di,
>  			unsigned long in_rate;
>  			unsigned div;
>  
> -			clk_set_rate(clk, sig->pixelclock);
> +			clk_set_rate(clk, sig->mode.pixelclock);
>  
>  			in_rate = clk_get_rate(clk);
> -			div = (in_rate + sig->pixelclock / 2) / sig->pixelclock;
> +			div = (in_rate + sig->mode.pixelclock / 2) /
> +				sig->mode.pixelclock;

Let's use this opportunity to switch to DIV_ROUND_CLOSEST here ...

> @@ -473,10 +479,11 @@ static void ipu_di_config_clock(struct ipu_di *di,
>  
>  			clk = di->clk_di;
>  
> -			clk_set_rate(clk, sig->pixelclock);
> +			clk_set_rate(clk, sig->mode.pixelclock);
>  
>  			in_rate = clk_get_rate(clk);
> -			div = (in_rate + sig->pixelclock / 2) / sig->pixelclock;
> +			div = (in_rate + sig->mode.pixelclock / 2) /
> +				sig->mode.pixelclock;

... and here.

regards
Philipp



More information about the dri-devel mailing list