Add option -o <number>, which can test only one specified mode.

Each mode line has a number just like '[i]'. So we can only test the specified mode with giving the number of mode to '-o' parameter.

Signed-off-by: Yi Sun <yi.sun@intel.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
Yi Sun 2012-09-25 17:13:17 +08:00 committed by Daniel Vetter
parent d00f72a01b
commit 53895acbe2

View File

@ -72,6 +72,7 @@ int dump_info = 0, test_all_modes =0, test_preferred_mode = 0, force_mode = 0,
int sleep_between_modes = 5; int sleep_between_modes = 5;
uint32_t depth = 24, stride, bpp; uint32_t depth = 24, stride, bpp;
int qr_code = 0; int qr_code = 0;
int only_one_mode = 0, specified_mode_num = 0;
drmModeModeInfo force_timing; drmModeModeInfo force_timing;
@ -193,8 +194,10 @@ static void dump_connectors_fd(int drmfd)
printf(" modes:\n"); printf(" modes:\n");
printf(" name refresh (Hz) hdisp hss hse htot vdisp " printf(" name refresh (Hz) hdisp hss hse htot vdisp "
"vss vse vtot flags type clock\n"); "vss vse vtot flags type clock\n");
for (j = 0; j < connector->count_modes; j++) for (j = 0; j < connector->count_modes; j++){
fprintf(stdout, "[%d]", j );
kmstest_dump_mode(&connector->modes[j]); kmstest_dump_mode(&connector->modes[j]);
}
drmModeFreeConnector(connector); drmModeFreeConnector(connector);
} }
@ -275,6 +278,12 @@ static void connector_find_preferred_mode(struct connector *c)
} }
} }
if ( only_one_mode ){
c->mode = connector->modes[specified_mode_num];
if (c->mode.type & DRM_MODE_TYPE_PREFERRED)
c->mode_valid = 1;
}
if (!c->mode_valid) { if (!c->mode_valid) {
if (connector->count_modes > 0) { if (connector->count_modes > 0) {
/* use the first mode as test mode */ /* use the first mode as test mode */
@ -318,7 +327,7 @@ static void connector_find_preferred_mode(struct connector *c)
c->crtc = resources->crtcs[i]; c->crtc = resources->crtcs[i];
c->pipe = i; c->pipe = i;
if(test_preferred_mode || force_mode) if(test_preferred_mode || force_mode || only_one_mode)
resources->crtcs[i] = 0; resources->crtcs[i] = 0;
c->connector = connector; c->connector = connector;
@ -525,7 +534,7 @@ set_mode(struct connector *c)
gem_close(drm_fd, fb_info.gem_handle); gem_close(drm_fd, fb_info.gem_handle);
fprintf(stdout, "CRTS(%u):",c->crtc); fprintf(stdout, "CRTS(%u):[%d]",c->crtc, j);
kmstest_dump_mode(&c->mode); kmstest_dump_mode(&c->mode);
if (drmModeSetCrtc(drm_fd, c->crtc, fb_id, 0, 0, if (drmModeSetCrtc(drm_fd, c->crtc, fb_id, 0, 0,
&c->id, 1, &c->mode)) { &c->id, 1, &c->mode)) {
@ -585,7 +594,7 @@ int update_display(void)
dump_crtcs_fd(drm_fd); dump_crtcs_fd(drm_fd);
} }
if (test_preferred_mode || test_all_modes || force_mode) { if (test_preferred_mode || test_all_modes || force_mode || only_one_mode) {
/* Find any connected displays */ /* Find any connected displays */
for (c = 0; c < resources->count_connectors; c++) { for (c = 0; c < resources->count_connectors; c++) {
connectors[c].id = resources->connectors[c]; connectors[c].id = resources->connectors[c];
@ -596,7 +605,7 @@ int update_display(void)
return 1; return 1;
} }
static char optstr[] = "hiaf:s:d:p:mrt"; static char optstr[] = "hiaf:s:d:p:mrto:";
static void __attribute__((noreturn)) usage(char *name) static void __attribute__((noreturn)) usage(char *name)
{ {
@ -609,6 +618,7 @@ static void __attribute__((noreturn)) usage(char *name)
fprintf(stderr, "\t-m\ttest the preferred mode\n"); fprintf(stderr, "\t-m\ttest the preferred mode\n");
fprintf(stderr, "\t-t\tuse a tiled framebuffer\n"); fprintf(stderr, "\t-t\tuse a tiled framebuffer\n");
fprintf(stderr, "\t-r\tprint a QR code on the screen whose content is \"pass\" for the automatic test\n"); fprintf(stderr, "\t-r\tprint a QR code on the screen whose content is \"pass\" for the automatic test\n");
fprintf(stderr, "\t-o\t<number of the mode>\tonly test specified mode\n");
fprintf(stderr, "\t-f\t<clock MHz>,<hdisp>,<hsync-start>,<hsync-end>,<htotal>,\n"); fprintf(stderr, "\t-f\t<clock MHz>,<hdisp>,<hsync-start>,<hsync-end>,<htotal>,\n");
fprintf(stderr, "\t\t<vdisp>,<vsync-start>,<vsync-end>,<vtotal>\n"); fprintf(stderr, "\t\t<vdisp>,<vsync-start>,<vsync-end>,<vtotal>\n");
fprintf(stderr, "\t\ttest force mode\n"); fprintf(stderr, "\t\ttest force mode\n");
@ -701,6 +711,10 @@ int main(int argc, char **argv)
case 'r': case 'r':
qr_code = 1; qr_code = 1;
break; break;
case 'o':
only_one_mode = 1;
specified_mode_num = atoi(optarg);
break;
default: default:
fprintf(stderr, "unknown option %c\n", c); fprintf(stderr, "unknown option %c\n", c);
/* fall through */ /* fall through */
@ -710,7 +724,7 @@ int main(int argc, char **argv)
} }
} }
if (!test_all_modes && !force_mode && !dump_info && if (!test_all_modes && !force_mode && !dump_info &&
!test_preferred_mode) !test_preferred_mode && !only_one_mode)
test_all_modes = 1; test_all_modes = 1;
drm_fd = drm_open_any(); drm_fd = drm_open_any();