[igt-dev] [PATCH i-g-t v3 2/4] lib/DG2: create flat ccs framebuffers with 4-tile

Kahola, Mika mika.kahola at intel.com
Fri May 13 08:51:00 UTC 2022


> -----Original Message-----
> From: B, Jeevan <jeevan.b at intel.com>
> Sent: Thursday, May 12, 2022 2:01 PM
> To: igt-dev at lists.freedesktop.org
> Cc: Kahola, Mika <mika.kahola at intel.com>; Deak, Imre
> <imre.deak at intel.com>; Latvala, Petri <petri.latvala at intel.com>; Heikkila,
> Juha-pekka <juha-pekka.heikkila at intel.com>; B, Jeevan <jeevan.b at intel.com>
> Subject: [PATCH i-g-t v3 2/4] lib/DG2: create flat ccs framebuffers with 4-tile
> 
> From: Juha-Pekka Heikkilä <juha-pekka.heikkila at intel.com>
> 
> Add support for DG2 flat ccs framebuffers with tile-4.
> 
> Signed-off-by: Juha-Pekka Heikkilä <juha-pekka.heikkila at intel.com>
> Signed-off-by: Jeevan B <jeevan.b at intel.com>

Reviewed-by: Mika Kahola <mika.kahola at intel.com>

