[Intel-gfx] [PATCH 09/12] drm/i915: Define transcoder timing register bitmasks

Jani Nikula jani.nikula at linux.intel.com
Tue Feb 14 10:32:49 UTC 2023


On Tue, 14 Feb 2023, Ville Syrjala <ville.syrjala at linux.intel.com> wrote:
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
> Define the contents of the transcoder timing registers using
> REG_GENMASK() & co. For ease of maintenance let's just define
> the bitmasks with the full 16bit width (also used by the
> current hand rolled stuff) even though not all bits are actually
> used. None of the unsued bits have ever contained anything.
>
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> ---
>  drivers/gpu/drm/i915/display/icl_dsi.c       | 10 +--
>  drivers/gpu/drm/i915/display/intel_crt.c     | 13 ++--
>  drivers/gpu/drm/i915/display/intel_display.c | 64 ++++++++++++--------
>  drivers/gpu/drm/i915/i915_reg.h              | 24 ++++++++
>  4 files changed, 75 insertions(+), 36 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/icl_dsi.c b/drivers/gpu/drm/i915/display/icl_dsi.c
> index 07897d6f9c53..def3aff4d717 100644
> --- a/drivers/gpu/drm/i915/display/icl_dsi.c
> +++ b/drivers/gpu/drm/i915/display/icl_dsi.c
> @@ -888,7 +888,7 @@ gen11_dsi_set_transcoder_timings(struct intel_encoder *encoder,
>  	for_each_dsi_port(port, intel_dsi->ports) {
>  		dsi_trans = dsi_port_to_transcoder(port);
>  		intel_de_write(dev_priv, TRANS_HTOTAL(dsi_trans),
> -			       (hactive - 1) | ((htotal - 1) << 16));
> +			       HACTIVE(hactive - 1) | HTOTAL(htotal - 1));
>  	}
>  
>  	/* TRANS_HSYNC register to be programmed only for video mode */
> @@ -911,7 +911,7 @@ gen11_dsi_set_transcoder_timings(struct intel_encoder *encoder,
>  		for_each_dsi_port(port, intel_dsi->ports) {
>  			dsi_trans = dsi_port_to_transcoder(port);
>  			intel_de_write(dev_priv, TRANS_HSYNC(dsi_trans),
> -				       (hsync_start - 1) | ((hsync_end - 1) << 16));
> +				       HSYNC_START(hsync_start - 1) | HSYNC_END(hsync_end - 1));
>  		}
>  	}
>  
> @@ -925,7 +925,7 @@ gen11_dsi_set_transcoder_timings(struct intel_encoder *encoder,
>  		 * For interlace mode: program required pixel minus 2
>  		 */
>  		intel_de_write(dev_priv, TRANS_VTOTAL(dsi_trans),
> -			       (vactive - 1) | ((vtotal - 1) << 16));
> +			       VACTIVE(vactive - 1) | VTOTAL(vtotal - 1));
>  	}
>  
>  	if (vsync_end < vsync_start || vsync_end > vtotal)
> @@ -939,7 +939,7 @@ gen11_dsi_set_transcoder_timings(struct intel_encoder *encoder,
>  		for_each_dsi_port(port, intel_dsi->ports) {
>  			dsi_trans = dsi_port_to_transcoder(port);
>  			intel_de_write(dev_priv, TRANS_VSYNC(dsi_trans),
> -				       (vsync_start - 1) | ((vsync_end - 1) << 16));
> +				       VSYNC_START(vsync_start - 1) | VSYNC_END(vsync_end - 1));
>  		}
>  	}
>  
> @@ -962,7 +962,7 @@ gen11_dsi_set_transcoder_timings(struct intel_encoder *encoder,
>  		for_each_dsi_port(port, intel_dsi->ports) {
>  			dsi_trans = dsi_port_to_transcoder(port);
>  			intel_de_write(dev_priv, TRANS_VBLANK(dsi_trans),
> -				       (vactive - 1) | ((vtotal - 1) << 16));
> +				       VBLANK_START(vactive - 1) | VBLANK_END(vtotal - 1));
>  		}
>  	}
>  }
> diff --git a/drivers/gpu/drm/i915/display/intel_crt.c b/drivers/gpu/drm/i915/display/intel_crt.c
> index ef0c7f5b0ad6..8f2ebead0826 100644
> --- a/drivers/gpu/drm/i915/display/intel_crt.c
> +++ b/drivers/gpu/drm/i915/display/intel_crt.c
> @@ -698,11 +698,11 @@ intel_crt_load_detect(struct intel_crt *crt, enum pipe pipe)
>  	save_vtotal = intel_de_read(dev_priv, TRANS_VTOTAL(cpu_transcoder));
>  	vblank = intel_de_read(dev_priv, TRANS_VBLANK(cpu_transcoder));
>  
> -	vtotal = ((save_vtotal >> 16) & 0xfff) + 1;
> -	vactive = (save_vtotal & 0x7ff) + 1;
> +	vtotal = REG_FIELD_GET(VTOTAL_MASK, save_vtotal) + 1;
> +	vactive = REG_FIELD_GET(VACTIVE_MASK, save_vtotal) + 1;
>  
> -	vblank_start = (vblank & 0xfff) + 1;
> -	vblank_end = ((vblank >> 16) & 0xfff) + 1;
> +	vblank_start = REG_FIELD_GET(VBLANK_START_MASK, vblank) + 1;
> +	vblank_end = REG_FIELD_GET(VBLANK_END_MASK, vblank) + 1;

