Commit c365acef authored by Pierre d'Herbemont's avatar Pierre d'Herbemont

media_instance: Don't rely on vlc_object_find now that input refcounting is fixed.

parent af3a9f1b
...@@ -183,8 +183,7 @@ struct libvlc_media_instance_t ...@@ -183,8 +183,7 @@ struct libvlc_media_instance_t
{ {
int i_refcount; int i_refcount;
vlc_mutex_t object_lock; vlc_mutex_t object_lock;
int i_input_id; /* Input object id. We don't use a pointer to input_thread_t * p_input_thread;
avoid any crash */
struct libvlc_instance_t * p_libvlc_instance; /* Parent instance */ struct libvlc_instance_t * p_libvlc_instance; /* Parent instance */
libvlc_media_descriptor_t * p_md; /* current media descriptor */ libvlc_media_descriptor_t * p_md; /* current media descriptor */
libvlc_event_manager_t * p_event_manager; libvlc_event_manager_t * p_event_manager;
......
...@@ -74,18 +74,12 @@ static inline libvlc_state_t vlc_to_libvlc_state( int vlc_state ) ...@@ -74,18 +74,12 @@ static inline libvlc_state_t vlc_to_libvlc_state( int vlc_state )
*/ */
static void release_input_thread( libvlc_media_instance_t *p_mi ) static void release_input_thread( libvlc_media_instance_t *p_mi )
{ {
input_thread_t *p_input_thread; input_thread_t * p_input_thread;
if( !p_mi || p_mi->i_input_id == -1 )
return;
p_input_thread = (input_thread_t*)vlc_object_get( p_mi->i_input_id );
p_mi->i_input_id = -1;
if( !p_input_thread ) if( !p_mi || !p_mi->p_input_thread )
return; return;
p_input_thread = p_mi->p_input_thread;
/* No one is tracking this input_thread appart us. Destroy it */ /* No one is tracking this input_thread appart us. Destroy it */
if( p_mi->b_own_its_input_thread ) if( p_mi->b_own_its_input_thread )
...@@ -101,13 +95,10 @@ static void release_input_thread( libvlc_media_instance_t *p_mi ) ...@@ -101,13 +95,10 @@ static void release_input_thread( libvlc_media_instance_t *p_mi )
var_Destroy( p_input_thread, "drawable" ); var_Destroy( p_input_thread, "drawable" );
} }
else
{
vlc_object_release( p_input_thread );
}
/* release for previous vlc_object_get */
vlc_object_release( p_input_thread ); vlc_object_release( p_input_thread );
p_mi->p_input_thread = NULL;
} }
/* /*
...@@ -121,27 +112,21 @@ input_thread_t *libvlc_get_input_thread( libvlc_media_instance_t *p_mi, ...@@ -121,27 +112,21 @@ input_thread_t *libvlc_get_input_thread( libvlc_media_instance_t *p_mi,
{ {
input_thread_t *p_input_thread; input_thread_t *p_input_thread;
if ( !p_mi ) if( !p_mi ) RAISENULL( "Media Instance is NULL" );
{
RAISENULL( "Input is NULL" );
}
vlc_mutex_lock( &p_mi->object_lock ); vlc_mutex_lock( &p_mi->object_lock );
if( !p_mi || p_mi->i_input_id == -1 ) if( !p_mi->p_input_thread )
{ {
vlc_mutex_unlock( &p_mi->object_lock ); vlc_mutex_unlock( &p_mi->object_lock );
RAISENULL( "Input is NULL" ); RAISENULL( "Input is NULL" );
} }
p_input_thread = (input_thread_t*)vlc_object_get( p_mi->i_input_id ); p_input_thread = p_mi->p_input_thread;
if( !p_input_thread ) vlc_object_yield( p_input_thread );
{
vlc_mutex_unlock( &p_mi->object_lock );
RAISENULL( "Input does not exist" );
}
vlc_mutex_unlock( &p_mi->object_lock ); vlc_mutex_unlock( &p_mi->object_lock );
return p_input_thread; return p_input_thread;
} }
...@@ -308,7 +293,7 @@ libvlc_media_instance_new( libvlc_instance_t * p_libvlc_instance, ...@@ -308,7 +293,7 @@ libvlc_media_instance_new( libvlc_instance_t * p_libvlc_instance,
p_mi->p_md = NULL; p_mi->p_md = NULL;
p_mi->drawable = 0; p_mi->drawable = 0;
p_mi->p_libvlc_instance = p_libvlc_instance; p_mi->p_libvlc_instance = p_libvlc_instance;
p_mi->i_input_id = -1; p_mi->p_input_thread = NULL;
/* refcount strategy: /* refcount strategy:
* - All items created by _new start with a refcount set to 1 * - All items created by _new start with a refcount set to 1
* - Accessor _release decrease the refcount by 1, if after that * - Accessor _release decrease the refcount by 1, if after that
...@@ -401,12 +386,12 @@ libvlc_media_instance_t * libvlc_media_instance_new_from_input_thread( ...@@ -401,12 +386,12 @@ libvlc_media_instance_t * libvlc_media_instance_new_from_input_thread(
return NULL; return NULL;
} }
p_mi->i_input_id = p_input->i_object_id;
p_mi->b_own_its_input_thread = VLC_FALSE;
/* will be released in media_instance_release() */ /* will be released in media_instance_release() */
vlc_object_yield( p_input ); vlc_object_yield( p_input );
p_mi->p_input_thread = p_input;
p_mi->b_own_its_input_thread = VLC_FALSE;
return p_mi; return p_mi;
} }
...@@ -580,17 +565,20 @@ void libvlc_media_instance_play( libvlc_media_instance_t *p_mi, ...@@ -580,17 +565,20 @@ void libvlc_media_instance_play( libvlc_media_instance_t *p_mi,
return; return;
} }
p_mi->i_input_id = input_Read( p_mi->p_libvlc_instance->p_libvlc_int, int i_input_id = input_Read( p_mi->p_libvlc_instance->p_libvlc_int,
p_mi->p_md->p_input_item, VLC_FALSE ); p_mi->p_md->p_input_item, VLC_FALSE );
p_input_thread = (input_thread_t*)vlc_object_get( p_mi->i_input_id ); /* Released in input_release */
p_mi->p_input_thread = (input_thread_t*)vlc_object_get( i_input_id );
if( !p_input_thread ) if( !p_mi->p_input_thread )
{ {
return; return;
vlc_mutex_unlock( &p_mi->object_lock ); vlc_mutex_unlock( &p_mi->object_lock );
} }
p_input_thread = p_mi->p_input_thread;
if( p_mi->drawable ) if( p_mi->drawable )
{ {
vlc_value_t val; vlc_value_t val;
...@@ -604,7 +592,6 @@ void libvlc_media_instance_play( libvlc_media_instance_t *p_mi, ...@@ -604,7 +592,6 @@ void libvlc_media_instance_play( libvlc_media_instance_t *p_mi,
var_AddCallback( p_input_thread, "intf-change", input_position_changed, p_mi ); var_AddCallback( p_input_thread, "intf-change", input_position_changed, p_mi );
var_AddCallback( p_input_thread, "intf-change", input_time_changed, p_mi ); var_AddCallback( p_input_thread, "intf-change", input_time_changed, p_mi );
vlc_object_release( p_input_thread );
vlc_mutex_unlock( &p_mi->object_lock ); vlc_mutex_unlock( &p_mi->object_lock );
} }
......
...@@ -147,8 +147,8 @@ libvlc_video_take_snapshot( libvlc_media_instance_t *p_mi, char *psz_filepath, ...@@ -147,8 +147,8 @@ libvlc_video_take_snapshot( libvlc_media_instance_t *p_mi, char *psz_filepath,
var_SetInteger( p_vout, "snapshot-width", i_width ); var_SetInteger( p_vout, "snapshot-width", i_width );
var_SetInteger( p_vout, "snapshot-height", i_height ); var_SetInteger( p_vout, "snapshot-height", i_height );
p_input_thread = (input_thread_t*)vlc_object_get( p_mi->i_input_id ); p_input_thread = p_mi->p_input_thread;
if( !p_input_thread ) if( !p_mi->p_input_thread )
{ {
libvlc_exception_raise( p_e, "Input does not exist" ); libvlc_exception_raise( p_e, "Input does not exist" );
return; return;
...@@ -159,7 +159,6 @@ libvlc_video_take_snapshot( libvlc_media_instance_t *p_mi, char *psz_filepath, ...@@ -159,7 +159,6 @@ libvlc_video_take_snapshot( libvlc_media_instance_t *p_mi, char *psz_filepath,
vout_Control( p_vout, VOUT_SNAPSHOT ); vout_Control( p_vout, VOUT_SNAPSHOT );
vlc_object_release( p_vout ); vlc_object_release( p_vout );
vlc_object_release( p_input_thread );
} }
int libvlc_video_get_height( libvlc_media_instance_t *p_mi, int libvlc_video_get_height( libvlc_media_instance_t *p_mi,
......
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