> ---
>  lib/gen9_render.h       |  38 +++++++++---
>  lib/igt_fb.c            |  51 ++++++++++++----
>  lib/intel_aux_pgtable.c |   6 +-
>  lib/intel_batchbuffer.c |   2 +-
>  lib/intel_bufops.c      | 118 ++++++++++++++++++++++++++++++++-----
>  lib/intel_chipset.h     |   3 +-
>  lib/rendercopy_gen9.c   | 125 +++++++++++++++++++++++++++-------------
>  lib/veboxcopy_gen12.c   | 109 ++++++++++++++++++++++++++---------
>  8 files changed, 347 insertions(+), 105 deletions(-)
> 
> diff --git a/lib/gen9_render.h b/lib/gen9_render.h index 06d9718c..af3a2b3a
> 100644
> --- a/lib/gen9_render.h
> +++ b/lib/gen9_render.h
> @@ -59,9 +59,15 @@ struct gen9_surface_state {
>  		uint32_t depth:11;
>  	} ss3;
> 
> -	struct {
> -		uint32_t minimum_array_element:27;
> -		uint32_t pad0:5;
> +	union {
> +		struct {
> +			uint32_t minimum_array_element:27;
> +			uint32_t pad0:5;
> +		} skl;
> +		struct {
> +			uint32_t decompress_in_l3:1;
> +			uint32_t pad0:31;
> +		} dg2;
>  	} ss4;
> 
>  	struct {
> @@ -116,6 +122,15 @@ struct gen9_surface_state {
>  			uint32_t media_compression:1;
>  			uint32_t pad2:1;
>  		} tgl;
> +
> +		struct {
> +			uint32_t pad0:14;
> +			uint32_t
> disable_support_for_multi_gpu_partial_writes:1;
> +			uint32_t disable_support_for_multi_gpu_atomics:1;
> +			uint32_t pad1:14;
> +			uint32_t memory_compression_enable:1;
> +			uint32_t memory_compression_type:1;
> +		} dg2;
>  	} ss7;
> 
>  	struct {
> @@ -138,15 +153,22 @@ struct gen9_surface_state {
>  		uint32_t aux_base_addr_hi;
>  	} ss11;
> 
> -	/* register can be used for either
> -	 * clear value or depth clear value
> -	 */
>  	struct {
> -		uint32_t clear_address;
> +		/*
> +		 * compression_format is used only dg2 onward.
> +		 * prior to dg2 full ss12 is used for the address
> +		 * but due to alignments bits 0..6 will be zero
> +		 * and asserted in code to be so
> +		 */
> +		uint32_t compression_format:5;
> +		uint32_t pad0:1;
> +		uint32_t clear_address:26;
>  	} ss12;
> 
>  	struct {
> -		uint32_t clear_address_hi;
> +		uint32_t clear_address_hi:16;
> +		uint32_t pad0:16;
> +
>  	} ss13;
> 
>  	struct {
> diff --git a/lib/igt_fb.c b/lib/igt_fb.c index eafbe7fd..f3cb711e 100644
> --- a/lib/igt_fb.c
> +++ b/lib/igt_fb.c
> @@ -457,6 +457,9 @@ void igt_get_fb_tile_size(int fd, uint64_t modifier, int
> fb_bpp,
>  	case I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC:
>  	case I915_FORMAT_MOD_Y_TILED_GEN12_MC_CCS:
>  	case I915_FORMAT_MOD_4_TILED:
> +	case I915_FORMAT_MOD_4_TILED_DG2_RC_CCS:
> +	case I915_FORMAT_MOD_4_TILED_DG2_MC_CCS:
> +	case I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC:
>  		igt_require_intel(fd);
>  		if (intel_display_ver(intel_get_drm_devid(fd)) == 2) {
>  			*width_ret = 128;
> @@ -565,14 +568,17 @@ void igt_get_fb_tile_size(int fd, uint64_t modifier, int
> fb_bpp,
> 
>  static bool is_gen12_mc_ccs_modifier(uint64_t modifier)  {
> -	return modifier == I915_FORMAT_MOD_Y_TILED_GEN12_MC_CCS;
> +	return modifier == I915_FORMAT_MOD_Y_TILED_GEN12_MC_CCS ||
> +		modifier == I915_FORMAT_MOD_4_TILED_DG2_MC_CCS;
>  }
> 
>  static bool is_gen12_ccs_modifier(uint64_t modifier)  {
>  	return is_gen12_mc_ccs_modifier(modifier) ||
>  		modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS ||
> -		modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC;
> +		modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC
> ||
> +		modifier == I915_FORMAT_MOD_4_TILED_DG2_RC_CCS ||
> +		modifier == I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC;
>  }
> 
>  static bool is_ccs_modifier(uint64_t modifier) @@ -584,7 +590,7 @@ static
> bool is_ccs_modifier(uint64_t modifier)
> 
>  static bool is_ccs_plane(const struct igt_fb *fb, int plane)  {
> -	if (!is_ccs_modifier(fb->modifier))
> +	if (!is_ccs_modifier(fb->modifier) ||
> +HAS_FLATCCS(intel_get_drm_devid(fb->fd)))
>  		return false;
> 
>  	return plane >= fb->num_planes / 2;
> @@ -602,8 +608,15 @@ static bool is_gen12_ccs_plane(const struct igt_fb *fb,
> int plane)
> 
>  static bool is_gen12_ccs_cc_plane(const struct igt_fb *fb, int plane)  {
> -	return fb->modifier ==
> I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC &&
> -	       plane == 2;
> +	if (fb->modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC
> &&
> +	    plane == 2)
> +		return true;
> +
> +	if (fb->modifier == I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC &&
> +	    plane == 1)
> +		return true;
> +
> +	return false;
>  }
> 
>  bool igt_fb_is_gen12_ccs_cc_plane(const struct igt_fb *fb, int plane) @@ -
> 686,10 +699,11 @@ static int fb_num_planes(const struct igt_fb *fb)  {
>  	int num_planes = lookup_drm_format(fb->drm_format)->num_planes;
> 
> -	if (is_ccs_modifier(fb->modifier))
> +	if (is_ccs_modifier(fb->modifier) &&
> +!HAS_FLATCCS(intel_get_drm_devid(fb->fd)))
>  		num_planes *= 2;
> 
> -	if (fb->modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC)
> +	if (fb->modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC
> ||
> +	    fb->modifier == I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC)
>  		num_planes++;
> 
>  	return num_planes;
> @@ -763,7 +777,7 @@ static uint32_t calc_plane_stride(struct igt_fb *fb, int
> plane)
>  		return ALIGN(min_stride, tile_width);
>  	} else if (is_gen12_ccs_cc_plane(fb, plane)) {
>  		/* clear color always fixed to 64 bytes */
> -		return 64;
> +		return HAS_FLATCCS(intel_get_drm_devid(fb->fd)) ? 512 : 64;
>  	} else if (is_gen12_ccs_plane(fb, plane)) {
>  		/*
>  		 * The CCS surface stride is
> @@ -966,6 +980,9 @@ uint64_t igt_fb_mod_to_tiling(uint64_t modifier)
>  	case I915_FORMAT_MOD_Y_TILED_GEN12_MC_CCS:
>  		return I915_TILING_Y;
>  	case I915_FORMAT_MOD_4_TILED:
> +	case I915_FORMAT_MOD_4_TILED_DG2_RC_CCS:
> +	case I915_FORMAT_MOD_4_TILED_DG2_MC_CCS:
> +	case I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC:
>  		return I915_TILING_4;
>  	case I915_FORMAT_MOD_Yf_TILED:
>  	case I915_FORMAT_MOD_Yf_TILED_CCS:
> @@ -2504,9 +2521,10 @@ igt_fb_create_intel_buf(int fd, struct buf_ops *bops,
>  	if (is_ccs_modifier(fb->modifier)) {
>  		igt_assert_eq(fb->strides[0] & 127, 0);
> 
> -		if (is_gen12_ccs_modifier(fb->modifier))
> -			igt_assert_eq(fb->strides[1] & 63, 0);
> -		else
> +		if (is_gen12_ccs_modifier(fb->modifier)) {
> +			if (!HAS_FLATCCS(intel_get_drm_devid(fb->fd)))
> +				igt_assert_eq(fb->strides[1] & 63, 0);
> +		} else
>  			igt_assert_eq(fb->strides[1] & 127, 0);
> 
>  		if (is_gen12_mc_ccs_modifier(fb->modifier))
> @@ -2539,7 +2557,7 @@ igt_fb_create_intel_buf(int fd, struct buf_ops *bops,
>  		buf->yuv_semiplanar_bpp = yuv_semiplanar_bpp(fb-
> >drm_format);
> 
>  	if (is_ccs_modifier(fb->modifier)) {
> -		num_surfaces = fb->num_planes / 2;
> +		num_surfaces = fb->num_planes /
> +(HAS_FLATCCS(intel_get_drm_devid(fb->fd)) ? 1 : 2);
>  		for (i = 0; i < num_surfaces; i++)
>  			init_buf_ccs(buf, i,
>  				     fb->offsets[num_surfaces + i], @@ -2560,6
> +2578,9 @@ igt_fb_create_intel_buf(int fd, struct buf_ops *bops,
>  	if (fb->modifier == I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC)
>  		buf->cc.offset = fb->offsets[2];
> 
> +	if (fb->modifier == I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC)
> +		buf->cc.offset = fb->offsets[1];
> +
>  	return buf;
>  }
> 
> @@ -4570,6 +4591,12 @@ const char *igt_fb_modifier_name(uint64_t
> modifier)
>  		return "Y-MC_CCS";
>  	case I915_FORMAT_MOD_4_TILED:
>  		return "4";
> +	case I915_FORMAT_MOD_4_TILED_DG2_RC_CCS:
> +		return "4-RC_CCS";
> +	case I915_FORMAT_MOD_4_TILED_DG2_MC_CCS:
> +		return "4-MC_CCS";
> +	case I915_FORMAT_MOD_4_TILED_DG2_RC_CCS_CC:
> +		return "4-RC_CCS-CC";
>  	default:
>  		return "?";
>  	}
> diff --git a/lib/intel_aux_pgtable.c b/lib/intel_aux_pgtable.c index
> f5796fdf..e31a6c34 100644
> --- a/lib/intel_aux_pgtable.c
> +++ b/lib/intel_aux_pgtable.c
> @@ -263,7 +263,8 @@ static uint64_t pgt_get_l1_flags(const struct intel_buf
> *buf, int surface_idx)
>  	} entry = {
>  		.e = {
>  			.valid = 1,
> -			.tile_mode = buf->tiling == I915_TILING_Y ? 1 : 0,
> +			.tile_mode = buf->tiling == I915_TILING_Y ? 1 :
> +				(buf->tiling == I915_TILING_4 ? 2 : 0),
>  		}
>  	};
> 
> @@ -274,7 +275,8 @@ static uint64_t pgt_get_l1_flags(const struct intel_buf
> *buf, int surface_idx)
>  	 */
>  	igt_assert(buf->tiling == I915_TILING_Y ||
>  		   buf->tiling == I915_TILING_Yf ||
> -		   buf->tiling == I915_TILING_Ys);
> +		   buf->tiling == I915_TILING_Ys ||
> +		   buf->tiling == I915_TILING_4);
> 
>  	entry.e.ycr = surface_idx > 0;
> 
> diff --git a/lib/intel_batchbuffer.c b/lib/intel_batchbuffer.c index
> ebf3c598..81d2e140 100644
> --- a/lib/intel_batchbuffer.c
> +++ b/lib/intel_batchbuffer.c
> @@ -1146,7 +1146,7 @@ igt_render_copyfunc_t igt_get_render_copyfunc(int
> devid)
>  		copy = gen9_render_copyfunc;
>  	else if (IS_GEN11(devid))
>  		copy = gen11_render_copyfunc;
> -	else if (IS_DG2(devid))
> +	else if (HAS_4TILE(devid))
>  		copy = gen12p71_render_copyfunc;
>  	else if (IS_GEN12(devid))
>  		copy = gen12_render_copyfunc;
> diff --git a/lib/intel_bufops.c b/lib/intel_bufops.c index f13063fa..05c0b0d4
> 100644
> --- a/lib/intel_bufops.c
> +++ b/lib/intel_bufops.c
> @@ -89,6 +89,7 @@
>  #define TILE_Y      TILE_DEF(I915_TILING_Y)
>  #define TILE_Yf     TILE_DEF(I915_TILING_Yf)
>  #define TILE_Ys     TILE_DEF(I915_TILING_Ys)
> +#define TILE_4      TILE_DEF(I915_TILING_4)
> 
>  #define CCS_OFFSET(buf) (buf->ccs[0].offset)  #define CCS_SIZE(gen, buf) \ @@
> -105,16 +106,19 @@ struct buf_ops {
>  	uint32_t supported_hw_tiles;
>  	uint32_t swizzle_x;
>  	uint32_t swizzle_y;
> +	uint32_t swizzle_tile4;
>  	bo_copy linear_to;
>  	bo_copy linear_to_x;
>  	bo_copy linear_to_y;
>  	bo_copy linear_to_yf;
>  	bo_copy linear_to_ys;
> +	bo_copy linear_to_tile4;
>  	bo_copy to_linear;
>  	bo_copy x_to_linear;
>  	bo_copy y_to_linear;
>  	bo_copy yf_to_linear;
>  	bo_copy ys_to_linear;
> +	bo_copy tile4_to_linear;
>  };
> 
>  static const char *tiling_str(uint32_t tiling) @@ -125,6 +129,7 @@ static const
> char *tiling_str(uint32_t tiling)
>  	case I915_TILING_Y:    return "Y";
>  	case I915_TILING_Yf:   return "Yf";
>  	case I915_TILING_Ys:   return "Ys";
> +	case I915_TILING_4:    return "4";
>  	default:               return "UNKNOWN";
>  	}
>  }
> @@ -222,7 +227,8 @@ static void set_hw_tiled(struct buf_ops *bops, struct
> intel_buf *buf)  {
>  	uint32_t ret_tiling, ret_swizzle;
> 
> -	if (buf->tiling != I915_TILING_X && buf->tiling != I915_TILING_Y)
> +	if (buf->tiling != I915_TILING_X && buf->tiling != I915_TILING_Y &&
> +	    buf->tiling != I915_TILING_4)
>  		return;
> 
>  	if (!buf_ops_has_hw_fence(bops, buf->tiling)) { @@ -320,6 +326,50
> @@ static void *y_ptr(void *ptr,
>  	return ptr + pos;
>  }
> 
> +/*
> + * (x,y) to memory location in tiled-4 surface
> + *
> + * coverted those divisions and multiplications to shifts and masks
> + * in hope this wouldn't be so slow.
> + */
> +static void *tile4_ptr(void *ptr,
> +			unsigned int x, unsigned int y,
> +			unsigned int stride, unsigned int cpp) {
> +	const int tile_width = 128;
> +	const int tile_height = 32;
> +	const int subtile_size = 64;
> +	const int owords = 16;
> +	int base, _x, _y, subtile, tile_x, tile_y;
> +	int x_loc = x << __builtin_ctz(cpp);
> +	int pos;
> +
> +	/* Pixel in tile via masks */
> +	tile_x = x_loc & (tile_width - 1);
> +	tile_y = y & (tile_height - 1);
> +
> +	/* subtile in 4k tile */
> +	_x = tile_x >> __builtin_ctz(owords);
> +	_y = tile_y >> 2;
> +
> +	/* tile-4 swizzle */
> +	subtile = ((_y >> 1) << 4) + ((_y & 1) << 2) + (_x & 3) + ((_x & 4) <<
> +1);
> +
> +	/* memory location */
> +	base = (y >> __builtin_ctz(tile_height)) *
> +		(stride << __builtin_ctz(tile_height)) +
> +		(((x_loc >> __builtin_ctz(tile_width)) << __builtin_ctz(4096)));
> +
> +	pos = base + (subtile << __builtin_ctz(subtile_size)) +
> +		((tile_y & 3) << __builtin_ctz(owords)) +
> +		(tile_x & (owords - 1));
> +	igt_assert((pos & (cpp - 1)) == 0);
> +	pos = pos >> __builtin_ctz(cpp);
> +
> +	return ptr + pos;
> +}
> +
> +
>  static void *yf_ptr(void *ptr,
>  		    unsigned int x, unsigned int y,
>  		    unsigned int stride, unsigned int cpp) @@ -365,6 +415,8 @@
> static tile_fn __get_tile_fn_ptr(int tiling)
>  	case I915_TILING_Yf:
>  		fn = yf_ptr;
>  		break;
> +	case I915_TILING_4:
> +		fn = tile4_ptr;
>  	case I915_TILING_Ys:
>  		/* To be implemented */
>  		break;
> @@ -391,7 +443,7 @@ static void __copy_ccs(struct buf_ops *bops, struct
> intel_buf *buf,
>  	void *map;
>  	int gen;
> 
> -	if (!buf->compression)
> +	if (!buf->compression || HAS_FLATCCS(intel_get_drm_devid(bops->fd)))
>  		return;
> 
>  	gen = bops->intel_gen;
> @@ -551,6 +603,13 @@ static void copy_linear_to_ys(struct buf_ops *bops,
> struct intel_buf *buf,
>  	__copy_linear_to(bops->fd, buf, linear, I915_TILING_Ys, 0);  }
> 
> +static void copy_linear_to_tile4(struct buf_ops *bops, struct intel_buf *buf,
> +				 uint32_t *linear)
> +{
> +	DEBUGFN();
> +	__copy_linear_to(bops->fd, buf, linear, I915_TILING_4,
> +bops->swizzle_tile4); }
> +
>  static void __copy_to_linear(int fd, struct intel_buf *buf,
>  			     uint32_t *linear, int tiling, uint32_t swizzle)  { @@ -
> 601,6 +660,13 @@ static void copy_ys_to_linear(struct buf_ops *bops, struct
> intel_buf *buf,
>  	__copy_to_linear(bops->fd, buf, linear, I915_TILING_Ys, 0);  }
> 
> +static void copy_tile4_to_linear(struct buf_ops *bops, struct intel_buf *buf,
> +				 uint32_t *linear)
> +{
> +	DEBUGFN();
> +	__copy_to_linear(bops->fd, buf, linear, I915_TILING_4, 0); }
> +
>  static void copy_linear_to_gtt(struct buf_ops *bops, struct intel_buf *buf,
>  			       uint32_t *linear)
>  {
> @@ -752,11 +818,10 @@ static void __intel_buf_init(struct buf_ops *bops,
>  	IGT_INIT_LIST_HEAD(&buf->link);
> 
>  	if (compression) {
> -		int aux_width, aux_height;
> -
>  		igt_require(bops->intel_gen >= 9);
>  		igt_assert(req_tiling == I915_TILING_Y ||
> -			   req_tiling == I915_TILING_Yf);
> +			   req_tiling == I915_TILING_Yf ||
> +			   req_tiling == I915_TILING_4);
>  		/*
>  		 * On GEN12+ we align the main surface to 4 * 4 main surface
>  		 * tiles, which is 64kB. These 16 tiles are mapped by 4 AUX @@ -
> 778,13 +843,18 @@ static void __intel_buf_init(struct buf_ops *bops,
>  		buf->bpp = bpp;
>  		buf->compression = compression;
> 
> -		aux_width = intel_buf_ccs_width(bops->intel_gen, buf);
> -		aux_height = intel_buf_ccs_height(bops->intel_gen, buf);
> +		if (!HAS_FLATCCS(intel_get_drm_devid(bops->fd))) {
> +			int aux_width, aux_height;
> 
> -		buf->ccs[0].offset = buf->surface[0].stride * ALIGN(height, 32);
> -		buf->ccs[0].stride = aux_width;
> +			aux_width = intel_buf_ccs_width(bops->intel_gen, buf);
> +			aux_height = intel_buf_ccs_height(bops->intel_gen,
> buf);
> 
> -		size = buf->ccs[0].offset + aux_width * aux_height;
> +			buf->ccs[0].offset = buf->surface[0].stride *
> ALIGN(height, 32);
> +			buf->ccs[0].stride = aux_width;
> +			size = buf->ccs[0].offset + aux_width * aux_height;
> +		} else {
> +			size = buf->ccs[0].offset;
> +		}
>  	} else {
>  		if (tiling) {
>  			devid =  intel_get_drm_devid(bops->fd); @@ -1176,17
> +1246,19 @@ void intel_buf_write_aux_to_png(struct intel_buf *buf, const
> char *filename)  #define DEFAULT_BUFOPS(__gen_start, __gen_end) \
>  	.gen_start          = __gen_start, \
>  	.gen_end            = __gen_end, \
> -	.supported_hw_tiles = TILE_X | TILE_Y, \
> +	.supported_hw_tiles = TILE_X | TILE_Y | TILE_4, \
>  	.linear_to          = copy_linear_to_wc, \
>  	.linear_to_x        = copy_linear_to_gtt, \
>  	.linear_to_y        = copy_linear_to_gtt, \
>  	.linear_to_yf       = copy_linear_to_yf, \
>  	.linear_to_ys       = copy_linear_to_ys, \
> +	.linear_to_tile4    = copy_linear_to_tile4, \
>  	.to_linear          = copy_wc_to_linear, \
>  	.x_to_linear        = copy_gtt_to_linear, \
>  	.y_to_linear        = copy_gtt_to_linear, \
>  	.yf_to_linear       = copy_yf_to_linear, \
> -	.ys_to_linear       = copy_ys_to_linear
> +	.ys_to_linear       = copy_ys_to_linear, \
> +	.tile4_to_linear    = copy_tile4_to_linear
> 
>  struct buf_ops buf_ops_arr[] = {
>  	{
> @@ -1201,7 +1273,7 @@ struct buf_ops buf_ops_arr[] = {
> 
>  	{
>  		DEFAULT_BUFOPS(12, 12),
> -		.supported_tiles   = TILE_NONE | TILE_X | TILE_Y | TILE_Yf |
> TILE_Ys,
> +		.supported_tiles   = TILE_NONE | TILE_X | TILE_Y | TILE_Yf |
> TILE_Ys | TILE_4,
>  	},
>  };
> 
> @@ -1230,6 +1302,8 @@ static bool probe_hw_tiling(struct buf_ops *bops,
> uint32_t tiling,
>  			bops->swizzle_x = buf_swizzle;
>  		else if (tiling == I915_TILING_Y)
>  			bops->swizzle_y = buf_swizzle;
> +		else if (tiling == I915_TILING_4)
> +			bops->swizzle_tile4 = buf_swizzle;
> 
>  		*swizzling_supported = buf_swizzle == phys_swizzle;
>  	}
> @@ -1390,6 +1464,24 @@ static struct buf_ops *__buf_ops_create(int fd, bool
> check_idempotency)
>  		}
>  	}
> 
> +	if (is_hw_tiling_supported(bops, I915_TILING_4)) {
> +		bool swizzling_supported;
> +		bool supported = probe_hw_tiling(bops, I915_TILING_4,
> +						 &swizzling_supported);
> +
> +		if (!swizzling_supported) {
> +			igt_debug("Swizzling for 4 is not supported\n");
> +			bops->supported_tiles &= ~TILE_4;
> +		}
> +
> +		igt_debug("4 fence support: %s\n", bool_str(supported));
> +		if (!supported) {
> +			bops->supported_hw_tiles &= ~TILE_4;
> +			bops->linear_to_tile4 = copy_linear_to_tile4;
> +			bops->tile4_to_linear = copy_tile4_to_linear;
> +		}
> +	}
> +
>  	/* Disable other tiling format functions if not supported */
>  	if (!is_tiling_supported(bops, I915_TILING_Yf)) {
>  		igt_debug("Yf format not supported\n"); diff --git
> a/lib/intel_chipset.h b/lib/intel_chipset.h index db75a829..4d9f4623 100644
> --- a/lib/intel_chipset.h
> +++ b/lib/intel_chipset.h
> @@ -219,6 +219,7 @@ void intel_check_pch(void);
> 
>  #define HAS_4TILE(devid)	(intel_get_device_info(devid)->has_4tile)
> 
> -#define HAS_FLATCCS(devid)	(intel_get_device_info(devid)->has_flatccs)
> +/* use HAS_4TILE here as all devices with 4-tile have flat ccs. */
> +#define HAS_FLATCCS(devid)	HAS_4TILE(devid)
> 
>  #endif /* _INTEL_CHIPSET_H */
> diff --git a/lib/rendercopy_gen9.c b/lib/rendercopy_gen9.c index
> 6c45efb4..ae0f775a 100644
> --- a/lib/rendercopy_gen9.c
> +++ b/lib/rendercopy_gen9.c
> @@ -165,7 +165,8 @@ intel_get_uc_mocs(int fd) {
> 
>  /* Mostly copy+paste from gen6, except height, width, pitch moved */  static
> uint32_t -gen8_bind_buf(struct intel_bb *ibb, const struct intel_buf *buf, int
> is_dst) {
> +gen8_bind_buf(struct intel_bb *ibb, const struct intel_buf *buf, int is_dst,
> +	      bool fast_clear) {
>  	struct gen9_surface_state *ss;
>  	uint32_t write_domain, read_domain;
>  	uint64_t address;
> @@ -192,15 +193,26 @@ gen8_bind_buf(struct intel_bb *ibb, const struct
> intel_buf *buf, int is_dst) {
>  		case 64: ss->ss0.surface_format =
> SURFACEFORMAT_R16G16B16A16_FLOAT; break;
>  		default: igt_assert(0);
>  	}
> -	ss->ss0.render_cache_read_write = 1;
>  	ss->ss0.vertical_alignment = 1; /* align 4 */
> -	ss->ss0.horizontal_alignment = 1; /* align 4 */
> +	ss->ss0.horizontal_alignment = 1; /* align 4 or HALIGN_32 on display
> +ver >= 13*/
> +
> +	if (HAS_4TILE(ibb->devid)) {
> +		/*
> +		 * mocs table version 1 index 3 groub wb use l3
> +		 */
> +		ss->ss1.memory_object_control = 3 << 1;
> +		ss->ss5.mip_tail_start_lod = 0;
> +	} else {
> +		ss->ss0.render_cache_read_write = 1;
> +		ss->ss1.memory_object_control = intel_get_uc_mocs(i915);
> +		ss->ss5.mip_tail_start_lod = 1; /* needed with trmode */
> +	}
> +
>  	if (buf->tiling == I915_TILING_X)
>  		ss->ss0.tiled_mode = 2;
>  	else if (buf->tiling != I915_TILING_NONE)
>  		ss->ss0.tiled_mode = 3;
> 
> -	ss->ss1.memory_object_control = intel_get_uc_mocs(i915);
>  	if (intel_buf_pxp(buf))
>  		ss->ss1.memory_object_control |= 1;
> 
> @@ -208,7 +220,6 @@ gen8_bind_buf(struct intel_bb *ibb, const struct
> intel_buf *buf, int is_dst) {
>  		ss->ss5.trmode = 1;
>  	else if (buf->tiling == I915_TILING_Ys)
>  		ss->ss5.trmode = 2;
> -	ss->ss5.mip_tail_start_lod = 1; /* needed with trmode */
> 
>  	address = intel_bb_offset_reloc(ibb, buf->handle,
>  					read_domain, write_domain,
> @@ -229,20 +240,23 @@ gen8_bind_buf(struct intel_bb *ibb, const struct
> intel_buf *buf, int is_dst) {
>  	if (buf->compression == I915_COMPRESSION_MEDIA)
>  		ss->ss7.tgl.media_compression = 1;
>  	else if (buf->compression == I915_COMPRESSION_RENDER) {
> -		igt_assert(buf->ccs[0].stride);
> -
>  		ss->ss6.aux_mode = 0x5; /* AUX_CCS_E */
> -		ss->ss6.aux_pitch = (buf->ccs[0].stride / 128) - 1;
> 
> -		address = intel_bb_offset_reloc_with_delta(ibb, buf->handle,
> -							   read_domain,
> write_domain,
> -							   (buf->cc.offset ? (1
> << 10) : 0) | buf->ccs[0].offset,
> -							   intel_bb_offset(ibb)
> + 4 * 10,
> -							   buf->addr.offset);
> -		ss->ss10.aux_base_addr = (address + buf->ccs[0].offset) >> 12;
> -		ss->ss11.aux_base_addr_hi = (address + buf->ccs[0].offset) >>
> 32;
> +		if (buf->ccs[0].stride) {
> +
> +			ss->ss6.aux_pitch = (buf->ccs[0].stride / 128) - 1;
> +
> +			address = intel_bb_offset_reloc_with_delta(ibb, buf-
> >handle,
> +
> read_domain, write_domain,
> +								   (buf-
> >cc.offset ? (1 << 10) : 0)
> +								   | buf-
> >ccs[0].offset,
> +
> intel_bb_offset(ibb) + 4 * 10,
> +								   buf-
> >addr.offset);
> +			ss->ss10.aux_base_addr = (address + buf-
> >ccs[0].offset) >> 12;
> +			ss->ss11.aux_base_addr_hi = (address + buf-
> >ccs[0].offset) >> 32;
> +		}
> 
> -		if (buf->cc.offset) {
> +		if (fast_clear || (buf->cc.offset && !HAS_FLATCCS(ibb->devid)))
> {
>  			igt_assert(buf->compression ==
> I915_COMPRESSION_RENDER);
> 
>  			ss->ss10.clearvalue_addr_enable = 1; @@ -252,8
> +266,30 @@ gen8_bind_buf(struct intel_bb *ibb, const struct intel_buf *buf, int
> is_dst) {
>  								   buf-
> >cc.offset,
> 
> intel_bb_offset(ibb) + 4 * 12,
>  								   buf-
> >addr.offset);
> -			ss->ss12.clear_address = address + buf->cc.offset;
> +
> +			/*
> +			 * If this assert doesn't hold below clear address will be
> +			 * written wrong.
> +			 */
> +
> +			igt_assert(__builtin_ctzl(address + buf->cc.offset) >= 6
> &&
> +				   (__builtin_clzl(address + buf->cc.offset) >=
> 16));
> +
> +			ss->ss12.clear_address = (address + buf->cc.offset) >>
> 6;
>  			ss->ss13.clear_address_hi = (address + buf->cc.offset)
> >> 32;
> +		} else if (HAS_FLATCCS(ibb->devid)) {
> +			ss->ss7.dg2.memory_compression_type = 0;
> +			ss->ss7.dg2.memory_compression_enable = 0;
> +			ss-
> >ss7.dg2.disable_support_for_multi_gpu_partial_writes = 1;
> +			ss->ss7.dg2.disable_support_for_multi_gpu_atomics =
> 1;
> +
> +			/*
> +			 * For now here is coming only 32bpp rgb format
> +			 * which is marked below as B8G8R8X8_UNORM = '8'
> +			 * If here ever arrive other formats below need to be
> +			 * fixed to take that into account.
> +			 */
> +			ss->ss12.compression_format = 8;
>  		}
>  	}
> 
> @@ -266,14 +302,15 @@ gen8_bind_surfaces(struct intel_bb *ibb,
>  		   const struct intel_buf *dst)
>  {
>  	uint32_t *binding_table, binding_table_offset;
> +	bool fast_clear = !src;
> 
>  	binding_table = intel_bb_ptr_align(ibb, 32);
>  	binding_table_offset = intel_bb_ptr_add_return_prev_offset(ibb, 32);
> 
> -	binding_table[0] = gen8_bind_buf(ibb, dst, 1);
> +	binding_table[0] = gen8_bind_buf(ibb, dst, 1, fast_clear);
> 
>  	if (src != NULL)
> -		binding_table[1] = gen8_bind_buf(ibb, src, 0);
> +		binding_table[1] = gen8_bind_buf(ibb, src, 0, false);
> 
>  	return binding_table_offset;
>  }
> @@ -856,12 +893,14 @@ gen8_emit_ps(struct intel_bb *ibb, uint32_t kernel,
> bool fast_clear) {  static void  gen9_emit_depth(struct intel_bb *ibb)  {
> +	bool need_10dw = HAS_4TILE(ibb->devid);
> +
>  	intel_bb_out(ibb, GEN8_3DSTATE_WM_DEPTH_STENCIL | (4 - 2));
>  	intel_bb_out(ibb, 0);
>  	intel_bb_out(ibb, 0);
>  	intel_bb_out(ibb, 0);
> 
> -	intel_bb_out(ibb, GEN7_3DSTATE_DEPTH_BUFFER | (8-2));
> +	intel_bb_out(ibb, GEN7_3DSTATE_DEPTH_BUFFER | (need_10dw ? (10-
> 2) :
> +(8-2)));
>  	intel_bb_out(ibb, 0);
>  	intel_bb_out(ibb, 0);
>  	intel_bb_out(ibb, 0);
> @@ -869,6 +908,10 @@ gen9_emit_depth(struct intel_bb *ibb)
>  	intel_bb_out(ibb, 0);
>  	intel_bb_out(ibb, 0);
>  	intel_bb_out(ibb, 0);
> +	if (need_10dw) {
> +		intel_bb_out(ibb, 0);
> +		intel_bb_out(ibb, 0);
> +	}
> 
>  	intel_bb_out(ibb, GEN8_3DSTATE_HIER_DEPTH_BUFFER | (5-2));
>  	intel_bb_out(ibb, 0);
> @@ -1080,7 +1123,7 @@ void _gen9_render_op(struct intel_bb *ibb,
> 
>  	gen9_emit_state_base_address(ibb);
> 
> -	if (IS_DG2(ibb->devid) || intel_gen(ibb->devid) > 12) {
> +	if (HAS_4TILE(ibb->devid) || intel_gen(ibb->devid) > 12) {
>  		intel_bb_out(ibb,
> GEN4_3DSTATE_BINDING_TABLE_POOL_ALLOC | 2);
>  		intel_bb_emit_reloc(ibb, ibb->handle,
>  				    I915_GEM_DOMAIN_RENDER |
> I915_GEM_DOMAIN_INSTRUCTION, 0, @@ -1197,18 +1240,12 @@ void
> gen12p71_render_copyfunc(struct intel_bb *ibb,
>  			      struct intel_buf *dst,
>  			      unsigned int dst_x, unsigned int dst_y)  {
> -	struct aux_pgtable_info pgtable_info = { };
> -
> -	gen12_aux_pgtable_init(&pgtable_info, ibb, src, dst);
> -
>  	_gen9_render_op(ibb, src, src_x, src_y,
>  			width, height, dst, dst_x, dst_y,
> -			pgtable_info.pgtable_buf,
> +			NULL,
>  			NULL,
>  			gen12p71_render_copy,
>  			sizeof(gen12p71_render_copy));
> -
> -	gen12_aux_pgtable_cleanup(ibb, &pgtable_info);
>  }
> 
>  void gen12_render_clearfunc(struct intel_bb *ibb, @@ -1217,16 +1254,24 @@
> void gen12_render_clearfunc(struct intel_bb *ibb,
>  			    unsigned int width, unsigned int height,
>  			    const float clear_color[4])
>  {
> -	struct aux_pgtable_info pgtable_info = { };
> -
> -	gen12_aux_pgtable_init(&pgtable_info, ibb, NULL, dst);
> -
> -	_gen9_render_op(ibb, NULL, 0, 0,
> -		        width, height, dst, dst_x, dst_y,
> -		        pgtable_info.pgtable_buf,
> -		        clear_color,
> -		        gen12_render_copy,
> -		        sizeof(gen12_render_copy));
> -
> -	gen12_aux_pgtable_cleanup(ibb, &pgtable_info);
> +	if (!HAS_4TILE(ibb->devid)) {
> +		struct aux_pgtable_info pgtable_info = { };
> +
> +		gen12_aux_pgtable_init(&pgtable_info, ibb, NULL, dst);
> +
> +		_gen9_render_op(ibb, NULL, 0, 0,
> +				width, height, dst, dst_x, dst_y,
> +				pgtable_info.pgtable_buf,
> +				clear_color,
> +				gen12_render_copy,
> +				sizeof(gen12_render_copy));
> +		gen12_aux_pgtable_cleanup(ibb, &pgtable_info);
> +	} else {
> +			_gen9_render_op(ibb, NULL, 0, 0,
> +					width, height, dst, dst_x, dst_y,
> +					NULL,
> +					clear_color,
> +					gen12p71_render_copy,
> +					sizeof(gen12p71_render_copy));
> +	}
>  }
> diff --git a/lib/veboxcopy_gen12.c b/lib/veboxcopy_gen12.c index
> 17564493..aa90939b 100644
> --- a/lib/veboxcopy_gen12.c
> +++ b/lib/veboxcopy_gen12.c
> @@ -53,19 +53,25 @@ struct vebox_surface_state {
>  		uint32_t width:14;
>  		uint32_t height:14;
>  	} ss2;
> -	struct {
> +	union {
> +		struct {
>  #define VEBOX_TILE_WALK_XMAJOR 0
>  #define VEBOX_TILE_WALK_YMAJOR 1
> -		uint32_t tile_walk:1;
> -		uint32_t tiled_surface:1;
> -		uint32_t chroma_half_pitch:1;
> -		uint32_t surface_pitch:17;
> -		uint32_t chroma_interleave:1;
> -		uint32_t lsb_packed_enable:1;
> -		uint32_t bayer_input_alignment:2;
> -		uint32_t bayer_pattern_format:1;
> -		uint32_t bayer_pattern_offset:2;
> -		uint32_t surface_format:5;
> +			uint32_t tile_walk:1;
> +			uint32_t tiled_surface:1;
> +			uint32_t chroma_half_pitch:1;
> +			uint32_t surface_pitch:17;
> +			uint32_t chroma_interleave:1;
> +			uint32_t lsb_packed_enable:1;
> +			uint32_t bayer_input_alignment:2;
> +			uint32_t bayer_pattern_format:1;
> +			uint32_t bayer_pattern_offset:2;
> +			uint32_t surface_format:5;
> +		} tgl;
> +		struct {
> +			uint32_t tile_mode:2;
> +			uint32_t pad0:30;
> +		} dg2;
>  	} ss3;
>  	struct {
>  		uint32_t u_y_offset:15;
> @@ -82,9 +88,15 @@ struct vebox_surface_state {
>  		uint32_t frame_x_offset:15;
>  		uint32_t pad:2;
>  	} ss6;
> -	struct {
> -		uint32_t derived_surface_pitch:17;
> -		uint32_t pad:15;
> +	union {
> +		struct {
> +			uint32_t derived_surface_pitch:17;
> +			uint32_t pad:15;
> +		} skl;
> +		struct {
> +			uint32_t pad:27;
> +			uint32_t compression_format:5;
> +		} dg2;
>  	} ss7;
>  	struct {
>  		uint32_t skin_score_output_surface_pitch:17;
> @@ -166,17 +178,46 @@ static void emit_surface_state_cmd(struct intel_bb
> *ibb,
>  	ss->ss2.height = height - 1;
>  	ss->ss2.width = width - 1;
> 
> -	ss->ss3.surface_format = format;
> +	ss->ss3.tgl.surface_format = format;
>  	if (format_is_interleaved_yuv(format))
> -		ss->ss3.chroma_interleave = 1;
> -	ss->ss3.surface_pitch = pitch - 1;
> -	ss->ss3.tile_walk = (tiling == I915_TILING_Y) ||
> -			    (tiling == I915_TILING_Yf);
> -	ss->ss3.tiled_surface = tiling != I915_TILING_NONE;
> +		ss->ss3.tgl.chroma_interleave = 1;
> +	ss->ss3.tgl.surface_pitch = pitch - 1;
> 
>  	ss->ss4.u_y_offset = uv_offset / pitch;
> 
> -	ss->ss7.derived_surface_pitch = pitch - 1;
> +	if (HAS_FLATCCS(ibb->devid)) {
> +		/*
> +		 * f-tile = 3 (Tile F)
> +		 */
> +		ss->ss3.dg2.tile_mode = (tiling != I915_TILING_NONE) ? 3 : 0;
> +
> +		switch (format) {
> +		case R8G8B8A8_UNORM:
> +			ss->ss7.dg2.compression_format = 0xa;
> +			break;
> +		case PLANAR_420_8:
> +			ss->ss7.dg2.compression_format = 0xf;
> +			break;
> +		case PLANAR_420_16:
> +			ss->ss7.dg2.compression_format = 8;
> +			break;
> +		case YCRCB_NORMAL:
> +			ss->ss7.dg2.compression_format = 3;
> +			break;
> +		case PACKED_444A_8:
> +			ss->ss7.dg2.compression_format = 0x9;
> +			break;
> +		default:
> +			igt_assert(0);
> +		}
> +	} else {
> +		ss->ss3.tgl.tile_walk = (tiling == I915_TILING_Y) ||
> +			(tiling == I915_TILING_Yf) ||
> +			(tiling == I915_TILING_4);
> +		ss->ss3.tgl.tiled_surface = tiling != I915_TILING_NONE;
> +	}
> +
> +	ss->ss7.skl.derived_surface_pitch = pitch - 1;
> 
>  	intel_bb_ptr_add(ibb, sizeof(*ss));
>  }
> @@ -203,7 +244,11 @@ static void emit_tiling_convert_cmd(struct intel_bb
> *ibb,
>  		tc->tc1_2.input_compression_type =
>  			src->compression == I915_COMPRESSION_RENDER;
>  	}
> -	tc->tc1_2.input_tiled_resource_mode = src->tiling == I915_TILING_Yf;
> +
> +	if (HAS_4TILE(ibb->devid))
> +		tc->tc1_2.input_mocs_idx = 3;
> +	else
> +		tc->tc1_2.input_tiled_resource_mode = src->tiling ==
> I915_TILING_Yf;
>  	reloc_delta = tc->tc1_2_l;
> 
>  	igt_assert(src->addr.offset == ALIGN(src->addr.offset, 0x1000)); @@ -
> 220,7 +265,12 @@ static void emit_tiling_convert_cmd(struct intel_bb *ibb,
>  		tc->tc3_4.output_compression_type =
>  			dst->compression == I915_COMPRESSION_RENDER;
>  	}
> -	tc->tc3_4.output_tiled_resource_mode = dst->tiling == I915_TILING_Yf;
> +
> +	if (HAS_4TILE(ibb->devid))
> +		tc->tc3_4.output_mocs_idx = 3;
> +	else
> +		tc->tc3_4.output_tiled_resource_mode = dst->tiling ==
> I915_TILING_Yf;
> +
>  	reloc_delta = tc->tc3_4_l;
> 
>  	igt_assert(dst->addr.offset == ALIGN(dst->addr.offset, 0x1000)); @@ -
> 255,10 +305,12 @@ void gen12_vebox_copyfunc(struct intel_bb *ibb,
>  	intel_bb_add_intel_buf(ibb, dst, true);
>  	intel_bb_add_intel_buf(ibb, src, false);
> 
> -	intel_bb_ptr_set(ibb, BATCH_STATE_SPLIT);
> -	gen12_aux_pgtable_init(&aux_pgtable_info, ibb, src, dst);
> -	aux_pgtable_state = gen12_create_aux_pgtable_state(ibb,
> -
> aux_pgtable_info.pgtable_buf);
> +	if (!HAS_FLATCCS(ibb->devid)) {
> +		intel_bb_ptr_set(ibb, BATCH_STATE_SPLIT);
> +		gen12_aux_pgtable_init(&aux_pgtable_info, ibb, src, dst);
> +		aux_pgtable_state = gen12_create_aux_pgtable_state(ibb,
> +
> aux_pgtable_info.pgtable_buf);
> +	}
> 
>  	intel_bb_ptr_set(ibb, 0);
>  	gen12_emit_aux_pgtable_state(ibb, aux_pgtable_state, false); @@ -
> 311,5 +363,6 @@ void gen12_vebox_copyfunc(struct intel_bb *ibb,
> 
>  	intel_bb_reset(ibb, false);
> 
> -	gen12_aux_pgtable_cleanup(ibb, &aux_pgtable_info);
> +	if (!HAS_FLATCCS(ibb->devid))
> +		gen12_aux_pgtable_cleanup(ibb, &aux_pgtable_info);
>  }
> --
> 2.36.0



More information about the igt-dev mailing list