Commit e0ac4474 authored by Eric Petit's avatar Eric Petit

Fixed a segfault by adding a mutex_lock() (thx fenrir)

parent 3b078b7b
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* AudioOutput.cpp: BeOS audio output * AudioOutput.cpp: BeOS audio output
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000, 2001 VideoLAN * Copyright (C) 1999, 2000, 2001 VideoLAN
* $Id: AudioOutput.cpp,v 1.17 2002/11/27 05:36:41 titer Exp $ * $Id: AudioOutput.cpp,v 1.18 2002/11/27 06:27:52 titer Exp $
* *
* Authors: Jean-Marc Dressler <polux@via.ecp.fr> * Authors: Jean-Marc Dressler <polux@via.ecp.fr>
* Samuel Hocevar <sam@zoy.org> * Samuel Hocevar <sam@zoy.org>
...@@ -129,20 +129,17 @@ static void Play( void *aout, void *p_buffer, size_t i_size, ...@@ -129,20 +129,17 @@ static void Play( void *aout, void *p_buffer, size_t i_size,
aout_buffer_t * p_aout_buffer; aout_buffer_t * p_aout_buffer;
aout_instance_t *p_aout = (aout_instance_t*) aout; aout_instance_t *p_aout = (aout_instance_t*) aout;
vlc_mutex_lock( &p_aout->output_fifo_lock );
p_aout_buffer = aout_FifoPop( p_aout, &p_aout->output.fifo ); p_aout_buffer = aout_FifoPop( p_aout, &p_aout->output.fifo );
vlc_mutex_unlock( &p_aout->output_fifo_lock );
if( p_aout_buffer != NULL ) if( p_aout_buffer != NULL )
{
/* sometimes p_aout_buffer is not NULL but still isn't valid.
we check i_nb_bytes so we are sure it is */
if( p_aout_buffer->i_nb_bytes == BUFFER_SIZE )
{ {
memcpy( (float*)p_buffer, memcpy( (float*)p_buffer,
p_aout_buffer->p_buffer, p_aout_buffer->p_buffer,
BUFFER_SIZE ); MIN( BUFFER_SIZE, p_aout_buffer->i_nb_bytes ) );
aout_BufferFree( p_aout_buffer ); aout_BufferFree( p_aout_buffer );
} }
}
} }
/***************************************************************************** /*****************************************************************************
......
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