[vlc-commits] commit: Xlib: check if we can call XInitThreads() before we do so ( =?UTF-8?Q?R=C3=A9mi=20Denis=2DCourmont=20?=)

git at videolan.org git at videolan.org
Sun Dec 5 00:19:25 CET 2010


vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Sun Dec  5 01:17:10 2010 +0200| [abbdcb63d9f4161055e24faec1c7edcc9b83e44c] | committer: Rémi Denis-Courmont 

Xlib: check if we can call XInitThreads() before we do so

Parental advisory: naked kludge and explicit hack

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=abbdcb63d9f4161055e24faec1c7edcc9b83e44c
---

 include/vlc_xlib.h |   20 ++++++++++++++++++--
 1 files changed, 18 insertions(+), 2 deletions(-)

diff --git a/include/vlc_xlib.h b/include/vlc_xlib.h
index 4e3632c..969dcbc 100644
--- a/include/vlc_xlib.h
+++ b/include/vlc_xlib.h
@@ -21,7 +21,10 @@
 #ifndef VLC_XLIB_H
 # define VLC_XLIB_H 1
 
+# include <stdio.h>
+# include <stdlib.h>
 # include <X11/Xlib.h>
+# include <X11/Xlibint.h>
 
 static inline bool vlc_xlib_init (vlc_object_t *obj)
 {
@@ -30,9 +33,22 @@ static inline bool vlc_xlib_init (vlc_object_t *obj)
     if (var_InheritBool (obj, "xlib"))
     {
         /* XInitThreads() can be called multiple times,
-         * but it is not reentrant. */
+         * but it is not reentrant, so we need this global lock. */
         vlc_global_lock (VLC_XLIB_MUTEX);
-        ok = XInitThreads () != 0;
+
+        if (_Xglobal_lock == NULL && unlikely(_XErrorFunction != NULL))
+        {
+            /* (_Xglobal_lock == NULL) => Xlib threads not initialized */
+            /* (_XErrorFunction != NULL) => Xlib already in use */
+            fprintf (stderr, "%s:%u:%u: Xlib not initialized for threads.\n"
+                     "This process is probably using LibVLC incorrectly.\n"
+                     "Pass \"--no-xlib\" to libvlc_new() to fix this.\n",
+                     __FILE__, __LINE__, __func__);
+            /* Initiate core meltdown */
+            abort ();
+        }
+        else
+            ok = XInitThreads () != 0;
         vlc_global_unlock (VLC_XLIB_MUTEX);
     }
     return ok;



More information about the vlc-commits mailing list