]> git.sesse.net Git - vlc/commitdiff
Xlib: check if we can call XInitThreads() before we do so
authorRémi Denis-Courmont <remi@remlab.net>
Sat, 4 Dec 2010 23:17:10 +0000 (01:17 +0200)
committerRémi Denis-Courmont <remi@remlab.net>
Sat, 4 Dec 2010 23:17:10 +0000 (01:17 +0200)
Parental advisory: naked kludge and explicit hack

include/vlc_xlib.h

index 4e3632c34180484d0fc1dfb4150708558754d8d7..969dcbc3525e0984ec9c9084fa24071c698f607d 100644 (file)
 #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;