VirtualBox

source: vbox/trunk/include/VBox/vmm/pdmaudioifs.h@ 69408

Last change on this file since 69408 was 68758, checked in by vboxsync, 7 years ago

vmm/pdmaudioifs.h: Documentation.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 59.1 KB
Line 
1/** @file
2 * PDM - Pluggable Device Manager, audio interfaces.
3 */
4
5/*
6 * Copyright (C) 2006-2017 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26/**
27 * == Audio architecture overview
28 *
29 * The audio architecture mainly consists of two PDM interfaces, PDMAUDIOCONNECTOR
30 * and PDMIHOSTAUDIO.
31 *
32 * The PDMAUDIOCONNECTOR interface is responsible of connecting a device emulation, such
33 * as SB16, AC'97 and HDA to one or multiple audio backend(s). Its API abstracts audio
34 * stream handling and I/O functions, device enumeration and so on.
35 *
36 * The PDMIHOSTAUDIO interface must be implemented by all audio backends to provide an
37 * abstract and common way of accessing needed functions, such as transferring output audio
38 * data for playing audio or recording input from the host.
39 *
40 * A device emulation can have one or more LUNs attached to it, whereas these LUNs in turn
41 * then all have their own PDMIAUDIOCONNECTOR, making it possible to connect multiple backends
42 * to a certain device emulation stream (multiplexing).
43 *
44 * An audio backend's job is to record and/or play audio data (depending on its capabilities).
45 * It highly depends on the host it's running on and needs very specific (host-OS-dependent) code.
46 * The backend itself only has very limited ways of accessing and/or communicating with the
47 * PDMIAUDIOCONNECTOR interface via callbacks, but never directly with the device emulation or
48 * other parts of the audio sub system.
49 *
50 *
51 * == Mixing
52 *
53 * The AUDIOMIXER API is optionally available to create and manage virtual audio mixers.
54 * Such an audio mixer in turn then can be used by the device emulation code to manage all
55 * the multiplexing to/from the connected LUN audio streams.
56 *
57 * Currently only input and output stream are supported. Duplex stream are not supported yet.
58 *
59 * This also is handy if certain LUN audio streams should be added or removed during runtime.
60 *
61 * To create a group of either input or output streams the AUDMIXSINK API can be used.
62 *
63 * For example: The device emulation has one hardware output stream (HW0), and that output
64 * stream shall be available to all connected LUN backends. For that to happen,
65 * an AUDMIXSINK sink has to be created and attached to the device's AUDIOMIXER object.
66 *
67 * As every LUN has its own AUDMIXSTREAM object, adding all those objects to the
68 * just created audio mixer sink will do the job.
69 *
70 * Note: The AUDIOMIXER API is purely optional and is not used by all currently implemented
71 * device emulations (e.g. SB16).
72 *
73 *
74 * == Data processing
75 *
76 * Audio input / output data gets handed-off to/from the device emulation in an unmodified
77 * - that is, raw - way. The actual audio frame / sample conversion is done via the PDMAUDIOMIXBUF API.
78 *
79 * This concentrates the audio data processing in one place and makes it easier to test / benchmark
80 * such code.
81 *
82 * A PDMAUDIOFRAME is the internal representation of a single audio frame, which consists of a single left
83 * and right audio sample in time. Only mono (1) and stereo (2) channel(s) currently are supported.
84 *
85 *
86 * == Diagram
87 *
88 * +-------------------------+
89 * +-------------------------+ +-------------------------+ +-------------------+
90 * |PDMAUDIOSTREAM | |PDMAUDIOCONNECTOR | + ++|LUN |
91 * |-------------------------| |-------------------------| | |||-------------------|
92 * |PDMAUDIOMIXBUF |+------>|PDMAUDIOSTREAM Host |+---|-|||PDMIAUDIOCONNECTOR |
93 * |PDMAUDIOSTREAMCFG |+------>|PDMAUDIOSTREAM Guest | | |||AUDMIXSTREAM |
94 * | | |Device capabilities | | ||| |
95 * | | |Device configuration | | ||| |
96 * | | | | | ||| |
97 * | | +|PDMIHOSTAUDIO | | ||| |
98 * | | ||+-----------------------+| | ||+-------------------+
99 * +-------------------------+ |||Backend storage space || | ||
100 * ||+-----------------------+| | ||
101 * |+-------------------------+ | ||
102 * | | ||
103 * +---------------------+ | | ||
104 * |PDMIHOSTAUDIO | | | ||
105 * |+--------------+ | | +-------------------+ | || +-------------+
106 * ||DirectSound | | | |AUDMIXSINK | | || |AUDIOMIXER |
107 * |+--------------+ | | |-------------------| | || |-------------|
108 * | | | |AUDMIXSTREAM0 |+---|-||----->|AUDMIXSINK0 |
109 * |+--------------+ | | |AUDMIXSTREAM1 |+---|-||----->|AUDMIXSINK1 |
110 * ||PulseAudio | | | |AUDMIXSTREAMn |+---|-||----->|AUDMIXSINKn |
111 * |+--------------+ |+----------+ +-------------------+ | || +-------------+
112 * | | | ||
113 * |+--------------+ | | ||
114 * ||Core Audio | | | ||
115 * |+--------------+ | | ||
116 * | | | ||
117 * | | | ||+----------------------------------+
118 * | | | |||Device (SB16 / AC'97 / HDA) |
119 * | | | |||----------------------------------|
120 * +---------------------+ | |||AUDIOMIXER (Optional) |
121 * | |||AUDMIXSINK0 (Optional) |
122 * | |||AUDMIXSINK1 (Optional) |
123 * | |||AUDMIXSINKn (Optional) |
124 * | ||| |
125 * | |+|LUN0 |
126 * | ++|LUN1 |
127 * +--+|LUNn |
128 * | |
129 * | |
130 * | |
131 * +----------------------------------+
132 */
133
134#ifndef ___VBox_vmm_pdmaudioifs_h
135#define ___VBox_vmm_pdmaudioifs_h
136
137#include <iprt/circbuf.h>
138#include <iprt/list.h>
139
140#include <VBox/types.h>
141#ifdef VBOX_WITH_STATISTICS
142# include <VBox/vmm/stam.h>
143#endif
144
145/** @defgroup grp_pdm_ifs_audio PDM Audio Interfaces
146 * @ingroup grp_pdm_interfaces
147 * @{
148 */
149
150/** PDM audio driver instance flags. */
151typedef uint32_t PDMAUDIODRVFLAGS;
152
153/** No flags set. */
154#define PDMAUDIODRVFLAGS_NONE 0
155/** Marks a primary audio driver which is critical
156 * when running the VM. */
157#define PDMAUDIODRVFLAGS_PRIMARY RT_BIT(0)
158
159/**
160 * Audio format in signed or unsigned variants.
161 */
162typedef enum PDMAUDIOFMT
163{
164 /** Invalid format, do not use. */
165 PDMAUDIOFMT_INVALID,
166 /** 8-bit, unsigned. */
167 PDMAUDIOFMT_U8,
168 /** 8-bit, signed. */
169 PDMAUDIOFMT_S8,
170 /** 16-bit, unsigned. */
171 PDMAUDIOFMT_U16,
172 /** 16-bit, signed. */
173 PDMAUDIOFMT_S16,
174 /** 32-bit, unsigned. */
175 PDMAUDIOFMT_U32,
176 /** 32-bit, signed. */
177 PDMAUDIOFMT_S32,
178 /** Hack to blow the type up to 32-bit. */
179 PDMAUDIOFMT_32BIT_HACK = 0x7fffffff
180} PDMAUDIOFMT;
181
182/**
183 * Audio direction.
184 */
185typedef enum PDMAUDIODIR
186{
187 /** Unknown direction. */
188 PDMAUDIODIR_UNKNOWN = 0,
189 /** Input. */
190 PDMAUDIODIR_IN = 1,
191 /** Output. */
192 PDMAUDIODIR_OUT = 2,
193 /** Duplex handling. */
194 PDMAUDIODIR_ANY = 3,
195 /** Hack to blow the type up to 32-bit. */
196 PDMAUDIODIR_32BIT_HACK = 0x7fffffff
197} PDMAUDIODIR;
198
199/** Device latency spec in milliseconds (ms). */
200typedef uint32_t PDMAUDIODEVLATSPECMS;
201
202/** Device latency spec in seconds (s). */
203typedef uint32_t PDMAUDIODEVLATSPECSEC;
204
205/** Audio device flags. Use with PDMAUDIODEV_FLAG_ flags. */
206typedef uint32_t PDMAUDIODEVFLAG;
207
208/** No flags set. */
209#define PDMAUDIODEV_FLAGS_NONE 0
210/** The device marks the default device within the host OS. */
211#define PDMAUDIODEV_FLAGS_DEFAULT RT_BIT(0)
212/** The device can be removed at any time and we have to deal with it. */
213#define PDMAUDIODEV_FLAGS_HOTPLUG RT_BIT(1)
214/** The device is known to be buggy and needs special treatment. */
215#define PDMAUDIODEV_FLAGS_BUGGY RT_BIT(2)
216/** Ignore the device, no matter what. */
217#define PDMAUDIODEV_FLAGS_IGNORE RT_BIT(3)
218/** The device is present but marked as locked by some other application. */
219#define PDMAUDIODEV_FLAGS_LOCKED RT_BIT(4)
220/** The device is present but not in an alive state (dead). */
221#define PDMAUDIODEV_FLAGS_DEAD RT_BIT(5)
222
223/**
224 * Audio device type.
225 */
226typedef enum PDMAUDIODEVICETYPE
227{
228 /** Unknown device type. This is the default. */
229 PDMAUDIODEVICETYPE_UNKNOWN = 0,
230 /** Dummy device; for backends which are not able to report
231 * actual device information (yet). */
232 PDMAUDIODEVICETYPE_DUMMY,
233 /** The device is built into the host (non-removable). */
234 PDMAUDIODEVICETYPE_BUILTIN,
235 /** The device is an (external) USB device. */
236 PDMAUDIODEVICETYPE_USB,
237 /** Hack to blow the type up to 32-bit. */
238 PDMAUDIODEVICETYPE_32BIT_HACK = 0x7fffffff
239} PDMAUDIODEVICETYPE;
240
241/**
242 * Audio device instance data.
243 */
244typedef struct PDMAUDIODEVICE
245{
246 /** List node. */
247 RTLISTNODE Node;
248 /** Friendly name of the device, if any. */
249 char szName[64];
250 /** The device type. */
251 PDMAUDIODEVICETYPE enmType;
252 /** Reference count indicating how many audio streams currently are relying on this device. */
253 uint8_t cRefCount;
254 /** Usage of the device. */
255 PDMAUDIODIR enmUsage;
256 /** Device flags. */
257 PDMAUDIODEVFLAG fFlags;
258 /** Maximum number of input audio channels the device supports. */
259 uint8_t cMaxInputChannels;
260 /** Maximum number of output audio channels the device supports. */
261 uint8_t cMaxOutputChannels;
262 /** Additional data which might be relevant for the current context. */
263 void *pvData;
264 /** Size of the additional data. */
265 size_t cbData;
266 /** Device type union, based on enmType. */
267 union
268 {
269 /** USB type specifics. */
270 struct
271 {
272 /** Vendor ID. */
273 int16_t VID;
274 /** Product ID. */
275 int16_t PID;
276 } USB;
277 } Type;
278} PDMAUDIODEVICE, *PPDMAUDIODEVICE;
279
280/**
281 * Structure for keeping an audio device enumeration.
282 */
283typedef struct PDMAUDIODEVICEENUM
284{
285 /** Number of audio devices in the list. */
286 uint16_t cDevices;
287 /** List of audio devices. */
288 RTLISTANCHOR lstDevices;
289} PDMAUDIODEVICEENUM, *PPDMAUDIODEVICEENUM;
290
291/**
292 * Audio (static) configuration of an audio host backend.
293 */
294typedef struct PDMAUDIOBACKENDCFG
295{
296 /** Size (in bytes) of the host backend's audio output stream structure. */
297 size_t cbStreamOut;
298 /** Size (in bytes) of the host backend's audio input stream structure. */
299 size_t cbStreamIn;
300 /** Number of concurrent output streams supported on the host.
301 * UINT32_MAX for unlimited concurrent streams, 0 if no concurrent input streams are supported. */
302 uint32_t cMaxStreamsOut;
303 /** Number of concurrent input streams supported on the host.
304 * UINT32_MAX for unlimited concurrent streams, 0 if no concurrent input streams are supported. */
305 uint32_t cMaxStreamsIn;
306} PDMAUDIOBACKENDCFG, *PPDMAUDIOBACKENDCFG;
307
308/**
309 * A single audio frame.
310 *
311 * Currently only two (2) channels, left and right, are supported.
312 *
313 * Note: When changing this structure, make sure to also handle
314 * VRDP's input / output processing in DrvAudioVRDE, as VRDP
315 * expects audio data in st_sample_t format (historical reasons)
316 * which happens to be the same as PDMAUDIOFRAME for now.
317 */
318typedef struct PDMAUDIOFRAME
319{
320 /** Left channel. */
321 int64_t i64LSample;
322 /** Right channel. */
323 int64_t i64RSample;
324} PDMAUDIOFRAME;
325/** Pointer to a single (stereo) audio frame. */
326typedef PDMAUDIOFRAME *PPDMAUDIOFRAME;
327/** Pointer to a const single (stereo) audio frame. */
328typedef PDMAUDIOFRAME const *PCPDMAUDIOFRAME;
329
330typedef enum PDMAUDIOENDIANNESS
331{
332 /** The usual invalid endian. */
333 PDMAUDIOENDIANNESS_INVALID,
334 /** Little endian. */
335 PDMAUDIOENDIANNESS_LITTLE,
336 /** Bit endian. */
337 PDMAUDIOENDIANNESS_BIG,
338 /** Endianness doesn't have a meaning in the context. */
339 PDMAUDIOENDIANNESS_NA,
340 /** The end of the valid endian values (exclusive). */
341 PDMAUDIOENDIANNESS_END,
342 /** Hack to blow the type up to 32-bit. */
343 PDMAUDIOENDIANNESS_32BIT_HACK = 0x7fffffff
344} PDMAUDIOENDIANNESS;
345
346/**
347 * Audio playback destinations.
348 */
349typedef enum PDMAUDIOPLAYBACKDEST
350{
351 /** Unknown destination. */
352 PDMAUDIOPLAYBACKDEST_UNKNOWN = 0,
353 /** Front channel. */
354 PDMAUDIOPLAYBACKDEST_FRONT,
355 /** Center / LFE (Subwoofer) channel. */
356 PDMAUDIOPLAYBACKDEST_CENTER_LFE,
357 /** Rear channel. */
358 PDMAUDIOPLAYBACKDEST_REAR,
359 /** Hack to blow the type up to 32-bit. */
360 PDMAUDIOPLAYBACKDEST_32BIT_HACK = 0x7fffffff
361} PDMAUDIOPLAYBACKDEST;
362
363/**
364 * Audio recording sources.
365 */
366typedef enum PDMAUDIORECSOURCE
367{
368 /** Unknown recording source. */
369 PDMAUDIORECSOURCE_UNKNOWN = 0,
370 /** Microphone-In. */
371 PDMAUDIORECSOURCE_MIC,
372 /** CD. */
373 PDMAUDIORECSOURCE_CD,
374 /** Video-In. */
375 PDMAUDIORECSOURCE_VIDEO,
376 /** AUX. */
377 PDMAUDIORECSOURCE_AUX,
378 /** Line-In. */
379 PDMAUDIORECSOURCE_LINE,
380 /** Phone-In. */
381 PDMAUDIORECSOURCE_PHONE,
382 /** Hack to blow the type up to 32-bit. */
383 PDMAUDIORECSOURCE_32BIT_HACK = 0x7fffffff
384} PDMAUDIORECSOURCE;
385
386/**
387 * Audio stream (data) layout.
388 */
389typedef enum PDMAUDIOSTREAMLAYOUT
390{
391 /** Unknown access type; do not use. */
392 PDMAUDIOSTREAMLAYOUT_UNKNOWN = 0,
393 /** Non-interleaved access, that is, consecutive
394 * access to the data. */
395 PDMAUDIOSTREAMLAYOUT_NON_INTERLEAVED,
396 /** Interleaved access, where the data can be
397 * mixed together with data of other audio streams. */
398 PDMAUDIOSTREAMLAYOUT_INTERLEAVED,
399 /** Complex layout, which does not fit into the
400 * interleaved / non-interleaved layouts. */
401 PDMAUDIOSTREAMLAYOUT_COMPLEX,
402 /** Raw (pass through) data, with no data layout processing done.
403 *
404 * This means that this stream will operate on PDMAUDIOFRAME data
405 * directly. Don't use this if you don't have to. */
406 PDMAUDIOSTREAMLAYOUT_RAW,
407 /** Hack to blow the type up to 32-bit. */
408 PDMAUDIOSTREAMLAYOUT_32BIT_HACK = 0x7fffffff
409} PDMAUDIOSTREAMLAYOUT, *PPDMAUDIOSTREAMLAYOUT;
410
411/** No stream channel data flags defined. */
412#define PDMAUDIOSTREAMCHANNELDATA_FLAG_NONE 0
413
414/**
415 * Structure for keeping a stream channel data block around.
416 */
417typedef struct PDMAUDIOSTREAMCHANNELDATA
418{
419 /** Circular buffer for the channel data. */
420 PRTCIRCBUF pCircBuf;
421 size_t cbAcq;
422 /** Channel data flags. */
423 uint32_t fFlags;
424} PDMAUDIOSTREAMCHANNELDATA, *PPDMAUDIOSTREAMCHANNELDATA;
425
426/**
427 * Structure for a single channel of an audio stream.
428 * An audio stream consists of one or multiple channels,
429 * depending on the configuration.
430 */
431typedef struct PDMAUDIOSTREAMCHANNEL
432{
433 /** Channel ID. */
434 uint8_t uChannel;
435 /** Step size (in bytes) to the channel's next frame. */
436 size_t cbStep;
437 /** Frame size (in bytes) of this channel. */
438 size_t cbFrame;
439 /** Offset (in bytes) to first frame in the data block. */
440 size_t cbFirst;
441 /** Currente offset (in bytes) in the data stream. */
442 size_t cbOff;
443 /** Associated data buffer. */
444 PDMAUDIOSTREAMCHANNELDATA Data;
445} PDMAUDIOSTREAMCHANNEL, *PPDMAUDIOSTREAMCHANNEL;
446
447/**
448 * Union for keeping an audio stream destination or source.
449 */
450typedef union PDMAUDIODESTSOURCE
451{
452 /** Desired playback destination (for an output stream). */
453 PDMAUDIOPLAYBACKDEST Dest;
454 /** Desired recording source (for an input stream). */
455 PDMAUDIORECSOURCE Source;
456} PDMAUDIODESTSOURCE, *PPDMAUDIODESTSOURCE;
457
458/**
459 * Properties of audio streams for host/guest
460 * for in or out directions.
461 */
462typedef struct PDMAUDIOPCMPROPS
463{
464 /** Sample width. Bits per sample. */
465 uint8_t cBits;
466 /** Signed or unsigned sample. */
467 bool fSigned;
468 /** Number of audio channels. */
469 uint8_t cChannels;
470 /** Sample frequency in Hertz (Hz). */
471 uint32_t uHz;
472 /** Shift count used for faster calculation of various
473 * values, such as the alignment, bytes to frames and so on.
474 * Depends on number of stream channels and the stream format
475 * being used.
476 *
477 ** @todo Use some RTAsmXXX functions instead?
478 */
479 uint8_t cShift;
480 /** Whether the endianness is swapped or not. */
481 bool fSwapEndian;
482} PDMAUDIOPCMPROPS, *PPDMAUDIOPCMPROPS;
483
484/** Calculates the cShift value of given sample bits and audio channels.
485 * Note: Does only support mono/stereo channels for now. */
486#define PDMAUDIOPCMPROPS_MAKE_SHIFT_PARMS(cBits, cChannels) ((cChannels == 2) + (cBits / 16))
487/** Calculates the cShift value of a PDMAUDIOPCMPROPS structure.
488 * Note: Does only support mono/stereo channels for now. */
489#define PDMAUDIOPCMPROPS_MAKE_SHIFT(pProps) PDMAUDIOPCMPROPS_MAKE_SHIFT_PARMS((pProps)->cChannels == 2) + (pProps)->cBits / 16)
490/** Converts (audio) frames to bytes.
491 * Needs the cShift value set correctly, using PDMAUDIOPCMPROPS_MAKE_SHIFT. */
492#define PDMAUDIOPCMPROPS_F2B(pProps, frames) ((frames) << (pProps)->cShift)
493/** Converts bytes to (audio) frames.
494 * Needs the cShift value set correctly, using PDMAUDIOPCMPROPS_MAKE_SHIFT. */
495#define PDMAUDIOPCMPROPS_B2F(pProps, cb) (cb >> (pProps)->cShift)
496
497/**
498 * Structure for keeping an audio stream configuration.
499 */
500typedef struct PDMAUDIOSTREAMCFG
501{
502 /** Friendly name of the stream. */
503 char szName[64];
504 /** Direction of the stream. */
505 PDMAUDIODIR enmDir;
506 /** Destination / source indicator, depending on enmDir. */
507 PDMAUDIODESTSOURCE DestSource;
508 /** The stream's PCM properties. */
509 PDMAUDIOPCMPROPS Props;
510 /** The stream's audio data layout.
511 * This indicates how the audio data buffers to/from the backend is being layouted.
512 *
513 * Currently, the following layouts are supported by the audio connector:
514 *
515 * PDMAUDIOSTREAMLAYOUT_NON_INTERLEAVED:
516 * One stream at once. The consecutive audio data is exactly in the format and frame width
517 * like defined in the PCM properties. This is the default.
518 *
519 * PDMAUDIOSTREAMLAYOUT_RAW:
520 * Can be one or many streams at once, depending on the stream's mixing buffer setup.
521 * The audio data will get handled as PDMAUDIOFRAME frames without any modification done. */
522 PDMAUDIOSTREAMLAYOUT enmLayout;
523 /** Hint about the optimal frame buffer size (in audio frames).
524 * 0 if no hint is given. */
525 uint32_t cFrameBufferHint;
526} PDMAUDIOSTREAMCFG, *PPDMAUDIOSTREAMCFG;
527
528/** Converts (audio) frames to bytes. */
529#define PDMAUDIOSTREAMCFG_F2B(pCfg, frames) ((frames) << (pCfg->Props).cShift)
530/** Converts bytes to (audio) frames. */
531#define PDMAUDIOSTREAMCFG_B2F(pCfg, cb) (cb >> (pCfg->Props).cShift)
532
533#if defined(RT_LITTLE_ENDIAN)
534# define PDMAUDIOHOSTENDIANNESS PDMAUDIOENDIANNESS_LITTLE
535#elif defined(RT_BIG_ENDIAN)
536# define PDMAUDIOHOSTENDIANNESS PDMAUDIOENDIANNESS_BIG
537#else
538# error "Port me!"
539#endif
540
541/**
542 * Audio mixer controls.
543 */
544typedef enum PDMAUDIOMIXERCTL
545{
546 /** Unknown mixer control. */
547 PDMAUDIOMIXERCTL_UNKNOWN = 0,
548 /** Master volume. */
549 PDMAUDIOMIXERCTL_VOLUME_MASTER,
550 /** Front. */
551 PDMAUDIOMIXERCTL_FRONT,
552 /** Center / LFE (Subwoofer). */
553 PDMAUDIOMIXERCTL_CENTER_LFE,
554 /** Rear. */
555 PDMAUDIOMIXERCTL_REAR,
556 /** Line-In. */
557 PDMAUDIOMIXERCTL_LINE_IN,
558 /** Microphone-In. */
559 PDMAUDIOMIXERCTL_MIC_IN,
560 /** Hack to blow the type up to 32-bit. */
561 PDMAUDIOMIXERCTL_32BIT_HACK = 0x7fffffff
562} PDMAUDIOMIXERCTL;
563
564/**
565 * Audio stream commands. Used in the audio connector
566 * as well as in the actual host backends.
567 */
568typedef enum PDMAUDIOSTREAMCMD
569{
570 /** Unknown command, do not use. */
571 PDMAUDIOSTREAMCMD_UNKNOWN = 0,
572 /** Enables the stream. */
573 PDMAUDIOSTREAMCMD_ENABLE,
574 /** Disables the stream. */
575 PDMAUDIOSTREAMCMD_DISABLE,
576 /** Pauses the stream. */
577 PDMAUDIOSTREAMCMD_PAUSE,
578 /** Resumes the stream. */
579 PDMAUDIOSTREAMCMD_RESUME,
580 /** Hack to blow the type up to 32-bit. */
581 PDMAUDIOSTREAMCMD_32BIT_HACK = 0x7fffffff
582} PDMAUDIOSTREAMCMD;
583
584/**
585 * Audio volume parameters.
586 */
587typedef struct PDMAUDIOVOLUME
588{
589 /** Set to @c true if this stream is muted, @c false if not. */
590 bool fMuted;
591 /** Left channel volume.
592 * Range is from [0 ... 255], whereas 0 specifies
593 * the most silent and 255 the loudest value. */
594 uint8_t uLeft;
595 /** Right channel volume.
596 * Range is from [0 ... 255], whereas 0 specifies
597 * the most silent and 255 the loudest value. */
598 uint8_t uRight;
599} PDMAUDIOVOLUME, *PPDMAUDIOVOLUME;
600
601/** Defines the minimum volume allowed. */
602#define PDMAUDIO_VOLUME_MIN (0)
603/** Defines the maximum volume allowed. */
604#define PDMAUDIO_VOLUME_MAX (255)
605
606/**
607 * Structure for holding rate processing information
608 * of a source + destination audio stream. This is needed
609 * because both streams can differ regarding their rates
610 * and therefore need to be treated accordingly.
611 */
612typedef struct PDMAUDIOSTREAMRATE
613{
614 /** Current (absolute) offset in the output
615 * (destination) stream. */
616 uint64_t dstOffset;
617 /** Increment for moving dstOffset for the
618 * destination stream. This is needed because the
619 * source <-> destination rate might be different. */
620 uint64_t dstInc;
621 /** Current (absolute) offset in the input
622 * stream. */
623 uint32_t srcOffset;
624 /** Last processed frame of the input stream.
625 * Needed for interpolation. */
626 PDMAUDIOFRAME srcFrameLast;
627} PDMAUDIOSTREAMRATE, *PPDMAUDIOSTREAMRATE;
628
629/**
630 * Structure for holding mixing buffer volume parameters.
631 * The volume values are in fixed point style and must
632 * be converted to/from before using with e.g. PDMAUDIOVOLUME.
633 */
634typedef struct PDMAUDMIXBUFVOL
635{
636 /** Set to @c true if this stream is muted, @c false if not. */
637 bool fMuted;
638 /** Left volume to apply during conversion. Pass 0
639 * to convert the original values. May not apply to
640 * all conversion functions. */
641 uint32_t uLeft;
642 /** Right volume to apply during conversion. Pass 0
643 * to convert the original values. May not apply to
644 * all conversion functions. */
645 uint32_t uRight;
646} PDMAUDMIXBUFVOL, *PPDMAUDMIXBUFVOL;
647
648/**
649 * Structure for holding frame conversion parameters for
650 * the audioMixBufConvFromXXX / audioMixBufConvToXXX macros.
651 */
652typedef struct PDMAUDMIXBUFCONVOPTS
653{
654 /** Number of audio frames to convert. */
655 uint32_t cFrames;
656 union
657 {
658 struct
659 {
660 /** Volume to use for conversion. */
661 PDMAUDMIXBUFVOL Volume;
662 } From;
663 };
664} PDMAUDMIXBUFCONVOPTS;
665/** Pointer to conversion parameters for the audio mixer. */
666typedef PDMAUDMIXBUFCONVOPTS *PPDMAUDMIXBUFCONVOPTS;
667/** Pointer to const conversion parameters for the audio mixer. */
668typedef PDMAUDMIXBUFCONVOPTS const *PCPDMAUDMIXBUFCONVOPTS;
669
670/**
671 * Note: All internal handling is done in audio frames,
672 * not in bytes!
673 */
674typedef uint32_t PDMAUDIOMIXBUFFMT;
675typedef PDMAUDIOMIXBUFFMT *PPDMAUDIOMIXBUFFMT;
676
677/**
678 * Convertion-from function used by the PDM audio buffer mixer.
679 *
680 * @returns Number of audio frames returned.
681 * @param paDst Where to return the converted frames.
682 * @param pvSrc The source frame bytes.
683 * @param cbSrc Number of bytes to convert.
684 * @param pOpts Conversion options.
685 */
686typedef DECLCALLBACK(uint32_t) FNPDMAUDIOMIXBUFCONVFROM(PPDMAUDIOFRAME paDst, const void *pvSrc, uint32_t cbSrc,
687 PCPDMAUDMIXBUFCONVOPTS pOpts);
688/** Pointer to a convertion-from function used by the PDM audio buffer mixer. */
689typedef FNPDMAUDIOMIXBUFCONVFROM *PFNPDMAUDIOMIXBUFCONVFROM;
690
691/**
692 * Convertion-to function used by the PDM audio buffer mixer.
693 *
694 * @param pvDst Output buffer.
695 * @param paSrc The input frames.
696 * @param pOpts Conversion options.
697 */
698typedef DECLCALLBACK(void) FNPDMAUDIOMIXBUFCONVTO(void *pvDst, PCPDMAUDIOFRAME paSrc, PCPDMAUDMIXBUFCONVOPTS pOpts);
699/** Pointer to a convertion-to function used by the PDM audio buffer mixer. */
700typedef FNPDMAUDIOMIXBUFCONVTO *PFNPDMAUDIOMIXBUFCONVTO;
701
702typedef struct PDMAUDIOMIXBUF *PPDMAUDIOMIXBUF;
703typedef struct PDMAUDIOMIXBUF
704{
705 RTLISTNODE Node;
706 /** Name of the buffer. */
707 char *pszName;
708 /** Frame buffer. */
709 PPDMAUDIOFRAME pFrames;
710 /** Size of the frame buffer (in audio frames). */
711 uint32_t cFrames;
712 /** The current read position (in frames). */
713 uint32_t offRead;
714 /** The current write position (in frames). */
715 uint32_t offWrite;
716 /**
717 * Total frames already mixed down to the parent buffer (if any). Always starting at
718 * the parent's offRead position.
719 *
720 * Note: Count always is specified in parent frames, as the sample count can differ between parent
721 * and child.
722 */
723 uint32_t cMixed;
724 /** How much audio frames are currently being used
725 * in this buffer.
726 * Note: This also is known as the distance in ring buffer terms. */
727 uint32_t cUsed;
728 /** Pointer to parent buffer (if any). */
729 PPDMAUDIOMIXBUF pParent;
730 /** List of children mix buffers to keep in sync with (if being a parent buffer). */
731 RTLISTANCHOR lstChildren;
732 /** Number of children mix buffers kept in lstChildren. */
733 uint32_t cChildren;
734 /** Intermediate structure for buffer conversion tasks. */
735 PPDMAUDIOSTREAMRATE pRate;
736 /** Internal representation of current volume used for mixing. */
737 PDMAUDMIXBUFVOL Volume;
738 /** This buffer's audio format. */
739 PDMAUDIOMIXBUFFMT AudioFmt;
740 /** Standard conversion-to function for set AudioFmt. */
741 PFNPDMAUDIOMIXBUFCONVTO pfnConvTo;
742 /** Standard conversion-from function for set AudioFmt. */
743 PFNPDMAUDIOMIXBUFCONVFROM pfnConvFrom;
744 /**
745 * Ratio of the associated parent stream's frequency by this stream's
746 * frequency (1<<32), represented as a signed 64 bit integer.
747 *
748 * For example, if the parent stream has a frequency of 44 khZ, and this
749 * stream has a frequency of 11 kHz, the ration then would be
750 * (44/11 * (1 << 32)).
751 *
752 * Currently this does not get changed once assigned.
753 */
754 int64_t iFreqRatio;
755 /** For quickly converting frames <-> bytes and vice versa. */
756 uint8_t cShift;
757} PDMAUDIOMIXBUF;
758
759typedef uint32_t PDMAUDIOFILEFLAGS;
760
761/* No flags defined. */
762#define PDMAUDIOFILEFLAG_NONE 0
763
764/**
765 * Audio file types.
766 */
767typedef enum PDMAUDIOFILETYPE
768{
769 /** Unknown type, do not use. */
770 PDMAUDIOFILETYPE_UNKNOWN = 0,
771 /** Wave (.WAV) file. */
772 PDMAUDIOFILETYPE_WAV,
773 /** Hack to blow the type up to 32-bit. */
774 PDMAUDIOFILETYPE_32BIT_HACK = 0x7fffffff
775} PDMAUDIOFILETYPE;
776
777/**
778 * Structure for an audio file handle.
779 */
780typedef struct PDMAUDIOFILE
781{
782 /** Type of the audio file. */
783 PDMAUDIOFILETYPE enmType;
784 /** File name. */
785 char szName[255];
786 /** Actual file handle. */
787 RTFILE hFile;
788 /** Data needed for the specific audio file type implemented.
789 * Optional, can be NULL. */
790 void *pvData;
791 /** Data size (in bytes). */
792 size_t cbData;
793} PDMAUDIOFILE, *PPDMAUDIOFILE;
794
795/** Stream status flag. To be used with PDMAUDIOSTRMSTS_FLAG_ flags. */
796typedef uint32_t PDMAUDIOSTREAMSTS;
797
798/** No flags being set. */
799#define PDMAUDIOSTREAMSTS_FLAG_NONE 0
800/** Whether this stream has been initialized by the
801 * backend or not. */
802#define PDMAUDIOSTREAMSTS_FLAG_INITIALIZED RT_BIT_32(0)
803/** Whether this stream is enabled or disabled. */
804#define PDMAUDIOSTREAMSTS_FLAG_ENABLED RT_BIT_32(1)
805/** Whether this stream has been paused or not. This also implies
806 * that this is an enabled stream! */
807#define PDMAUDIOSTREAMSTS_FLAG_PAUSED RT_BIT_32(2)
808/** Whether this stream was marked as being disabled
809 * but there are still associated guest output streams
810 * which rely on its data. */
811#define PDMAUDIOSTREAMSTS_FLAG_PENDING_DISABLE RT_BIT_32(3)
812/** Whether this stream is in re-initialization phase.
813 * All other bits remain untouched to be able to restore
814 * the stream's state after the re-initialization bas been
815 * finished. */
816#define PDMAUDIOSTREAMSTS_FLAG_PENDING_REINIT RT_BIT_32(4)
817/** Validation mask. */
818#define PDMAUDIOSTREAMSTS_VALID_MASK UINT32_C(0x0000001F)
819
820/**
821 * Enumeration presenting a backend's current status.
822 */
823typedef enum PDMAUDIOBACKENDSTS
824{
825 /** Unknown/invalid status. */
826 PDMAUDIOBACKENDSTS_UNKNOWN = 0,
827 /** The backend is in its initialization phase.
828 * Not all backends support this status. */
829 PDMAUDIOBACKENDSTS_INITIALIZING,
830 /** The backend has stopped its operation. */
831 PDMAUDIOBACKENDSTS_STOPPED,
832 /** The backend is up and running. */
833 PDMAUDIOBACKENDSTS_RUNNING,
834 /** The backend ran into an error and is unable to recover.
835 * A manual re-initialization might help. */
836 PDMAUDIOBACKENDSTS_ERROR,
837 /** Hack to blow the type up to 32-bit. */
838 PDMAUDIOBACKENDSTS_32BIT_HACK = 0x7fffffff
839} PDMAUDIOBACKENDSTS;
840
841/**
842 * Audio stream context.
843 */
844typedef enum PDMAUDIOSTREAMCTX
845{
846 /** No context set / invalid. */
847 PDMAUDIOSTREAMCTX_UNKNOWN = 0,
848 /** Host stream, connected to a backend. */
849 PDMAUDIOSTREAMCTX_HOST,
850 /** Guest stream, connected to the device emulation. */
851 PDMAUDIOSTREAMCTX_GUEST,
852 /** Hack to blow the type up to 32-bit. */
853 PDMAUDIOSTREAMCTX_32BIT_HACK = 0x7fffffff
854} PDMAUDIOSTREAMCTX;
855
856/**
857 * Structure for keeping audio input stream specifics.
858 * Do not use directly. Instead, use PDMAUDIOSTREAM.
859 */
860typedef struct PDMAUDIOSTREAMIN
861{
862 /** Timestamp (in ms) since last read. */
863 uint64_t tsLastReadMS;
864#ifdef VBOX_WITH_STATISTICS
865 STAMCOUNTER StatBytesElapsed;
866 STAMCOUNTER StatBytesTotalRead;
867 STAMCOUNTER StatFramesCaptured;
868#endif
869} PDMAUDIOSTREAMIN, *PPDMAUDIOSTREAMIN;
870
871/**
872 * Structure for keeping audio output stream specifics.
873 * Do not use directly. Instead, use PDMAUDIOSTREAM.
874 */
875typedef struct PDMAUDIOSTREAMOUT
876{
877 /** Timestamp (in ms) since last write. */
878 uint64_t tsLastWriteMS;
879#ifdef VBOX_WITH_STATISTICS
880 STAMCOUNTER StatBytesElapsed;
881 STAMCOUNTER StatBytesTotalWritten;
882 STAMCOUNTER StatFramesPlayed;
883#endif
884} PDMAUDIOSTREAMOUT, *PPDMAUDIOSTREAMOUT;
885
886typedef struct PDMAUDIOSTREAM *PPDMAUDIOSTREAM;
887
888/**
889 * Structure for maintaining an nput/output audio stream.
890 */
891typedef struct PDMAUDIOSTREAM
892{
893 /** List node. */
894 RTLISTNODE Node;
895 /** Pointer to the other pair of this stream.
896 * This might be the host or guest side. */
897 PPDMAUDIOSTREAM pPair;
898 /** Name of this stream. */
899 char szName[64];
900 /** Number of references to this stream. Only can be
901 * destroyed if the reference count is reaching 0. */
902 uint32_t cRefs;
903 /** The stream's audio configuration. */
904 PDMAUDIOSTREAMCFG Cfg;
905 /** Stream status flag. */
906 PDMAUDIOSTREAMSTS fStatus;
907 /** This stream's mixing buffer. */
908 PDMAUDIOMIXBUF MixBuf;
909 /** Audio direction of this stream. */
910 PDMAUDIODIR enmDir;
911 /** Context of this stream. */
912 PDMAUDIOSTREAMCTX enmCtx;
913 /** Timestamp (in ms) since last iteration. */
914 uint64_t tsLastIterateMS;
915 /** Union for input/output specifics. */
916 union
917 {
918 PDMAUDIOSTREAMIN In;
919 PDMAUDIOSTREAMOUT Out;
920 };
921 /** Data to backend-specific stream data.
922 * This data block will be casted by the backend to access its backend-dependent data.
923 *
924 * That way the backends do not have access to the audio connector's data. */
925 void *pvBackend;
926 /** Size (in bytes) of the backend-specific stream data. */
927 size_t cbBackend;
928} PDMAUDIOSTREAM, *PPDMAUDIOSTREAM;
929
930/** Pointer to a audio connector interface. */
931typedef struct PDMIAUDIOCONNECTOR *PPDMIAUDIOCONNECTOR;
932
933/**
934 * Enumeration for an audio callback source.
935 */
936typedef enum PDMAUDIOCBSOURCE
937{
938 /** Invalid, do not use. */
939 PDMAUDIOCBSOURCE_INVALID = 0,
940 /** Device emulation. */
941 PDMAUDIOCBSOURCE_DEVICE = 1,
942 /** Audio connector interface. */
943 PDMAUDIOCBSOURCE_CONNECTOR = 2,
944 /** Backend (lower). */
945 PDMAUDIOCBSOURCE_BACKEND = 3,
946 /** Hack to blow the type up to 32-bit. */
947 PDMAUDIOCBSOURCE_32BIT_HACK = 0x7fffffff
948} PDMAUDIOCBSOURCE;
949
950/**
951 * Audio device callback types.
952 * Those callbacks are being sent from the audio connector -> device emulation.
953 */
954typedef enum PDMAUDIODEVICECBTYPE
955{
956 /** Invalid, do not use. */
957 PDMAUDIODEVICECBTYPE_INVALID = 0,
958 /** Data is availabe as input for passing to the device emulation. */
959 PDMAUDIODEVICECBTYPE_DATA_INPUT,
960 /** Free data for the device emulation to write to the backend. */
961 PDMAUDIODEVICECBTYPE_DATA_OUTPUT,
962 /** Hack to blow the type up to 32-bit. */
963 PDMAUDIODEVICECBTYPE_32BIT_HACK = 0x7fffffff
964} PDMAUDIODEVICECBTYPE;
965
966/**
967 * Device callback data for audio input.
968 */
969typedef struct PDMAUDIODEVICECBDATA_DATA_INPUT
970{
971 /** Input: How many bytes are availabe as input for passing
972 * to the device emulation. */
973 uint32_t cbInAvail;
974 /** Output: How many bytes have been read. */
975 uint32_t cbOutRead;
976} PDMAUDIODEVICECBDATA_DATA_INPUT, *PPDMAUDIODEVICECBDATA_DATA_INPUT;
977
978/**
979 * Device callback data for audio output.
980 */
981typedef struct PDMAUDIODEVICECBDATA_DATA_OUTPUT
982{
983 /** Input: How many bytes are free for the device emulation to write. */
984 uint32_t cbInFree;
985 /** Output: How many bytes were written by the device emulation. */
986 uint32_t cbOutWritten;
987} PDMAUDIODEVICECBDATA_DATA_OUTPUT, *PPDMAUDIODEVICECBDATA_DATA_OUTPUT;
988
989/**
990 * Audio backend callback types.
991 * Those callbacks are being sent from the backend -> audio connector.
992 */
993typedef enum PDMAUDIOBACKENDCBTYPE
994{
995 /** Invalid, do not use. */
996 PDMAUDIOBACKENDCBTYPE_INVALID = 0,
997 /** The backend's status has changed. */
998 PDMAUDIOBACKENDCBTYPE_STATUS,
999 /** One or more host audio devices have changed. */
1000 PDMAUDIOBACKENDCBTYPE_DEVICES_CHANGED,
1001 /** Hack to blow the type up to 32-bit. */
1002 PDMAUDIOBACKENDCBTYPE_32BIT_HACK = 0x7fffffff
1003} PDMAUDIOBACKENDCBTYPE;
1004
1005/** Pointer to a host audio interface. */
1006typedef struct PDMIHOSTAUDIO *PPDMIHOSTAUDIO;
1007
1008/**
1009 * Host audio callback function.
1010 * This function will be called from a backend to communicate with the host audio interface.
1011 *
1012 * @returns IPRT status code.
1013 * @param pDrvIns Pointer to driver instance which called us.
1014 * @param enmType Callback type.
1015 * @param pvUser User argument.
1016 * @param cbUser Size (in bytes) of user argument.
1017 */
1018typedef DECLCALLBACK(int) FNPDMHOSTAUDIOCALLBACK(PPDMDRVINS pDrvIns, PDMAUDIOBACKENDCBTYPE enmType, void *pvUser, size_t cbUser);
1019/** Pointer to a FNPDMHOSTAUDIOCALLBACK(). */
1020typedef FNPDMHOSTAUDIOCALLBACK *PFNPDMHOSTAUDIOCALLBACK;
1021
1022/**
1023 * Audio callback registration record.
1024 */
1025typedef struct PDMAUDIOCBRECORD
1026{
1027 /** List node. */
1028 RTLISTANCHOR Node;
1029 /** Callback source. */
1030 PDMAUDIOCBSOURCE enmSource;
1031 /** Callback type, based on the given source. */
1032 union
1033 {
1034 /** Device callback stuff. */
1035 struct
1036 {
1037 PDMAUDIODEVICECBTYPE enmType;
1038 } Device;
1039 };
1040 /** Pointer to context data. Optional. */
1041 void *pvCtx;
1042 /** Size (in bytes) of context data.
1043 * Must be 0 if pvCtx is NULL. */
1044 size_t cbCtx;
1045} PDMAUDIOCBRECORD, *PPDMAUDIOCBRECORD;
1046
1047#define PPDMAUDIOBACKENDSTREAM void *
1048
1049/**
1050 * Audio connector interface (up).
1051 */
1052typedef struct PDMIAUDIOCONNECTOR
1053{
1054 /**
1055 * Enables or disables the given audio direction for this driver.
1056 *
1057 * When disabled, assiociated output streams consume written audio without passing them further down to the backends.
1058 * Associated input streams then return silence when read from those.
1059 *
1060 * @returns VBox status code.
1061 * @param pInterface Pointer to the interface structure containing the called function pointer.
1062 * @param enmDir Audio direction to enable or disable driver for.
1063 * @param fEnable Whether to enable or disable the specified audio direction.
1064 */
1065 DECLR3CALLBACKMEMBER(int, pfnEnable, (PPDMIAUDIOCONNECTOR pInterface, PDMAUDIODIR enmDir, bool fEnable));
1066
1067 /**
1068 * Returns whether the given audio direction for this driver is enabled or not.
1069 *
1070 * @returns True if audio is enabled for the given direction, false if not.
1071 * @param pInterface Pointer to the interface structure containing the called function pointer.
1072 * @param enmDir Audio direction to retrieve enabled status for.
1073 */
1074 DECLR3CALLBACKMEMBER(bool, pfnIsEnabled, (PPDMIAUDIOCONNECTOR pInterface, PDMAUDIODIR enmDir));
1075
1076 /**
1077 * Retrieves the current configuration of the host audio backend.
1078 *
1079 * @returns VBox status code.
1080 * @param pInterface Pointer to the interface structure containing the called function pointer.
1081 * @param pCfg Where to store the host audio backend configuration data.
1082 */
1083 DECLR3CALLBACKMEMBER(int, pfnGetConfig, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOBACKENDCFG pCfg));
1084
1085 /**
1086 * Retrieves the current status of the host audio backend.
1087 *
1088 * @returns Status of the host audio backend.
1089 * @param pInterface Pointer to the interface structure containing the called function pointer.
1090 * @param enmDir Audio direction to check host audio backend for. Specify PDMAUDIODIR_ANY for the overall
1091 * backend status.
1092 */
1093 DECLR3CALLBACKMEMBER(PDMAUDIOBACKENDSTS, pfnGetStatus, (PPDMIAUDIOCONNECTOR pInterface, PDMAUDIODIR enmDir));
1094
1095 /**
1096 * Creates an audio stream.
1097 *
1098 * @returns VBox status code.
1099 * @param pInterface Pointer to the interface structure containing the called function pointer.
1100 * @param pCfgHost Stream configuration for host side.
1101 * @param pCfgGuest Stream configuration for guest side.
1102 * @param ppStream Pointer where to return the created audio stream on success.
1103 */
1104 DECLR3CALLBACKMEMBER(int, pfnStreamCreate, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAMCFG pCfgHost, PPDMAUDIOSTREAMCFG pCfgGuest, PPDMAUDIOSTREAM *ppStream));
1105
1106 /**
1107 * Destroys an audio stream.
1108 *
1109 * @param pInterface Pointer to the interface structure containing the called function pointer.
1110 * @param pStream Pointer to audio stream.
1111 */
1112 DECLR3CALLBACKMEMBER(int, pfnStreamDestroy, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1113
1114 /**
1115 * Adds a reference to the specified audio stream.
1116 *
1117 * @returns New reference count. UINT32_MAX on error.
1118 * @param pInterface Pointer to the interface structure containing the called function pointer.
1119 * @param pStream Pointer to audio stream adding the reference to.
1120 */
1121 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamRetain, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1122
1123 /**
1124 * Releases a reference from the specified stream.
1125 *
1126 * @returns New reference count. UINT32_MAX on error.
1127 * @param pInterface Pointer to the interface structure containing the called function pointer.
1128 * @param pStream Pointer to audio stream releasing a reference from.
1129 */
1130 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamRelease, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1131
1132 /**
1133 * Reads PCM audio data from the host (input).
1134 *
1135 * @returns VBox status code.
1136 * @param pInterface Pointer to the interface structure containing the called function pointer.
1137 * @param pStream Pointer to audio stream to write to.
1138 * @param pvBuf Where to store the read data.
1139 * @param cbBuf Number of bytes to read.
1140 * @param pcbRead Bytes of audio data read. Optional.
1141 */
1142 DECLR3CALLBACKMEMBER(int, pfnStreamRead, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream, void *pvBuf, uint32_t cbBuf, uint32_t *pcbRead));
1143
1144 /**
1145 * Writes PCM audio data to the host (output).
1146 *
1147 * @returns VBox status code.
1148 * @param pInterface Pointer to the interface structure containing the called function pointer.
1149 * @param pStream Pointer to audio stream to read from.
1150 * @param pvBuf Audio data to be written.
1151 * @param cbBuf Number of bytes to be written.
1152 * @param pcbWritten Bytes of audio data written. Optional.
1153 */
1154 DECLR3CALLBACKMEMBER(int, pfnStreamWrite, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream, const void *pvBuf, uint32_t cbBuf, uint32_t *pcbWritten));
1155
1156 /**
1157 * Controls a specific audio stream.
1158 *
1159 * @returns VBox status code.
1160 * @param pInterface Pointer to the interface structure containing the called function pointer.
1161 * @param pStream Pointer to audio stream.
1162 * @param enmStreamCmd The stream command to issue.
1163 */
1164 DECLR3CALLBACKMEMBER(int, pfnStreamControl, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream, PDMAUDIOSTREAMCMD enmStreamCmd));
1165
1166 /**
1167 * Processes stream data.
1168 *
1169 * @param pInterface Pointer to the interface structure containing the called function pointer.
1170 * @param pStream Pointer to audio stream.
1171 */
1172 DECLR3CALLBACKMEMBER(int, pfnStreamIterate, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1173
1174 /**
1175 * Returns the number of readable data (in bytes) of a specific audio input stream.
1176 *
1177 * @returns Number of readable data (in bytes).
1178 * @param pInterface Pointer to the interface structure containing the called function pointer.
1179 * @param pStream Pointer to audio stream.
1180 */
1181 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamGetReadable, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1182
1183 /**
1184 * Returns the number of writable data (in bytes) of a specific audio output stream.
1185 *
1186 * @returns Number of writable data (in bytes).
1187 * @param pInterface Pointer to the interface structure containing the called function pointer.
1188 * @param pStream Pointer to audio stream.
1189 */
1190 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamGetWritable, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1191
1192 /**
1193 * Returns the status of a specific audio stream.
1194 *
1195 * @returns Audio stream status
1196 * @param pInterface Pointer to the interface structure containing the called function pointer.
1197 * @param pStream Pointer to audio stream.
1198 */
1199 DECLR3CALLBACKMEMBER(PDMAUDIOSTREAMSTS, pfnStreamGetStatus, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream));
1200
1201 /**
1202 * Sets the audio volume of a specific audio stream.
1203 *
1204 * @returns VBox status code.
1205 * @param pInterface Pointer to the interface structure containing the called function pointer.
1206 * @param pStream Pointer to audio stream.
1207 * @param pVol Pointer to audio volume structure to set the stream's audio volume to.
1208 */
1209 DECLR3CALLBACKMEMBER(int, pfnStreamSetVolume, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream, PPDMAUDIOVOLUME pVol));
1210
1211 /**
1212 * Plays (transfers) available audio frames via the host backend. Only works with output streams.
1213 *
1214 * @returns VBox status code.
1215 * @param pInterface Pointer to the interface structure containing the called function pointer.
1216 * @param pStream Pointer to audio stream.
1217 * @param pcFramesPlayed Number of frames played. Optional.
1218 */
1219 DECLR3CALLBACKMEMBER(int, pfnStreamPlay, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream, uint32_t *pcFramesPlayed));
1220
1221 /**
1222 * Captures (transfers) available audio frames from the host backend. Only works with input streams.
1223 *
1224 * @returns VBox status code.
1225 * @param pInterface Pointer to the interface structure containing the called function pointer.
1226 * @param pStream Pointer to audio stream.
1227 * @param pcFramesCaptured Number of frames captured. Optional.
1228 */
1229 DECLR3CALLBACKMEMBER(int, pfnStreamCapture, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOSTREAM pStream, uint32_t *pcFramesCaptured));
1230
1231 /**
1232 * Registers (device) callbacks.
1233 * This is handy for letting the device emulation know of certain events, e.g. processing input / output data
1234 * or configuration changes.
1235 *
1236 * @returns VBox status code.
1237 * @param pInterface Pointer to the interface structure containing the called function pointer.
1238 * @param paCallbacks Pointer to array of callbacks to register.
1239 * @param cCallbacks Number of callbacks to register.
1240 */
1241 DECLR3CALLBACKMEMBER(int, pfnRegisterCallbacks, (PPDMIAUDIOCONNECTOR pInterface, PPDMAUDIOCBRECORD paCallbacks, size_t cCallbacks));
1242
1243} PDMIAUDIOCONNECTOR, *PPDMIAUDIOCONNECTOR;
1244
1245/** PDMIAUDIOCONNECTOR interface ID. */
1246#define PDMIAUDIOCONNECTOR_IID "A643B40C-733F-4307-9549-070AF0EE0ED6"
1247
1248/**
1249 * Assigns all needed interface callbacks for an audio backend.
1250 *
1251 * @param a_Prefix The function name prefix.
1252 */
1253#define PDMAUDIO_IHOSTAUDIO_CALLBACKS(a_Prefix) \
1254 do { \
1255 pThis->IHostAudio.pfnInit = RT_CONCAT(a_Prefix,Init); \
1256 pThis->IHostAudio.pfnShutdown = RT_CONCAT(a_Prefix,Shutdown); \
1257 pThis->IHostAudio.pfnGetConfig = RT_CONCAT(a_Prefix,GetConfig); \
1258 /** @todo Add pfnGetDevices here as soon as supported by all backends. */ \
1259 pThis->IHostAudio.pfnGetStatus = RT_CONCAT(a_Prefix,GetStatus); \
1260 /** @todo Ditto for pfnSetCallback. */ \
1261 pThis->IHostAudio.pfnStreamCreate = RT_CONCAT(a_Prefix,StreamCreate); \
1262 pThis->IHostAudio.pfnStreamDestroy = RT_CONCAT(a_Prefix,StreamDestroy); \
1263 pThis->IHostAudio.pfnStreamControl = RT_CONCAT(a_Prefix,StreamControl); \
1264 pThis->IHostAudio.pfnStreamGetReadable = RT_CONCAT(a_Prefix,StreamGetReadable); \
1265 pThis->IHostAudio.pfnStreamGetWritable = RT_CONCAT(a_Prefix,StreamGetWritable); \
1266 pThis->IHostAudio.pfnStreamGetStatus = RT_CONCAT(a_Prefix,StreamGetStatus); \
1267 pThis->IHostAudio.pfnStreamIterate = RT_CONCAT(a_Prefix,StreamIterate); \
1268 pThis->IHostAudio.pfnStreamPlay = RT_CONCAT(a_Prefix,StreamPlay); \
1269 pThis->IHostAudio.pfnStreamCapture = RT_CONCAT(a_Prefix,StreamCapture); \
1270 } while (0)
1271
1272/**
1273 * PDM host audio interface.
1274 */
1275typedef struct PDMIHOSTAUDIO
1276{
1277 /**
1278 * Initializes the host backend (driver).
1279 *
1280 * @returns VBox status code.
1281 * @param pInterface Pointer to the interface structure containing the called function pointer.
1282 */
1283 DECLR3CALLBACKMEMBER(int, pfnInit, (PPDMIHOSTAUDIO pInterface));
1284
1285 /**
1286 * Shuts down the host backend (driver).
1287 *
1288 * @returns VBox status code.
1289 * @param pInterface Pointer to the interface structure containing the called function pointer.
1290 */
1291 DECLR3CALLBACKMEMBER(void, pfnShutdown, (PPDMIHOSTAUDIO pInterface));
1292
1293 /**
1294 * Returns the host backend's configuration (backend).
1295 *
1296 * @returns VBox status code.
1297 * @param pInterface Pointer to the interface structure containing the called function pointer.
1298 * @param pBackendCfg Where to store the backend audio configuration to.
1299 */
1300 DECLR3CALLBACKMEMBER(int, pfnGetConfig, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDCFG pBackendCfg));
1301
1302 /**
1303 * Returns (enumerates) host audio device information.
1304 *
1305 * @returns VBox status code.
1306 * @param pInterface Pointer to the interface structure containing the called function pointer.
1307 * @param pDeviceEnum Where to return the enumerated audio devices.
1308 */
1309 DECLR3CALLBACKMEMBER(int, pfnGetDevices, (PPDMIHOSTAUDIO pInterface, PPDMAUDIODEVICEENUM pDeviceEnum));
1310
1311 /**
1312 * Returns the current status from the audio backend.
1313 *
1314 * @returns PDMAUDIOBACKENDSTS enum.
1315 * @param pInterface Pointer to the interface structure containing the called function pointer.
1316 * @param enmDir Audio direction to get status for. Pass PDMAUDIODIR_ANY for overall status.
1317 */
1318 DECLR3CALLBACKMEMBER(PDMAUDIOBACKENDSTS, pfnGetStatus, (PPDMIHOSTAUDIO pInterface, PDMAUDIODIR enmDir));
1319
1320 /**
1321 * Sets a callback the audio backend can call. Optional.
1322 *
1323 * @returns VBox status code.
1324 * @param pInterface Pointer to the interface structure containing the called function pointer.
1325 * @param pfnCallback The callback function to use, or NULL when unregistering.
1326 */
1327 DECLR3CALLBACKMEMBER(int, pfnSetCallback, (PPDMIHOSTAUDIO pInterface, PFNPDMHOSTAUDIOCALLBACK pfnCallback));
1328
1329 /**
1330 * Creates an audio stream using the requested stream configuration.
1331 * If a backend is not able to create this configuration, it will return its best match in the acquired configuration
1332 * structure on success.
1333 *
1334 * @returns VBox status code.
1335 * @param pInterface Pointer to the interface structure containing the called function pointer.
1336 * @param pStream Pointer to audio stream.
1337 * @param pCfgReq Pointer to requested stream configuration.
1338 * @param pCfgAcq Pointer to acquired stream configuration.
1339 */
1340 DECLR3CALLBACKMEMBER(int, pfnStreamCreate, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream, PPDMAUDIOSTREAMCFG pCfgReq, PPDMAUDIOSTREAMCFG pCfgAcq));
1341
1342 /**
1343 * Destroys an audio stream.
1344 *
1345 * @returns VBox status code.
1346 * @param pInterface Pointer to the interface structure containing the called function pointer.
1347 * @param pStream Pointer to audio stream.
1348 */
1349 DECLR3CALLBACKMEMBER(int, pfnStreamDestroy, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1350
1351 /**
1352 * Controls an audio stream.
1353 *
1354 * @returns VBox status code.
1355 * @param pInterface Pointer to the interface structure containing the called function pointer.
1356 * @param pStream Pointer to audio stream.
1357 * @param enmStreamCmd The stream command to issue.
1358 */
1359 DECLR3CALLBACKMEMBER(int, pfnStreamControl, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream, PDMAUDIOSTREAMCMD enmStreamCmd));
1360
1361 /**
1362 * Returns the amount which is readable from the audio (input) stream.
1363 *
1364 * @returns For non-raw layout streams: Number of readable bytes.
1365 * for raw layout streams : Number of readable audio frames.
1366 * @param pInterface Pointer to the interface structure containing the called function pointer.
1367 * @param pStream Pointer to audio stream.
1368 */
1369 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamGetReadable, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1370
1371 /**
1372 * Returns the amount which is writable to the audio (output) stream.
1373 *
1374 * @returns For non-raw layout streams: Number of writable bytes.
1375 * for raw layout streams : Number of writable audio frames.
1376 * @param pInterface Pointer to the interface structure containing the called function pointer.
1377 * @param pStream Pointer to audio stream.
1378 */
1379 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamGetWritable, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1380
1381 /**
1382 * Returns the amount which is pending (in other words has not yet been processed) by/from the backend yet.
1383 * Optional.
1384 *
1385 * For input streams this is read audio data by the backend which has not been processed by the host yet.
1386 * For output streams this is written audio data to the backend which has not been processed by the backend yet.
1387 *
1388 * @returns For non-raw layout streams: Number of pending bytes.
1389 * for raw layout streams : Number of pending audio frames.
1390 * @param pInterface Pointer to the interface structure containing the called function pointer.
1391 * @param pStream Pointer to audio stream.
1392 */
1393 DECLR3CALLBACKMEMBER(uint32_t, pfnStreamGetPending, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1394
1395 /**
1396 * Returns the current status of the given backend stream.
1397 *
1398 * @returns PDMAUDIOSTREAMSTS
1399 * @param pInterface Pointer to the interface structure containing the called function pointer.
1400 * @param pStream Pointer to audio stream.
1401 */
1402 DECLR3CALLBACKMEMBER(PDMAUDIOSTREAMSTS, pfnStreamGetStatus, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1403
1404 /**
1405 * Gives the host backend the chance to do some (necessary) iteration work.
1406 *
1407 * @returns VBox status code.
1408 * @param pInterface Pointer to the interface structure containing the called function pointer.
1409 * @param pStream Pointer to audio stream.
1410 */
1411 DECLR3CALLBACKMEMBER(int, pfnStreamIterate, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1412
1413 /**
1414 * Signals the backend that the host wants to begin playing for this iteration. Optional.
1415 *
1416 * @param pInterface Pointer to the interface structure containing the called function pointer.
1417 * @param pStream Pointer to audio stream.
1418 */
1419 DECLR3CALLBACKMEMBER(void, pfnStreamPlayBegin, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1420
1421 /**
1422 * Plays (writes to) an audio (output) stream.
1423 *
1424 * @returns VBox status code.
1425 * @param pInterface Pointer to the interface structure containing the called function pointer.
1426 * @param pStream Pointer to audio stream.
1427 * @param pvBuf Pointer to audio data buffer to play.
1428 * @param cxBuf For non-raw layout streams: Size (in bytes) of audio data buffer,
1429 * for raw layout streams : Size (in audio frames) of audio data buffer.
1430 * @param pcxWritten For non-raw layout streams: Returns number of bytes written. Optional.
1431 * for raw layout streams : Returns number of frames written. Optional.
1432 */
1433 DECLR3CALLBACKMEMBER(int, pfnStreamPlay, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream, const void *pvBuf, uint32_t cxBuf, uint32_t *pcxWritten));
1434
1435 /**
1436 * Signals the backend that the host finished playing for this iteration. Optional.
1437 *
1438 * @param pInterface Pointer to the interface structure containing the called function pointer.
1439 * @param pStream Pointer to audio stream.
1440 */
1441 DECLR3CALLBACKMEMBER(void, pfnStreamPlayEnd, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1442
1443 /**
1444 * Signals the backend that the host wants to begin capturing for this iteration. Optional.
1445 *
1446 * @param pInterface Pointer to the interface structure containing the called function pointer.
1447 * @param pStream Pointer to audio stream.
1448 */
1449 DECLR3CALLBACKMEMBER(void, pfnStreamCaptureBegin, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1450
1451 /**
1452 * Captures (reads from) an audio (input) stream.
1453 *
1454 * @returns VBox status code.
1455 * @param pInterface Pointer to the interface structure containing the called function pointer.
1456 * @param pStream Pointer to audio stream.
1457 * @param pvBuf Buffer where to store read audio data.
1458 * @param cxBuf For non-raw layout streams: Size (in bytes) of audio data buffer,
1459 * for raw layout streams : Size (in audio frames) of audio data buffer.
1460 * @param pcxRead For non-raw layout streams: Returns number of bytes read. Optional.
1461 * for raw layout streams : Returns number of frames read. Optional.
1462 */
1463 DECLR3CALLBACKMEMBER(int, pfnStreamCapture, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream, void *pvBuf, uint32_t cxBuf, uint32_t *pcxRead));
1464
1465 /**
1466 * Signals the backend that the host finished capturing for this iteration. Optional.
1467 *
1468 * @param pInterface Pointer to the interface structure containing the called function pointer.
1469 * @param pStream Pointer to audio stream.
1470 */
1471 DECLR3CALLBACKMEMBER(void, pfnStreamCaptureEnd, (PPDMIHOSTAUDIO pInterface, PPDMAUDIOBACKENDSTREAM pStream));
1472
1473} PDMIHOSTAUDIO, *PPDMIHOSTAUDIO;
1474
1475/** PDMIHOSTAUDIO interface ID. */
1476#define PDMIHOSTAUDIO_IID "640F5A31-8245-491C-538F-29A0F9D08881"
1477
1478/** @} */
1479
1480#endif /* !___VBox_vmm_pdmaudioifs_h */
1481
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