VirtualBox

source: vbox/trunk/include/VBox/vmm/dbgfcorefmt.h@ 58650

Last change on this file since 58650 was 58106, checked in by vboxsync, 9 years ago

include,misc: Corrected a bunch of doxygen errors.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.9 KB
Line 
1/** @file
2 * DBGF - Debugger Facility, VM Core File Format.
3 */
4
5/*
6 * Copyright (C) 2010-2015 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_dbgfcore_h
27#define ___VBox_vmm_dbgfcore_h
28
29#include <VBox/types.h>
30#include <VBox/vmm/cpumctx.h>
31#include <iprt/assert.h>
32
33
34RT_C_DECLS_BEGIN
35
36
37/** @defgroup grp_dbgf_corefmt VM Core File Format
38 * @ingroup grp_dbgf
39 *
40 * @todo Add description of the core file format and how the structures in this
41 * file relate to it. Point to X86XSAVEAREA in x86.h for the CPU's
42 * FPU/SSE/AVX/XXX state.
43 * @todo Add the note names.
44 *
45 * @{
46 */
47
48/** DBGCORECOREDESCRIPTOR::u32Magic. */
49#define DBGFCORE_MAGIC UINT32_C(0xc01ac0de)
50/** DBGCORECOREDESCRIPTOR::u32FmtVersion. */
51#define DBGFCORE_FMT_VERSION UINT32_C(0x00010003)
52
53/**
54 * An x86 segment selector.
55 */
56typedef struct DBGFCORESEL
57{
58 uint64_t uBase;
59 uint32_t uLimit;
60 uint32_t uAttr;
61 uint16_t uSel;
62 uint16_t uReserved0;
63 uint32_t uReserved1;
64} VBOXX86SEL;
65AssertCompileSizeAlignment(DBGFCORESEL, 8);
66
67/**
68 * A gdtr/ldtr descriptor.
69 */
70typedef struct DBGFCOREXDTR
71{
72 uint64_t uAddr;
73 uint32_t cb;
74 uint32_t uReserved0;
75} DBGFXDTR;
76AssertCompileSizeAlignment(DBGFCORESEL, 8);
77
78/**
79 * A simpler to parse CPU dump than CPUMCTX.
80 *
81 * Please bump DBGFCORE_FMT_VERSION by 1 if you make any changes to this
82 * structure.
83 */
84typedef struct DBGFCORECPU
85{
86 uint64_t rax;
87 uint64_t rbx;
88 uint64_t rcx;
89 uint64_t rdx;
90 uint64_t rsi;
91 uint64_t rdi;
92 uint64_t r8;
93 uint64_t r9;
94 uint64_t r10;
95 uint64_t r11;
96 uint64_t r12;
97 uint64_t r13;
98 uint64_t r14;
99 uint64_t r15;
100 uint64_t rip;
101 uint64_t rsp;
102 uint64_t rbp;
103 DBGFCORESEL cs;
104 DBGFCORESEL ds;
105 DBGFCORESEL es;
106 DBGFCORESEL fs;
107 DBGFCORESEL gs;
108 DBGFCORESEL ss;
109 uint64_t cr0;
110 uint64_t cr2;
111 uint64_t cr3;
112 uint64_t cr4;
113 uint64_t dr[8];
114 DBGFCOREXDTR gdtr;
115 DBGFCOREXDTR idtr;
116 VBOXX86SEL ldtr;
117 VBOXX86SEL tr;
118 union
119 {
120 uint64_t cs;
121 uint64_t eip;
122 uint64_t esp;
123 } sysenter;
124 uint64_t msrEFER;
125 uint64_t msrSTAR;
126 uint64_t msrPAT;
127 uint64_t msrLSTAR;
128 uint64_t msrCSTAR;
129 uint64_t msrSFMASK;
130 uint64_t msrKernelGSBase;
131 uint64_t msrApicBase;
132 uint64_t aXcr[2];
133 uint32_t cbExt;
134 uint32_t uPadding0;
135 X86XSAVEAREA ext;
136} DBGFCORECPU;
137/** Pointer to a DBGF-core CPU. */
138typedef DBGFCORECPU *PDBGFCORECPU;
139/** Pointer to the const DBGF-core CPU. */
140typedef const DBGFCORECPU *PCDBGFCORECPU;
141AssertCompileMemberAlignment(DBGFCORECPU, cr0, 8);
142AssertCompileMemberAlignment(DBGFCORECPU, msrEFER, 8);
143AssertCompileMemberAlignment(DBGFCORECPU, ext, 8);
144AssertCompileSizeAlignment(DBGFCORECPU, 8);
145
146/**
147 * The DBGF Core descriptor.
148 */
149typedef struct DBGFCOREDESCRIPTOR
150{
151 /** The core file magic (DBGFCORE_MAGIC) */
152 uint32_t u32Magic;
153 /** The core file format version (DBGFCORE_FMT_VERSION). */
154 uint32_t u32FmtVersion;
155 /** Size of this structure (sizeof(DBGFCOREDESCRIPTOR)). */
156 uint32_t cbSelf;
157 /** VirtualBox version. */
158 uint32_t u32VBoxVersion;
159 /** VirtualBox revision. */
160 uint32_t u32VBoxRevision;
161 /** Number of CPUs. */
162 uint32_t cCpus;
163} DBGFCOREDESCRIPTOR;
164AssertCompileSizeAlignment(DBGFCOREDESCRIPTOR, 8);
165/** Pointer to DBGFCOREDESCRIPTOR data. */
166typedef DBGFCOREDESCRIPTOR *PDBGFCOREDESCRIPTOR;
167
168/** @} */
169
170RT_C_DECLS_END
171
172#endif
173
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