]> git.sesse.net Git - vlc/commitdiff
* ./modules/audio_output/esd.c: we now properly use the esd_get_latency()
authorSam Hocevar <sam@videolan.org>
Tue, 13 Aug 2002 14:53:46 +0000 (14:53 +0000)
committerSam Hocevar <sam@videolan.org>
Tue, 13 Aug 2002 14:53:46 +0000 (14:53 +0000)
    return value to avoid audio starvation.
  * ./modules/audio_filter/converter/*: a little loop optimization trick.
  * ./src/audio_output/aout_ext-dec.c: removed this deprecated file.

modules/audio_filter/converter/a52tospdif.c
modules/audio_filter/converter/fixed32tofloat32.c
modules/audio_filter/converter/fixed32tos16.c
modules/audio_output/esd.c
src/audio_output/aout_ext-dec.c [deleted file]

index 849546f253f3b70a7d8a5d7c782d92e0a8414138..89c204e6de0b48efe2af7f57a8d58b6e6db1309b 100644 (file)
@@ -2,7 +2,7 @@
  * a52tospdif.c : encapsulates A/52 frames into S/PDIF packets
  *****************************************************************************
  * Copyright (C) 2002 VideoLAN
- * $Id: a52tospdif.c,v 1.4 2002/08/13 11:59:36 sam Exp $
+ * $Id: a52tospdif.c,v 1.5 2002/08/13 14:53:46 sam Exp $
  *
  * Authors: Christophe Massiot <massiot@via.ecp.fr>
  *          Stéphane Borel <stef@via.ecp.fr>
@@ -105,7 +105,7 @@ static void DoWork( aout_instance_t * p_aout, aout_filter_t * p_filter,
     swab( p_out + 8, p_in, i_length );
 #   else
     p_out += 8;
-    for ( i = 0; i < i_length / 2; i++ )
+    for ( i = i_length / 2 ; i-- ; )
     {
         p_out[0] = p_in[1];
         p_out[1] = p_in[0];
index d36bafa9b49a55b785db6f79c9d17b7a864883ed..f722ddc89e495ae9c76cfd8e706a2de552e2bef4 100644 (file)
@@ -2,7 +2,7 @@
  * fixed32float32.c : converter from fixed32 to float32 bits integer
  *****************************************************************************
  * Copyright (C) 2002 VideoLAN
- * $Id: fixed32tofloat32.c,v 1.2 2002/08/12 21:40:40 jpsaman Exp $
+ * $Id: fixed32tofloat32.c,v 1.3 2002/08/13 14:53:46 sam Exp $
  *
  * Authors: Jean-Paul Saman <jpsaman@wxs.nl>
  *
@@ -88,20 +88,24 @@ static void DoWork( aout_instance_t * p_aout, aout_filter_t * p_filter,
     vlc_fixed_t * p_in = (vlc_fixed_t *)p_in_buf->p_buffer;
     float * p_out = (float *)p_out_buf->p_buffer;
 
-    for ( i = 0; i < p_in_buf->i_nb_samples * p_filter->input.i_channels; i++ )
+    for ( i = p_in_buf->i_nb_samples * p_filter->input.i_channels ; i-- )
     {
         /* convert vlc_fixed_t into s32 */
-//        s32 temp;
-//        if ( *p_in >= 8 ) temp = 32767;
-//        else if ( *p_in < -8 ) temp = -32768;
-//        else temp = *p_in * (s32) 4096; // (32768/8);
+#if 0
+        s32 temp;
+        if ( *p_in >= 8 ) temp = 32767;
+        else if ( *p_in < -8 ) temp = -32768;
+        else temp = *p_in * (s32) 4096; // (32768/8);
+#endif
 
         /* convert s32 into float */
-//        if (temp >= 32768)
-//            *p_out = (float) 1.0;
-//        else if (temp <= -32768)
-//            *p_out = (float) -1.0;
-//        else *p_out = (float) (temp/32768.0);
+#if 0
+        if (temp >= 32768)
+            *p_out = (float) 1.0;
+        else if (temp <= -32768)
+            *p_out = (float) -1.0;
+        else *p_out = (float) (temp/32768.0);
+#endif
 
         /* combined conversion */
         if ( *p_in >= 8 ) *p_out = (float) 1.0;
index 209997d47ad731039a0344a8c457b84acc329b25..0cc1badb68ad89c7b86e52244844bd6214c13d86 100644 (file)
@@ -1,8 +1,8 @@
 /*****************************************************************************
- * fixed32tos16.c : converter from fised32 to signed 16 bits integer
+ * fixed32tos16.c : converter from fixed32 to signed 16 bits integer
  *****************************************************************************
  * Copyright (C) 2002 VideoLAN
- * $Id: fixed32tos16.c,v 1.1 2002/08/12 20:34:56 jpsaman Exp $
+ * $Id: fixed32tos16.c,v 1.2 2002/08/13 14:53:46 sam Exp $
  *
  * Authors: Jean-Paul Saman <jpsaman@wxs.nl>
  *
@@ -201,7 +201,7 @@ static void DoWork( aout_instance_t * p_aout, aout_filter_t * p_filter,
     s16 sample;
 //    static struct audio_dither dither;
 
-    for ( i = 0; i < p_in_buf->i_nb_samples * p_filter->input.i_channels; i++ )
+    for ( i = p_in_buf->i_nb_samples * p_filter->input.i_channels ; i-- )
     {
         /* Accurate scaling */
 //        p_out = mpg321_s24_to_s16_pcm(16, *p_in++, &dither);
index 0f4743dd800dcd82f2dd4cefa5cfd63c33120428..99a7e271063bea1709c06da0a3b7df108bf32382 100644 (file)
@@ -2,7 +2,7 @@
  * esd.c : EsounD module
  *****************************************************************************
  * Copyright (C) 2000, 2001 VideoLAN
- * $Id: esd.c,v 1.2 2002/08/13 11:59:36 sam Exp $
+ * $Id: esd.c,v 1.3 2002/08/13 14:53:46 sam Exp $
  *
  * Authors: Samuel Hocevar <sam@zoy.org>
  *
@@ -36,8 +36,6 @@
 
 #include <esd.h>
 
-#define DEFAULT_FRAME_SIZE 2048*2
-
 /*****************************************************************************
  * aout_sys_t: esd audio output method descriptor
  *****************************************************************************
@@ -49,6 +47,8 @@ struct aout_sys_t
     esd_format_t esd_format;
     int          i_fd;
     vlc_bool_t   b_initialized;
+
+    mtime_t      latency;
 };
 
 /*****************************************************************************
@@ -141,7 +141,17 @@ static int SetFormat( aout_instance_t *p_aout )
     }
 
     p_aout->output.output.i_format = AOUT_FMT_S16_NE;
-    p_aout->output.i_nb_samples = DEFAULT_FRAME_SIZE;
+    p_aout->output.i_nb_samples = ESD_BUF_SIZE * 2;
+
+    /* ESD latency is calculated for 44100 Hz. We don't have any way to get the
+     * number of buffered samples, so I assume ESD_BUF_SIZE/2 */
+    p_sys->latency =
+        (mtime_t)( esd_get_latency( esd_open_sound(NULL) ) + ESD_BUF_SIZE / 2
+                    * p_aout->output.output.i_rate / ESD_DEFAULT_RATE
+                    * aout_FormatTo( &p_aout->output.output, 1 ) )
+      * (mtime_t)1000000
+      / (mtime_t)aout_FormatToByterate( &p_aout->output.output,
+                                        p_aout->output.output.i_rate );
 
     p_sys->b_initialized = VLC_TRUE;
 
@@ -181,7 +191,6 @@ static int ESDThread( aout_instance_t * p_aout )
     while ( !p_aout->b_die )
     {
         aout_buffer_t * p_buffer;
-        mtime_t next_date = 0;
         int i_tmp, i_size;
         byte_t * p_bytes;
 
@@ -191,19 +200,9 @@ static int ESDThread( aout_instance_t * p_aout )
             continue;
         }
 
