linuxOS_AP06/buildroot/package/weston/0018-HACK-gl-renderer-Workaround-dmabuf-import-attach-for.patch
2025-06-03 12:28:32 +08:00

70 lines
2.3 KiB
Diff

From 7266b2a0cb571d4926db2855aa8bca7c3a1558ae Mon Sep 17 00:00:00 2001
From: Jeffy Chen <jeffy.chen@rock-chips.com>
Date: Thu, 6 Dec 2018 18:53:05 +0800
Subject: [PATCH 18/95] HACK: gl-renderer: Workaround dmabuf import/attach for
old mali
Tested on px3se with libmali-utgard-400-r7p0-r3p0-wayland.so, the
mpp + waylandsink works.
Signed-off-by: Jeffy Chen <jeffy.chen@rock-chips.com>
---
libweston/renderer-gl/gl-renderer-internal.h | 2 ++
libweston/renderer-gl/gl-renderer.c | 13 ++++++++++++-
2 files changed, 14 insertions(+), 1 deletion(-)
diff --git a/libweston/renderer-gl/gl-renderer-internal.h b/libweston/renderer-gl/gl-renderer-internal.h
index 938aa30..703f88b 100644
--- a/libweston/renderer-gl/gl-renderer-internal.h
+++ b/libweston/renderer-gl/gl-renderer-internal.h
@@ -305,6 +305,8 @@ struct gl_renderer {
struct weston_log_scope *shader_scope;
struct dmabuf_allocator *allocator;
+
+ bool is_mali_egl;
};
static inline struct gl_renderer *
diff --git a/libweston/renderer-gl/gl-renderer.c b/libweston/renderer-gl/gl-renderer.c
index 6090cc8..b688e8f 100644
--- a/libweston/renderer-gl/gl-renderer.c
+++ b/libweston/renderer-gl/gl-renderer.c
@@ -3056,6 +3056,14 @@ import_simple_dmabuf(struct gl_renderer *gr,
}
}
+ /* Old mali needs extra attributes */
+ if (gr->is_mali_egl) {
+ attribs[atti++] = EGL_YUV_COLOR_SPACE_HINT_EXT;
+ attribs[atti++] = EGL_ITU_REC601_EXT;
+ attribs[atti++] = EGL_SAMPLE_RANGE_HINT_EXT;
+ attribs[atti++] = EGL_YUV_NARROW_RANGE_EXT;
+ }
+
attribs[atti++] = EGL_NONE;
return gr->create_image(gr->egl_display, EGL_NO_CONTEXT,
@@ -3217,7 +3225,7 @@ gl_renderer_query_dmabuf_formats(struct weston_compositor *wc,
if (!gr->has_dmabuf_import_modifiers ||
!gr->query_dmabuf_formats(gr->egl_display, 0, NULL, &num)) {
- num = gr->has_gl_texture_rg ? ARRAY_LENGTH(fallback_formats) : 2;
+ num = (gr->has_gl_texture_rg || gr->is_mali_egl) ? ARRAY_LENGTH(fallback_formats) : 2;
fallback = true;
}
@@ -3810,6 +3818,9 @@ log_egl_info(struct gl_renderer *gr, EGLDisplay egldpy)
str = eglQueryString(egldpy, EGL_VENDOR);
weston_log("EGL vendor: %s\n", str ? str : "(null)");
+ if (!strcmp(str, "ARM"))
+ gr->is_mali_egl = 1;
+
str = eglQueryString(egldpy, EGL_CLIENT_APIS);
weston_log("EGL client APIs: %s\n", str ? str : "(null)");
--
2.20.1