]> git.sesse.net Git - vlc/blobdiff - include/audio_output.h
* ./modules/audio_output/oss.c: compilation fixes.
[vlc] / include / audio_output.h
index 0576f2415a95fe490b34e918c6e72c88f976c7ae..a6fc838a223eeda1defd89a08fa6aa08d3520d5f 100644 (file)
@@ -1,10 +1,10 @@
 /*****************************************************************************
- * audio_output.h : audio output thread interface
+ * audio_output.h : audio output interface
  *****************************************************************************
- * Copyright (C) 1999, 2000 VideoLAN
- * $Id: audio_output.h,v 1.32 2001/04/29 02:48:51 stef Exp $
+ * Copyright (C) 2002 VideoLAN
+ * $Id: audio_output.h,v 1.53 2002/08/08 00:35:10 sam Exp $
  *
- * Authors: Michel Kaempf <maxx@via.ecp.fr>
+ * Authors: Christophe Massiot <massiot@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
  *****************************************************************************/
 
 /*****************************************************************************
- * Required headers:
- * - "common.h"                                                   ( boolean_t )
- * - "mtime.h"                                                      ( mtime_t )
- * - "threads.h"                                               ( vlc_thread_t )
- *****************************************************************************/
-
-/* TODO :
- *
- * - Créer un flag destroy dans les fifos audio pour indiquer au thread audio
- *   qu'il peut libérer la mémoire occupée par le buffer de la fifo lorsqu'il
- *   le désire (fin du son ou fin du thread)
- *
- */
-
-/*
- * Macros
- */
-#define AOUT_FIFO_ISEMPTY( fifo )       ( (fifo).l_end_frame == (fifo).l_start_frame )
-#define AOUT_FIFO_ISFULL( fifo )        ( ((((fifo).l_end_frame + 1) - (fifo).l_start_frame) & AOUT_FIFO_SIZE) == 0 )
-
-/*****************************************************************************
- * aout_increment_t
+ * audio_sample_format_t
  *****************************************************************************
- * This structure is used to keep the progression of an index up-to-date, in
- * order to avoid rounding problems and heavy computations, as the function
- * that handles this structure only uses additions.
+ * This structure defines a format for audio samples.
  *****************************************************************************/
-typedef struct aout_increment_s
+struct audio_sample_format_t
 {
-    /* The remainder is used to keep track of the fractional part of the
-     * index. */
-    long                l_remainder;
-
-    /*
-     * The increment structure is initialized with the result of an euclidean
-     * division :
-     *
-     *  l_euclidean_numerator                           l_euclidean_remainder
-     * ----------------------- = l_euclidean_integer + -----------------------
-     * l_euclidean_denominator                         l_euclidean_denominator
-     *
-     */
-    long                l_euclidean_integer;
-    long                l_euclidean_remainder;
-    long                l_euclidean_denominator;
-
-} aout_increment_t;
-
-/*****************************************************************************
- * aout_fifo_t
- *****************************************************************************/
-typedef struct aout_fifo_s
-{
-    /* See the fifo types below */
-    int                 i_type;
-    boolean_t           b_die;
-    int                 i_fifo;      /* Just to keep track of the fifo index */
-
+    int                 i_format;
+    int                 i_rate;
     int                 i_channels;
-    boolean_t           b_stereo;
-    long                l_rate;
-
-    vlc_mutex_t         data_lock;
-    vlc_cond_t          data_wait;
+};
+
+#define AOUT_FMT_MU_LAW     0x00000001
+#define AOUT_FMT_A_LAW      0x00000002
+#define AOUT_FMT_IMA_ADPCM  0x00000004
+#define AOUT_FMT_U8         0x00000008
+#define AOUT_FMT_S16_LE     0x00000010            /* Little endian signed 16 */
+#define AOUT_FMT_S16_BE     0x00000020               /* Big endian signed 16 */
+#define AOUT_FMT_S8         0x00000040
+#define AOUT_FMT_U16_LE     0x00000080                  /* Little endian U16 */
+#define AOUT_FMT_U16_BE     0x00000100                     /* Big endian U16 */
+#define AOUT_FMT_A52        0x00000400             /* ATSC A/52 (for SP/DIF) */
+#define AOUT_FMT_FLOAT32    0x00000800
+#define AOUT_FMT_FIXED32    0x00001000
+
+#define AOUT_FMTS_IDENTICAL( p_first, p_second ) (                          \
+    (p_first->i_format == p_second->i_format)                               \
+      && (p_first->i_rate == p_second->i_rate)                              \
+      && (p_first->i_channels == p_second->i_channels                       \
+           || p_first->i_channels == -1 || p_second->i_channels == -1) )
 
