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

decoder: keep the lock around DecoderWaitDate() and aout_DecPlay()

DecoderWaitDate() needs to return with the lock held to fix #5825.
Anyway, there was not much point in releasing the lock after
DecoderWaitUnblock() and acquire it again without sleeping.

aout_DecPlay() needs the lock, since the aout is not reentrant.
parent e7e30875
...@@ -1135,10 +1135,11 @@ static void DecoderWaitDate( decoder_t *p_dec, ...@@ -1135,10 +1135,11 @@ static void DecoderWaitDate( decoder_t *p_dec,
{ {
decoder_owner_sys_t *p_owner = p_dec->p_owner; decoder_owner_sys_t *p_owner = p_dec->p_owner;
vlc_assert_locked( &p_owner->lock );
if( *pb_reject || i_deadline < 0 ) if( *pb_reject || i_deadline < 0 )
return; return;
vlc_mutex_lock( &p_owner->lock );
do do
{ {
if( p_owner->b_flushing || p_owner->b_exit ) if( p_owner->b_flushing || p_owner->b_exit )
...@@ -1149,7 +1150,6 @@ static void DecoderWaitDate( decoder_t *p_dec, ...@@ -1149,7 +1150,6 @@ static void DecoderWaitDate( decoder_t *p_dec,
} }
while( vlc_cond_timedwait( &p_owner->wait_request, &p_owner->lock, while( vlc_cond_timedwait( &p_owner->wait_request, &p_owner->lock,
i_deadline ) == 0 ); i_deadline ) == 0 );
vlc_mutex_unlock( &p_owner->lock );
} }
static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio, static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio,
...@@ -1215,8 +1215,6 @@ static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio, ...@@ -1215,8 +1215,6 @@ static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio,
DecoderFixTs( p_dec, &p_audio->i_pts, NULL, &p_audio->i_length, DecoderFixTs( p_dec, &p_audio->i_pts, NULL, &p_audio->i_length,
&i_rate, AOUT_MAX_ADVANCE_TIME ); &i_rate, AOUT_MAX_ADVANCE_TIME );
vlc_mutex_unlock( &p_owner->lock );
if( !p_aout || if( !p_aout ||
p_audio->i_pts <= VLC_TS_INVALID || p_audio->i_pts <= VLC_TS_INVALID ||
i_rate < INPUT_RATE_DEFAULT/AOUT_MAX_INPUT_RATE || i_rate < INPUT_RATE_DEFAULT/AOUT_MAX_INPUT_RATE ||
...@@ -1228,6 +1226,7 @@ static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio, ...@@ -1228,6 +1226,7 @@ static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio,
if( !b_reject ) if( !b_reject )
{ {
assert( !p_owner->b_paused );
if( !aout_DecPlay( p_aout, p_audio, i_rate ) ) if( !aout_DecPlay( p_aout, p_audio, i_rate ) )
*pi_played_sum += 1; *pi_played_sum += 1;
*pi_lost_sum += aout_DecGetResetLost( p_aout ); *pi_lost_sum += aout_DecGetResetLost( p_aout );
...@@ -1244,9 +1243,7 @@ static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio, ...@@ -1244,9 +1243,7 @@ static void DecoderPlayAudio( decoder_t *p_dec, aout_buffer_t *p_audio,
} }
if( !b_has_more ) if( !b_has_more )
return; break;
vlc_mutex_lock( &p_owner->lock );
if( !p_owner->buffer.p_audio ) if( !p_owner->buffer.p_audio )
break; break;
} }
...@@ -1593,13 +1590,12 @@ static void DecoderPlaySpu( decoder_t *p_dec, subpicture_t *p_subpic ) ...@@ -1593,13 +1590,12 @@ static void DecoderPlaySpu( decoder_t *p_dec, subpicture_t *p_subpic )
DecoderFixTs( p_dec, &p_subpic->i_start, &p_subpic->i_stop, NULL, DecoderFixTs( p_dec, &p_subpic->i_start, &p_subpic->i_stop, NULL,
NULL, INT64_MAX ); NULL, INT64_MAX );
vlc_mutex_unlock( &p_owner->lock );
if( p_subpic->i_start <= VLC_TS_INVALID ) if( p_subpic->i_start <= VLC_TS_INVALID )
b_reject = true; b_reject = true;
DecoderWaitDate( p_dec, &b_reject, DecoderWaitDate( p_dec, &b_reject,
p_subpic->i_start - SPU_MAX_PREPARE_TIME ); p_subpic->i_start - SPU_MAX_PREPARE_TIME );
vlc_mutex_unlock( &p_owner->lock );
if( !b_reject ) if( !b_reject )
vout_PutSubpicture( p_vout, p_subpic ); vout_PutSubpicture( p_vout, p_subpic );
......
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