Commit 347c0fec authored by Sam Hocevar's avatar Sam Hocevar

* ./plugins/mpeg_system/mpeg_es.c: fixed a segfault when no decoder was

    found (p_fifo might be NULL).
  * ./plugins/mpeg_system/mpeg_es.c, ./src/input/input_ext-dec.c: fixed
    a deadlock issue with demuxers waiting on p_fifo->data_lock.
parent bd0431f6
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* mpeg_es.c : Elementary Stream input module for vlc * mpeg_es.c : Elementary Stream input module for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2001 VideoLAN * Copyright (C) 2001 VideoLAN
* $Id: mpeg_es.c,v 1.10 2002/07/23 00:39:17 sam Exp $ * $Id: mpeg_es.c,v 1.11 2002/07/24 15:21:47 sam Exp $
* *
* Authors: Christophe Massiot <massiot@via.ecp.fr> * Authors: Christophe Massiot <massiot@via.ecp.fr>
* *
...@@ -172,12 +172,17 @@ static int ESDemux( input_thread_t * p_input ) ...@@ -172,12 +172,17 @@ static int ESDemux( input_thread_t * p_input )
p_input->stream.p_selected_program->pp_es[0]->p_decoder_fifo; p_input->stream.p_selected_program->pp_es[0]->p_decoder_fifo;
pes_packet_t * p_pes; pes_packet_t * p_pes;
data_packet_t * p_data; data_packet_t * p_data;
if( p_fifo == NULL )
{
return -1;
}
i_read = input_SplitBuffer( p_input, &p_data, ES_PACKET_SIZE ); i_read = input_SplitBuffer( p_input, &p_data, ES_PACKET_SIZE );
if ( i_read <= 0 ) if ( i_read <= 0 )
{ {
return( i_read ); return i_read;
} }
p_pes = input_NewPES( p_input->p_method_data ); p_pes = input_NewPES( p_input->p_method_data );
...@@ -186,7 +191,7 @@ static int ESDemux( input_thread_t * p_input ) ...@@ -186,7 +191,7 @@ static int ESDemux( input_thread_t * p_input )
{ {
msg_Err( p_input, "out of memory" ); msg_Err( p_input, "out of memory" );
input_DeletePacket( p_input->p_method_data, p_data ); input_DeletePacket( p_input->p_method_data, p_data );
return( -1 ); return -1;
} }
p_pes->i_rate = p_input->stream.control.i_rate; p_pes->i_rate = p_input->stream.control.i_rate;
...@@ -194,6 +199,10 @@ static int ESDemux( input_thread_t * p_input ) ...@@ -194,6 +199,10 @@ static int ESDemux( input_thread_t * p_input )
p_pes->i_nb_data = 1; p_pes->i_nb_data = 1;
vlc_mutex_lock( &p_fifo->data_lock ); vlc_mutex_lock( &p_fifo->data_lock );
/* If the decoder is waiting for us, wake him up */
vlc_cond_signal( &p_fifo->data_wait );
if( p_fifo->i_depth >= MAX_PACKETS_IN_FIFO ) if( p_fifo->i_depth >= MAX_PACKETS_IN_FIFO )
{ {
/* Wait for the decoder. */ /* Wait for the decoder. */
...@@ -213,6 +222,6 @@ static int ESDemux( input_thread_t * p_input ) ...@@ -213,6 +222,6 @@ static int ESDemux( input_thread_t * p_input )
input_DecodePES( p_fifo, p_pes ); input_DecodePES( p_fifo, p_pes );
return( 1 ); return 1;
} }
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* input_ext-dec.c: services to the decoders * input_ext-dec.c: services to the decoders
***************************************************************************** *****************************************************************************
* Copyright (C) 1998-2001 VideoLAN * Copyright (C) 1998-2001 VideoLAN
* $Id: input_ext-dec.c,v 1.32 2002/06/01 12:32:01 sam Exp $ * $Id: input_ext-dec.c,v 1.33 2002/07/24 15:21:47 sam Exp $
* *
* Authors: Christophe Massiot <massiot@via.ecp.fr> * Authors: Christophe Massiot <massiot@via.ecp.fr>
* *
...@@ -99,6 +99,9 @@ void DecoderError( decoder_fifo_t * p_fifo ) ...@@ -99,6 +99,9 @@ void DecoderError( decoder_fifo_t * p_fifo )
p_fifo->p_first = NULL; p_fifo->p_first = NULL;
p_fifo->pp_last = &p_fifo->p_first; p_fifo->pp_last = &p_fifo->p_first;
/* If the input is waiting for us, tell him to stop */
vlc_cond_signal( &p_fifo->data_wait );
/* Waiting for the input thread to put new PES packets in the fifo */ /* Waiting for the input thread to put new PES packets in the fifo */
vlc_cond_wait (&p_fifo->data_wait, &p_fifo->data_lock); vlc_cond_wait (&p_fifo->data_wait, &p_fifo->data_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