Commit b213aefc authored by Laurent Aimar's avatar Laurent Aimar

Fixed a potential crash in aout_FiltersPlay.

This function was returning a buffer allocated with the wrong type (alloca)
when a filter returned 0 sample (scaletempo at least).
parent 2b1be1cc
...@@ -334,7 +334,7 @@ void aout_FiltersPlay( aout_instance_t * p_aout, ...@@ -334,7 +334,7 @@ void aout_FiltersPlay( aout_instance_t * p_aout,
{ {
int i; int i;
for ( i = 0; i < i_nb_filters; i++ ) for( i = 0; i < i_nb_filters; i++ )
{ {
aout_filter_t * p_filter = pp_filters[i]; aout_filter_t * p_filter = pp_filters[i];
aout_buffer_t * p_output_buffer; aout_buffer_t * p_output_buffer;
...@@ -343,25 +343,32 @@ void aout_FiltersPlay( aout_instance_t * p_aout, ...@@ -343,25 +343,32 @@ void aout_FiltersPlay( aout_instance_t * p_aout,
* p_filter->output.i_rate / p_filter->input.i_rate) so we need * p_filter->output.i_rate / p_filter->input.i_rate) so we need
* slightly bigger buffers. */ * slightly bigger buffers. */
aout_BufferAlloc( &p_filter->output_alloc, aout_BufferAlloc( &p_filter->output_alloc,
((mtime_t)(*pp_input_buffer)->i_nb_samples + 2) ((mtime_t)(*pp_input_buffer)->i_nb_samples + 2)
* 1000000 / p_filter->input.i_rate, * 1000000 / p_filter->input.i_rate,
*pp_input_buffer, p_output_buffer ); *pp_input_buffer, p_output_buffer );
if ( p_output_buffer == NULL ) if( p_output_buffer == NULL )
return; return;
/* Please note that p_output_buffer->i_nb_samples & i_nb_bytes /* Please note that p_output_buffer->i_nb_samples & i_nb_bytes
* shall be set by the filter plug-in. */ * shall be set by the filter plug-in. */
if( (*pp_input_buffer)->i_nb_samples > 0 )
{
p_filter->pf_do_work( p_aout, p_filter, *pp_input_buffer,
p_output_buffer );
}
else
{
p_output_buffer->i_nb_bytes = 0;
p_output_buffer->i_nb_samples = 0;
}
p_filter->pf_do_work( p_aout, p_filter, *pp_input_buffer, if( !p_filter->b_in_place )
p_output_buffer );
if ( !p_filter->b_in_place )
{ {
aout_BufferFree( *pp_input_buffer ); aout_BufferFree( *pp_input_buffer );
*pp_input_buffer = p_output_buffer; *pp_input_buffer = p_output_buffer;
} }
if( p_output_buffer->i_nb_samples <= 0 )
break;
} }
assert( (*pp_input_buffer) == NULL || (*pp_input_buffer)->i_alloc_type != AOUT_ALLOC_STACK );
} }
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