mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-28 01:58:19 +00:00
[901/906] glx: use the display handle from the global display
Intel drivers require the display handles be the same for context sharing to occur. Also solves some cases of use after free of the display when integrating with gstreamer-vaapi. See https://bugs.freedesktop.org/show_bug.cgi?id=41736 for the intel bug.
This commit is contained in:
parent
18ebef308c
commit
c3146c0d48
1 changed files with 5 additions and 5 deletions
|
@ -163,7 +163,7 @@ gst_gl_context_glx_create_context (GstGLContext * context,
|
|||
external_gl_context = gst_gl_context_get_gl_context (other_context);
|
||||
}
|
||||
|
||||
device = (Display *) gst_gl_window_get_display (window);
|
||||
device = (Display *) gst_gl_display_get_handle (window->display);
|
||||
glx_exts = glXQueryExtensionsString (device, DefaultScreen (device));
|
||||
|
||||
create_context = gst_gl_check_extension ("GLX_ARB_create_context", glx_exts);
|
||||
|
@ -248,7 +248,7 @@ gst_gl_context_glx_destroy_context (GstGLContext * context)
|
|||
|
||||
context_glx = GST_GL_CONTEXT_GLX (context);
|
||||
window = gst_gl_context_get_window (context);
|
||||
device = (Display *) gst_gl_window_get_display (window);
|
||||
device = (Display *) gst_gl_display_get_handle (window->display);
|
||||
|
||||
glXDestroyContext (device, context_glx->glx_context);
|
||||
|
||||
|
@ -270,7 +270,7 @@ gst_gl_context_glx_choose_format (GstGLContext * context, GError ** error)
|
|||
context_glx = GST_GL_CONTEXT_GLX (context);
|
||||
window = gst_gl_context_get_window (context);
|
||||
window_x11 = GST_GL_WINDOW_X11 (window);
|
||||
device = (Display *) gst_gl_window_get_display (window);
|
||||
device = (Display *) gst_gl_display_get_handle (window->display);
|
||||
|
||||
if (!glXQueryExtension (device, &error_base, &event_base)) {
|
||||
g_set_error (error, GST_GL_CONTEXT_ERROR,
|
||||
|
@ -362,7 +362,7 @@ static void
|
|||
gst_gl_context_glx_swap_buffers (GstGLContext * context)
|
||||
{
|
||||
GstGLWindow *window = gst_gl_context_get_window (context);
|
||||
Display *device = (Display *) gst_gl_window_get_display (window);
|
||||
Display *device = (Display *) gst_gl_display_get_handle (window->display);
|
||||
Window window_handle = (Window) gst_gl_window_get_window_handle (window);
|
||||
|
||||
glXSwapBuffers (device, window_handle);
|
||||
|
@ -380,7 +380,7 @@ static gboolean
|
|||
gst_gl_context_glx_activate (GstGLContext * context, gboolean activate)
|
||||
{
|
||||
GstGLWindow *window = gst_gl_context_get_window (context);
|
||||
Display *device = (Display *) gst_gl_window_get_display (window);
|
||||
Display *device = (Display *) gst_gl_display_get_handle (window->display);
|
||||
Window window_handle = (Window) gst_gl_window_get_window_handle (window);
|
||||
gboolean result;
|
||||
|
||||
|
|
Loading…
Reference in a new issue