CACA: use key thread (partially fix #3661)
[vlc/asuraparaju-public.git] / include / vlc_aout_mixer.h
blob5fd2ce0953dc8814fc6e7cfa921503fb60bb917c
1 /*****************************************************************************
2 * vlc_aout_mixer.h : audio output mixer interface
3 *****************************************************************************
4 * Copyright (C) 2002-2009 the VideoLAN team
5 * $Id$
7 * Authors: Christophe Massiot <massiot@via.ecp.fr>
8 * Laurent Aimar <fenrir _AT_ videolan _DOT_ org>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 #ifndef VLC_AOUT_MIXER_H
26 #define VLC_AOUT_MIXER_H 1
28 /**
29 * \file
30 * This file defines functions, structures and macros for audio output mixer object
33 #ifdef __cplusplus
34 extern "C" {
35 #endif
37 //#include <vlc_aout.h>
39 /* */
40 typedef struct aout_mixer_sys_t aout_mixer_sys_t;
41 typedef struct aout_mixer_t aout_mixer_t;
43 typedef struct {
44 /* Is the input to be ignored while mixing */
45 bool is_invalid;
47 /* */
48 aout_fifo_t fifo;
50 /* Pointer on the first byte of data to mix.
52 * It points in the first buffer of fifo
54 uint8_t *begin;
56 /* Software multiplier */
57 float multiplier;
58 } aout_mixer_input_t;
60 /**
61 * audio output mixer
63 struct aout_mixer_t {
64 VLC_COMMON_MEMBERS
66 /* Module */
67 module_t *module;
69 /* Mixer format.
71 * You cannot modify it.
73 audio_sample_format_t fmt;
75 /* Mixer output buffer allocation method.
77 * You can override it in the open function only.
79 aout_alloc_t allocation;
81 /* Multiplier used to raise or lower the volume of the sound in
82 * software.
84 float multiplier;
86 /* Array of mixer inputs */
87 unsigned input_count;
88 aout_mixer_input_t **input;
90 /* Mix input into the given buffer (mandatory) */
91 void (*mix)(aout_mixer_t *, aout_buffer_t *);
93 /* Private place holder for the aout_mixer_t module (optional)
95 * A module is free to use it as it wishes.
97 aout_mixer_sys_t *sys;
100 #ifdef __cplusplus
102 #endif
104 #endif