[Mesa-dev] [PATCH v5 0/4] Disable glthread if libX11 isn't thread-safe

Gregory Hainaut gregory.hainaut at gmail.com
Mon May 29 11:18:24 UTC 2017


Hello Mesa developers,

Following the discussion from
https://lists.freedesktop.org/archives/mesa-dev/2017-April/153137.html

A check was added to ensure that X11 display can be locked. It should be enough
to ensure thread safety between X11 and glthread.

I also did the check on DRI3 as I'm not 100% sure that it is really thread safe.

------------------------------------

v2: based on Nicolai/Matt reviews
Add a check on DRI extension version
Use C comments :)

v3: based on Emil reviews
Split the initial first patch into 3 sub patches dri extension / glx / egl
Improve error message
Improve code readability
Just include libX11 on EGL protected by ifdef

v4: based on Eric feedback, I marked DRI3 as always thread safe

v5: Fix the null pointer check on patch 4. I added Daniel comment on
patch 3 but I'm not sure I got it right.

Thanks you for all the review comments.

Best regards,


Gregory Hainaut (4):
  dri: Extend __DRIbackgroundCallableExtensionRec to include a callback
    that checks for thread safety
  glx: implement __DRIbackgroundCallableExtension.isThreadSafe
  egl: implement __DRIbackgroundCallableExtension.isThreadSafe
  glthread/gallium: require safe_glthread to start glthread

 include/GL/internal/dri_interface.h          | 13 +++++++++++
 src/egl/drivers/dri2/egl_dri2.c              | 34 +++++++++++++++++++++++++++-
 src/gallium/state_trackers/dri/dri_context.c | 21 +++++++++++++----
 src/glx/dri2_glx.c                           | 15 +++++++++++-
 src/glx/dri3_glx.c                           | 12 +++++++++-
 5 files changed, 88 insertions(+), 7 deletions(-)

-- 
2.11.0



More information about the mesa-dev mailing list