VirtualBox

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

Last change on this file since 76077 was 74041, checked in by vboxsync, 6 years ago

Audio/Mixer: Added AudioMixerSinkGetName().

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