-    long                l_frame_size;
-    void *              buffer;
-    mtime_t *           date;
-    /* The start frame is the first frame in the buffer that contains decoded
-     * audio data. It it also the first frame in the current timestamped frame
-     * area, ie the first dated frame in the decoded part of the buffer. :-p */
-    long                l_start_frame;
-    boolean_t           b_start_frame;
-    /* The next frame is the end frame of the current timestamped frame area,
-     * ie the first dated frame after the start frame. */
-    long                l_next_frame;
-    boolean_t           b_next_frame;
-    /* The end frame is the first frame, after the start frame, that doesn't
-     * contain decoded audio data. That's why the end frame is the first frame
-     * where the audio decoder can store its decoded audio frames. */
-    long                l_end_frame;
-
-    long                l_unit;
-    aout_increment_t    unit_increment;
-    /* The following variable is used to store the number of remaining audio
-     * units in the current timestamped frame area. */
-    long                l_units;
-
-} aout_fifo_t;
-
-#define AOUT_EMPTY_FIFO         0
-#define AOUT_INTF_MONO_FIFO     1
-#define AOUT_INTF_STEREO_FIFO   2
-#define AOUT_ADEC_MONO_FIFO     3
-#define AOUT_ADEC_STEREO_FIFO   4
+#ifdef WORDS_BIGENDIAN
+#   define AOUT_FMT_S16_NE AOUT_FMT_S16_BE
+#   define AOUT_FMT_U16_NE AOUT_FMT_U16_BE
+#else
+#   define AOUT_FMT_S16_NE AOUT_FMT_S16_LE
+#   define AOUT_FMT_U16_NE AOUT_FMT_U16_LE
+#endif
 
 /*****************************************************************************
- * aout_thread_t : audio output thread descriptor
+ * aout_buffer_t : audio output buffer
  *****************************************************************************/
