VirtualBox

source: vbox/trunk/include/VBox/vmm/dbgf.h@ 35361

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

fix OSE

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 50.6 KB
Line 
1/** @file
2 * DBGF - Debugger Facility.
3 */
4
5/*
6 * Copyright (C) 2006-2010 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_vmm_dbgf_h
27#define ___VBox_vmm_dbgf_h
28
29#include <VBox/types.h>
30#include <VBox/log.h> /* LOG_ENABLED */
31#include <VBox/vmm/vmm.h>
32#include <VBox/vmm/dbgfsel.h>
33
34#include <iprt/stdarg.h>
35#include <iprt/dbg.h>
36
37RT_C_DECLS_BEGIN
38
39
40/** @defgroup grp_dbgf The Debugger Facility API
41 * @{
42 */
43
44#if defined(IN_RC) || defined(IN_RING0)
45/** @addgroup grp_dbgf_rz The RZ DBGF API
46 * @ingroup grp_dbgf
47 * @{
48 */
49VMMRZDECL(int) DBGFRZTrap01Handler(PVM pVM, PVMCPU pVCpu, PCPUMCTXCORE pRegFrame, RTGCUINTREG uDr6);
50VMMRZDECL(int) DBGFRZTrap03Handler(PVM pVM, PVMCPU pVCpu, PCPUMCTXCORE pRegFrame);
51/** @} */
52#endif
53
54
55
56/**
57 * Mixed address.
58 */
59typedef struct DBGFADDRESS
60{
61 /** The flat address. */
62 RTGCUINTPTR FlatPtr;
63 /** The selector offset address. */
64 RTGCUINTPTR off;
65 /** The selector. DBGF_SEL_FLAT is a legal value. */
66 RTSEL Sel;
67 /** Flags describing further details about the address. */
68 uint16_t fFlags;
69} DBGFADDRESS;
70/** Pointer to a mixed address. */
71typedef DBGFADDRESS *PDBGFADDRESS;
72/** Pointer to a const mixed address. */
73typedef const DBGFADDRESS *PCDBGFADDRESS;
74
75/** @name DBGFADDRESS Flags.
76 * @{ */
77/** A 16:16 far address. */
78#define DBGFADDRESS_FLAGS_FAR16 0
79/** A 16:32 far address. */
80#define DBGFADDRESS_FLAGS_FAR32 1
81/** A 16:64 far address. */
82#define DBGFADDRESS_FLAGS_FAR64 2
83/** A flat address. */
84#define DBGFADDRESS_FLAGS_FLAT 3
85/** A physical address. */
86#define DBGFADDRESS_FLAGS_PHYS 4
87/** A physical address. */
88#define DBGFADDRESS_FLAGS_RING0 5
89/** The address type mask. */
90#define DBGFADDRESS_FLAGS_TYPE_MASK 7
91
92/** Set if the address is valid. */
93#define DBGFADDRESS_FLAGS_VALID RT_BIT(3)
94
95/** The address is within the hypervisor memoary area (HMA).
96 * If not set, the address can be assumed to be a guest address. */
97#define DBGFADDRESS_FLAGS_HMA RT_BIT(4)
98
99/** Checks if the mixed address is flat or not. */
100#define DBGFADDRESS_IS_FLAT(pAddress) ( ((pAddress)->fFlags & DBGFADDRESS_FLAGS_TYPE_MASK) == DBGFADDRESS_FLAGS_FLAT )
101/** Checks if the mixed address is flat or not. */
102#define DBGFADDRESS_IS_PHYS(pAddress) ( ((pAddress)->fFlags & DBGFADDRESS_FLAGS_TYPE_MASK) == DBGFADDRESS_FLAGS_PHYS )
103/** Checks if the mixed address is far 16:16 or not. */
104#define DBGFADDRESS_IS_FAR16(pAddress) ( ((pAddress)->fFlags & DBGFADDRESS_FLAGS_TYPE_MASK) == DBGFADDRESS_FLAGS_FAR16 )
105/** Checks if the mixed address is far 16:32 or not. */
106#define DBGFADDRESS_IS_FAR32(pAddress) ( ((pAddress)->fFlags & DBGFADDRESS_FLAGS_TYPE_MASK) == DBGFADDRESS_FLAGS_FAR32 )
107/** Checks if the mixed address is far 16:64 or not. */
108#define DBGFADDRESS_IS_FAR64(pAddress) ( ((pAddress)->fFlags & DBGFADDRESS_FLAGS_TYPE_MASK) == DBGFADDRESS_FLAGS_FAR64 )
109/** Checks if the mixed address is valid. */
110#define DBGFADDRESS_IS_VALID(pAddress) ( !!((pAddress)->fFlags & DBGFADDRESS_FLAGS_VALID) )
111/** Checks if the address is flagged as within the HMA. */
112#define DBGFADDRESS_IS_HMA(pAddress) ( !!((pAddress)->fFlags & DBGFADDRESS_FLAGS_HMA) )
113/** @} */
114
115VMMR3DECL(int) DBGFR3AddrFromSelOff(PVM pVM, VMCPUID idCpu, PDBGFADDRESS pAddress, RTSEL Sel, RTUINTPTR off);
116VMMR3DECL(int) DBGFR3AddrFromSelInfoOff(PVM pVM, PDBGFADDRESS pAddress, PCDBGFSELINFO pSelInfo, RTUINTPTR off);
117VMMR3DECL(PDBGFADDRESS) DBGFR3AddrFromFlat(PVM pVM, PDBGFADDRESS pAddress, RTGCUINTPTR FlatPtr);
118VMMR3DECL(PDBGFADDRESS) DBGFR3AddrFromPhys(PVM pVM, PDBGFADDRESS pAddress, RTGCPHYS PhysAddr);
119VMMR3DECL(bool) DBGFR3AddrIsValid(PVM pVM, PCDBGFADDRESS pAddress);
120VMMR3DECL(int) DBGFR3AddrToPhys(PVM pVM, VMCPUID idCpu, PDBGFADDRESS pAddress, PRTGCPHYS pGCPhys);
121VMMR3DECL(int) DBGFR3AddrToHostPhys(PVM pVM, VMCPUID idCpu, PDBGFADDRESS pAddress, PRTHCPHYS pHCPhys);
122VMMR3DECL(int) DBGFR3AddrToVolatileR3Ptr(PVM pVM, VMCPUID idCpu, PDBGFADDRESS pAddress, bool fReadOnly, void **ppvR3Ptr);
123VMMR3DECL(PDBGFADDRESS) DBGFR3AddrAdd(PDBGFADDRESS pAddress, RTGCUINTPTR uAddend);
124VMMR3DECL(PDBGFADDRESS) DBGFR3AddrSub(PDBGFADDRESS pAddress, RTGCUINTPTR uSubtrahend);
125
126
127
128
129/**
130 * VMM Debug Event Type.
131 */
132typedef enum DBGFEVENTTYPE
133{
134 /** Halt completed.
135 * This notifies that a halt command have been successfully completed.
136 */
137 DBGFEVENT_HALT_DONE = 0,
138 /** Detach completed.
139 * This notifies that the detach command have been successfully completed.
140 */
141 DBGFEVENT_DETACH_DONE,
142 /** The command from the debugger is not recognized.
143 * This means internal error or half implemented features.
144 */
145 DBGFEVENT_INVALID_COMMAND,
146
147
148 /** Fatal error.
149 * This notifies a fatal error in the VMM and that the debugger get's a
150 * chance to first hand information about the the problem.
151 */
152 DBGFEVENT_FATAL_ERROR = 100,
153 /** Breakpoint Hit.
154 * This notifies that a breakpoint installed by the debugger was hit. The
155 * identifier of the breakpoint can be found in the DBGFEVENT::u::Bp::iBp member.
156 */
157 DBGFEVENT_BREAKPOINT,
158 /** Breakpoint Hit in the Hypervisor.
159 * This notifies that a breakpoint installed by the debugger was hit. The
160 * identifier of the breakpoint can be found in the DBGFEVENT::u::Bp::iBp member.
161 */
162 DBGFEVENT_BREAKPOINT_HYPER,
163 /** Assertion in the Hypervisor (breakpoint instruction).
164 * This notifies that a breakpoint instruction was hit in the hypervisor context.
165 */
166 DBGFEVENT_ASSERTION_HYPER,
167 /** Single Stepped.
168 * This notifies that a single step operation was completed.
169 */
170 DBGFEVENT_STEPPED,
171 /** Single Stepped.
172 * This notifies that a hypervisor single step operation was completed.
173 */
174 DBGFEVENT_STEPPED_HYPER,
175 /** The developer have used the DBGFSTOP macro or the PDMDeviceDBGFSTOP function
176 * to bring up the debugger at a specific place.
177 */
178 DBGFEVENT_DEV_STOP,
179 /** The VM is terminating.
180 * When this notification is received, the debugger thread should detach ASAP.
181 */
182 DBGFEVENT_TERMINATING,
183
184 /** The usual 32-bit hack. */
185 DBGFEVENT_32BIT_HACK = 0x7fffffff
186} DBGFEVENTTYPE;
187
188
189/**
190 * The context of an event.
191 */
192typedef enum DBGFEVENTCTX
193{
194 /** The usual invalid entry. */
195 DBGFEVENTCTX_INVALID = 0,
196 /** Raw mode. */
197 DBGFEVENTCTX_RAW,
198 /** Recompiled mode. */
199 DBGFEVENTCTX_REM,
200 /** VMX / AVT mode. */
201 DBGFEVENTCTX_HWACCL,
202 /** Hypervisor context. */
203 DBGFEVENTCTX_HYPER,
204 /** Other mode */
205 DBGFEVENTCTX_OTHER,
206
207 /** The usual 32-bit hack */
208 DBGFEVENTCTX_32BIT_HACK = 0x7fffffff
209} DBGFEVENTCTX;
210
211/**
212 * VMM Debug Event.
213 */
214typedef struct DBGFEVENT
215{
216 /** Type. */
217 DBGFEVENTTYPE enmType;
218 /** Context */
219 DBGFEVENTCTX enmCtx;
220 /** Type specific data. */
221 union
222 {
223 /** Fatal error details. */
224 struct
225 {
226 /** The GC return code. */
227 int rc;
228 } FatalError;
229
230 /** Source location. */
231 struct
232 {
233 /** File name. */
234 R3PTRTYPE(const char *) pszFile;
235 /** Function name. */
236 R3PTRTYPE(const char *) pszFunction;
237 /** Message. */
238 R3PTRTYPE(const char *) pszMessage;
239 /** Line number. */
240 unsigned uLine;
241 } Src;
242
243 /** Assertion messages. */
244 struct
245 {
246 /** The first message. */
247 R3PTRTYPE(const char *) pszMsg1;
248 /** The second message. */
249 R3PTRTYPE(const char *) pszMsg2;
250 } Assert;
251
252 /** Breakpoint. */
253 struct DBGFEVENTBP
254 {
255 /** The identifier of the breakpoint which was hit. */
256 RTUINT iBp;
257 } Bp;
258 /** Padding for ensuring that the structure is 8 byte aligned. */
259 uint64_t au64Padding[4];
260 } u;
261} DBGFEVENT;
262/** Pointer to VMM Debug Event. */
263typedef DBGFEVENT *PDBGFEVENT;
264/** Pointer to const VMM Debug Event. */
265typedef const DBGFEVENT *PCDBGFEVENT;
266
267
268/** @def DBGFSTOP
269 * Stops the debugger raising a DBGFEVENT_DEVELOPER_STOP event.
270 *
271 * @returns VBox status code which must be propagated up to EM if not VINF_SUCCESS.
272 * @param pVM VM Handle.
273 */
274#ifdef VBOX_STRICT
275# define DBGFSTOP(pVM) DBGFR3EventSrc(pVM, DBGFEVENT_DEV_STOP, __FILE__, __LINE__, __PRETTY_FUNCTION__, NULL)
276#else
277# define DBGFSTOP(pVM) VINF_SUCCESS
278#endif
279
280VMMR3DECL(int) DBGFR3Init(PVM pVM);
281VMMR3DECL(int) DBGFR3Term(PVM pVM);
282VMMR3DECL(void) DBGFR3Relocate(PVM pVM, RTGCINTPTR offDelta);
283VMMR3DECL(int) DBGFR3VMMForcedAction(PVM pVM);
284VMMR3DECL(int) DBGFR3Event(PVM pVM, DBGFEVENTTYPE enmEvent);
285VMMR3DECL(int) DBGFR3EventSrc(PVM pVM, DBGFEVENTTYPE enmEvent, const char *pszFile, unsigned uLine, const char *pszFunction, const char *pszFormat, ...);
286VMMR3DECL(int) DBGFR3EventSrcV(PVM pVM, DBGFEVENTTYPE enmEvent, const char *pszFile, unsigned uLine, const char *pszFunction, const char *pszFormat, va_list args);
287VMMR3DECL(int) DBGFR3EventAssertion(PVM pVM, DBGFEVENTTYPE enmEvent, const char *pszMsg1, const char *pszMsg2);
288VMMR3DECL(int) DBGFR3EventBreakpoint(PVM pVM, DBGFEVENTTYPE enmEvent);
289VMMR3DECL(int) DBGFR3Attach(PVM pVM);
290VMMR3DECL(int) DBGFR3Detach(PVM pVM);
291VMMR3DECL(int) DBGFR3EventWait(PVM pVM, RTMSINTERVAL cMillies, PCDBGFEVENT *ppEvent);
292VMMR3DECL(int) DBGFR3Halt(PVM pVM);
293VMMR3DECL(bool) DBGFR3IsHalted(PVM pVM);
294VMMR3DECL(bool) DBGFR3CanWait(PVM pVM);
295VMMR3DECL(int) DBGFR3Resume(PVM pVM);
296VMMR3DECL(int) DBGFR3Step(PVM pVM, VMCPUID idCpu);
297VMMR3DECL(int) DBGFR3PrgStep(PVMCPU pVCpu);
298
299
300/** Breakpoint type. */
301typedef enum DBGFBPTYPE
302{
303 /** Free breakpoint entry. */
304 DBGFBPTYPE_FREE = 0,
305 /** Debug register. */
306 DBGFBPTYPE_REG,
307 /** INT 3 instruction. */
308 DBGFBPTYPE_INT3,
309 /** Recompiler. */
310 DBGFBPTYPE_REM,
311 /** ensure 32-bit size. */
312 DBGFBPTYPE_32BIT_HACK = 0x7fffffff
313} DBGFBPTYPE;
314
315
316/**
317 * A Breakpoint.
318 */
319typedef struct DBGFBP
320{
321 /** The number of breakpoint hits. */
322 uint64_t cHits;
323 /** The hit number which starts to trigger the breakpoint. */
324 uint64_t iHitTrigger;
325 /** The hit number which stops triggering the breakpoint (disables it).
326 * Use ~(uint64_t)0 if it should never stop. */
327 uint64_t iHitDisable;
328 /** The Flat GC address of the breakpoint.
329 * (PC register value if REM type?) */
330 RTGCUINTPTR GCPtr;
331 /** The breakpoint id. */
332 RTUINT iBp;
333 /** The breakpoint status - enabled or disabled. */
334 bool fEnabled;
335
336 /** The breakpoint type. */
337 DBGFBPTYPE enmType;
338
339#if GC_ARCH_BITS == 64
340 uint32_t u32Padding;
341#endif
342
343 /** Union of type specific data. */
344 union
345 {
346 /** Debug register data. */
347 struct DBGFBPREG
348 {
349 /** The debug register number. */
350 uint8_t iReg;
351 /** The access type (one of the X86_DR7_RW_* value). */
352 uint8_t fType;
353 /** The access size. */
354 uint8_t cb;
355 } Reg;
356 /** Recompiler breakpoint data. */
357 struct DBGFBPINT3
358 {
359 /** The byte value we replaced by the INT 3 instruction. */
360 uint8_t bOrg;
361 } Int3;
362
363 /** Recompiler breakpoint data. */
364 struct DBGFBPREM
365 {
366 /** nothing yet */
367 uint8_t fDummy;
368 } Rem;
369 /** Paddind to ensure that the size is identical on win32 and linux. */
370 uint64_t u64Padding;
371 } u;
372} DBGFBP;
373
374/** Pointer to a breakpoint. */
375typedef DBGFBP *PDBGFBP;
376/** Pointer to a const breakpoint. */
377typedef const DBGFBP *PCDBGFBP;
378
379
380VMMR3DECL(int) DBGFR3BpSet(PVM pVM, PCDBGFADDRESS pAddress, uint64_t iHitTrigger, uint64_t iHitDisable, PRTUINT piBp);
381VMMR3DECL(int) DBGFR3BpSetReg(PVM pVM, PCDBGFADDRESS pAddress, uint64_t iHitTrigger, uint64_t iHitDisable,
382 uint8_t fType, uint8_t cb, PRTUINT piBp);
383VMMR3DECL(int) DBGFR3BpSetREM(PVM pVM, PCDBGFADDRESS pAddress, uint64_t iHitTrigger, uint64_t iHitDisable, PRTUINT piBp);
384VMMR3DECL(int) DBGFR3BpClear(PVM pVM, RTUINT iBp);
385VMMR3DECL(int) DBGFR3BpEnable(PVM pVM, RTUINT iBp);
386VMMR3DECL(int) DBGFR3BpDisable(PVM pVM, RTUINT iBp);
387
388/**
389 * Breakpoint enumeration callback function.
390 *
391 * @returns VBox status code. Any failure will stop the enumeration.
392 * @param pVM The VM handle.
393 * @param pvUser The user argument.
394 * @param pBp Pointer to the breakpoint information. (readonly)
395 */
396typedef DECLCALLBACK(int) FNDBGFBPENUM(PVM pVM, void *pvUser, PCDBGFBP pBp);
397/** Pointer to a breakpoint enumeration callback function. */
398typedef FNDBGFBPENUM *PFNDBGFBPENUM;
399
400VMMR3DECL(int) DBGFR3BpEnum(PVM pVM, PFNDBGFBPENUM pfnCallback, void *pvUser);
401VMMDECL(RTGCUINTREG) DBGFBpGetDR7(PVM pVM);
402VMMDECL(RTGCUINTREG) DBGFBpGetDR0(PVM pVM);
403VMMDECL(RTGCUINTREG) DBGFBpGetDR1(PVM pVM);
404VMMDECL(RTGCUINTREG) DBGFBpGetDR2(PVM pVM);
405VMMDECL(RTGCUINTREG) DBGFBpGetDR3(PVM pVM);
406VMMDECL(bool) DBGFIsStepping(PVMCPU pVCpu);
407
408
409
410VMMR3DECL(CPUMMODE) DBGFR3CpuGetMode(PVM pVM, VMCPUID idCpu);
411
412
413
414
415/**
416 * Info helper callback structure.
417 */
418typedef struct DBGFINFOHLP
419{
420 /**
421 * Print formatted string.
422 *
423 * @param pHlp Pointer to this structure.
424 * @param pszFormat The format string.
425 * @param ... Arguments.
426 */
427 DECLCALLBACKMEMBER(void, pfnPrintf)(PCDBGFINFOHLP pHlp, const char *pszFormat, ...);
428
429 /**
430 * Print formatted string.
431 *
432 * @param pHlp Pointer to this structure.
433 * @param pszFormat The format string.
434 * @param args Argument list.
435 */
436 DECLCALLBACKMEMBER(void, pfnPrintfV)(PCDBGFINFOHLP pHlp, const char *pszFormat, va_list args);
437} DBGFINFOHLP;
438
439
440/**
441 * Info handler, device version.
442 *
443 * @param pDevIns The device instance which registered the info.
444 * @param pHlp Callback functions for doing output.
445 * @param pszArgs Argument string. Optional and specific to the handler.
446 */
447typedef DECLCALLBACK(void) FNDBGFHANDLERDEV(PPDMDEVINS pDevIns, PCDBGFINFOHLP pHlp, const char *pszArgs);
448/** Pointer to a FNDBGFHANDLERDEV function. */
449typedef FNDBGFHANDLERDEV *PFNDBGFHANDLERDEV;
450
451/**
452 * Info handler, USB device version.
453 *
454 * @param pUsbIns The USB device instance which registered the info.
455 * @param pHlp Callback functions for doing output.
456 * @param pszArgs Argument string. Optional and specific to the handler.
457 */
458typedef DECLCALLBACK(void) FNDBGFHANDLERUSB(PPDMUSBINS pUsbIns, PCDBGFINFOHLP pHlp, const char *pszArgs);
459/** Pointer to a FNDBGFHANDLERUSB function. */
460typedef FNDBGFHANDLERUSB *PFNDBGFHANDLERUSB;
461
462/**
463 * Info handler, driver version.
464 *
465 * @param pDrvIns The driver instance which registered the info.
466 * @param pHlp Callback functions for doing output.
467 * @param pszArgs Argument string. Optional and specific to the handler.
468 */
469typedef DECLCALLBACK(void) FNDBGFHANDLERDRV(PPDMDRVINS pDrvIns, PCDBGFINFOHLP pHlp, const char *pszArgs);
470/** Pointer to a FNDBGFHANDLERDRV function. */
471typedef FNDBGFHANDLERDRV *PFNDBGFHANDLERDRV;
472
473/**
474 * Info handler, internal version.
475 *
476 * @param pVM The VM handle.
477 * @param pHlp Callback functions for doing output.
478 * @param pszArgs Argument string. Optional and specific to the handler.
479 */
480typedef DECLCALLBACK(void) FNDBGFHANDLERINT(PVM pVM, PCDBGFINFOHLP pHlp, const char *pszArgs);
481/** Pointer to a FNDBGFHANDLERINT function. */
482typedef FNDBGFHANDLERINT *PFNDBGFHANDLERINT;
483
484/**
485 * Info handler, external version.
486 *
487 * @param pvUser User argument.
488 * @param pHlp Callback functions for doing output.
489 * @param pszArgs Argument string. Optional and specific to the handler.
490 */
491typedef DECLCALLBACK(void) FNDBGFHANDLEREXT(void *pvUser, PCDBGFINFOHLP pHlp, const char *pszArgs);
492/** Pointer to a FNDBGFHANDLEREXT function. */
493typedef FNDBGFHANDLEREXT *PFNDBGFHANDLEREXT;
494
495
496/** @name Flags for the info registration functions.
497 * @{ */
498/** The handler must run on the EMT. */
499#define DBGFINFO_FLAGS_RUN_ON_EMT RT_BIT(0)
500/** @} */
501
502VMMR3DECL(int) DBGFR3InfoRegisterDevice(PVM pVM, const char *pszName, const char *pszDesc, PFNDBGFHANDLERDEV pfnHandler, PPDMDEVINS pDevIns);
503VMMR3DECL(int) DBGFR3InfoRegisterDriver(PVM pVM, const char *pszName, const char *pszDesc, PFNDBGFHANDLERDRV pfnHandler, PPDMDRVINS pDrvIns);
504VMMR3DECL(int) DBGFR3InfoRegisterInternal(PVM pVM, const char *pszName, const char *pszDesc, PFNDBGFHANDLERINT pfnHandler);
505VMMR3DECL(int) DBGFR3InfoRegisterInternalEx(PVM pVM, const char *pszName, const char *pszDesc, PFNDBGFHANDLERINT pfnHandler, uint32_t fFlags);
506VMMR3DECL(int) DBGFR3InfoRegisterExternal(PVM pVM, const char *pszName, const char *pszDesc, PFNDBGFHANDLEREXT pfnHandler, void *pvUser);
507VMMR3DECL(int) DBGFR3InfoDeregisterDevice(PVM pVM, PPDMDEVINS pDevIns, const char *pszName);
508VMMR3DECL(int) DBGFR3InfoDeregisterDriver(PVM pVM, PPDMDRVINS pDrvIns, const char *pszName);
509VMMR3DECL(int) DBGFR3InfoDeregisterInternal(PVM pVM, const char *pszName);
510VMMR3DECL(int) DBGFR3InfoDeregisterExternal(PVM pVM, const char *pszName);
511VMMR3DECL(int) DBGFR3Info(PVM pVM, const char *pszName, const char *pszArgs, PCDBGFINFOHLP pHlp);
512VMMR3DECL(int) DBGFR3InfoLogRel(PVM pVM, const char *pszName, const char *pszArgs);
513VMMR3DECL(int) DBGFR3InfoStdErr(PVM pVM, const char *pszName, const char *pszArgs);
514VMMR3DECL(int) DBGFR3InfoMulti(PVM pVM, const char *pszIncludePat, const char *pszExcludePat,
515 const char *pszSepFmt, PCDBGFINFOHLP pHlp);
516
517/** @def DBGFR3InfoLog
518 * Display a piece of info writing to the log if enabled.
519 *
520 * @param pVM VM handle.
521 * @param pszName The identifier of the info to display.
522 * @param pszArgs Arguments to the info handler.
523 */
524#ifdef LOG_ENABLED
525#define DBGFR3InfoLog(pVM, pszName, pszArgs) \
526 do { \
527 if (LogIsEnabled()) \
528 DBGFR3Info(pVM, pszName, pszArgs, NULL); \
529 } while (0)
530#else
531#define DBGFR3InfoLog(pVM, pszName, pszArgs) do { } while (0)
532#endif
533
534/**
535 * Enumeration callback for use with DBGFR3InfoEnum.
536 *
537 * @returns VBox status code.
538 * A status code indicating failure will end the enumeration
539 * and DBGFR3InfoEnum will return with that status code.
540 * @param pVM VM handle.
541 * @param pszName Info identifier name.
542 * @param pszDesc The description.
543 */
544typedef DECLCALLBACK(int) FNDBGFINFOENUM(PVM pVM, const char *pszName, const char *pszDesc, void *pvUser);
545/** Pointer to a FNDBGFINFOENUM function. */
546typedef FNDBGFINFOENUM *PFNDBGFINFOENUM;
547
548VMMR3DECL(int) DBGFR3InfoEnum(PVM pVM, PFNDBGFINFOENUM pfnCallback, void *pvUser);
549VMMR3DECL(PCDBGFINFOHLP) DBGFR3InfoLogHlp(void);
550VMMR3DECL(PCDBGFINFOHLP) DBGFR3InfoLogRelHlp(void);
551
552
553
554VMMR3DECL(int) DBGFR3LogModifyGroups(PVM pVM, const char *pszGroupSettings);
555VMMR3DECL(int) DBGFR3LogModifyFlags(PVM pVM, const char *pszFlagSettings);
556VMMR3DECL(int) DBGFR3LogModifyDestinations(PVM pVM, const char *pszDestSettings);
557
558
559
560/** Max length (including '\\0') of a symbol name. */
561#define DBGF_SYMBOL_NAME_LENGTH 512
562
563/**
564 * Debug symbol.
565 */
566typedef struct DBGFSYMBOL
567{
568 /** Symbol value (address). */
569 RTGCUINTPTR Value;
570 /** Symbol size. */
571 uint32_t cb;
572 /** Symbol Flags. (reserved). */
573 uint32_t fFlags;
574 /** Symbol name. */
575 char szName[DBGF_SYMBOL_NAME_LENGTH];
576} DBGFSYMBOL;
577/** Pointer to debug symbol. */
578typedef DBGFSYMBOL *PDBGFSYMBOL;
579/** Pointer to const debug symbol. */
580typedef const DBGFSYMBOL *PCDBGFSYMBOL;
581
582/**
583 * Debug line number information.
584 */
585typedef struct DBGFLINE
586{
587 /** Address. */
588 RTGCUINTPTR Address;
589 /** Line number. */
590 uint32_t uLineNo;
591 /** Filename. */
592 char szFilename[260];
593} DBGFLINE;
594/** Pointer to debug line number. */
595typedef DBGFLINE *PDBGFLINE;
596/** Pointer to const debug line number. */
597typedef const DBGFLINE *PCDBGFLINE;
598
599/** @name Address spaces aliases.
600 * @{ */
601/** The guest global address space. */
602#define DBGF_AS_GLOBAL ((RTDBGAS)-1)
603/** The guest kernel address space.
604 * This is usually resolves to the same as DBGF_AS_GLOBAL. */
605#define DBGF_AS_KERNEL ((RTDBGAS)-2)
606/** The physical address space. */
607#define DBGF_AS_PHYS ((RTDBGAS)-3)
608/** Raw-mode context. */
609#define DBGF_AS_RC ((RTDBGAS)-4)
610/** Ring-0 context. */
611#define DBGF_AS_R0 ((RTDBGAS)-5)
612/** Raw-mode context and then global guest context.
613 * When used for looking up information, it works as if the call was first made
614 * with DBGF_AS_RC and then on failure with DBGF_AS_GLOBAL. When called for
615 * making address space changes, it works as if DBGF_AS_RC was used. */
616#define DBGF_AS_RC_AND_GC_GLOBAL ((RTDBGAS)-6)
617
618/** The first special one. */
619#define DBGF_AS_FIRST DBGF_AS_RC_AND_GC_GLOBAL
620/** The last special one. */
621#define DBGF_AS_LAST DBGF_AS_GLOBAL
622/** The number of special address space handles. */
623#define DBGF_AS_COUNT (6U)
624/** Converts an alias handle to an array index. */
625#define DBGF_AS_ALIAS_2_INDEX(hAlias) \
626 ( (uintptr_t)(hAlias) - (uintptr_t)DBGF_AS_FIRST )
627/** Predicat macro that check if the specified handle is an alias. */
628#define DBGF_AS_IS_ALIAS(hAlias) \
629 ( DBGF_AS_ALIAS_2_INDEX(hAlias) < DBGF_AS_COUNT )
630/** Predicat macro that check if the specified alias is a fixed one or not. */
631#define DBGF_AS_IS_FIXED_ALIAS(hAlias) \
632 ( DBGF_AS_ALIAS_2_INDEX(hAlias) < (uintptr_t)DBGF_AS_PHYS - (uintptr_t)DBGF_AS_FIRST + 1U )
633
634/** @} */
635
636VMMR3DECL(int) DBGFR3AsAdd(PVM pVM, RTDBGAS hDbgAs, RTPROCESS ProcId);
637VMMR3DECL(int) DBGFR3AsDelete(PVM pVM, RTDBGAS hDbgAs);
638VMMR3DECL(int) DBGFR3AsSetAlias(PVM pVM, RTDBGAS hAlias, RTDBGAS hAliasFor);
639VMMR3DECL(RTDBGAS) DBGFR3AsResolve(PVM pVM, RTDBGAS hAlias);
640VMMR3DECL(RTDBGAS) DBGFR3AsResolveAndRetain(PVM pVM, RTDBGAS hAlias);
641VMMR3DECL(RTDBGAS) DBGFR3AsQueryByName(PVM pVM, const char *pszName);
642VMMR3DECL(RTDBGAS) DBGFR3AsQueryByPid(PVM pVM, RTPROCESS ProcId);
643
644VMMR3DECL(int) DBGFR3AsLoadImage(PVM pVM, RTDBGAS hDbgAs, const char *pszFilename, const char *pszModName, PCDBGFADDRESS pModAddress, RTDBGSEGIDX iModSeg, uint32_t fFlags);
645VMMR3DECL(int) DBGFR3AsLoadMap(PVM pVM, RTDBGAS hDbgAs, const char *pszFilename, const char *pszModName, PCDBGFADDRESS pModAddress, RTDBGSEGIDX iModSeg, RTGCUINTPTR uSubtrahend, uint32_t fFlags);
646VMMR3DECL(int) DBGFR3AsLinkModule(PVM pVM, RTDBGAS hDbgAs, RTDBGMOD hMod, PCDBGFADDRESS pModAddress, RTDBGSEGIDX iModSeg, uint32_t fFlags);
647
648VMMR3DECL(int) DBGFR3AsSymbolByAddr(PVM pVM, RTDBGAS hDbgAs, PCDBGFADDRESS pAddress, PRTGCINTPTR poffDisp, PRTDBGSYMBOL pSymbol, PRTDBGMOD phMod);
649VMMR3DECL(PRTDBGSYMBOL) DBGFR3AsSymbolByAddrA(PVM pVM, RTDBGAS hDbgAs, PCDBGFADDRESS pAddress, PRTGCINTPTR poffDisp, PRTDBGMOD phMod);
650VMMR3DECL(int) DBGFR3AsSymbolByName(PVM pVM, RTDBGAS hDbgAs, const char *pszSymbol, PRTDBGSYMBOL pSymbol, PRTDBGMOD phMod);
651
652/* The following are soon to be obsoleted: */
653VMMR3DECL(int) DBGFR3ModuleLoad(PVM pVM, const char *pszFilename, RTGCUINTPTR AddressDelta, const char *pszName, RTGCUINTPTR ModuleAddress, unsigned cbImage);
654VMMR3DECL(void) DBGFR3ModuleRelocate(PVM pVM, RTGCUINTPTR OldImageBase, RTGCUINTPTR NewImageBase, RTGCUINTPTR cbImage,
655 const char *pszFilename, const char *pszName);
656VMMR3DECL(int) DBGFR3SymbolAdd(PVM pVM, RTGCUINTPTR ModuleAddress, RTGCUINTPTR SymbolAddress, RTUINT cbSymbol, const char *pszSymbol);
657VMMR3DECL(int) DBGFR3SymbolByAddr(PVM pVM, RTGCUINTPTR Address, PRTGCINTPTR poffDisplacement, PDBGFSYMBOL pSymbol);
658VMMR3DECL(int) DBGFR3SymbolByName(PVM pVM, const char *pszSymbol, PDBGFSYMBOL pSymbol);
659
660VMMR3DECL(int) DBGFR3LineByAddr(PVM pVM, RTGCUINTPTR Address, PRTGCINTPTR poffDisplacement, PDBGFLINE pLine);
661VMMR3DECL(PDBGFLINE) DBGFR3LineByAddrAlloc(PVM pVM, RTGCUINTPTR Address, PRTGCINTPTR poffDisplacement);
662VMMR3DECL(void) DBGFR3LineFree(PDBGFLINE pLine);
663
664
665/**
666 * Return type.
667 */
668typedef enum DBGFRETRUNTYPE
669{
670 /** The usual invalid 0 value. */
671 DBGFRETURNTYPE_INVALID = 0,
672 /** Near 16-bit return. */
673 DBGFRETURNTYPE_NEAR16,
674 /** Near 32-bit return. */
675 DBGFRETURNTYPE_NEAR32,
676 /** Near 64-bit return. */
677 DBGFRETURNTYPE_NEAR64,
678 /** Far 16:16 return. */
679 DBGFRETURNTYPE_FAR16,
680 /** Far 16:32 return. */
681 DBGFRETURNTYPE_FAR32,
682 /** Far 16:64 return. */
683 DBGFRETURNTYPE_FAR64,
684 /** 16-bit iret return (e.g. real or 286 protect mode). */
685 DBGFRETURNTYPE_IRET16,
686 /** 32-bit iret return. */
687 DBGFRETURNTYPE_IRET32,
688 /** 32-bit iret return. */
689 DBGFRETURNTYPE_IRET32_PRIV,
690 /** 32-bit iret return to V86 mode. */
691 DBGFRETURNTYPE_IRET32_V86,
692 /** @todo 64-bit iret return. */
693 DBGFRETURNTYPE_IRET64,
694 /** The end of the valid return types. */
695 DBGFRETURNTYPE_END,
696 /** The usual 32-bit blowup. */
697 DBGFRETURNTYPE_32BIT_HACK = 0x7fffffff
698} DBGFRETURNTYPE;
699
700/**
701 * Figures the size of the return state on the stack.
702 *
703 * @returns number of bytes. 0 if invalid parameter.
704 * @param enmRetType The type of return.
705 */
706DECLINLINE(unsigned) DBGFReturnTypeSize(DBGFRETURNTYPE enmRetType)
707{
708 switch (enmRetType)
709 {
710 case DBGFRETURNTYPE_NEAR16: return 2;
711 case DBGFRETURNTYPE_NEAR32: return 4;
712 case DBGFRETURNTYPE_NEAR64: return 8;
713 case DBGFRETURNTYPE_FAR16: return 4;
714 case DBGFRETURNTYPE_FAR32: return 4;
715 case DBGFRETURNTYPE_FAR64: return 8;
716 case DBGFRETURNTYPE_IRET16: return 6;
717 case DBGFRETURNTYPE_IRET32: return 4*3;
718 case DBGFRETURNTYPE_IRET32_PRIV: return 4*5;
719 case DBGFRETURNTYPE_IRET32_V86: return 4*9;
720 case DBGFRETURNTYPE_IRET64:
721 default:
722 return 0;
723 }
724}
725
726
727/** Pointer to stack frame info. */
728typedef struct DBGFSTACKFRAME *PDBGFSTACKFRAME;
729/** Pointer to const stack frame info. */
730typedef struct DBGFSTACKFRAME const *PCDBGFSTACKFRAME;
731/**
732 * Info about a stack frame.
733 */
734typedef struct DBGFSTACKFRAME
735{
736 /** Frame number. */
737 uint32_t iFrame;
738 /** Frame flags. */
739 uint32_t fFlags;
740 /** The frame address.
741 * The off member is [e|r]bp and the Sel member is ss. */
742 DBGFADDRESS AddrFrame;
743 /** The stack address of the frame.
744 * The off member is [e|r]sp and the Sel member is ss. */
745 DBGFADDRESS AddrStack;
746 /** The program counter (PC) address of the frame.
747 * The off member is [e|r]ip and the Sel member is cs. */
748 DBGFADDRESS AddrPC;
749 /** Pointer to the symbol nearest the program counter (PC). NULL if not found. */
750 PRTDBGSYMBOL pSymPC;
751 /** Pointer to the linnumber nearest the program counter (PC). NULL if not found. */
752 PDBGFLINE pLinePC;
753
754 /** The return frame address.
755 * The off member is [e|r]bp and the Sel member is ss. */
756 DBGFADDRESS AddrReturnFrame;
757 /** The return stack address.
758 * The off member is [e|r]sp and the Sel member is ss. */
759 DBGFADDRESS AddrReturnStack;
760 /** The way this frame returns to the next one. */
761 DBGFRETURNTYPE enmReturnType;
762
763 /** The program counter (PC) address which the frame returns to.
764 * The off member is [e|r]ip and the Sel member is cs. */
765 DBGFADDRESS AddrReturnPC;
766 /** Pointer to the symbol nearest the return PC. NULL if not found. */
767 PRTDBGSYMBOL pSymReturnPC;
768 /** Pointer to the linnumber nearest the return PC. NULL if not found. */
769 PDBGFLINE pLineReturnPC;
770
771 /** 32-bytes of stack arguments. */
772 union
773 {
774 /** 64-bit view */
775 uint64_t au64[4];
776 /** 32-bit view */
777 uint32_t au32[8];
778 /** 16-bit view */
779 uint16_t au16[16];
780 /** 8-bit view */
781 uint8_t au8[32];
782 } Args;
783
784 /** Pointer to the next frame.
785 * Might not be used in some cases, so consider it internal. */
786 PCDBGFSTACKFRAME pNextInternal;
787 /** Pointer to the first frame.
788 * Might not be used in some cases, so consider it internal. */
789 PCDBGFSTACKFRAME pFirstInternal;
790} DBGFSTACKFRAME;
791
792/** @name DBGFSTACKFRAME Flags.
793 * @{ */
794/** Set if the content of the frame is filled in by DBGFR3StackWalk() and can be used
795 * to construct the next frame. */
796#define DBGFSTACKFRAME_FLAGS_ALL_VALID RT_BIT(0)
797/** This is the last stack frame we can read.
798 * This flag is not set if the walk stop because of max dept or recursion. */
799#define DBGFSTACKFRAME_FLAGS_LAST RT_BIT(1)
800/** This is the last record because we detected a loop. */
801#define DBGFSTACKFRAME_FLAGS_LOOP RT_BIT(2)
802/** This is the last record because we reached the maximum depth. */
803#define DBGFSTACKFRAME_FLAGS_MAX_DEPTH RT_BIT(3)
804/** 16-bit frame. */
805#define DBGFSTACKFRAME_FLAGS_16BIT RT_BIT(4)
806/** 32-bit frame. */
807#define DBGFSTACKFRAME_FLAGS_32BIT RT_BIT(5)
808/** 64-bit frame. */
809#define DBGFSTACKFRAME_FLAGS_64BIT RT_BIT(6)
810/** @} */
811
812/** @name DBGFCODETYPE
813 * @{ */
814typedef enum DBGFCODETYPE
815{
816 /** The usual invalid 0 value. */
817 DBGFCODETYPE_INVALID = 0,
818 /** Stack walk for guest code. */
819 DBGFCODETYPE_GUEST,
820 /** Stack walk for hypervisor code. */
821 DBGFCODETYPE_HYPER,
822 /** Stack walk for ring 0 code. */
823 DBGFCODETYPE_RING0,
824 /** The usual 32-bit blowup. */
825 DBGFCODETYPE_32BIT_HACK = 0x7fffffff
826} DBGFCODETYPE;
827/** @} */
828
829VMMR3DECL(int) DBGFR3StackWalkBegin(PVM pVM, VMCPUID idCpu, DBGFCODETYPE enmCodeType, PCDBGFSTACKFRAME *ppFirstFrame);
830VMMR3DECL(int) DBGFR3StackWalkBeginEx(PVM pVM, VMCPUID idCpu, DBGFCODETYPE enmCodeType, PCDBGFADDRESS pAddrFrame,
831 PCDBGFADDRESS pAddrStack,PCDBGFADDRESS pAddrPC,
832 DBGFRETURNTYPE enmReturnType, PCDBGFSTACKFRAME *ppFirstFrame);
833VMMR3DECL(PCDBGFSTACKFRAME) DBGFR3StackWalkNext(PCDBGFSTACKFRAME pCurrent);
834VMMR3DECL(void) DBGFR3StackWalkEnd(PCDBGFSTACKFRAME pFirstFrame);
835
836
837
838
839/** Flags to pass to DBGFR3DisasInstrEx().
840 * @{ */
841/** Disassemble the current guest instruction, with annotations. */
842#define DBGF_DISAS_FLAGS_CURRENT_GUEST RT_BIT(0)
843/** Disassemble the current hypervisor instruction, with annotations. */
844#define DBGF_DISAS_FLAGS_CURRENT_HYPER RT_BIT(1)
845/** No annotations for current context. */
846#define DBGF_DISAS_FLAGS_NO_ANNOTATION RT_BIT(2)
847/** No symbol lookup. */
848#define DBGF_DISAS_FLAGS_NO_SYMBOLS RT_BIT(3)
849/** No instruction bytes. */
850#define DBGF_DISAS_FLAGS_NO_BYTES RT_BIT(4)
851/** No address in the output. */
852#define DBGF_DISAS_FLAGS_NO_ADDRESS RT_BIT(5)
853/** Set if the hidden selector registers are known to be valid. (REM hack to
854 * avoid assertions.) */
855#define DBGF_DISAS_FLAGS_HID_SEL_REGS_VALID RT_BIT(6)
856/** Disassemble in the default mode of the specific context. */
857#define DBGF_DISAS_FLAGS_DEFAULT_MODE UINT32_C(0x00000000)
858/** Disassemble in 16-bit mode. */
859#define DBGF_DISAS_FLAGS_16BIT_MODE UINT32_C(0x10000000)
860/** Disassemble in 16-bit mode with real mode address translation. */
861#define DBGF_DISAS_FLAGS_16BIT_REAL_MODE UINT32_C(0x20000000)
862/** Disassemble in 32-bit mode. */
863#define DBGF_DISAS_FLAGS_32BIT_MODE UINT32_C(0x30000000)
864/** Disassemble in 64-bit mode. */
865#define DBGF_DISAS_FLAGS_64BIT_MODE UINT32_C(0x40000000)
866/** The disassembly mode mask. */
867#define DBGF_DISAS_FLAGS_MODE_MASK UINT32_C(0x70000000)
868/** Mask containing the valid flags. */
869#define DBGF_DISAS_FLAGS_VALID_MASK UINT32_C(0x7000007f)
870/** @} */
871
872/** Special flat selector. */
873#define DBGF_SEL_FLAT 1
874
875VMMR3DECL(int) DBGFR3DisasInstrEx(PVM pVM, VMCPUID idCpu, RTSEL Sel, RTGCPTR GCPtr, uint32_t fFlags,
876 char *pszOutput, uint32_t cbOutput, uint32_t *pcbInstr);
877VMMR3DECL(int) DBGFR3DisasInstrCurrent(PVMCPU pVCpu, char *pszOutput, uint32_t cbOutput);
878VMMR3DECL(int) DBGFR3DisasInstrCurrentLogInternal(PVMCPU pVCpu, const char *pszPrefix);
879
880/** @def DBGFR3DisasInstrCurrentLog
881 * Disassembles the current guest context instruction and writes it to the log.
882 * All registers and data will be displayed. Addresses will be attempted resolved to symbols.
883 */
884#ifdef LOG_ENABLED
885# define DBGFR3DisasInstrCurrentLog(pVCpu, pszPrefix) \
886 do { \
887 if (LogIsEnabled()) \
888 DBGFR3DisasInstrCurrentLogInternal(pVCpu, pszPrefix); \
889 } while (0)
890#else
891# define DBGFR3DisasInstrCurrentLog(pVCpu, pszPrefix) do { } while (0)
892#endif
893
894VMMR3DECL(int) DBGFR3DisasInstrLogInternal(PVMCPU pVCpu, RTSEL Sel, RTGCPTR GCPtr);
895
896/** @def DBGFR3DisasInstrLog
897 * Disassembles the specified guest context instruction and writes it to the log.
898 * Addresses will be attempted resolved to symbols.
899 * @thread Any EMT.
900 */
901#ifdef LOG_ENABLED
902# define DBGFR3DisasInstrLog(pVCpu, Sel, GCPtr) \
903 do { \
904 if (LogIsEnabled()) \
905 DBGFR3DisasInstrLogInternal(pVCpu, Sel, GCPtr); \
906 } while (0)
907#else
908# define DBGFR3DisasInstrLog(pVCpu, Sel, GCPtr) do { } while (0)
909#endif
910
911
912VMMR3DECL(int) DBGFR3MemScan(PVM pVM, VMCPUID idCpu, PCDBGFADDRESS pAddress, RTGCUINTPTR cbRange, RTGCUINTPTR uAlign,
913 const void *pvNeedle, size_t cbNeedle, PDBGFADDRESS pHitAddress);
914VMMR3DECL(int) DBGFR3MemRead(PVM pVM, VMCPUID idCpu, PCDBGFADDRESS pAddress, void *pvBuf, size_t cbRead);
915VMMR3DECL(int) DBGFR3MemReadString(PVM pVM, VMCPUID idCpu, PCDBGFADDRESS pAddress, char *pszBuf, size_t cbBuf);
916VMMR3DECL(int) DBGFR3MemWrite(PVM pVM, VMCPUID idCpu, PCDBGFADDRESS pAddress, void const *pvBuf, size_t cbRead);
917
918
919/** @name Flags for DBGFR3PagingDumpEx, PGMR3DumpHierarchyHCEx and
920 * PGMR3DumpHierarchyGCEx
921 * @{ */
922/** The CR3 from the current CPU state. */
923#define DBGFPGDMP_FLAGS_CURRENT_CR3 RT_BIT_32(0)
924/** The current CPU paging mode (PSE, PAE, LM, EPT, NX). */
925#define DBGFPGDMP_FLAGS_CURRENT_MODE RT_BIT_32(1)
926/** Whether PSE is enabled (!DBGFPGDMP_FLAGS_CURRENT_STATE).
927 * Same value as X86_CR4_PSE. */
928#define DBGFPGDMP_FLAGS_PSE RT_BIT_32(4) /* */
929/** Whether PAE is enabled (!DBGFPGDMP_FLAGS_CURRENT_STATE).
930 * Same value as X86_CR4_PAE. */
931#define DBGFPGDMP_FLAGS_PAE RT_BIT_32(5) /* */
932/** Whether LME is enabled (!DBGFPGDMP_FLAGS_CURRENT_STATE).
933 * Same value as MSR_K6_EFER_LME. */
934#define DBGFPGDMP_FLAGS_LME RT_BIT_32(8)
935/** Whether nested paging is enabled (!DBGFPGDMP_FLAGS_CURRENT_STATE). */
936#define DBGFPGDMP_FLAGS_NP RT_BIT_32(9)
937/** Whether extended nested page tables are enabled
938 * (!DBGFPGDMP_FLAGS_CURRENT_STATE). */
939#define DBGFPGDMP_FLAGS_EPT RT_BIT_32(10)
940/** Whether no-execution is enabled (!DBGFPGDMP_FLAGS_CURRENT_STATE).
941 * Same value as MSR_K6_EFER_NXE. */
942#define DBGFPGDMP_FLAGS_NXE RT_BIT_32(11)
943/** Whether to print the CR3. */
944#define DBGFPGDMP_FLAGS_PRINT_CR3 RT_BIT_32(27)
945/** Whether to print the header. */
946#define DBGFPGDMP_FLAGS_HEADER RT_BIT_32(28)
947/** Whether to dump additional page information. */
948#define DBGFPGDMP_FLAGS_PAGE_INFO RT_BIT_32(29)
949/** Dump the shadow tables if set.
950 * Cannot be used together with DBGFPGDMP_FLAGS_GUEST. */
951#define DBGFPGDMP_FLAGS_SHADOW RT_BIT_32(30)
952/** Dump the guest tables if set.
953 * Cannot be used together with DBGFPGDMP_FLAGS_SHADOW. */
954#define DBGFPGDMP_FLAGS_GUEST RT_BIT_32(31)
955/** Mask of valid bits. */
956#define DBGFPGDMP_FLAGS_VALID_MASK UINT32_C(0xf8000f33)
957/** The mask of bits controlling the paging mode. */
958#define DBGFPGDMP_FLAGS_MODE_MASK UINT32_C(0x00000f32)
959/** @} */
960VMMDECL(int) DBGFR3PagingDumpEx(PVM pVM, VMCPUID idCpu, uint32_t fFlags, uint64_t cr3, uint64_t u64FirstAddr,
961 uint64_t u64LastAddr, uint32_t cMaxDepth, PCDBGFINFOHLP pHlp);
962
963
964/** @name DBGFR3SelQueryInfo flags.
965 * @{ */
966/** Get the info from the guest descriptor table. */
967#define DBGFSELQI_FLAGS_DT_GUEST UINT32_C(0)
968/** Get the info from the shadow descriptor table.
969 * Only works in raw-mode. */
970#define DBGFSELQI_FLAGS_DT_SHADOW UINT32_C(1)
971/** If currently executing in in 64-bit mode, blow up data selectors. */
972#define DBGFSELQI_FLAGS_DT_ADJ_64BIT_MODE UINT32_C(2)
973/** @} */
974VMMR3DECL(int) DBGFR3SelQueryInfo(PVM pVM, VMCPUID idCpu, RTSEL Sel, uint32_t fFlags, PDBGFSELINFO pSelInfo);
975
976
977/**
978 * Register identifiers.
979 */
980typedef enum DBGFREG
981{
982 /* General purpose registers: */
983 DBGFREG_AL = 0,
984 DBGFREG_AX = DBGFREG_AL,
985 DBGFREG_EAX = DBGFREG_AL,
986 DBGFREG_RAX = DBGFREG_AL,
987
988 DBGFREG_CL,
989 DBGFREG_CX = DBGFREG_CL,
990 DBGFREG_ECX = DBGFREG_CL,
991 DBGFREG_RCX = DBGFREG_CL,
992
993 DBGFREG_DL,
994 DBGFREG_DX = DBGFREG_DL,
995 DBGFREG_EDX = DBGFREG_DL,
996 DBGFREG_RDX = DBGFREG_DL,
997
998 DBGFREG_BL,
999 DBGFREG_BX = DBGFREG_BL,
1000 DBGFREG_EBX = DBGFREG_BL,
1001 DBGFREG_RBX = DBGFREG_BL,
1002
1003 DBGFREG_SPL,
1004 DBGFREG_SP = DBGFREG_SPL,
1005 DBGFREG_ESP = DBGFREG_SPL,
1006 DBGFREG_RSP = DBGFREG_SPL,
1007
1008 DBGFREG_BPL,
1009 DBGFREG_BP = DBGFREG_BPL,
1010 DBGFREG_EBP = DBGFREG_BPL,
1011 DBGFREG_RBP = DBGFREG_BPL,
1012
1013 DBGFREG_SIL,
1014 DBGFREG_SI = DBGFREG_SIL,
1015 DBGFREG_ESI = DBGFREG_SIL,
1016 DBGFREG_RSI = DBGFREG_SIL,
1017
1018 DBGFREG_DIL,
1019 DBGFREG_DI = DBGFREG_DIL,
1020 DBGFREG_EDI = DBGFREG_DIL,
1021 DBGFREG_RDI = DBGFREG_DIL,
1022
1023 DBGFREG_R8,
1024 DBGFREG_R8B = DBGFREG_R8,
1025 DBGFREG_R8W = DBGFREG_R8,
1026 DBGFREG_R8D = DBGFREG_R8,
1027
1028 DBGFREG_R9,
1029 DBGFREG_R9B = DBGFREG_R9,
1030 DBGFREG_R9W = DBGFREG_R9,
1031 DBGFREG_R9D = DBGFREG_R9,
1032
1033 DBGFREG_R10,
1034 DBGFREG_R10B = DBGFREG_R10,
1035 DBGFREG_R10W = DBGFREG_R10,
1036 DBGFREG_R10D = DBGFREG_R10,
1037
1038 DBGFREG_R11,
1039 DBGFREG_R11B = DBGFREG_R11,
1040 DBGFREG_R11W = DBGFREG_R11,
1041 DBGFREG_R11D = DBGFREG_R11,
1042
1043 DBGFREG_R12,
1044 DBGFREG_R12B = DBGFREG_R12,
1045 DBGFREG_R12W = DBGFREG_R12,
1046 DBGFREG_R12D = DBGFREG_R12,
1047
1048 DBGFREG_R13,
1049 DBGFREG_R13B = DBGFREG_R13,
1050 DBGFREG_R13W = DBGFREG_R13,
1051 DBGFREG_R13D = DBGFREG_R13,
1052
1053 DBGFREG_R14,
1054 DBGFREG_R14B = DBGFREG_R14,
1055 DBGFREG_R14W = DBGFREG_R14,
1056 DBGFREG_R14D = DBGFREG_R14,
1057
1058 DBGFREG_R15,
1059 DBGFREG_R15B = DBGFREG_R15,
1060 DBGFREG_R15W = DBGFREG_R15,
1061 DBGFREG_R15D = DBGFREG_R15,
1062
1063 /* Segments and other special registers: */
1064 DBGFREG_CS,
1065 DBGFREG_CS_ATTR,
1066 DBGFREG_CS_BASE,
1067 DBGFREG_CS_LIMIT,
1068
1069 DBGFREG_DS,
1070 DBGFREG_DS_ATTR,
1071 DBGFREG_DS_BASE,
1072 DBGFREG_DS_LIMIT,
1073
1074 DBGFREG_ES,
1075 DBGFREG_ES_ATTR,
1076 DBGFREG_ES_BASE,
1077 DBGFREG_ES_LIMIT,
1078
1079 DBGFREG_FS,
1080 DBGFREG_FS_ATTR,
1081 DBGFREG_FS_BASE,
1082 DBGFREG_FS_LIMIT,
1083
1084 DBGFREG_GS,
1085 DBGFREG_GS_ATTR,
1086 DBGFREG_GS_BASE,
1087 DBGFREG_GS_LIMIT,
1088
1089 DBGFREG_SS,
1090 DBGFREG_SS_ATTR,
1091 DBGFREG_SS_BASE,
1092 DBGFREG_SS_LIMIT,
1093
1094 DBGFREG_IP,
1095 DBGFREG_EIP = DBGFREG_IP,
1096 DBGFREG_RIP = DBGFREG_IP,
1097
1098 DBGFREG_FLAGS,
1099 DBGFREG_EFLAGS = DBGFREG_FLAGS,
1100 DBGFREG_RFLAGS = DBGFREG_FLAGS,
1101
1102 /* FPU: */
1103 DBGFREG_FCW,
1104 DBGFREG_FSW,
1105 DBGFREG_FTW,
1106 DBGFREG_FOP,
1107 DBGFREG_FPUIP,
1108 DBGFREG_FPUCS,
1109 DBGFREG_FPUDP,
1110 DBGFREG_FPUDS,
1111 DBGFREG_MXCSR,
1112 DBGFREG_MXCSR_MASK,
1113
1114 DBGFREG_ST0,
1115 DBGFREG_ST1,
1116 DBGFREG_ST2,
1117 DBGFREG_ST3,
1118 DBGFREG_ST4,
1119 DBGFREG_ST5,
1120 DBGFREG_ST6,
1121 DBGFREG_ST7,
1122
1123 DBGFREG_MM0,
1124 DBGFREG_MM1,
1125 DBGFREG_MM2,
1126 DBGFREG_MM3,
1127 DBGFREG_MM4,
1128 DBGFREG_MM5,
1129 DBGFREG_MM6,
1130 DBGFREG_MM7,
1131
1132 /* SSE: */
1133 DBGFREG_XMM0,
1134 DBGFREG_XMM1,
1135 DBGFREG_XMM2,
1136 DBGFREG_XMM3,
1137 DBGFREG_XMM4,
1138 DBGFREG_XMM5,
1139 DBGFREG_XMM6,
1140 DBGFREG_XMM7,
1141 DBGFREG_XMM8,
1142 DBGFREG_XMM9,
1143 DBGFREG_XMM10,
1144 DBGFREG_XMM11,
1145 DBGFREG_XMM12,
1146 DBGFREG_XMM13,
1147 DBGFREG_XMM14,
1148 DBGFREG_XMM15,
1149 /** @todo add XMM aliases. */
1150
1151 /* System registers: */
1152 DBGFREG_GDTR_BASE,
1153 DBGFREG_GDTR_LIMIT,
1154 DBGFREG_IDTR_BASE,
1155 DBGFREG_IDTR_LIMIT,
1156 DBGFREG_LDTR,
1157 DBGFREG_LDTR_ATTR,
1158 DBGFREG_LDTR_BASE,
1159 DBGFREG_LDTR_LIMIT,
1160 DBGFREG_TR,
1161 DBGFREG_TR_ATTR,
1162 DBGFREG_TR_BASE,
1163 DBGFREG_TR_LIMIT,
1164
1165 DBGFREG_CR0,
1166 DBGFREG_CR2,
1167 DBGFREG_CR3,
1168 DBGFREG_CR4,
1169 DBGFREG_CR8,
1170
1171 DBGFREG_DR0,
1172 DBGFREG_DR1,
1173 DBGFREG_DR2,
1174 DBGFREG_DR3,
1175 DBGFREG_DR6,
1176 DBGFREG_DR7,
1177
1178 /* MSRs: */
1179 DBGFREG_MSR_IA32_APICBASE,
1180 DBGFREG_MSR_IA32_CR_PAT,
1181 DBGFREG_MSR_IA32_PERF_STATUS,
1182 DBGFREG_MSR_IA32_SYSENTER_CS,
1183 DBGFREG_MSR_IA32_SYSENTER_EIP,
1184 DBGFREG_MSR_IA32_SYSENTER_ESP,
1185 DBGFREG_MSR_IA32_TSC,
1186 DBGFREG_MSR_K6_EFER,
1187 DBGFREG_MSR_K6_STAR,
1188 DBGFREG_MSR_K8_CSTAR,
1189 DBGFREG_MSR_K8_FS_BASE,
1190 DBGFREG_MSR_K8_GS_BASE,
1191 DBGFREG_MSR_K8_KERNEL_GS_BASE,
1192 DBGFREG_MSR_K8_LSTAR,
1193 DBGFREG_MSR_K8_SF_MASK,
1194 DBGFREG_MSR_K8_TSC_AUX,
1195
1196 /** The number of registers to pass to DBGFR3RegQueryAll. */
1197 DBGFREG_ALL_COUNT,
1198
1199 /* Misc aliases that doesn't need be part of the 'all' query: */
1200 DBGFREG_AH = DBGFREG_ALL_COUNT,
1201 DBGFREG_CH,
1202 DBGFREG_DH,
1203 DBGFREG_BH,
1204 DBGFREG_GDTR,
1205 DBGFREG_IDTR,
1206
1207 /** The end of the registers. */
1208 DBGFREG_END,
1209 /** The usual 32-bit type hack. */
1210 DBGFREG_32BIT_HACK = 0x7fffffff
1211} DBGFREG;
1212/** Pointer to a register identifier. */
1213typedef DBGFREG *PDBGFREG;
1214/** Pointer to a const register identifier. */
1215typedef DBGFREG const *PCDBGFREG;
1216
1217/**
1218 * Register value type.
1219 */
1220typedef enum DBGFREGVALTYPE
1221{
1222 DBGFREGVALTYPE_INVALID = 0,
1223 /** Unsigned 8-bit register value. */
1224 DBGFREGVALTYPE_U8,
1225 /** Unsigned 16-bit register value. */
1226 DBGFREGVALTYPE_U16,
1227 /** Unsigned 32-bit register value. */
1228 DBGFREGVALTYPE_U32,
1229 /** Unsigned 64-bit register value. */
1230 DBGFREGVALTYPE_U64,
1231 /** Unsigned 128-bit register value. */
1232 DBGFREGVALTYPE_U128,
1233 /** 80-bit register value. */
1234 DBGFREGVALTYPE_80,
1235 /** Long double register value. */
1236 DBGFREGVALTYPE_LRD,
1237 /** Descriptor table register value. */
1238 DBGFREGVALTYPE_DTR,
1239 /** End of the valid register value types. */
1240 DBGFREGVALTYPE_END,
1241 /** The usual 32-bit type hack. */
1242 DBGFREGVALTYPE_32BIT_HACK = 0x7fffffff
1243} DBGFREGVALTYPE;
1244
1245
1246/**
1247 * Entry in a batch query or set operation.
1248 */
1249typedef struct DBGFREGENTRY
1250{
1251 /** The register identifier. */
1252 DBGFREG enmReg;
1253 /** The size of the value in bytes. */
1254 DBGFREGVALTYPE enmType;
1255 /** The register value. The valid view is indicated by enmType. */
1256 union DBGFREGVAL
1257 {
1258 uint8_t u8; /**< The 8-bit view. */
1259 uint16_t u16; /**< The 16-bit view. */
1260 uint32_t u32; /**< The 32-bit view. */
1261 uint64_t u64; /**< The 64-bit view. */
1262 uint128_t u128; /**< The 128-bit view. */
1263 long double lrd; /**< The long double view. */
1264 /** GDTR or LDTR (DBGFREGVALTYPE_DTR). */
1265 struct
1266 {
1267 /** The table address. */
1268 uint64_t u64Base;
1269 /** The table limit (length minus 1). */
1270 uint32_t u32Limit;
1271 } dtr;
1272
1273 uint8_t au8[16]; /**< The 8-bit array view. */
1274 uint16_t au16[8]; /**< The 16-bit array view. */
1275 uint32_t au32[4]; /**< The 32-bit array view. */
1276 uint64_t au64[2]; /**< The 64-bit array view. */
1277 RTUINT128U u;
1278 } Val;
1279} DBGFREGENTRY;
1280/** Pointer to a register entry in a batch operation. */
1281typedef DBGFREGENTRY *PDBGFREGENTRY;
1282/** Pointer to a const register entry in a batch operation. */
1283typedef DBGFREGENTRY const *PCDBGFREGENTRY;
1284
1285VMMR3DECL(int) DBGFR3RegQueryU8( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint8_t *pu8);
1286VMMR3DECL(int) DBGFR3RegQueryU16( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint16_t *pu16);
1287VMMR3DECL(int) DBGFR3RegQueryU32( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint32_t *pu32);
1288VMMR3DECL(int) DBGFR3RegQueryU64( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint64_t *pu64);
1289VMMR3DECL(int) DBGFR3RegQueryU128(PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint128_t *pu128);
1290VMMR3DECL(int) DBGFR3RegQueryLrd( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, long double *plrd);
1291VMMR3DECL(int) DBGFR3RegQueryXdtr(PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint64_t *pu64Base, uint16_t *pu16Limit);
1292VMMR3DECL(int) DBGFR3RegQueryBatch(PVM pVM,VMCPUID idCpu, PDBGFREGENTRY paRegs, size_t cRegs);
1293VMMR3DECL(int) DBGFR3RegQueryAll( PVM pVM, VMCPUID idCpu, PDBGFREGENTRY paRegs, size_t cRegs);
1294
1295VMMR3DECL(int) DBGFR3RegSetU8( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint8_t u8);
1296VMMR3DECL(int) DBGFR3RegSetU16( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint16_t u16);
1297VMMR3DECL(int) DBGFR3RegSetU32( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint32_t u32);
1298VMMR3DECL(int) DBGFR3RegSetU64( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint64_t u64);
1299VMMR3DECL(int) DBGFR3RegSetU128( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, uint128_t u128);
1300VMMR3DECL(int) DBGFR3RegSetLrd( PVM pVM, VMCPUID idCpu, DBGFREG enmReg, long double lrd);
1301VMMR3DECL(int) DBGFR3RegSetBatch( PVM pVM, VMCPUID idCpu, PCDBGFREGENTRY paRegs, size_t cbRegs);
1302
1303VMMR3DECL(const char *) DBGFR3RegName(DBGFREG enmReg, DBGFREGVALTYPE enmType);
1304
1305
1306/**
1307 * Guest OS digger interface identifier.
1308 *
1309 * This is for use together with PDBGFR3QueryInterface and is used to
1310 * obtain access to optional interfaces.
1311 */
1312typedef enum DBGFOSINTERFACE
1313{
1314 /** The usual invalid entry. */
1315 DBGFOSINTERFACE_INVALID = 0,
1316 /** Process info. */
1317 DBGFOSINTERFACE_PROCESS,
1318 /** Thread info. */
1319 DBGFOSINTERFACE_THREAD,
1320 /** The end of the valid entries. */
1321 DBGFOSINTERFACE_END,
1322 /** The usual 32-bit type blowup. */
1323 DBGFOSINTERFACE_32BIT_HACK = 0x7fffffff
1324} DBGFOSINTERFACE;
1325/** Pointer to a Guest OS digger interface identifier. */
1326typedef DBGFOSINTERFACE *PDBGFOSINTERFACE;
1327/** Pointer to a const Guest OS digger interface identifier. */
1328typedef DBGFOSINTERFACE const *PCDBGFOSINTERFACE;
1329
1330
1331/**
1332 * Guest OS Digger Registration Record.
1333 *
1334 * This is used with the DBGFR3OSRegister() API.
1335 */
1336typedef struct DBGFOSREG
1337{
1338 /** Magic value (DBGFOSREG_MAGIC). */
1339 uint32_t u32Magic;
1340 /** Flags. Reserved. */
1341 uint32_t fFlags;
1342 /** The size of the instance data. */
1343 uint32_t cbData;
1344 /** Operative System name. */
1345 char szName[24];
1346
1347 /**
1348 * Constructs the instance.
1349 *
1350 * @returns VBox status code.
1351 * @param pVM Pointer to the shared VM structure.
1352 * @param pvData Pointer to the instance data.
1353 */
1354 DECLCALLBACKMEMBER(int, pfnConstruct)(PVM pVM, void *pvData);
1355
1356 /**
1357 * Destroys the instance.
1358 *
1359 * @param pVM Pointer to the shared VM structure.
1360 * @param pvData Pointer to the instance data.
1361 */
1362 DECLCALLBACKMEMBER(void, pfnDestruct)(PVM pVM, void *pvData);
1363
1364 /**
1365 * Probes the guest memory for OS finger prints.
1366 *
1367 * No setup or so is performed, it will be followed by a call to pfnInit
1368 * or pfnRefresh that should take care of that.
1369 *
1370 * @returns true if is an OS handled by this module, otherwise false.
1371 * @param pVM Pointer to the shared VM structure.
1372 * @param pvData Pointer to the instance data.
1373 */
1374 DECLCALLBACKMEMBER(bool, pfnProbe)(PVM pVM, void *pvData);
1375
1376 /**
1377 * Initializes a fresly detected guest, loading symbols and such useful stuff.
1378 *
1379 * This is called after pfnProbe.
1380 *
1381 * @returns VBox status code.
1382 * @param pVM Pointer to the shared VM structure.
1383 * @param pvData Pointer to the instance data.
1384 */
1385 DECLCALLBACKMEMBER(int, pfnInit)(PVM pVM, void *pvData);
1386
1387 /**
1388 * Refreshes symbols and stuff following a redetection of the same OS.
1389 *
1390 * This is called after pfnProbe.
1391 *
1392 * @returns VBox status code.
1393 * @param pVM Pointer to the shared VM structure.
1394 * @param pvData Pointer to the instance data.
1395 */
1396 DECLCALLBACKMEMBER(int, pfnRefresh)(PVM pVM, void *pvData);
1397
1398 /**
1399 * Terminates an OS when a new (or none) OS has been detected,
1400 * and before destruction.
1401 *
1402 * This is called after pfnProbe and if needed before pfnDestruct.
1403 *
1404 * @param pVM Pointer to the shared VM structure.
1405 * @param pvData Pointer to the instance data.
1406 */
1407 DECLCALLBACKMEMBER(void, pfnTerm)(PVM pVM, void *pvData);
1408
1409 /**
1410 * Queries the version of the running OS.
1411 *
1412 * This is only called after pfnInit().
1413 *
1414 * @returns VBox status code.
1415 * @param pVM Pointer to the shared VM structure.
1416 * @param pvData Pointer to the instance data.
1417 * @param pszVersion Where to store the version string.
1418 * @param cchVersion The size of the version string buffer.
1419 */
1420 DECLCALLBACKMEMBER(int, pfnQueryVersion)(PVM pVM, void *pvData, char *pszVersion, size_t cchVersion);
1421
1422 /**
1423 * Queries the pointer to a interface.
1424 *
1425 * This is called after pfnProbe.
1426 *
1427 * @returns Pointer to the interface if available, NULL if not available.
1428 * @param pVM Pointer to the shared VM structure.
1429 * @param pvData Pointer to the instance data.
1430 * @param enmIf The interface identifier.
1431 */
1432 DECLCALLBACKMEMBER(void *, pfnQueryInterface)(PVM pVM, void *pvData, DBGFOSINTERFACE enmIf);
1433
1434 /** Trailing magic (DBGFOSREG_MAGIC). */
1435 uint32_t u32EndMagic;
1436} DBGFOSREG;
1437/** Pointer to a Guest OS digger registration record. */
1438typedef DBGFOSREG *PDBGFOSREG;
1439/** Pointer to a const Guest OS digger registration record. */
1440typedef DBGFOSREG const *PCDBGFOSREG;
1441
1442/** Magic value for DBGFOSREG::u32Magic and DBGFOSREG::u32EndMagic. (Hitomi Kanehara) */
1443#define DBGFOSREG_MAGIC 0x19830808
1444
1445VMMR3DECL(int) DBGFR3OSRegister(PVM pVM, PCDBGFOSREG pReg);
1446VMMR3DECL(int) DBGFR3OSDeregister(PVM pVM, PCDBGFOSREG pReg);
1447VMMR3DECL(int) DBGFR3OSDetect(PVM pVM, char *pszName, size_t cchName);
1448VMMR3DECL(int) DBGFR3OSQueryNameAndVersion(PVM pVM, char *pszName, size_t cchName, char *pszVersion, size_t cchVersion);
1449VMMR3DECL(void *) DBGFR3OSQueryInterface(PVM pVM, DBGFOSINTERFACE enmIf);
1450
1451
1452VMMR3DECL(int) DBGFR3CoreWrite(PVM pVM, const char *pszFilename, bool fReplaceFile);
1453
1454/** @} */
1455
1456
1457RT_C_DECLS_END
1458
1459#endif
1460
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