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

decoder: reduce lock scope and cosmetic

p_owner->b_paused can only be written by the owner, so the owner thread
does not need to lock to read it. (However, locking is necessary to
write it from the owner thread, or to read it from the decoder thread.)
parent a308b7a1
...@@ -2056,30 +2056,31 @@ void input_DecoderChangePause( decoder_t *p_dec, bool b_paused, mtime_t i_date ) ...@@ -2056,30 +2056,31 @@ void input_DecoderChangePause( decoder_t *p_dec, bool b_paused, mtime_t i_date )
{ {
decoder_owner_sys_t *p_owner = p_dec->p_owner; decoder_owner_sys_t *p_owner = p_dec->p_owner;
vlc_mutex_lock( &p_owner->lock );
/* Normally, p_owner->b_paused != b_paused here. But if a track is added /* Normally, p_owner->b_paused != b_paused here. But if a track is added
* while the input is paused (e.g. add sub file), then b_paused is * while the input is paused (e.g. add sub file), then b_paused is
* (incorrectly) false. */ * (incorrectly) false. FIXME: This is a bug in the decoder owner. */
if( likely(p_owner->b_paused != b_paused) ) { if( unlikely(p_owner->b_paused == b_paused) )
p_owner->b_paused = b_paused; return;
p_owner->pause.i_date = i_date;
p_owner->pause.i_ignore = 0; vlc_mutex_lock( &p_owner->lock );
vlc_cond_signal( &p_owner->wait_request ); p_owner->b_paused = b_paused;
p_owner->pause.i_date = i_date;
/* XXX only audio and video output have to be paused. p_owner->pause.i_ignore = 0;
* - for sout it is useless vlc_cond_signal( &p_owner->wait_request );
* - for subs, it is done by the vout
*/ /* XXX only audio and video output have to be paused.
if( p_owner->fmt.i_cat == AUDIO_ES ) * - for sout it is useless
{ * - for subs, it is done by the vout
if( p_owner->p_aout ) */
aout_DecChangePause( p_owner->p_aout, b_paused, i_date ); if( p_owner->fmt.i_cat == AUDIO_ES )
} {
else if( p_owner->fmt.i_cat == VIDEO_ES ) if( p_owner->p_aout )
{ aout_DecChangePause( p_owner->p_aout, b_paused, i_date );
if( p_owner->p_vout ) }
vout_ChangePause( p_owner->p_vout, b_paused, i_date ); else if( p_owner->fmt.i_cat == VIDEO_ES )
} {
if( p_owner->p_vout )
vout_ChangePause( p_owner->p_vout, b_paused, i_date );
} }
vlc_mutex_unlock( &p_owner->lock ); vlc_mutex_unlock( &p_owner->lock );
} }
......
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