VirtualBox

source: vbox/trunk/src/VBox/Devices/Audio/HDAStreamPeriod.h@ 74098

Last change on this file since 74098 was 71754, checked in by vboxsync, 7 years ago

DevHDA: Alignment fixing.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.4 KB
Line 
1/* $Id: HDAStreamPeriod.h 71754 2018-04-09 01:27:04Z vboxsync $ */
2/** @file
3 * HDAStreamPeriod.h - Stream period functions for HD Audio.
4 */
5
6/*
7 * Copyright (C) 2017 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 HDA_STREAMPERIOD_H
19#define HDA_STREAMPERIOD_H
20
21#include <iprt/critsect.h>
22#ifdef DEBUG
23# include <iprt/time.h>
24#endif
25#include <VBox/log.h> /* LOG_ENABLED */
26
27struct HDASTREAM;
28typedef HDASTREAM *PHDASTREAM;
29
30#ifdef LOG_ENABLED
31/**
32 * Structure for debug information of an HDA stream's period.
33 */
34typedef struct HDASTREAMPERIODDBGINFO
35{
36 /** Host start time (in ns) of the period. */
37 uint64_t tsStartNs;
38} HDASTREAMPERIODDBGINFO, *PHDASTREAMPERIODDBGINFO;
39#endif
40
41/** No flags set. */
42#define HDASTREAMPERIOD_FLAG_NONE 0
43/** The stream period has been initialized and is in a valid state. */
44#define HDASTREAMPERIOD_FLAG_VALID RT_BIT(0)
45/** The stream period is active. */
46#define HDASTREAMPERIOD_FLAG_ACTIVE RT_BIT(1)
47
48/**
49 * Structure for keeping an HDA stream's (time) period.
50 * This is needed in order to keep track of stream timing and interrupt delivery.
51 */
52typedef struct HDASTREAMPERIOD
53{
54 /** Critical section for serializing access. */
55 RTCRITSECT CritSect;
56 /** Associated HDA stream descriptor (SD) number. */
57 uint8_t u8SD;
58 /** The period's status flags. */
59 uint8_t fStatus;
60 /** Number of pending interrupts required for this period. */
61 uint8_t cIntPending;
62 uint8_t bPadding0;
63 /** Hertz (Hz) rate this period runs with. */
64 uint32_t u32Hz;
65 /** Period start time (in wall clock counts). */
66 uint64_t u64StartWalClk;
67 /** Period duration (in wall clock counts). */
68 uint64_t u64DurationWalClk;
69 /** The period's (relative) elapsed time (in wall clock counts). */
70 uint64_t u64ElapsedWalClk;
71 /** Delay (in wall clock counts) for tweaking the period timing. Optional. */
72 int64_t i64DelayWalClk;
73 /** Number of audio frames to transfer for this period. */
74 uint32_t framesToTransfer;
75 /** Number of audio frames already transfered. */
76 uint32_t framesTransferred;
77#ifdef LOG_ENABLED
78 /** Debugging information. */
79 HDASTREAMPERIODDBGINFO Dbg;
80#endif
81} HDASTREAMPERIOD;
82AssertCompileSizeAlignment(HDASTREAMPERIOD, 8);
83/** Pointer to a HDA stream's time period keeper. */
84typedef HDASTREAMPERIOD *PHDASTREAMPERIOD;
85
86#ifdef IN_RING3
87int hdaR3StreamPeriodCreate(PHDASTREAMPERIOD pPeriod);
88void hdaR3StreamPeriodDestroy(PHDASTREAMPERIOD pPeriod);
89int hdaR3StreamPeriodInit(PHDASTREAMPERIOD pPeriod, uint8_t u8SD, uint16_t u16LVI, uint32_t u32CBL, PPDMAUDIOSTREAMCFG pStreamCfg);
90void hdaR3StreamPeriodReset(PHDASTREAMPERIOD pPeriod);
91int hdaR3StreamPeriodBegin(PHDASTREAMPERIOD pPeriod, uint64_t u64WalClk);
92void hdaR3StreamPeriodEnd(PHDASTREAMPERIOD pPeriod);
93void hdaR3StreamPeriodPause(PHDASTREAMPERIOD pPeriod);
94void hdaR3StreamPeriodResume(PHDASTREAMPERIOD pPeriod);
95bool hdaR3StreamPeriodLock(PHDASTREAMPERIOD pPeriod);
96void hdaR3StreamPeriodUnlock(PHDASTREAMPERIOD pPeriod);
97uint64_t hdaR3StreamPeriodFramesToWalClk(PHDASTREAMPERIOD pPeriod, uint32_t uFrames);
98uint64_t hdaR3StreamPeriodGetAbsEndWalClk(PHDASTREAMPERIOD pPeriod);
99uint64_t hdaR3StreamPeriodGetAbsElapsedWalClk(PHDASTREAMPERIOD pPeriod);
100uint32_t hdaR3StreamPeriodGetRemainingFrames(PHDASTREAMPERIOD pPeriod);
101bool hdaR3StreamPeriodHasElapsed(PHDASTREAMPERIOD pPeriod);
102bool hdaR3StreamPeriodHasPassedAbsWalClk(PHDASTREAMPERIOD pPeriod, uint64_t u64WalClk);
103bool hdaR3StreamPeriodNeedsInterrupt(PHDASTREAMPERIOD pPeriod);
104void hdaR3StreamPeriodAcquireInterrupt(PHDASTREAMPERIOD pPeriod);
105void hdaR3StreamPeriodReleaseInterrupt(PHDASTREAMPERIOD pPeriod);
106void hdaR3StreamPeriodInc(PHDASTREAMPERIOD pPeriod, uint32_t framesInc);
107bool hdaR3StreamPeriodIsComplete(PHDASTREAMPERIOD pPeriod);
108#endif /* IN_RING3 */
109
110#endif /* !HDA_STREAMPERIOD_H */
111
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