[i-g-t 11/16] tests/kms_color_chamelium: New subtests for Plane CTM

Bhanuprakash Modem bhanuprakash.modem at intel.com
Wed Jul 20 10:48:37 UTC 2022


To verify plane CTM, draw 3 rectangles using before colors with the
ctm matrix applied and verify the frame dump is equal to using after
colors with an identify ctm matrix.

v2:
* Rebase
* Dynamic subtests

Cc: Harry Wentland <harry.wentland at amd.com>
Cc: Ville Syrjälä <ville.syrjala at linux.intel.com>
Cc: Pekka Paalanen <ppaalanen at gmail.com>
Cc: Uma Shankar <uma.shankar at intel.com>
Cc: Kunal Joshi <kunal1.joshi at intel.com>
Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
---
 tests/kms_color_chamelium.c | 156 ++++++++++++++++++++++++++++++++++++
 1 file changed, 156 insertions(+)

diff --git a/tests/kms_color_chamelium.c b/tests/kms_color_chamelium.c
index e75a70ec..749a1ca8 100644
--- a/tests/kms_color_chamelium.c
+++ b/tests/kms_color_chamelium.c
@@ -643,6 +643,87 @@ static bool test_plane_degamma(data_t *data,
 	return ret;
 }
 
+static bool test_plane_ctm(data_t *data,
+			  igt_plane_t *plane,
+			  color_t *before,
+			  color_t *after,
+			  double *ctm_matrix,
+			  struct chamelium_port *port)
+{
+	igt_output_t *output = data->output;
+	igt_display_t *display = &data->display;
+	drmModeModeInfo *mode = data->mode;
+	struct igt_fb fb, fbref;
+	struct chamelium_frame_dump *frame_hardware;
+	bool ret = true;
+
+	igt_info("Plane CTM test is running on pipe-%s plane-%d(%s)\n",
+			kmstest_pipe_name(plane->pipe->pipe), plane->index,
+			kmstest_plane_type_name(plane->type));
+
+	igt_require(igt_plane_has_prop(plane, IGT_PLANE_CTM));
+
+	igt_output_set_pipe(output, plane->pipe->pipe);
+
+	/* Create a framebuffer at the size of the output. */
+	igt_assert(igt_create_fb(data->drm_fd,
+			      mode->hdisplay,
+			      mode->vdisplay,
+			      DRM_FORMAT_XRGB8888,
+			      DRM_FORMAT_MOD_LINEAR,
+			      &fb));
+
+	igt_assert(igt_create_fb(data->drm_fd,
+			      mode->hdisplay,
+			      mode->vdisplay,
+			      DRM_FORMAT_XRGB8888,
+			      DRM_FORMAT_MOD_LINEAR,
+			      &fbref));
+
+	disable_degamma(plane->pipe);
+	disable_ctm(plane->pipe);
+	disable_gamma(plane->pipe);
+
+	disable_plane_degamma(plane);
+	disable_plane_ctm(plane);
+	disable_plane_gamma(plane);
+
+	igt_plane_set_fb(plane, &fbref);
+	igt_display_commit2(display, display->is_atomic ?
+					COMMIT_ATOMIC : COMMIT_LEGACY);
+
+	/* Without CTM transformation. */
+	paint_rectangles(data, mode, after, &fbref);
+
+	/* With CTM transformation. */
+	paint_rectangles(data, mode, before, &fb);
+	igt_plane_set_fb(plane, &fb);
+	set_plane_ctm(plane, ctm_matrix);
+	igt_display_commit2(display, display->is_atomic ?
+				COMMIT_ATOMIC : COMMIT_LEGACY);
+
+	chamelium_capture(data->chamelium, port, 0, 0, 0, 0, 1);
+	frame_hardware =
+		chamelium_read_captured_frame(data->chamelium, 0);
+
+	/* Verify that the framebuffer reference of the software
+	 * computed output is equal to the frame dump of the CTM
+	 * matrix transformation output.
+	 */
+	ret = chamelium_frame_match_or_dump(data->chamelium, port,
+					     frame_hardware,
+					     &fbref,
+					     CHAMELIUM_CHECK_ANALOG);
+
+	disable_plane_ctm(plane);
+	igt_plane_set_fb(plane, NULL);
+	igt_output_set_pipe(output, PIPE_NONE);
+	igt_display_commit2(display, display->is_atomic ?
+					COMMIT_ATOMIC : COMMIT_LEGACY);
+
+	return ret;
+}
+
 static void
 prep_pipe(data_t *data, enum pipe p)
 {
@@ -802,6 +883,68 @@ run_ctm_tests_for_pipe(data_t *data, enum pipe p,
 	}
 }
 
+static void
+run_ctm_tests_for_plane(data_t *data, enum pipe pipe,
+			color_t *expected,
+			double *ctm,
+			int iter)
+{
+	double delta;
+	color_t red_green_blue[] = {
+		{ 1.0, 0.0, 0.0 },
+		{ 0.0, 1.0, 0.0 },
+		{ 0.0, 0.0, 1.0 }
+	};
+	igt_plane_t *plane;
+	int port_idx = test_setup(data, pipe);
+	int last_plane = (&data->display)->pipes[pipe].n_planes - 1;
+
+	igt_require(port_idx);
+
+	data->color_depth = 8;
+	delta = 1.0 / (1 << data->color_depth);
+	data->drm_format = DRM_FORMAT_XRGB8888;
+	data->mode = igt_output_get_mode(data->output);
+
+	igt_dynamic_f("pipe-%s-%s", kmstest_pipe_name(pipe), data->output->name) {
+		bool success = false;
+		int i, count = 0;
+
+		for_each_plane_on_pipe(&data->display, pipe, plane) {
+			if (!extended && j__ != 0 && j__ != last_plane)
+				continue;
+
+			success = false;
+
+			if (!iter)
+				success |= test_plane_ctm(data, plane,
+							  red_green_blue,
+							  expected, ctm,
+							  data->ports[port_idx]);
+
+			for (i = 0; i < iter; i++) {
+				expected[0].r =
+				expected[1].g =
+				expected[2].b =
+					ctm[0] + delta * (i - (iter/2));
+
+				success |= test_plane_ctm(data, plane,
+							  red_green_blue,
+							  expected, ctm,
+							  data->ports[port_idx]);
+				if (success)
+					break;
+			}
+
+			igt_assert(success);
+			count++;
+		}
+
+		if (!count)
+			igt_skip ("No valid planes found.\n");
+	}
+}
+
 static void
 run_limited_range_ctm_test_for_pipe(data_t *data, enum pipe p,
 		bool (*test_t)(data_t*, igt_plane_t*, struct chamelium_port*))
@@ -959,6 +1102,19 @@ run_tests_for_pipe(data_t *data)
 			}
 		}
 	}
+
+	for (i = 0; i < ARRAY_SIZE(ctm_tests); i++) {
+		igt_describe_f("%s", ctm_tests[i].desc);
+		igt_subtest_with_dynamic_f("plane-%s", ctm_tests[i].name) {
+			for_each_pipe(&data->display, pipe) {
+				run_ctm_tests_for_plane(data, pipe,
+							ctm_tests[i].colors,
+							ctm_tests[i].ctm,
+							ctm_tests[i].iter);
+			}
+		}
+	}
+
 }
 
 static int opt_handler(int opt, int opt_index, void *data)
-- 
2.35.1



More information about the Intel-gfx-trybot mailing list