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

Use static mutexes

parent 917aae76
...@@ -88,7 +88,19 @@ static const struct gcry_thread_cbs gcry_threads_vlc = ...@@ -88,7 +88,19 @@ static const struct gcry_thread_cbs gcry_threads_vlc =
*/ */
static inline void vlc_gcrypt_init (void) static inline void vlc_gcrypt_init (void)
{ {
vlc_mutex_t *lock = var_AcquireMutex ("gcrypt_mutex"); /* This would need a process-wide static mutex with all libraries linking
* to a given instance of libgcrypt. We cannot do this as we have different
* plugins linking with gcrypt, and some underlying libraries may use it
* behind our back. Only way is to always link gcrypt statically (ouch!) or
* have upstream gcrypt provide one shared object per threading system. */
static vlc_mutex_t lock = VLC_STATIC_MUTEX;
static bool done = false;
vlc_mutex_lock (&lock);
if (!done)
{
gcry_control (GCRYCTL_SET_THREAD_CBS, &gcry_threads_vlc); gcry_control (GCRYCTL_SET_THREAD_CBS, &gcry_threads_vlc);
vlc_mutex_unlock (lock); done = true;
}
vlc_mutex_unlock (&lock);
} }
...@@ -180,23 +180,17 @@ int InitAudioDec( decoder_t *p_dec, AVCodecContext *p_context, ...@@ -180,23 +180,17 @@ int InitAudioDec( decoder_t *p_dec, AVCodecContext *p_context,
} }
/* ***** Open the codec ***** */ /* ***** Open the codec ***** */
vlc_mutex_t *lock = var_AcquireMutex( "avcodec" ); vlc_mutex_lock( &avcodec_lock );
if( lock == NULL )
{
free( p_sys->p_context->extradata );
free( p_sys );
return VLC_ENOMEM;
}
if (avcodec_open( p_sys->p_context, p_sys->p_codec ) < 0) if (avcodec_open( p_sys->p_context, p_sys->p_codec ) < 0)
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
msg_Err( p_dec, "cannot open codec (%s)", p_sys->psz_namecodec ); msg_Err( p_dec, "cannot open codec (%s)", p_sys->psz_namecodec );
free( p_sys->p_context->extradata ); free( p_sys->p_context->extradata );
free( p_sys ); free( p_sys );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
msg_Dbg( p_dec, "ffmpeg codec (%s) started", p_sys->psz_namecodec ); msg_Dbg( p_dec, "ffmpeg codec (%s) started", p_sys->psz_namecodec );
......
...@@ -202,6 +202,8 @@ vlc_module_begin(); ...@@ -202,6 +202,8 @@ vlc_module_begin();
vlc_module_end(); vlc_module_end();
vlc_mutex_t avcodec_lock = VLC_STATIC_MUTEX;
/***************************************************************************** /*****************************************************************************
* OpenDecoder: probe the decoder and return score * OpenDecoder: probe the decoder and return score
*****************************************************************************/ *****************************************************************************/
...@@ -319,9 +321,9 @@ static void CloseDecoder( vlc_object_t *p_this ) ...@@ -319,9 +321,9 @@ static void CloseDecoder( vlc_object_t *p_this )
free( p_sys->p_context->extradata ); free( p_sys->p_context->extradata );
p_sys->p_context->extradata = NULL; p_sys->p_context->extradata = NULL;
lock = var_AcquireMutex( "avcodec" ); vlc_mutex_lock( &avcodec_lock );
avcodec_close( p_sys->p_context ); avcodec_close( p_sys->p_context );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
msg_Dbg( p_dec, "ffmpeg codec (%s) stopped", p_sys->psz_namecodec ); msg_Dbg( p_dec, "ffmpeg codec (%s) stopped", p_sys->psz_namecodec );
av_free( p_sys->p_context ); av_free( p_sys->p_context );
} }
...@@ -331,8 +333,9 @@ static void CloseDecoder( vlc_object_t *p_this ) ...@@ -331,8 +333,9 @@ static void CloseDecoder( vlc_object_t *p_this )
void InitLibavcodec( vlc_object_t *p_object ) void InitLibavcodec( vlc_object_t *p_object )
{ {
static int b_ffmpeginit = 0; static bool b_ffmpeginit = false;
vlc_mutex_t *lock = var_AcquireMutex( "avcodec" );
vlc_mutex_lock( &avcodec_lock );
/* *** init ffmpeg library (libavcodec) *** */ /* *** init ffmpeg library (libavcodec) *** */
if( !b_ffmpeginit ) if( !b_ffmpeginit )
...@@ -340,9 +343,9 @@ void InitLibavcodec( vlc_object_t *p_object ) ...@@ -340,9 +343,9 @@ void InitLibavcodec( vlc_object_t *p_object )
avcodec_init(); avcodec_init();
avcodec_register_all(); avcodec_register_all();
av_log_set_callback( LibavutilCallback ); av_log_set_callback( LibavutilCallback );
b_ffmpeginit = 1; b_ffmpeginit = true;
msg_Dbg( p_object, "libavcodec initialized (interface %d )", msg_Dbg( p_object, "libavcodec initialized (interface 0x%x)",
LIBAVCODEC_VERSION_INT ); LIBAVCODEC_VERSION_INT );
} }
else else
...@@ -350,5 +353,5 @@ void InitLibavcodec( vlc_object_t *p_object ) ...@@ -350,5 +353,5 @@ void InitLibavcodec( vlc_object_t *p_object )
msg_Dbg( p_object, "libavcodec already initialized" ); msg_Dbg( p_object, "libavcodec already initialized" );
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
} }
...@@ -48,6 +48,9 @@ int InitAudioDec( decoder_t *p_dec, AVCodecContext *p_context, ...@@ -48,6 +48,9 @@ int InitAudioDec( decoder_t *p_dec, AVCodecContext *p_context,
AVCodec *p_codec, int i_codec_id, const char *psz_namecodec ); AVCodec *p_codec, int i_codec_id, const char *psz_namecodec );
void EndAudioDec( decoder_t *p_dec ); void EndAudioDec( decoder_t *p_dec );
/* Avcodec global lock */
extern vlc_mutex_t avcodec_lock;
/***************************************************************************** /*****************************************************************************
* Module descriptor help strings * Module descriptor help strings
*****************************************************************************/ *****************************************************************************/
......
...@@ -604,11 +604,11 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -604,11 +604,11 @@ int OpenEncoder( vlc_object_t *p_this )
p_context->extradata = NULL; p_context->extradata = NULL;
p_context->flags |= CODEC_FLAG_GLOBAL_HEADER; p_context->flags |= CODEC_FLAG_GLOBAL_HEADER;
vlc_mutex_t *lock = var_AcquireMutex( "avcodec" ); vlc_mutex_lock( &avcodec_lock );
if( avcodec_open( p_context, p_codec ) ) if( avcodec_open( p_context, p_codec ) )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
if( p_enc->fmt_in.i_cat == AUDIO_ES && if( p_enc->fmt_in.i_cat == AUDIO_ES &&
(p_context->channels > 2 || i_codec_id == CODEC_ID_MP2 (p_context->channels > 2 || i_codec_id == CODEC_ID_MP2
|| i_codec_id == CODEC_ID_MP3) ) || i_codec_id == CODEC_ID_MP3) )
...@@ -658,10 +658,10 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -658,10 +658,10 @@ int OpenEncoder( vlc_object_t *p_this )
} }
p_context->codec = NULL; p_context->codec = NULL;
vlc_mutex_lock( lock ); vlc_mutex_lock( &avcodec_lock );
if( avcodec_open( p_context, p_codec ) ) if( avcodec_open( p_context, p_codec ) )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
msg_Err( p_enc, "cannot open encoder" ); msg_Err( p_enc, "cannot open encoder" );
intf_UserFatal( p_enc, false, intf_UserFatal( p_enc, false,
_("Streaming / Transcoding failed"), _("Streaming / Transcoding failed"),
...@@ -679,7 +679,7 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -679,7 +679,7 @@ int OpenEncoder( vlc_object_t *p_this )
return VLC_EGENERIC; return VLC_EGENERIC;
} }
} }
vlc_mutex_unlock( lock); vlc_mutex_unlock( &avcodec_lock );
p_enc->fmt_out.i_extra = p_context->extradata_size; p_enc->fmt_out.i_extra = p_context->extradata_size;
if( p_enc->fmt_out.i_extra ) if( p_enc->fmt_out.i_extra )
...@@ -1111,9 +1111,9 @@ void CloseEncoder( vlc_object_t *p_this ) ...@@ -1111,9 +1111,9 @@ void CloseEncoder( vlc_object_t *p_this )
free( pp_contexts ); free( pp_contexts );
} }
vlc_mutex_t *lock = var_AcquireMutex( "avcodec" ); vlc_mutex_lock( &avcodec_lock );
avcodec_close( p_sys->p_context ); avcodec_close( p_sys->p_context );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
av_free( p_sys->p_context ); av_free( p_sys->p_context );
free( p_sys->p_buffer ); free( p_sys->p_buffer );
......
...@@ -383,23 +383,16 @@ int InitVideoDec( decoder_t *p_dec, AVCodecContext *p_context, ...@@ -383,23 +383,16 @@ int InitVideoDec( decoder_t *p_dec, AVCodecContext *p_context,
} }
/* ***** Open the codec ***** */ /* ***** Open the codec ***** */
vlc_mutex_t *lock = var_AcquireMutex( "avcodec" ); vlc_mutex_lock( &avcodec_lock );
if( lock == NULL )
{
free( p_sys->p_buffer_orig );
free( p_sys );
return VLC_ENOMEM;
}
if( avcodec_open( p_sys->p_context, p_sys->p_codec ) < 0 ) if( avcodec_open( p_sys->p_context, p_sys->p_codec ) < 0 )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
msg_Err( p_dec, "cannot open codec (%s)", p_sys->psz_namecodec ); msg_Err( p_dec, "cannot open codec (%s)", p_sys->psz_namecodec );
free( p_sys->p_buffer_orig ); free( p_sys->p_buffer_orig );
free( p_sys ); free( p_sys );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &avcodec_lock );
msg_Dbg( p_dec, "ffmpeg codec (%s) started", p_sys->psz_namecodec ); msg_Dbg( p_dec, "ffmpeg codec (%s) started", p_sys->psz_namecodec );
......
...@@ -72,7 +72,6 @@ typedef struct ...@@ -72,7 +72,6 @@ typedef struct
{ {
vlc_object_t *p_libvlc; vlc_object_t *p_libvlc;
vlc_mutex_t *p_lock;
int i_refcount; int i_refcount;
ass_library_t *p_library; ass_library_t *p_library;
ass_renderer_t *p_renderer; ass_renderer_t *p_renderer;
...@@ -120,6 +119,8 @@ static int BuildRegions( spu_t *p_spu, rectangle_t *p_region, int i_max_region, ...@@ -120,6 +119,8 @@ static int BuildRegions( spu_t *p_spu, rectangle_t *p_region, int i_max_region,
static void SubpictureReleaseRegions( spu_t *p_spu, subpicture_t *p_subpic ); static void SubpictureReleaseRegions( spu_t *p_spu, subpicture_t *p_subpic );
static void RegionDraw( subpicture_region_t *p_region, ass_image_t *p_img ); static void RegionDraw( subpicture_region_t *p_region, ass_image_t *p_img );
static vlc_mutex_t libass_lock = VLC_STATIC_MUTEX;
//#define DEBUG_REGION //#define DEBUG_REGION
/***************************************************************************** /*****************************************************************************
...@@ -151,16 +152,16 @@ static int Create( vlc_object_t *p_this ) ...@@ -151,16 +152,16 @@ static int Create( vlc_object_t *p_this )
p_sys->i_refcount = 1; p_sys->i_refcount = 1;
/* Add a track */ /* Add a track */
vlc_mutex_lock( p_sys->p_ass->p_lock ); vlc_mutex_lock( &libass_lock );
p_sys->p_track = p_track = ass_new_track( p_sys->p_ass->p_library ); p_sys->p_track = p_track = ass_new_track( p_sys->p_ass->p_library );
if( !p_track ) if( !p_track )
{ {
vlc_mutex_unlock( p_sys->p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
DecSysRelease( p_sys ); DecSysRelease( p_sys );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
ass_process_codec_private( p_track, p_dec->fmt_in.p_extra, p_dec->fmt_in.i_extra ); ass_process_codec_private( p_track, p_dec->fmt_in.p_extra, p_dec->fmt_in.i_extra );
vlc_mutex_unlock( p_sys->p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
return VLC_SUCCESS; return VLC_SUCCESS;
} }
...@@ -194,10 +195,10 @@ static void DecSysRelease( decoder_sys_t *p_sys ) ...@@ -194,10 +195,10 @@ static void DecSysRelease( decoder_sys_t *p_sys )
vlc_mutex_unlock( &p_sys->lock ); vlc_mutex_unlock( &p_sys->lock );
vlc_mutex_destroy( &p_sys->lock ); vlc_mutex_destroy( &p_sys->lock );
vlc_mutex_lock( p_sys->p_ass->p_lock ); vlc_mutex_lock( &libass_lock );
if( p_sys->p_track ) if( p_sys->p_track )
ass_free_track( p_sys->p_track ); ass_free_track( p_sys->p_track );
vlc_mutex_unlock( p_sys->p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
AssHandleRelease( p_sys->p_ass ); AssHandleRelease( p_sys->p_ass );
free( p_sys ); free( p_sys );
...@@ -264,13 +265,13 @@ static subpicture_t *DecodeBlock( decoder_t *p_dec, block_t **pp_block ) ...@@ -264,13 +265,13 @@ static subpicture_t *DecodeBlock( decoder_t *p_dec, block_t **pp_block )
p_spu->b_ephemer = true; p_spu->b_ephemer = true;
p_spu->b_absolute = true; p_spu->b_absolute = true;
vlc_mutex_lock( p_sys->p_ass->p_lock ); vlc_mutex_lock( &libass_lock );
if( p_sys->p_track ) if( p_sys->p_track )
{ {
ass_process_chunk( p_sys->p_track, p_spu->p_sys->p_subs_data, p_spu->p_sys->i_subs_len, ass_process_chunk( p_sys->p_track, p_spu->p_sys->p_subs_data, p_spu->p_sys->i_subs_len,
p_spu->i_start / 1000, (p_spu->i_stop-p_spu->i_start) / 1000 ); p_spu->i_start / 1000, (p_spu->i_stop-p_spu->i_start) / 1000 );
} }
vlc_mutex_unlock( p_sys->p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
p_spu->pf_pre_render = PreRender; p_spu->pf_pre_render = PreRender;
p_spu->pf_update_regions = UpdateRegions; p_spu->pf_update_regions = UpdateRegions;
...@@ -320,7 +321,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic, ...@@ -320,7 +321,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic,
return; return;
} }
vlc_mutex_lock( p_ass->p_lock ); vlc_mutex_lock( &libass_lock );
/* */ /* */
fmt = *p_fmt; fmt = *p_fmt;
...@@ -347,7 +348,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic, ...@@ -347,7 +348,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic,
if( !i_changed && !b_fmt_changed ) if( !i_changed && !b_fmt_changed )
{ {
vlc_mutex_unlock( p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
return; return;
} }
...@@ -368,7 +369,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic, ...@@ -368,7 +369,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic,
if( i_region <= 0 ) if( i_region <= 0 )
{ {
vlc_mutex_unlock( p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
return; return;
} }
...@@ -402,7 +403,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic, ...@@ -402,7 +403,7 @@ static void UpdateRegions( spu_t *p_spu, subpicture_t *p_subpic,
*pp_region_last = r; *pp_region_last = r;
pp_region_last = &r->p_next; pp_region_last = &r->p_next;
} }
vlc_mutex_unlock( p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
} }
static rectangle_t r_create( int x0, int y0, int x1, int y1 ) static rectangle_t r_create( int x0, int y0, int x1, int y1 )
...@@ -616,9 +617,7 @@ static void SubpictureReleaseRegions( spu_t *p_spu, subpicture_t *p_subpic ) ...@@ -616,9 +617,7 @@ static void SubpictureReleaseRegions( spu_t *p_spu, subpicture_t *p_subpic )
/* */ /* */
static ass_handle_t *AssHandleHold( decoder_t *p_dec ) static ass_handle_t *AssHandleHold( decoder_t *p_dec )
{ {
vlc_mutex_t *p_lock = var_AcquireMutex( "libass" ); vlc_mutex_lock( &libass_lock );
if( !p_lock )
return NULL;
ass_handle_t *p_ass = NULL; ass_handle_t *p_ass = NULL;
ass_library_t *p_library = NULL; ass_library_t *p_library = NULL;
...@@ -635,7 +634,7 @@ static ass_handle_t *AssHandleHold( decoder_t *p_dec ) ...@@ -635,7 +634,7 @@ static ass_handle_t *AssHandleHold( decoder_t *p_dec )
p_ass->i_refcount++; p_ass->i_refcount++;
vlc_mutex_unlock( p_lock ); vlc_mutex_unlock( &libass_lock );
return p_ass; return p_ass;
} }
...@@ -646,7 +645,6 @@ static ass_handle_t *AssHandleHold( decoder_t *p_dec ) ...@@ -646,7 +645,6 @@ static ass_handle_t *AssHandleHold( decoder_t *p_dec )
/* */ /* */
p_ass->p_libvlc = VLC_OBJECT(p_dec->p_libvlc); p_ass->p_libvlc = VLC_OBJECT(p_dec->p_libvlc);
p_ass->p_lock = p_lock;
p_ass->i_refcount = 1; p_ass->i_refcount = 1;
/* Create libass library */ /* Create libass library */
...@@ -713,7 +711,7 @@ static ass_handle_t *AssHandleHold( decoder_t *p_dec ) ...@@ -713,7 +711,7 @@ static ass_handle_t *AssHandleHold( decoder_t *p_dec )
var_Set( p_dec->p_libvlc, "libass-handle", val ); var_Set( p_dec->p_libvlc, "libass-handle", val );
/* */ /* */
vlc_mutex_unlock( p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
return p_ass; return p_ass;
error: error:
...@@ -723,16 +721,16 @@ error: ...@@ -723,16 +721,16 @@ error:
ass_library_done( p_library ); ass_library_done( p_library );
free( p_ass ); free( p_ass );
vlc_mutex_unlock( p_lock ); vlc_mutex_unlock( &libass_lock );
return NULL; return NULL;
} }
static void AssHandleRelease( ass_handle_t *p_ass ) static void AssHandleRelease( ass_handle_t *p_ass )
{ {
vlc_mutex_lock( p_ass->p_lock ); vlc_mutex_lock( &libass_lock );
p_ass->i_refcount--; p_ass->i_refcount--;
if( p_ass->i_refcount > 0 ) if( p_ass->i_refcount > 0 )
{ {
vlc_mutex_unlock( p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
return; return;
} }
...@@ -743,7 +741,7 @@ static void AssHandleRelease( ass_handle_t *p_ass ) ...@@ -743,7 +741,7 @@ static void AssHandleRelease( ass_handle_t *p_ass )
val.p_address = NULL; val.p_address = NULL;
var_Set( p_ass->p_libvlc, "libass-handle", val ); var_Set( p_ass->p_libvlc, "libass-handle", val );
vlc_mutex_unlock( p_ass->p_lock ); vlc_mutex_unlock( &libass_lock );
free( p_ass ); free( p_ass );
} }
...@@ -326,6 +326,8 @@ static int Open( vlc_object_t *p_this ) ...@@ -326,6 +326,8 @@ static int Open( vlc_object_t *p_this )
} }
} }
static vlc_mutex_t qt_mutex = VLC_STATIC_MUTEX;
/***************************************************************************** /*****************************************************************************
* Close: * Close:
*****************************************************************************/ *****************************************************************************/
...@@ -333,10 +335,9 @@ static void Close( vlc_object_t *p_this ) ...@@ -333,10 +335,9 @@ static void Close( vlc_object_t *p_this )
{ {
decoder_t *p_dec = (decoder_t*)p_this; decoder_t *p_dec = (decoder_t*)p_this;
decoder_sys_t *p_sys = p_dec->p_sys; decoder_sys_t *p_sys = p_dec->p_sys;
vlc_mutex_t *lock;
/* get lock, avoid segfault */ /* get lock, avoid segfault */
lock = var_AcquireMutex( "qt_mutex" ); vlc_mutex_lock( &qt_mutex );
if( p_dec->fmt_out.i_cat == AUDIO_ES ) if( p_dec->fmt_out.i_cat == AUDIO_ES )
{ {
...@@ -375,7 +376,7 @@ static void Close( vlc_object_t *p_this ) ...@@ -375,7 +376,7 @@ static void Close( vlc_object_t *p_this )
#endif #endif
#endif #endif
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
free( p_sys ); free( p_sys );
} }
...@@ -394,9 +395,7 @@ static int OpenAudio( decoder_t *p_dec ) ...@@ -394,9 +395,7 @@ static int OpenAudio( decoder_t *p_dec )
unsigned long OutputBufferSize = 0; unsigned long OutputBufferSize = 0;
/* get lock, avoid segfault */ /* get lock, avoid segfault */
vlc_mutex_t *lock = var_AcquireMutex( "qt_mutex" ); vlc_mutex_lock( &qt_mutex );
if( lock == NULL )
return VLC_EGENERIC;
p_sys = calloc( sizeof( decoder_sys_t ), 1 ); p_sys = calloc( sizeof( decoder_sys_t ), 1 );
p_dec->p_sys = p_sys; p_dec->p_sys = p_sys;
...@@ -515,7 +514,7 @@ static int OpenAudio( decoder_t *p_dec ) ...@@ -515,7 +514,7 @@ static int OpenAudio( decoder_t *p_dec )
p_sys->i_out = 0; p_sys->i_out = 0;
p_sys->i_out_frames = 0; p_sys->i_out_frames = 0;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
return VLC_SUCCESS; return VLC_SUCCESS;
exit_error: exit_error:
...@@ -523,7 +522,7 @@ exit_error: ...@@ -523,7 +522,7 @@ exit_error:
#ifdef LOADER #ifdef LOADER
Restore_LDT_Keeper( p_sys->ldt_fs ); Restore_LDT_Keeper( p_sys->ldt_fs );
#endif #endif
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
free( p_sys ); free( p_sys );
return VLC_EGENERIC; return VLC_EGENERIC;
...@@ -595,7 +594,7 @@ static aout_buffer_t *DecodeAudio( decoder_t *p_dec, block_t **pp_block ) ...@@ -595,7 +594,7 @@ static aout_buffer_t *DecodeAudio( decoder_t *p_dec, block_t **pp_block )
{ {
int i_frames = p_sys->i_buffer / p_sys->InFrameSize; int i_frames = p_sys->i_buffer / p_sys->InFrameSize;
unsigned long i_out_frames, i_out_bytes; unsigned long i_out_frames, i_out_bytes;
vlc_mutex_t *lock = var_AcquireMutex( "qt_mutex "); vlc_mutex_lock( &qt_mutex );
i_error = p_sys->SoundConverterConvertBuffer( p_sys->myConverter, i_error = p_sys->SoundConverterConvertBuffer( p_sys->myConverter,
p_sys->p_buffer, p_sys->p_buffer,
...@@ -603,7 +602,7 @@ static aout_buffer_t *DecodeAudio( decoder_t *p_dec, block_t **pp_block ) ...@@ -603,7 +602,7 @@ static aout_buffer_t *DecodeAudio( decoder_t *p_dec, block_t **pp_block )
p_sys->out_buffer, p_sys->out_buffer,
&i_out_frames, &i_out_frames,
&i_out_bytes ); &i_out_bytes );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
/* /*
msg_Dbg( p_dec, "decoded %d frames -> %ld frames (error=%d)", msg_Dbg( p_dec, "decoded %d frames -> %ld frames (error=%d)",
...@@ -674,7 +673,6 @@ static int OpenVideo( decoder_t *p_dec ) ...@@ -674,7 +673,6 @@ static int OpenVideo( decoder_t *p_dec )
return VLC_ENOMEM; return VLC_ENOMEM;
#ifndef WIN32 #ifndef WIN32
vlc_mutex_t *lock;
long i_result; long i_result;
ComponentDescription desc; ComponentDescription desc;
Component prev; Component prev;
...@@ -703,7 +701,7 @@ static int OpenVideo( decoder_t *p_dec ) ...@@ -703,7 +701,7 @@ static int OpenVideo( decoder_t *p_dec )
fcc, p_dec->fmt_in.video.i_width, p_dec->fmt_in.video.i_height ); fcc, p_dec->fmt_in.video.i_width, p_dec->fmt_in.video.i_height );
/* get lock, avoid segfault */ /* get lock, avoid segfault */
lock = var_AcquireMutex( "qt_mutex" ); vlc_mutex_lock( &qt_mutex );
#ifdef __APPLE__ #ifdef __APPLE__
EnterMovies(); EnterMovies();
...@@ -845,14 +843,14 @@ static int OpenVideo( decoder_t *p_dec ) ...@@ -845,14 +843,14 @@ static int OpenVideo( decoder_t *p_dec )
p_dec->fmt_out.video.i_height= p_dec->fmt_in.video.i_height; p_dec->fmt_out.video.i_height= p_dec->fmt_in.video.i_height;
p_dec->fmt_out.video.i_aspect = VOUT_ASPECT_FACTOR * p_dec->fmt_in.video.i_width / p_dec->fmt_in.video.i_height; p_dec->fmt_out.video.i_aspect = VOUT_ASPECT_FACTOR * p_dec->fmt_in.video.i_width / p_dec->fmt_in.video.i_height;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
return VLC_SUCCESS; return VLC_SUCCESS;
exit_error: exit_error:
#ifdef LOADER #ifdef LOADER
Restore_LDT_Keeper( p_sys->ldt_fs ); Restore_LDT_Keeper( p_sys->ldt_fs );
#endif #endif
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
#endif /* !WIN32 */ #endif /* !WIN32 */
...@@ -866,7 +864,6 @@ exit_error: ...@@ -866,7 +864,6 @@ exit_error:
static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block ) static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
{ {
decoder_sys_t *p_sys = p_dec->p_sys; decoder_sys_t *p_sys = p_dec->p_sys;
vlc_mutex_t *lock;
block_t *p_block; block_t *p_block;
picture_t *p_pic; picture_t *p_pic;
mtime_t i_pts; mtime_t i_pts;
...@@ -916,7 +913,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block ) ...@@ -916,7 +913,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
return NULL; return NULL;
} }
lock = var_AcquireMutex( "qt_mutex" ); vlc_mutex_lock( &qt_mutex );
if( ( p_pic = p_dec->pf_vout_buffer_new( p_dec ) ) ) if( ( p_pic = p_dec->pf_vout_buffer_new( p_dec ) ) )
{ {
...@@ -940,7 +937,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block ) ...@@ -940,7 +937,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
p_pic->date = i_pts; p_pic->date = i_pts;
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qt_mutex );
block_Release( p_block ); block_Release( p_block );
return p_pic; return p_pic;
......
...@@ -203,12 +203,13 @@ static void * load_syms_linux(decoder_t *p_dec, const char *path) ...@@ -203,12 +203,13 @@ static void * load_syms_linux(decoder_t *p_dec, const char *path)
} }
#endif #endif
static vlc_mutex_t rm_mutex = VLC_STATIC_MUTEX;
static int InitVideo(decoder_t *p_dec) static int InitVideo(decoder_t *p_dec)
{ {
int result; int result;
struct rv_init_t init_data; struct rv_init_t init_data;
char fcc[4]; char fcc[4];
vlc_mutex_t *lock;
char *g_decode_path; char *g_decode_path;
int i_vide = p_dec->fmt_in.i_extra; int i_vide = p_dec->fmt_in.i_extra;
...@@ -309,9 +310,7 @@ static int InitVideo(decoder_t *p_dec) ...@@ -309,9 +310,7 @@ static int InitVideo(decoder_t *p_dec)
return VLC_EGENERIC; return VLC_EGENERIC;
} }
lock = var_AcquireMutex( "rm_mutex" ); vlc_mutex_lock( &rm_mutex );
if ( lock == NULL )
return VLC_EGENERIC;
p_sys->handle=NULL; p_sys->handle=NULL;
#ifdef WIN32 #ifdef WIN32
...@@ -358,7 +357,7 @@ static int InitVideo(decoder_t *p_dec) ...@@ -358,7 +357,7 @@ static int InitVideo(decoder_t *p_dec)
p_dec->fmt_out.video.i_aspect = VOUT_ASPECT_FACTOR * p_dec->fmt_in.video.i_width / p_dec->fmt_in.video.i_height; p_dec->fmt_out.video.i_aspect = VOUT_ASPECT_FACTOR * p_dec->fmt_in.video.i_width / p_dec->fmt_in.video.i_height;
p_sys->inited = 0; p_sys->inited = 0;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &rm_mutex );
return VLC_SUCCESS; return VLC_SUCCESS;
} }
...@@ -397,10 +396,9 @@ static void Close( vlc_object_t *p_this ) ...@@ -397,10 +396,9 @@ static void Close( vlc_object_t *p_this )
{ {
decoder_t *p_dec = (decoder_t*)p_this; decoder_t *p_dec = (decoder_t*)p_this;
decoder_sys_t *p_sys = p_dec->p_sys; decoder_sys_t *p_sys = p_dec->p_sys;
vlc_mutex_t *lock;
/* get lock, avoid segfault */ /* get lock, avoid segfault */
lock = var_AcquireMutex( "rm_mutex" ); vlc_mutex_lock( &rm_mutex );
#ifdef WIN32 #ifdef WIN32
if (dll_type == 1) if (dll_type == 1)
...@@ -435,8 +433,7 @@ static void Close( vlc_object_t *p_this ) ...@@ -435,8 +433,7 @@ static void Close( vlc_object_t *p_this )
#endif #endif
p_sys->inited = 0; p_sys->inited = 0;
if ( lock ) vlc_mutex_unlock( &rm_mutex );
vlc_mutex_unlock( lock );
if ( p_sys ) if ( p_sys )
free( p_sys ); free( p_sys );
...@@ -448,7 +445,6 @@ static void Close( vlc_object_t *p_this ) ...@@ -448,7 +445,6 @@ static void Close( vlc_object_t *p_this )
static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block ) static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
{ {
decoder_sys_t *p_sys = p_dec->p_sys; decoder_sys_t *p_sys = p_dec->p_sys;
vlc_mutex_t *lock;
block_t *p_block; block_t *p_block;
picture_t *p_pic; picture_t *p_pic;
mtime_t i_pts; mtime_t i_pts;
...@@ -465,9 +461,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block ) ...@@ -465,9 +461,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
i_pts = p_block->i_pts ? p_block->i_pts : p_block->i_dts; i_pts = p_block->i_pts ? p_block->i_pts : p_block->i_dts;
lock = var_AcquireMutex( "rm_mutex" ); vlc_mutex_lock( &rm_mutex );
if ( lock == NULL )
return NULL;
p_pic = p_dec->pf_vout_buffer_new( p_dec ); p_pic = p_dec->pf_vout_buffer_new( p_dec );
...@@ -559,7 +553,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block ) ...@@ -559,7 +553,7 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
p_pic->b_force = 1; p_pic->b_force = 1;
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &rm_mutex );
block_Release( p_block ); block_Release( p_block );
return p_pic; return p_pic;
......
...@@ -233,7 +233,7 @@ static void FreeLines( line_desc_t * ); ...@@ -233,7 +233,7 @@ static void FreeLines( line_desc_t * );
static void FreeLine( line_desc_t * ); static void FreeLine( line_desc_t * );
#ifdef HAVE_FONTCONFIG #ifdef HAVE_FONTCONFIG
static vlc_object_t *FontBuilderAttach( filter_t *p_filter, vlc_mutex_t **pp_lock ); static vlc_object_t *FontBuilderAttach( filter_t *p_filter );
static void FontBuilderDetach( filter_t *p_filter, vlc_object_t *p_fontbuilder ); static void FontBuilderDetach( filter_t *p_filter, vlc_object_t *p_fontbuilder );
static void* FontBuilderThread( vlc_object_t *p_this); static void* FontBuilderThread( vlc_object_t *p_this);
static void FontBuilderDestructor( vlc_object_t *p_this ); static void FontBuilderDestructor( vlc_object_t *p_this );
...@@ -261,7 +261,6 @@ struct filter_sys_t ...@@ -261,7 +261,6 @@ struct filter_sys_t
int i_default_font_size; int i_default_font_size;
int i_display_height; int i_display_height;
#ifdef HAVE_FONTCONFIG #ifdef HAVE_FONTCONFIG
vlc_mutex_t *p_fontconfig_lock;
bool b_fontconfig_ok; bool b_fontconfig_ok;
FcConfig *p_fontconfig; FcConfig *p_fontconfig;
#endif #endif
...@@ -367,7 +366,7 @@ static int Create( vlc_object_t *p_this ) ...@@ -367,7 +366,7 @@ static int Create( vlc_object_t *p_this )
#ifdef HAVE_FONTCONFIG #ifdef HAVE_FONTCONFIG
p_sys->b_fontconfig_ok = false; p_sys->b_fontconfig_ok = false;
p_sys->p_fontconfig = NULL; p_sys->p_fontconfig = NULL;
p_sys->p_fontbuilder = FontBuilderAttach( p_filter, &p_sys->p_fontconfig_lock ); p_sys->p_fontbuilder = FontBuilderAttach( p_filter );
#endif #endif
p_sys->i_use_kerning = FT_HAS_KERNING( p_sys->p_face ); p_sys->i_use_kerning = FT_HAS_KERNING( p_sys->p_face );
...@@ -434,10 +433,12 @@ static void Destroy( vlc_object_t *p_this ) ...@@ -434,10 +433,12 @@ static void Destroy( vlc_object_t *p_this )
} }
#ifdef HAVE_FONTCONFIG #ifdef HAVE_FONTCONFIG
static vlc_object_t *FontBuilderAttach( filter_t *p_filter, vlc_mutex_t **pp_lock ) static vlc_mutex_t fb_lock = VLC_STATIC_MUTEX;
static vlc_object_t *FontBuilderAttach( filter_t *p_filter )
{ {
/* Check for an existing Fontbuilder thread */ /* Check for an existing Fontbuilder thread */
vlc_mutex_t *p_lock = var_AcquireMutex( "fontbuilder" ); vlc_mutex_lock( &fb_lock );
vlc_object_t *p_fontbuilder = vlc_object_t *p_fontbuilder =
vlc_object_find_name( p_filter->p_libvlc, vlc_object_find_name( p_filter->p_libvlc,
"fontlist builder", FIND_CHILD ); "fontlist builder", FIND_CHILD );
...@@ -482,13 +483,12 @@ static vlc_object_t *FontBuilderAttach( filter_t *p_filter, vlc_mutex_t **pp_loc ...@@ -482,13 +483,12 @@ static vlc_object_t *FontBuilderAttach( filter_t *p_filter, vlc_mutex_t **pp_loc
var_AddCallback( p_fontbuilder, "build-done", FontBuilderDone, p_filter ); var_AddCallback( p_fontbuilder, "build-done", FontBuilderDone, p_filter );
FontBuilderGetFcConfig( p_filter, p_fontbuilder ); FontBuilderGetFcConfig( p_filter, p_fontbuilder );
} }
vlc_mutex_unlock( p_lock ); vlc_mutex_unlock( &fb_lock );
*pp_lock = p_lock;
return p_fontbuilder; return p_fontbuilder;
} }
static void FontBuilderDetach( filter_t *p_filter, vlc_object_t *p_fontbuilder ) static void FontBuilderDetach( filter_t *p_filter, vlc_object_t *p_fontbuilder )
{ {
vlc_mutex_t *lock = var_AcquireMutex( "fontbuilder" ); vlc_mutex_lock( &fb_lock );
if( p_fontbuilder ) if( p_fontbuilder )
{ {
const bool b_alive = vlc_object_alive( p_fontbuilder ); const bool b_alive = vlc_object_alive( p_fontbuilder );
...@@ -499,18 +499,18 @@ static void FontBuilderDetach( filter_t *p_filter, vlc_object_t *p_fontbuilder ) ...@@ -499,18 +499,18 @@ static void FontBuilderDetach( filter_t *p_filter, vlc_object_t *p_fontbuilder )
if( b_alive ) if( b_alive )
{ {
vlc_object_kill( p_fontbuilder ); vlc_object_kill( p_fontbuilder );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &fb_lock );
/* We need to unlock otherwise we may not join (the thread waiting /* We need to unlock otherwise we may not join (the thread waiting
* for the lock). It is safe to unlock as no one else will try a * for the lock). It is safe to unlock as no one else will try a
* join and we have a reference on the object) */ * join and we have a reference on the object) */
vlc_thread_join( p_fontbuilder ); vlc_thread_join( p_fontbuilder );
vlc_mutex_lock( lock ); vlc_mutex_lock( &fb_lock );
} }
vlc_object_release( p_fontbuilder ); vlc_object_release( p_fontbuilder );
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &fb_lock );
} }
static void* FontBuilderThread( vlc_object_t *p_this ) static void* FontBuilderThread( vlc_object_t *p_this )
{ {
...@@ -540,9 +540,9 @@ static void* FontBuilderThread( vlc_object_t *p_this ) ...@@ -540,9 +540,9 @@ static void* FontBuilderThread( vlc_object_t *p_this )
msg_Dbg( p_this, "Finished building font database." ); msg_Dbg( p_this, "Finished building font database." );
msg_Dbg( p_this, "Took %ld seconds", (long)((t2 - t1)/1000000) ); msg_Dbg( p_this, "Took %ld seconds", (long)((t2 - t1)/1000000) );
vlc_mutex_t *p_lock = var_AcquireMutex( "fontbuilder" ); vlc_mutex_lock( &fb_lock );
p_this->p_private = p_fontconfig; p_this->p_private = p_fontconfig;
vlc_mutex_unlock( p_lock ); vlc_mutex_unlock( &fb_lock );
var_SetBool( p_this, "build-done", true ); var_SetBool( p_this, "build-done", true );
vlc_restorecancel (canc); vlc_restorecancel (canc);
...@@ -570,11 +570,11 @@ static int FontBuilderDone( vlc_object_t *p_this, const char *psz_var, ...@@ -570,11 +570,11 @@ static int FontBuilderDone( vlc_object_t *p_this, const char *psz_var,
if( newval.b_bool ) if( newval.b_bool )
{ {
vlc_mutex_t *p_lock = var_AcquireMutex( "fontbuilder" ); vlc_mutex_lock( &fb_lock );
FontBuilderGetFcConfig( p_filter, p_this ); FontBuilderGetFcConfig( p_filter, p_this );
vlc_mutex_unlock( p_lock ); vlc_mutex_unlock( &fb_lock );
} }
VLC_UNUSED(psz_var); VLC_UNUSED(psz_var);
...@@ -2019,7 +2019,7 @@ static int ProcessLines( filter_t *p_filter, ...@@ -2019,7 +2019,7 @@ static int ProcessLines( filter_t *p_filter,
{ {
char *psz_fontfile = NULL; char *psz_fontfile = NULL;
vlc_mutex_lock( p_sys->p_fontconfig_lock ); vlc_mutex_lock( &fb_lock );
if( p_sys->b_fontconfig_ok ) if( p_sys->b_fontconfig_ok )
{ {
/* FIXME Is there really a race condition between FontConfig_Select with default fontconfig(NULL) /* FIXME Is there really a race condition between FontConfig_Select with default fontconfig(NULL)
...@@ -2030,7 +2030,7 @@ static int ProcessLines( filter_t *p_filter, ...@@ -2030,7 +2030,7 @@ static int ProcessLines( filter_t *p_filter,
p_style->b_italic, p_style->b_italic,
&i_idx ); &i_idx );
} }
vlc_mutex_unlock( p_sys->p_fontconfig_lock ); vlc_mutex_unlock( &fb_lock );
if( psz_fontfile && ! *psz_fontfile ) if( psz_fontfile && ! *psz_fontfile )
{ {
......
...@@ -110,6 +110,8 @@ vlc_module_begin(); ...@@ -110,6 +110,8 @@ vlc_module_begin();
CACHE_SIZE_LONGTEXT, true ); CACHE_SIZE_LONGTEXT, true );
vlc_module_end(); vlc_module_end();
static vlc_mutex_t gnutls_mutex = VLC_STATIC_MUTEX;
/** /**
* Initializes GnuTLS with proper locking. * Initializes GnuTLS with proper locking.
* @return VLC_SUCCESS on success, a VLC error code otherwise. * @return VLC_SUCCESS on success, a VLC error code otherwise.
...@@ -120,7 +122,7 @@ static int gnutls_Init (vlc_object_t *p_this) ...@@ -120,7 +122,7 @@ static int gnutls_Init (vlc_object_t *p_this)
vlc_gcrypt_init (); /* GnuTLS depends on gcrypt */ vlc_gcrypt_init (); /* GnuTLS depends on gcrypt */
vlc_mutex_t *lock = var_AcquireMutex ("gnutls_mutex"); vlc_mutex_lock (&gnutls_mutex);
if (gnutls_global_init ()) if (gnutls_global_init ())
{ {
msg_Err (p_this, "cannot initialize GnuTLS"); msg_Err (p_this, "cannot initialize GnuTLS");
...@@ -139,7 +141,7 @@ static int gnutls_Init (vlc_object_t *p_this) ...@@ -139,7 +141,7 @@ static int gnutls_Init (vlc_object_t *p_this)
ret = VLC_SUCCESS; ret = VLC_SUCCESS;
error: error:
vlc_mutex_unlock (lock); vlc_mutex_unlock (&gnutls_mutex);
return ret; return ret;
} }
...@@ -149,11 +151,11 @@ error: ...@@ -149,11 +151,11 @@ error:
*/ */
static void gnutls_Deinit (vlc_object_t *p_this) static void gnutls_Deinit (vlc_object_t *p_this)
{ {
vlc_mutex_t *lock = var_AcquireMutex( "gnutls_mutex" ); vlc_mutex_lock (&gnutls_mutex);
gnutls_global_deinit (); gnutls_global_deinit ();
msg_Dbg (p_this, "GnuTLS deinitialized"); msg_Dbg (p_this, "GnuTLS deinitialized");
vlc_mutex_unlock (lock); vlc_mutex_unlock (&gnutls_mutex);
} }
......
...@@ -82,14 +82,14 @@ vlc_module_begin(); ...@@ -82,14 +82,14 @@ vlc_module_begin();
linked_with_a_crap_library_which_uses_atexit(); linked_with_a_crap_library_which_uses_atexit();
vlc_module_end(); vlc_module_end();
static vlc_mutex_t gtk_lock = VLC_STATIC_MUTEX;
/***************************************************************************** /*****************************************************************************
* Open: initialize and create window * Open: initialize and create window
*****************************************************************************/ *****************************************************************************/
static int Open( vlc_object_t *p_this ) static int Open( vlc_object_t *p_this )
{ {
vlc_mutex_t *lock; vlc_mutex_lock( &gtk_lock );
lock = var_AcquireMutex( "gtk" );
if( i_refcount > 0 ) if( i_refcount > 0 )
{ {
...@@ -119,7 +119,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -119,7 +119,7 @@ static int Open( vlc_object_t *p_this )
} }
i_refcount++; i_refcount++;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &gtk_lock );
return VLC_SUCCESS; return VLC_SUCCESS;
} }
...@@ -129,25 +129,19 @@ static int Open( vlc_object_t *p_this ) ...@@ -129,25 +129,19 @@ static int Open( vlc_object_t *p_this )
*****************************************************************************/ *****************************************************************************/
static void Close( vlc_object_t *p_this ) static void Close( vlc_object_t *p_this )
{ {
vlc_mutex_t *lock; vlc_mutex_lock( &gtk_lock );
lock = var_AcquireMutex( "gtk" );
i_refcount--; i_refcount--;
if( i_refcount > 0 ) if( --i_refcount == 0 )
{ {
vlc_mutex_unlock( lock );
return;
}
gtk_main_quit(); gtk_main_quit();
vlc_thread_join( p_gtk_main ); vlc_thread_join( p_gtk_main );
vlc_object_release( p_gtk_main ); vlc_object_release( p_gtk_main );
p_gtk_main = NULL; p_gtk_main = NULL;
}
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &gtk_lock );
} }
static gint foo( gpointer bar ) { return TRUE; } static gint foo( gpointer bar ) { return TRUE; }
......
...@@ -82,19 +82,19 @@ vlc_module_end(); ...@@ -82,19 +82,19 @@ vlc_module_end();
} /* extern "C" */ } /* extern "C" */
static vlc_mutex_t qte_lock = VLC_STATIC_MUTEX;
/***************************************************************************** /*****************************************************************************
* Open: initialize and create window * Open: initialize and create window
*****************************************************************************/ *****************************************************************************/
static int Open( vlc_object_t *p_this ) static int Open( vlc_object_t *p_this )
{ {
vlc_mutex_t *lock; vlc_mutex_lock( &qte_lock );
lock = var_AcquireMutex( "qte" );
if( i_refcount > 0 ) if( i_refcount > 0 )
{ {
i_refcount++; i_refcount++;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qte_lock );
return VLC_SUCCESS; return VLC_SUCCESS;
} }
...@@ -113,7 +113,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -113,7 +113,7 @@ static int Open( vlc_object_t *p_this )
} }
i_refcount++; i_refcount++;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qte_lock );
vlc_object_attach( p_qte_main, p_this ); vlc_object_attach( p_qte_main, p_this );
msg_Dbg( p_this, "qte_main running" ); msg_Dbg( p_this, "qte_main running" );
...@@ -126,9 +126,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -126,9 +126,7 @@ static int Open( vlc_object_t *p_this )
*****************************************************************************/ *****************************************************************************/
static void Close( vlc_object_t *p_this ) static void Close( vlc_object_t *p_this )
{ {
vlc_mutex_t *lock; vlc_mutex_lock( &qte_lock );
lock = var_AcquireMutex( "qte" );
i_refcount--; i_refcount--;
...@@ -149,7 +147,7 @@ static void Close( vlc_object_t *p_this ) ...@@ -149,7 +147,7 @@ static void Close( vlc_object_t *p_this )
vlc_object_release( p_qte_main ); vlc_object_release( p_qte_main );
p_qte_main = NULL; p_qte_main = NULL;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &qte_lock );
} }
/***************************************************************************** /*****************************************************************************
......
...@@ -135,6 +135,8 @@ vlc_module_begin(); ...@@ -135,6 +135,8 @@ vlc_module_begin();
#endif #endif
vlc_module_end(); vlc_module_end();
static vlc_mutex_t sdl_lock = VLC_STATIC_MUTEX;
/***************************************************************************** /*****************************************************************************
* OpenVideo: allocate SDL video thread output method * OpenVideo: allocate SDL video thread output method
***************************************************************************** *****************************************************************************
...@@ -146,7 +148,7 @@ static int Open ( vlc_object_t *p_this ) ...@@ -146,7 +148,7 @@ static int Open ( vlc_object_t *p_this )
{ {
vout_thread_t * p_vout = (vout_thread_t *)p_this; vout_thread_t * p_vout = (vout_thread_t *)p_this;
/* XXX: check for conflicts with the SDL audio output */ /* XXX: check for conflicts with the SDL audio output */
vlc_mutex_t *lock = var_AcquireMutex( "sdl" ); vlc_mutex_lock( &sdl_lock );
#ifdef HAVE_SETENV #ifdef HAVE_SETENV
char *psz_method; char *psz_method;
...@@ -158,7 +160,7 @@ static int Open ( vlc_object_t *p_this ) ...@@ -158,7 +160,7 @@ static int Open ( vlc_object_t *p_this )
p_vout->p_sys = malloc( sizeof( vout_sys_t ) ); p_vout->p_sys = malloc( sizeof( vout_sys_t ) );
if( p_vout->p_sys == NULL ) if( p_vout->p_sys == NULL )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &sdl_lock );
return VLC_ENOMEM; return VLC_ENOMEM;
} }
...@@ -167,7 +169,7 @@ static int Open ( vlc_object_t *p_this ) ...@@ -167,7 +169,7 @@ static int Open ( vlc_object_t *p_this )
/* Check if SDL video module has been initialized */ /* Check if SDL video module has been initialized */
if( SDL_WasInit( SDL_INIT_VIDEO ) != 0 ) if( SDL_WasInit( SDL_INIT_VIDEO ) != 0 )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &sdl_lock );
free( p_vout->p_sys ); free( p_vout->p_sys );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
...@@ -212,11 +214,11 @@ static int Open ( vlc_object_t *p_this ) ...@@ -212,11 +214,11 @@ static int Open ( vlc_object_t *p_this )
{ {
msg_Err( p_vout, "cannot initialize SDL (%s)", SDL_GetError() ); msg_Err( p_vout, "cannot initialize SDL (%s)", SDL_GetError() );
free( p_vout->p_sys ); free( p_vout->p_sys );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &sdl_lock );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &sdl_lock );
/* Translate keys into unicode */ /* Translate keys into unicode */
SDL_EnableUNICODE(1); SDL_EnableUNICODE(1);
......
...@@ -228,6 +228,8 @@ static int VerboseCallback( vlc_object_t *, char const *, ...@@ -228,6 +228,8 @@ static int VerboseCallback( vlc_object_t *, char const *,
static void InitDeviceValues( libvlc_int_t * ); static void InitDeviceValues( libvlc_int_t * );
vlc_mutex_t global_lock = VLC_STATIC_MUTEX;
/** /**
* Allocate a libvlc instance, initialize global data if needed * Allocate a libvlc instance, initialize global data if needed
* It also initializes the threading system * It also initializes the threading system
...@@ -240,7 +242,7 @@ libvlc_int_t * libvlc_InternalCreate( void ) ...@@ -240,7 +242,7 @@ libvlc_int_t * libvlc_InternalCreate( void )
/* Now that the thread system is initialized, we don't have much, but /* Now that the thread system is initialized, we don't have much, but
* at least we have variables */ * at least we have variables */
vlc_mutex_t *lock = var_AcquireMutex( "libvlc" ); vlc_mutex_lock( &global_lock );
if( i_instances == 0 ) if( i_instances == 0 )
{ {
/* Guess what CPU we have */ /* Guess what CPU we have */
...@@ -254,7 +256,7 @@ libvlc_int_t * libvlc_InternalCreate( void ) ...@@ -254,7 +256,7 @@ libvlc_int_t * libvlc_InternalCreate( void )
VLC_OBJECT_GENERIC, "libvlc" ); VLC_OBJECT_GENERIC, "libvlc" );
if( p_libvlc != NULL ) if( p_libvlc != NULL )
i_instances++; i_instances++;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
if( p_libvlc == NULL ) if( p_libvlc == NULL )
return NULL; return NULL;
...@@ -1136,7 +1138,7 @@ int libvlc_InternalDestroy( libvlc_int_t *p_libvlc ) ...@@ -1136,7 +1138,7 @@ int libvlc_InternalDestroy( libvlc_int_t *p_libvlc )
p_libvlc->p_hotkeys ); p_libvlc->p_hotkeys );
FREENULL( p_libvlc->p_hotkeys ); FREENULL( p_libvlc->p_hotkeys );
vlc_mutex_t *lock = var_AcquireMutex( "libvlc" ); vlc_mutex_lock( &global_lock );
i_instances--; i_instances--;
if( i_instances == 0 ) if( i_instances == 0 )
...@@ -1144,7 +1146,7 @@ int libvlc_InternalDestroy( libvlc_int_t *p_libvlc ) ...@@ -1144,7 +1146,7 @@ int libvlc_InternalDestroy( libvlc_int_t *p_libvlc )
/* System specific cleaning code */ /* System specific cleaning code */
system_End( p_libvlc ); system_End( p_libvlc );
} }
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
msg_Flush( p_libvlc ); msg_Flush( p_libvlc );
msg_Destroy( p_libvlc ); msg_Destroy( p_libvlc );
......
...@@ -45,6 +45,7 @@ void system_End ( libvlc_int_t * ); ...@@ -45,6 +45,7 @@ void system_End ( libvlc_int_t * );
/* /*
* Threads subsystem * Threads subsystem
*/ */
vlc_mutex_t global_lock; /* TODO: remove this crap */
/* Hopefully, no need to export this. There is a new thread API instead. */ /* Hopefully, no need to export this. There is a new thread API instead. */
void vlc_thread_cancel (vlc_object_t *); void vlc_thread_cancel (vlc_object_t *);
......
...@@ -87,6 +87,8 @@ static void QueueMsg ( vlc_object_t *, int, const char *, ...@@ -87,6 +87,8 @@ static void QueueMsg ( vlc_object_t *, int, const char *,
static void FlushMsg ( msg_queue_t * ); static void FlushMsg ( msg_queue_t * );
static void PrintMsg ( vlc_object_t *, msg_item_t * ); static void PrintMsg ( vlc_object_t *, msg_item_t * );
static vlc_mutex_t msg_stack_lock = VLC_STATIC_MUTEX;
/** /**
* Initialize messages queues * Initialize messages queues
* This function initializes all message queues * This function initializes all message queues
...@@ -113,10 +115,10 @@ void msg_Create (libvlc_int_t *p_libvlc) ...@@ -113,10 +115,10 @@ void msg_Create (libvlc_int_t *p_libvlc)
SetFilePointer( QUEUE.logfile, 0, NULL, FILE_END ); SetFilePointer( QUEUE.logfile, 0, NULL, FILE_END );
#endif #endif
vlc_mutex_t *lock = var_AcquireMutex( "msg-stack" ); vlc_mutex_lock( &msg_stack_lock );
if( banks++ == 0 ) if( banks++ == 0 )
vlc_threadvar_create( &msg_context, NULL ); vlc_threadvar_create( &msg_context, NULL );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &msg_stack_lock );
} }
/** /**
...@@ -175,10 +177,10 @@ void msg_Destroy (libvlc_int_t *p_libvlc) ...@@ -175,10 +177,10 @@ void msg_Destroy (libvlc_int_t *p_libvlc)
FlushMsg( &QUEUE ); FlushMsg( &QUEUE );
vlc_mutex_t *lock = var_AcquireMutex( "msg-stack" ); vlc_mutex_lock( &msg_stack_lock );
if( --banks == 0 ) if( --banks == 0 )
vlc_threadvar_delete( &msg_context ); vlc_threadvar_delete( &msg_context );
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &msg_stack_lock );
#ifdef UNDER_CE #ifdef UNDER_CE
CloseHandle( QUEUE.logfile ); CloseHandle( QUEUE.logfile );
......
...@@ -120,7 +120,7 @@ void __module_InitBank( vlc_object_t *p_this ) ...@@ -120,7 +120,7 @@ void __module_InitBank( vlc_object_t *p_this )
{ {
module_bank_t *p_bank = NULL; module_bank_t *p_bank = NULL;
vlc_mutex_t *lock = var_AcquireMutex( "libvlc" ); vlc_mutex_lock( &global_lock );
if( p_module_bank == NULL ) if( p_module_bank == NULL )
{ {
...@@ -145,7 +145,7 @@ void __module_InitBank( vlc_object_t *p_this ) ...@@ -145,7 +145,7 @@ void __module_InitBank( vlc_object_t *p_this )
else else
p_module_bank->i_usage++; p_module_bank->i_usage++;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
} }
...@@ -161,17 +161,17 @@ void __module_EndBank( vlc_object_t *p_this ) ...@@ -161,17 +161,17 @@ void __module_EndBank( vlc_object_t *p_this )
{ {
module_bank_t *p_bank; module_bank_t *p_bank;
vlc_mutex_t *lock = var_AcquireMutex( "libvlc" ); vlc_mutex_lock( &global_lock );
p_bank = p_module_bank; p_bank = p_module_bank;
assert (p_bank != NULL); assert (p_bank != NULL);
if( --p_bank->i_usage > 0 ) if( --p_bank->i_usage > 0 )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
return; return;
} }
/*FIXME: For thread safety, we need to: /*FIXME: For thread safety, we need to:
p_module_bank = NULL; - immediately, but that will crash the cache */ p_module_bank = NULL; - immediately, but that will crash the cache */
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
/* Save the configuration */ /* Save the configuration */
config_AutoSaveConfigFile( p_this ); config_AutoSaveConfigFile( p_this );
...@@ -223,14 +223,14 @@ void __module_EndBank( vlc_object_t *p_this ) ...@@ -223,14 +223,14 @@ void __module_EndBank( vlc_object_t *p_this )
*/ */
void __module_LoadBuiltins( vlc_object_t * p_this ) void __module_LoadBuiltins( vlc_object_t * p_this )
{ {
vlc_mutex_t *lock = var_AcquireMutex( "libvlc" ); vlc_mutex_lock( &global_lock );
if( p_module_bank->b_builtins ) if( p_module_bank->b_builtins )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
return; return;
} }
p_module_bank->b_builtins = true; p_module_bank->b_builtins = true;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
msg_Dbg( p_this, "checking builtin modules" ); msg_Dbg( p_this, "checking builtin modules" );
ALLOCATE_ALL_BUILTINS(); ALLOCATE_ALL_BUILTINS();
...@@ -247,14 +247,14 @@ void __module_LoadBuiltins( vlc_object_t * p_this ) ...@@ -247,14 +247,14 @@ void __module_LoadBuiltins( vlc_object_t * p_this )
void __module_LoadPlugins( vlc_object_t * p_this ) void __module_LoadPlugins( vlc_object_t * p_this )
{ {
#ifdef HAVE_DYNAMIC_PLUGINS #ifdef HAVE_DYNAMIC_PLUGINS
vlc_mutex_t *lock = var_AcquireMutex( "libvlc" ); vlc_mutex_lock( &global_lock );
if( p_module_bank->b_plugins ) if( p_module_bank->b_plugins )
{ {
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
return; return;
} }
p_module_bank->b_plugins = true; p_module_bank->b_plugins = true;
vlc_mutex_unlock( lock ); vlc_mutex_unlock( &global_lock );
msg_Dbg( p_this, "checking plugin modules" ); msg_Dbg( p_this, "checking plugin modules" );
......
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