Renamed .SMBuild files to smbuild for simplicity Added musl-fts, musl-obstack, glslang, python-glad, libptytty, libmilter, elfutils and fuse to base section build list Discarded fuse2 and fuse3 from base section Temporarily discarded slapt-get, syslinux, p7zip, acpid, libelf-compat, gnu-eif, libtirpc, mozilla-nss, lua53, qpdf, kernel-source and signify from base section build list Disabled nls and made amends to base/e2fsprogs Upgraded base/git to 2.46.2 Upgraded extra/gnumeric to 1.12.57 Disabled nls in base/gnutls, extra/dia Disabled a patch and made amends in base/llvm Fixed configure.local file in base/mandoc Upgraded base/rust to 1.79 Fixed a ton of build files to use build prefix as /usr and miscellaneous changes Discarded extra/bluez,blueman,scrcpy,adafruit-io Added tomb to extra Added new build option to extra/libass Upgraded extra/mpv to 0.37.0 Disabled tests in gtk/gdk-pixbuf Upgraded gtk/goffice to 0.10.57 Added gtk-doc to gtk section Fixed build options in gtk/gtk2 Added new patches to gtk/gtk3 Added gtksourceview to gtk section Added vulkan-headers to xorg section Upgraded xorg/mesa to 23.1.9 Added libplacebo to xorg section Fixed build stuff in xorg/glew
119 lines
4.5 KiB
Diff
119 lines
4.5 KiB
Diff
Patch-Source: https://gitlab.gnome.org/GNOME/gtk/-/commit/cf7decae1a1a2af825caca8da018ce09cd9ce31a
|
|
https://gitlab.gnome.org/GNOME/gtk/-/issues/5749
|
|
--
|
|
From cf7decae1a1a2af825caca8da018ce09cd9ce31a Mon Sep 17 00:00:00 2001
|
|
From: Benjamin Otte <otte@redhat.com>
|
|
Date: Sat, 1 Jul 2023 22:46:47 +0200
|
|
Subject: [PATCH] gdkgl: Check for GLsync before using it
|
|
|
|
Copy what we do in GTK4: Check for GL >= 3.2 or GLES >= 3.0 or the
|
|
GL_ARB_sync extension.
|
|
Then store that info for a (private) gdk_gl_context_has_sync()
|
|
function.
|
|
And then check that function before using GLsync objects as introduced
|
|
by commit 9811485990b.
|
|
|
|
Fixes #5749
|
|
---
|
|
gdk/gdkgl.c | 10 +++++++---
|
|
gdk/gdkglcontext.c | 13 +++++++++++++
|
|
gdk/gdkglcontextprivate.h | 1 +
|
|
3 files changed, 21 insertions(+), 3 deletions(-)
|
|
|
|
diff --git a/gdk/gdkgl.c b/gdk/gdkgl.c
|
|
index 86b169039a8..d3b460b4b71 100644
|
|
--- a/gdk/gdkgl.c
|
|
+++ b/gdk/gdkgl.c
|
|
@@ -341,7 +341,7 @@ gdk_cairo_draw_from_gl (cairo_t *cr,
|
|
int width,
|
|
int height)
|
|
{
|
|
- GdkGLContext *paint_context;
|
|
+ GdkGLContext *paint_context, *current_context;
|
|
cairo_surface_t *image;
|
|
cairo_matrix_t matrix;
|
|
int dx, dy, window_scale;
|
|
@@ -352,7 +352,7 @@ gdk_cairo_draw_from_gl (cairo_t *cr,
|
|
int alpha_size = 0;
|
|
cairo_region_t *clip_region;
|
|
GdkGLContextPaintData *paint_data;
|
|
- GLsync sync = NULL;
|
|
+ GLsync sync;
|
|
|
|
impl_window = window->impl_window;
|
|
|
|
@@ -366,9 +366,13 @@ gdk_cairo_draw_from_gl (cairo_t *cr,
|
|
}
|
|
|
|
clip_region = gdk_cairo_region_from_clip (cr);
|
|
+ current_context = gdk_gl_context_get_current ();
|
|
|
|
- if ((gdk_gl_context_get_current () != NULL) && (gdk_gl_context_get_current () != paint_context))
|
|
+ if ((current_context != NULL) && (current_context != paint_context) &&
|
|
+ gdk_gl_context_has_sync (current_context))
|
|
sync = glFenceSync (GL_SYNC_GPU_COMMANDS_COMPLETE, 0);
|
|
+ else
|
|
+ sync = NULL;
|
|
|
|
gdk_gl_context_make_current (paint_context);
|
|
|
|
diff --git a/gdk/gdkglcontext.c b/gdk/gdkglcontext.c
|
|
index 3b23639e1ce..4c137a8d5dd 100644
|
|
--- a/gdk/gdkglcontext.c
|
|
+++ b/gdk/gdkglcontext.c
|
|
@@ -101,6 +101,7 @@ typedef struct {
|
|
guint has_gl_framebuffer_blit : 1;
|
|
guint has_frame_terminator : 1;
|
|
guint has_unpack_subimage : 1;
|
|
+ guint has_sync : 1;
|
|
guint extensions_checked : 1;
|
|
guint debug_enabled : 1;
|
|
guint forward_compatible : 1;
|
|
@@ -441,6 +442,14 @@ gdk_gl_context_has_unpack_subimage (GdkGLContext *context)
|
|
return priv->has_unpack_subimage;
|
|
}
|
|
|
|
+gboolean
|
|
+gdk_gl_context_has_sync (GdkGLContext *context)
|
|
+{
|
|
+ GdkGLContextPrivate *priv = gdk_gl_context_get_instance_private (context);
|
|
+
|
|
+ return priv->has_sync;
|
|
+}
|
|
+
|
|
/**
|
|
* gdk_gl_context_set_debug_enabled:
|
|
* @context: a #GdkGLContext
|
|
@@ -809,6 +818,7 @@ gdk_gl_context_check_extensions (GdkGLContext *context)
|
|
priv->has_frame_terminator = FALSE;
|
|
|
|
priv->has_unpack_subimage = epoxy_has_gl_extension ("GL_EXT_unpack_subimage");
|
|
+ priv->has_sync = priv->gl_version >= 30;
|
|
}
|
|
else
|
|
{
|
|
@@ -818,6 +828,9 @@ gdk_gl_context_check_extensions (GdkGLContext *context)
|
|
priv->has_gl_framebuffer_blit = priv->gl_version >= 30 || epoxy_has_gl_extension ("GL_EXT_framebuffer_blit");
|
|
priv->has_frame_terminator = epoxy_has_gl_extension ("GL_GREMEDY_frame_terminator");
|
|
priv->has_unpack_subimage = TRUE;
|
|
+ priv->has_sync = priv->gl_version >= 32 ||
|
|
+ epoxy_has_gl_extension ("GL_ARB_sync") ||
|
|
+ epoxy_has_gl_extension ("GL_APPLE_sync");
|
|
|
|
/* We asked for a core profile, but we didn't get one, so we're in legacy mode */
|
|
if (priv->gl_version < 32)
|
|
diff --git a/gdk/gdkglcontextprivate.h b/gdk/gdkglcontextprivate.h
|
|
index cb0b76793fa..94ecb34d30b 100644
|
|
--- a/gdk/gdkglcontextprivate.h
|
|
+++ b/gdk/gdkglcontextprivate.h
|
|
@@ -86,6 +86,7 @@ gboolean gdk_gl_context_use_texture_rectangle (GdkGLContext
|
|
gboolean gdk_gl_context_has_framebuffer_blit (GdkGLContext *context);
|
|
gboolean gdk_gl_context_has_frame_terminator (GdkGLContext *context);
|
|
gboolean gdk_gl_context_has_unpack_subimage (GdkGLContext *context);
|
|
+gboolean gdk_gl_context_has_sync (GdkGLContext *context);
|
|
void gdk_gl_context_end_frame (GdkGLContext *context,
|
|
cairo_region_t *painted,
|
|
cairo_region_t *damage);
|
|
--
|
|
GitLab
|
|
|