VirtualBox

source: vbox/trunk/include/VBox/iom.h@ 33185

Last change on this file since 33185 was 30724, checked in by vboxsync, 15 years ago

Recommitted r63480 - VMMDev: Adding an optional (disabled by default) testing side to the device to assist simple guest benchmarks and tests. Started on a MMIO and IOPort benchmark (for comparison with network performance numbers).

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 12.7 KB
Line 
1/** @file
2 * IOM - Input / Output Monitor. (VMM)
3 */
4
5/*
6 * Copyright (C) 2006-2007 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___VBox_iom_h
27#define ___VBox_iom_h
28
29#include <VBox/cdefs.h>
30#include <VBox/types.h>
31#include <VBox/dis.h>
32
33RT_C_DECLS_BEGIN
34
35
36/** @defgroup grp_iom The Input / Ouput Monitor API
37 * @{
38 */
39
40/** @def IOM_NO_PDMINS_CHECKS
41 * Until all devices have been fully adjusted to PDM style, the pPdmIns
42 * parameter is not checked by IOM.
43 * @todo Check this again, now.
44 */
45#define IOM_NO_PDMINS_CHECKS
46
47/**
48 * Macro for checking if an I/O or MMIO emulation call succeeded.
49 *
50 * This macro shall only be used with the IOM APIs where it's mentioned
51 * in the return value description. And there is must be used to correctly
52 * determin if the call succeeded and things like the EIP needs updating.
53 *
54 *
55 * @returns Success indicator (true/false).
56 *
57 * @param rc The status code. This may be evaluated
58 * more than once!
59 *
60 * @remark To avoid making assumptions about the layout of the
61 * VINF_EM_FIRST...VINF_EM_LAST range we're checking
62 * explicitly for each for exach the exceptions.
63 * However, for efficieny we ASSUME that the
64 * VINF_EM_LAST is smaller than most of the relevant
65 * status codes. We also ASSUME that the
66 * VINF_EM_RESCHEDULE_REM status code is the most
67 * frequent status code we'll enounter in this range.
68 *
69 * @todo Will have to add VINF_EM_DBG_HYPER_BREAKPOINT if the
70 * I/O port and MMIO breakpoints should trigger before
71 * the I/O is done. Currently, we don't implement these
72 * kind of breakpoints.
73 */
74#define IOM_SUCCESS(rc) ( (rc) == VINF_SUCCESS \
75 || ( (rc) <= VINF_EM_LAST \
76 && (rc) != VINF_EM_RESCHEDULE_REM \
77 && (rc) >= VINF_EM_FIRST \
78 && (rc) != VINF_EM_RESCHEDULE_RAW \
79 && (rc) != VINF_EM_RESCHEDULE_HWACC \
80 ) \
81 )
82
83
84/**
85 * Port I/O Handler for IN operations.
86 *
87 * @returns VINF_SUCCESS or VINF_EM_*.
88 * @returns VERR_IOM_IOPORT_UNUSED if the port is really unused and a ~0 value should be returned.
89 *
90 * @param pDevIns The device instance.
91 * @param pvUser User argument.
92 * @param uPort Port number used for the IN operation.
93 * @param pu32 Where to store the result. This is always a 32-bit
94 * variable regardless of what @a cb might say.
95 * @param cb Number of bytes read.
96 */
97typedef DECLCALLBACK(int) FNIOMIOPORTIN(PPDMDEVINS pDevIns, void *pvUser, RTIOPORT Port, uint32_t *pu32, unsigned cb);
98/** Pointer to a FNIOMIOPORTIN(). */
99typedef FNIOMIOPORTIN *PFNIOMIOPORTIN;
100
101/**
102 * Port I/O Handler for string IN operations.
103 *
104 * @returns VINF_SUCCESS or VINF_EM_*.
105 * @returns VERR_IOM_IOPORT_UNUSED if the port is really unused and a ~0 value should be returned.
106 *
107 * @param pDevIns The device instance.
108 * @param pvUser User argument.
109 * @param uPort Port number used for the IN operation.
110 * @param pGCPtrDst Pointer to the destination buffer (GC, incremented appropriately).
111 * @param pcTransfers Pointer to the number of transfer units to read, on return remaining transfer units.
112 * @param cb Size of the transfer unit (1, 2 or 4 bytes).
113 */
114typedef DECLCALLBACK(int) FNIOMIOPORTINSTRING(PPDMDEVINS pDevIns, void *pvUser, RTIOPORT Port, RTGCPTR *pGCPtrDst, PRTGCUINTREG pcTransfers, unsigned cb);
115/** Pointer to a FNIOMIOPORTINSTRING(). */
116typedef FNIOMIOPORTINSTRING *PFNIOMIOPORTINSTRING;
117
118/**
119 * Port I/O Handler for OUT operations.
120 *
121 * @returns VINF_SUCCESS or VINF_EM_*.
122 *
123 * @param pDevIns The device instance.
124 * @param pvUser User argument.
125 * @param uPort Port number used for the OUT operation.
126 * @param u32 The value to output.
127 * @param cb The value size in bytes.
128 */
129typedef DECLCALLBACK(int) FNIOMIOPORTOUT(PPDMDEVINS pDevIns, void *pvUser, RTIOPORT Port, uint32_t u32, unsigned cb);
130/** Pointer to a FNIOMIOPORTOUT(). */
131typedef FNIOMIOPORTOUT *PFNIOMIOPORTOUT;
132
133/**
134 * Port I/O Handler for string OUT operations.
135 *
136 * @returns VINF_SUCCESS or VINF_EM_*.
137 *
138 * @param pDevIns The device instance.
139 * @param pvUser User argument.
140 * @param uPort Port number used for the OUT operation.
141 * @param pGCPtrSrc Pointer to the source buffer (GC, incremented appropriately).
142 * @param pcTransfers Pointer to the number of transfer units to write, on return remaining transfer units.
143 * @param cb Size of the transfer unit (1, 2 or 4 bytes).
144 */
145typedef DECLCALLBACK(int) FNIOMIOPORTOUTSTRING(PPDMDEVINS pDevIns, void *pvUser, RTIOPORT Port, RTGCPTR *pGCPtrSrc, PRTGCUINTREG pcTransfers, unsigned cb);
146/** Pointer to a FNIOMIOPORTOUTSTRING(). */
147typedef FNIOMIOPORTOUTSTRING *PFNIOMIOPORTOUTSTRING;
148
149
150/**
151 * Memory mapped I/O Handler for read operations.
152 *
153 * @returns VBox status code.
154 *
155 * @param pDevIns The device instance.
156 * @param pvUser User argument.
157 * @param GCPhysAddr Physical address (in GC) where the read starts.
158 * @param pv Where to store the result.
159 * @param cb Number of bytes read.
160 *
161 * @remark wonder if we could merge the IOMMMIO* and IOMPORT* callbacks...
162 */
163typedef DECLCALLBACK(int) FNIOMMMIOREAD(PPDMDEVINS pDevIns, void *pvUser, RTGCPHYS GCPhysAddr, void *pv, unsigned cb);
164/** Pointer to a FNIOMMMIOREAD(). */
165typedef FNIOMMMIOREAD *PFNIOMMMIOREAD;
166
167/**
168 * Port I/O Handler for write operations.
169 *
170 * @returns VBox status code.
171 *
172 * @param pDevIns The device instance.
173 * @param pvUser User argument.
174 * @param GCPhysAddr Physical address (in GC) where the read starts.
175 * @param pv Where to fetch the result.
176 * @param cb Number of bytes to write.
177 *
178 * @remark wonder if we could merge the IOMMMIO* and IOMPORT* callbacks...
179 */
180typedef DECLCALLBACK(int) FNIOMMMIOWRITE(PPDMDEVINS pDevIns, void *pvUser, RTGCPHYS GCPhysAddr, void *pv, unsigned cb);
181/** Pointer to a FNIOMMMIOWRITE(). */
182typedef FNIOMMMIOWRITE *PFNIOMMMIOWRITE;
183
184/**
185 * Port I/O Handler for memset operations, actually for REP STOS* instructions handling.
186 *
187 * @returns VBox status code.
188 *
189 * @param pDevIns The device instance.
190 * @param pvUser User argument.
191 * @param GCPhysAddr Physical address (in GC) where the write starts.
192 * @param u32Item Byte/Word/Dword data to fill.
193 * @param cbItem Size of data in u32Item parameter, restricted to 1/2/4 bytes.
194 * @param cItems Number of iterations.
195 */
196typedef DECLCALLBACK(int) FNIOMMMIOFILL(PPDMDEVINS pDevIns, void *pvUser, RTGCPHYS GCPhysAddr, uint32_t u32Item, unsigned cbItem, unsigned cItems);
197/** Pointer to a FNIOMMMIOFILL(). */
198typedef FNIOMMMIOFILL *PFNIOMMMIOFILL;
199
200VMMDECL(VBOXSTRICTRC) IOMIOPortRead(PVM pVM, RTIOPORT Port, uint32_t *pu32Value, size_t cbValue);
201VMMDECL(VBOXSTRICTRC) IOMIOPortWrite(PVM pVM, RTIOPORT Port, uint32_t u32Value, size_t cbValue);
202VMMDECL(VBOXSTRICTRC) IOMInterpretOUT(PVM pVM, PCPUMCTXCORE pRegFrame, PDISCPUSTATE pCpu);
203VMMDECL(VBOXSTRICTRC) IOMInterpretIN(PVM pVM, PCPUMCTXCORE pRegFrame, PDISCPUSTATE pCpu);
204VMMDECL(VBOXSTRICTRC) IOMIOPortReadString(PVM pVM, RTIOPORT Port, PRTGCPTR pGCPtrDst, PRTGCUINTREG pcTransfers, unsigned cb);
205VMMDECL(VBOXSTRICTRC) IOMIOPortWriteString(PVM pVM, RTIOPORT Port, PRTGCPTR pGCPtrSrc, PRTGCUINTREG pcTransfers, unsigned cb);
206VMMDECL(VBOXSTRICTRC) IOMInterpretINS(PVM pVM, PCPUMCTXCORE pRegFrame, PDISCPUSTATE pCpu);
207VMMDECL(VBOXSTRICTRC) IOMInterpretINSEx(PVM pVM, PCPUMCTXCORE pRegFrame, uint32_t uPort, uint32_t uPrefix, uint32_t cbTransfer);
208VMMDECL(VBOXSTRICTRC) IOMInterpretOUTS(PVM pVM, PCPUMCTXCORE pRegFrame, PDISCPUSTATE pCpu);
209VMMDECL(VBOXSTRICTRC) IOMInterpretOUTSEx(PVM pVM, PCPUMCTXCORE pRegFrame, uint32_t uPort, uint32_t uPrefix, uint32_t cbTransfer);
210VMMDECL(VBOXSTRICTRC) IOMMMIORead(PVM pVM, RTGCPHYS GCPhys, uint32_t *pu32Value, size_t cbValue);
211VMMDECL(VBOXSTRICTRC) IOMMMIOWrite(PVM pVM, RTGCPHYS GCPhys, uint32_t u32Value, size_t cbValue);
212VMMDECL(VBOXSTRICTRC) IOMMMIOPhysHandler(PVM pVM, RTGCUINT uErrorCode, PCPUMCTXCORE pCtxCore, RTGCPHYS GCPhysFault);
213VMMDECL(VBOXSTRICTRC) IOMInterpretCheckPortIOAccess(PVM pVM, PCPUMCTXCORE pCtxCore, RTIOPORT Port, unsigned cb);
214VMMDECL(int) IOMMMIOMapMMIO2Page(PVM pVM, RTGCPHYS GCPhys, RTGCPHYS GCPhysRemapped, uint64_t fPageFlags);
215VMMDECL(int) IOMMMIOMapMMIOHCPage(PVM pVM, RTGCPHYS GCPhys, RTHCPHYS HCPhys, uint64_t fPageFlags);
216VMMDECL(int) IOMMMIOResetRegion(PVM pVM, RTGCPHYS GCPhys);
217VMMDECL(bool) IOMIsLockOwner(PVM pVM);
218
219#ifdef IN_RC
220/** @defgroup grp_iom_gc The IOM Guest Context API
221 * @ingroup grp_iom
222 * @{
223 */
224VMMRCDECL(VBOXSTRICTRC) IOMGCIOPortHandler(PVM pVM, PCPUMCTXCORE pRegFrame, PDISCPUSTATE pCpu);
225/** @} */
226#endif /* IN_RC */
227
228
229
230#ifdef IN_RING3
231/** @defgroup grp_iom_r3 The IOM Host Context Ring-3 API
232 * @ingroup grp_iom
233 * @{
234 */
235VMMR3DECL(int) IOMR3Init(PVM pVM);
236VMMR3DECL(void) IOMR3Reset(PVM pVM);
237VMMR3DECL(void) IOMR3Relocate(PVM pVM, RTGCINTPTR offDelta);
238VMMR3DECL(int) IOMR3Term(PVM pVM);
239VMMR3DECL(int) IOMR3IOPortRegisterR3(PVM pVM, PPDMDEVINS pDevIns, RTIOPORT PortStart, RTUINT cPorts, RTHCPTR pvUser,
240 R3PTRTYPE(PFNIOMIOPORTOUT) pfnOutCallback, R3PTRTYPE(PFNIOMIOPORTIN) pfnInCallback,
241 R3PTRTYPE(PFNIOMIOPORTOUTSTRING) pfnOutStringCallback, R3PTRTYPE(PFNIOMIOPORTINSTRING) pfnInStringCallback,
242 const char *pszDesc);
243VMMR3DECL(int) IOMR3IOPortRegisterRC(PVM pVM, PPDMDEVINS pDevIns, RTIOPORT PortStart, RTUINT cPorts, RTRCPTR pvUser,
244 RCPTRTYPE(PFNIOMIOPORTOUT) pfnOutCallback, RCPTRTYPE(PFNIOMIOPORTIN) pfnInCallback,
245 RCPTRTYPE(PFNIOMIOPORTOUTSTRING) pfnOutStrCallback, RCPTRTYPE(PFNIOMIOPORTINSTRING) pfnInStrCallback,
246 const char *pszDesc);
247VMMR3DECL(int) IOMR3IOPortRegisterR0(PVM pVM, PPDMDEVINS pDevIns, RTIOPORT PortStart, RTUINT cPorts, RTR0PTR pvUser,
248 R0PTRTYPE(PFNIOMIOPORTOUT) pfnOutCallback, R0PTRTYPE(PFNIOMIOPORTIN) pfnInCallback,
249 R0PTRTYPE(PFNIOMIOPORTOUTSTRING) pfnOutStrCallback, R0PTRTYPE(PFNIOMIOPORTINSTRING) pfnInStrCallback,
250 const char *pszDesc);
251VMMR3DECL(int) IOMR3IOPortDeregister(PVM pVM, PPDMDEVINS pDevIns, RTIOPORT PortStart, RTUINT cPorts);
252
253VMMR3DECL(int) IOMR3MMIORegisterR3(PVM pVM, PPDMDEVINS pDevIns, RTGCPHYS GCPhysStart, RTUINT cbRange, RTHCPTR pvUser,
254 R3PTRTYPE(PFNIOMMMIOWRITE) pfnWriteCallback,
255 R3PTRTYPE(PFNIOMMMIOREAD) pfnReadCallback,
256 R3PTRTYPE(PFNIOMMMIOFILL) pfnFillCallback, const char *pszDesc);
257VMMR3DECL(int) IOMR3MMIORegisterR0(PVM pVM, PPDMDEVINS pDevIns, RTGCPHYS GCPhysStart, RTUINT cbRange, RTR0PTR pvUser,
258 R0PTRTYPE(PFNIOMMMIOWRITE) pfnWriteCallback,
259 R0PTRTYPE(PFNIOMMMIOREAD) pfnReadCallback,
260 R0PTRTYPE(PFNIOMMMIOFILL) pfnFillCallback);
261VMMR3DECL(int) IOMR3MMIORegisterRC(PVM pVM, PPDMDEVINS pDevIns, RTGCPHYS GCPhysStart, RTUINT cbRange, RTGCPTR pvUser,
262 RCPTRTYPE(PFNIOMMMIOWRITE) pfnWriteCallback,
263 RCPTRTYPE(PFNIOMMMIOREAD) pfnReadCallback,
264 RCPTRTYPE(PFNIOMMMIOFILL) pfnFillCallback);
265VMMR3DECL(int) IOMR3MMIODeregister(PVM pVM, PPDMDEVINS pDevIns, RTGCPHYS GCPhysStart, RTUINT cbRange);
266
267VMMR3DECL(PPDMCRITSECT) IOMR3GetCritSect(PVM pVM);
268
269/** @} */
270#endif /* IN_RING3 */
271
272
273/** @} */
274
275RT_C_DECLS_END
276
277#endif
278
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