VirtualBox

source: vbox/trunk/src/VBox/VMM/VMMAll/MMAll.cpp@ 93705

Last change on this file since 93705 was 93629, checked in by vboxsync, 3 years ago

VMM/MMHyper: Removed unused code. [build fix] bugref:10093

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 8.1 KB
Line 
1/* $Id: MMAll.cpp 93629 2022-02-06 23:45:44Z vboxsync $ */
2/** @file
3 * MM - Memory Manager - Any Context.
4 */
5
6/*
7 * Copyright (C) 2006-2022 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
19/*********************************************************************************************************************************
20* Header Files *
21*********************************************************************************************************************************/
22#define LOG_GROUP LOG_GROUP_MM_HYPER
23#include <VBox/vmm/mm.h>
24#include <VBox/vmm/vmm.h>
25#include "MMInternal.h"
26#include <VBox/vmm/vmcc.h>
27#include <VBox/vmm/hm.h>
28#include <VBox/log.h>
29#include <iprt/assert.h>
30#include <iprt/string.h>
31
32
33
34/**
35 * Lookup a host context ring-3 address.
36 *
37 * @returns Pointer to the corresponding lookup record.
38 * @returns NULL on failure.
39 * @param pVM The cross context VM structure.
40 * @param R3Ptr The host context ring-3 address to lookup.
41 * @param poff Where to store the offset into the HMA memory chunk.
42 */
43DECLINLINE(PMMLOOKUPHYPER) mmHyperLookupR3(PVM pVM, RTR3PTR R3Ptr, uint32_t *poff)
44{
45 /** @todo cache last lookup, this stuff ain't cheap! */
46 PMMLOOKUPHYPER pLookup = (PMMLOOKUPHYPER)((uint8_t *)pVM->mm.s.CTX_SUFF(pHyperHeap) + pVM->mm.s.offLookupHyper);
47 for (;;)
48 {
49 switch (pLookup->enmType)
50 {
51 case MMLOOKUPHYPERTYPE_LOCKED:
52 {
53 const RTR3UINTPTR off = (RTR3UINTPTR)R3Ptr - (RTR3UINTPTR)pLookup->u.Locked.pvR3;
54 if (off < pLookup->cb)
55 {
56 *poff = off;
57 return pLookup;
58 }
59 break;
60 }
61
62 case MMLOOKUPHYPERTYPE_HCPHYS:
63 {
64 const RTR3UINTPTR off = (RTR3UINTPTR)R3Ptr - (RTR3UINTPTR)pLookup->u.HCPhys.pvR3;
65 if (off < pLookup->cb)
66 {
67 *poff = off;
68 return pLookup;
69 }
70 break;
71 }
72
73 case MMLOOKUPHYPERTYPE_GCPHYS: /* (for now we'll not allow these kind of conversions) */
74 case MMLOOKUPHYPERTYPE_MMIO2:
75 case MMLOOKUPHYPERTYPE_DYNAMIC:
76 break;
77
78 default:
79 AssertMsgFailed(("enmType=%d\n", pLookup->enmType));
80 break;
81 }
82
83 /* next */
84 if (pLookup->offNext == (int32_t)NIL_OFFSET)
85 break;
86 pLookup = (PMMLOOKUPHYPER)((uint8_t *)pLookup + pLookup->offNext);
87 }
88
89 AssertMsgFailed(("R3Ptr=%RHv is not inside the hypervisor memory area!\n", R3Ptr));
90 return NULL;
91}
92
93
94/**
95 * Calculate the host context ring-0 address of an offset into the HMA memory chunk.
96 *
97 * @returns the host context ring-0 address.
98 * @param pVM The cross context VM structure.
99 * @param pLookup The HMA lookup record.
100 * @param off The offset into the HMA memory chunk.
101 */
102DECLINLINE(RTR0PTR) mmHyperLookupCalcR0(PVM pVM, PMMLOOKUPHYPER pLookup, uint32_t off)
103{
104 switch (pLookup->enmType)
105 {
106 case MMLOOKUPHYPERTYPE_LOCKED:
107 if (pLookup->u.Locked.pvR0)
108 return (RTR0PTR)((RTR0UINTPTR)pLookup->u.Locked.pvR0 + off);
109#ifdef IN_RING3
110 AssertMsg(SUPR3IsDriverless(), ("%s\n", R3STRING(pLookup->pszDesc)));
111#else
112 AssertMsgFailed(("%s\n", R3STRING(pLookup->pszDesc)));
113#endif
114 NOREF(pVM);
115 return NIL_RTR0PTR;
116
117 case MMLOOKUPHYPERTYPE_HCPHYS:
118 if (pLookup->u.HCPhys.pvR0)
119 return (RTR0PTR)((RTR0UINTPTR)pLookup->u.HCPhys.pvR0 + off);
120#ifdef IN_RING3
121 AssertMsg(SUPR3IsDriverless(), ("%s\n", R3STRING(pLookup->pszDesc)));
122#else
123 AssertMsgFailed(("%s\n", R3STRING(pLookup->pszDesc)));
124#endif
125 return NIL_RTR0PTR;
126
127 default:
128 AssertMsgFailed(("enmType=%d\n", pLookup->enmType));
129 return NIL_RTR0PTR;
130 }
131}
132
133
134/**
135 * Converts a ring-3 host context address in the Hypervisor memory region to a ring-0 host context address.
136 *
137 * @returns ring-0 host context address.
138 * @param pVM The cross context VM structure.
139 * @param R3Ptr The ring-3 host context address.
140 * You'll be damned if this is not in the HMA! :-)
141 * @thread The Emulation Thread.
142 */
143VMMDECL(RTR0PTR) MMHyperR3ToR0(PVM pVM, RTR3PTR R3Ptr)
144{
145 uint32_t off;
146 PMMLOOKUPHYPER pLookup = mmHyperLookupR3(pVM, R3Ptr, &off);
147 if (pLookup)
148 return mmHyperLookupCalcR0(pVM, pLookup, off);
149 AssertMsgFailed(("R3Ptr=%p is not inside the hypervisor memory area!\n", R3Ptr));
150 return NIL_RTR0PTR;
151}
152
153
154#ifdef IN_RING0
155/**
156 * Converts a ring-3 host context address in the Hypervisor memory region to a current context address.
157 *
158 * @returns current context address.
159 * @param pVM The cross context VM structure.
160 * @param R3Ptr The ring-3 host context address.
161 * You'll be damned if this is not in the HMA! :-)
162 * @thread The Emulation Thread.
163 */
164VMMDECL(void *) MMHyperR3ToCC(PVM pVM, RTR3PTR R3Ptr)
165{
166 uint32_t off;
167 PMMLOOKUPHYPER pLookup = mmHyperLookupR3(pVM, R3Ptr, &off);
168 if (pLookup)
169 return mmHyperLookupCalcR0(pVM, pLookup, off);
170 return NULL;
171}
172#endif
173
174
175/**
176 * Gets the string name of a memory tag.
177 *
178 * @returns name of enmTag.
179 * @param enmTag The tag.
180 */
181const char *mmGetTagName(MMTAG enmTag)
182{
183 switch (enmTag)
184 {
185 #define TAG2STR(tag) case MM_TAG_##tag: return #tag
186
187 TAG2STR(CFGM);
188 TAG2STR(CFGM_BYTES);
189 TAG2STR(CFGM_STRING);
190 TAG2STR(CFGM_USER);
191
192 TAG2STR(CPUM_CTX);
193 TAG2STR(CPUM_CPUID);
194 TAG2STR(CPUM_MSRS);
195
196 TAG2STR(CSAM);
197 TAG2STR(CSAM_PATCH);
198
199 TAG2STR(DBGF);
200 TAG2STR(DBGF_AS);
201 TAG2STR(DBGF_FLOWTRACE);
202 TAG2STR(DBGF_INFO);
203 TAG2STR(DBGF_LINE);
204 TAG2STR(DBGF_LINE_DUP);
205 TAG2STR(DBGF_MODULE);
206 TAG2STR(DBGF_OS);
207 TAG2STR(DBGF_REG);
208 TAG2STR(DBGF_STACK);
209 TAG2STR(DBGF_SYMBOL);
210 TAG2STR(DBGF_SYMBOL_DUP);
211 TAG2STR(DBGF_TYPE);
212 TAG2STR(DBGF_TRACER);
213
214 TAG2STR(EM);
215
216 TAG2STR(IEM);
217
218 TAG2STR(IOM);
219 TAG2STR(IOM_STATS);
220
221 TAG2STR(MM);
222 TAG2STR(MM_LOOKUP_GUEST);
223 TAG2STR(MM_LOOKUP_PHYS);
224 TAG2STR(MM_LOOKUP_VIRT);
225 TAG2STR(MM_PAGE);
226
227 TAG2STR(PARAV);
228
229 TAG2STR(PATM);
230 TAG2STR(PATM_PATCH);
231
232 TAG2STR(PDM);
233 TAG2STR(PDM_DEVICE);
234 TAG2STR(PDM_DEVICE_DESC);
235 TAG2STR(PDM_DEVICE_USER);
236 TAG2STR(PDM_DRIVER);
237 TAG2STR(PDM_DRIVER_DESC);
238 TAG2STR(PDM_DRIVER_USER);
239 TAG2STR(PDM_USB);
240 TAG2STR(PDM_USB_DESC);
241 TAG2STR(PDM_USB_USER);
242 TAG2STR(PDM_LUN);
243 TAG2STR(PDM_QUEUE);
244 TAG2STR(PDM_THREAD);
245 TAG2STR(PDM_ASYNC_COMPLETION);
246#ifdef VBOX_WITH_NETSHAPER
247 TAG2STR(PDM_NET_SHAPER);
248#endif /* VBOX_WITH_NETSHAPER */
249
250 TAG2STR(PGM);
251 TAG2STR(PGM_CHUNK_MAPPING);
252 TAG2STR(PGM_HANDLERS);
253 TAG2STR(PGM_HANDLER_TYPES);
254 TAG2STR(PGM_MAPPINGS);
255 TAG2STR(PGM_PHYS);
256 TAG2STR(PGM_POOL);
257
258 TAG2STR(REM);
259
260 TAG2STR(SELM);
261
262 TAG2STR(SSM);
263
264 TAG2STR(STAM);
265
266 TAG2STR(TM);
267
268 TAG2STR(TRPM);
269
270 TAG2STR(VM);
271 TAG2STR(VM_REQ);
272
273 TAG2STR(VMM);
274
275 TAG2STR(HM);
276
277 #undef TAG2STR
278
279 default:
280 {
281 AssertMsgFailed(("Unknown tag %d! forgot to add it to the switch?\n", enmTag));
282#ifdef IN_RING3
283 static char sz[48];
284 RTStrPrintf(sz, sizeof(sz), "%d", enmTag);
285 return sz;
286#else
287 return "unknown tag!";
288#endif
289 }
290 }
291}
292
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