Compiler complained on crc_lowres and crc_hires2 being uninitialized and indeed, display_commit_mode() seems to have intention of retruning the value through the parameter that is only a single pointer. This couses only the local copy of the pointer, the one inside display_commit_mode(), to be overwritten. Let's fix that! Also add missing hires crc comparison (M. Kahola). v2: make display_commit_mode return just the last CRC Cc: Mika Kahola <mika.kahola@xxxxxxxxx> Cc: Maarten Lankhorst <maarten.lankhorst@xxxxxxxxxxxxxxx> Signed-off-by: Arkadiusz Hiler <arkadiusz.hiler@xxxxxxxxx> --- tests/kms_plane_lowres.c | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/tests/kms_plane_lowres.c b/tests/kms_plane_lowres.c index 85d3145d..a5518f17 100644 --- a/tests/kms_plane_lowres.c +++ b/tests/kms_plane_lowres.c @@ -125,11 +125,12 @@ test_fini(data_t *data, igt_output_t *output, enum pipe pipe) data->fb = NULL; } -static int +static void display_commit_mode(igt_display_t *display, igt_pipe_crc_t *pipe_crc, - enum pipe pipe, int flags, igt_crc_t *crc) + enum pipe pipe, int flags, igt_crc_t **out_crc) { char buf[256]; + igt_crc_t *crcs; struct drm_event *e = (void *)buf; unsigned int vblank_start, vblank_stop; int n, ret; @@ -148,10 +149,14 @@ display_commit_mode(igt_display_t *display, igt_pipe_crc_t *pipe_crc, igt_assert_eq(e->type, DRM_EVENT_FLIP_COMPLETE); igt_reset_timeout(); - n = igt_pipe_crc_get_crcs(pipe_crc, vblank_stop - vblank_start, &crc); + n = igt_pipe_crc_get_crcs(pipe_crc, vblank_stop - vblank_start, &crcs); igt_assert_eq(n, vblank_stop - vblank_start); - return n; + /* there is no need to return all the intermediary CRCs */ + /* so let's return just the last one */ + *out_crc = malloc(sizeof(igt_crc_t)); + memcpy(*out_crc, &crcs[n-1], sizeof(igt_crc_t)); + free(crcs); } static void @@ -252,7 +257,8 @@ test_plane_position_with_output(data_t *data, enum pipe pipe, check_mode(&mode_lowres, mode2); - display_commit_mode(&data->display, pipe_crc, pipe, flags, crc_lowres); + display_commit_mode(&data->display, pipe_crc, pipe, flags, &crc_lowres); + free(crc_lowres); igt_assert_plane_visible(data->drm_fd, pipe, false); @@ -264,10 +270,15 @@ test_plane_position_with_output(data_t *data, enum pipe pipe, check_mode(mode1, mode3); - display_commit_mode(&data->display, pipe_crc, pipe, flags, crc_hires2); + display_commit_mode(&data->display, pipe_crc, pipe, flags, &crc_hires2); igt_assert_plane_visible(data->drm_fd, pipe, true); + igt_assert_crc_equal(crc_hires1, crc_hires2); + + free(crc_hires1); + free(crc_hires2); + igt_pipe_crc_stop(pipe_crc); igt_pipe_crc_free(pipe_crc); -- 2.13.6 _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx