VirtualBox

source: vbox/trunk/src/VBox/Devices/Audio/AudioHlp.h@ 88786

Last change on this file since 88786 was 88357, checked in by vboxsync, 4 years ago

Audio: Moved PDMAUDIOFILE and associated stuff out of pdmaudioifs.h and into AudioHlp.h, renaming the typedefs & defines. bugref:9890

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.7 KB
Line 
1/* $Id: AudioHlp.h 88357 2021-04-04 22:58:35Z vboxsync $ */
2/** @file
3 * Audio helper routines.
4 */
5
6/*
7 * Copyright (C) 2006-2020 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef VBOX_INCLUDED_SRC_Audio_AudioHlp_h
19#define VBOX_INCLUDED_SRC_Audio_AudioHlp_h
20#ifndef RT_WITHOUT_PRAGMA_ONCE
21# pragma once
22#endif
23
24#include <limits.h>
25
26#include <iprt/circbuf.h>
27#include <iprt/critsect.h>
28#include <iprt/file.h>
29#include <iprt/path.h>
30
31#include <VBox/vmm/pdmdev.h>
32#include <VBox/vmm/pdm.h>
33#include <VBox/vmm/pdmaudioifs.h>
34
35/** @name Audio calculation helper methods.
36 * @{ */
37uint32_t AudioHlpCalcBitrate(uint8_t cBits, uint32_t uHz, uint8_t cChannels);
38/** @} */
39
40/** @name Audio PCM properties helper methods.
41 * @{ */
42bool AudioHlpPcmPropsAreValid(PCPDMAUDIOPCMPROPS pProps);
43/** @} */
44
45/** @name Audio configuration helper methods.
46 * @{ */
47bool AudioHlpStreamCfgIsValid(PCPDMAUDIOSTREAMCFG pCfg);
48/** @} */
49
50/** @name Audio string-ify methods.
51 * @{ */
52PDMAUDIOFMT AudioHlpStrToAudFmt(const char *pszFmt);
53/** @} */
54
55
56/** @name AUDIOHLPFILE_FLAGS_XXX
57 * @{ */
58/** No flags defined. */
59#define AUDIOHLPFILE_FLAGS_NONE UINT32_C(0)
60/** Keep the audio file even if it contains no audio data. */
61#define AUDIOHLPFILE_FLAGS_KEEP_IF_EMPTY RT_BIT_32(0)
62/** Audio file flag validation mask. */
63#define AUDIOHLPFILE_FLAGS_VALID_MASK UINT32_C(0x1)
64/** @} */
65
66/** Audio file default open flags. */
67#define AUDIOHLPFILE_DEFAULT_OPEN_FLAGS (RTFILE_O_OPEN_CREATE | RTFILE_O_APPEND | RTFILE_O_WRITE | RTFILE_O_DENY_WRITE)
68
69/**
70 * Audio file types.
71 */
72typedef enum AUDIOHLPFILETYPE
73{
74 /** The customary invalid zero value. */
75 AUDIOHLPFILETYPE_INVALID = 0,
76 /** Unknown type, do not use. */
77 AUDIOHLPFILETYPE_UNKNOWN,
78 /** Raw (PCM) file. */
79 AUDIOHLPFILETYPE_RAW,
80 /** Wave (.WAV) file. */
81 AUDIOHLPFILETYPE_WAV,
82 /** Hack to blow the type up to 32-bit. */
83 AUDIOHLPFILETYPE_32BIT_HACK = 0x7fffffff
84} AUDIOHLPFILETYPE;
85
86/** @name Audio file (name) helper methods.
87 * @{ */
88int AudioHlpFileNameSanitize(char *pszPath, size_t cbPath);
89int AudioHlpFileNameGet(char *pszFile, size_t cchFile, const char *pszPath, const char *pszName,
90 uint32_t uInstance, AUDIOHLPFILETYPE enmType, uint32_t fFlags);
91/** @} */
92
93/** @name AUDIOHLPFILENAME_FLAGS_XXX
94 * @{ */
95/** No flags defined. */
96#define AUDIOHLPFILENAME_FLAGS_NONE UINT32_C(0)
97/** Adds an ISO timestamp to the file name. */
98#define AUDIOHLPFILENAME_FLAGS_TS RT_BIT(0)
99/** @} */
100
101/**
102 * Audio file handle.
103 */
104typedef struct AUDIOHLPFILE
105{
106 /** Type of the audio file. */
107 AUDIOHLPFILETYPE enmType;
108 /** Audio file flags, AUDIOHLPFILE_FLAGS_XXX. */
109 uint32_t fFlags;
110 /** Actual file handle. */
111 RTFILE hFile;
112 /** Data needed for the specific audio file type implemented.
113 * Optional, can be NULL. */
114 void *pvData;
115 /** Data size (in bytes). */
116 size_t cbData;
117 /** File name and path. */
118 char szName[RTPATH_MAX];
119} AUDIOHLPFILE;
120/** Pointer to an audio file handle. */
121typedef AUDIOHLPFILE *PAUDIOHLPFILE;
122
123/** @name Audio file methods.
124 * @{ */
125int AudioHlpFileCreateAndOpen(PAUDIOHLPFILE *ppFile, const char *pszDir, const char *pszName,
126 uint32_t iInstance, PCPDMAUDIOPCMPROPS pProps);
127int AudioHlpFileCreateAndOpenEx(PAUDIOHLPFILE *ppFile, AUDIOHLPFILETYPE enmType, const char *pszDir, const char *pszName,
128 uint32_t iInstance, uint32_t fFilename, uint32_t fCreate,
129 PCPDMAUDIOPCMPROPS pProps, uint64_t fOpen);
130int AudioHlpFileCreate(AUDIOHLPFILETYPE enmType, const char *pszFile, uint32_t fFlags, PAUDIOHLPFILE *ppFile);
131void AudioHlpFileDestroy(PAUDIOHLPFILE pFile);
132int AudioHlpFileOpen(PAUDIOHLPFILE pFile, uint32_t fOpen, PCPDMAUDIOPCMPROPS pProps);
133int AudioHlpFileClose(PAUDIOHLPFILE pFile);
134int AudioHlpFileDelete(PAUDIOHLPFILE pFile);
135size_t AudioHlpFileGetDataSize(PAUDIOHLPFILE pFile);
136bool AudioHlpFileIsOpen(PAUDIOHLPFILE pFile);
137int AudioHlpFileWrite(PAUDIOHLPFILE pFile, const void *pvBuf, size_t cbBuf, uint32_t fFlags);
138/** @} */
139
140#define AUDIO_MAKE_FOURCC(c0, c1, c2, c3) RT_H2LE_U32_C(RT_MAKE_U32_FROM_U8(c0, c1, c2, c3))
141
142#endif /* !VBOX_INCLUDED_SRC_Audio_AudioHlp_h */
143
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