VirtualBox

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

Last change on this file since 76768 was 76565, checked in by vboxsync, 6 years ago

Devices: Use VBOX_INCLUDED_SRC_ as header guard prefix with scm.

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