[igt-dev] [i-g-t V3 41/45] tests/kms_prime: Use Rendercopy instead of Blit

B, Jeevan jeevan.b at intel.com
Thu Apr 27 11:06:00 UTC 2023



> -----Original Message-----
> From: igt-dev <igt-dev-bounces at lists.freedesktop.org> On Behalf Of
> Bhanuprakash Modem
> Sent: Wednesday, April 26, 2023 5:17 PM
> To: igt-dev at lists.freedesktop.org
> Subject: [igt-dev] [i-g-t V3 41/45] tests/kms_prime: Use Rendercopy instead of
> Blit
> 
> Instead of using Blitter, use Rendercopy to export the color frame buffer.
> 
LGTM
> Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
Reviewed-by: Jeevan B <jeevan.b at intel.com>
> ---
>  tests/kms_prime.c | 71 ++++++++++++++++++++++++++++++++---------------
>  1 file changed, 48 insertions(+), 23 deletions(-)
> 
> diff --git a/tests/kms_prime.c b/tests/kms_prime.c index dd5ab993e..0828bf6b5
> 100644
> --- a/tests/kms_prime.c
> +++ b/tests/kms_prime.c
> @@ -150,35 +150,60 @@ static void prepare_fb(int importer_fd, struct
> dumb_bo *scratch, struct igt_fb *
>  		    color_encoding, color_range);
>  }
> 
> +static struct intel_buf * create_buf(int fd, struct buf_ops *bops, int width,
> +				     int height, uint32_t gem_handle) {
> +	struct intel_buf *buf;
> +	uint32_t name, handle;
> +
> +	name = gem_flink(fd, gem_handle);
> +	handle = gem_open(fd, name);
> +
> +	buf = intel_buf_create_using_handle(bops, handle,
> +					    width, height, 32, 0,
> +					    I915_TILING_NONE, 0);
> +
> +	/* Make sure we close handle on destroy path */
> +	intel_buf_set_ownership(buf, true);
> +	return buf;
> +}
> +
>  static void import_fb(int importer_fd, struct igt_fb *fb,
>  		      int dmabuf_fd, uint32_t pitch)
>  {
>  	uint32_t offsets[4] = {}, pitches[4] = {}, handles[4] = {},
> temp_buf_handle;
>  	int ret;
> 
> -	if (is_i915_device(importer_fd)) {
> -		if (gem_has_lmem(importer_fd)) {
> -			uint64_t ahnd = get_reloc_ahnd(importer_fd, 0);
> -			uint64_t fb_size = 0;
> -
> -			igt_info("Importer is dGPU\n");
> -			temp_buf_handle = prime_fd_to_handle(importer_fd,
> dmabuf_fd);
> -			igt_assert(temp_buf_handle > 0);
> -			fb->gem_handle =
> igt_create_bo_with_dimensions(importer_fd, fb->width, fb->height,
> -								       fb-
> >drm_format, fb->modifier, pitch, &fb_size, NULL, NULL);
> -			igt_assert(fb->gem_handle > 0);
> -
> -			igt_blitter_src_copy(importer_fd, ahnd, 0, NULL,
> temp_buf_handle,
> -					     0, pitch, fb->modifier, 0, 0, fb_size,
> fb->width,
> -					     fb->height, 32, fb->gem_handle, 0,
> pitch, fb->modifier,
> -					     0, 0, fb_size);
> -
> -			gem_sync(importer_fd, fb->gem_handle);
> -			gem_close(importer_fd, temp_buf_handle);
> -			put_ahnd(ahnd);
> -		} else {
> -			fb->gem_handle = prime_fd_to_handle(importer_fd,
> dmabuf_fd);
> -		}
> +	if (is_i915_device(importer_fd) && gem_has_lmem(importer_fd)) {
> +		uint32_t devid = intel_get_drm_devid(importer_fd);
> +		struct buf_ops *bops = buf_ops_create(importer_fd);
> +		igt_render_copyfunc_t rendercopy =
> igt_get_render_copyfunc(devid);
> +		struct intel_bb *ibb = intel_bb_create(importer_fd, 4096);
> +		struct intel_buf *src, *dst;
> +		uint32_t *ptr;
> +		uint64_t fb_size = 0;
> +
> +		igt_info("Importer is dGPU\n");
> +		temp_buf_handle = prime_fd_to_handle(importer_fd,
> dmabuf_fd);
> +		igt_assert(temp_buf_handle > 0);
> +		fb->gem_handle =
> igt_create_bo_with_dimensions(importer_fd, fb->width, fb->height,
> +							       fb->drm_format,
> fb->modifier, pitch, &fb_size, NULL, NULL);
> +		igt_assert(fb->gem_handle > 0);
> +
> +		ptr = gem_mmap__device_coherent(importer_fd,
> temp_buf_handle, 0,
> +						ALIGN(fb_size, 4096),
> +						PROT_READ | PROT_WRITE);
> +
> +		src = create_buf(importer_fd, bops, fb->width, fb->height,
> temp_buf_handle);
> +		dst = create_buf(importer_fd, bops, fb->width, fb->height, fb-
> >gem_handle);
> +		rendercopy(ibb, src, 0, 0, fb->width, fb->height, dst, 0, 0);
> +
> +		igt_assert(gem_munmap(ptr, fb_size) == 0);
> +		intel_bb_destroy(ibb);
> +		intel_buf_destroy(src);
> +		intel_buf_destroy(dst);
> +		buf_ops_destroy(bops);
> +		gem_close(importer_fd, temp_buf_handle);
>  	} else {
>  		fb->gem_handle = prime_fd_to_handle(importer_fd,
> dmabuf_fd);
>  	}
> --
> 2.40.0



More information about the igt-dev mailing list