By the way, its earlier (<= 0.8.6) incarnation were buggy.
-VLC_EXPORT(void, vlc_thread_ready, (vlc_object_t *obj));
-#define vlc_thread_ready(o) vlc_thread_ready(VLC_OBJECT(o))
-
/**
* Save the cancellation state and disable cancellation for the calling thread.
* This function must be called before entering a piece of code that is not
/**
* Save the cancellation state and disable cancellation for the calling thread.
* This function must be called before entering a piece of code that is not
VLC_EXPORT(char **, module_GetModulesNamesForCapability,
( const char * psz_capability, char ***psz_longname ) );
VLC_EXPORT(char **, module_GetModulesNamesForCapability,
( const char * psz_capability, char ***psz_longname ) );
-#ifdef LIBVLC_USE_PTHREAD
-# include <semaphore.h> /* TODO: get rid of vlc_thread_ready and this */
-#endif
-
/**
* Private LibVLC data for each object.
*/
/**
* Private LibVLC data for each object.
*/
/* Thread properties, if any */
vlc_thread_t thread_id;
bool b_thread;
/* Thread properties, if any */
vlc_thread_t thread_id;
bool b_thread;
-#ifdef LIBVLC_USE_PTHREAD
- sem_t thread_ready;
-#elif defined (WIN32)
- HANDLE thread_ready;
-#endif
/* Objects thread synchronization */
vlc_mutex_t lock;
/* Objects thread synchronization */
vlc_mutex_t lock;
vlc_submodule_create
__vlc_thread_create
__vlc_thread_join
vlc_submodule_create
__vlc_thread_create
__vlc_thread_join
__vlc_thread_set_priority
vlc_threadvar_create
vlc_threadvar_delete
__vlc_thread_set_priority
vlc_threadvar_create
vlc_threadvar_delete
assert( !p_priv->b_thread );
#if defined( LIBVLC_USE_PTHREAD )
assert( !p_priv->b_thread );
#if defined( LIBVLC_USE_PTHREAD )
- if (b_wait)
- sem_init (&p_priv->thread_ready, 0, 0);
#ifndef __APPLE__
if( config_GetInt( p_this, "rt-priority" ) > 0 )
#endif
#ifndef __APPLE__
if( config_GetInt( p_this, "rt-priority" ) > 0 )
#endif
if( config_GetType( p_this, "rt-offset" ) )
i_priority += config_GetInt( p_this, "rt-offset" );
}
if( config_GetType( p_this, "rt-offset" ) )
i_priority += config_GetInt( p_this, "rt-offset" );
}
-#elif defined (WIN32)
- if (b_wait)
- p_priv->thread_ready = CreateEvent (NULL, TRUE, FALSE, NULL);
#endif
p_priv->b_thread = true;
#endif
p_priv->b_thread = true;
{
msg_Dbg( p_this, "thread (%s) created at priority %d (%s:%d)",
psz_name, i_priority, psz_file, i_line );
{
msg_Dbg( p_this, "thread (%s) created at priority %d (%s:%d)",
psz_name, i_priority, psz_file, i_line );
- if( b_wait )
- {
- msg_Dbg( p_this, "waiting for thread initialization" );
-#if defined (LIBVLC_USE_PTHREAD)
- sem_wait (&p_priv->thread_ready);
- sem_destroy (&p_priv->thread_ready);
-#elif defined (WIN32)
- WaitForSingleObject (p_priv->thread_ready, INFINITE);
- CloseHandle (p_priv->thread_ready);
-#endif
- }
-#undef vlc_thread_ready
-void vlc_thread_ready (vlc_object_t *obj)
-{
- vlc_object_internals_t *priv = vlc_internals (obj);
-
- assert (priv->b_thread);
-#if defined (LIBVLC_USE_PTHREAD)
- assert (pthread_equal (pthread_self (), priv->thread_id));
- sem_post (&priv->thread_ready);
-#elif defined (WIN32)
- SetEvent (priv->thread_ready);
-#endif
-}
-
/*****************************************************************************
* vlc_thread_set_priority: set the priority of the current thread when we
* couldn't set it in vlc_thread_create (for instance for the main thread)
/*****************************************************************************
* vlc_thread_set_priority: set the priority of the current thread when we
* couldn't set it in vlc_thread_create (for instance for the main thread)