VirtualBox

source: vbox/trunk/src/VBox/VMM/DBGFAddr.cpp@ 19167

Last change on this file since 19167 was 18927, checked in by vboxsync, 16 years ago

Big step to separate VMM data structures for guest SMP. (pgm, em)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 5.0 KB
Line 
1/* $Id: DBGFAddr.cpp 18927 2009-04-16 11:41:38Z vboxsync $ */
2/** @file
3 * DBGF - Debugger Facility, Mixed Address Methods.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22
23/*******************************************************************************
24* Header Files *
25*******************************************************************************/
26#define LOG_GROUP LOG_GROUP_DBGF
27#include <VBox/dbgf.h>
28#include <VBox/selm.h>
29#include "DBGFInternal.h"
30#include <VBox/vm.h>
31#include <VBox/mm.h>
32#include <VBox/err.h>
33#include <VBox/log.h>
34
35
36
37/**
38 * Checks if an address is in the HMA or not.
39 * @returns true if it's inside the HMA.
40 * @returns flase if it's not inside the HMA.
41 * @param pVM The VM handle.
42 * @param FlatPtr The address in question.
43 */
44DECLINLINE(bool) dbgfR3IsHMA(PVM pVM, RTGCUINTPTR FlatPtr)
45{
46 return MMHyperIsInsideArea(pVM, FlatPtr);
47}
48
49
50/**
51 * Creates a mixed address from a Sel:off pair.
52 *
53 * @returns VBox status code.
54 * @param pVM The VM handle.
55 * @param pAddress Where to store the mixed address.
56 * @param Sel The selector part.
57 * @param off The offset part.
58 */
59VMMR3DECL(int) DBGFR3AddrFromSelOff(PVM pVM, PDBGFADDRESS pAddress, RTSEL Sel, RTUINTPTR off)
60{
61 pAddress->Sel = Sel;
62 pAddress->off = off;
63 if (Sel != DBGF_SEL_FLAT)
64 {
65 /* @todo SMP support!! */
66 PVMCPU pVCpu = &pVM->aCpus[0];
67
68 SELMSELINFO SelInfo;
69 int rc = SELMR3GetSelectorInfo(pVM, pVCpu, Sel, &SelInfo);
70 if (RT_FAILURE(rc))
71 return rc;
72
73 /* check limit. */
74 if (SELMSelInfoIsExpandDown(&SelInfo))
75 {
76 if ( !SelInfo.Raw.Gen.u1Granularity
77 && off > UINT32_C(0xffff))
78 return VERR_OUT_OF_SELECTOR_BOUNDS;
79 if (off <= SelInfo.cbLimit)
80 return VERR_OUT_OF_SELECTOR_BOUNDS;
81 }
82 else if (off > SelInfo.cbLimit)
83 return VERR_OUT_OF_SELECTOR_BOUNDS;
84
85 pAddress->FlatPtr = SelInfo.GCPtrBase + off;
86 /** @todo fix this flat selector test! */
87 if ( !SelInfo.GCPtrBase
88 && SelInfo.Raw.Gen.u1Granularity
89 && SelInfo.Raw.Gen.u1DefBig)
90 pAddress->fFlags = DBGFADDRESS_FLAGS_FLAT;
91 else if (SelInfo.cbLimit <= UINT32_C(0xffff))
92 pAddress->fFlags = DBGFADDRESS_FLAGS_FAR16;
93 else if (SelInfo.cbLimit <= UINT32_C(0xffffffff))
94 pAddress->fFlags = DBGFADDRESS_FLAGS_FAR32;
95 else
96 pAddress->fFlags = DBGFADDRESS_FLAGS_FAR64;
97 }
98 else
99 {
100 pAddress->FlatPtr = off;
101 pAddress->fFlags = DBGFADDRESS_FLAGS_FLAT;
102 }
103 pAddress->fFlags |= DBGFADDRESS_FLAGS_VALID;
104 if (dbgfR3IsHMA(pVM, pAddress->FlatPtr))
105 pAddress->fFlags |= DBGFADDRESS_FLAGS_HMA;
106
107 return VINF_SUCCESS;
108}
109
110
111/**
112 * Creates a mixed address from a flat address.
113 *
114 * @param pVM The VM handle.
115 * @param pAddress Where to store the mixed address.
116 * @param FlatPtr The flat pointer.
117 */
118VMMR3DECL(PDBGFADDRESS) DBGFR3AddrFromFlat(PVM pVM, PDBGFADDRESS pAddress, RTGCUINTPTR FlatPtr)
119{
120 pAddress->Sel = DBGF_SEL_FLAT;
121 pAddress->off = FlatPtr;
122 pAddress->FlatPtr = FlatPtr;
123 pAddress->fFlags = DBGFADDRESS_FLAGS_FLAT | DBGFADDRESS_FLAGS_VALID;
124 if (dbgfR3IsHMA(pVM, pAddress->FlatPtr))
125 pAddress->fFlags |= DBGFADDRESS_FLAGS_HMA;
126 return pAddress;
127}
128
129
130/**
131 * Creates a mixed address from a guest physical address.
132 *
133 * @param pVM The VM handle.
134 * @param pAddress Where to store the mixed address.
135 * @param PhysAddr The guest physical address.
136 */
137VMMR3DECL(void) DBGFR3AddrFromPhys(PVM pVM, PDBGFADDRESS pAddress, RTGCPHYS PhysAddr)
138{
139 pAddress->Sel = DBGF_SEL_FLAT;
140 pAddress->off = PhysAddr;
141 pAddress->FlatPtr = PhysAddr;
142 pAddress->fFlags = DBGFADDRESS_FLAGS_PHYS | DBGFADDRESS_FLAGS_VALID;
143}
144
145
146/**
147 * Checks if the specified address is valid (checks the structure pointer too).
148 *
149 * @returns true if valid.
150 * @returns false if invalid.
151 * @param pVM The VM handle.
152 * @param pAddress The address to validate.
153 */
154VMMR3DECL(bool) DBGFR3AddrIsValid(PVM pVM, PCDBGFADDRESS pAddress)
155{
156 if (!VALID_PTR(pAddress))
157 return false;
158 if (!DBGFADDRESS_IS_VALID(pAddress))
159 return false;
160 /* more? */
161 return true;
162}
163
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