Commit de447780 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

Protect XInitThreads() with a global lock

(cherry picked from commit ddfbaea04ac415ce036350e3f2244b6f6bb881dc)

Conflicts:

	include/vlc_threads.h
	src/misc/threads.c
parent 588b5225
...@@ -431,6 +431,8 @@ class vlc_mutex_locker ...@@ -431,6 +431,8 @@ class vlc_mutex_locker
#endif #endif
enum { enum {
VLC_XLIB_MUTEX,
/* Insert new entry HERE */
VLC_MAX_MUTEX VLC_MAX_MUTEX
}; };
......
/*****************************************************************************
* vlc_xlib.h: initialization of Xlib
*****************************************************************************
* Copyright (C) 2010 Rémi Denis-Courmont
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#ifndef VLC_XLIB_H
# define VLC_XLIB_H 1
# include <X11/Xlib.h>
static inline bool vlc_xlib_init (vlc_object_t *obj)
{
bool ok = false;
if (var_InheritBool (obj, "xlib"))
{
/* XInitThreads() can be called multiple times,
* but it is not reentrant. */
vlc_global_lock (VLC_XLIB_MUTEX);
ok = XInitThreads () != 0;
vlc_global_unlock (VLC_XLIB_MUTEX);
}
return ok;
}
#endif
...@@ -34,9 +34,10 @@ ...@@ -34,9 +34,10 @@
#include <vlc_cpu.h> #include <vlc_cpu.h>
#include <pulse/pulseaudio.h> #include <pulse/pulseaudio.h>
#ifdef HAVE_X11_XLIB_H #ifdef X_DISPLAY_MISSING
# include <X11/Xlib.h> # error Xlib required due to PulseAudio bug 799!
#endif #endif
#include <vlc_xlib.h>
#include <assert.h> #include <assert.h>
...@@ -121,12 +122,9 @@ static int Open ( vlc_object_t *p_this ) ...@@ -121,12 +122,9 @@ static int Open ( vlc_object_t *p_this )
struct pa_buffer_attr a; struct pa_buffer_attr a;
struct pa_channel_map map; struct pa_channel_map map;
#ifdef X_DISPLAY_MISSING if( !vlc_xlib_init( p_this ) )
# error Xlib required due to PulseAudio bug 799!
#else
if( !var_InheritBool( p_this, "xlib" ) || !XInitThreads() )
return VLC_EGENERIC; return VLC_EGENERIC;
#endif
/* Allocate structures */ /* Allocate structures */
p_aout->output.p_sys = p_sys = calloc( 1, sizeof( aout_sys_t ) ); p_aout->output.p_sys = p_sys = calloc( 1, sizeof( aout_sys_t ) );
if( p_sys == NULL ) if( p_sys == NULL )
......
...@@ -461,7 +461,12 @@ static void Delete( vlc_va_t *p_external ) ...@@ -461,7 +461,12 @@ static void Delete( vlc_va_t *p_external )
/* */ /* */
vlc_va_t *vlc_va_NewVaapi( int i_codec_id ) vlc_va_t *vlc_va_NewVaapi( int i_codec_id )
{ {
if( !XInitThreads() ) bool fail;
vlc_global_lock( VLC_XLIB_MUTEX );
fail = !XInitThreads();
vlc_global_unlock( VLC_XLIB_MUTEX );
if( unlikely(fail) )
return NULL; return NULL;
vlc_va_vaapi_t *p_va = calloc( 1, sizeof(*p_va) ); vlc_va_vaapi_t *p_va = calloc( 1, sizeof(*p_va) );
......
...@@ -30,6 +30,7 @@ ...@@ -30,6 +30,7 @@
#include <vlc_plugin.h> #include <vlc_plugin.h>
#include <vlc_interface.h> #include <vlc_interface.h>
#include <vlc_vout_window.h> #include <vlc_vout_window.h>
#include <vlc_xlib.h>
#include <hildon/hildon-program.h> #include <hildon/hildon-program.h>
#include <hildon/hildon-banner.h> #include <hildon/hildon-banner.h>
...@@ -80,7 +81,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -80,7 +81,7 @@ static int Open( vlc_object_t *p_this )
intf_sys_t *p_sys; intf_sys_t *p_sys;
vlc_value_t val; vlc_value_t val;
if( !var_InheritBool( p_this, "xlib" ) || !XInitThreads() ) if( !vlc_xlib_init( p_this ) )
return VLC_EGENERIC; return VLC_EGENERIC;
/* Allocate instance and initialize some members */ /* Allocate instance and initialize some members */
......
...@@ -39,7 +39,7 @@ ...@@ -39,7 +39,7 @@
#include "util/qvlcapp.hpp" /* QVLCApplication definition */ #include "util/qvlcapp.hpp" /* QVLCApplication definition */
#ifdef Q_WS_X11 #ifdef Q_WS_X11
#include <X11/Xlib.h> #include <vlc_xlib.h>
#endif #endif
#include "../../../share/vlc32x32.xpm" #include "../../../share/vlc32x32.xpm"
...@@ -283,7 +283,7 @@ static int Open( vlc_object_t *p_this, bool isDialogProvider ) ...@@ -283,7 +283,7 @@ static int Open( vlc_object_t *p_this, bool isDialogProvider )
intf_thread_t *p_intf = (intf_thread_t *)p_this; intf_thread_t *p_intf = (intf_thread_t *)p_this;
#ifdef Q_WS_X11 #ifdef Q_WS_X11
if( !var_InheritBool( p_this, "xlib" ) || !XInitThreads() ) if( !vlc_xlib_init( p_this ) )
return VLC_EGENERIC; return VLC_EGENERIC;
char *display = var_CreateGetNonEmptyString( p_intf, "x11-display" ); char *display = var_CreateGetNonEmptyString( p_intf, "x11-display" );
......
...@@ -40,6 +40,9 @@ ...@@ -40,6 +40,9 @@
#include "../src/generic_window.hpp" #include "../src/generic_window.hpp"
#include <vlc_common.h>
#include <vlc_xlib.h>
X11Factory::X11Factory( intf_thread_t *pIntf ): OSFactory( pIntf ), X11Factory::X11Factory( intf_thread_t *pIntf ): OSFactory( pIntf ),
m_pDisplay( NULL ), m_pTimerLoop( NULL ), m_dirSep( "/" ) m_pDisplay( NULL ), m_pTimerLoop( NULL ), m_dirSep( "/" )
{ {
...@@ -57,7 +60,7 @@ X11Factory::~X11Factory() ...@@ -57,7 +60,7 @@ X11Factory::~X11Factory()
bool X11Factory::init() bool X11Factory::init()
{ {
// make sure xlib is safe-thread // make sure xlib is safe-thread
if( !var_InheritBool( getIntf(), "xlib" ) || !XInitThreads() ) if( !vlc_xlib_init( VLC_OBJECT(getIntf()) ) )
{ {
msg_Err( getIntf(), "initializing xlib for multi-threading failed" ); msg_Err( getIntf(), "initializing xlib for multi-threading failed" );
return false; return false;
......
...@@ -34,6 +34,7 @@ ...@@ -34,6 +34,7 @@
#include <vlc_common.h> #include <vlc_common.h>
#include <vlc_plugin.h> #include <vlc_plugin.h>
#include <vlc_xlib.h>
#include <vlc_vout_display.h> #include <vlc_vout_display.h>
#include <vlc_vout_opengl.h> #include <vlc_vout_opengl.h>
#include "../opengl.h" #include "../opengl.h"
...@@ -207,7 +208,7 @@ static int CreateWindow (vout_display_t *vd, xcb_connection_t *conn, ...@@ -207,7 +208,7 @@ static int CreateWindow (vout_display_t *vd, xcb_connection_t *conn,
*/ */
static int Open (vlc_object_t *obj) static int Open (vlc_object_t *obj)
{ {
if (!var_InheritBool (obj, "xlib") || !XInitThreads ()) if (!vlc_xlib_init (obj))
return VLC_EGENERIC; return VLC_EGENERIC;
vout_display_t *vd = (vout_display_t *)obj; vout_display_t *vd = (vout_display_t *)obj;
......
...@@ -104,6 +104,7 @@ pluginsinclude_HEADERS = \ ...@@ -104,6 +104,7 @@ pluginsinclude_HEADERS = \
../include/vlc_vout_opengl.h \ ../include/vlc_vout_opengl.h \
../include/vlc_vout_window.h \ ../include/vlc_vout_window.h \
../include/vlc_xml.h \ ../include/vlc_xml.h \
../include/vlc_xlib.h \
$(NULL) $(NULL)
noinst_HEADERS = \ noinst_HEADERS = \
......
...@@ -239,6 +239,7 @@ void vlc_thread_cancel (vlc_object_t *obj) ...@@ -239,6 +239,7 @@ void vlc_thread_cancel (vlc_object_t *obj)
void vlc_global_mutex (unsigned n, bool acquire) void vlc_global_mutex (unsigned n, bool acquire)
{ {
static vlc_mutex_t locks[] = { static vlc_mutex_t locks[] = {
VLC_STATIC_MUTEX,
}; };
assert (n < (sizeof (locks) / sizeof (locks[0]))); assert (n < (sizeof (locks) / sizeof (locks[0])));
vlc_mutex_t *lock = locks + n; vlc_mutex_t *lock = locks + n;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment