[vlc-devel] commit: Bring the glibc detection back, not using dlopen() hacks anymore. ( Rémi Denis-Courmont )

git version control git at videolan.org
Mon Apr 6 19:59:33 CEST 2009


vlc | branch: 0.9-bugfix | Rémi Denis-Courmont <remi at remlab.net> | Mon Apr  6 20:27:47 2009 +0300| [dbece52fd28403b9d5077aa58187d62cce84f7da] | committer: Rémi Denis-Courmont 

Bring the glibc detection back, not using dlopen() hacks anymore.
(cherry picked from commit 288559204f8b0ef943d5e7273b9a076f69318c26)

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

 src/misc/linux_specific.c |   24 +++++++++++++++++++++++-
 1 files changed, 23 insertions(+), 1 deletions(-)

diff --git a/src/misc/linux_specific.c b/src/misc/linux_specific.c
index 0a4be0a..74db593 100644
--- a/src/misc/linux_specific.c
+++ b/src/misc/linux_specific.c
@@ -22,11 +22,13 @@
 # include "config.h"
 #endif
 
+#include <stdio.h>
+#include <string.h>
+
 #include <vlc_common.h>
 #include "../libvlc.h"
 
 #if 0
-#include <stdio.h>
 #include <assert.h>
 #include <pthread.h>
 
@@ -70,8 +72,28 @@ static void set_libvlc_path (void)
 }
 #endif
 
+#ifdef __GLIBC__
+# include <gnu/libc-version.h>
+# include <stdlib.h>
+#endif
+
 void system_Init (libvlc_int_t *libvlc, int *argc, const char *argv[])
 {
+#ifdef __GLIBC__
+    const char *glcv = gnu_get_libc_version ();
+
+    /* gettext in glibc 2.5-2.7 is not thread-safe. LibVLC keeps crashing,
+     * especially in sterror_r(). Even if we have NLS disabled, the calling
+     * process might have called setlocale(). */
+    if (strverscmp (glcv, "2.5") >= 0 && strverscmp (glcv, "2.8") < 0)
+    {
+        fputs ("LibVLC has detected an unusable buggy GNU/libc version.\n"
+               "Please update to version 2.8 or newer.\n", stderr);
+        fflush (stderr);
+        abort ();
+    }
+#endif
+
 #if 0
     static pthread_once_t once = PTHREAD_ONCE_INIT;
     pthread_once (&once, set_libvlc_path);




More information about the vlc-devel mailing list