[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