[igt-dev] [PATCH i-g-t 2/2] lib/igt_fb: Add support for 10bpc ARGB/ABGR

Chris Wilson chris at chris-wilson.co.uk
Thu Oct 3 20:09:12 UTC 2019


Quoting Ville Syrjala (2019-10-03 20:58:54)
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
> 
> Hook up conversion routines for 10bpc ARGB/ABGR formats.
> Cairo only has the RGB30 without alpha so we'll do the
> rendering with floats and use pixman to convert.
> 
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> ---
>  lib/igt_fb.c | 17 +++++++++++++++++
>  1 file changed, 17 insertions(+)
> 
> diff --git a/lib/igt_fb.c b/lib/igt_fb.c
> index db789ae79458..8b47cf975598 100644
> --- a/lib/igt_fb.c
> +++ b/lib/igt_fb.c
> @@ -175,6 +175,18 @@ static const struct format_desc_struct {
>           .num_planes = 1, .plane_bpp = { 32, },
>           .hsub = 1, .vsub = 1,
>         },
> +       { .name = "ARGB2101010", .depth = 30, .drm_id = DRM_FORMAT_ARGB2101010,
> +         .cairo_id = CAIRO_FORMAT_INVALID,
> +         .pixman_id = PIXMAN_a2r10g10b10,
> +         .num_planes = 1, .plane_bpp = { 32, },
> +         .hsub = 1, .vsub = 1,
> +       },
> +       { .name = "ABGR2101010", .depth = -1, .drm_id = DRM_FORMAT_ABGR2101010,
> +         .cairo_id = CAIRO_FORMAT_INVALID,
> +         .pixman_id = PIXMAN_a2b10g10r10,
> +         .num_planes = 1, .plane_bpp = { 32, },
> +         .hsub = 1, .vsub = 1,
> +       },

No typos in the name this time.

>         { .name = "XRGB16161616F", .depth = -1, .drm_id = DRM_FORMAT_XRGB16161616F,
>           .cairo_id = CAIRO_FORMAT_RGBA128F,
>           .num_planes = 1, .plane_bpp = { 64, },
> @@ -313,6 +325,7 @@ static const struct format_desc_struct {
>         },
>         { .name = "IGT-FLOAT", .depth = -1, .drm_id = IGT_FORMAT_FLOAT,
>           .cairo_id = CAIRO_FORMAT_INVALID,
> +         .pixman_id = PIXMAN_rgba_float,
>           .num_planes = 1, .plane_bpp = { 128 },
>         },
>  };
> @@ -3110,6 +3123,10 @@ static void create_cairo_surface__convert(int fd, struct igt_fb *fb)
>                 default:
>                         igt_assert_f(0, "Unsupported format %u", f->cairo_id);
>                 }
> +       } else if (PIXMAN_FORMAT_A(f->pixman_id) &&
> +                  PIXMAN_FORMAT_R(f->pixman_id) > 8) {
> +               cairo_id = CAIRO_FORMAT_RGBA128F;
> +               drm_format = IGT_FORMAT_FLOAT;

Fits the description. Priority order in if-else looks fine.

Reviewed-by: Chris Wilson <chris at chris-wilson.co.uk>
-Chris


More information about the igt-dev mailing list