-        if ( p_aout->output.output.i_format != AOUT_FMT_SPDIF )
-        {
-            /* Get the presentation date of the next write() operation. It
-             * is equal to the current date + esd latency */
-            /* FIXME: wtf ? it works better with a - here */
-            next_date = -(mtime_t)esd_get_latency(esd_open_sound(NULL))
-                      * 1000000
-                      / aout_FormatToByterate( &p_aout->output.output,
-                                               p_aout->output.output.i_rate );
-            next_date += mdate();
-        }
-
-        p_buffer = aout_OutputNextBuffer( p_aout, next_date );
+        /* Get the presentation date of the next write() operation. It
+         * is equal to the current date + buffered samples + esd latency */
+        p_buffer = aout_OutputNextBuffer( p_aout, mdate() + p_sys->latency );
 
         if ( p_buffer != NULL )
         {
@@ -214,7 +213,7 @@ static int ESDThread( aout_instance_t * p_aout )
         else
         {
             i_size = aout_FormatToSize( &p_aout->output.output,
-                                        DEFAULT_FRAME_SIZE );
+                                        ESD_BUF_SIZE * 2 );
             p_bytes = alloca( i_size );
             memset( p_bytes, 0, i_size );
         }
diff --git a/src/audio_output/aout_ext-dec.c b/src/audio_output/aout_ext-dec.c
deleted file mode 100644 (file)
index 239ee03..0000000
+++ /dev/null
@@ -1,194 +0,0 @@
-/*****************************************************************************
- * aout_ext-dec.c : exported fifo management functions
- *****************************************************************************
- * Copyright (C) 1999-2001 VideoLAN
- * $Id: aout_ext-dec.c,v 1.21 2002/08/12 09:34:15 sam Exp $
- *
- * Authors: Michel Kaempf <maxx@via.ecp.fr>
- *          Cyril Deguet <asmax@via.ecp.fr>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- * 
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * 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.
- *****************************************************************************/
-
-/*****************************************************************************
- * Preamble
- *****************************************************************************/
-#include <stdlib.h>                            /* calloc(), malloc(), free() */
-#include <string.h>
-
-#include <vlc/vlc.h>
-
-#include "audio_output.h"
-
-/*****************************************************************************
- * aout_CreateFifo
- *****************************************************************************/
-aout_fifo_t * __aout_CreateFifo( vlc_object_t *p_this, int i_format,
-                                 int i_channels, int i_rate, int i_frame_size,
-                                 void *p_buffer )
-{
-    aout_thread_t *p_aout;
-    aout_fifo_t   *p_fifo = NULL;
-    int i_index;
-
-    /* Spawn an audio output if there is none */
-    p_aout = vlc_object_find( p_this, VLC_OBJECT_AOUT, FIND_ANYWHERE );
-
-    if( p_aout )
-    {
-        if( p_aout->fifo[0].i_format != i_format )
-        {
-            msg_Dbg( p_this, "changing aout type" );
-            vlc_object_detach( p_aout );
-            vlc_object_release( p_aout );
-            aout_DestroyThread( p_aout );
-            p_aout = NULL;
-        }
-    }
-
-    if( p_aout == NULL )
-    {
-        msg_Dbg( p_this, "no aout present, spawning one" );
-
-        p_aout = aout_CreateThread( p_this, i_channels, i_rate );
-        /* Everything failed */
-        if( p_aout == NULL )
-        {
-            return NULL;
-        }
-    }
-
-    /* temporary hack to switch output type (mainly for spdif)
-     * FIXME: to be adapted when several output are available */
-    /* Take the fifos lock */
-    vlc_mutex_lock( &p_aout->fifos_lock );
-
-    /* Look for a free fifo structure */
-    for( i_index = 0; i_index < AOUT_MAX_FIFOS; i_index++ )
-    {
-        if( p_aout->fifo[i_index].i_format == AOUT_FIFO_NONE )
-        {
-            p_fifo = &p_aout->fifo[i_index];
-            p_fifo->i_fifo = i_index;
-            break;
-        }
-    }
-
-    if( p_fifo == NULL )
-    {
-        msg_Err( p_aout, "no fifo available" );
-        vlc_mutex_unlock( &p_aout->fifos_lock );
-        return NULL;
-    }
-
-    /* Initialize the new fifo structure */
-    switch ( p_fifo->i_format = i_format )
-    {
-        case AOUT_FIFO_PCM:
-        case AOUT_FIFO_SPDIF:
-            p_fifo->b_die = 0;
-
-            p_fifo->i_channels = i_channels;
-            p_fifo->i_rate = i_rate;
-            p_fifo->i_frame_size = i_frame_size;
-
-            p_fifo->i_unit_limit = (AOUT_FIFO_SIZE + 1)
-                                     * (i_frame_size / i_channels);
-
-            /* Allocate the memory needed to store the audio frames and their
-             * dates. As the fifo is a rotative fifo, we must be able to find
-             * out whether the fifo is full or empty, that's why we must in
-             * fact allocate memory for (AOUT_FIFO_SIZE+1) audio frames. */
-            p_fifo->date = malloc( ( sizeof(s16) * i_frame_size 
-                                      + sizeof(mtime_t) )
-                                   * ( AOUT_FIFO_SIZE + 1 ) );
-            if ( p_fifo->date == NULL )
-            {
-                msg_Err( p_aout, "out of memory" );
-                p_fifo->i_format = AOUT_FIFO_NONE;
-                vlc_mutex_unlock( &p_aout->fifos_lock );
-                return NULL;
-            }
-
-            p_fifo->buffer = (u8 *)p_fifo->date + sizeof(mtime_t)
-                                                     * ( AOUT_FIFO_SIZE + 1 );
-
-            /* Set the fifo's buffer as empty (the first frame that is to be
-             * played is also the first frame that is not to be played) */
-            p_fifo->i_start_frame = 0;
-            /* p_fifo->i_next_frame = 0; */
-            p_fifo->i_end_frame = 0;
-
-            /* Waiting for the audio decoder to compute enough frames to work
-             * out the fifo's current rate (as soon as the decoder has decoded
-             * enough frames, the members of the fifo structure that are not
-             * initialized now will be calculated) */
-            p_fifo->b_start_frame = 0;
-            p_fifo->b_next_frame = 0;
-            break;
-
-        default:
-            msg_Err( p_aout, "unknown fifo type 0x%x", p_fifo->i_format );
-            p_fifo->i_format = AOUT_FIFO_NONE;
-            vlc_mutex_unlock( &p_aout->fifos_lock );
-            return NULL;
-    }
-
-    /* Release the fifos lock */
-    vlc_mutex_unlock( &p_aout->fifos_lock );
-
-    msg_Dbg( p_aout, "fifo #%i allocated, %i channels, rate %li, "
-                     "frame size %i", p_fifo->i_fifo, p_fifo->i_channels,
-                     p_fifo->i_rate, p_fifo->i_frame_size );
-
-    /* Return the pointer to the fifo structure */
-    return p_fifo;
-}
-
-/*****************************************************************************
- * aout_DestroyFifo
- *****************************************************************************/
-void aout_DestroyFifo( aout_fifo_t * p_fifo )
-{
-    vlc_mutex_lock( &p_fifo->data_lock );
-    p_fifo->b_die = 1;
-    vlc_mutex_unlock( &p_fifo->data_lock );
-}
-
-/*****************************************************************************
- * aout_FreeFifo
- *****************************************************************************/
-void aout_FreeFifo( aout_fifo_t * p_fifo )
-{
-    switch ( p_fifo->i_format )
-    {
-        case AOUT_FIFO_NONE:
-
-            break;
-
-        case AOUT_FIFO_PCM:
-        case AOUT_FIFO_SPDIF:
-
-            free( p_fifo->date );
-            p_fifo->i_format = AOUT_FIFO_NONE;
-
-            break;
-
-        default:
-
-            break;
-    }
-}
-