mirror of
https://github.com/tiagovignatti/intel-gpu-tools.git
synced 2025-06-11 01:46:14 +00:00
tests/testdisplay.c: Add a option '-r'.
With the option '-r', the testdisplay could paint a 2-D bar code(QR bar code) on the screen. The word "pass" is hiden in the bar code image. Further more, with this option, testdisplay will wait until a system signal 'SIGUSR1' coming after each mode setting. This function is for another program to control testdisplay. danvet: Fix up the missing static. Signed-off-by: Yi Sun <yi.sun@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
3b0f80308a
commit
41fe811feb
@ -774,5 +774,6 @@ void kmstest_dump_mode(drmModeModeInfo *mode)
|
|||||||
mode->flags,
|
mode->flags,
|
||||||
mode->type,
|
mode->type,
|
||||||
mode->clock);
|
mode->clock);
|
||||||
|
fflush(stdout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BIN
tests/pass.png
Normal file
BIN
tests/pass.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 376 B |
@ -62,12 +62,16 @@
|
|||||||
#include "drmtest.h"
|
#include "drmtest.h"
|
||||||
#include "testdisplay.h"
|
#include "testdisplay.h"
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <signal.h>
|
||||||
|
|
||||||
drmModeRes *resources;
|
drmModeRes *resources;
|
||||||
int drm_fd, modes;
|
int drm_fd, modes;
|
||||||
int dump_info = 0, test_all_modes =0, test_preferred_mode = 0, force_mode = 0,
|
int dump_info = 0, test_all_modes =0, test_preferred_mode = 0, force_mode = 0,
|
||||||
test_plane, enable_tiling;
|
test_plane, enable_tiling;
|
||||||
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;
|
||||||
|
|
||||||
drmModeModeInfo force_timing;
|
drmModeModeInfo force_timing;
|
||||||
|
|
||||||
@ -334,6 +338,40 @@ paint_color_key(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void paint_image(cairo_t *cr, const char *file)
|
||||||
|
{
|
||||||
|
int img_x, img_y, img_w, img_h, img_w_o, img_h_o;
|
||||||
|
double img_w_scale, img_h_scale;
|
||||||
|
|
||||||
|
cairo_surface_t *image;
|
||||||
|
|
||||||
|
img_y = height * (0.10 );
|
||||||
|
img_h = height * 0.08 * 4;
|
||||||
|
img_w = img_h;
|
||||||
|
|
||||||
|
img_x = (width / 2) - (img_w / 2);
|
||||||
|
|
||||||
|
image = cairo_image_surface_create_from_png(file);
|
||||||
|
|
||||||
|
img_w_o = cairo_image_surface_get_width(image);
|
||||||
|
img_h_o = cairo_image_surface_get_height(image);
|
||||||
|
|
||||||
|
cairo_translate(cr, img_x, img_y);
|
||||||
|
|
||||||
|
fprintf(stderr, "drew %dx%d image at %d,%d\n", img_w, img_h,
|
||||||
|
img_x, img_y);
|
||||||
|
|
||||||
|
img_w_scale = (double)img_w / (double)img_w_o;
|
||||||
|
img_h_scale = (double)img_h / (double)img_h_o;
|
||||||
|
cairo_scale(cr, img_w_scale, img_h_scale);
|
||||||
|
|
||||||
|
cairo_set_source_surface(cr, image, 0, 0);
|
||||||
|
cairo_scale(cr, 1, 1);
|
||||||
|
|
||||||
|
cairo_paint(cr);
|
||||||
|
cairo_surface_destroy(image);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
paint_output_info(cairo_t *cr, int l_width, int l_height, void *priv)
|
paint_output_info(cairo_t *cr, int l_width, int l_height, void *priv)
|
||||||
{
|
{
|
||||||
@ -419,6 +457,26 @@ paint_output_info(cairo_t *cr, int l_width, int l_height, void *priv)
|
|||||||
cairo_set_source_rgb(cr, 1, 1, 1);
|
cairo_set_source_rgb(cr, 1, 1, 1);
|
||||||
cairo_fill(cr);
|
cairo_fill(cr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (qr_code)
|
||||||
|
paint_image(cr, "./pass.png");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sighandler(int signo)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void set_single(void)
|
||||||
|
{
|
||||||
|
int sigs[] = { SIGUSR1 };
|
||||||
|
struct sigaction sa;
|
||||||
|
sa.sa_handler = sighandler;
|
||||||
|
|
||||||
|
sigemptyset(&sa.sa_mask);
|
||||||
|
|
||||||
|
if (sigaction(sigs[0], &sa, NULL) == -1)
|
||||||
|
perror("Could not set signal handler");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -480,9 +538,14 @@ set_mode(struct connector *c)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sleep_between_modes && test_all_modes)
|
if (sleep_between_modes && test_all_modes && !qr_code)
|
||||||
sleep(sleep_between_modes);
|
sleep(sleep_between_modes);
|
||||||
|
|
||||||
|
if (qr_code){
|
||||||
|
set_single();
|
||||||
|
pause();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(test_all_modes){
|
if(test_all_modes){
|
||||||
@ -536,7 +599,7 @@ int update_display(void)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char optstr[] = "hiaf:s:d:p:mt";
|
static char optstr[] = "hiaf:s:d:p:mrt";
|
||||||
|
|
||||||
static void usage(char *name)
|
static void usage(char *name)
|
||||||
{
|
{
|
||||||
@ -548,6 +611,7 @@ static void usage(char *name)
|
|||||||
fprintf(stderr, "\t-p\t<planew,h>,<crtcx,y>,<crtcw,h> test overlay plane\n");
|
fprintf(stderr, "\t-p\t<planew,h>,<crtcx,y>,<crtcw,h> test overlay plane\n");
|
||||||
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-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");
|
||||||
@ -558,7 +622,7 @@ static void usage(char *name)
|
|||||||
#define dump_resource(res) if (res) dump_##res()
|
#define dump_resource(res) if (res) dump_##res()
|
||||||
|
|
||||||
static gboolean input_event(GIOChannel *source, GIOCondition condition,
|
static gboolean input_event(GIOChannel *source, GIOCondition condition,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
gchar buf[2];
|
gchar buf[2];
|
||||||
gsize count;
|
gsize count;
|
||||||
@ -571,6 +635,24 @@ static gboolean input_event(GIOChannel *source, GIOCondition condition,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void enter_exec_path( char **argv )
|
||||||
|
{
|
||||||
|
char *exec_path = NULL;
|
||||||
|
char *pos = NULL;
|
||||||
|
short len_path = 0;
|
||||||
|
|
||||||
|
len_path = strlen( argv[0] );
|
||||||
|
exec_path = (char*) malloc(len_path);
|
||||||
|
|
||||||
|
memcpy(exec_path, argv[0], len_path);
|
||||||
|
pos = strrchr(exec_path, '/');
|
||||||
|
if (pos != NULL)
|
||||||
|
*(pos+1) = '\0';
|
||||||
|
|
||||||
|
chdir(exec_path);
|
||||||
|
free(exec_path);
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int c;
|
int c;
|
||||||
@ -579,6 +661,8 @@ int main(int argc, char **argv)
|
|||||||
GMainLoop *mainloop;
|
GMainLoop *mainloop;
|
||||||
float force_clock;
|
float force_clock;
|
||||||
|
|
||||||
|
enter_exec_path( argv );
|
||||||
|
|
||||||
opterr = 0;
|
opterr = 0;
|
||||||
while ((c = getopt(argc, argv, optstr)) != -1) {
|
while ((c = getopt(argc, argv, optstr)) != -1) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
@ -617,6 +701,9 @@ int main(int argc, char **argv)
|
|||||||
case 't':
|
case 't':
|
||||||
enable_tiling = 1;
|
enable_tiling = 1;
|
||||||
break;
|
break;
|
||||||
|
case 'r':
|
||||||
|
qr_code = 1;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "unknown option %c\n", c);
|
fprintf(stderr, "unknown option %c\n", c);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user