All of lore.kernel.org
 help / color / mirror / Atom feed
From: Rodrigo Vivi <rodrigo.vivi@intel.com>
To: Alan Previn <alan.previn.teres.alexis@intel.com>
Cc: igt-dev@lists.freedesktop.org
Subject: Re: [igt-dev] [PATCH i-g-t 10/17] Add test where both src and dest are protected
Date: Fri, 4 Jun 2021 09:31:42 -0400	[thread overview]
Message-ID: <YLorPkfLZ9D+V+RJ@intel.com> (raw)
In-Reply-To: <20210518103344.2264397-11-alan.previn.teres.alexis@intel.com>

On Tue, May 18, 2021 at 03:33:37AM -0700, Alan Previn wrote:
> When both the source and destination surfaces are
> protected, the destination pixel result of the 3d
> copy operation would be the same as the source. By
> appending this test case to the end of the prior
> test (raw-src to protected-dest) and reusing the
> previous' test destination as the current source,
> we can prove that new-source was decrypted properly
> as we would see the difference in results: repeating
> the same render operation but with a src buffer
> that is protected in this case yields matching
> (but still encrypted) output rendered pixels.
> 
> Signed-off-by: Alan Previn <alan.previn.teres.alexis@intel.com>
> ---
>  tests/i915/gem_pxp.c | 144 +++++++++++++++++++++++++++++++++++++++----
>  1 file changed, 133 insertions(+), 11 deletions(-)
> 
> diff --git a/tests/i915/gem_pxp.c b/tests/i915/gem_pxp.c
> index 5a29024a..2f2d2716 100644
> --- a/tests/i915/gem_pxp.c
> +++ b/tests/i915/gem_pxp.c
> @@ -308,29 +308,51 @@ static void fill_bo_content(int i915, uint32_t bo, uint32_t size, uint32_t initc
>  
>  #define COMPARE_COLOR_READIBLE     1
>  #define COMPARE_COLOR_UNREADIBLE   2
> +#define COMPARE_BUFFER_READIBLE    3
> +#define COMPARE_BUFFER_UNREADIBLE  4
> +#define COPY_BUFFER                5
>  #define COMPARE_N_PIXELS_VERBOSELY 0
>  
> -static void assert_bo_content_check(int i915, uint32_t bo, int compare_op,
> -				    uint32_t size, uint32_t color)
> +static void assert_bo_content_check(int i915, uint32_t bo, int compare_op, uint32_t size,
> +				    uint32_t color, uint32_t *auxptr, int auxsize)
>  {
> -	uint32_t *ptr, *ptrtmp;
> +	uint32_t *ptr, *ptrtmp, *auxtmp;
>  	int loop = 0, num_matches = 0;
>  	uint32_t value;
> -	bool op_readible = (compare_op == COMPARE_COLOR_READIBLE);
> +	bool op_readible = ((compare_op == COMPARE_COLOR_READIBLE) ||
> +		 (compare_op == COMPARE_BUFFER_READIBLE));
> +	bool chk_buff = ((compare_op == COMPARE_BUFFER_READIBLE) ||
> +		 (compare_op == COMPARE_BUFFER_UNREADIBLE));

why do we need to differentiate between color and buffer if they
are doing the same thing everywhere?

well, I'm assuming this is a future case, so anyway:


Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>



> +	bool copy_buff = (compare_op == COPY_BUFFER);
>  
>  	ptr = gem_mmap__device_coherent(i915, bo, 0, size, PROT_READ);
>  	ptrtmp = ptr;
>  
> +	if (chk_buff || copy_buff) {
> +		if (auxsize < size)
> +			auxptr = NULL;
> +		igt_assert(auxptr);
> +		auxtmp = auxptr;
> +	}
> +
>  	if (COMPARE_N_PIXELS_VERBOSELY) {
>  		igt_info("--------->>>\n");
>  		while (loop < COMPARE_N_PIXELS_VERBOSELY && loop < (size/4)) {
>  			value = *ptrtmp;
> -			igt_info("Color read = 0x%08x ", value);
> -			igt_info("expected %c= 0x%08x)\n", op_readible?'=':'!', color);
> +			if (chk_buff)
> +				color = *auxtmp;
> +			if (copy_buff)
> +				igt_info("Color copy = 0x%08x\n", value);
> +			else {
> +				igt_info("Color read = 0x%08x ", value);
> +				igt_info("expected %c= 0x%08x)\n", op_readible?'=':'!', color);
> +			}
> +			++auxtmp;
>  			++ptrtmp;
>  			++loop;
>  		}
>  		igt_info("<<<---------\n");
> +		auxtmp = auxptr;
>  		ptrtmp = ptr;
>  		loop = 0;
>  	}
> @@ -338,8 +360,25 @@ static void assert_bo_content_check(int i915, uint32_t bo, int compare_op,
>  	/* count all pixels for matches */
>  	while (loop++ < (size/4)) {
>  		value = *ptrtmp;
> -		if (value == color)
> -			++num_matches;
> +		switch (compare_op) {
> +		case COMPARE_COLOR_READIBLE:
> +		case COMPARE_COLOR_UNREADIBLE:
> +			if (value == color)
> +				++num_matches;
> +			break;
> +		case COMPARE_BUFFER_READIBLE:
> +		case COMPARE_BUFFER_UNREADIBLE:
> +			if (value == (*auxtmp))
> +				++num_matches;
> +			++auxtmp;
> +			break;
> +		case COPY_BUFFER:
> +			*auxtmp = value;
> +			++auxtmp;
> +			break;
> +		default:
> +			break;
> +		}
>  		++ptrtmp;
>  	}
>  
> @@ -361,7 +400,8 @@ static uint32_t alloc_and_fill_dest_buff(int i915, bool protected, uint32_t size
>  	igt_assert_eq(ret, 0);
>  	igt_assert(bo);
>  	fill_bo_content(i915, bo, size, init_color);
> -	assert_bo_content_check(i915, bo, COMPARE_COLOR_READIBLE, size, init_color);
> +	assert_bo_content_check(i915, bo, COMPARE_COLOR_READIBLE,
> +				size, init_color, NULL, 0);
>  
>  	return bo;
>  }
> @@ -379,6 +419,7 @@ static uint32_t alloc_and_fill_dest_buff(int i915, bool protected, uint32_t size
>  #define TSTSURF_FILLCOLOR2  0xdeaddead
>  #define TSTSURF_INITCOLOR1  0x12341234
>  #define TSTSURF_INITCOLOR2  0x56785678
> +#define TSTSURF_INITCOLOR3  0xabcdabcd
>  
>  static void test_render_baseline(int i915)
>  {
> @@ -413,7 +454,7 @@ static void test_render_baseline(int i915)
>  	gem_sync(i915, dstbo);
>  
>  	assert_bo_content_check(i915, dstbo, COMPARE_COLOR_READIBLE,
> -				TSTSURF_SIZE, TSTSURF_FILLCOLOR1);
> +				TSTSURF_SIZE, TSTSURF_FILLCOLOR1, NULL, 0);
>  
>  	intel_bb_destroy(ibb);
>  	intel_buf_destroy(srcbuf);
> @@ -464,13 +505,92 @@ static void test_render_pxp_src_to_protdest(int i915)
>  	gem_sync(i915, dstbo);
>  
>  	assert_bo_content_check(i915, dstbo, COMPARE_COLOR_UNREADIBLE,
> -				TSTSURF_SIZE, TSTSURF_FILLCOLOR2);
> +				TSTSURF_SIZE, TSTSURF_FILLCOLOR2, NULL, 0);
> +
> +	intel_bb_destroy(ibb);
> +	intel_buf_destroy(srcbuf);
> +	gem_close(i915, srcbo);
> +	intel_buf_destroy(dstbuf);
> +	gem_close(i915, dstbo);
> +	gem_context_destroy(i915, ctx);
> +	buf_ops_destroy(bops);
> +}
> +
> +static void test_render_pxp_protsrc_to_protdest(int i915)
> +{
> +	uint32_t ctx, srcbo, dstbo, dstbo2;
> +	struct intel_buf *srcbuf, *dstbuf, *dstbuf2;
> +	struct buf_ops *bops;
> +	struct intel_bb *ibb;
> +	uint32_t devid;
> +	int ret;
> +	uint32_t encrypted[TSTSURF_SIZE/TSTSURF_BYTESPP];
> +
> +	devid = intel_get_drm_devid(i915);
> +	igt_assert(devid);
> +
> +	bops = buf_ops_create(i915);
> +	igt_assert(bops);
> +
> +	/*
> +	 * Perform a protected render operation but only label
> +	 * the dest as protected. After rendering, the content
> +	 * should be encrypted
> +	 */
> +	ret = create_ctx_with_params(i915, true, true, true, false, &ctx);
> +	igt_assert_eq(ret, 0);
> +	igt_assert_eq(get_ctx_protected_param(i915, ctx), 1);
> +	ibb = intel_bb_create_with_context(i915, ctx, 4096);
> +	igt_assert(ibb);
> +	intel_bb_set_pxp(ibb, true, DISPLAY_APPTYPE, I915_PROTECTED_CONTENT_DEFAULT_SESSION);
> +
> +	dstbo = alloc_and_fill_dest_buff(i915, true, TSTSURF_SIZE, TSTSURF_INITCOLOR2);
> +	dstbuf = intel_buf_create_using_handle(bops, dstbo, TSTSURF_WIDTH, TSTSURF_HEIGHT,
> +						TSTSURF_BYTESPP*8, 0, I915_TILING_NONE, 0);
> +	intel_buf_set_pxp(dstbuf, true);
> +
> +	srcbo = alloc_and_fill_dest_buff(i915, false, TSTSURF_SIZE, TSTSURF_FILLCOLOR2);
> +	srcbuf = intel_buf_create_using_handle(bops, srcbo, TSTSURF_WIDTH, TSTSURF_HEIGHT,
> +						TSTSURF_BYTESPP*8, 0, I915_TILING_NONE, 0);
> +
> +	gen12_render_copyfunc(ibb, srcbuf, 0, 0, TSTSURF_WIDTH, TSTSURF_HEIGHT, dstbuf, 0, 0);
> +	gem_sync(i915, dstbo);
> +
> +	assert_bo_content_check(i915, dstbo, COMPARE_COLOR_UNREADIBLE,
> +				TSTSURF_SIZE, TSTSURF_FILLCOLOR2, NULL, 0);
> +
> +	/*
> +	 * Reuse prior dst as the new-src and create dst2 as the new-dest.
> +	 * Take a copy of encrypted content from new-src for comparison after render
> +	 * operation. After the rendering, we should find no difference in content
> +	 * since both new-src and new-dest are labelled as encrypted. HW should read
> +	 * and decrypt new-src, perform the render and re-encrypt when going into
> +	 * new-dest
> +	 */
> +	assert_bo_content_check(i915, dstbo, COPY_BUFFER,
> +				TSTSURF_SIZE, 0, encrypted, TSTSURF_SIZE);
> +
> +	dstbo2 = alloc_and_fill_dest_buff(i915, false, TSTSURF_SIZE, TSTSURF_INITCOLOR3);
> +	dstbuf2 = intel_buf_create_using_handle(bops, dstbo2, TSTSURF_WIDTH, TSTSURF_HEIGHT,
> +						TSTSURF_BYTESPP*8, 0, I915_TILING_NONE, 0);
> +	intel_buf_set_pxp(dstbuf2, true);
> +	intel_buf_set_pxp(dstbuf, true);/*this time, src is protected*/
> +
> +	intel_bb_set_pxp(ibb, true, DISPLAY_APPTYPE, I915_PROTECTED_CONTENT_DEFAULT_SESSION);
> +
> +	gen12_render_copyfunc(ibb, dstbuf, 0, 0, TSTSURF_WIDTH, TSTSURF_HEIGHT, dstbuf2, 0, 0);
> +	gem_sync(i915, dstbo2);
> +
> +	assert_bo_content_check(i915, dstbo2, COMPARE_BUFFER_READIBLE,
> +				TSTSURF_SIZE, 0, encrypted, TSTSURF_SIZE);
>  
>  	intel_bb_destroy(ibb);
>  	intel_buf_destroy(srcbuf);
>  	gem_close(i915, srcbo);
>  	intel_buf_destroy(dstbuf);
>  	gem_close(i915, dstbo);
> +	intel_buf_destroy(dstbuf2);
> +	gem_close(i915, dstbo2);
>  	gem_context_destroy(i915, ctx);
>  	buf_ops_destroy(bops);
>  }
> @@ -548,6 +668,8 @@ igt_main
>  			test_render_baseline(i915);
>  		igt_subtest("protected-raw-src-copy-not-readible")
>  			test_render_pxp_src_to_protdest(i915);
> +		igt_subtest("protected-encrypted-src-copy-not-readible")
> +			test_render_pxp_protsrc_to_protdest(i915);
>  	}
>  
>  	igt_fixture {
> -- 
> 2.25.1
> 
> _______________________________________________
> igt-dev mailing list
> igt-dev@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/igt-dev
_______________________________________________
igt-dev mailing list
igt-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/igt-dev

  reply	other threads:[~2021-06-04 13:31 UTC|newest]

Thread overview: 55+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-05-18 10:33 [igt-dev] [PATCH i-g-t 00/17] Introduce PXP Test Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 01/17] Sync i915_drm.h UAPI from kernel Alan Previn
2021-06-02 20:07   ` Rodrigo Vivi
2021-06-03  0:15     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 02/17] Add PXP UAPI support in i915_drm.h Alan Previn
2021-06-02 20:10   ` Rodrigo Vivi
2021-06-03  0:50     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 03/17] Update IOCTL wrapper with DRM_IOCTL_I915_GEM_CONTEXT_CREATE_EXT Alan Previn
2021-06-02 20:10   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 04/17] Add basic PXP testing of buffer and context alloc Alan Previn
2021-06-02 20:23   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 05/17] Perform a regular 3d copy as a control checkpoint Alan Previn
2021-06-02 21:37   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 06/17] Add PXP attribute support in batchbuffer and buffer_ops libs Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 07/17] Add MI_SET_APPID instruction definition Alan Previn
2021-06-02 21:40   ` Rodrigo Vivi
2021-06-03  0:54     ` Teres Alexis, Alan Previn
2021-06-03 15:06       ` Rodrigo Vivi
2021-06-03  8:52   ` Michal Wajdeczko
2021-06-03 15:22     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 08/17] Enable protected session cmd in gen12_render_copyfunc Alan Previn
2021-06-04 13:16   ` Rodrigo Vivi
2021-06-10 17:36     ` Teres Alexis, Alan Previn
2021-06-10 19:55       ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 09/17] Add subtest to copy raw source to protected dest Alan Previn
2021-06-04 13:22   ` Rodrigo Vivi
2021-06-05  1:30     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 10/17] Add test where both src and dest are protected Alan Previn
2021-06-04 13:31   ` Rodrigo Vivi [this message]
2021-06-05  1:38     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 11/17] Verify PXP teardown occurred through suspend-resume Alan Previn
2021-06-03 21:40   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 12/17] Verify execbuf fails with stale PXP context after teardown Alan Previn
2021-06-04 13:38   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 13/17] Verify execbuf fails with stale PXP buffer " Alan Previn
2021-06-03 21:41   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 14/17] Verify execbuf ok with stale prot-buff and regular context Alan Previn
2021-06-04 13:56   ` Rodrigo Vivi
2021-06-05  0:27     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 15/17] Ensure RESET_STATS reports invalidated protected context Alan Previn
2021-06-03 21:43   ` Rodrigo Vivi
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 16/17] Verify protected surfaces are dma buffer sharable Alan Previn
2021-06-04 14:18   ` Rodrigo Vivi
2021-06-05  0:45     ` Teres Alexis, Alan Previn
2021-05-18 10:33 ` [igt-dev] [PATCH i-g-t 17/17] tests/i915_pxp: CRC validation for display tests Alan Previn
2021-06-04 14:40   ` Rodrigo Vivi
2021-06-05  1:07     ` Teres Alexis, Alan Previn
2021-06-10 13:00       ` Shankar, Uma
2021-06-10 14:17         ` Rodrigo Vivi
2021-05-18 11:30 ` [igt-dev] ✓ Fi.CI.BAT: success for Introduce PXP Test (rev5) Patchwork
2021-05-18 18:19 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork
2021-06-02 21:44   ` Rodrigo Vivi
2021-06-03 18:09     ` Teres Alexis, Alan Previn
2021-06-03 18:13       ` Rodrigo Vivi
  -- strict thread matches above, loose matches on Subject: below --
2021-05-15 23:01 [igt-dev] [PATCH i-g-t 00/17] Introduce PXP Test Alan Previn
2021-05-15 23:01 ` [igt-dev] [PATCH i-g-t 10/17] Add test where both src and dest are protected Alan Previn

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=YLorPkfLZ9D+V+RJ@intel.com \
    --to=rodrigo.vivi@intel.com \
    --cc=alan.previn.teres.alexis@intel.com \
    --cc=igt-dev@lists.freedesktop.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.