Sink CRC is the most reliable way to test PSR. However in some platforms apparently auto generated packages force panel to keep calculating CRC invalidating our current sink crc check over debugfs. So, this manual test help us to find possible gaps on this platforms where we cannot trust on sink crc checks. Signed-off-by: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> --- tests/kms_psr_sink_crc.c | 74 ++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 68 insertions(+), 6 deletions(-) diff --git a/tests/kms_psr_sink_crc.c b/tests/kms_psr_sink_crc.c index 155c25f..3853031 100644 --- a/tests/kms_psr_sink_crc.c +++ b/tests/kms_psr_sink_crc.c @@ -26,6 +26,7 @@ #include <stdbool.h> #include <stdio.h> #include <string.h> +#include <termios.h> #include "ioctl_wrappers.h" #include "drmtest.h" @@ -37,6 +38,7 @@ #include "igt_aux.h" bool running_with_psr_disabled; +bool manual; #define CRC_BLACK "000000000000" @@ -244,6 +246,9 @@ static void get_sink_crc(data_t *data, char *crc) { int ret; FILE *file; + if (manual) + return; + file = igt_debugfs_fopen("i915_sink_crc_eDP1", "r"); igt_require(file); @@ -271,6 +276,9 @@ static bool is_green(char *crc) unsigned int rh, gh, bh, mask; int ret; + if (manual) + return false; + sscanf(color_mask, "%4x", &mask); memcpy(rs, &crc[0], 4); @@ -293,6 +301,31 @@ static bool is_green(char *crc) (bh & mask) == 0); } +static void assert(bool condition, const char *debug_msg) +{ + if (manual) { + struct termios oldt, newt; + char c; + + igt_info("%s? [Y/n]: ", debug_msg); + + tcgetattr(STDIN_FILENO, &oldt); + newt = oldt; + newt.c_lflag &= ~(ICANON); + tcsetattr(STDIN_FILENO, TCSANOW, &newt); + c = getchar(); + if (c != '\n') + igt_info("\n"); + tcsetattr(STDIN_FILENO, TCSANOW, &oldt); + + if (c == 'n' || c == 'N') + igt_fail(-1); + } else { + igt_debug("%s\n", debug_msg); + igt_assert(condition); + } +} + static void test_crc(data_t *data) { uint32_t handle = data->fb_white.gem_handle; @@ -300,18 +333,19 @@ static void test_crc(data_t *data) void *ptr; char ref_crc[12]; char crc[12]; + char manual_debug[50] = ""; igt_plane_set_fb(data->primary, &data->fb_green); igt_display_commit(&data->display); /* Confirm that screen became Green */ get_sink_crc(data, ref_crc); - igt_assert(is_green(ref_crc)); + assert(is_green(ref_crc), "screen GREEN"); /* Confirm screen stays Green after PSR got active */ igt_assert(wait_psr_entry(data, 10)); get_sink_crc(data, ref_crc); - igt_assert(is_green(ref_crc)); + assert(is_green(ref_crc), "screen GREEN"); /* Setting a secondary fb/plane */ switch (data->test_plane) { @@ -325,7 +359,10 @@ static void test_crc(data_t *data) /* Confirm it is not Green anymore */ igt_assert(wait_psr_entry(data, 10)); get_sink_crc(data, ref_crc); - igt_assert(!is_green(ref_crc)); + if (data->test_plane == PRIMARY) + assert(!is_green(ref_crc), "screen WHITE"); + else + assert(!is_green(ref_crc), "GREEN background with WHITE box"); switch (data->op) { case PAGE_FLIP: @@ -333,7 +370,8 @@ static void test_crc(data_t *data) igt_assert(drmModePageFlip(data->drm_fd, data->crtc_id, data->fb_green.fb_id, 0, NULL) == 0); get_sink_crc(data, crc); - igt_assert(is_green(crc)); + assert(is_green(crc), "screen GREEN"); + strcpy(manual_debug, "still GREEN"); break; case MMAP_GTT: ptr = gem_mmap__gtt(data->drm_fd, handle, data->mod_size, @@ -342,6 +380,8 @@ static void test_crc(data_t *data) I915_GEM_DOMAIN_GTT, I915_GEM_DOMAIN_GTT); memset(ptr, 0xcc, data->mod_size); munmap(ptr, data->mod_size); + strcpy(manual_debug, + "BLACK or TRANSPARENT mark on top of plane in test"); break; case MMAP_GTT_WAITING: ptr = gem_mmap__gtt(data->drm_fd, handle, data->mod_size, @@ -352,7 +392,11 @@ static void test_crc(data_t *data) /* Printing white on white so the screen shouldn't change */ memset(ptr, 0xff, data->mod_size); get_sink_crc(data, crc); - igt_assert(strcmp(ref_crc, crc) == 0); + if (data->test_plane == PRIMARY) + assert(strcmp(ref_crc, crc) == 0, "screen WHITE"); + else + assert(strcmp(ref_crc, crc) == 0, + "GREEN background with WHITE box"); igt_info("Waiting 10s...\n"); sleep(10); @@ -360,6 +404,8 @@ static void test_crc(data_t *data) /* Now lets print black to change the screen */ memset(ptr, 0, data->mod_size); munmap(ptr, data->mod_size); + strcpy(manual_debug, + "BLACK or TRANSPARENT mark on top of plane in test"); break; case MMAP_CPU: ptr = gem_mmap__cpu(data->drm_fd, handle, 0, data->mod_size, PROT_WRITE); @@ -368,26 +414,34 @@ static void test_crc(data_t *data) memset(ptr, 0, data->mod_size); munmap(ptr, data->mod_size); gem_sw_finish(data->drm_fd, handle); + strcpy(manual_debug, + "BLACK or TRANSPARENT mark on top of plane in test"); break; case BLT: fill_blt(data, handle, 0); + strcpy(manual_debug, + "BLACK or TRANSPARENT mark on top of plane in test"); break; case RENDER: fill_render(data, handle, 0); + strcpy(manual_debug, + "BLACK or TRANSPARENT mark on top of plane in test"); break; case PLANE_MOVE: /* Only in use when testing Sprite and Cursor */ igt_plane_set_position(test_plane, 500, 500); igt_display_commit(&data->display); + strcpy(manual_debug, "White box moved to 500x500"); break; case PLANE_ONOFF: /* Only in use when testing Sprite and Cursor */ igt_plane_set_fb(test_plane, NULL); igt_display_commit(&data->display); + strcpy(manual_debug, "screen GREEN"); break; } get_sink_crc(data, crc); - igt_assert(strcmp(ref_crc, crc) != 0); + assert(strcmp(ref_crc, crc) != 0, manual_debug); } static void test_cleanup(data_t *data) { @@ -480,6 +534,9 @@ static int opt_handler(int opt, int opt_index) case 'n': running_with_psr_disabled = true; break; + case 'm': + manual = true; + break; default: igt_assert(0); } @@ -493,6 +550,7 @@ int main(int argc, char *argv[]) " --no-psr\tRun test without PSR to check the CRC test logic."; static struct option long_options[] = { {"no-psr", 0, 0, 'n'}, + {"manual", 0, 0, 'm'}, { 0, 0, 0, 0 } }; data_t data = {}; @@ -507,6 +565,10 @@ int main(int argc, char *argv[]) kmstest_set_vt_graphics_mode(); data.devid = intel_get_drm_devid(data.drm_fd); + if ((IS_VALLEYVIEW(data.devid) || IS_CHERRYVIEW(data.devid)) && + !manual) + igt_skip("Sink CRC is unreliable on this platform when PSR is enabled. Test available only on manual mode. Run again with --manual\n"); + igt_skip_on(!psr_enabled(&data)); data.bufmgr = drm_intel_bufmgr_gem_init(data.drm_fd, 4096); -- 1.9.3 _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx