[igt-dev] [PATCH i-g-t 1/2] lib/igt_fb: Add XBGR2101010 support via pixman
Chris Wilson
chris at chris-wilson.co.uk
Mon Sep 30 19:35:11 UTC 2019
Quoting Ville Syrjala (2019-09-18 14:51:55)
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
> Use pixman to swizzle cairo RGB30 into XBGR2101010.
>
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> ---
> lib/igt_fb.c | 9 +++++++++
> 1 file changed, 9 insertions(+)
>
> diff --git a/lib/igt_fb.c b/lib/igt_fb.c
> index bad3eeca4132..612c25d5baed 100644
> --- a/lib/igt_fb.c
> +++ b/lib/igt_fb.c
> @@ -157,6 +157,12 @@ static const struct format_desc_struct {
> .num_planes = 1, .plane_bpp = { 32, },
> .hsub = 1, .vsub = 1,
> },
> + { .name = "XBGB2101010", .depth = -1, .drm_id = DRM_FORMAT_XBGR2101010,
> + .cairo_id = CAIRO_FORMAT_INVALID,
> + .pixman_id = PIXMAN_x2b10g10r10,
> + .num_planes = 1, .plane_bpp = { 32, },
> + .hsub = 1, .vsub = 1,
> + },
That's self-consistent.
> { .name = "ARGB8888", .depth = 32, .drm_id = DRM_FORMAT_ARGB8888,
> .cairo_id = CAIRO_FORMAT_ARGB32,
> .pixman_id = PIXMAN_a8r8g8b8,
> @@ -3107,6 +3113,9 @@ static void create_cairo_surface__convert(int fd, struct igt_fb *fb)
> } else if (PIXMAN_FORMAT_A(f->pixman_id)) {
> cairo_id = CAIRO_FORMAT_ARGB32;
> drm_format = DRM_FORMAT_ARGB8888;
> + } else if (PIXMAN_FORMAT_R(f->pixman_id) > 8) {
> + cairo_id = CAIRO_FORMAT_RGB30;
> + drm_format = DRM_FORMAT_XRGB2101010;
A little less sure about this rule, but if it ever needs extending for
more formats, it should hopefully become quickly apparent.
Reviewed-by: Chris Wilson <chris at chris-wilson.co.uk>
-Chris
More information about the igt-dev
mailing list