I forget how these are defined in bspec and if the field size grows
towards later platforms... but this widens the masks. I'm guess it'll
probably read as zero anyway, but in theory that's a functional change.

BR,
Jani.

>  
>  	/* Set the border color to purple. */
>  	intel_de_write(dev_priv, BCLRPAT(cpu_transcoder), 0x500050);
> @@ -732,11 +732,12 @@ intel_crt_load_detect(struct intel_crt *crt, enum pipe pipe)
>  		*/
>  		if (vblank_start <= vactive && vblank_end >= vtotal) {
>  			u32 vsync = intel_de_read(dev_priv, TRANS_VSYNC(cpu_transcoder));
> -			u32 vsync_start = (vsync & 0xffff) + 1;
> +			u32 vsync_start = REG_FIELD_GET(VSYNC_START_MASK, vsync) + 1;
>  
>  			vblank_start = vsync_start;
>  			intel_de_write(dev_priv, TRANS_VBLANK(cpu_transcoder),
> -				       (vblank_start - 1) | ((vblank_end - 1) << 16));
> +				       VBLANK_START(vblank_start - 1) |
> +				       VBLANK_END(vblank_end - 1));
>  			restore_vblank = true;
>  		}
>  		/* sample in the vertical border, selecting the larger one */
> diff --git a/drivers/gpu/drm/i915/display/intel_display.c b/drivers/gpu/drm/i915/display/intel_display.c
> index ac021ca88e3c..1d92a789baab 100644
> --- a/drivers/gpu/drm/i915/display/intel_display.c
> +++ b/drivers/gpu/drm/i915/display/intel_display.c
> @@ -2848,18 +2848,24 @@ static void intel_set_transcoder_timings(const struct intel_crtc_state *crtc_sta
>  			       vsyncshift);
>  
>  	intel_de_write(dev_priv, TRANS_HTOTAL(cpu_transcoder),
> -		       (adjusted_mode->crtc_hdisplay - 1) | ((adjusted_mode->crtc_htotal - 1) << 16));
> +		       HACTIVE(adjusted_mode->crtc_hdisplay - 1) |
> +		       HTOTAL(adjusted_mode->crtc_htotal - 1));
>  	intel_de_write(dev_priv, TRANS_HBLANK(cpu_transcoder),
> -		       (adjusted_mode->crtc_hblank_start - 1) | ((adjusted_mode->crtc_hblank_end - 1) << 16));
> +		       HBLANK_START(adjusted_mode->crtc_hblank_start - 1) |
> +		       HBLANK_END(adjusted_mode->crtc_hblank_end - 1));
>  	intel_de_write(dev_priv, TRANS_HSYNC(cpu_transcoder),
> -		       (adjusted_mode->crtc_hsync_start - 1) | ((adjusted_mode->crtc_hsync_end - 1) << 16));
> +		       HSYNC_START(adjusted_mode->crtc_hsync_start - 1) |
> +		       HSYNC_END(adjusted_mode->crtc_hsync_end - 1));
>  
>  	intel_de_write(dev_priv, TRANS_VTOTAL(cpu_transcoder),
> -		       (adjusted_mode->crtc_vdisplay - 1) | ((crtc_vtotal - 1) << 16));
> +		       VACTIVE(adjusted_mode->crtc_vdisplay - 1) |
> +		       VTOTAL(crtc_vtotal - 1));
>  	intel_de_write(dev_priv, TRANS_VBLANK(cpu_transcoder),
> -		       (adjusted_mode->crtc_vblank_start - 1) | ((crtc_vblank_end - 1) << 16));
> +		       VBLANK_START(adjusted_mode->crtc_vblank_start - 1) |
> +		       VBLANK_END(crtc_vblank_end - 1));
>  	intel_de_write(dev_priv, TRANS_VSYNC(cpu_transcoder),
> -		       (adjusted_mode->crtc_vsync_start - 1) | ((adjusted_mode->crtc_vsync_end - 1) << 16));
> +		       VSYNC_START(adjusted_mode->crtc_vsync_start - 1) |
> +		       VSYNC_END(adjusted_mode->crtc_vsync_end - 1));
>  
>  	/* Workaround: when the EDP input selection is B, the VTOTAL_B must be
>  	 * programmed with the VTOTAL_EDP value. Same for VTOTAL_C. This is
> @@ -2912,30 +2918,31 @@ static void intel_get_transcoder_timings(struct intel_crtc *crtc,
>  	u32 tmp;
>  
>  	tmp = intel_de_read(dev_priv, TRANS_HTOTAL(cpu_transcoder));
> -	adjusted_mode->crtc_hdisplay = (tmp & 0xffff) + 1;
> -	adjusted_mode->crtc_htotal = ((tmp >> 16) & 0xffff) + 1;
> +	adjusted_mode->crtc_hdisplay = REG_FIELD_GET(HACTIVE_MASK, tmp) + 1;
> +	adjusted_mode->crtc_htotal = REG_FIELD_GET(HTOTAL_MASK, tmp) + 1;
>  
>  	if (!transcoder_is_dsi(cpu_transcoder)) {
>  		tmp = intel_de_read(dev_priv, TRANS_HBLANK(cpu_transcoder));
> -		adjusted_mode->crtc_hblank_start = (tmp & 0xffff) + 1;
> -		adjusted_mode->crtc_hblank_end = ((tmp >> 16) & 0xffff) + 1;
> +		adjusted_mode->crtc_hblank_start = REG_FIELD_GET(HBLANK_START_MASK, tmp) + 1;
> +		adjusted_mode->crtc_hblank_end = REG_FIELD_GET(HBLANK_END_MASK, tmp) + 1;
>  	}
> +
>  	tmp = intel_de_read(dev_priv, TRANS_HSYNC(cpu_transcoder));
> -	adjusted_mode->crtc_hsync_start = (tmp & 0xffff) + 1;
> -	adjusted_mode->crtc_hsync_end = ((tmp >> 16) & 0xffff) + 1;
> +	adjusted_mode->crtc_hsync_start = REG_FIELD_GET(HSYNC_START_MASK, tmp) + 1;
> +	adjusted_mode->crtc_hsync_end = REG_FIELD_GET(HSYNC_END_MASK, tmp) + 1;
>  
>  	tmp = intel_de_read(dev_priv, TRANS_VTOTAL(cpu_transcoder));
> -	adjusted_mode->crtc_vdisplay = (tmp & 0xffff) + 1;
> -	adjusted_mode->crtc_vtotal = ((tmp >> 16) & 0xffff) + 1;
> +	adjusted_mode->crtc_vdisplay = REG_FIELD_GET(VACTIVE_MASK, tmp) + 1;
> +	adjusted_mode->crtc_vtotal = REG_FIELD_GET(VTOTAL_MASK, tmp) + 1;
>  
>  	if (!transcoder_is_dsi(cpu_transcoder)) {
>  		tmp = intel_de_read(dev_priv, TRANS_VBLANK(cpu_transcoder));
> -		adjusted_mode->crtc_vblank_start = (tmp & 0xffff) + 1;
> -		adjusted_mode->crtc_vblank_end = ((tmp >> 16) & 0xffff) + 1;
> +		adjusted_mode->crtc_vblank_start = REG_FIELD_GET(VBLANK_START_MASK, tmp) + 1;
> +		adjusted_mode->crtc_vblank_end = REG_FIELD_GET(VBLANK_END_MASK, tmp) + 1;
>  	}
>  	tmp = intel_de_read(dev_priv, TRANS_VSYNC(cpu_transcoder));
> -	adjusted_mode->crtc_vsync_start = (tmp & 0xffff) + 1;
> -	adjusted_mode->crtc_vsync_end = ((tmp >> 16) & 0xffff) + 1;
> +	adjusted_mode->crtc_vsync_start = REG_FIELD_GET(VSYNC_START_MASK, tmp) + 1;
> +	adjusted_mode->crtc_vsync_end = REG_FIELD_GET(VSYNC_END_MASK, tmp) + 1;
>  
>  	if (intel_pipe_is_interlaced(pipe_config)) {
>  		adjusted_mode->flags |= DRM_MODE_FLAG_INTERLACE;
> @@ -8816,13 +8823,20 @@ void i830_enable_pipe(struct drm_i915_private *dev_priv, enum pipe pipe)
>  		PLL_REF_INPUT_DREFCLK |
>  		DPLL_VCO_ENABLE;
>  
> -	intel_de_write(dev_priv, TRANS_HTOTAL(cpu_transcoder), (640 - 1) | ((800 - 1) << 16));
> -	intel_de_write(dev_priv, TRANS_HBLANK(cpu_transcoder), (640 - 1) | ((800 - 1) << 16));
> -	intel_de_write(dev_priv, TRANS_HSYNC(cpu_transcoder), (656 - 1) | ((752 - 1) << 16));
> -	intel_de_write(dev_priv, TRANS_VTOTAL(cpu_transcoder), (480 - 1) | ((525 - 1) << 16));
> -	intel_de_write(dev_priv, TRANS_VBLANK(cpu_transcoder), (480 - 1) | ((525 - 1) << 16));
> -	intel_de_write(dev_priv, TRANS_VSYNC(cpu_transcoder), (490 - 1) | ((492 - 1) << 16));
> -	intel_de_write(dev_priv, PIPESRC(pipe), ((640 - 1) << 16) | (480 - 1));
> +	intel_de_write(dev_priv, TRANS_HTOTAL(cpu_transcoder),
> +		       HACTIVE(640 - 1) | HTOTAL(800 - 1));
> +	intel_de_write(dev_priv, TRANS_HBLANK(cpu_transcoder),
> +		       HBLANK_START(640 - 1) | HBLANK_END(800 - 1));
> +	intel_de_write(dev_priv, TRANS_HSYNC(cpu_transcoder),
> +		       HSYNC_START(656 - 1) | HSYNC_END(752 - 1));
> +	intel_de_write(dev_priv, TRANS_VTOTAL(cpu_transcoder),
> +		       VACTIVE(480 - 1) | VTOTAL(525 - 1));
> +	intel_de_write(dev_priv, TRANS_VBLANK(cpu_transcoder),
> +		       VBLANK_START(480 - 1) | VBLANK_END(525 - 1));
> +	intel_de_write(dev_priv, TRANS_VSYNC(cpu_transcoder),
> +		       VSYNC_START(490 - 1) | VSYNC_END(492 - 1));
> +	intel_de_write(dev_priv, PIPESRC(pipe),
> +		       PIPESRC_WIDTH(640 - 1) | PIPESRC_HEIGHT(480 - 1));
>  
>  	intel_de_write(dev_priv, FP0(pipe), fp);
>  	intel_de_write(dev_priv, FP1(pipe), fp);
> diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
> index 23886356af35..c5e073af983a 100644
> --- a/drivers/gpu/drm/i915/i915_reg.h
> +++ b/drivers/gpu/drm/i915/i915_reg.h
> @@ -1913,11 +1913,35 @@
>  
>  /* Pipe/transcoder A timing regs */
>  #define _TRANS_HTOTAL_A		0x60000
> +#define   HTOTAL_MASK			REG_GENMASK(31, 16)
> +#define   HTOTAL(htotal)		REG_FIELD_PREP(HTOTAL_MASK, (htotal))
> +#define   HACTIVE_MASK			REG_GENMASK(15, 0)
> +#define   HACTIVE(hdisplay)		REG_FIELD_PREP(HACTIVE_MASK, (hdisplay))
>  #define _TRANS_HBLANK_A		0x60004
> +#define   HBLANK_END_MASK		REG_GENMASK(31, 16)
> +#define   HBLANK_END(hblank_end)	REG_FIELD_PREP(HBLANK_END_MASK, (hblank_end))
> +#define   HBLANK_START_MASK		REG_GENMASK(15, 0)
> +#define   HBLANK_START(hblank_start)	REG_FIELD_PREP(HBLANK_START_MASK, (hblank_start))
>  #define _TRANS_HSYNC_A		0x60008
> +#define   HSYNC_END_MASK		REG_GENMASK(31, 16)
> +#define   HSYNC_END(hsync_end)		REG_FIELD_PREP(HSYNC_END_MASK, (hsync_end))
> +#define   HSYNC_START_MASK		REG_GENMASK(15, 0)
> +#define   HSYNC_START(hsync_start)	REG_FIELD_PREP(HSYNC_START_MASK, (hsync_start))
>  #define _TRANS_VTOTAL_A		0x6000c
> +#define   VTOTAL_MASK			REG_GENMASK(31, 16)
> +#define   VTOTAL(vtotal)		REG_FIELD_PREP(VTOTAL_MASK, (vtotal))
> +#define   VACTIVE_MASK			REG_GENMASK(15, 0)
> +#define   VACTIVE(vdisplay)		REG_FIELD_PREP(VACTIVE_MASK, (vdisplay))
>  #define _TRANS_VBLANK_A		0x60010
> +#define   VBLANK_END_MASK		REG_GENMASK(31, 16)
> +#define   VBLANK_END(vblank_end)	REG_FIELD_PREP(VBLANK_END_MASK, (vblank_end))
> +#define   VBLANK_START_MASK		REG_GENMASK(15, 0)
> +#define   VBLANK_START(vblank_start)	REG_FIELD_PREP(VBLANK_START_MASK, (vblank_start))
>  #define _TRANS_VSYNC_A		0x60014
> +#define   VSYNC_END_MASK		REG_GENMASK(31, 16)
> +#define   VSYNC_END(vsync_end)		REG_FIELD_PREP(VSYNC_END_MASK, (vsync_end))
> +#define   VSYNC_START_MASK		REG_GENMASK(15, 0)
> +#define   VSYNC_START(vsync_start)	REG_FIELD_PREP(VSYNC_START_MASK, (vsync_start))
>  #define _TRANS_EXITLINE_A	0x60018
>  #define _PIPEASRC		0x6001c
>  #define   PIPESRC_WIDTH_MASK	REG_GENMASK(31, 16)

-- 
Jani Nikula, Intel Open Source Graphics Center


More information about the Intel-gfx mailing list