Commit 481e0b5b authored by Laurent Aimar's avatar Laurent Aimar

Fixed segfault with --minimize-threads

parent a73c1e41
...@@ -679,6 +679,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block ) ...@@ -679,6 +679,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block )
} }
else if( p_dec->fmt_in.i_cat == AUDIO_ES ) else if( p_dec->fmt_in.i_cat == AUDIO_ES )
{ {
if( p_block )
DecoderUpdatePreroll( &p_dec->p_owner->i_preroll_end, p_block ); DecoderUpdatePreroll( &p_dec->p_owner->i_preroll_end, p_block );
if( p_dec->p_owner->p_packetizer ) if( p_dec->p_owner->p_packetizer )
...@@ -687,7 +688,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block ) ...@@ -687,7 +688,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block )
decoder_t *p_packetizer = p_dec->p_owner->p_packetizer; decoder_t *p_packetizer = p_dec->p_owner->p_packetizer;
while( (p_packetized_block = while( (p_packetized_block =
p_packetizer->pf_packetize( p_packetizer, &p_block )) ) p_packetizer->pf_packetize( p_packetizer, p_block ? &p_block : NULL )) )
{ {
if( p_packetizer->fmt_out.i_extra && !p_dec->fmt_in.i_extra ) if( p_packetizer->fmt_out.i_extra && !p_dec->fmt_in.i_extra )
{ {
...@@ -707,13 +708,14 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block ) ...@@ -707,13 +708,14 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block )
} }
} }
} }
else else if( p_block )
{ {
DecoderDecodeAudio( p_dec, p_block ); DecoderDecodeAudio( p_dec, p_block );
} }
} }
else if( p_dec->fmt_in.i_cat == VIDEO_ES ) else if( p_dec->fmt_in.i_cat == VIDEO_ES )
{ {
if( p_block )
DecoderUpdatePreroll( &p_dec->p_owner->i_preroll_end, p_block ); DecoderUpdatePreroll( &p_dec->p_owner->i_preroll_end, p_block );
if( p_dec->p_owner->p_packetizer ) if( p_dec->p_owner->p_packetizer )
...@@ -722,7 +724,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block ) ...@@ -722,7 +724,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block )
decoder_t *p_packetizer = p_dec->p_owner->p_packetizer; decoder_t *p_packetizer = p_dec->p_owner->p_packetizer;
while( (p_packetized_block = while( (p_packetized_block =
p_packetizer->pf_packetize( p_packetizer, &p_block )) ) p_packetizer->pf_packetize( p_packetizer, p_block ? &p_block : NULL )) )
{ {
if( p_packetizer->fmt_out.i_extra && !p_dec->fmt_in.i_extra ) if( p_packetizer->fmt_out.i_extra && !p_dec->fmt_in.i_extra )
{ {
...@@ -742,7 +744,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block ) ...@@ -742,7 +744,7 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block )
} }
} }
} }
else else if( p_block )
{ {
DecoderDecodeVideo( p_dec, p_block ); DecoderDecodeVideo( p_dec, p_block );
} }
...@@ -753,9 +755,10 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block ) ...@@ -753,9 +755,10 @@ static int DecoderDecode( decoder_t *p_dec, block_t *p_block )
vout_thread_t *p_vout; vout_thread_t *p_vout;
subpicture_t *p_spu; subpicture_t *p_spu;
if( p_block )
DecoderUpdatePreroll( &p_dec->p_owner->i_preroll_end, p_block ); DecoderUpdatePreroll( &p_dec->p_owner->i_preroll_end, p_block );
while( (p_spu = p_dec->pf_decode_sub( p_dec, &p_block ) ) ) while( (p_spu = p_dec->pf_decode_sub( p_dec, p_block ? &p_block : NULL ) ) )
{ {
vlc_mutex_lock( &p_input->p->counters.counters_lock ); vlc_mutex_lock( &p_input->p->counters.counters_lock );
stats_UpdateInteger( p_dec, p_input->p->counters.p_decoded_sub, 1, NULL ); stats_UpdateInteger( p_dec, p_input->p->counters.p_decoded_sub, 1, NULL );
......
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