[igt-dev] [i-g-t 1/2] tests/kms_color: Fix multiple failures in deep-color tests

Bhanuprakash Modem bhanuprakash.modem at intel.com
Thu Jul 14 08:14:08 UTC 2022


This patch will sanitize the system state before starting the subtest.
And also, preserve connector's mode to use all over the subtets, since
igt_display_reset() will clear it.

Fixes: https://gitlab.freedesktop.org/drm/intel/-/issues/6198
Fixes: https://gitlab.freedesktop.org/drm/intel/-/issues/4137
Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
---
 tests/kms_color.c | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/tests/kms_color.c b/tests/kms_color.c
index 6ea721f1..8c15c7be 100644
--- a/tests/kms_color.c
+++ b/tests/kms_color.c
@@ -839,6 +839,7 @@ run_deep_color_tests_for_pipe(data_t *data, enum pipe p)
 		if (!panel_supports_deep_color(data->drm_fd, output->name))
 			continue;
 
+		igt_display_reset(&data->display);
 		igt_output_set_prop_value(output, IGT_CONNECTOR_MAX_BPC, 10);
 		igt_output_set_pipe(output, p);
 		igt_display_commit_atomic(&data->display, DRM_MODE_ATOMIC_ALLOW_MODESET, NULL);
@@ -850,7 +851,10 @@ run_deep_color_tests_for_pipe(data_t *data, enum pipe p)
 		data->color_depth = 10;
 		data->drm_format = DRM_FORMAT_XRGB2101010;
 		data->output = output;
-		data->mode = igt_output_get_mode(data->output);
+
+		data->mode = malloc(sizeof(drmModeModeInfo));
+		igt_assert(data->mode);
+		memcpy(data->mode, igt_output_get_mode(data->output), sizeof(drmModeModeInfo));
 
 		igt_dynamic_f("pipe-%s-%s-gamma", kmstest_pipe_name(p), output->name) {
 			igt_display_reset(&data->display);
@@ -884,6 +888,8 @@ run_deep_color_tests_for_pipe(data_t *data, enum pipe p)
 			igt_assert(ret);
 		}
 
+		free(data->mode);
+
 		break;
 	}
 
-- 
2.35.1



More information about the igt-dev mailing list