diff options
author | Damien Lespiau <damien.lespiau@intel.com> | 2014-07-07 13:30:41 +0100 |
---|---|---|
committer | Damien Lespiau <damien.lespiau@intel.com> | 2014-07-07 17:59:52 +0100 |
commit | de538cfc7cd649216801829daffe602f4efee08a (patch) | |
tree | 3c1b12c88b98433ca7b328773a11391c057f9d20 /tests/kms_plane.c | |
parent | 202b2b9567606a016edf8293048ca4d67d9eba4f (diff) |
kms_plane: Make the gathering of reference CRCs test agnostic
We're going to add tests for panning. Both position and panning tests
share the need to grab reference CRCs of single coloured fb, so let's
separate this function from the position test.
Cc: Lei Liu <lei.a.liu@intel.com>
Cc: Yi Sun <yi.sun@intel.com>
Signed-off-by: Damien Lespiau <damien.lespiau@intel.com>
Diffstat (limited to 'tests/kms_plane.c')
-rw-r--r-- | tests/kms_plane.c | 104 |
1 files changed, 60 insertions, 44 deletions
diff --git a/tests/kms_plane.c b/tests/kms_plane.c index 5db09473..45c4a774 100644 --- a/tests/kms_plane.c +++ b/tests/kms_plane.c @@ -34,10 +34,60 @@ #include "igt_kms.h" typedef struct { + float red; + float green; + float blue; +} color_t; + +typedef struct { int drm_fd; igt_display_t display; + igt_pipe_crc_t *pipe_crc; } data_t; +static color_t green = { 0.0f, 1.0f, 0.0f }; + +/* + * Common code across all tests, acting on data_t + */ +static void test_init(data_t *data, enum pipe pipe) +{ + data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO); +} + +static void test_fini(data_t *data) +{ + igt_pipe_crc_free(data->pipe_crc); +} + +static void +test_grab_crc(data_t *data, igt_output_t *output, color_t *fb_color, + igt_crc_t *crc /* out */) +{ + struct igt_fb fb; + drmModeModeInfo *mode; + igt_plane_t *primary; + + primary = igt_output_get_plane(output, 0); + + mode = igt_output_get_mode(output); + igt_create_color_fb(data->drm_fd, mode->hdisplay, mode->vdisplay, + DRM_FORMAT_XRGB8888, + false, /* tiled */ + fb_color->red, fb_color->green, fb_color->blue, + &fb); + igt_plane_set_fb(primary, &fb); + + igt_display_commit(&data->display); + + igt_pipe_crc_collect_crc(data->pipe_crc, crc); + + igt_plane_set_fb(primary, NULL); + igt_display_commit(&data->display); + + igt_remove_fb(data->drm_fd, &fb); +} + /* * Plane position test. * - We start by grabbing a reference CRC of a full green fb being scanned @@ -51,7 +101,6 @@ typedef struct { typedef struct { data_t *data; - igt_pipe_crc_t *pipe_crc; igt_crc_t reference_crc; } test_position_t; @@ -83,46 +132,6 @@ create_fb_for_mode__position(data_t *data, drmModeModeInfo *mode, cairo_destroy(cr); } -static void -test_position_init(test_position_t *test, igt_output_t *output, enum pipe pipe) -{ - data_t *data = test->data; - struct igt_fb green_fb; - drmModeModeInfo *mode; - igt_plane_t *primary; - - test->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO); - - igt_output_set_pipe(output, pipe); - primary = igt_output_get_plane(output, 0); - - mode = igt_output_get_mode(output); - igt_create_color_fb(data->drm_fd, mode->hdisplay, mode->vdisplay, - DRM_FORMAT_XRGB8888, - false, /* tiled */ - 0.0, 1.0, 0.0, - &green_fb); - igt_plane_set_fb(primary, &green_fb); - - igt_display_commit(&data->display); - - igt_pipe_crc_collect_crc(test->pipe_crc, &test->reference_crc); - - igt_plane_set_fb(primary, NULL); - igt_display_commit(&data->display); - - igt_remove_fb(data->drm_fd, &green_fb); -} - -static void -test_position_fini(test_position_t *test, igt_output_t *output) -{ - igt_pipe_crc_free(test->pipe_crc); - - igt_output_set_pipe(output, PIPE_ANY); - igt_display_commit(&test->data->display); -} - enum { TEST_POSITION_FULLY_COVERED = 1 << 0, }; @@ -143,7 +152,11 @@ test_plane_position_with_output(data_t *data, igt_info("Testing connector %s using pipe %c plane %d\n", igt_output_name(output), pipe_name(pipe), plane); - test_position_init(&test, output, pipe); + test_init(data, pipe); + + test_grab_crc(data, output, &green, &test.reference_crc); + + igt_output_set_pipe(output, pipe); mode = igt_output_get_mode(output); primary = igt_output_get_plane(output, 0); @@ -168,7 +181,7 @@ test_plane_position_with_output(data_t *data, igt_display_commit(&data->display); - igt_pipe_crc_collect_crc(test.pipe_crc, &crc); + igt_pipe_crc_collect_crc(data->pipe_crc, &crc); if (flags & TEST_POSITION_FULLY_COVERED) igt_assert(igt_crc_equal(&test.reference_crc, &crc)); @@ -178,7 +191,10 @@ test_plane_position_with_output(data_t *data, igt_plane_set_fb(primary, NULL); igt_plane_set_fb(sprite, NULL); - test_position_fini(&test, output); + /* reset the constraint on the pipe */ + igt_output_set_pipe(output, PIPE_ANY); + + test_fini(data); } static void |