VirtualBox

source: vbox/trunk/src/VBox/Devices/Audio/AudioMixer.h@ 63547

Last change on this file since 63547 was 63362, checked in by vboxsync, 8 years ago

Audio: PDMPCMPROPS -> PDMAUDIOPCMPROPS.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.2 KB
Line 
1/* $Id: AudioMixer.h 63362 2016-08-12 14:21:25Z vboxsync $ */
2/** @file
3 * VBox audio: Mixing routines, mainly used by the various audio device
4 * emulations to achieve proper multiplexing from/to attached
5 * devices LUNs.
6 */
7
8/*
9 * Copyright (C) 2014-2016 Oracle Corporation
10 *
11 * This file is part of VirtualBox Open Source Edition (OSE), as
12 * available from http://www.virtualbox.org. This file is free software;
13 * you can redistribute it and/or modify it under the terms of the GNU
14 * General Public License (GPL) as published by the Free Software
15 * Foundation, in version 2 as it comes in the "COPYING" file of the
16 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
17 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
18 */
19
20#ifndef AUDIO_MIXER_H
21#define AUDIO_MIXER_H
22
23#include <iprt/cdefs.h>
24#include <VBox/vmm/pdmaudioifs.h>
25
26/**
27 * Structure for maintaining an audio mixer instance.
28 */
29typedef struct AUDIOMIXER
30{
31 /** Mixer name. */
32 char *pszName;
33 /** Format the mixer should convert/output
34 * data to so that the underlying device emulation
35 * can work with it. */
36 PDMAUDIOSTREAMCFG devFmt;
37 /** The master volume of this mixer. */
38 PDMAUDIOVOLUME VolMaster;
39 /** List of audio mixer sinks. */
40 RTLISTANCHOR lstSinks;
41 /** Number of used audio sinks. */
42 uint8_t cSinks;
43} AUDIOMIXER, *PAUDIOMIXER;
44
45/** No flags specified. */
46#define AUDMIXSTREAM_FLAG_NONE 0
47
48/** Prototype needed for AUDMIXSTREAM struct definition. */
49typedef struct AUDMIXSINK *PAUDMIXSINK;
50
51/**
52 * Structure for maintaining an audio mixer stream.
53 */
54typedef struct AUDMIXSTREAM
55{
56 /** List node. */
57 RTLISTNODE Node;
58 /** Name of this stream. */
59 char *pszName;
60 /** Sink this stream is attached to. */
61 PAUDMIXSINK pSink;
62 /** Stream flags of type AUDMIXSTREAM_FLAG_. */
63 uint32_t fFlags;
64 /** Pointer to audio connector being used. */
65 PPDMIAUDIOCONNECTOR pConn;
66 /** Pointer to PDM audio stream this mixer stream handles. */
67 PPDMAUDIOSTREAM pStream;
68} AUDMIXSTREAM, *PAUDMIXSTREAM;
69
70/** Defines an audio sink's current status. */
71#define AUDMIXSINKSTS uint32_t
72
73/** No status specified. */
74#define AUDMIXSINK_STS_NONE 0
75/** The sink is active and running. */
76#define AUDMIXSINK_STS_RUNNING RT_BIT(0)
77/** The sink is in a pending disable state. */
78#define AUDMIXSINK_STS_PENDING_DISABLE RT_BIT(1)
79/** Dirty flag.
80 * For output sinks this means that there is data in the
81 * sink which has not been played yet.
82 * For input sinks this means that there is data in the
83 * sink which has been recorded but not transferred to the
84 * destination yet. */
85#define AUDMIXSINK_STS_DIRTY RT_BIT(2)
86
87/**
88 * Audio mixer sink direction.
89 */
90typedef enum AUDMIXSINKDIR
91{
92 /** Unknown direction. */
93 AUDMIXSINKDIR_UNKNOWN = 0,
94 /** Input (capturing from a device). */
95 AUDMIXSINKDIR_INPUT,
96 /** Output (playing to a device). */
97 AUDMIXSINKDIR_OUTPUT,
98 /** The usual 32-bit hack. */
99 AUDMIXSINKDIR_32BIT_HACK = 0x7fffffff
100} AUDMIXSINKDIR;
101
102/**
103 * Audio mixer sink command.
104 */
105typedef enum AUDMIXSINKCMD
106{
107 /** Unknown command, do not use. */
108 AUDMIXSINKCMD_UNKNOWN = 0,
109 /** Enables the sink. */
110 AUDMIXSINKCMD_ENABLE,
111 /** Disables the sink. */
112 AUDMIXSINKCMD_DISABLE,
113 /** Pauses the sink. */
114 AUDMIXSINKCMD_PAUSE,
115 /** Resumes the sink. */
116 AUDMIXSINKCMD_RESUME,
117 /** Hack to blow the type up to 32-bit. */
118 AUDMIXSINKCMD_32BIT_HACK = 0x7fffffff
119} AUDMIXSINKCMD;
120
121/**
122 * Structure for keeping audio input sink specifics.
123 * Do not use directly. Instead, use AUDMIXSINK.
124 */
125typedef struct AUDMIXSINKIN
126{
127#ifdef VBOX_AUDIO_MIXER_WITH_MIXBUF
128 /** This sink's mixing buffer, acting as
129 * a parent buffer for all streams this sink owns. */
130 PDMAUDIOMIXBUF MixBuf;
131#else
132 /** Number of bytes available to read from the sink. */
133 uint32_t cbReadable;
134#endif
135} AUDMIXSINKIN;
136
137/**
138 * Structure for keeping audio output sink specifics.
139 * Do not use directly. Instead, use AUDMIXSINK.
140 */
141typedef struct AUDMIXSINKOUT
142{
143#ifdef VBOX_AUDIO_MIXER_WITH_MIXBUF
144 /** This sink's mixing buffer, acting as
145 * a parent buffer for all streams this sink owns. */
146 PDMAUDIOMIXBUF MixBuf;
147#else
148 /** Number of bytes available to write to the sink. */
149 uint32_t cbWritable;
150#endif
151} AUDMIXSINKOUT;
152
153/**
154 * Structure for maintaining an audio mixer sink.
155 */
156typedef struct AUDMIXSINK
157{
158 RTLISTNODE Node;
159 /** Pointer to mixer object this sink is bound to. */
160 PAUDIOMIXER pParent;
161 /** Name of this sink. */
162 char *pszName;
163 /** The sink direction, that is,
164 * if this sink handles input or output. */
165 AUDMIXSINKDIR enmDir;
166 /** Union for input/output specifics. */
167 union
168 {
169 AUDMIXSINKIN In;
170 AUDMIXSINKOUT Out;
171 };
172 /** Sink status of type AUDMIXSINK_STS_XXX. */
173 AUDMIXSINKSTS fStatus;
174 /** The sink's PCM format. */
175 PDMAUDIOPCMPROPS PCMProps;
176 /** Number of streams assigned. */
177 uint8_t cStreams;
178 /** List of assigned streams.
179 * Note: All streams have the same PCM properties, so the
180 * mixer does not do any conversion. */
181 /** @todo Use something faster -- vector maybe? */
182 RTLISTANCHOR lstStreams;
183 /** The volume of this sink. The volume always will
184 * be combined with the mixer's master volume. */
185 PDMAUDIOVOLUME Volume;
186 /** The volume of this sink, combined with the last set master volume. */
187 PDMAUDIOVOLUME VolumeCombined;
188 /** Timestamp (in ms) since last update. */
189 uint64_t tsLastUpdatedMS;
190} AUDMIXSINK, *PAUDMIXSINK;
191
192/**
193 * Audio mixer operation.
194 */
195typedef enum AUDMIXOP
196{
197 /** Invalid operation, do not use. */
198 AUDMIXOP_INVALID = 0,
199 /** Copy data from A to B, overwriting data in B. */
200 AUDMIXOP_COPY,
201 /** Blend data from A with (existing) data in B. */
202 AUDMIXOP_BLEND,
203 /** The usual 32-bit hack. */
204 AUDMIXOP_32BIT_HACK = 0x7fffffff
205} AUDMIXOP;
206
207/** No flags specified. */
208#define AUDMIXSTRMCTL_FLAG_NONE 0
209
210int AudioMixerCreate(const char *pszName, uint32_t uFlags, PAUDIOMIXER *ppMixer);
211int AudioMixerCreateSink(PAUDIOMIXER pMixer, const char *pszName, AUDMIXSINKDIR enmDir, PAUDMIXSINK *ppSink);
212void AudioMixerDestroy(PAUDIOMIXER pMixer);
213void AudioMixerInvalidate(PAUDIOMIXER pMixer);
214void AudioMixerRemoveSink(PAUDIOMIXER pMixer, PAUDMIXSINK pSink);
215int AudioMixerSetMasterVolume(PAUDIOMIXER pMixer, PPDMAUDIOVOLUME pVol);
216void AudioMixerDebug(PAUDIOMIXER pMixer, PCDBGFINFOHLP pHlp, const char *pszArgs);
217
218int AudioMixerSinkAddStream(PAUDMIXSINK pSink, PAUDMIXSTREAM pStream);
219int AudioMixerSinkCreateStream(PAUDMIXSINK pSink, PPDMIAUDIOCONNECTOR pConnector, PPDMAUDIOSTREAMCFG pCfg, uint32_t fFlags, PAUDMIXSTREAM *ppStream);
220int AudioMixerSinkCtl(PAUDMIXSINK pSink, AUDMIXSINKCMD enmCmd);
221void AudioMixerSinkDestroy(PAUDMIXSINK pSink);
222uint32_t AudioMixerSinkGetReadable(PAUDMIXSINK pSink);
223uint32_t AudioMixerSinkGetWritable(PAUDMIXSINK pSink);
224AUDMIXSINKDIR AudioMixerSinkGetDir(PAUDMIXSINK pSink);
225PAUDMIXSTREAM AudioMixerSinkGetStream(PAUDMIXSINK pSink, uint8_t uIndex);
226AUDMIXSINKSTS AudioMixerSinkGetStatus(PAUDMIXSINK pSink);
227uint8_t AudioMixerSinkGetStreamCount(PAUDMIXSINK pSink);
228int AudioMixerSinkRead(PAUDMIXSINK pSink, AUDMIXOP enmOp, void *pvBuf, uint32_t cbBuf, uint32_t *pcbRead);
229void AudioMixerSinkRemoveStream(PAUDMIXSINK pSink, PAUDMIXSTREAM pStream);
230void AudioMixerSinkRemoveAllStreams(PAUDMIXSINK pSink);
231int AudioMixerSinkSetFormat(PAUDMIXSINK pSink, PPDMAUDIOPCMPROPS pPCMProps);
232int AudioMixerSinkSetVolume(PAUDMIXSINK pSink, PPDMAUDIOVOLUME pVol);
233int AudioMixerSinkWrite(PAUDMIXSINK pSink, AUDMIXOP enmOp, const void *pvBuf, uint32_t cbBuf, uint32_t *pcbWritten);
234int AudioMixerSinkUpdate(PAUDMIXSINK pSink);
235
236int AudioMixerStreamCtl(PAUDMIXSTREAM pStream, PDMAUDIOSTREAMCMD enmCmd, uint32_t fCtl);
237void AudioMixerStreamDestroy(PAUDMIXSTREAM pStream);
238bool AudioMixerStreamIsActive(PAUDMIXSTREAM pStream);
239bool AudioMixerStreamIsValid(PAUDMIXSTREAM pStream);
240
241#endif /* AUDIO_MIXER_H */
242
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette