VirtualBox

source: vbox/trunk/src/VBox/VMM/include/IOMInline.h@ 38838

Last change on this file since 38838 was 37467, checked in by vboxsync, 14 years ago

IOM: Clean up locking now that all devices has its own CS.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.6 KB
Line 
1/* $Id: IOMInline.h 37467 2011-06-15 13:08:45Z vboxsync $ */
2/** @file
3 * IOM - Inlined functions.
4 */
5
6/*
7 * Copyright (C) 2006-2011 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 ___IOMInline_h
19#define ___IOMInline_h
20
21/** @addtogroup grp_iom_int Internals
22 * @internal
23 * @{
24 */
25
26/**
27 * Gets the I/O port range for the specified I/O port in the current context.
28 *
29 * @returns Pointer to I/O port range.
30 * @returns NULL if no port registered.
31 *
32 * @param pVM The VM handle.
33 * @param Port The I/O port lookup.
34 */
35DECLINLINE(CTX_SUFF(PIOMIOPORTRANGE)) iomIOPortGetRange(PVM pVM, RTIOPORT Port)
36{
37 Assert(PDMCritSectIsOwner(&pVM->iom.s.CritSect));
38 return (CTX_SUFF(PIOMIOPORTRANGE))RTAvlroIOPortRangeGet(&pVM->iom.s.CTX_SUFF(pTrees)->CTX_SUFF(IOPortTree), Port);
39}
40
41
42/**
43 * Gets the I/O port range for the specified I/O port in the HC.
44 *
45 * @returns Pointer to I/O port range.
46 * @returns NULL if no port registered.
47 *
48 * @param pVM The VM handle.
49 * @param Port The I/O port to lookup.
50 */
51DECLINLINE(PIOMIOPORTRANGER3) iomIOPortGetRangeR3(PVM pVM, RTIOPORT Port)
52{
53 Assert(PDMCritSectIsOwner(&pVM->iom.s.CritSect));
54 return (PIOMIOPORTRANGER3)RTAvlroIOPortRangeGet(&pVM->iom.s.CTX_SUFF(pTrees)->IOPortTreeR3, Port);
55}
56
57
58/**
59 * Gets the MMIO range for the specified physical address in the current context.
60 *
61 * @returns Pointer to MMIO range.
62 * @returns NULL if address not in a MMIO range.
63 *
64 * @param pVM The VM handle.
65 * @param GCPhys Physical address to lookup.
66 */
67DECLINLINE(PIOMMMIORANGE) iomMmioGetRange(PVM pVM, RTGCPHYS GCPhys)
68{
69 Assert(PDMCritSectIsOwner(&pVM->iom.s.CritSect));
70 PIOMMMIORANGE pRange = pVM->iom.s.CTX_SUFF(pMMIORangeLast);
71 if ( !pRange
72 || GCPhys - pRange->GCPhys >= pRange->cb)
73 pVM->iom.s.CTX_SUFF(pMMIORangeLast) = pRange
74 = (PIOMMMIORANGE)RTAvlroGCPhysRangeGet(&pVM->iom.s.CTX_SUFF(pTrees)->MMIOTree, GCPhys);
75 return pRange;
76}
77
78/**
79 * Retain a MMIO range.
80 *
81 * @param pRange The range to release.
82 */
83DECLINLINE(void) iomMmioRetainRange(PIOMMMIORANGE pRange)
84{
85 uint32_t cRefs = ASMAtomicIncU32(&pRange->cRefs);
86 Assert(cRefs > 1);
87 Assert(cRefs < _1M);
88}
89
90
91/**
92 * Gets the referenced MMIO range for the specified physical address in the
93 * current context.
94 *
95 * @returns Pointer to MMIO range.
96 * @returns NULL if address not in a MMIO range.
97 *
98 * @param pVM The VM handle.
99 * @param GCPhys Physical address to lookup.
100 */
101DECLINLINE(PIOMMMIORANGE) iomMmioGetRangeWithRef(PVM pVM, RTGCPHYS GCPhys)
102{
103 int rc = PDMCritSectEnter(&pVM->iom.s.CritSect, VINF_SUCCESS);
104 AssertRCReturn(rc, NULL);
105
106 PIOMMMIORANGE pRange = pVM->iom.s.CTX_SUFF(pMMIORangeLast);
107 if ( !pRange
108 || GCPhys - pRange->GCPhys >= pRange->cb)
109 pVM->iom.s.CTX_SUFF(pMMIORangeLast) = pRange
110 = (PIOMMMIORANGE)RTAvlroGCPhysRangeGet(&pVM->iom.s.CTX_SUFF(pTrees)->MMIOTree, GCPhys);
111 if (pRange)
112 iomMmioRetainRange(pRange);
113
114 PDMCritSectLeave(&pVM->iom.s.CritSect);
115 return pRange;
116}
117
118
119/**
120 * Releases a MMIO range.
121 *
122 * @param pVM The VM handle.
123 * @param pRange The range to release.
124 */
125DECLINLINE(void) iomMmioReleaseRange(PVM pVM, PIOMMMIORANGE pRange)
126{
127 uint32_t cRefs = ASMAtomicDecU32(&pRange->cRefs);
128 if (!cRefs)
129 iomMmioFreeRange(pVM, pRange);
130}
131
132
133#ifdef VBOX_STRICT
134/**
135 * Gets the MMIO range for the specified physical address in the current context.
136 *
137 * @returns Pointer to MMIO range.
138 * @returns NULL if address not in a MMIO range.
139 *
140 * @param pVM The VM handle.
141 * @param GCPhys Physical address to lookup.
142 */
143DECLINLINE(PIOMMMIORANGE) iomMMIOGetRangeUnsafe(PVM pVM, RTGCPHYS GCPhys)
144{
145 PIOMMMIORANGE pRange = pVM->iom.s.CTX_SUFF(pMMIORangeLast);
146 if ( !pRange
147 || GCPhys - pRange->GCPhys >= pRange->cb)
148 pVM->iom.s.CTX_SUFF(pMMIORangeLast) = pRange
149 = (PIOMMMIORANGE)RTAvlroGCPhysRangeGet(&pVM->iom.s.CTX_SUFF(pTrees)->MMIOTree, GCPhys);
150 return pRange;
151}
152#endif /* VBOX_STRICT */
153
154
155#ifdef VBOX_WITH_STATISTICS
156/**
157 * Gets the MMIO statistics record.
158 *
159 * In ring-3 this will lazily create missing records, while in GC/R0 the caller has to
160 * return the appropriate status to defer the operation to ring-3.
161 *
162 * @returns Pointer to MMIO stats.
163 * @returns NULL if not found (R0/GC), or out of memory (R3).
164 *
165 * @param pVM The VM handle.
166 * @param GCPhys Physical address to lookup.
167 * @param pRange The MMIO range.
168 */
169DECLINLINE(PIOMMMIOSTATS) iomMmioGetStats(PVM pVM, RTGCPHYS GCPhys, PIOMMMIORANGE pRange)
170{
171 PDMCritSectEnter(&pVM->iom.s.CritSect, VINF_SUCCESS);
172
173 /* For large ranges, we'll put everything on the first byte. */
174 if (pRange->cb > PAGE_SIZE)
175 GCPhys = pRange->GCPhys;
176
177 PIOMMMIOSTATS pStats = pVM->iom.s.CTX_SUFF(pMMIOStatsLast);
178 if ( !pStats
179 || pStats->Core.Key != GCPhys)
180 {
181 pStats = (PIOMMMIOSTATS)RTAvloGCPhysGet(&pVM->iom.s.CTX_SUFF(pTrees)->MmioStatTree, GCPhys);
182# ifdef IN_RING3
183 if (!pStats)
184 pStats = iomR3MMIOStatsCreate(pVM, GCPhys, pRange->pszDesc);
185# endif
186 }
187
188 PDMCritSectLeave(&pVM->iom.s.CritSect);
189 return pStats;
190}
191#endif /* VBOX_WITH_STATISTICS */
192
193
194/** @} */
195
196#endif
197
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