X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Faudio_mixer%2Ffloat32.c;h=c3284b63fcb93b56de64303817b526aad04a6004;hb=300a5c1017d98a0cb0435e2ff9889204c7187c1f;hp=001df14a50cd71c151482bf2c7e84bce6fbc8c68;hpb=81442b6bf1af46dbaedc3388ea0b48f55bf13ae1;p=vlc diff --git a/modules/audio_mixer/float32.c b/modules/audio_mixer/float32.c index 001df14a50..c3284b63fc 100644 --- a/modules/audio_mixer/float32.c +++ b/modules/audio_mixer/float32.c @@ -1,8 +1,8 @@ /***************************************************************************** * float32.c : precise float32 audio mixer implementation ***************************************************************************** - * Copyright (C) 2002 VideoLAN - * $Id: float32.c,v 1.3 2002/09/19 21:56:39 massiot Exp $ + * Copyright (C) 2002 the VideoLAN team + * $Id$ * * Authors: Christophe Massiot * @@ -18,13 +18,12 @@ * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ /***************************************************************************** * Preamble *****************************************************************************/ -#include #include /* malloc(), free() */ #include @@ -43,19 +42,21 @@ static void DoWork ( aout_instance_t *, aout_buffer_t * ); * Module descriptor *****************************************************************************/ vlc_module_begin(); - set_description( _("float32 audio mixer module") ); + set_category( CAT_AUDIO ); + set_subcategory( SUBCAT_AUDIO_MISC ); + set_description( _("Float32 audio mixer") ); set_capability( "audio mixer", 10 ); set_callbacks( Create, NULL ); vlc_module_end(); /***************************************************************************** - * Create: allocate trivial mixer + * Create: allocate mixer *****************************************************************************/ static int Create( vlc_object_t *p_this ) { aout_instance_t * p_aout = (aout_instance_t *)p_this; - if ( p_aout->mixer.mixer.i_format != AOUT_FMT_FLOAT32 ) + if ( p_aout->mixer.mixer.i_format != VLC_FOURCC('f','l','3','2') ) { return -1; } @@ -112,21 +113,23 @@ static void DoWork( aout_instance_t * p_aout, aout_buffer_t * p_buffer ) int i_nb_inputs = p_aout->i_nb_inputs; float f_multiplier = p_aout->mixer.f_multiplier; int i_input; + int i_nb_channels = aout_FormatNbChannels( &p_aout->mixer.mixer ); for ( i_input = 0; i_input < i_nb_inputs; i_input++ ) { - int i_nb_words = p_buffer->i_nb_samples - * p_aout->mixer.mixer.i_channels; + int i_nb_words = p_buffer->i_nb_samples * i_nb_channels; aout_input_t * p_input = p_aout->pp_inputs[i_input]; float * p_out = (float *)p_buffer->p_buffer; float * p_in = (float *)p_input->p_first_byte_to_mix; + if ( p_input->b_error ) continue; + for ( ; ; ) { ptrdiff_t i_available_words = ( (float *)p_input->fifo.p_first->p_buffer - p_in) + p_input->fifo.p_first->i_nb_samples - * p_aout->mixer.mixer.i_channels; + * i_nb_channels; if ( i_available_words < i_nb_words ) {