OSDN Git Service

modetest: Make RGB565 pwetty too
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Thu, 18 Apr 2013 14:26:52 +0000 (17:26 +0300)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Wed, 22 May 2013 10:13:12 +0000 (13:13 +0300)
Render the crosshairs for 565 and x888/a888 formats.

v2: Use the drm format to determine cairo format

Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
tests/modetest/buffers.c

index 9b2bf72..b75cca7 100644 (file)
@@ -661,15 +661,32 @@ fill_smpte(const struct format_info *info, void *planes[3], unsigned int width,
 #define BLUE  0
 
 static void
-make_pwetty(void *data, int width, int height, int stride)
+make_pwetty(void *data, int width, int height, int stride, uint32_t format)
 {
 #ifdef HAVE_CAIRO
        cairo_surface_t *surface;
        cairo_t *cr;
        int x, y;
+       cairo_format_t cairo_format;
+
+       /* we can ignore the order of R,G,B channels */
+       switch (format) {
+       case DRM_FORMAT_XRGB8888:
+       case DRM_FORMAT_ARGB8888:
+       case DRM_FORMAT_XBGR8888:
+       case DRM_FORMAT_ABGR8888:
+               cairo_format = CAIRO_FORMAT_ARGB32;
+               break;
+       case DRM_FORMAT_RGB565:
+       case DRM_FORMAT_BGR565:
+               cairo_format = CAIRO_FORMAT_RGB16_565;
+               break;
+       default:
+               return;
+       }
 
        surface = cairo_image_surface_create_for_data(data,
-                                                     CAIRO_FORMAT_ARGB32,
+                                                     cairo_format,
                                                      width, height,
                                                      stride);
        cr = cairo_create(surface);
@@ -779,6 +796,7 @@ fill_tiles_rgb16(const struct format_info *info, unsigned char *mem,
                 unsigned int width, unsigned int height, unsigned int stride)
 {
        const struct rgb_info *rgb = &info->rgb;
+       unsigned char *mem_base = mem;
        unsigned int x, y;
 
        for (y = 0; y < height; ++y) {
@@ -795,6 +813,8 @@ fill_tiles_rgb16(const struct format_info *info, unsigned char *mem,
                }
                mem += stride;
        }
+
+       make_pwetty(mem_base, width, height, stride, info->format);
 }
 
 static void
@@ -842,7 +862,7 @@ fill_tiles_rgb32(const struct format_info *info, unsigned char *mem,
                mem += stride;
        }
 
-       make_pwetty(mem_base, width, height, stride);
+       make_pwetty(mem_base, width, height, stride, info->format);
 }
 
 static void