annotate src/cpu/x86/vm/register_x86.hpp @ 4582:b24386206122

Made all vm builds go into subdirectories, even product builds to simplify building the various types of VMs (server, client and graal). Made HotSpot build jobs use the number of CPUs on the host machine.
author Doug Simon <doug.simon@oracle.com>
date Mon, 13 Feb 2012 23:13:37 +0100
parents f95d63e2154a
children 8c92982cbbc4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
2 * Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
25 #ifndef CPU_X86_VM_REGISTER_X86_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #define CPU_X86_VM_REGISTER_X86_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "asm/register.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "vm_version_x86.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30
0
a61af66fc99e Initial load
duke
parents:
diff changeset
31 class VMRegImpl;
a61af66fc99e Initial load
duke
parents:
diff changeset
32 typedef VMRegImpl* VMReg;
a61af66fc99e Initial load
duke
parents:
diff changeset
33
a61af66fc99e Initial load
duke
parents:
diff changeset
34 // Use Register as shortcut
a61af66fc99e Initial load
duke
parents:
diff changeset
35 class RegisterImpl;
a61af66fc99e Initial load
duke
parents:
diff changeset
36 typedef RegisterImpl* Register;
a61af66fc99e Initial load
duke
parents:
diff changeset
37
a61af66fc99e Initial load
duke
parents:
diff changeset
38
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // The implementation of integer registers for the ia32 architecture
a61af66fc99e Initial load
duke
parents:
diff changeset
40 inline Register as_Register(int encoding) {
a61af66fc99e Initial load
duke
parents:
diff changeset
41 return (Register)(intptr_t) encoding;
a61af66fc99e Initial load
duke
parents:
diff changeset
42 }
a61af66fc99e Initial load
duke
parents:
diff changeset
43
a61af66fc99e Initial load
duke
parents:
diff changeset
44 class RegisterImpl: public AbstractRegisterImpl {
a61af66fc99e Initial load
duke
parents:
diff changeset
45 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
46 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
47 #ifndef AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
48 number_of_registers = 8,
a61af66fc99e Initial load
duke
parents:
diff changeset
49 number_of_byte_registers = 4
a61af66fc99e Initial load
duke
parents:
diff changeset
50 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
51 number_of_registers = 16,
a61af66fc99e Initial load
duke
parents:
diff changeset
52 number_of_byte_registers = 16
a61af66fc99e Initial load
duke
parents:
diff changeset
53 #endif // AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
54 };
a61af66fc99e Initial load
duke
parents:
diff changeset
55
a61af66fc99e Initial load
duke
parents:
diff changeset
56 // derived registers, offsets, and addresses
a61af66fc99e Initial load
duke
parents:
diff changeset
57 Register successor() const { return as_Register(encoding() + 1); }
a61af66fc99e Initial load
duke
parents:
diff changeset
58
a61af66fc99e Initial load
duke
parents:
diff changeset
59 // construction
a61af66fc99e Initial load
duke
parents:
diff changeset
60 inline friend Register as_Register(int encoding);
a61af66fc99e Initial load
duke
parents:
diff changeset
61
a61af66fc99e Initial load
duke
parents:
diff changeset
62 VMReg as_VMReg();
a61af66fc99e Initial load
duke
parents:
diff changeset
63
a61af66fc99e Initial load
duke
parents:
diff changeset
64 // accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
65 int encoding() const { assert(is_valid(), "invalid register"); return (intptr_t)this; }
a61af66fc99e Initial load
duke
parents:
diff changeset
66 bool is_valid() const { return 0 <= (intptr_t)this && (intptr_t)this < number_of_registers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
67 bool has_byte_register() const { return 0 <= (intptr_t)this && (intptr_t)this < number_of_byte_registers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
68 const char* name() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
69 };
a61af66fc99e Initial load
duke
parents:
diff changeset
70
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // The integer registers of the ia32/amd64 architecture
a61af66fc99e Initial load
duke
parents:
diff changeset
72
a61af66fc99e Initial load
duke
parents:
diff changeset
73 CONSTANT_REGISTER_DECLARATION(Register, noreg, (-1));
a61af66fc99e Initial load
duke
parents:
diff changeset
74
a61af66fc99e Initial load
duke
parents:
diff changeset
75
a61af66fc99e Initial load
duke
parents:
diff changeset
76 CONSTANT_REGISTER_DECLARATION(Register, rax, (0));
a61af66fc99e Initial load
duke
parents:
diff changeset
77 CONSTANT_REGISTER_DECLARATION(Register, rcx, (1));
a61af66fc99e Initial load
duke
parents:
diff changeset
78 CONSTANT_REGISTER_DECLARATION(Register, rdx, (2));
a61af66fc99e Initial load
duke
parents:
diff changeset
79 CONSTANT_REGISTER_DECLARATION(Register, rbx, (3));
a61af66fc99e Initial load
duke
parents:
diff changeset
80 CONSTANT_REGISTER_DECLARATION(Register, rsp, (4));
a61af66fc99e Initial load
duke
parents:
diff changeset
81 CONSTANT_REGISTER_DECLARATION(Register, rbp, (5));
a61af66fc99e Initial load
duke
parents:
diff changeset
82 CONSTANT_REGISTER_DECLARATION(Register, rsi, (6));
a61af66fc99e Initial load
duke
parents:
diff changeset
83 CONSTANT_REGISTER_DECLARATION(Register, rdi, (7));
a61af66fc99e Initial load
duke
parents:
diff changeset
84 #ifdef AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
85 CONSTANT_REGISTER_DECLARATION(Register, r8, (8));
a61af66fc99e Initial load
duke
parents:
diff changeset
86 CONSTANT_REGISTER_DECLARATION(Register, r9, (9));
a61af66fc99e Initial load
duke
parents:
diff changeset
87 CONSTANT_REGISTER_DECLARATION(Register, r10, (10));
a61af66fc99e Initial load
duke
parents:
diff changeset
88 CONSTANT_REGISTER_DECLARATION(Register, r11, (11));
a61af66fc99e Initial load
duke
parents:
diff changeset
89 CONSTANT_REGISTER_DECLARATION(Register, r12, (12));
a61af66fc99e Initial load
duke
parents:
diff changeset
90 CONSTANT_REGISTER_DECLARATION(Register, r13, (13));
a61af66fc99e Initial load
duke
parents:
diff changeset
91 CONSTANT_REGISTER_DECLARATION(Register, r14, (14));
a61af66fc99e Initial load
duke
parents:
diff changeset
92 CONSTANT_REGISTER_DECLARATION(Register, r15, (15));
a61af66fc99e Initial load
duke
parents:
diff changeset
93 #endif // AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
94
a61af66fc99e Initial load
duke
parents:
diff changeset
95 // Use FloatRegister as shortcut
a61af66fc99e Initial load
duke
parents:
diff changeset
96 class FloatRegisterImpl;
a61af66fc99e Initial load
duke
parents:
diff changeset
97 typedef FloatRegisterImpl* FloatRegister;
a61af66fc99e Initial load
duke
parents:
diff changeset
98
a61af66fc99e Initial load
duke
parents:
diff changeset
99 inline FloatRegister as_FloatRegister(int encoding) {
a61af66fc99e Initial load
duke
parents:
diff changeset
100 return (FloatRegister)(intptr_t) encoding;
a61af66fc99e Initial load
duke
parents:
diff changeset
101 }
a61af66fc99e Initial load
duke
parents:
diff changeset
102
a61af66fc99e Initial load
duke
parents:
diff changeset
103 // The implementation of floating point registers for the ia32 architecture
a61af66fc99e Initial load
duke
parents:
diff changeset
104 class FloatRegisterImpl: public AbstractRegisterImpl {
a61af66fc99e Initial load
duke
parents:
diff changeset
105 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
106 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
107 number_of_registers = 8
a61af66fc99e Initial load
duke
parents:
diff changeset
108 };
a61af66fc99e Initial load
duke
parents:
diff changeset
109
a61af66fc99e Initial load
duke
parents:
diff changeset
110 // construction
a61af66fc99e Initial load
duke
parents:
diff changeset
111 inline friend FloatRegister as_FloatRegister(int encoding);
a61af66fc99e Initial load
duke
parents:
diff changeset
112
a61af66fc99e Initial load
duke
parents:
diff changeset
113 VMReg as_VMReg();
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115 // derived registers, offsets, and addresses
a61af66fc99e Initial load
duke
parents:
diff changeset
116 FloatRegister successor() const { return as_FloatRegister(encoding() + 1); }
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
119 int encoding() const { assert(is_valid(), "invalid register"); return (intptr_t)this; }
a61af66fc99e Initial load
duke
parents:
diff changeset
120 bool is_valid() const { return 0 <= (intptr_t)this && (intptr_t)this < number_of_registers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
121 const char* name() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
122
a61af66fc99e Initial load
duke
parents:
diff changeset
123 };
a61af66fc99e Initial load
duke
parents:
diff changeset
124
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // Use XMMRegister as shortcut
a61af66fc99e Initial load
duke
parents:
diff changeset
126 class XMMRegisterImpl;
a61af66fc99e Initial load
duke
parents:
diff changeset
127 typedef XMMRegisterImpl* XMMRegister;
a61af66fc99e Initial load
duke
parents:
diff changeset
128
a61af66fc99e Initial load
duke
parents:
diff changeset
129 // Use MMXRegister as shortcut
a61af66fc99e Initial load
duke
parents:
diff changeset
130 class MMXRegisterImpl;
a61af66fc99e Initial load
duke
parents:
diff changeset
131 typedef MMXRegisterImpl* MMXRegister;
a61af66fc99e Initial load
duke
parents:
diff changeset
132
a61af66fc99e Initial load
duke
parents:
diff changeset
133 inline XMMRegister as_XMMRegister(int encoding) {
a61af66fc99e Initial load
duke
parents:
diff changeset
134 return (XMMRegister)(intptr_t)encoding;
a61af66fc99e Initial load
duke
parents:
diff changeset
135 }
a61af66fc99e Initial load
duke
parents:
diff changeset
136
a61af66fc99e Initial load
duke
parents:
diff changeset
137 inline MMXRegister as_MMXRegister(int encoding) {
a61af66fc99e Initial load
duke
parents:
diff changeset
138 return (MMXRegister)(intptr_t)encoding;
a61af66fc99e Initial load
duke
parents:
diff changeset
139 }
a61af66fc99e Initial load
duke
parents:
diff changeset
140
a61af66fc99e Initial load
duke
parents:
diff changeset
141 // The implementation of XMM registers for the IA32 architecture
a61af66fc99e Initial load
duke
parents:
diff changeset
142 class XMMRegisterImpl: public AbstractRegisterImpl {
a61af66fc99e Initial load
duke
parents:
diff changeset
143 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
144 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
145 #ifndef AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
146 number_of_registers = 8
a61af66fc99e Initial load
duke
parents:
diff changeset
147 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
148 number_of_registers = 16
a61af66fc99e Initial load
duke
parents:
diff changeset
149 #endif // AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
150 };
a61af66fc99e Initial load
duke
parents:
diff changeset
151
a61af66fc99e Initial load
duke
parents:
diff changeset
152 // construction
a61af66fc99e Initial load
duke
parents:
diff changeset
153 friend XMMRegister as_XMMRegister(int encoding);
a61af66fc99e Initial load
duke
parents:
diff changeset
154
a61af66fc99e Initial load
duke
parents:
diff changeset
155 VMReg as_VMReg();
a61af66fc99e Initial load
duke
parents:
diff changeset
156
a61af66fc99e Initial load
duke
parents:
diff changeset
157 // derived registers, offsets, and addresses
a61af66fc99e Initial load
duke
parents:
diff changeset
158 XMMRegister successor() const { return as_XMMRegister(encoding() + 1); }
a61af66fc99e Initial load
duke
parents:
diff changeset
159
a61af66fc99e Initial load
duke
parents:
diff changeset
160 // accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
161 int encoding() const { assert(is_valid(), "invalid register"); return (intptr_t)this; }
a61af66fc99e Initial load
duke
parents:
diff changeset
162 bool is_valid() const { return 0 <= (intptr_t)this && (intptr_t)this < number_of_registers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
163 const char* name() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
164 };
a61af66fc99e Initial load
duke
parents:
diff changeset
165
a61af66fc99e Initial load
duke
parents:
diff changeset
166
a61af66fc99e Initial load
duke
parents:
diff changeset
167 // The XMM registers, for P3 and up chips
a61af66fc99e Initial load
duke
parents:
diff changeset
168 CONSTANT_REGISTER_DECLARATION(XMMRegister, xnoreg , (-1));
a61af66fc99e Initial load
duke
parents:
diff changeset
169 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm0 , ( 0));
a61af66fc99e Initial load
duke
parents:
diff changeset
170 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm1 , ( 1));
a61af66fc99e Initial load
duke
parents:
diff changeset
171 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm2 , ( 2));
a61af66fc99e Initial load
duke
parents:
diff changeset
172 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm3 , ( 3));
a61af66fc99e Initial load
duke
parents:
diff changeset
173 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm4 , ( 4));
a61af66fc99e Initial load
duke
parents:
diff changeset
174 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm5 , ( 5));
a61af66fc99e Initial load
duke
parents:
diff changeset
175 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm6 , ( 6));
a61af66fc99e Initial load
duke
parents:
diff changeset
176 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm7 , ( 7));
a61af66fc99e Initial load
duke
parents:
diff changeset
177 #ifdef AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
178 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm8, (8));
a61af66fc99e Initial load
duke
parents:
diff changeset
179 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm9, (9));
a61af66fc99e Initial load
duke
parents:
diff changeset
180 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm10, (10));
a61af66fc99e Initial load
duke
parents:
diff changeset
181 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm11, (11));
a61af66fc99e Initial load
duke
parents:
diff changeset
182 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm12, (12));
a61af66fc99e Initial load
duke
parents:
diff changeset
183 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm13, (13));
a61af66fc99e Initial load
duke
parents:
diff changeset
184 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm14, (14));
a61af66fc99e Initial load
duke
parents:
diff changeset
185 CONSTANT_REGISTER_DECLARATION(XMMRegister, xmm15, (15));
a61af66fc99e Initial load
duke
parents:
diff changeset
186 #endif // AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
187
a61af66fc99e Initial load
duke
parents:
diff changeset
188 // Only used by the 32bit stubGenerator. These can't be described by vmreg and hence
a61af66fc99e Initial load
duke
parents:
diff changeset
189 // can't be described in oopMaps and therefore can't be used by the compilers (at least
a61af66fc99e Initial load
duke
parents:
diff changeset
190 // were deopt might wan't to see them).
a61af66fc99e Initial load
duke
parents:
diff changeset
191
a61af66fc99e Initial load
duke
parents:
diff changeset
192 // The MMX registers, for P3 and up chips
a61af66fc99e Initial load
duke
parents:
diff changeset
193 CONSTANT_REGISTER_DECLARATION(MMXRegister, mnoreg , (-1));
a61af66fc99e Initial load
duke
parents:
diff changeset
194 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx0 , ( 0));
a61af66fc99e Initial load
duke
parents:
diff changeset
195 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx1 , ( 1));
a61af66fc99e Initial load
duke
parents:
diff changeset
196 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx2 , ( 2));
a61af66fc99e Initial load
duke
parents:
diff changeset
197 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx3 , ( 3));
a61af66fc99e Initial load
duke
parents:
diff changeset
198 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx4 , ( 4));
a61af66fc99e Initial load
duke
parents:
diff changeset
199 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx5 , ( 5));
a61af66fc99e Initial load
duke
parents:
diff changeset
200 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx6 , ( 6));
a61af66fc99e Initial load
duke
parents:
diff changeset
201 CONSTANT_REGISTER_DECLARATION(MMXRegister, mmx7 , ( 7));
a61af66fc99e Initial load
duke
parents:
diff changeset
202
a61af66fc99e Initial load
duke
parents:
diff changeset
203
a61af66fc99e Initial load
duke
parents:
diff changeset
204 // Need to know the total number of registers of all sorts for SharedInfo.
a61af66fc99e Initial load
duke
parents:
diff changeset
205 // Define a class that exports it.
a61af66fc99e Initial load
duke
parents:
diff changeset
206 class ConcreteRegisterImpl : public AbstractRegisterImpl {
a61af66fc99e Initial load
duke
parents:
diff changeset
207 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
208 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
209 // A big enough number for C2: all the registers plus flags
a61af66fc99e Initial load
duke
parents:
diff changeset
210 // This number must be large enough to cover REG_COUNT (defined by c2) registers.
a61af66fc99e Initial load
duke
parents:
diff changeset
211 // There is no requirement that any ordering here matches any ordering c2 gives
a61af66fc99e Initial load
duke
parents:
diff changeset
212 // it's optoregs.
a61af66fc99e Initial load
duke
parents:
diff changeset
213
a61af66fc99e Initial load
duke
parents:
diff changeset
214 number_of_registers = RegisterImpl::number_of_registers +
a61af66fc99e Initial load
duke
parents:
diff changeset
215 #ifdef AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
216 RegisterImpl::number_of_registers + // "H" half of a 64bit register
a61af66fc99e Initial load
duke
parents:
diff changeset
217 #endif // AMD64
a61af66fc99e Initial load
duke
parents:
diff changeset
218 2 * FloatRegisterImpl::number_of_registers +
a61af66fc99e Initial load
duke
parents:
diff changeset
219 2 * XMMRegisterImpl::number_of_registers +
a61af66fc99e Initial load
duke
parents:
diff changeset
220 1 // eflags
a61af66fc99e Initial load
duke
parents:
diff changeset
221 };
a61af66fc99e Initial load
duke
parents:
diff changeset
222
a61af66fc99e Initial load
duke
parents:
diff changeset
223 static const int max_gpr;
a61af66fc99e Initial load
duke
parents:
diff changeset
224 static const int max_fpr;
a61af66fc99e Initial load
duke
parents:
diff changeset
225 static const int max_xmm;
a61af66fc99e Initial load
duke
parents:
diff changeset
226
a61af66fc99e Initial load
duke
parents:
diff changeset
227 };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
228
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
229 #endif // CPU_X86_VM_REGISTER_X86_HPP