[1] | 1 | /** @file
|
---|
| 2 | * Disassembler - opcode.h.
|
---|
| 3 | */
|
---|
| 4 |
|
---|
| 5 | /*
|
---|
[8155] | 6 | * Copyright (C) 2006-2007 Sun Microsystems, Inc.
|
---|
[1] | 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
|
---|
[5999] | 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.
|
---|
[8155] | 24 | *
|
---|
| 25 | * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
|
---|
| 26 | * Clara, CA 95054 USA or visit http://www.sun.com if you need
|
---|
| 27 | * additional information or have any questions.
|
---|
[1] | 28 | */
|
---|
| 29 |
|
---|
[3632] | 30 | #ifndef ___VBox_opcode_h
|
---|
| 31 | #define ___VBox_opcode_h
|
---|
[1] | 32 |
|
---|
| 33 | #define MODRM_MOD(a) (a>>6)
|
---|
| 34 | #define MODRM_REG(a) ((a>>3)&0x7)
|
---|
| 35 | #define MODRM_RM(a) (a&0x7)
|
---|
| 36 | #define MAKE_MODRM(mod, reg, rm) (((mod&3) << 6) | ((reg&7) << 3) | (rm&7))
|
---|
| 37 |
|
---|
| 38 | #define SIB_SCALE(a) (a>>6)
|
---|
| 39 | #define SIB_INDEX(a) ((a>>3)&0x7)
|
---|
| 40 | #define SIB_BASE(a) (a&0x7)
|
---|
| 41 |
|
---|
| 42 |
|
---|
| 43 | /** Full Intel X86 opcode list
|
---|
| 44 | * @{
|
---|
| 45 | */
|
---|
| 46 | #define OP_INVALID 0
|
---|
| 47 | #define OP_OPSIZE 1
|
---|
| 48 | #define OP_ADRSIZE 2
|
---|
| 49 | #define OP_SEG 3
|
---|
| 50 | #define OP_REPNE 4
|
---|
| 51 | #define OP_REPE 5
|
---|
| 52 | #define OP_LOCK 6 /* disassembler assumes this is the last prefix byte value!!!! */
|
---|
| 53 | #define OP_AND 7
|
---|
| 54 | #define OP_OR 8
|
---|
| 55 | #define OP_DAA 9
|
---|
| 56 | #define OP_SUB 10
|
---|
| 57 | #define OP_DAS 11
|
---|
| 58 | #define OP_XOR 12
|
---|
| 59 | #define OP_AAA 13
|
---|
| 60 | #define OP_CMP 14
|
---|
| 61 | #define OP_IMM_GRP1 15
|
---|
| 62 | #define OP_AAS 16
|
---|
| 63 | #define OP_INC 17
|
---|
| 64 | #define OP_DEC 18
|
---|
| 65 | #define OP_PUSHA 19
|
---|
| 66 | #define OP_POPA 20
|
---|
| 67 | #define OP_BOUND 21
|
---|
| 68 | #define OP_ARPL 22
|
---|
| 69 | #define OP_PUSH 23
|
---|
| 70 | #define OP_POP 24
|
---|
| 71 | #define OP_IMUL 25
|
---|
| 72 | #define OP_INSB 26
|
---|
| 73 | #define OP_INSWD 27
|
---|
| 74 | #define OP_OUTSB 28
|
---|
| 75 | #define OP_OUTSWD 29
|
---|
| 76 | #define OP_JO 30
|
---|
| 77 | #define OP_JNO 31
|
---|
| 78 | #define OP_JC 32
|
---|
| 79 | #define OP_JNC 33
|
---|
| 80 | #define OP_JE 34
|
---|
| 81 | #define OP_JNE 35
|
---|
| 82 | #define OP_JBE 36
|
---|
| 83 | #define OP_JNBE 37
|
---|
| 84 | #define OP_JS 38
|
---|
| 85 | #define OP_JNS 39
|
---|
| 86 | #define OP_JP 40
|
---|
| 87 | #define OP_JNP 41
|
---|
| 88 | #define OP_JL 42
|
---|
| 89 | #define OP_JNL 43
|
---|
| 90 | #define OP_JLE 44
|
---|
| 91 | #define OP_JNLE 45
|
---|
| 92 | #define OP_ADD 46
|
---|
| 93 | #define OP_TEST 47
|
---|
| 94 | #define OP_XCHG 48
|
---|
| 95 | #define OP_MOV 49
|
---|
| 96 | #define OP_LEA 50
|
---|
| 97 | #define OP_NOP 51
|
---|
| 98 | #define OP_CBW 52
|
---|
| 99 | #define OP_CWD 53
|
---|
| 100 | #define OP_CALL 54
|
---|
| 101 | #define OP_WAIT 55
|
---|
| 102 | #define OP_PUSHF 56
|
---|
| 103 | #define OP_POPF 57
|
---|
| 104 | #define OP_SAHF 58
|
---|
| 105 | #define OP_LAHF 59
|
---|
| 106 | #define OP_MOVSB 60
|
---|
| 107 | #define OP_MOVSWD 61
|
---|
| 108 | #define OP_CMPSB 62
|
---|
| 109 | #define OP_CMPWD 63
|
---|
| 110 | #define OP_STOSB 64
|
---|
| 111 | #define OP_STOSWD 65
|
---|
| 112 | #define OP_LODSB 66
|
---|
| 113 | #define OP_LODSWD 67
|
---|
| 114 | #define OP_SCASB 68
|
---|
| 115 | #define OP_SCASWD 69
|
---|
| 116 | #define OP_SHIFT_GRP2 70
|
---|
| 117 | #define OP_RETN 71
|
---|
| 118 | #define OP_LES 72
|
---|
| 119 | #define OP_LDS 73
|
---|
| 120 | #define OP_ENTER 74
|
---|
| 121 | #define OP_LEAVE 75
|
---|
| 122 | #define OP_RETF 76
|
---|
| 123 | #define OP_INT3 77
|
---|
| 124 | #define OP_INT 78
|
---|
| 125 | #define OP_INTO 79
|
---|
| 126 | #define OP_IRET 80
|
---|
| 127 | #define OP_AAM 81
|
---|
| 128 | #define OP_AAD 82
|
---|
| 129 | #define OP_XLAT 83
|
---|
| 130 | #define OP_ESCF0 84
|
---|
| 131 | #define OP_ESCF1 85
|
---|
| 132 | #define OP_ESCF2 86
|
---|
| 133 | #define OP_ESCF3 87
|
---|
| 134 | #define OP_ESCF4 88
|
---|
| 135 | #define OP_ESCF5 89
|
---|
| 136 | #define OP_ESCF6 90
|
---|
| 137 | #define OP_ESCF7 91
|
---|
| 138 | #define OP_LOOPNE 92
|
---|
| 139 | #define OP_LOOPE 93
|
---|
| 140 | #define OP_LOOP 94
|
---|
| 141 | #define OP_JECXZ 95
|
---|
| 142 | #define OP_IN 96
|
---|
| 143 | #define OP_OUT 97
|
---|
| 144 | #define OP_JMP 98
|
---|
| 145 | #define OP_2B_ESC 99
|
---|
| 146 | #define OP_ADC 100
|
---|
| 147 | #define OP_SBB 101
|
---|
| 148 | #define OP_HLT 102
|
---|
| 149 | #define OP_CMC 103
|
---|
| 150 | #define OP_UNARY_GRP3 104
|
---|
| 151 | #define OP_CLC 105
|
---|
| 152 | #define OP_STC 106
|
---|
| 153 | #define OP_CLI 107
|
---|
| 154 | #define OP_STI 108
|
---|
| 155 | #define OP_CLD 109
|
---|
| 156 | #define OP_STD 110
|
---|
| 157 | #define OP_INC_GRP4 111
|
---|
| 158 | #define OP_IND_GRP5 112
|
---|
| 159 | #define OP_GRP6 113
|
---|
| 160 | #define OP_GRP7 114
|
---|
| 161 | #define OP_LAR 115
|
---|
| 162 | #define OP_LSL 116
|
---|
| 163 | #define OP_SYSCALL 117
|
---|
| 164 | #define OP_CLTS 118
|
---|
| 165 | #define OP_SYSRET 119
|
---|
| 166 | #define OP_INVD 120
|
---|
| 167 | #define OP_WBINVD 121
|
---|
| 168 | #define OP_ILLUD2 122
|
---|
| 169 | #define OP_FEMMS 123
|
---|
| 170 | #define OP_3DNOW 124
|
---|
| 171 | #define OP_MOVUPS 125
|
---|
| 172 | #define OP_MOVLPS 126
|
---|
| 173 | #define OP_UNPCKLPS 127
|
---|
| 174 | #define OP_MOVHPS 128
|
---|
| 175 | #define OP_UNPCKHPS 129
|
---|
| 176 | #define OP_PREFETCH_GRP16 130
|
---|
| 177 | #define OP_MOV_CR 131
|
---|
| 178 | #define OP_MOVAPS 132
|
---|
| 179 | #define OP_CVTPI2PS 133
|
---|
| 180 | #define OP_MOVNTPS 134
|
---|
| 181 | #define OP_CVTTPS2PI 135
|
---|
| 182 | #define OP_CVTPS2PI 136
|
---|
| 183 | #define OP_UCOMISS 137
|
---|
| 184 | #define OP_COMISS 138
|
---|
| 185 | #define OP_WRMSR 139
|
---|
| 186 | #define OP_RDTSC 140
|
---|
| 187 | #define OP_RDMSR 141
|
---|
| 188 | #define OP_RPPMC 142
|
---|
| 189 | #define OP_SYSENTER 143
|
---|
| 190 | #define OP_SYSEXIT 144
|
---|
| 191 | #define OP_PAUSE 145
|
---|
| 192 | #define OP_CMOVO 146
|
---|
| 193 | #define OP_CMOVNO 147
|
---|
| 194 | #define OP_CMOVC 148
|
---|
| 195 | #define OP_CMOVNC 149
|
---|
| 196 | #define OP_CMOVZ 150
|
---|
| 197 | #define OP_CMOVNZ 151
|
---|
| 198 | #define OP_CMOVBE 152
|
---|
| 199 | #define OP_CMOVNBE 153
|
---|
| 200 | #define OP_CMOVS 154
|
---|
| 201 | #define OP_CMOVNS 155
|
---|
| 202 | #define OP_CMOVP 156
|
---|
| 203 | #define OP_CMOVNP 157
|
---|
| 204 | #define OP_CMOVL 158
|
---|
| 205 | #define OP_CMOVNL 159
|
---|
| 206 | #define OP_CMOVLE 160
|
---|
| 207 | #define OP_CMOVNLE 161
|
---|
| 208 | #define OP_MOVMSKPS 162
|
---|
| 209 | #define OP_SQRTPS 163
|
---|
| 210 | #define OP_RSQRTPS 164
|
---|
| 211 | #define OP_RCPPS 165
|
---|
| 212 | #define OP_ANDPS 166
|
---|
| 213 | #define OP_ANDNPS 167
|
---|
| 214 | #define OP_ORPS 168
|
---|
| 215 | #define OP_XORPS 169
|
---|
| 216 | #define OP_ADDPS 170
|
---|
| 217 | #define OP_MULPS 171
|
---|
| 218 | #define OP_CVTPS2PD 172
|
---|
| 219 | #define OP_CVTDQ2PS 173
|
---|
| 220 | #define OP_SUBPS 174
|
---|
| 221 | #define OP_MINPS 175
|
---|
| 222 | #define OP_DIVPS 176
|
---|
| 223 | #define OP_MAXPS 177
|
---|
| 224 | #define OP_PUNPCKLBW 178
|
---|
| 225 | #define OP_PUNPCKLWD 179
|
---|
| 226 | #define OP_PUNPCKLDQ 180
|
---|
| 227 | #define OP_PACKSSWB 181
|
---|
| 228 | #define OP_PCMPGTB 182
|
---|
| 229 | #define OP_PCMPGTW 183
|
---|
| 230 | #define OP_PCMPGTD 184
|
---|
| 231 | #define OP_PACKUSWB 185
|
---|
| 232 | #define OP_PUNPCKHBW 186
|
---|
| 233 | #define OP_PUNPCKHWD 187
|
---|
| 234 | #define OP_PUNPCKHDQ 188
|
---|
| 235 | #define OP_PACKSSDW 189
|
---|
| 236 | #define OP_MOVD 190
|
---|
| 237 | #define OP_MOVQ 191
|
---|
| 238 | #define OP_PSHUFW 192
|
---|
| 239 |
|
---|
| 240 |
|
---|
| 241 |
|
---|
| 242 | #define OP_PCMPEQB 196
|
---|
| 243 | #define OP_PCMPEQW 197
|
---|
| 244 | #define OP_PCMPEQD 198
|
---|
| 245 | #define OP_SETO 199
|
---|
| 246 | #define OP_SETNO 200
|
---|
| 247 | #define OP_SETC 201
|
---|
| 248 | #define OP_SETNC 202
|
---|
| 249 | #define OP_SETE 203
|
---|
| 250 | #define OP_SETNE 204
|
---|
| 251 | #define OP_SETBE 205
|
---|
| 252 | #define OP_SETNBE 206
|
---|
| 253 | #define OP_SETS 207
|
---|
| 254 | #define OP_SETNS 208
|
---|
| 255 | #define OP_SETP 209
|
---|
| 256 | #define OP_SETNP 210
|
---|
| 257 | #define OP_SETL 211
|
---|
| 258 | #define OP_SETNL 212
|
---|
| 259 | #define OP_SETLE 213
|
---|
| 260 | #define OP_SETNLE 214
|
---|
| 261 | #define OP_CPUID 215
|
---|
| 262 | #define OP_BT 216
|
---|
| 263 | #define OP_SHLD 217
|
---|
| 264 | #define OP_RSM 218
|
---|
| 265 | #define OP_BTS 219
|
---|
| 266 | #define OP_SHRD 220
|
---|
| 267 | #define OP_GRP15 221
|
---|
| 268 | #define OP_CMPXCHG 222
|
---|
| 269 | #define OP_LSS 223
|
---|
| 270 | #define OP_BTR 224
|
---|
| 271 | #define OP_LFS 225
|
---|
| 272 | #define OP_LGS 226
|
---|
| 273 | #define OP_MOVZX 227
|
---|
| 274 | #define OP_GRP10_INV 228
|
---|
| 275 | #define OP_GRP8 229
|
---|
| 276 | #define OP_BTC 230
|
---|
| 277 | #define OP_BSF 231
|
---|
| 278 | #define OP_BSR 232
|
---|
| 279 | #define OP_MOVSX 233
|
---|
| 280 | #define OP_XADD 234
|
---|
| 281 | #define OP_CMPPS 235
|
---|
| 282 | #define OP_MOVNTI 236
|
---|
| 283 | #define OP_PINSRW 237
|
---|
| 284 | #define OP_PEXTRW 238
|
---|
| 285 | #define OP_SHUFPS 239
|
---|
| 286 | #define OP_GRP9 240
|
---|
| 287 | #define OP_BSWAP 241
|
---|
| 288 | #define OP_PSRLW 242
|
---|
| 289 | #define OP_PSRLD 243
|
---|
| 290 | #define OP_PSRLQ 244
|
---|
| 291 | #define OP_PADDQ 245
|
---|
| 292 | #define OP_PMULLW 246
|
---|
| 293 | #define OP_PMOVSKB 247
|
---|
| 294 | #define OP_PSUBUSB 248
|
---|
| 295 | #define OP_PSUBUSW 249
|
---|
| 296 | #define OP_PMINUB 250
|
---|
| 297 | #define OP_PAND 251
|
---|
| 298 | #define OP_PADDUSB 252
|
---|
| 299 | #define OP_PADDUSW 253
|
---|
| 300 | #define OP_PMAXUB 254
|
---|
| 301 | #define OP_PANDN 255
|
---|
| 302 | #define OP_PAVGN 256
|
---|
| 303 | #define OP_PSRAW 257
|
---|
| 304 | #define OP_PSRAD 258
|
---|
| 305 | #define OP_PAVGW 259
|
---|
| 306 | #define OP_PMULHUW 260
|
---|
| 307 | #define OP_PMULHW 261
|
---|
| 308 | #define OP_MOVNTQ 262
|
---|
| 309 | #define OP_PSUBSB 263
|
---|
| 310 | #define OP_PSUBSW 264
|
---|
| 311 | #define OP_PMINSW 265
|
---|
| 312 | #define OP_POR 266
|
---|
| 313 | #define OP_PADDSB 267
|
---|
| 314 | #define OP_PADDSW 268
|
---|
| 315 | #define OP_PMAXSW 269
|
---|
| 316 | #define OP_PXOR 270
|
---|
| 317 | #define OP_PSLLW 271
|
---|
| 318 | #define OP_PSLLD 272
|
---|
| 319 | #define OP_PSSQ 273
|
---|
| 320 | #define OP_PMULUDQ 274
|
---|
| 321 | #define OP_PADDWD 275
|
---|
| 322 | #define OP_PADBW 276
|
---|
| 323 | #define OP_PMASKMOVQ 277
|
---|
| 324 | #define OP_PSUBB 278
|
---|
| 325 | #define OP_PSUBW 279
|
---|
| 326 |
|
---|
| 327 | #define OP_PSUBD 281
|
---|
| 328 | #define OP_PADDB 282
|
---|
| 329 | #define OP_PADDW 283
|
---|
| 330 | #define OP_PADDD 284
|
---|
| 331 | #define OP_MOVUPD 285
|
---|
| 332 | #define OP_MOVLPD 286
|
---|
| 333 | #define OP_UNPCKLPD 287
|
---|
| 334 | #define OP_UNPCKHPD 288
|
---|
| 335 | #define OP_MOVHPD 289
|
---|
| 336 |
|
---|
| 337 | #define OP_MOVAPD 291
|
---|
| 338 | #define OP_CVTPI2PD 292
|
---|
| 339 | #define OP_MOVNTPD 293
|
---|
| 340 | #define OP_CVTTPD2PI 294
|
---|
| 341 | #define OP_CVTPD2PI 295
|
---|
| 342 | #define OP_UCOMISD 296
|
---|
| 343 | #define OP_COMISD 297
|
---|
| 344 | #define OP_MOVMSKPD 298
|
---|
| 345 | #define OP_SQRTPD 299
|
---|
| 346 | #define OP_ANDPD 301
|
---|
| 347 | #define OP_ANDNPD 302
|
---|
| 348 | #define OP_ORPD 303
|
---|
| 349 | #define OP_XORPD 304
|
---|
| 350 | #define OP_ADDPD 305
|
---|
| 351 | #define OP_MULPD 306
|
---|
| 352 | #define OP_CVTPD2PS 307
|
---|
| 353 | #define OP_CVTPS2DQ 308
|
---|
| 354 | #define OP_SUBPD 309
|
---|
| 355 | #define OP_MINPD 310
|
---|
| 356 | #define OP_DIVPD 311
|
---|
| 357 | #define OP_MAXPD 312
|
---|
| 358 |
|
---|
| 359 | #define OP_GRP12 313
|
---|
| 360 | #define OP_GRP13 314
|
---|
| 361 | #define OP_GRP14 315
|
---|
| 362 | #define OP_EMMS 316
|
---|
| 363 | #define OP_MMX_UD78 317
|
---|
| 364 | #define OP_MMX_UD79 318
|
---|
| 365 | #define OP_MMX_UD7A 319
|
---|
| 366 | #define OP_MMX_UD7B 320
|
---|
| 367 | #define OP_MMX_UD7C 321
|
---|
| 368 | #define OP_MMX_UD7D 322
|
---|
| 369 |
|
---|
| 370 |
|
---|
| 371 | #define OP_PUNPCKLQDQ 325
|
---|
| 372 | #define OP_PUNPCKHQD 326
|
---|
| 373 |
|
---|
| 374 | #define OP_MOVDQA 328
|
---|
| 375 | #define OP_PSHUFD 329
|
---|
| 376 |
|
---|
| 377 |
|
---|
| 378 |
|
---|
| 379 | #define OP_CMPPD 334
|
---|
| 380 | #define OP_SHUFPD 337
|
---|
| 381 |
|
---|
| 382 |
|
---|
| 383 | #define OP_CVTTPD2DQ 353
|
---|
| 384 | #define OP_MOVNTDQ 354
|
---|
| 385 |
|
---|
| 386 | #define OP_PMASKMOVDQU 369
|
---|
| 387 |
|
---|
| 388 |
|
---|
| 389 |
|
---|
| 390 |
|
---|
| 391 | #define OP_MOVSD 377
|
---|
| 392 | #define OP_CVTSI2SD 378
|
---|
| 393 | #define OP_CVTTSD2SI 379
|
---|
| 394 | #define OP_CVTSD2SI 380
|
---|
| 395 | #define OP_SQRTSD 381
|
---|
| 396 | #define OP_ADDSD 382
|
---|
| 397 | #define OP_MULSD 383
|
---|
| 398 | #define OP_CVTSD2SS 384
|
---|
| 399 | #define OP_SUBSD 385
|
---|
| 400 | #define OP_MINSD 386
|
---|
| 401 | #define OP_DIVSD 387
|
---|
| 402 | #define OP_MAXSD 388
|
---|
| 403 | #define OP_PSHUFLW 389
|
---|
| 404 | #define OP_CMPSD 390
|
---|
| 405 | #define OP_MOVDQ2Q 391
|
---|
| 406 | #define OP_CVTPD2DQ 392
|
---|
| 407 | #define OP_MOVSS 393
|
---|
| 408 | #define OP_CVTSI2SS 394
|
---|
| 409 | #define OP_CVTTSS2SI 395
|
---|
| 410 | #define OP_CVTSS2SI 396
|
---|
| 411 | #define OP_SQRTSS 397
|
---|
| 412 | #define OP_RSQRTSS 398
|
---|
| 413 | #define OP_ADDSS 399
|
---|
| 414 | #define OP_MULSS 401
|
---|
| 415 | #define OP_CVTTPS2DQ 403
|
---|
| 416 | #define OP_SUBSS 404
|
---|
| 417 | #define OP_MINSS 405
|
---|
| 418 | #define OP_DIVSS 406
|
---|
| 419 | #define OP_MAXSS 407
|
---|
| 420 | #define OP_MOVDQU 408
|
---|
| 421 | #define OP_PSHUFHW 409
|
---|
| 422 | #define OP_CMPSS 410
|
---|
| 423 | #define OP_MOVQ2DQ 411
|
---|
| 424 | #define OP_CVTDQ2PD 412
|
---|
| 425 | /** @} */
|
---|
| 426 |
|
---|
| 427 | /** Floating point ops
|
---|
| 428 | * @{
|
---|
| 429 | */
|
---|
| 430 | #define OP_FADD 413
|
---|
| 431 | #define OP_FMUL 414
|
---|
| 432 | #define OP_FCOM 415
|
---|
| 433 | #define OP_FCOMP 416
|
---|
| 434 | #define OP_FSUB 417
|
---|
| 435 | #define OP_FSUBR 418
|
---|
| 436 | #define OP_FDIV 419
|
---|
| 437 | #define OP_FDIVR 420
|
---|
| 438 | #define OP_FLD 421
|
---|
| 439 | #define OP_FST 422
|
---|
| 440 | #define OP_FSTP 423
|
---|
| 441 | #define OP_FLDENV 424
|
---|
| 442 |
|
---|
| 443 | #define OP_FSTENV 426
|
---|
| 444 | #define OP_FSTCW 427
|
---|
| 445 | #define OP_FXCH 428
|
---|
| 446 | #define OP_FNOP 429
|
---|
| 447 | #define OP_FCHS 430
|
---|
| 448 | #define OP_FABS 431
|
---|
| 449 |
|
---|
| 450 | #define OP_FLD1 433
|
---|
| 451 | #define OP_FLDL2T 434
|
---|
| 452 | #define OP_FLDL2E 435
|
---|
| 453 | #define OP_FLDPI 436
|
---|
| 454 | #define OP_FLDLG2 437
|
---|
| 455 | #define OP_FLDLN2 438
|
---|
| 456 | #define OP_FLDZ 439
|
---|
| 457 | #define OP_F2XM1 440
|
---|
| 458 | #define OP_FYL2X 441
|
---|
| 459 | #define OP_FPTAN 442
|
---|
| 460 | #define OP_FPATAN 443
|
---|
| 461 | #define OP_FXTRACT 444
|
---|
| 462 | #define OP_FREM1 445
|
---|
| 463 | #define OP_FDECSTP 446
|
---|
| 464 | #define OP_FINCSTP 447
|
---|
| 465 | #define OP_FPREM 448
|
---|
| 466 | #define OP_FYL2XP1 449
|
---|
| 467 | #define OP_FSQRT 450
|
---|
| 468 | #define OP_FSINCOS 451
|
---|
| 469 | #define OP_FRNDINT 452
|
---|
| 470 | #define OP_FSCALE 453
|
---|
| 471 | #define OP_FSIN 454
|
---|
| 472 | #define OP_FCOS 455
|
---|
| 473 | #define OP_FIADD 456
|
---|
| 474 | #define OP_FIMUL 457
|
---|
| 475 | #define OP_FISUB 460
|
---|
| 476 | #define OP_FISUBR 461
|
---|
| 477 | #define OP_FIDIV 462
|
---|
| 478 | #define OP_FIDIVR 463
|
---|
| 479 | #define OP_FCMOVB 464
|
---|
| 480 | #define OP_FCMOVE 465
|
---|
| 481 | #define OP_FCMOVBE 466
|
---|
| 482 | #define OP_FCMOVU 467
|
---|
| 483 | #define OP_FUCOMPP 468
|
---|
| 484 | #define OP_FILD 469
|
---|
| 485 | #define OP_FIST 470
|
---|
| 486 | #define OP_FISTP 471
|
---|
| 487 | #define OP_FCMOVNB 474
|
---|
| 488 | #define OP_FCMOVNE 475
|
---|
| 489 | #define OP_FCMOVNBE 476
|
---|
| 490 | #define OP_FCMOVNU 477
|
---|
| 491 | #define OP_FCLEX 478
|
---|
| 492 | #define OP_FINIT 479
|
---|
| 493 | #define OP_FUCOMI 480
|
---|
| 494 | #define OP_FCOMI 481
|
---|
| 495 | #define OP_FRSTOR 482
|
---|
| 496 | #define OP_FSAVE 483
|
---|
| 497 | #define OP_FSTSW 484
|
---|
| 498 | #define OP_FFREE 485
|
---|
| 499 | #define OP_FUCOM 486
|
---|
| 500 | #define OP_FUCOMP 487
|
---|
| 501 | #define OP_FICOM 490
|
---|
| 502 | #define OP_FICOMP 491
|
---|
| 503 | #define OP_FADDP 496
|
---|
| 504 | #define OP_FMULP 497
|
---|
| 505 | #define OP_FCOMPP 498
|
---|
| 506 | #define OP_FSUBRP 499
|
---|
| 507 | #define OP_FSUBP 500
|
---|
| 508 | #define OP_FDIVRP 501
|
---|
| 509 | #define OP_FDIVP 502
|
---|
| 510 | #define OP_FBLD 503
|
---|
| 511 | #define OP_FBSTP 504
|
---|
| 512 | #define OP_FCOMIP 506
|
---|
| 513 | #define OP_FUCOMIP 507
|
---|
| 514 | /** @} */
|
---|
| 515 |
|
---|
| 516 | /** 3DNow!
|
---|
| 517 | * @{
|
---|
| 518 | */
|
---|
| 519 | #define OP_PI2FW 508
|
---|
| 520 | #define OP_PI2FD 509
|
---|
| 521 | #define OP_PF2IW 510
|
---|
| 522 | #define OP_PF2ID 511
|
---|
| 523 | #define OP_PFPNACC 512
|
---|
| 524 | #define OP_PFCMPGE 513
|
---|
| 525 | #define OP_PFMIN 514
|
---|
| 526 | #define OP_PFRCP 515
|
---|
| 527 | #define OP_PFRSQRT 516
|
---|
| 528 | #define OP_PFSUB 517
|
---|
| 529 | #define OP_PFADD 518
|
---|
| 530 | #define OP_PFCMPGT 519
|
---|
| 531 | #define OP_PFMAX 520
|
---|
| 532 | #define OP_PFRCPIT1 521
|
---|
| 533 | #define OP_PFRSQRTIT1 522
|
---|
| 534 | #define OP_PFSUBR 523
|
---|
| 535 | #define OP_PFACC 524
|
---|
| 536 | #define OP_PFCMPEQ 525
|
---|
| 537 | #define OP_PFMUL 526
|
---|
| 538 | #define OP_PFRCPIT2 527
|
---|
| 539 | #define OP_PFMULHRW 528
|
---|
| 540 | #define OP_PFSWAPD 529
|
---|
| 541 | #define OP_PAVGUSB 530
|
---|
| 542 | #define OP_PFNACC 531
|
---|
| 543 | #define OP_ROL 532
|
---|
| 544 | #define OP_ROR 533
|
---|
| 545 | #define OP_RCL 534
|
---|
| 546 | #define OP_RCR 535
|
---|
| 547 | #define OP_SHL 536
|
---|
| 548 | #define OP_SHR 537
|
---|
| 549 | #define OP_SAR 538
|
---|
| 550 | #define OP_NOT 539
|
---|
| 551 | #define OP_NEG 540
|
---|
| 552 | #define OP_MUL 541
|
---|
| 553 | #define OP_DIV 542
|
---|
| 554 | #define OP_IDIV 543
|
---|
| 555 | #define OP_SLDT 544
|
---|
| 556 | #define OP_STR 545
|
---|
| 557 | #define OP_LLDT 546
|
---|
| 558 | #define OP_LTR 547
|
---|
| 559 | #define OP_VERR 548
|
---|
| 560 | #define OP_VERW 549
|
---|
| 561 | #define OP_SGDT 550
|
---|
| 562 | #define OP_LGDT 551
|
---|
| 563 | #define OP_SIDT 552
|
---|
| 564 | #define OP_LIDT 553
|
---|
| 565 | #define OP_SMSW 554
|
---|
| 566 | #define OP_LMSW 555
|
---|
| 567 | #define OP_INVLPG 556
|
---|
| 568 | #define OP_CMPXCHG8B 557
|
---|
| 569 | #define OP_PSLLQ 558
|
---|
| 570 | #define OP_PSRLDQ 559
|
---|
| 571 | #define OP_PSLLDQ 560
|
---|
| 572 | #define OP_FXSAVE 561
|
---|
| 573 | #define OP_FXRSTOR 562
|
---|
| 574 | #define OP_LDMXCSR 563
|
---|
| 575 | #define OP_STMXCSR 564
|
---|
| 576 | #define OP_LFENCE 565
|
---|
| 577 | #define OP_MFENCE 566
|
---|
| 578 | #define OP_SFENCE 567
|
---|
| 579 | #define OP_PREFETCH 568
|
---|
| 580 | #define OP_MONITOR 569
|
---|
| 581 | #define OP_MWAIT 570
|
---|
| 582 | #define OP_CLFLUSH 571
|
---|
| 583 |
|
---|
| 584 | #define OP_MOV_DR 600
|
---|
| 585 | #define OP_MOV_TR 601
|
---|
| 586 |
|
---|
[7456] | 587 | /* VT-x instructions */
|
---|
| 588 | #define OP_VMREAD 650
|
---|
| 589 | #define OP_VMWRITE 651
|
---|
| 590 | #define OP_VMCALL 652
|
---|
| 591 | #define OP_VMXON 653
|
---|
| 592 | #define OP_VMXOFF 654
|
---|
| 593 | #define OP_VMCLEAR 655
|
---|
| 594 | #define OP_VMLAUNCH 656
|
---|
| 595 | #define OP_VMRESUME 657
|
---|
| 596 | #define OP_VMPTRLD 658
|
---|
| 597 | #define OP_VMPTRST 659
|
---|
[7000] | 598 |
|
---|
[7456] | 599 |
|
---|
[7000] | 600 | /* 64 bits prefix bytes */
|
---|
| 601 | #define OP_REX 0x40
|
---|
| 602 | #define OP_REX_B 0x41
|
---|
| 603 | #define OP_REX_X 0x42
|
---|
| 604 | #define OP_REX_XB 0x43
|
---|
| 605 | #define OP_REX_R 0x44
|
---|
| 606 | #define OP_REX_RB 0x45
|
---|
| 607 | #define OP_REX_RX 0x46
|
---|
| 608 | #define OP_REX_RXB 0x47
|
---|
| 609 | #define OP_REX_W 0x48
|
---|
| 610 | #define OP_REX_WB 0x49
|
---|
| 611 | #define OP_REX_WX 0x4A
|
---|
| 612 | #define OP_REX_WXB 0x4B
|
---|
| 613 | #define OP_REX_WR 0x4C
|
---|
| 614 | #define OP_REX_WRB 0x4D
|
---|
| 615 | #define OP_REX_WRX 0x4E
|
---|
| 616 | #define OP_REX_WRXB 0x4F
|
---|
| 617 |
|
---|
[1] | 618 | /** @} */
|
---|
| 619 |
|
---|
| 620 |
|
---|
| 621 | /** Opcode parameters
|
---|
| 622 | * @{
|
---|
| 623 | */
|
---|
[1883] | 624 | /* NOTE: Register order is important for translations!! */
|
---|
[1] | 625 | #define OP_PARM_NONE 0
|
---|
| 626 | #define OP_PARM_REG_EAX 1
|
---|
| 627 | #define OP_PARM_REG_GEN32_START OP_PARM_REG_EAX
|
---|
| 628 | #define OP_PARM_REG_ECX 2
|
---|
| 629 | #define OP_PARM_REG_EDX 3
|
---|
| 630 | #define OP_PARM_REG_EBX 4
|
---|
| 631 | #define OP_PARM_REG_ESP 5
|
---|
| 632 | #define OP_PARM_REG_EBP 6
|
---|
| 633 | #define OP_PARM_REG_ESI 7
|
---|
| 634 | #define OP_PARM_REG_EDI 8
|
---|
| 635 |
|
---|
| 636 | #define OP_PARM_REG_ES 9
|
---|
| 637 | #define OP_PARM_REG_SEG_START OP_PARM_REG_ES
|
---|
| 638 | #define OP_PARM_REG_CS 10
|
---|
| 639 | #define OP_PARM_REG_SS 11
|
---|
| 640 | #define OP_PARM_REG_DS 12
|
---|
| 641 | #define OP_PARM_REG_FS 13
|
---|
| 642 | #define OP_PARM_REG_GS 14
|
---|
| 643 |
|
---|
| 644 | #define OP_PARM_REG_AX 15
|
---|
| 645 | #define OP_PARM_REG_GEN16_START OP_PARM_REG_AX
|
---|
| 646 | #define OP_PARM_REG_CX 16
|
---|
| 647 | #define OP_PARM_REG_DX 17
|
---|
| 648 | #define OP_PARM_REG_BX 18
|
---|
| 649 | #define OP_PARM_REG_SP 19
|
---|
| 650 | #define OP_PARM_REG_BP 20
|
---|
| 651 | #define OP_PARM_REG_SI 21
|
---|
| 652 | #define OP_PARM_REG_DI 22
|
---|
| 653 |
|
---|
| 654 | #define OP_PARM_REG_AL 23
|
---|
| 655 | #define OP_PARM_REG_GEN8_START OP_PARM_REG_AL
|
---|
| 656 | #define OP_PARM_REG_CL 24
|
---|
| 657 | #define OP_PARM_REG_DL 25
|
---|
| 658 | #define OP_PARM_REG_BL 26
|
---|
| 659 | #define OP_PARM_REG_AH 27
|
---|
| 660 | #define OP_PARM_REG_CH 28
|
---|
| 661 | #define OP_PARM_REG_DH 29
|
---|
| 662 | #define OP_PARM_REG_BH 30
|
---|
| 663 |
|
---|
| 664 | #define OP_PARM_REGFP_0 31
|
---|
| 665 | #define OP_PARM_REG_FP_START OP_PARM_REGFP_0
|
---|
| 666 | #define OP_PARM_REGFP_1 32
|
---|
| 667 | #define OP_PARM_REGFP_2 33
|
---|
| 668 | #define OP_PARM_REGFP_3 34
|
---|
| 669 | #define OP_PARM_REGFP_4 35
|
---|
| 670 | #define OP_PARM_REGFP_5 36
|
---|
| 671 | #define OP_PARM_REGFP_6 37
|
---|
| 672 | #define OP_PARM_REGFP_7 38
|
---|
| 673 |
|
---|
| 674 | #define OP_PARM_NTA 39
|
---|
| 675 | #define OP_PARM_T0 40
|
---|
| 676 | #define OP_PARM_T1 41
|
---|
| 677 | #define OP_PARM_T2 42
|
---|
| 678 |
|
---|
| 679 | #define OP_PARM_1 43
|
---|
| 680 |
|
---|
| 681 | #define OP_PARM_VTYPE(a) ((int)a & 0xFE0)
|
---|
| 682 | #define OP_PARM_VSUBTYPE(a) ((int)a & 0x01F)
|
---|
| 683 |
|
---|
| 684 | #define OP_PARM_A 0x40
|
---|
| 685 | #define OP_PARM_VARIABLE OP_PARM_A
|
---|
| 686 | #define OP_PARM_E 0x60
|
---|
| 687 | #define OP_PARM_F 0x80
|
---|
| 688 | #define OP_PARM_G 0xA0
|
---|
| 689 | #define OP_PARM_I 0x100
|
---|
| 690 | #define OP_PARM_J 0x120
|
---|
| 691 | #define OP_PARM_M 0x140
|
---|
| 692 | #define OP_PARM_O 0x160
|
---|
| 693 | #define OP_PARM_Q 0x180
|
---|
| 694 | #define OP_PARM_R 0x1A0
|
---|
| 695 | #define OP_PARM_X 0x200
|
---|
| 696 | #define OP_PARM_Y 0x220
|
---|
| 697 |
|
---|
| 698 | /* Grouped rare parameters for optimization purposes */
|
---|
| 699 | #define IS_OP_PARM_RARE(a) ((a & 0xF00) == 0x300)
|
---|
| 700 | #define OP_PARM_C 0x300 /* control register */
|
---|
| 701 | #define OP_PARM_D 0x320 /* debug register */
|
---|
| 702 | #define OP_PARM_S 0x340 /* segment register */
|
---|
| 703 | #define OP_PARM_T 0x360 /* test register */
|
---|
| 704 | #define OP_PARM_P 0x380 /* mmx register */
|
---|
| 705 | #define OP_PARM_W 0x3A0 /* xmm register */
|
---|
| 706 | #define OP_PARM_V 0x3C0
|
---|
| 707 |
|
---|
| 708 | #define OP_PARM_NONE 0
|
---|
| 709 | #define OP_PARM_a 0x1
|
---|
| 710 | #define OP_PARM_b 0x2
|
---|
| 711 | #define OP_PARM_d 0x3
|
---|
| 712 | #define OP_PARM_dq 0x4
|
---|
| 713 | #define OP_PARM_p 0x5
|
---|
| 714 | #define OP_PARM_pd 0x6
|
---|
| 715 | #define OP_PARM_pi 0x7
|
---|
| 716 | #define OP_PARM_ps 0x8
|
---|
| 717 | #define OP_PARM_pq 0x9
|
---|
| 718 | #define OP_PARM_q 0xA
|
---|
| 719 | #define OP_PARM_s 0xB
|
---|
| 720 | #define OP_PARM_sd 0xC
|
---|
| 721 | #define OP_PARM_ss 0xD
|
---|
| 722 | #define OP_PARM_v 0xE
|
---|
| 723 | #define OP_PARM_w 0xF
|
---|
| 724 | #define OP_PARM_z 0x10
|
---|
| 725 |
|
---|
| 726 |
|
---|
| 727 | #define OP_PARM_Ap (OP_PARM_A+OP_PARM_p)
|
---|
| 728 | #define OP_PARM_Cd (OP_PARM_C+OP_PARM_d)
|
---|
| 729 | #define OP_PARM_Dd (OP_PARM_D+OP_PARM_d)
|
---|
| 730 | #define OP_PARM_Eb (OP_PARM_E+OP_PARM_b)
|
---|
| 731 | #define OP_PARM_Ed (OP_PARM_E+OP_PARM_d)
|
---|
| 732 | #define OP_PARM_Ep (OP_PARM_E+OP_PARM_p)
|
---|
| 733 | #define OP_PARM_Ev (OP_PARM_E+OP_PARM_v)
|
---|
| 734 | #define OP_PARM_Ew (OP_PARM_E+OP_PARM_w)
|
---|
| 735 | #define OP_PARM_Fv (OP_PARM_F+OP_PARM_v)
|
---|
| 736 | #define OP_PARM_Gb (OP_PARM_G+OP_PARM_b)
|
---|
| 737 | #define OP_PARM_Gd (OP_PARM_G+OP_PARM_d)
|
---|
| 738 | #define OP_PARM_Gv (OP_PARM_G+OP_PARM_v)
|
---|
[7093] | 739 | #define OP_PARM_Gw (OP_PARM_G+OP_PARM_w)
|
---|
[1] | 740 | #define OP_PARM_Ib (OP_PARM_I+OP_PARM_b)
|
---|
| 741 | #define OP_PARM_Id (OP_PARM_I+OP_PARM_d)
|
---|
| 742 | #define OP_PARM_Iq (OP_PARM_I+OP_PARM_q)
|
---|
| 743 | #define OP_PARM_Iw (OP_PARM_I+OP_PARM_w)
|
---|
| 744 | #define OP_PARM_Iv (OP_PARM_I+OP_PARM_v)
|
---|
| 745 | #define OP_PARM_Iz (OP_PARM_I+OP_PARM_z)
|
---|
| 746 | #define OP_PARM_Jb (OP_PARM_J+OP_PARM_b)
|
---|
| 747 | #define OP_PARM_Jv (OP_PARM_J+OP_PARM_v)
|
---|
| 748 | #define OP_PARM_Ma (OP_PARM_M+OP_PARM_a)
|
---|
| 749 | #define OP_PARM_Mb (OP_PARM_M+OP_PARM_b)
|
---|
| 750 | #define OP_PARM_Mw (OP_PARM_M+OP_PARM_w)
|
---|
| 751 | #define OP_PARM_Md (OP_PARM_M+OP_PARM_d)
|
---|
| 752 | #define OP_PARM_Mp (OP_PARM_M+OP_PARM_p)
|
---|
| 753 | #define OP_PARM_Mq (OP_PARM_M+OP_PARM_q)
|
---|
| 754 | #define OP_PARM_Ms (OP_PARM_M+OP_PARM_s)
|
---|
| 755 | #define OP_PARM_Ob (OP_PARM_O+OP_PARM_b)
|
---|
| 756 | #define OP_PARM_Ov (OP_PARM_O+OP_PARM_v)
|
---|
| 757 | #define OP_PARM_Pq (OP_PARM_P+OP_PARM_q)
|
---|
| 758 | #define OP_PARM_Pd (OP_PARM_P+OP_PARM_d)
|
---|
| 759 | #define OP_PARM_Qd (OP_PARM_Q+OP_PARM_d)
|
---|
| 760 | #define OP_PARM_Qq (OP_PARM_Q+OP_PARM_q)
|
---|
| 761 | #define OP_PARM_Rd (OP_PARM_R+OP_PARM_d)
|
---|
| 762 | #define OP_PARM_Rw (OP_PARM_R+OP_PARM_w)
|
---|
| 763 | #define OP_PARM_Sw (OP_PARM_S+OP_PARM_w)
|
---|
| 764 | #define OP_PARM_Td (OP_PARM_T+OP_PARM_d)
|
---|
| 765 | #define OP_PARM_Vq (OP_PARM_V+OP_PARM_q)
|
---|
| 766 | #define OP_PARM_Wq (OP_PARM_W+OP_PARM_q)
|
---|
| 767 | #define OP_PARM_Ws (OP_PARM_W+OP_PARM_s)
|
---|
| 768 | #define OP_PARM_Xb (OP_PARM_X+OP_PARM_b)
|
---|
| 769 | #define OP_PARM_Xv (OP_PARM_X+OP_PARM_v)
|
---|
| 770 | #define OP_PARM_Yb (OP_PARM_Y+OP_PARM_b)
|
---|
| 771 | #define OP_PARM_Yv (OP_PARM_Y+OP_PARM_v)
|
---|
| 772 |
|
---|
| 773 |
|
---|
| 774 | #define OP_PARM_Vps (OP_PARM_V+OP_PARM_ps)
|
---|
| 775 | #define OP_PARM_Vss (OP_PARM_V+OP_PARM_ss)
|
---|
| 776 | #define OP_PARM_Vpd (OP_PARM_V+OP_PARM_pd)
|
---|
| 777 | #define OP_PARM_Vdq (OP_PARM_V+OP_PARM_dq)
|
---|
| 778 | #define OP_PARM_Wps (OP_PARM_W+OP_PARM_ps)
|
---|
| 779 | #define OP_PARM_Wpd (OP_PARM_W+OP_PARM_pd)
|
---|
| 780 | #define OP_PARM_Wss (OP_PARM_W+OP_PARM_ss)
|
---|
| 781 | #define OP_PARM_Wdq (OP_PARM_W+OP_PARM_dq)
|
---|
| 782 | #define OP_PARM_Ppi (OP_PARM_P+OP_PARM_pi)
|
---|
| 783 | #define OP_PARM_Qpi (OP_PARM_Q+OP_PARM_pi)
|
---|
| 784 | #define OP_PARM_Qdq (OP_PARM_Q+OP_PARM_dq)
|
---|
| 785 | #define OP_PARM_Vsd (OP_PARM_V+OP_PARM_sd)
|
---|
| 786 | #define OP_PARM_Wsd (OP_PARM_W+OP_PARM_sd)
|
---|
| 787 | #define OP_PARM_Vpq (OP_PARM_V+OP_PARM_pq)
|
---|
| 788 | #define OP_PARM_Pdq (OP_PARM_P+OP_PARM_dq)
|
---|
| 789 |
|
---|
| 790 | /** @} */
|
---|
| 791 |
|
---|
[3633] | 792 | #endif
|
---|
[1] | 793 |
|
---|