[Intel-gfx] [PATCH] tests/testdisplay.c: Add a option '-g' to save images which intended to paint on screen during each mode setting.

Ben Widawsky ben at bwidawsk.net
Wed Aug 1 05:21:51 CEST 2012


On 2012-07-31 18:51, Yi Sun wrote:
> That option will save all the images which are created and intended
> to paint on screen.
> The images will be saved in folder "saveimages" with PNG format.
>
> Signed-off-by: Yi Sun <yi.sun at intel.com>
>
> diff --git a/tests/testdisplay.c b/tests/testdisplay.c
> index 4430d07..2d1fdb0 100644
> --- a/tests/testdisplay.c
> +++ b/tests/testdisplay.c
> @@ -64,6 +64,7 @@
>
>  #include <stdlib.h>
>  #include <signal.h>
> +#include <sys/stat.h>
>
>  drmModeRes *resources;
>  int drm_fd, modes;
> @@ -72,6 +73,7 @@ int dump_info = 0, test_all_modes =0,
> test_preferred_mode = 0, force_mode = 0,
>  int sleep_between_modes = 5;
>  uint32_t depth = 24, stride, bpp;
>  int qr_code = 0;
> +int save_image = 0;
>
>  drmModeModeInfo force_timing;
>
> @@ -379,6 +381,8 @@ paint_output_info(cairo_t *cr, int l_width, int
> l_height, void *priv)
>  	cairo_text_extents_t name_extents, mode_extents;
>  	char name_buf[128], mode_buf[128];
>  	int i, x, y, modes_x, modes_y;
> +	static int count = 0;
> +	count++;
>
>  	/* Get text extents for each string */
>  	snprintf(name_buf, sizeof name_buf, "%s",
> @@ -460,6 +464,25 @@ paint_output_info(cairo_t *cr, int l_width, int
> l_height, void *priv)
>
>  	if (qr_code)
>  		paint_image(cr, "./pass.png");
> +
> +	if (save_image){
> +		char pngname[256];
> +		char *pos;
> +
> +		readlink("/proc/self/exe", pngname, sizeof(pngname));
> +		pos = strrchr(pngname, '/');
> +		*(pos + 1) = '\0';
> +
> +		strcat(pngname, "saveimages");
> +
> +		//judge whether folder mkdir existed, if not create it.
> +		if(access(pngname,0) == -1)
> +			if (mkdir( pngname,0777))
> +				fprintf (stderr, "error %d, %s\n", errno, strerror (errno));
> +
> +		sprintf(pngname, "%s/%d_%s@%d.png", pngname, count, c->mode.name,
> c->mode.vrefresh);

I think we've already decided we're willing to piss off the BSD folks, 
but just in case we haven't I googled around for a more portable way to 
do this. It seems argv[0] *may* be better, may not. In any case, this 
reminds me that maybe we should start noting things which won't work in 
non-linux operating systems.

I also find it comical that adding the argument, and writing the 
surface is like 5 lines, and the rest is all finding the damn executable 
path :-)

> +		cairo_surface_write_to_png( cairo_get_target(cr), pngname );
> +	}
>  }
>
>  static void sighandler(int signo)
> @@ -599,7 +622,7 @@ int update_display(void)
>  	return 1;
>  }
>
> -static char optstr[] = "hiaf:s:d:p:mrt";
> +static char optstr[] = "hiaf:s:d:p:mrtg";
>
>  static void usage(char *name)
>  {
> @@ -612,6 +635,7 @@ static void usage(char *name)
>  	fprintf(stderr, "\t-m\ttest the preferred mode\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-g\tsave images which is intended to paint on
> the screen as png files in folder \"saveimages\"\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\ttest force mode\n");
> @@ -704,6 +728,9 @@ int main(int argc, char **argv)
>  		case 'r':
>  			qr_code = 1;
>  			break;
> +		case 'g':
> +			save_image = 1;
> +			break;
>  		default:
>  			fprintf(stderr, "unknown option %c\n", c);
>  			/* fall through */




More information about the Intel-gfx mailing list