VirtualBox

source: vbox/trunk/src/VBox/Devices/Audio/DevHDA.h@ 71710

Last change on this file since 71710 was 70964, checked in by vboxsync, 7 years ago

Audio/HDA: Implemented separate timers for per audio stream to a) remove a lot of complexity when it comes to synchronizing data when recording and playing back at the same time and b) to make recording a lot smoother while playing back audio.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 9.2 KB
Line 
1/* $Id: DevHDA.h 70964 2018-02-11 21:25:29Z vboxsync $ */
2/** @file
3 * DevHDA.h - VBox Intel HD Audio Controller.
4 */
5
6/*
7 * Copyright (C) 2016-2018 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 DEV_HDA_H
19#define DEV_HDA_H
20
21/*********************************************************************************************************************************
22* Header Files *
23*********************************************************************************************************************************/
24#include <iprt/path.h>
25
26#include <VBox/vmm/pdmdev.h>
27
28#include "AudioMixer.h"
29
30#include "HDACodec.h"
31#include "HDAStream.h"
32#include "HDAStreamMap.h"
33#include "HDAStreamPeriod.h"
34
35
36/*********************************************************************************************************************************
37* Defines *
38*********************************************************************************************************************************/
39
40
41/*********************************************************************************************************************************
42* Structures and Typedefs *
43*********************************************************************************************************************************/
44
45/**
46 * Structure defining an HDA mixer sink.
47 * Its purpose is to know which audio mixer sink is bound to
48 * which SDn (SDI/SDO) device stream.
49 *
50 * This is needed in order to handle interleaved streams
51 * (that is, multiple channels in one stream) or non-interleaved
52 * streams (each channel has a dedicated stream).
53 *
54 * This is only known to the actual device emulation level.
55 */
56typedef struct HDAMIXERSINK
57{
58 R3PTRTYPE(PHDASTREAM) pStream;
59 /** Pointer to the actual audio mixer sink. */
60 R3PTRTYPE(PAUDMIXSINK) pMixSink;
61} HDAMIXERSINK, *PHDAMIXERSINK;
62
63/**
64 * Structure for mapping a stream tag to an HDA stream.
65 */
66typedef struct HDATAG
67{
68 /** Own stream tag. */
69 uint8_t uTag;
70 uint8_t Padding[7];
71 /** Pointer to associated stream. */
72 R3PTRTYPE(PHDASTREAM) pStream;
73} HDATAG, *PHDATAG;
74
75/** @todo Make STAM values out of this? */
76typedef struct HDASTATEDBGINFO
77{
78#ifdef DEBUG
79 /** Timestamp (in ns) of the last timer callback (hdaTimer).
80 * Used to calculate the time actually elapsed between two timer callbacks. */
81 uint64_t tsTimerLastCalledNs;
82 /** IRQ debugging information. */
83 struct
84 {
85 /** Timestamp (in ns) of last processed (asserted / deasserted) IRQ. */
86 uint64_t tsProcessedLastNs;
87 /** Timestamp (in ns) of last asserted IRQ. */
88 uint64_t tsAssertedNs;
89 /** How many IRQs have been asserted already. */
90 uint64_t cAsserted;
91 /** Accumulated elapsed time (in ns) of all IRQ being asserted. */
92 uint64_t tsAssertedTotalNs;
93 /** Timestamp (in ns) of last deasserted IRQ. */
94 uint64_t tsDeassertedNs;
95 /** How many IRQs have been deasserted already. */
96 uint64_t cDeasserted;
97 /** Accumulated elapsed time (in ns) of all IRQ being deasserted. */
98 uint64_t tsDeassertedTotalNs;
99 } IRQ;
100#endif
101 /** Whether debugging is enabled or not. */
102 bool fEnabled;
103 /** Path where to dump the debug output to.
104 * Defaults to VBOX_AUDIO_DEBUG_DUMP_PCM_DATA_PATH. */
105 char szOutPath[RTPATH_MAX + 1];
106} HDASTATEDBGINFO, *PHDASTATEDBGINFO;
107
108/**
109 * ICH Intel HD Audio Controller state.
110 */
111typedef struct HDASTATE
112{
113 /** The PCI device structure. */
114 PDMPCIDEV PciDev;
115 /** R3 Pointer to the device instance. */
116 PPDMDEVINSR3 pDevInsR3;
117 /** R0 Pointer to the device instance. */
118 PPDMDEVINSR0 pDevInsR0;
119 /** R0 Pointer to the device instance. */
120 PPDMDEVINSRC pDevInsRC;
121 /** Padding for alignment. */
122 uint32_t u32Padding;
123 /** Critical section protecting the HDA state. */
124 PDMCRITSECT CritSect;
125 /** The base interface for LUN\#0. */
126 PDMIBASE IBase;
127 RTGCPHYS MMIOBaseAddr;
128 /** The HDA's register set. */
129 uint32_t au32Regs[HDA_NUM_REGS];
130 /** Internal stream states. */
131 HDASTREAM aStreams[HDA_MAX_STREAMS];
132 /** Mapping table between stream tags and stream states. */
133 HDATAG aTags[HDA_MAX_TAGS];
134 /** CORB buffer base address. */
135 uint64_t u64CORBBase;
136 /** RIRB buffer base address. */
137 uint64_t u64RIRBBase;
138 /** DMA base address.
139 * Made out of DPLBASE + DPUBASE (3.3.32 + 3.3.33). */
140 uint64_t u64DPBase;
141 /** Pointer to CORB buffer. */
142 R3PTRTYPE(uint32_t *) pu32CorbBuf;
143 /** Size in bytes of CORB buffer. */
144 uint32_t cbCorbBuf;
145 /** Padding for alignment. */
146 uint32_t u32Padding1;
147 /** Pointer to RIRB buffer. */
148 R3PTRTYPE(uint64_t *) pu64RirbBuf;
149 /** Size in bytes of RIRB buffer. */
150 uint32_t cbRirbBuf;
151 /** DMA position buffer enable bit. */
152 bool fDMAPosition;
153 /** Flag whether the R0 part is enabled. */
154 bool fR0Enabled;
155 /** Flag whether the RC part is enabled. */
156 bool fRCEnabled;
157 /** Number of active (running) SDn streams. */
158 uint8_t cStreamsActive;
159 /** The stream timers for pumping data thru the attached LUN drivers. */
160 PTMTIMERR3 pTimer[HDA_MAX_STREAMS];
161#ifdef VBOX_WITH_STATISTICS
162 STAMPROFILE StatTimer;
163 STAMPROFILE StatIn;
164 STAMPROFILE StatOut;
165 STAMCOUNTER StatBytesRead;
166 STAMCOUNTER StatBytesWritten;
167#endif
168 /** Pointer to HDA codec to use. */
169 R3PTRTYPE(PHDACODEC) pCodec;
170 /** List of associated LUN drivers (HDADRIVER). */
171 RTLISTANCHORR3 lstDrv;
172 /** The device' software mixer. */
173 R3PTRTYPE(PAUDIOMIXER) pMixer;
174 /** HDA sink for (front) output. */
175 HDAMIXERSINK SinkFront;
176#ifdef VBOX_WITH_AUDIO_HDA_51_SURROUND
177 /** HDA sink for center / LFE output. */
178 HDAMIXERSINK SinkCenterLFE;
179 /** HDA sink for rear output. */
180 HDAMIXERSINK SinkRear;
181#endif
182 /** HDA mixer sink for line input. */
183 HDAMIXERSINK SinkLineIn;
184#ifdef VBOX_WITH_AUDIO_HDA_MIC_IN
185 /** Audio mixer sink for microphone input. */
186 HDAMIXERSINK SinkMicIn;
187#endif
188 /** Last updated wall clock (WALCLK) counter. */
189 uint64_t u64WalClk;
190#ifdef VBOX_STRICT
191 /** Wall clock (WALCLK) stale count.
192 * This indicates the number of set wall clock
193 * values which did not actually move the counter forward (stale). */
194 uint8_t u8WalClkStaleCnt;
195 uint8_t au8Padding2[7];
196#endif
197 /** Response Interrupt Count (RINTCNT). */
198 uint16_t u16RespIntCnt;
199 /** Position adjustment (in audio frames).
200 *
201 * This is not an official feature of the HDA specs, but used by
202 * certain OS drivers (e.g. snd_hda_intel) to work around certain
203 * quirks by "real" HDA hardware implementations.
204 *
205 * The position adjustment specifies how many audio frames
206 * a stream is ahead from its actual reading/writing position when
207 * starting a stream.
208 */
209 uint16_t cPosAdjustFrames;
210 /** Whether the position adjustment is enabled or not. */
211 bool fPosAdjustEnabled;
212 uint8_t Padding1[3];
213 /** Current IRQ level. */
214 uint8_t u8IRQL;
215 /** The device timer Hz rate. Defaults to HDA_TIMER_HZ_DEFAULT. */
216 uint16_t u16TimerHz;
217 /** Padding for alignment. */
218 uint8_t au8Padding3[3];
219 HDASTATEDBGINFO Dbg;
220} HDASTATE, *PHDASTATE;
221#endif /* !DEV_HDA_H */
222
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