VirtualBox

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

Last change on this file since 86513 was 82968, checked in by vboxsync, 5 years ago

Copyright year updates by scm.

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