xref: /freebsd/usr.sbin/bhyve/gdb/amd64.xml (revision f81cdf24ba5436367377f7c8e8f51f6df2a75ca7)
1*f81cdf24SMark Johnston<?xml version="1.0"?>
2*f81cdf24SMark Johnston<!-- Copyright (C) 2010-2017 Free Software Foundation, Inc.
3*f81cdf24SMark Johnston
4*f81cdf24SMark Johnston     Copying and distribution of this file, with or without modification,
5*f81cdf24SMark Johnston     are permitted in any medium without royalty provided the copyright
6*f81cdf24SMark Johnston     notice and this notice are preserved.  -->
7*f81cdf24SMark Johnston
8*f81cdf24SMark Johnston<!-- x86_64 64bit -->
9*f81cdf24SMark Johnston
10*f81cdf24SMark Johnston<!DOCTYPE target SYSTEM "gdb-target.dtd">
11*f81cdf24SMark Johnston
12*f81cdf24SMark Johnston<feature name="org.gnu.gdb.i386.core">
13*f81cdf24SMark Johnston  <flags id="x64_eflags" size="4">
14*f81cdf24SMark Johnston	<field name="" start="22" end="31"/>
15*f81cdf24SMark Johnston	<field name="ID" start="21" end="21"/>
16*f81cdf24SMark Johnston	<field name="VIP" start="20" end="20"/>
17*f81cdf24SMark Johnston	<field name="VIF" start="19" end="19"/>
18*f81cdf24SMark Johnston	<field name="AC" start="18" end="18"/>
19*f81cdf24SMark Johnston	<field name="VM" start="17" end="17"/>
20*f81cdf24SMark Johnston	<field name="RF" start="16" end="16"/>
21*f81cdf24SMark Johnston	<field name="" start="15" end="15"/>
22*f81cdf24SMark Johnston	<field name="NT" start="14" end="14"/>
23*f81cdf24SMark Johnston	<field name="IOPL" start="12" end="13"/>
24*f81cdf24SMark Johnston	<field name="OF" start="11" end="11"/>
25*f81cdf24SMark Johnston	<field name="DF" start="10" end="10"/>
26*f81cdf24SMark Johnston	<field name="IF" start="9" end="9"/>
27*f81cdf24SMark Johnston	<field name="TF" start="8" end="8"/>
28*f81cdf24SMark Johnston	<field name="SF" start="7" end="7"/>
29*f81cdf24SMark Johnston	<field name="ZF" start="6" end="6"/>
30*f81cdf24SMark Johnston	<field name="" start="5" end="5"/>
31*f81cdf24SMark Johnston	<field name="AF" start="4" end="4"/>
32*f81cdf24SMark Johnston	<field name="" start="3" end="3"/>
33*f81cdf24SMark Johnston	<field name="PF" start="2" end="2"/>
34*f81cdf24SMark Johnston	<field name="" start="1" end="1"/>
35*f81cdf24SMark Johnston	<field name="CF" start="0" end="0"/>
36*f81cdf24SMark Johnston  </flags>
37*f81cdf24SMark Johnston
38*f81cdf24SMark Johnston  <!-- General registers -->
39*f81cdf24SMark Johnston
40*f81cdf24SMark Johnston  <reg name="rax" bitsize="64" type="int64" regnum="0"/>
41*f81cdf24SMark Johnston  <reg name="rbx" bitsize="64" type="int64"/>
42*f81cdf24SMark Johnston  <reg name="rcx" bitsize="64" type="int64"/>
43*f81cdf24SMark Johnston  <reg name="rdx" bitsize="64" type="int64"/>
44*f81cdf24SMark Johnston  <reg name="rsi" bitsize="64" type="int64"/>
45*f81cdf24SMark Johnston  <reg name="rdi" bitsize="64" type="int64"/>
46*f81cdf24SMark Johnston  <reg name="rbp" bitsize="64" type="data_ptr"/>
47*f81cdf24SMark Johnston  <reg name="rsp" bitsize="64" type="data_ptr"/>
48*f81cdf24SMark Johnston  <reg name="r8" bitsize="64" type="int64"/>
49*f81cdf24SMark Johnston  <reg name="r9" bitsize="64" type="int64"/>
50*f81cdf24SMark Johnston  <reg name="r10" bitsize="64" type="int64"/>
51*f81cdf24SMark Johnston  <reg name="r11" bitsize="64" type="int64"/>
52*f81cdf24SMark Johnston  <reg name="r12" bitsize="64" type="int64"/>
53*f81cdf24SMark Johnston  <reg name="r13" bitsize="64" type="int64"/>
54*f81cdf24SMark Johnston  <reg name="r14" bitsize="64" type="int64"/>
55*f81cdf24SMark Johnston  <reg name="r15" bitsize="64" type="int64"/>
56*f81cdf24SMark Johnston
57*f81cdf24SMark Johnston  <reg name="rip" bitsize="64" type="code_ptr"/>
58*f81cdf24SMark Johnston  <reg name="eflags" bitsize="32" type="x64_eflags"/>
59*f81cdf24SMark Johnston
60*f81cdf24SMark Johnston  <!-- Segment registers -->
61*f81cdf24SMark Johnston
62*f81cdf24SMark Johnston  <reg name="cs" bitsize="32" type="int32"/>
63*f81cdf24SMark Johnston  <reg name="ss" bitsize="32" type="int32"/>
64*f81cdf24SMark Johnston  <reg name="ds" bitsize="32" type="int32"/>
65*f81cdf24SMark Johnston  <reg name="es" bitsize="32" type="int32"/>
66*f81cdf24SMark Johnston  <reg name="fs" bitsize="32" type="int32"/>
67*f81cdf24SMark Johnston  <reg name="gs" bitsize="32" type="int32"/>
68*f81cdf24SMark Johnston
69*f81cdf24SMark Johnston  <!-- Segment descriptor caches and TLS base MSRs -->
70*f81cdf24SMark Johnston
71*f81cdf24SMark Johnston  <!--reg name="cs_base" bitsize="64" type="int64"/>
72*f81cdf24SMark Johnston  <reg name="ss_base" bitsize="64" type="int64"/>
73*f81cdf24SMark Johnston  <reg name="ds_base" bitsize="64" type="int64"/>
74*f81cdf24SMark Johnston  <reg name="es_base" bitsize="64" type="int64"/-->
75*f81cdf24SMark Johnston  <reg name="fs_base" bitsize="64" type="int64"/>
76*f81cdf24SMark Johnston  <reg name="gs_base" bitsize="64" type="int64"/>
77*f81cdf24SMark Johnston  <reg name="k_gs_base" bitsize="64" type="int64"/>
78*f81cdf24SMark Johnston
79*f81cdf24SMark Johnston  <!-- Control registers -->
80*f81cdf24SMark Johnston
81*f81cdf24SMark Johnston  <flags id="x64_cr0" size="8">
82*f81cdf24SMark Johnston	<field name="PG" start="31" end="31"/>
83*f81cdf24SMark Johnston	<field name="CD" start="30" end="30"/>
84*f81cdf24SMark Johnston	<field name="NW" start="29" end="29"/>
85*f81cdf24SMark Johnston	<field name="AM" start="18" end="18"/>
86*f81cdf24SMark Johnston	<field name="WP" start="16" end="16"/>
87*f81cdf24SMark Johnston	<field name="NE" start="5" end="5"/>
88*f81cdf24SMark Johnston	<field name="ET" start="4" end="4"/>
89*f81cdf24SMark Johnston	<field name="TS" start="3" end="3"/>
90*f81cdf24SMark Johnston	<field name="EM" start="2" end="2"/>
91*f81cdf24SMark Johnston	<field name="MP" start="1" end="1"/>
92*f81cdf24SMark Johnston	<field name="PE" start="0" end="0"/>
93*f81cdf24SMark Johnston  </flags>
94*f81cdf24SMark Johnston
95*f81cdf24SMark Johnston  <flags id="x64_cr3" size="8">
96*f81cdf24SMark Johnston	<field name="PDBR" start="12" end="63"/>
97*f81cdf24SMark Johnston	<!--field name="" start="3" end="11"/>
98*f81cdf24SMark Johnston	<field name="WT" start="2" end="2"/>
99*f81cdf24SMark Johnston	<field name="CD" start="1" end="1"/>
100*f81cdf24SMark Johnston	<field name="" start="0" end="0"/-->
101*f81cdf24SMark Johnston	<field name="PCID" start="0" end="11"/>
102*f81cdf24SMark Johnston  </flags>
103*f81cdf24SMark Johnston
104*f81cdf24SMark Johnston  <flags id="x64_cr4" size="8">
105*f81cdf24SMark Johnston	<field name="PKE" start="22" end="22"/>
106*f81cdf24SMark Johnston	<field name="SMAP" start="21" end="21"/>
107*f81cdf24SMark Johnston	<field name="SMEP" start="20" end="20"/>
108*f81cdf24SMark Johnston	<field name="OSXSAVE" start="18" end="18"/>
109*f81cdf24SMark Johnston	<field name="PCIDE" start="17" end="17"/>
110*f81cdf24SMark Johnston	<field name="FSGSBASE" start="16" end="16"/>
111*f81cdf24SMark Johnston	<field name="SMXE" start="14" end="14"/>
112*f81cdf24SMark Johnston	<field name="VMXE" start="13" end="13"/>
113*f81cdf24SMark Johnston	<field name="LA57" start="12" end="12"/>
114*f81cdf24SMark Johnston	<field name="UMIP" start="11" end="11"/>
115*f81cdf24SMark Johnston	<field name="OSXMMEXCPT" start="10" end="10"/>
116*f81cdf24SMark Johnston	<field name="OSFXSR" start="9" end="9"/>
117*f81cdf24SMark Johnston	<field name="PCE" start="8" end="8"/>
118*f81cdf24SMark Johnston	<field name="PGE" start="7" end="7"/>
119*f81cdf24SMark Johnston	<field name="MCE" start="6" end="6"/>
120*f81cdf24SMark Johnston	<field name="PAE" start="5" end="5"/>
121*f81cdf24SMark Johnston	<field name="PSE" start="4" end="4"/>
122*f81cdf24SMark Johnston	<field name="DE" start="3" end="3"/>
123*f81cdf24SMark Johnston	<field name="TSD" start="2" end="2"/>
124*f81cdf24SMark Johnston	<field name="PVI" start="1" end="1"/>
125*f81cdf24SMark Johnston	<field name="VME" start="0" end="0"/>
126*f81cdf24SMark Johnston  </flags>
127*f81cdf24SMark Johnston
128*f81cdf24SMark Johnston  <flags id="x64_efer" size="8">
129*f81cdf24SMark Johnston	<field name="TCE" start="15" end="15"/>
130*f81cdf24SMark Johnston	<field name="FFXSR" start="14" end="14"/>
131*f81cdf24SMark Johnston	<field name="LMSLE" start="13" end="13"/>
132*f81cdf24SMark Johnston	<field name="SVME" start="12" end="12"/>
133*f81cdf24SMark Johnston	<field name="NXE" start="11" end="11"/>
134*f81cdf24SMark Johnston	<field name="LMA" start="10" end="10"/>
135*f81cdf24SMark Johnston	<field name="LME" start="8" end="8"/>
136*f81cdf24SMark Johnston	<field name="SCE" start="0" end="0"/>
137*f81cdf24SMark Johnston  </flags>
138*f81cdf24SMark Johnston
139*f81cdf24SMark Johnston  <reg name="cr0" bitsize="64" type="x64_cr0"/>
140*f81cdf24SMark Johnston  <reg name="cr2" bitsize="64" type="int64"/>
141*f81cdf24SMark Johnston  <reg name="cr3" bitsize="64" type="x64_cr3"/>
142*f81cdf24SMark Johnston  <reg name="cr4" bitsize="64" type="x64_cr4"/>
143*f81cdf24SMark Johnston  <reg name="cr8" bitsize="64" type="int64"/>
144*f81cdf24SMark Johnston  <reg name="efer" bitsize="64" type="x64_efer"/>
145*f81cdf24SMark Johnston
146*f81cdf24SMark Johnston  <!-- x87 FPU -->
147*f81cdf24SMark Johnston
148*f81cdf24SMark Johnston  <reg name="st0" bitsize="80" type="i387_ext"/>
149*f81cdf24SMark Johnston  <reg name="st1" bitsize="80" type="i387_ext"/>
150*f81cdf24SMark Johnston  <reg name="st2" bitsize="80" type="i387_ext"/>
151*f81cdf24SMark Johnston  <reg name="st3" bitsize="80" type="i387_ext"/>
152*f81cdf24SMark Johnston  <reg name="st4" bitsize="80" type="i387_ext"/>
153*f81cdf24SMark Johnston  <reg name="st5" bitsize="80" type="i387_ext"/>
154*f81cdf24SMark Johnston  <reg name="st6" bitsize="80" type="i387_ext"/>
155*f81cdf24SMark Johnston  <reg name="st7" bitsize="80" type="i387_ext"/>
156*f81cdf24SMark Johnston
157*f81cdf24SMark Johnston  <reg name="fctrl" bitsize="32" type="int" group="float"/>
158*f81cdf24SMark Johnston  <reg name="fstat" bitsize="32" type="int" group="float"/>
159*f81cdf24SMark Johnston  <reg name="ftag" bitsize="32" type="int" group="float"/>
160*f81cdf24SMark Johnston  <reg name="fiseg" bitsize="32" type="int" group="float"/>
161*f81cdf24SMark Johnston  <reg name="fioff" bitsize="32" type="int" group="float"/>
162*f81cdf24SMark Johnston  <reg name="foseg" bitsize="32" type="int" group="float"/>
163*f81cdf24SMark Johnston  <reg name="fooff" bitsize="32" type="int" group="float"/>
164*f81cdf24SMark Johnston  <reg name="fop" bitsize="32" type="int" group="float"/>
165*f81cdf24SMark Johnston</feature>
166