-typedef int  (aout_open_t)       ( p_aout_thread_t p_aout );
-typedef int  (aout_setformat_t)  ( p_aout_thread_t p_aout );
-typedef long (aout_getbufinfo_t) ( p_aout_thread_t p_aout,
-                                   long l_buffer_limit );
-typedef void (aout_play_t)       ( p_aout_thread_t p_aout,
-                                   byte_t *buffer, int i_size );
-typedef void (aout_close_t)      ( p_aout_thread_t p_aout );
-
-typedef struct aout_thread_s
+struct aout_buffer_t
 {
-    vlc_thread_t        thread_id;
-    boolean_t           b_die;
-    boolean_t           b_active;
-
-    vlc_mutex_t         fifos_lock;
-    aout_fifo_t         fifo[ AOUT_MAX_FIFOS ];
-
-    /* Plugin used and shortcuts to access its capabilities */
-    struct module_s *   p_module;
-    aout_open_t *       pf_open;
-    aout_setformat_t *  pf_setformat;
-    aout_getbufinfo_t * pf_getbufinfo;
-    aout_play_t *       pf_play;
-    aout_close_t *      pf_close;
-
-    void *              buffer;
-    /* The s32 buffer is used to mix all the audio fifos together before
-     * converting them and storing them in the audio output buffer */
-    s32 *               s32_buffer;
-
-    /* The size of the audio output buffer is kept in audio units, as this is
-     * the only unit that is common with every audio decoder and audio fifo */
-    long                l_units;
-    long                l_msleep;
-
-    /* date is the moment where the first audio unit of the output buffer
-     * will be played */
-    mtime_t             date;
-
-    /* Path to the audio output device (default is set to "/dev/dsp") */
-    char *              psz_device;
-    int                 i_fd;
-
-    /* Format of the audio output samples */
-    int                 i_format;
-    /* Number of channels */
-    int                 i_channels;
-    /* Mono or Stereo sound */
-    boolean_t           b_stereo;
-    /* Rate and gain of the audio output sound (in Hz) */
-    long                l_rate;
-    long                l_gain;
+    byte_t *                p_buffer;
+    int                     i_alloc_type;
+    size_t                  i_size;
+    int                     i_nb_samples;
+    mtime_t                 start_date, end_date;
 
-    /* there might be some useful private structure, such as audio_buf_info
-     * for the OSS output */
-    p_aout_sys_t        p_sys;
-
-
-    /* there is the current volume */
-    int                 vol;
-
-} aout_thread_t;
-
-/* Those are from <linux/soundcard.h> but are needed because of formats
- * on other platforms */
-#define AOUT_FMT_U8          0x00000008
-#define AOUT_FMT_S16_LE      0x00000010           /* Little endian signed 16 */
-#define AOUT_FMT_S16_BE      0x00000020              /* Big endian signed 16 */
-#define AOUT_FMT_S8          0x00000040
-#define AOUT_FMT_U16_LE      0x00000080                 /* Little endian U16 */
-#define AOUT_FMT_U16_BE      0x00000100                    /* Big endian U16 */
-#define AOUT_FMT_AC3         0x00000400                 /* Dolby Digital AC3 */
-
-
-#ifdef WORDS_BIGENDIAN
-#define AOUT_FMT_S16_NE      AOUT_FMT_S16_BE
-#else
-#define AOUT_FMT_S16_NE      AOUT_FMT_S16_LE
-#endif
+    struct aout_buffer_t *  p_next;
+};
 
 /*****************************************************************************
  * Prototypes
  *****************************************************************************/
-aout_thread_t * aout_CreateThread       ( int *pi_status );
-void            aout_DestroyThread      ( aout_thread_t *p_aout,
-                                          int *pi_status );
-
-aout_fifo_t *   aout_CreateFifo         ( aout_thread_t *p_aout,
-                                          aout_fifo_t *p_fifo );
-void            aout_DestroyFifo        ( aout_fifo_t *p_fifo );
-void            aout_FreeFifo           ( aout_fifo_t *p_fifo );
+/* From audio_output.c : */
+#define aout_NewInstance(a) __aout_NewInstance(VLC_OBJECT(a))
+VLC_EXPORT( aout_instance_t *, __aout_NewInstance,    ( vlc_object_t * ) );
+VLC_EXPORT( void,              aout_DeleteInstance, ( aout_instance_t * ) );
+VLC_EXPORT( aout_buffer_t *, aout_BufferNew, ( aout_instance_t *, aout_input_t *, size_t ) );
+VLC_EXPORT( void, aout_BufferDelete, ( aout_instance_t *, aout_input_t *, aout_buffer_t * ) );
+VLC_EXPORT( void, aout_BufferPlay, ( aout_instance_t *, aout_input_t *, aout_buffer_t * ) );
+VLC_EXPORT( int, aout_FormatToBytes, ( audio_sample_format_t * p_format ) );
+
+/* From input.c : */
+#define aout_InputNew(a,b,c) __aout_InputNew(VLC_OBJECT(a),b,c)
+VLC_EXPORT( aout_input_t *, __aout_InputNew, ( vlc_object_t *, aout_instance_t **, audio_sample_format_t * ) );
+VLC_EXPORT( void, aout_InputDelete, ( aout_instance_t *, aout_input_t * ) );
+
+/* From output.c : */
+VLC_EXPORT( aout_buffer_t *, aout_OutputNextBuffer, ( aout_instance_t *, mtime_t ) );