[igt-dev] [i-g-t 3/5] tests/kms_vrr: Add Negative tests to validate VRR

Navare, Manasi manasi.d.navare at intel.com
Fri Mar 4 01:20:29 UTC 2022


On Thu, Feb 24, 2022 at 10:46:46AM +0530, Bhanuprakash Modem wrote:
> This patch will try to enable VRR on Non-VRR panel. VRR should
> not be enabled on the Non-VRR panel. Hence Kernel should reject
> the commit.
> 
> Cc: Manasi Navare <manasi.d.navare at intel.com>
> Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
> ---
>  tests/kms_vrr.c | 69 +++++++++++++++++++++++++++++++++++++++++++++++--
>  1 file changed, 67 insertions(+), 2 deletions(-)
> 
> diff --git a/tests/kms_vrr.c b/tests/kms_vrr.c
> index 8976d4a6c3..7deab77311 100644
> --- a/tests/kms_vrr.c
> +++ b/tests/kms_vrr.c
> @@ -45,6 +45,7 @@ enum {
>  	TEST_DPMS = 1 << 0,
>  	TEST_SUSPEND = 1 << 1,
>  	TEST_FLIPLINE = 1 << 2,
> +	TEST_NEGATIVE = 1 << 3,
>  };
>  
>  typedef struct range {
> @@ -244,6 +245,34 @@ static void prepare_test(data_t *data, igt_output_t *output, enum pipe pipe)
>  	igt_display_commit2(&data->display, COMMIT_ATOMIC);
>  }
>  
> +static void prepare_negative_test(data_t *data, igt_output_t *output, enum pipe pipe)
> +{
> +	drmModeModeInfo *mode;
> +
> +	/* Reset output */
> +	igt_display_reset(&data->display);
> +	igt_output_set_pipe(output, pipe);
> +
> +	/* Capture VRR range */
> +	data->range = get_vrr_range(data, output);
> +
> +	/* Prepare resources */
> +	mode = igt_output_get_mode(output);
> +	igt_assert(igt_create_fb(data->drm_fd, mode->hdisplay, mode->vdisplay,
> +				 DRM_FORMAT_XRGB8888, DRM_FORMAT_MOD_LINEAR,
> +				 &data->fb0));
> +
> +	/* Take care of any required modesetting before the test begins. */
> +	data->primary = igt_output_get_plane_type(output, DRM_PLANE_TYPE_PRIMARY);
> +	igt_plane_set_fb(data->primary, &data->fb0);
> +
> +	/* Clear vrr_enabled state before enabling it, because
> +	 * it might be left enabled if the previous test fails.
> +	 */
> +	igt_pipe_set_prop_value(&data->display, pipe, IGT_CRTC_VRR_ENABLED, 0);
> +	igt_display_commit2(&data->display, COMMIT_ATOMIC);
> +}
> +
>  /* Performs an atomic non-blocking page-flip on a pipe. */
>  static void
>  do_flip(data_t *data, igt_fb_t *fb)
> @@ -430,6 +459,32 @@ test_basic(data_t *data, enum pipe pipe, igt_output_t *output, uint32_t flags)
>  	igt_remove_fb(data->drm_fd, &data->fb0);
>  }
>  
> +/* VRR on Non-VRR panel: VRR should not be enabled on the Non-VRR panel.
> + * Kernel should reject the commit.
> + */
> +static void
> +test_negative_basic(data_t *data, enum pipe pipe,
> +		    igt_output_t *output, uint32_t flags)
> +{
> +	int ret;
> +
> +	igt_info("VRR Negative Test execution on %s, PIPE_%s.\n",
> +			output->name, kmstest_pipe_name(pipe));
> +
> +	prepare_negative_test(data, output, pipe);
> +	igt_pipe_set_prop_value(&data->display, pipe, IGT_CRTC_VRR_ENABLED, 1);
> +
> +	ret = igt_display_try_commit2(&data->display, COMMIT_ATOMIC);
> +	igt_assert_f(ret == 0, "VRR shouln't be enabled on Non-VRR panel.\n");

No this is not correct since in the kernel, if its a non VRR panel then it will just
do the modeset without enabling VRR so you will just see the visual artifacts but not reject it.

Manasi

> +
> +	/* Clean-up */
> +	igt_plane_set_fb(data->primary, NULL);
> +	igt_output_set_pipe(output, PIPE_NONE);
> +	set_vrr_on_pipe(data, pipe, false);
> +
> +	igt_remove_fb(data->drm_fd, &data->fb0);
> +}
> +
>  /* Runs tests on outputs that are VRR capable. */
>  static void
>  run_vrr_test(data_t *data, test_t test, uint32_t flags)
> @@ -439,8 +494,14 @@ run_vrr_test(data_t *data, test_t test, uint32_t flags)
>  	for_each_connected_output(&data->display, output) {
>  		enum pipe pipe;
>  
> -		if (!has_vrr(output))
> -			continue;
> +		/* For Negative tests, panel should be non-vrr. */
> +		if (flags & TEST_NEGATIVE) {
> +			if (has_vrr(output))
> +				continue;
> +		} else {
> +			if (!has_vrr(output))
> +				continue;
> +		}
>  
>  		for_each_pipe(&data->display, pipe) {
>  			if (igt_pipe_connector_valid(pipe, output)) {
> @@ -486,6 +547,10 @@ igt_main
>  	igt_subtest_with_dynamic("flipline")
>  		run_vrr_test(&data, test_basic, TEST_FLIPLINE);
>  
> +	igt_describe("Make sure that VRR should not be enabled on the Non-VRR panel.");
> +	igt_subtest_with_dynamic("negative-basic")
> +		run_vrr_test(&data, test_negative_basic, TEST_NEGATIVE);
> +
>  	igt_fixture {
>  		igt_display_fini(&data.display);
>  	}
> -- 
> 2.35.0
> 


More information about the igt-dev mailing list