Commit | Line | Data |
---|---|---|
40fb9820 | 1 | /* This file is automatically generated by i386-gen. Do not edit! */ |
f12dc422 | 2 | /* Copyright 2007, 2008, 2009, 2010, 2011 |
22da050b | 3 | Free Software Foundation, Inc. |
40fb9820 L |
4 | |
5 | This file is part of the GNU opcodes library. | |
6 | ||
7 | This library is free software; you can redistribute it and/or modify | |
8 | it under the terms of the GNU General Public License as published by | |
9 | the Free Software Foundation; either version 3, or (at your option) | |
10 | any later version. | |
11 | ||
12 | It is distributed in the hope that it will be useful, but WITHOUT | |
13 | ANY WARRANTY; without even the implied warranty of MERCHANTABILITY | |
14 | or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public | |
15 | License for more details. | |
16 | ||
17 | You should have received a copy of the GNU General Public License | |
18 | along with this program; if not, write to the Free Software | |
19 | Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, | |
20 | MA 02110-1301, USA. */ | |
21 | ||
22 | #define CPU_UNKNOWN_FLAGS \ | |
23 | { { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \ | |
22109423 | 24 | 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, \ |
752573b2 | 25 | 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1 } } |
40fb9820 L |
26 | |
27 | #define CPU_GENERIC32_FLAGS \ | |
28 | { { 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 29 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 30 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
31 | |
32 | #define CPU_GENERIC64_FLAGS \ | |
da98bb4c | 33 | { { 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, \ |
5dd85c99 | 34 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 35 | 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0 } } |
40fb9820 L |
36 | |
37 | #define CPU_NONE_FLAGS \ | |
38 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 39 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 40 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
41 | |
42 | #define CPU_I186_FLAGS \ | |
43 | { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 44 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 45 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
46 | |
47 | #define CPU_I286_FLAGS \ | |
48 | { { 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 49 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 50 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
51 | |
52 | #define CPU_I386_FLAGS \ | |
53 | { { 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 54 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 55 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
56 | |
57 | #define CPU_I486_FLAGS \ | |
58 | { { 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 59 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 60 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
61 | |
62 | #define CPU_I586_FLAGS \ | |
22109423 | 63 | { { 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 64 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 65 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
66 | |
67 | #define CPU_I686_FLAGS \ | |
22109423 | 68 | { { 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 69 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 70 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
22109423 L |
71 | |
72 | #define CPU_PENTIUMPRO_FLAGS \ | |
73 | { { 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, \ | |
74 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 75 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
76 | |
77 | #define CPU_P2_FLAGS \ | |
22109423 | 78 | { { 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, \ |
309d3373 | 79 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 80 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
81 | |
82 | #define CPU_P3_FLAGS \ | |
22109423 | 83 | { { 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, \ |
309d3373 | 84 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 85 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
86 | |
87 | #define CPU_P4_FLAGS \ | |
22109423 | 88 | { { 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, \ |
309d3373 | 89 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 90 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
91 | |
92 | #define CPU_NOCONA_FLAGS \ | |
22109423 | 93 | { { 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, \ |
5dd85c99 | 94 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 95 | 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0 } } |
40fb9820 L |
96 | |
97 | #define CPU_CORE_FLAGS \ | |
22109423 | 98 | { { 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, \ |
309d3373 | 99 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 100 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
101 | |
102 | #define CPU_CORE2_FLAGS \ | |
22109423 L |
103 | { { 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, \ |
104 | 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 105 | 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0 } } |
bd5295b2 L |
106 | |
107 | #define CPU_COREI7_FLAGS \ | |
22109423 L |
108 | { { 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, \ |
109 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 110 | 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 } } |
40fb9820 L |
111 | |
112 | #define CPU_K6_FLAGS \ | |
22109423 | 113 | { { 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, \ |
309d3373 | 114 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 115 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
116 | |
117 | #define CPU_K6_2_FLAGS \ | |
22109423 | 118 | { { 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, \ |
309d3373 | 119 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 120 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
121 | |
122 | #define CPU_ATHLON_FLAGS \ | |
22109423 | 123 | { { 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, \ |
309d3373 | 124 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 125 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
126 | |
127 | #define CPU_K8_FLAGS \ | |
22109423 | 128 | { { 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, \ |
c7b8aa3a | 129 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 130 | 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 } } |
40fb9820 L |
131 | |
132 | #define CPU_AMDFAM10_FLAGS \ | |
22109423 L |
133 | { { 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, \ |
134 | 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 135 | 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 } } |
69dd9865 | 136 | |
68339fdf | 137 | #define CPU_BDVER1_FLAGS \ |
22109423 L |
138 | { { 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, \ |
139 | 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, \ | |
752573b2 | 140 | 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 } } |
309d3373 JB |
141 | |
142 | #define CPU_8087_FLAGS \ | |
22109423 | 143 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 144 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 145 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
309d3373 JB |
146 | |
147 | #define CPU_287_FLAGS \ | |
22109423 | 148 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 149 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 150 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
309d3373 JB |
151 | |
152 | #define CPU_387_FLAGS \ | |
22109423 | 153 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 154 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 155 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
309d3373 JB |
156 | |
157 | #define CPU_ANY87_FLAGS \ | |
22109423 | 158 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 159 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 160 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
bd5295b2 L |
161 | |
162 | #define CPU_CLFLUSH_FLAGS \ | |
163 | { { 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
309d3373 | 164 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 165 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
bd5295b2 | 166 | |
22109423 | 167 | #define CPU_NOP_FLAGS \ |
bd5295b2 | 168 | { { 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
309d3373 | 169 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 170 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
22109423 L |
171 | |
172 | #define CPU_SYSCALL_FLAGS \ | |
173 | { { 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
174 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 175 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
176 | |
177 | #define CPU_MMX_FLAGS \ | |
22109423 | 178 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, \ |
309d3373 | 179 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 180 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
181 | |
182 | #define CPU_SSE_FLAGS \ | |
22109423 | 183 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, \ |
309d3373 | 184 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 185 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
186 | |
187 | #define CPU_SSE2_FLAGS \ | |
22109423 | 188 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, \ |
309d3373 | 189 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 190 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
191 | |
192 | #define CPU_SSE3_FLAGS \ | |
22109423 | 193 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
309d3373 | 194 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 195 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
196 | |
197 | #define CPU_SSSE3_FLAGS \ | |
22109423 L |
198 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
199 | 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 200 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
201 | |
202 | #define CPU_SSE4_1_FLAGS \ | |
22109423 L |
203 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
204 | 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 205 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
206 | |
207 | #define CPU_SSE4_2_FLAGS \ | |
22109423 L |
208 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
209 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 210 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
309d3373 JB |
211 | |
212 | #define CPU_ANY_SSE_FLAGS \ | |
22109423 L |
213 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, \ |
214 | 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 215 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 | 216 | |
6305a203 | 217 | #define CPU_VMX_FLAGS \ |
309d3373 | 218 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
22109423 | 219 | 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 220 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
6305a203 L |
221 | |
222 | #define CPU_SMX_FLAGS \ | |
309d3373 | 223 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
22109423 | 224 | 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 225 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
6305a203 | 226 | |
f03fe4c1 L |
227 | #define CPU_XSAVE_FLAGS \ |
228 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
22109423 | 229 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 230 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
c7b8aa3a L |
231 | |
232 | #define CPU_XSAVEOPT_FLAGS \ | |
233 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
22109423 | 234 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 235 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
c0f3af97 L |
236 | |
237 | #define CPU_AES_FLAGS \ | |
22109423 L |
238 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
239 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 240 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
c0f3af97 | 241 | |
594ab6a3 | 242 | #define CPU_PCLMUL_FLAGS \ |
22109423 L |
243 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
244 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, \ | |
752573b2 | 245 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
c0f3af97 L |
246 | |
247 | #define CPU_FMA_FLAGS \ | |
22109423 L |
248 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
249 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, \ | |
752573b2 | 250 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
922d8de8 DR |
251 | |
252 | #define CPU_FMA4_FLAGS \ | |
22109423 L |
253 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
254 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, \ | |
752573b2 | 255 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
5dd85c99 SP |
256 | |
257 | #define CPU_XOP_FLAGS \ | |
22109423 L |
258 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
259 | 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, \ | |
752573b2 | 260 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
f1f8f695 | 261 | |
f88c9eb0 | 262 | #define CPU_LWP_FLAGS \ |
f1f8f695 | 263 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
22109423 | 264 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, \ |
752573b2 | 265 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
f88c9eb0 | 266 | |
f12dc422 | 267 | #define CPU_BMI_FLAGS \ |
f88c9eb0 | 268 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
22109423 | 269 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, \ |
752573b2 JK |
270 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
271 | ||
272 | #define CPU_TBM_FLAGS \ | |
273 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
274 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
275 | 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } | |
f12dc422 L |
276 | |
277 | #define CPU_MOVBE_FLAGS \ | |
278 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
279 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 280 | 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
1b7f3fb0 L |
281 | |
282 | #define CPU_RDTSCP_FLAGS \ | |
283 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c7b8aa3a | 284 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 285 | 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0 } } |
f1f8f695 L |
286 | |
287 | #define CPU_EPT_FLAGS \ | |
288 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
22109423 | 289 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 290 | 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0 } } |
c7b8aa3a L |
291 | |
292 | #define CPU_FSGSBASE_FLAGS \ | |
293 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
294 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 295 | 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 } } |
c7b8aa3a L |
296 | |
297 | #define CPU_RDRND_FLAGS \ | |
298 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
299 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 300 | 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0 } } |
c7b8aa3a L |
301 | |
302 | #define CPU_F16C_FLAGS \ | |
303 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
304 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 305 | 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 } } |
f03fe4c1 | 306 | |
40fb9820 | 307 | #define CPU_3DNOW_FLAGS \ |
22109423 | 308 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, \ |
309d3373 | 309 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 310 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
311 | |
312 | #define CPU_3DNOWA_FLAGS \ | |
22109423 | 313 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, \ |
309d3373 | 314 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 315 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
316 | |
317 | #define CPU_PADLOCK_FLAGS \ | |
22109423 L |
318 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
319 | 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 320 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
321 | |
322 | #define CPU_SVME_FLAGS \ | |
309d3373 | 323 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
22109423 | 324 | 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 325 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
326 | |
327 | #define CPU_SSE4A_FLAGS \ | |
22109423 L |
328 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
329 | 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 330 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
331 | |
332 | #define CPU_ABM_FLAGS \ | |
333 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
22109423 | 334 | 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 335 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
c0f3af97 L |
336 | |
337 | #define CPU_AVX_FLAGS \ | |
22109423 L |
338 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, \ |
339 | 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
752573b2 | 340 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
309d3373 JB |
341 | |
342 | #define CPU_ANY_AVX_FLAGS \ | |
343 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
22109423 | 344 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
752573b2 | 345 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } } |
8a9036a4 L |
346 | |
347 | #define CPU_L1OM_FLAGS \ | |
348 | { { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \ | |
f88c9eb0 | 349 | 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \ |
752573b2 | 350 | 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1 } } |
40fb9820 L |
351 | |
352 | ||
353 | #define OPERAND_TYPE_NONE \ | |
354 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
7d5e4556 | 355 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 356 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
357 | |
358 | #define OPERAND_TYPE_REG8 \ | |
359 | { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
7d5e4556 | 360 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 361 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
362 | |
363 | #define OPERAND_TYPE_REG16 \ | |
364 | { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
7d5e4556 | 365 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 366 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
367 | |
368 | #define OPERAND_TYPE_REG32 \ | |
369 | { { 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
7d5e4556 | 370 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 371 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
372 | |
373 | #define OPERAND_TYPE_REG64 \ | |
374 | { { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
7d5e4556 | 375 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 376 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
377 | |
378 | #define OPERAND_TYPE_IMM1 \ | |
c0f3af97 | 379 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, \ |
7d5e4556 | 380 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 381 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
382 | |
383 | #define OPERAND_TYPE_IMM8 \ | |
c0f3af97 | 384 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, \ |
7d5e4556 | 385 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 386 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
387 | |
388 | #define OPERAND_TYPE_IMM8S \ | |
c0f3af97 | 389 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, \ |
7d5e4556 | 390 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 391 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
392 | |
393 | #define OPERAND_TYPE_IMM16 \ | |
c0f3af97 | 394 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, \ |
7d5e4556 | 395 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 396 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
397 | |
398 | #define OPERAND_TYPE_IMM32 \ | |
c0f3af97 | 399 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, \ |
7d5e4556 | 400 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 401 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
402 | |
403 | #define OPERAND_TYPE_IMM32S \ | |
c0f3af97 | 404 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, \ |
7d5e4556 | 405 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 406 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
407 | |
408 | #define OPERAND_TYPE_IMM64 \ | |
c0f3af97 | 409 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, \ |
7d5e4556 | 410 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 411 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
412 | |
413 | #define OPERAND_TYPE_BASEINDEX \ | |
7d5e4556 | 414 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 415 | 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 416 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
417 | |
418 | #define OPERAND_TYPE_DISP8 \ | |
c0f3af97 L |
419 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
420 | 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 421 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
422 | |
423 | #define OPERAND_TYPE_DISP16 \ | |
7d5e4556 | 424 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 425 | 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 426 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
427 | |
428 | #define OPERAND_TYPE_DISP32 \ | |
7d5e4556 | 429 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 430 | 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 431 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
432 | |
433 | #define OPERAND_TYPE_DISP32S \ | |
7d5e4556 | 434 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 435 | 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 436 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
437 | |
438 | #define OPERAND_TYPE_DISP64 \ | |
7d5e4556 | 439 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 440 | 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 441 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
442 | |
443 | #define OPERAND_TYPE_INOUTPORTREG \ | |
7d5e4556 | 444 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 445 | 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 446 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
447 | |
448 | #define OPERAND_TYPE_SHIFTCOUNT \ | |
7d5e4556 | 449 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 450 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 451 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
452 | |
453 | #define OPERAND_TYPE_CONTROL \ | |
c0f3af97 | 454 | { { 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
7d5e4556 | 455 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 456 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
457 | |
458 | #define OPERAND_TYPE_TEST \ | |
c0f3af97 | 459 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
7d5e4556 | 460 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 461 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
462 | |
463 | #define OPERAND_TYPE_DEBUG \ | |
7d5e4556 L |
464 | { { 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
465 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 466 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
467 | |
468 | #define OPERAND_TYPE_FLOATREG \ | |
7d5e4556 L |
469 | { { 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
470 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 471 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
472 | |
473 | #define OPERAND_TYPE_FLOATACC \ | |
474 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 475 | 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 476 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
477 | |
478 | #define OPERAND_TYPE_SREG2 \ | |
c0f3af97 | 479 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, \ |
7d5e4556 | 480 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 481 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
482 | |
483 | #define OPERAND_TYPE_SREG3 \ | |
c0f3af97 | 484 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, \ |
7d5e4556 | 485 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 486 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
487 | |
488 | #define OPERAND_TYPE_ACC \ | |
489 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 490 | 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 491 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
492 | |
493 | #define OPERAND_TYPE_JUMPABSOLUTE \ | |
494 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 495 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 496 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
497 | |
498 | #define OPERAND_TYPE_REGMMX \ | |
7d5e4556 L |
499 | { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
500 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 501 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
502 | |
503 | #define OPERAND_TYPE_REGXMM \ | |
7d5e4556 L |
504 | { { 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
505 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 506 | 0, 0, 0, 0, 0, 0 } } |
c0f3af97 L |
507 | |
508 | #define OPERAND_TYPE_REGYMM \ | |
509 | { { 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
510 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 511 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
512 | |
513 | #define OPERAND_TYPE_ESSEG \ | |
514 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 515 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 516 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
517 | |
518 | #define OPERAND_TYPE_ACC32 \ | |
519 | { { 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 520 | 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, \ |
a683cc34 | 521 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
522 | |
523 | #define OPERAND_TYPE_ACC64 \ | |
524 | { { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 525 | 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, \ |
a683cc34 | 526 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 | 527 | |
65da13b5 L |
528 | #define OPERAND_TYPE_INOUTPORTREG \ |
529 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
c0f3af97 | 530 | 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 531 | 0, 0, 0, 0, 0, 0 } } |
65da13b5 | 532 | |
40fb9820 | 533 | #define OPERAND_TYPE_REG16_INOUTPORTREG \ |
7d5e4556 | 534 | { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 535 | 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 536 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
537 | |
538 | #define OPERAND_TYPE_DISP16_32 \ | |
7d5e4556 | 539 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
c0f3af97 | 540 | 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 541 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
542 | |
543 | #define OPERAND_TYPE_ANYDISP \ | |
c0f3af97 L |
544 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
545 | 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 546 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
547 | |
548 | #define OPERAND_TYPE_IMM16_32 \ | |
c0f3af97 | 549 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, \ |
7d5e4556 | 550 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 551 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
552 | |
553 | #define OPERAND_TYPE_IMM16_32S \ | |
c0f3af97 | 554 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, \ |
7d5e4556 | 555 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 556 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
557 | |
558 | #define OPERAND_TYPE_IMM16_32_32S \ | |
c0f3af97 | 559 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, \ |
7d5e4556 | 560 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ |
a683cc34 | 561 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
562 | |
563 | #define OPERAND_TYPE_IMM32_32S_DISP32 \ | |
c0f3af97 L |
564 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, \ |
565 | 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 566 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
567 | |
568 | #define OPERAND_TYPE_IMM64_DISP64 \ | |
c0f3af97 L |
569 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, \ |
570 | 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 571 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
572 | |
573 | #define OPERAND_TYPE_IMM32_32S_64_DISP32 \ | |
c0f3af97 L |
574 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, \ |
575 | 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 | 576 | 0, 0, 0, 0, 0, 0 } } |
40fb9820 L |
577 | |
578 | #define OPERAND_TYPE_IMM32_32S_64_DISP32_64 \ | |
c0f3af97 L |
579 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, \ |
580 | 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
a683cc34 SP |
581 | 0, 0, 0, 0, 0, 0 } } |
582 | ||
583 | #define OPERAND_TYPE_VEC_IMM4 \ | |
584 | { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
585 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ | |
586 | 0, 0, 0, 0, 1, 0 } } |