summaryrefslogtreecommitdiff
path: root/src/cmd/objdump
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd/objdump')
-rw-r--r--src/cmd/objdump/Makefile5
-rw-r--r--src/cmd/objdump/x86.go13800
2 files changed, 13805 insertions, 0 deletions
diff --git a/src/cmd/objdump/Makefile b/src/cmd/objdump/Makefile
new file mode 100644
index 000000000..426b95e53
--- /dev/null
+++ b/src/cmd/objdump/Makefile
@@ -0,0 +1,5 @@
+x86.go: bundle
+ ./bundle -p main -x x86_ rsc.io/x86/x86asm >x86.go
+
+bundle:
+ go build -o bundle code.google.com/p/rsc/cmd/bundle
diff --git a/src/cmd/objdump/x86.go b/src/cmd/objdump/x86.go
new file mode 100644
index 000000000..8e741331f
--- /dev/null
+++ b/src/cmd/objdump/x86.go
@@ -0,0 +1,13800 @@
+// DO NOT EDIT. Generated by code.google.com/p/rsc/cmd/bundle
+// bundle -p main -x x86_ rsc.io/x86/x86asm
+
+/* decode.go */
+
+// Copyright 2014 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// Table-driven decoding of x86 instructions.
+
+package main
+
+import (
+ "bytes"
+ "encoding/binary"
+ "errors"
+ "fmt"
+ "runtime"
+ "strings"
+)
+
+// Set trace to true to cause the decoder to print the PC sequence
+// of the executed instruction codes. This is typically only useful
+// when you are running a test of a single input case.
+const x86_trace = false
+
+// A decodeOp is a single instruction in the decoder bytecode program.
+//
+// The decodeOps correspond to consuming and conditionally branching
+// on input bytes, consuming additional fields, and then interpreting
+// consumed data as instruction arguments. The names of the xRead and xArg
+// operations are taken from the Intel manual conventions, for example
+// Volume 2, Section 3.1.1, page 487 of
+// http://www.intel.com/content/dam/www/public/us/en/documents/manuals/64-ia-32-architectures-software-developer-manual-325462.pdf
+//
+// The actual decoding program is generated by ../x86map.
+//
+// TODO(rsc): We may be able to merge various of the memory operands
+// since we don't care about, say, the distinction between m80dec and m80bcd.
+// Similarly, mm and mm1 have identical meaning, as do xmm and xmm1.
+
+type x86_decodeOp uint16
+
+const (
+ x86_xFail x86_decodeOp = iota // invalid instruction (return)
+ x86_xMatch // completed match
+ x86_xJump // jump to pc
+
+ x86_xCondByte // switch on instruction byte value
+ x86_xCondSlashR // read and switch on instruction /r value
+ x86_xCondPrefix // switch on presence of instruction prefix
+ x86_xCondIs64 // switch on 64-bit processor mode
+ x86_xCondDataSize // switch on operand size
+ x86_xCondAddrSize // switch on address size
+ x86_xCondIsMem // switch on memory vs register argument
+
+ x86_xSetOp // set instruction opcode
+
+ x86_xReadSlashR // read /r
+ x86_xReadIb // read ib
+ x86_xReadIw // read iw
+ x86_xReadId // read id
+ x86_xReadIo // read io
+ x86_xReadCb // read cb
+ x86_xReadCw // read cw
+ x86_xReadCd // read cd
+ x86_xReadCp // read cp
+ x86_xReadCm // read cm
+
+ x86_xArg1 // arg 1
+ x86_xArg3 // arg 3
+ x86_xArgAL // arg AL
+ x86_xArgAX // arg AX
+ x86_xArgCL // arg CL
+ x86_xArgCR0dashCR7 // arg CR0-CR7
+ x86_xArgCS // arg CS
+ x86_xArgDR0dashDR7 // arg DR0-DR7
+ x86_xArgDS // arg DS
+ x86_xArgDX // arg DX
+ x86_xArgEAX // arg EAX
+ x86_xArgEDX // arg EDX
+ x86_xArgES // arg ES
+ x86_xArgFS // arg FS
+ x86_xArgGS // arg GS
+ x86_xArgImm16 // arg imm16
+ x86_xArgImm32 // arg imm32
+ x86_xArgImm64 // arg imm64
+ x86_xArgImm8 // arg imm8
+ x86_xArgImm8u // arg imm8 but record as unsigned
+ x86_xArgImm16u // arg imm8 but record as unsigned
+ x86_xArgM // arg m
+ x86_xArgM128 // arg m128
+ x86_xArgM1428byte // arg m14/28byte
+ x86_xArgM16 // arg m16
+ x86_xArgM16and16 // arg m16&16
+ x86_xArgM16and32 // arg m16&32
+ x86_xArgM16and64 // arg m16&64
+ x86_xArgM16colon16 // arg m16:16
+ x86_xArgM16colon32 // arg m16:32
+ x86_xArgM16colon64 // arg m16:64
+ x86_xArgM16int // arg m16int
+ x86_xArgM2byte // arg m2byte
+ x86_xArgM32 // arg m32
+ x86_xArgM32and32 // arg m32&32
+ x86_xArgM32fp // arg m32fp
+ x86_xArgM32int // arg m32int
+ x86_xArgM512byte // arg m512byte
+ x86_xArgM64 // arg m64
+ x86_xArgM64fp // arg m64fp
+ x86_xArgM64int // arg m64int
+ x86_xArgM8 // arg m8
+ x86_xArgM80bcd // arg m80bcd
+ x86_xArgM80dec // arg m80dec
+ x86_xArgM80fp // arg m80fp
+ x86_xArgM94108byte // arg m94/108byte
+ x86_xArgMm // arg mm
+ x86_xArgMm1 // arg mm1
+ x86_xArgMm2 // arg mm2
+ x86_xArgMm2M64 // arg mm2/m64
+ x86_xArgMmM32 // arg mm/m32
+ x86_xArgMmM64 // arg mm/m64
+ x86_xArgMem // arg mem
+ x86_xArgMoffs16 // arg moffs16
+ x86_xArgMoffs32 // arg moffs32
+ x86_xArgMoffs64 // arg moffs64
+ x86_xArgMoffs8 // arg moffs8
+ x86_xArgPtr16colon16 // arg ptr16:16
+ x86_xArgPtr16colon32 // arg ptr16:32
+ x86_xArgR16 // arg r16
+ x86_xArgR16op // arg r16 with +rw in opcode
+ x86_xArgR32 // arg r32
+ x86_xArgR32M16 // arg r32/m16
+ x86_xArgR32M8 // arg r32/m8
+ x86_xArgR32op // arg r32 with +rd in opcode
+ x86_xArgR64 // arg r64
+ x86_xArgR64M16 // arg r64/m16
+ x86_xArgR64op // arg r64 with +rd in opcode
+ x86_xArgR8 // arg r8
+ x86_xArgR8op // arg r8 with +rb in opcode
+ x86_xArgRAX // arg RAX
+ x86_xArgRDX // arg RDX
+ x86_xArgRM // arg r/m
+ x86_xArgRM16 // arg r/m16
+ x86_xArgRM32 // arg r/m32
+ x86_xArgRM64 // arg r/m64
+ x86_xArgRM8 // arg r/m8
+ x86_xArgReg // arg reg
+ x86_xArgRegM16 // arg reg/m16
+ x86_xArgRegM32 // arg reg/m32
+ x86_xArgRegM8 // arg reg/m8
+ x86_xArgRel16 // arg rel16
+ x86_xArgRel32 // arg rel32
+ x86_xArgRel8 // arg rel8
+ x86_xArgSS // arg SS
+ x86_xArgST // arg ST, aka ST(0)
+ x86_xArgSTi // arg ST(i) with +i in opcode
+ x86_xArgSreg // arg Sreg
+ x86_xArgTR0dashTR7 // arg TR0-TR7
+ x86_xArgXmm // arg xmm
+ x86_xArgXMM0 // arg <XMM0>
+ x86_xArgXmm1 // arg xmm1
+ x86_xArgXmm2 // arg xmm2
+ x86_xArgXmm2M128 // arg xmm2/m128
+ x86_xArgXmm2M16 // arg xmm2/m16
+ x86_xArgXmm2M32 // arg xmm2/m32
+ x86_xArgXmm2M64 // arg xmm2/m64
+ x86_xArgXmmM128 // arg xmm/m128
+ x86_xArgXmmM32 // arg xmm/m32
+ x86_xArgXmmM64 // arg xmm/m64
+ x86_xArgRmf16 // arg r/m16 but force mod=3
+ x86_xArgRmf32 // arg r/m32 but force mod=3
+ x86_xArgRmf64 // arg r/m64 but force mod=3
+)
+
+// instPrefix returns an Inst describing just one prefix byte.
+// It is only used if there is a prefix followed by an unintelligible
+// or invalid instruction byte sequence.
+func x86_instPrefix(b byte, mode int) (x86_Inst, error) {
+ // When tracing it is useful to see what called instPrefix to report an error.
+ if x86_trace {
+ _, file, line, _ := runtime.Caller(1)
+ fmt.Printf("%s:%d\n", file, line)
+ }
+ p := x86_Prefix(b)
+ switch p {
+ case x86_PrefixDataSize:
+ if mode == 16 {
+ p = x86_PrefixData32
+ } else {
+ p = x86_PrefixData16
+ }
+ case x86_PrefixAddrSize:
+ if mode == 32 {
+ p = x86_PrefixAddr16
+ } else {
+ p = x86_PrefixAddr32
+ }
+ }
+ // Note: using composite literal with Prefix key confuses 'bundle' tool.
+ inst := x86_Inst{Len: 1}
+ inst.Prefix = x86_Prefixes{p}
+ return inst, nil
+}
+
+// truncated reports a truncated instruction.
+// For now we use instPrefix but perhaps later we will return
+// a specific error here.
+func x86_truncated(src []byte, mode int) (x86_Inst, error) {
+ // return Inst{}, len(src), ErrTruncated
+ return x86_instPrefix(src[0], mode) // too long
+}
+
+// These are the errors returned by Decode.
+var (
+ x86_ErrInvalidMode = errors.New("invalid x86 mode in Decode")
+ x86_ErrTruncated = errors.New("truncated instruction")
+ x86_ErrUnrecognized = errors.New("unrecognized instruction")
+)
+
+// decoderCover records coverage information for which parts
+// of the byte code have been executed.
+// TODO(rsc): This is for testing. Only use this if a flag is given.
+var x86_decoderCover []bool
+
+// Decode decodes the leading bytes in src as a single instruction.
+// The mode arguments specifies the assumed processor mode:
+// 16, 32, or 64 for 16-, 32-, and 64-bit execution modes.
+func x86_Decode(src []byte, mode int) (inst x86_Inst, err error) {
+ return x86_decode1(src, mode, false)
+}
+
+// decode1 is the implementation of Decode but takes an extra
+// gnuCompat flag to cause it to change its behavior to mimic
+// bugs (or at least unique features) of GNU libopcodes as used
+// by objdump. We don't believe that logic is the right thing to do
+// in general, but when testing against libopcodes it simplifies the
+// comparison if we adjust a few small pieces of logic.
+// The affected logic is in the conditional branch for "mandatory" prefixes,
+// case xCondPrefix.
+func x86_decode1(src []byte, mode int, gnuCompat bool) (x86_Inst, error) {
+ switch mode {
+ case 16, 32, 64:
+ // ok
+ // TODO(rsc): 64-bit mode not tested, probably not working.
+ default:
+ return x86_Inst{}, x86_ErrInvalidMode
+ }
+
+ // Maximum instruction size is 15 bytes.
+ // If we need to read more, return 'truncated instruction.
+ if len(src) > 15 {
+ src = src[:15]
+ }
+
+ var (
+ // prefix decoding information
+ pos = 0 // position reading src
+ nprefix = 0 // number of prefixes
+ lockIndex = -1 // index of LOCK prefix in src and inst.Prefix
+ repIndex = -1 // index of REP/REPN prefix in src and inst.Prefix
+ segIndex = -1 // index of Group 2 prefix in src and inst.Prefix
+ dataSizeIndex = -1 // index of Group 3 prefix in src and inst.Prefix
+ addrSizeIndex = -1 // index of Group 4 prefix in src and inst.Prefix
+ rex x86_Prefix // rex byte if present (or 0)
+ rexUsed x86_Prefix // bits used in rex byte
+ rexIndex = -1 // index of rex byte
+
+ addrMode = mode // address mode (width in bits)
+ dataMode = mode // operand mode (width in bits)
+
+ // decoded ModR/M fields
+ haveModrm bool
+ modrm int
+ mod int
+ regop int
+ rm int
+
+ // if ModR/M is memory reference, Mem form
+ mem x86_Mem
+ haveMem bool
+
+ // decoded SIB fields
+ haveSIB bool
+ sib int
+ scale int
+ index int
+ base int
+
+ // decoded immediate values
+ imm int64
+ imm8 int8
+ immc int64
+
+ // output
+ opshift int
+ inst x86_Inst
+ narg int // number of arguments written to inst
+ )
+
+ if mode == 64 {
+ dataMode = 32
+ }
+
+ // Prefixes are certainly the most complex and underspecified part of
+ // decoding x86 instructions. Although the manuals say things like
+ // up to four prefixes, one from each group, nearly everyone seems to
+ // agree that in practice as many prefixes as possible, including multiple
+ // from a particular group or repetitions of a given prefix, can be used on
+ // an instruction, provided the total instruction length including prefixes
+ // does not exceed the agreed-upon maximum of 15 bytes.
+ // Everyone also agrees that if one of these prefixes is the LOCK prefix
+ // and the instruction is not one of the instructions that can be used with
+ // the LOCK prefix or if the destination is not a memory operand,
+ // then the instruction is invalid and produces the #UD exception.
+ // However, that is the end of any semblance of agreement.
+ //
+ // What happens if prefixes are given that conflict with other prefixes?
+ // For example, the memory segment overrides CS, DS, ES, FS, GS, SS
+ // conflict with each other: only one segment can be in effect.
+ // Disassemblers seem to agree that later prefixes take priority over
+ // earlier ones. I have not taken the time to write assembly programs
+ // to check to see if the hardware agrees.
+ //
+ // What happens if prefixes are given that have no meaning for the
+ // specific instruction to which they are attached? It depends.
+ // If they really have no meaning, they are ignored. However, a future
+ // processor may assign a different meaning. As a disassembler, we
+ // don't really know whether we're seeing a meaningless prefix or one
+ // whose meaning we simply haven't been told yet.
+ //
+ // Combining the two questions, what happens when conflicting
+ // extension prefixes are given? No one seems to know for sure.
+ // For example, MOVQ is 66 0F D6 /r, MOVDQ2Q is F2 0F D6 /r,
+ // and MOVQ2DQ is F3 0F D6 /r. What is '66 F2 F3 0F D6 /r'?
+ // Which prefix wins? See the xCondPrefix prefix for more.
+ //
+ // Writing assembly test cases to divine which interpretation the
+ // CPU uses might clarify the situation, but more likely it would
+ // make the situation even less clear.
+
+ // Read non-REX prefixes.
+ReadPrefixes:
+ for ; pos < len(src); pos++ {
+ p := x86_Prefix(src[pos])
+ switch p {
+ default:
+ nprefix = pos
+ break ReadPrefixes
+
+ // Group 1 - lock and repeat prefixes
+ // According to Intel, there should only be one from this set,
+ // but according to AMD both can be present.
+ case 0xF0:
+ if lockIndex >= 0 {
+ inst.Prefix[lockIndex] |= x86_PrefixIgnored
+ }
+ lockIndex = pos
+ case 0xF2, 0xF3:
+ if repIndex >= 0 {
+ inst.Prefix[repIndex] |= x86_PrefixIgnored
+ }
+ repIndex = pos
+
+ // Group 2 - segment override / branch hints
+ case 0x26, 0x2E, 0x36, 0x3E:
+ if mode == 64 {
+ p |= x86_PrefixIgnored
+ break
+ }
+ fallthrough
+ case 0x64, 0x65:
+ if segIndex >= 0 {
+ inst.Prefix[segIndex] |= x86_PrefixIgnored
+ }
+ segIndex = pos
+
+ // Group 3 - operand size override
+ case 0x66:
+ if mode == 16 {
+ dataMode = 32
+ p = x86_PrefixData32
+ } else {
+ dataMode = 16
+ p = x86_PrefixData16
+ }
+ if dataSizeIndex >= 0 {
+ inst.Prefix[dataSizeIndex] |= x86_PrefixIgnored
+ }
+ dataSizeIndex = pos
+
+ // Group 4 - address size override
+ case 0x67:
+ if mode == 32 {
+ addrMode = 16
+ p = x86_PrefixAddr16
+ } else {
+ addrMode = 32
+ p = x86_PrefixAddr32
+ }
+ if addrSizeIndex >= 0 {
+ inst.Prefix[addrSizeIndex] |= x86_PrefixIgnored
+ }
+ addrSizeIndex = pos
+ }
+
+ if pos >= len(inst.Prefix) {
+ return x86_instPrefix(src[0], mode) // too long
+ }
+
+ inst.Prefix[pos] = p
+ }
+
+ // Read REX prefix.
+ if pos < len(src) && mode == 64 && x86_Prefix(src[pos]).IsREX() {
+ rex = x86_Prefix(src[pos])
+ rexIndex = pos
+ if pos >= len(inst.Prefix) {
+ return x86_instPrefix(src[0], mode) // too long
+ }
+ inst.Prefix[pos] = rex
+ pos++
+ if rex&x86_PrefixREXW != 0 {
+ dataMode = 64
+ if dataSizeIndex >= 0 {
+ inst.Prefix[dataSizeIndex] |= x86_PrefixIgnored
+ }
+ }
+ }
+
+ // Decode instruction stream, interpreting decoding instructions.
+ // opshift gives the shift to use when saving the next
+ // opcode byte into inst.Opcode.
+ opshift = 24
+ if x86_decoderCover == nil {
+ x86_decoderCover = make([]bool, len(x86_decoder))
+ }
+
+ // Decode loop, executing decoder program.
+ var oldPC, prevPC int
+Decode:
+ for pc := 1; ; { // TODO uint
+ oldPC = prevPC
+ prevPC = pc
+ if x86_trace {
+ println("run", pc)
+ }
+ x := x86_decoder[pc]
+ x86_decoderCover[pc] = true
+ pc++
+
+ // Read and decode ModR/M if needed by opcode.
+ switch x86_decodeOp(x) {
+ case x86_xCondSlashR, x86_xReadSlashR:
+ if haveModrm {
+ return x86_Inst{Len: pos}, x86_errInternal
+ }
+ haveModrm = true
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ modrm = int(src[pos])
+ pos++
+ if opshift >= 0 {
+ inst.Opcode |= uint32(modrm) << uint(opshift)
+ opshift -= 8
+ }
+ mod = modrm >> 6
+ regop = (modrm >> 3) & 07
+ rm = modrm & 07
+ if rex&x86_PrefixREXR != 0 {
+ rexUsed |= x86_PrefixREXR
+ regop |= 8
+ }
+ if addrMode == 16 {
+ // 16-bit modrm form
+ if mod != 3 {
+ haveMem = true
+ mem = x86_addr16[rm]
+ if rm == 6 && mod == 0 {
+ mem.Base = 0
+ }
+
+ // Consume disp16 if present.
+ if mod == 0 && rm == 6 || mod == 2 {
+ if pos+2 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ mem.Disp = int64(binary.LittleEndian.Uint16(src[pos:]))
+ pos += 2
+ }
+
+ // Consume disp8 if present.
+ if mod == 1 {
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ mem.Disp = int64(int8(src[pos]))
+ pos++
+ }
+ }
+ } else {
+ haveMem = mod != 3
+
+ // 32-bit or 64-bit form
+ // Consume SIB encoding if present.
+ if rm == 4 && mod != 3 {
+ haveSIB = true
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ sib = int(src[pos])
+ pos++
+ if opshift >= 0 {
+ inst.Opcode |= uint32(sib) << uint(opshift)
+ opshift -= 8
+ }
+ scale = sib >> 6
+ index = (sib >> 3) & 07
+ base = sib & 07
+ if rex&x86_PrefixREXB != 0 {
+ rexUsed |= x86_PrefixREXB
+ base |= 8
+ }
+ if rex&x86_PrefixREXX != 0 {
+ rexUsed |= x86_PrefixREXX
+ index |= 8
+ }
+
+ mem.Scale = 1 << uint(scale)
+ if index == 4 {
+ // no mem.Index
+ } else {
+ mem.Index = x86_baseRegForBits(addrMode) + x86_Reg(index)
+ }
+ if base&7 == 5 && mod == 0 {
+ // no mem.Base
+ } else {
+ mem.Base = x86_baseRegForBits(addrMode) + x86_Reg(base)
+ }
+ } else {
+ if rex&x86_PrefixREXB != 0 {
+ rexUsed |= x86_PrefixREXB
+ rm |= 8
+ }
+ if mod == 0 && rm&7 == 5 || rm&7 == 4 {
+ // base omitted
+ } else if mod != 3 {
+ mem.Base = x86_baseRegForBits(addrMode) + x86_Reg(rm)
+ }
+ }
+
+ // Consume disp32 if present.
+ if mod == 0 && (rm&7 == 5 || haveSIB && base&7 == 5) || mod == 2 {
+ if pos+4 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ mem.Disp = int64(binary.LittleEndian.Uint32(src[pos:]))
+ pos += 4
+ }
+
+ // Consume disp8 if present.
+ if mod == 1 {
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ mem.Disp = int64(int8(src[pos]))
+ pos++
+ }
+
+ // In 64-bit, mod=0 rm=5 is PC-relative instead of just disp.
+ // See Vol 2A. Table 2-7.
+ if mode == 64 && mod == 0 && rm&7 == 5 {
+ if addrMode == 32 {
+ mem.Base = x86_EIP
+ } else {
+ mem.Base = x86_RIP
+ }
+ }
+ }
+
+ if segIndex >= 0 {
+ mem.Segment = x86_prefixToSegment(inst.Prefix[segIndex])
+ }
+ }
+
+ // Execute single opcode.
+ switch x86_decodeOp(x) {
+ default:
+ println("bad op", x, "at", pc-1, "from", oldPC)
+ return x86_Inst{Len: pos}, x86_errInternal
+
+ case x86_xFail:
+ inst.Op = 0
+ break Decode
+
+ case x86_xMatch:
+ break Decode
+
+ case x86_xJump:
+ pc = int(x86_decoder[pc])
+
+ // Conditional branches.
+
+ case x86_xCondByte:
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ b := src[pos]
+ n := int(x86_decoder[pc])
+ pc++
+ for i := 0; i < n; i++ {
+ xb, xpc := x86_decoder[pc], int(x86_decoder[pc+1])
+ pc += 2
+ if b == byte(xb) {
+ pc = xpc
+ pos++
+ if opshift >= 0 {
+ inst.Opcode |= uint32(b) << uint(opshift)
+ opshift -= 8
+ }
+ continue Decode
+ }
+ }
+ // xCondByte is the only conditional with a fall through,
+ // so that it can be used to pick off special cases before
+ // an xCondSlash. If the fallthrough instruction is xFail,
+ // advance the position so that the decoded instruction
+ // size includes the byte we just compared against.
+ if x86_decodeOp(x86_decoder[pc]) == x86_xJump {
+ pc = int(x86_decoder[pc+1])
+ }
+ if x86_decodeOp(x86_decoder[pc]) == x86_xFail {
+ pos++
+ }
+
+ case x86_xCondIs64:
+ if mode == 64 {
+ pc = int(x86_decoder[pc+1])
+ } else {
+ pc = int(x86_decoder[pc])
+ }
+
+ case x86_xCondIsMem:
+ mem := haveMem
+ if !haveModrm {
+ if pos >= len(src) {
+ return x86_instPrefix(src[0], mode) // too long
+ }
+ mem = src[pos]>>6 != 3
+ }
+ if mem {
+ pc = int(x86_decoder[pc+1])
+ } else {
+ pc = int(x86_decoder[pc])
+ }
+
+ case x86_xCondDataSize:
+ switch dataMode {
+ case 16:
+ if dataSizeIndex >= 0 {
+ inst.Prefix[dataSizeIndex] |= x86_PrefixImplicit
+ }
+ pc = int(x86_decoder[pc])
+ case 32:
+ if dataSizeIndex >= 0 {
+ inst.Prefix[dataSizeIndex] |= x86_PrefixImplicit
+ }
+ pc = int(x86_decoder[pc+1])
+ case 64:
+ rexUsed |= x86_PrefixREXW
+ pc = int(x86_decoder[pc+2])
+ }
+
+ case x86_xCondAddrSize:
+ switch addrMode {
+ case 16:
+ if addrSizeIndex >= 0 {
+ inst.Prefix[addrSizeIndex] |= x86_PrefixImplicit
+ }
+ pc = int(x86_decoder[pc])
+ case 32:
+ if addrSizeIndex >= 0 {
+ inst.Prefix[addrSizeIndex] |= x86_PrefixImplicit
+ }
+ pc = int(x86_decoder[pc+1])
+ case 64:
+ pc = int(x86_decoder[pc+2])
+ }
+
+ case x86_xCondPrefix:
+ // Conditional branch based on presence or absence of prefixes.
+ // The conflict cases here are completely undocumented and
+ // differ significantly between GNU libopcodes and Intel xed.
+ // I have not written assembly code to divine what various CPUs
+ // do, but it wouldn't surprise me if they are not consistent either.
+ //
+ // The basic idea is to switch on the presence of a prefix, so that
+ // for example:
+ //
+ // xCondPrefix, 4
+ // 0xF3, 123,
+ // 0xF2, 234,
+ // 0x66, 345,
+ // 0, 456
+ //
+ // branch to 123 if the F3 prefix is present, 234 if the F2 prefix
+ // is present, 66 if the 345 prefix is present, and 456 otherwise.
+ // The prefixes are given in descending order so that the 0 will be last.
+ //
+ // It is unclear what should happen if multiple conditions are
+ // satisfied: what if F2 and F3 are both present, or if 66 and F2
+ // are present, or if all three are present? The one chosen becomes
+ // part of the opcode and the others do not. Perhaps the answer
+ // depends on the specific opcodes in question.
+ //
+ // The only clear example is that CRC32 is F2 0F 38 F1 /r, and
+ // it comes in 16-bit and 32-bit forms based on the 66 prefix,
+ // so 66 F2 0F 38 F1 /r should be treated as F2 taking priority,
+ // with the 66 being only an operand size override, and probably
+ // F2 66 0F 38 F1 /r should be treated the same.
+ // Perhaps that rule is specific to the case of CRC32, since no
+ // 66 0F 38 F1 instruction is defined (today) (that we know of).
+ // However, both libopcodes and xed seem to generalize this
+ // example and choose F2/F3 in preference to 66, and we
+ // do the same.
+ //
+ // Next, what if both F2 and F3 are present? Which wins?
+ // The Intel xed rule, and ours, is that the one that occurs last wins.
+ // The GNU libopcodes rule, which we implement only in gnuCompat mode,
+ // is that F3 beats F2 unless F3 has no special meaning, in which
+ // case F3 can be a modified on an F2 special meaning.
+ //
+ // Concretely,
+ // 66 0F D6 /r is MOVQ
+ // F2 0F D6 /r is MOVDQ2Q
+ // F3 0F D6 /r is MOVQ2DQ.
+ //
+ // F2 66 0F D6 /r is 66 + MOVDQ2Q always.
+ // 66 F2 0F D6 /r is 66 + MOVDQ2Q always.
+ // F3 66 0F D6 /r is 66 + MOVQ2DQ always.
+ // 66 F3 0F D6 /r is 66 + MOVQ2DQ always.
+ // F2 F3 0F D6 /r is F2 + MOVQ2DQ always.
+ // F3 F2 0F D6 /r is F3 + MOVQ2DQ in Intel xed, but F2 + MOVQ2DQ in GNU libopcodes.
+ // Adding 66 anywhere in the prefix section of the
+ // last two cases does not change the outcome.
+ //
+ // Finally, what if there is a variant in which 66 is a mandatory
+ // prefix rather than an operand size override, but we know of
+ // no corresponding F2/F3 form, and we see both F2/F3 and 66.
+ // Does F2/F3 still take priority, so that the result is an unknown
+ // instruction, or does the 66 take priority, so that the extended
+ // 66 instruction should be interpreted as having a REP/REPN prefix?
+ // Intel xed does the former and GNU libopcodes does the latter.
+ // We side with Intel xed, unless we are trying to match libopcodes
+ // more closely during the comparison-based test suite.
+ //
+ // In 64-bit mode REX.W is another valid prefix to test for, but
+ // there is less ambiguity about that. When present, REX.W is
+ // always the first entry in the table.
+ n := int(x86_decoder[pc])
+ pc++
+ sawF3 := false
+ for j := 0; j < n; j++ {
+ prefix := x86_Prefix(x86_decoder[pc+2*j])
+ if prefix.IsREX() {
+ rexUsed |= prefix
+ if rex&prefix == prefix {
+ pc = int(x86_decoder[pc+2*j+1])
+ continue Decode
+ }
+ continue
+ }
+ ok := false
+ if prefix == 0 {
+ ok = true
+ } else if prefix.IsREX() {
+ rexUsed |= prefix
+ if rex&prefix == prefix {
+ ok = true
+ }
+ } else {
+ if prefix == 0xF3 {
+ sawF3 = true
+ }
+ switch prefix {
+ case x86_PrefixLOCK:
+ if lockIndex >= 0 {
+ inst.Prefix[lockIndex] |= x86_PrefixImplicit
+ ok = true
+ }
+ case x86_PrefixREP, x86_PrefixREPN:
+ if repIndex >= 0 && inst.Prefix[repIndex]&0xFF == prefix {
+ inst.Prefix[repIndex] |= x86_PrefixImplicit
+ ok = true
+ }
+ if gnuCompat && !ok && prefix == 0xF3 && repIndex >= 0 && (j+1 >= n || x86_decoder[pc+2*(j+1)] != 0xF2) {
+ // Check to see if earlier prefix F3 is present.
+ for i := repIndex - 1; i >= 0; i-- {
+ if inst.Prefix[i]&0xFF == prefix {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ ok = true
+ }
+ }
+ }
+ if gnuCompat && !ok && prefix == 0xF2 && repIndex >= 0 && !sawF3 && inst.Prefix[repIndex]&0xFF == 0xF3 {
+ // Check to see if earlier prefix F2 is present.
+ for i := repIndex - 1; i >= 0; i-- {
+ if inst.Prefix[i]&0xFF == prefix {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ ok = true
+ }
+ }
+ }
+ case x86_PrefixCS, x86_PrefixDS, x86_PrefixES, x86_PrefixFS, x86_PrefixGS, x86_PrefixSS:
+ if segIndex >= 0 && inst.Prefix[segIndex]&0xFF == prefix {
+ inst.Prefix[segIndex] |= x86_PrefixImplicit
+ ok = true
+ }
+ case x86_PrefixDataSize:
+ // Looking for 66 mandatory prefix.
+ // The F2/F3 mandatory prefixes take priority when both are present.
+ // If we got this far in the xCondPrefix table and an F2/F3 is present,
+ // it means the table didn't have any entry for that prefix. But if 66 has
+ // special meaning, perhaps F2/F3 have special meaning that we don't know.
+ // Intel xed works this way, treating the F2/F3 as inhibiting the 66.
+ // GNU libopcodes allows the 66 to match. We do what Intel xed does
+ // except in gnuCompat mode.
+ if repIndex >= 0 && !gnuCompat {
+ inst.Op = 0
+ break Decode
+ }
+ if dataSizeIndex >= 0 {
+ inst.Prefix[dataSizeIndex] |= x86_PrefixImplicit
+ ok = true
+ }
+ case x86_PrefixAddrSize:
+ if addrSizeIndex >= 0 {
+ inst.Prefix[addrSizeIndex] |= x86_PrefixImplicit
+ ok = true
+ }
+ }
+ }
+ if ok {
+ pc = int(x86_decoder[pc+2*j+1])
+ continue Decode
+ }
+ }
+ inst.Op = 0
+ break Decode
+
+ case x86_xCondSlashR:
+ pc = int(x86_decoder[pc+regop&7])
+
+ // Input.
+
+ case x86_xReadSlashR:
+ // done above
+
+ case x86_xReadIb:
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ imm8 = int8(src[pos])
+ pos++
+
+ case x86_xReadIw:
+ if pos+2 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ imm = int64(binary.LittleEndian.Uint16(src[pos:]))
+ pos += 2
+
+ case x86_xReadId:
+ if pos+4 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ imm = int64(binary.LittleEndian.Uint32(src[pos:]))
+ pos += 4
+
+ case x86_xReadIo:
+ if pos+8 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ imm = int64(binary.LittleEndian.Uint64(src[pos:]))
+ pos += 8
+
+ case x86_xReadCb:
+ if pos >= len(src) {
+ return x86_truncated(src, mode)
+ }
+ immc = int64(src[pos])
+ pos++
+
+ case x86_xReadCw:
+ if pos+2 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ immc = int64(binary.LittleEndian.Uint16(src[pos:]))
+ pos += 2
+
+ case x86_xReadCm:
+ if addrMode == 16 {
+ if pos+2 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ immc = int64(binary.LittleEndian.Uint16(src[pos:]))
+ pos += 2
+ } else if addrMode == 32 {
+ if pos+4 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ immc = int64(binary.LittleEndian.Uint32(src[pos:]))
+ pos += 4
+ } else {
+ if pos+8 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ immc = int64(binary.LittleEndian.Uint64(src[pos:]))
+ pos += 8
+ }
+ case x86_xReadCd:
+ if pos+4 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ immc = int64(binary.LittleEndian.Uint32(src[pos:]))
+ pos += 4
+
+ case x86_xReadCp:
+ if pos+6 > len(src) {
+ return x86_truncated(src, mode)
+ }
+ w := binary.LittleEndian.Uint32(src[pos:])
+ w2 := binary.LittleEndian.Uint16(src[pos+4:])
+ immc = int64(w2)<<32 | int64(w)
+ pos += 6
+
+ // Output.
+
+ case x86_xSetOp:
+ inst.Op = x86_Op(x86_decoder[pc])
+ pc++
+
+ case x86_xArg1,
+ x86_xArg3,
+ x86_xArgAL,
+ x86_xArgAX,
+ x86_xArgCL,
+ x86_xArgCS,
+ x86_xArgDS,
+ x86_xArgDX,
+ x86_xArgEAX,
+ x86_xArgEDX,
+ x86_xArgES,
+ x86_xArgFS,
+ x86_xArgGS,
+ x86_xArgRAX,
+ x86_xArgRDX,
+ x86_xArgSS,
+ x86_xArgST,
+ x86_xArgXMM0:
+ inst.Args[narg] = x86_fixedArg[x]
+ narg++
+
+ case x86_xArgImm8:
+ inst.Args[narg] = x86_Imm(imm8)
+ narg++
+
+ case x86_xArgImm8u:
+ inst.Args[narg] = x86_Imm(uint8(imm8))
+ narg++
+
+ case x86_xArgImm16:
+ inst.Args[narg] = x86_Imm(int16(imm))
+ narg++
+
+ case x86_xArgImm16u:
+ inst.Args[narg] = x86_Imm(uint16(imm))
+ narg++
+
+ case x86_xArgImm32:
+ inst.Args[narg] = x86_Imm(int32(imm))
+ narg++
+
+ case x86_xArgImm64:
+ inst.Args[narg] = x86_Imm(imm)
+ narg++
+
+ case x86_xArgM,
+ x86_xArgM128,
+ x86_xArgM1428byte,
+ x86_xArgM16,
+ x86_xArgM16and16,
+ x86_xArgM16and32,
+ x86_xArgM16and64,
+ x86_xArgM16colon16,
+ x86_xArgM16colon32,
+ x86_xArgM16colon64,
+ x86_xArgM16int,
+ x86_xArgM2byte,
+ x86_xArgM32,
+ x86_xArgM32and32,
+ x86_xArgM32fp,
+ x86_xArgM32int,
+ x86_xArgM512byte,
+ x86_xArgM64,
+ x86_xArgM64fp,
+ x86_xArgM64int,
+ x86_xArgM8,
+ x86_xArgM80bcd,
+ x86_xArgM80dec,
+ x86_xArgM80fp,
+ x86_xArgM94108byte,
+ x86_xArgMem:
+ if !haveMem {
+ inst.Op = 0
+ break Decode
+ }
+ inst.Args[narg] = mem
+ inst.MemBytes = int(x86_memBytes[x86_decodeOp(x)])
+ narg++
+
+ case x86_xArgPtr16colon16:
+ inst.Args[narg] = x86_Imm(immc >> 16)
+ inst.Args[narg+1] = x86_Imm(immc & (1<<16 - 1))
+ narg += 2
+
+ case x86_xArgPtr16colon32:
+ inst.Args[narg] = x86_Imm(immc >> 32)
+ inst.Args[narg+1] = x86_Imm(immc & (1<<32 - 1))
+ narg += 2
+
+ case x86_xArgMoffs8, x86_xArgMoffs16, x86_xArgMoffs32, x86_xArgMoffs64:
+ // TODO(rsc): Can address be 64 bits?
+ mem = x86_Mem{Disp: int64(immc)}
+ if segIndex >= 0 {
+ mem.Segment = x86_prefixToSegment(inst.Prefix[segIndex])
+ inst.Prefix[segIndex] |= x86_PrefixImplicit
+ }
+ inst.Args[narg] = mem
+ inst.MemBytes = int(x86_memBytes[x86_decodeOp(x)])
+ narg++
+
+ case x86_xArgR8, x86_xArgR16, x86_xArgR32, x86_xArgR64, x86_xArgXmm, x86_xArgXmm1, x86_xArgDR0dashDR7:
+ base := x86_baseReg[x]
+ index := x86_Reg(regop)
+ if rex != 0 && base == x86_AL && index >= 4 {
+ rexUsed |= x86_PrefixREX
+ index -= 4
+ base = x86_SPB
+ }
+ inst.Args[narg] = base + index
+ narg++
+
+ case x86_xArgMm, x86_xArgMm1, x86_xArgTR0dashTR7:
+ inst.Args[narg] = x86_baseReg[x] + x86_Reg(regop&7)
+ narg++
+
+ case x86_xArgCR0dashCR7:
+ // AMD documents an extension that the LOCK prefix
+ // can be used in place of a REX prefix in order to access
+ // CR8 from 32-bit mode. The LOCK prefix is allowed in
+ // all modes, provided the corresponding CPUID bit is set.
+ if lockIndex >= 0 {
+ inst.Prefix[lockIndex] |= x86_PrefixImplicit
+ regop += 8
+ }
+ inst.Args[narg] = x86_CR0 + x86_Reg(regop)
+ narg++
+
+ case x86_xArgSreg:
+ regop &= 7
+ if regop >= 6 {
+ inst.Op = 0
+ break Decode
+ }
+ inst.Args[narg] = x86_ES + x86_Reg(regop)
+ narg++
+
+ case x86_xArgRmf16, x86_xArgRmf32, x86_xArgRmf64:
+ base := x86_baseReg[x]
+ index := x86_Reg(modrm & 07)
+ if rex&x86_PrefixREXB != 0 {
+ rexUsed |= x86_PrefixREXB
+ index += 8
+ }
+ inst.Args[narg] = base + index
+ narg++
+
+ case x86_xArgR8op, x86_xArgR16op, x86_xArgR32op, x86_xArgR64op, x86_xArgSTi:
+ n := inst.Opcode >> uint(opshift+8) & 07
+ base := x86_baseReg[x]
+ index := x86_Reg(n)
+ if rex&x86_PrefixREXB != 0 && x86_decodeOp(x) != x86_xArgSTi {
+ rexUsed |= x86_PrefixREXB
+ index += 8
+ }
+ if rex != 0 && base == x86_AL && index >= 4 {
+ rexUsed |= x86_PrefixREX
+ index -= 4
+ base = x86_SPB
+ }
+ inst.Args[narg] = base + index
+ narg++
+
+ case x86_xArgRM8, x86_xArgRM16, x86_xArgRM32, x86_xArgRM64, x86_xArgR32M16, x86_xArgR32M8, x86_xArgR64M16,
+ x86_xArgMmM32, x86_xArgMmM64, x86_xArgMm2M64,
+ x86_xArgXmm2M16, x86_xArgXmm2M32, x86_xArgXmm2M64, x86_xArgXmmM64, x86_xArgXmmM128, x86_xArgXmmM32, x86_xArgXmm2M128:
+ if haveMem {
+ inst.Args[narg] = mem
+ inst.MemBytes = int(x86_memBytes[x86_decodeOp(x)])
+ } else {
+ base := x86_baseReg[x]
+ index := x86_Reg(rm)
+ switch x86_decodeOp(x) {
+ case x86_xArgMmM32, x86_xArgMmM64, x86_xArgMm2M64:
+ // There are only 8 MMX registers, so these ignore the REX.X bit.
+ index &= 7
+ case x86_xArgRM8:
+ if rex != 0 && index >= 4 {
+ rexUsed |= x86_PrefixREX
+ index -= 4
+ base = x86_SPB
+ }
+ }
+ inst.Args[narg] = base + index
+ }
+ narg++
+
+ case x86_xArgMm2: // register only; TODO(rsc): Handle with tag modrm_regonly tag
+ if haveMem {
+ inst.Op = 0
+ break Decode
+ }
+ inst.Args[narg] = x86_baseReg[x] + x86_Reg(rm&7)
+ narg++
+
+ case x86_xArgXmm2: // register only; TODO(rsc): Handle with tag modrm_regonly tag
+ if haveMem {
+ inst.Op = 0
+ break Decode
+ }
+ inst.Args[narg] = x86_baseReg[x] + x86_Reg(rm)
+ narg++
+
+ case x86_xArgRel8:
+ inst.Args[narg] = x86_Rel(int8(immc))
+ narg++
+
+ case x86_xArgRel16:
+ inst.Args[narg] = x86_Rel(int16(immc))
+ narg++
+
+ case x86_xArgRel32:
+ inst.Args[narg] = x86_Rel(int32(immc))
+ narg++
+ }
+ }
+
+ if inst.Op == 0 {
+ // Invalid instruction.
+ if nprefix > 0 {
+ return x86_instPrefix(src[0], mode) // invalid instruction
+ }
+ return x86_Inst{Len: pos}, x86_ErrUnrecognized
+ }
+
+ // Matched! Hooray!
+
+ // 90 decodes as XCHG EAX, EAX but is NOP.
+ // 66 90 decodes as XCHG AX, AX and is NOP too.
+ // 48 90 decodes as XCHG RAX, RAX and is NOP too.
+ // 43 90 decodes as XCHG R8D, EAX and is *not* NOP.
+ // F3 90 decodes as REP XCHG EAX, EAX but is PAUSE.
+ // It's all too special to handle in the decoding tables, at least for now.
+ if inst.Op == x86_XCHG && inst.Opcode>>24 == 0x90 {
+ if inst.Args[0] == x86_RAX || inst.Args[0] == x86_EAX || inst.Args[0] == x86_AX {
+ inst.Op = x86_NOP
+ if dataSizeIndex >= 0 {
+ inst.Prefix[dataSizeIndex] &^= x86_PrefixImplicit
+ }
+ inst.Args[0] = nil
+ inst.Args[1] = nil
+ }
+ if repIndex >= 0 && inst.Prefix[repIndex] == 0xF3 {
+ inst.Prefix[repIndex] |= x86_PrefixImplicit
+ inst.Op = x86_PAUSE
+ inst.Args[0] = nil
+ inst.Args[1] = nil
+ } else if gnuCompat {
+ for i := nprefix - 1; i >= 0; i-- {
+ if inst.Prefix[i]&0xFF == 0xF3 {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ inst.Op = x86_PAUSE
+ inst.Args[0] = nil
+ inst.Args[1] = nil
+ break
+ }
+ }
+ }
+ }
+
+ // defaultSeg returns the default segment for an implicit
+ // memory reference: the final override if present, or else DS.
+ defaultSeg := func() x86_Reg {
+ if segIndex >= 0 {
+ inst.Prefix[segIndex] |= x86_PrefixImplicit
+ return x86_prefixToSegment(inst.Prefix[segIndex])
+ }
+ return x86_DS
+ }
+
+ // Add implicit arguments not present in the tables.
+ // Normally we shy away from making implicit arguments explicit,
+ // following the Intel manuals, but adding the arguments seems
+ // the best way to express the effect of the segment override prefixes.
+ // TODO(rsc): Perhaps add these to the tables and
+ // create bytecode instructions for them.
+ usedAddrSize := false
+ switch inst.Op {
+ case x86_INSB, x86_INSW, x86_INSD:
+ inst.Args[0] = x86_Mem{Segment: x86_ES, Base: x86_baseRegForBits(addrMode) + x86_DI - x86_AX}
+ inst.Args[1] = x86_DX
+ usedAddrSize = true
+
+ case x86_OUTSB, x86_OUTSW, x86_OUTSD:
+ inst.Args[0] = x86_DX
+ inst.Args[1] = x86_Mem{Segment: defaultSeg(), Base: x86_baseRegForBits(addrMode) + x86_SI - x86_AX}
+ usedAddrSize = true
+
+ case x86_MOVSB, x86_MOVSW, x86_MOVSD, x86_MOVSQ:
+ inst.Args[0] = x86_Mem{Segment: x86_ES, Base: x86_baseRegForBits(addrMode) + x86_DI - x86_AX}
+ inst.Args[1] = x86_Mem{Segment: defaultSeg(), Base: x86_baseRegForBits(addrMode) + x86_SI - x86_AX}
+ usedAddrSize = true
+
+ case x86_CMPSB, x86_CMPSW, x86_CMPSD, x86_CMPSQ:
+ inst.Args[0] = x86_Mem{Segment: defaultSeg(), Base: x86_baseRegForBits(addrMode) + x86_SI - x86_AX}
+ inst.Args[1] = x86_Mem{Segment: x86_ES, Base: x86_baseRegForBits(addrMode) + x86_DI - x86_AX}
+ usedAddrSize = true
+
+ case x86_LODSB, x86_LODSW, x86_LODSD, x86_LODSQ:
+ switch inst.Op {
+ case x86_LODSB:
+ inst.Args[0] = x86_AL
+ case x86_LODSW:
+ inst.Args[0] = x86_AX
+ case x86_LODSD:
+ inst.Args[0] = x86_EAX
+ case x86_LODSQ:
+ inst.Args[0] = x86_RAX
+ }
+ inst.Args[1] = x86_Mem{Segment: defaultSeg(), Base: x86_baseRegForBits(addrMode) + x86_SI - x86_AX}
+ usedAddrSize = true
+
+ case x86_STOSB, x86_STOSW, x86_STOSD, x86_STOSQ:
+ inst.Args[0] = x86_Mem{Segment: x86_ES, Base: x86_baseRegForBits(addrMode) + x86_DI - x86_AX}
+ switch inst.Op {
+ case x86_STOSB:
+ inst.Args[1] = x86_AL
+ case x86_STOSW:
+ inst.Args[1] = x86_AX
+ case x86_STOSD:
+ inst.Args[1] = x86_EAX
+ case x86_STOSQ:
+ inst.Args[1] = x86_RAX
+ }
+ usedAddrSize = true
+
+ case x86_SCASB, x86_SCASW, x86_SCASD, x86_SCASQ:
+ inst.Args[1] = x86_Mem{Segment: x86_ES, Base: x86_baseRegForBits(addrMode) + x86_DI - x86_AX}
+ switch inst.Op {
+ case x86_SCASB:
+ inst.Args[0] = x86_AL
+ case x86_SCASW:
+ inst.Args[0] = x86_AX
+ case x86_SCASD:
+ inst.Args[0] = x86_EAX
+ case x86_SCASQ:
+ inst.Args[0] = x86_RAX
+ }
+ usedAddrSize = true
+
+ case x86_XLATB:
+ inst.Args[0] = x86_Mem{Segment: defaultSeg(), Base: x86_baseRegForBits(addrMode) + x86_BX - x86_AX}
+ usedAddrSize = true
+ }
+
+ // If we used the address size annotation to construct the
+ // argument list, mark that prefix as implicit: it doesn't need
+ // to be shown when printing the instruction.
+ if haveMem || usedAddrSize {
+ if addrSizeIndex >= 0 {
+ inst.Prefix[addrSizeIndex] |= x86_PrefixImplicit
+ }
+ }
+
+ // Similarly, if there's some memory operand, the segment
+ // will be shown there and doesn't need to be shown as an
+ // explicit prefix.
+ if haveMem {
+ if segIndex >= 0 {
+ inst.Prefix[segIndex] |= x86_PrefixImplicit
+ }
+ }
+
+ // Branch predict prefixes are overloaded segment prefixes,
+ // since segment prefixes don't make sense on conditional jumps.
+ // Rewrite final instance to prediction prefix.
+ // The set of instructions to which the prefixes apply (other then the
+ // Jcc conditional jumps) is not 100% clear from the manuals, but
+ // the disassemblers seem to agree about the LOOP and JCXZ instructions,
+ // so we'll follow along.
+ // TODO(rsc): Perhaps this instruction class should be derived from the CSV.
+ if x86_isCondJmp[inst.Op] || x86_isLoop[inst.Op] || inst.Op == x86_JCXZ || inst.Op == x86_JECXZ || inst.Op == x86_JRCXZ {
+ PredictLoop:
+ for i := nprefix - 1; i >= 0; i-- {
+ p := inst.Prefix[i]
+ switch p & 0xFF {
+ case x86_PrefixCS:
+ inst.Prefix[i] = x86_PrefixPN
+ break PredictLoop
+ case x86_PrefixDS:
+ inst.Prefix[i] = x86_PrefixPT
+ break PredictLoop
+ }
+ }
+ }
+
+ // The BND prefix is part of the Intel Memory Protection Extensions (MPX).
+ // A REPN applied to certain control transfers is a BND prefix to bound
+ // the range of possible destinations. There's surprisingly little documentation
+ // about this, so we just do what libopcodes and xed agree on.
+ // In particular, it's unclear why a REPN applied to LOOP or JCXZ instructions
+ // does not turn into a BND.
+ // TODO(rsc): Perhaps this instruction class should be derived from the CSV.
+ if x86_isCondJmp[inst.Op] || inst.Op == x86_JMP || inst.Op == x86_CALL || inst.Op == x86_RET {
+ for i := nprefix - 1; i >= 0; i-- {
+ p := inst.Prefix[i]
+ if p&^x86_PrefixIgnored == x86_PrefixREPN {
+ inst.Prefix[i] = x86_PrefixBND
+ break
+ }
+ }
+ }
+
+ // The LOCK prefix only applies to certain instructions, and then only
+ // to instances of the instruction with a memory destination.
+ // Other uses of LOCK are invalid and cause a processor exception,
+ // in contrast to the "just ignore it" spirit applied to all other prefixes.
+ // Mark invalid lock prefixes.
+ hasLock := false
+ if lockIndex >= 0 && inst.Prefix[lockIndex]&x86_PrefixImplicit == 0 {
+ switch inst.Op {
+ // TODO(rsc): Perhaps this instruction class should be derived from the CSV.
+ case x86_ADD, x86_ADC, x86_AND, x86_BTC, x86_BTR, x86_BTS, x86_CMPXCHG, x86_CMPXCHG8B, x86_CMPXCHG16B, x86_DEC, x86_INC, x86_NEG, x86_NOT, x86_OR, x86_SBB, x86_SUB, x86_XOR, x86_XADD, x86_XCHG:
+ if x86_isMem(inst.Args[0]) {
+ hasLock = true
+ break
+ }
+ fallthrough
+ default:
+ inst.Prefix[lockIndex] |= x86_PrefixInvalid
+ }
+ }
+
+ // In certain cases, all of which require a memory destination,
+ // the REPN and REP prefixes are interpreted as XACQUIRE and XRELEASE
+ // from the Intel Transactional Synchroniation Extensions (TSX).
+ //
+ // The specific rules are:
+ // (1) Any instruction with a valid LOCK prefix can have XACQUIRE or XRELEASE.
+ // (2) Any XCHG, which always has an implicit LOCK, can have XACQUIRE or XRELEASE.
+ // (3) Any 0x88-, 0x89-, 0xC6-, or 0xC7-opcode MOV can have XRELEASE.
+ if x86_isMem(inst.Args[0]) {
+ if inst.Op == x86_XCHG {
+ hasLock = true
+ }
+
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ p := inst.Prefix[i] &^ x86_PrefixIgnored
+ switch p {
+ case x86_PrefixREPN:
+ if hasLock {
+ inst.Prefix[i] = inst.Prefix[i]&x86_PrefixIgnored | x86_PrefixXACQUIRE
+ }
+
+ case x86_PrefixREP:
+ if hasLock {
+ inst.Prefix[i] = inst.Prefix[i]&x86_PrefixIgnored | x86_PrefixXRELEASE
+ }
+
+ if inst.Op == x86_MOV {
+ op := (inst.Opcode >> 24) &^ 1
+ if op == 0x88 || op == 0xC6 {
+ inst.Prefix[i] = inst.Prefix[i]&x86_PrefixIgnored | x86_PrefixXRELEASE
+ }
+ }
+ }
+ }
+ }
+
+ // If REP is used on a non-REP-able instruction, mark the prefix as ignored.
+ if repIndex >= 0 {
+ switch inst.Prefix[repIndex] {
+ case x86_PrefixREP, x86_PrefixREPN:
+ switch inst.Op {
+ // According to the manuals, the REP/REPE prefix applies to all of these,
+ // while the REPN applies only to some of them. However, both libopcodes
+ // and xed show both prefixes explicitly for all instructions, so we do the same.
+ // TODO(rsc): Perhaps this instruction class should be derived from the CSV.
+ case x86_INSB, x86_INSW, x86_INSD,
+ x86_MOVSB, x86_MOVSW, x86_MOVSD, x86_MOVSQ,
+ x86_OUTSB, x86_OUTSW, x86_OUTSD,
+ x86_LODSB, x86_LODSW, x86_LODSD, x86_LODSQ,
+ x86_CMPSB, x86_CMPSW, x86_CMPSD, x86_CMPSQ,
+ x86_SCASB, x86_SCASW, x86_SCASD, x86_SCASQ,
+ x86_STOSB, x86_STOSW, x86_STOSD, x86_STOSQ:
+ // ok
+ default:
+ inst.Prefix[repIndex] |= x86_PrefixIgnored
+ }
+ }
+ }
+
+ // If REX was present, mark implicit if all the 1 bits were consumed.
+ if rexIndex >= 0 {
+ if rexUsed != 0 {
+ rexUsed |= x86_PrefixREX
+ }
+ if rex&^rexUsed == 0 {
+ inst.Prefix[rexIndex] |= x86_PrefixImplicit
+ }
+ }
+
+ inst.DataSize = dataMode
+ inst.AddrSize = addrMode
+ inst.Mode = mode
+ inst.Len = pos
+ return inst, nil
+}
+
+var x86_errInternal = errors.New("internal error")
+
+// addr16 records the eight 16-bit addressing modes.
+var x86_addr16 = [8]x86_Mem{
+ {Base: x86_BX, Scale: 1, Index: x86_SI},
+ {Base: x86_BX, Scale: 1, Index: x86_DI},
+ {Base: x86_BP, Scale: 1, Index: x86_SI},
+ {Base: x86_BP, Scale: 1, Index: x86_DI},
+ {Base: x86_SI},
+ {Base: x86_DI},
+ {Base: x86_BP},
+ {Base: x86_BX},
+}
+
+// baseReg returns the base register for a given register size in bits.
+func x86_baseRegForBits(bits int) x86_Reg {
+ switch bits {
+ case 8:
+ return x86_AL
+ case 16:
+ return x86_AX
+ case 32:
+ return x86_EAX
+ case 64:
+ return x86_RAX
+ }
+ return 0
+}
+
+// baseReg records the base register for argument types that specify
+// a range of registers indexed by op, regop, or rm.
+var x86_baseReg = [...]x86_Reg{
+ x86_xArgDR0dashDR7: x86_DR0,
+ x86_xArgMm1: x86_M0,
+ x86_xArgMm2: x86_M0,
+ x86_xArgMm2M64: x86_M0,
+ x86_xArgMm: x86_M0,
+ x86_xArgMmM32: x86_M0,
+ x86_xArgMmM64: x86_M0,
+ x86_xArgR16: x86_AX,
+ x86_xArgR16op: x86_AX,
+ x86_xArgR32: x86_EAX,
+ x86_xArgR32M16: x86_EAX,
+ x86_xArgR32M8: x86_EAX,
+ x86_xArgR32op: x86_EAX,
+ x86_xArgR64: x86_RAX,
+ x86_xArgR64M16: x86_RAX,
+ x86_xArgR64op: x86_RAX,
+ x86_xArgR8: x86_AL,
+ x86_xArgR8op: x86_AL,
+ x86_xArgRM16: x86_AX,
+ x86_xArgRM32: x86_EAX,
+ x86_xArgRM64: x86_RAX,
+ x86_xArgRM8: x86_AL,
+ x86_xArgRmf16: x86_AX,
+ x86_xArgRmf32: x86_EAX,
+ x86_xArgRmf64: x86_RAX,
+ x86_xArgSTi: x86_F0,
+ x86_xArgTR0dashTR7: x86_TR0,
+ x86_xArgXmm1: x86_X0,
+ x86_xArgXmm2: x86_X0,
+ x86_xArgXmm2M128: x86_X0,
+ x86_xArgXmm2M16: x86_X0,
+ x86_xArgXmm2M32: x86_X0,
+ x86_xArgXmm2M64: x86_X0,
+ x86_xArgXmm: x86_X0,
+ x86_xArgXmmM128: x86_X0,
+ x86_xArgXmmM32: x86_X0,
+ x86_xArgXmmM64: x86_X0,
+}
+
+// prefixToSegment returns the segment register
+// corresponding to a particular segment prefix.
+func x86_prefixToSegment(p x86_Prefix) x86_Reg {
+ switch p &^ x86_PrefixImplicit {
+ case x86_PrefixCS:
+ return x86_CS
+ case x86_PrefixDS:
+ return x86_DS
+ case x86_PrefixES:
+ return x86_ES
+ case x86_PrefixFS:
+ return x86_FS
+ case x86_PrefixGS:
+ return x86_GS
+ case x86_PrefixSS:
+ return x86_SS
+ }
+ return 0
+}
+
+// fixedArg records the fixed arguments corresponding to the given bytecodes.
+var x86_fixedArg = [...]x86_Arg{
+ x86_xArg1: x86_Imm(1),
+ x86_xArg3: x86_Imm(3),
+ x86_xArgAL: x86_AL,
+ x86_xArgAX: x86_AX,
+ x86_xArgDX: x86_DX,
+ x86_xArgEAX: x86_EAX,
+ x86_xArgEDX: x86_EDX,
+ x86_xArgRAX: x86_RAX,
+ x86_xArgRDX: x86_RDX,
+ x86_xArgCL: x86_CL,
+ x86_xArgCS: x86_CS,
+ x86_xArgDS: x86_DS,
+ x86_xArgES: x86_ES,
+ x86_xArgFS: x86_FS,
+ x86_xArgGS: x86_GS,
+ x86_xArgSS: x86_SS,
+ x86_xArgST: x86_F0,
+ x86_xArgXMM0: x86_X0,
+}
+
+// memBytes records the size of the memory pointed at
+// by a memory argument of the given form.
+var x86_memBytes = [...]int8{
+ x86_xArgM128: 128 / 8,
+ x86_xArgM16: 16 / 8,
+ x86_xArgM16and16: (16 + 16) / 8,
+ x86_xArgM16colon16: (16 + 16) / 8,
+ x86_xArgM16colon32: (16 + 32) / 8,
+ x86_xArgM16int: 16 / 8,
+ x86_xArgM2byte: 2,
+ x86_xArgM32: 32 / 8,
+ x86_xArgM32and32: (32 + 32) / 8,
+ x86_xArgM32fp: 32 / 8,
+ x86_xArgM32int: 32 / 8,
+ x86_xArgM64: 64 / 8,
+ x86_xArgM64fp: 64 / 8,
+ x86_xArgM64int: 64 / 8,
+ x86_xArgMm2M64: 64 / 8,
+ x86_xArgMmM32: 32 / 8,
+ x86_xArgMmM64: 64 / 8,
+ x86_xArgMoffs16: 16 / 8,
+ x86_xArgMoffs32: 32 / 8,
+ x86_xArgMoffs64: 64 / 8,
+ x86_xArgMoffs8: 8 / 8,
+ x86_xArgR32M16: 16 / 8,
+ x86_xArgR32M8: 8 / 8,
+ x86_xArgR64M16: 16 / 8,
+ x86_xArgRM16: 16 / 8,
+ x86_xArgRM32: 32 / 8,
+ x86_xArgRM64: 64 / 8,
+ x86_xArgRM8: 8 / 8,
+ x86_xArgXmm2M128: 128 / 8,
+ x86_xArgXmm2M16: 16 / 8,
+ x86_xArgXmm2M32: 32 / 8,
+ x86_xArgXmm2M64: 64 / 8,
+ x86_xArgXmm: 128 / 8,
+ x86_xArgXmmM128: 128 / 8,
+ x86_xArgXmmM32: 32 / 8,
+ x86_xArgXmmM64: 64 / 8,
+}
+
+// isCondJmp records the conditional jumps.
+var x86_isCondJmp = [x86_maxOp + 1]bool{
+ x86_JA: true,
+ x86_JAE: true,
+ x86_JB: true,
+ x86_JBE: true,
+ x86_JE: true,
+ x86_JG: true,
+ x86_JGE: true,
+ x86_JL: true,
+ x86_JLE: true,
+ x86_JNE: true,
+ x86_JNO: true,
+ x86_JNP: true,
+ x86_JNS: true,
+ x86_JO: true,
+ x86_JP: true,
+ x86_JS: true,
+}
+
+// isLoop records the loop operators.
+var x86_isLoop = [x86_maxOp + 1]bool{
+ x86_LOOP: true,
+ x86_LOOPE: true,
+ x86_LOOPNE: true,
+ x86_JECXZ: true,
+ x86_JRCXZ: true,
+}
+
+/* gnu.go */
+
+// Copyright 2014 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// GNUSyntax returns the GNU assembler syntax for the instruction, as defined by GNU binutils.
+// This general form is often called ``AT&T syntax'' as a reference to AT&T System V Unix.
+func x86_GNUSyntax(inst x86_Inst) string {
+ // Rewrite instruction to mimic GNU peculiarities.
+ // Note that inst has been passed by value and contains
+ // no pointers, so any changes we make here are local
+ // and will not propagate back out to the caller.
+
+ // Adjust opcode [sic].
+ switch inst.Op {
+ case x86_FDIV, x86_FDIVR, x86_FSUB, x86_FSUBR, x86_FDIVP, x86_FDIVRP, x86_FSUBP, x86_FSUBRP:
+ // DC E0, DC F0: libopcodes swaps FSUBR/FSUB and FDIVR/FDIV, at least
+ // if you believe the Intel manual is correct (the encoding is irregular as given;
+ // libopcodes uses the more regular expected encoding).
+ // TODO(rsc): Test to ensure Intel manuals are correct and report to libopcodes maintainers?
+ // NOTE: iant thinks this is deliberate, but we can't find the history.
+ _, reg1 := inst.Args[0].(x86_Reg)
+ _, reg2 := inst.Args[1].(x86_Reg)
+ if reg1 && reg2 && (inst.Opcode>>24 == 0xDC || inst.Opcode>>24 == 0xDE) {
+ switch inst.Op {
+ case x86_FDIV:
+ inst.Op = x86_FDIVR
+ case x86_FDIVR:
+ inst.Op = x86_FDIV
+ case x86_FSUB:
+ inst.Op = x86_FSUBR
+ case x86_FSUBR:
+ inst.Op = x86_FSUB
+ case x86_FDIVP:
+ inst.Op = x86_FDIVRP
+ case x86_FDIVRP:
+ inst.Op = x86_FDIVP
+ case x86_FSUBP:
+ inst.Op = x86_FSUBRP
+ case x86_FSUBRP:
+ inst.Op = x86_FSUBP
+ }
+ }
+
+ case x86_MOVNTSD:
+ // MOVNTSD is F2 0F 2B /r.
+ // MOVNTSS is F3 0F 2B /r (supposedly; not in manuals).
+ // Usually inner prefixes win for display,
+ // so that F3 F2 0F 2B 11 is REP MOVNTSD
+ // and F2 F3 0F 2B 11 is REPN MOVNTSS.
+ // Libopcodes always prefers MOVNTSS regardless of prefix order.
+ if x86_countPrefix(&inst, 0xF3) > 0 {
+ found := false
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ switch inst.Prefix[i] & 0xFF {
+ case 0xF3:
+ if !found {
+ found = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ case 0xF2:
+ inst.Prefix[i] &^= x86_PrefixImplicit
+ }
+ }
+ inst.Op = x86_MOVNTSS
+ }
+ }
+
+ // Add implicit arguments.
+ switch inst.Op {
+ case x86_MONITOR:
+ inst.Args[0] = x86_EDX
+ inst.Args[1] = x86_ECX
+ inst.Args[2] = x86_EAX
+ if inst.AddrSize == 16 {
+ inst.Args[2] = x86_AX
+ }
+
+ case x86_MWAIT:
+ if inst.Mode == 64 {
+ inst.Args[0] = x86_RCX
+ inst.Args[1] = x86_RAX
+ } else {
+ inst.Args[0] = x86_ECX
+ inst.Args[1] = x86_EAX
+ }
+ }
+
+ // Adjust which prefixes will be displayed.
+ // The rule is to display all the prefixes not implied by
+ // the usual instruction display, that is, all the prefixes
+ // except the ones with PrefixImplicit set.
+ // However, of course, there are exceptions to the rule.
+ switch inst.Op {
+ case x86_CRC32:
+ // CRC32 has a mandatory F2 prefix.
+ // If there are multiple F2s and no F3s, the extra F2s do not print.
+ // (And Decode has already marked them implicit.)
+ // However, if there is an F3 anywhere, then the extra F2s do print.
+ // If there are multiple F2 prefixes *and* an (ignored) F3,
+ // then libopcodes prints the extra F2s as REPNs.
+ if x86_countPrefix(&inst, 0xF2) > 1 {
+ x86_unmarkImplicit(&inst, 0xF2)
+ x86_markLastImplicit(&inst, 0xF2)
+ }
+
+ // An unused data size override should probably be shown,
+ // to distinguish DATA16 CRC32B from plain CRC32B,
+ // but libopcodes always treats the final override as implicit
+ // and the others as explicit.
+ x86_unmarkImplicit(&inst, x86_PrefixDataSize)
+ x86_markLastImplicit(&inst, x86_PrefixDataSize)
+
+ case x86_CVTSI2SD, x86_CVTSI2SS:
+ if !x86_isMem(inst.Args[1]) {
+ x86_markLastImplicit(&inst, x86_PrefixDataSize)
+ }
+
+ case x86_CVTSD2SI, x86_CVTSS2SI, x86_CVTTSD2SI, x86_CVTTSS2SI,
+ x86_ENTER, x86_FLDENV, x86_FNSAVE, x86_FNSTENV, x86_FRSTOR, x86_LGDT, x86_LIDT, x86_LRET,
+ x86_POP, x86_PUSH, x86_RET, x86_SGDT, x86_SIDT, x86_SYSRET, x86_XBEGIN:
+ x86_markLastImplicit(&inst, x86_PrefixDataSize)
+
+ case x86_LOOP, x86_LOOPE, x86_LOOPNE, x86_MONITOR:
+ x86_markLastImplicit(&inst, x86_PrefixAddrSize)
+
+ case x86_MOV:
+ // The 16-bit and 32-bit forms of MOV Sreg, dst and MOV src, Sreg
+ // cannot be distinguished when src or dst refers to memory, because
+ // Sreg is always a 16-bit value, even when we're doing a 32-bit
+ // instruction. Because the instruction tables distinguished these two,
+ // any operand size prefix has been marked as used (to decide which
+ // branch to take). Unmark it, so that it will show up in disassembly,
+ // so that the reader can tell the size of memory operand.
+ // up with the same arguments
+ dst, _ := inst.Args[0].(x86_Reg)
+ src, _ := inst.Args[1].(x86_Reg)
+ if x86_ES <= src && src <= x86_GS && x86_isMem(inst.Args[0]) || x86_ES <= dst && dst <= x86_GS && x86_isMem(inst.Args[1]) {
+ x86_unmarkImplicit(&inst, x86_PrefixDataSize)
+ }
+
+ case x86_MOVDQU:
+ if x86_countPrefix(&inst, 0xF3) > 1 {
+ x86_unmarkImplicit(&inst, 0xF3)
+ x86_markLastImplicit(&inst, 0xF3)
+ }
+
+ case x86_MOVQ2DQ:
+ x86_markLastImplicit(&inst, x86_PrefixDataSize)
+
+ case x86_SLDT, x86_SMSW, x86_STR, x86_FXRSTOR, x86_XRSTOR, x86_XSAVE, x86_XSAVEOPT, x86_CMPXCHG8B:
+ if x86_isMem(inst.Args[0]) {
+ x86_unmarkImplicit(&inst, x86_PrefixDataSize)
+ }
+
+ case x86_SYSEXIT:
+ x86_unmarkImplicit(&inst, x86_PrefixDataSize)
+ }
+
+ if x86_isCondJmp[inst.Op] || x86_isLoop[inst.Op] || inst.Op == x86_JCXZ || inst.Op == x86_JECXZ || inst.Op == x86_JRCXZ {
+ if x86_countPrefix(&inst, x86_PrefixCS) > 0 && x86_countPrefix(&inst, x86_PrefixDS) > 0 {
+ for i, p := range inst.Prefix {
+ switch p & 0xFFF {
+ case x86_PrefixPN, x86_PrefixPT:
+ inst.Prefix[i] &= 0xF0FF // cut interpretation bits, producing original segment prefix
+ }
+ }
+ }
+ }
+
+ // XACQUIRE/XRELEASE adjustment.
+ if inst.Op == x86_MOV {
+ // MOV into memory is a candidate for turning REP into XRELEASE.
+ // However, if the REP is followed by a REPN, that REPN blocks the
+ // conversion.
+ haveREPN := false
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ switch inst.Prefix[i] &^ x86_PrefixIgnored {
+ case x86_PrefixREPN:
+ haveREPN = true
+ case x86_PrefixXRELEASE:
+ if haveREPN {
+ inst.Prefix[i] = x86_PrefixREP
+ }
+ }
+ }
+ }
+
+ // We only format the final F2/F3 as XRELEASE/XACQUIRE.
+ haveXA := false
+ haveXR := false
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ switch inst.Prefix[i] &^ x86_PrefixIgnored {
+ case x86_PrefixXRELEASE:
+ if !haveXR {
+ haveXR = true
+ } else {
+ inst.Prefix[i] = x86_PrefixREP
+ }
+
+ case x86_PrefixXACQUIRE:
+ if !haveXA {
+ haveXA = true
+ } else {
+ inst.Prefix[i] = x86_PrefixREPN
+ }
+ }
+ }
+
+ // Determine opcode.
+ op := strings.ToLower(inst.Op.String())
+ if alt := x86_gnuOp[inst.Op]; alt != "" {
+ op = alt
+ }
+
+ // Determine opcode suffix.
+ // Libopcodes omits the suffix if the width of the operation
+ // can be inferred from a register arguments. For example,
+ // add $1, %ebx has no suffix because you can tell from the
+ // 32-bit register destination that it is a 32-bit add,
+ // but in addl $1, (%ebx), the destination is memory, so the
+ // size is not evident without the l suffix.
+ needSuffix := true
+SuffixLoop:
+ for i, a := range inst.Args {
+ if a == nil {
+ break
+ }
+ switch a := a.(type) {
+ case x86_Reg:
+ switch inst.Op {
+ case x86_MOVSX, x86_MOVZX:
+ continue
+
+ case x86_SHL, x86_SHR, x86_RCL, x86_RCR, x86_ROL, x86_ROR, x86_SAR:
+ if i == 1 {
+ // shift count does not tell us operand size
+ continue
+ }
+
+ case x86_CRC32:
+ // The source argument does tell us operand size,
+ // but libopcodes still always puts a suffix on crc32.
+ continue
+
+ case x86_PUSH, x86_POP:
+ // Even though segment registers are 16-bit, push and pop
+ // can save/restore them from 32-bit slots, so they
+ // do not imply operand size.
+ if x86_ES <= a && a <= x86_GS {
+ continue
+ }
+
+ case x86_CVTSI2SD, x86_CVTSI2SS:
+ // The integer register argument takes priority.
+ if x86_X0 <= a && a <= x86_X15 {
+ continue
+ }
+ }
+
+ if x86_AL <= a && a <= x86_R15 || x86_ES <= a && a <= x86_GS || x86_X0 <= a && a <= x86_X15 || x86_M0 <= a && a <= x86_M7 {
+ needSuffix = false
+ break SuffixLoop
+ }
+ }
+ }
+
+ if needSuffix {
+ switch inst.Op {
+ case x86_CMPXCHG8B, x86_FLDCW, x86_FNSTCW, x86_FNSTSW, x86_LDMXCSR, x86_LLDT, x86_LMSW, x86_LTR, x86_PCLMULQDQ,
+ x86_SETA, x86_SETAE, x86_SETB, x86_SETBE, x86_SETE, x86_SETG, x86_SETGE, x86_SETL, x86_SETLE, x86_SETNE, x86_SETNO, x86_SETNP, x86_SETNS, x86_SETO, x86_SETP, x86_SETS,
+ x86_SLDT, x86_SMSW, x86_STMXCSR, x86_STR, x86_VERR, x86_VERW:
+ // For various reasons, libopcodes emits no suffix for these instructions.
+
+ case x86_CRC32:
+ op += x86_byteSizeSuffix(x86_argBytes(&inst, inst.Args[1]))
+
+ case x86_LGDT, x86_LIDT, x86_SGDT, x86_SIDT:
+ op += x86_byteSizeSuffix(inst.DataSize / 8)
+
+ case x86_MOVZX, x86_MOVSX:
+ // Integer size conversions get two suffixes.
+ op = op[:4] + x86_byteSizeSuffix(x86_argBytes(&inst, inst.Args[1])) + x86_byteSizeSuffix(x86_argBytes(&inst, inst.Args[0]))
+
+ case x86_LOOP, x86_LOOPE, x86_LOOPNE:
+ // Add w suffix to indicate use of CX register instead of ECX.
+ if inst.AddrSize == 16 {
+ op += "w"
+ }
+
+ case x86_CALL, x86_ENTER, x86_JMP, x86_LCALL, x86_LEAVE, x86_LJMP, x86_LRET, x86_RET, x86_SYSRET, x86_XBEGIN:
+ // Add w suffix to indicate use of 16-bit target.
+ // Exclude JMP rel8.
+ if inst.Opcode>>24 == 0xEB {
+ break
+ }
+ if inst.DataSize == 16 && inst.Mode != 16 {
+ x86_markLastImplicit(&inst, x86_PrefixDataSize)
+ op += "w"
+ } else if inst.Mode == 64 {
+ op += "q"
+ }
+
+ case x86_FRSTOR, x86_FNSAVE, x86_FNSTENV, x86_FLDENV:
+ // Add s suffix to indicate shortened FPU state (I guess).
+ if inst.DataSize == 16 {
+ op += "s"
+ }
+
+ case x86_PUSH, x86_POP:
+ if x86_markLastImplicit(&inst, x86_PrefixDataSize) {
+ op += x86_byteSizeSuffix(inst.DataSize / 8)
+ } else if inst.Mode == 64 {
+ op += "q"
+ } else {
+ op += x86_byteSizeSuffix(inst.MemBytes)
+ }
+
+ default:
+ if x86_isFloat(inst.Op) {
+ // I can't explain any of this, but it's what libopcodes does.
+ switch inst.MemBytes {
+ default:
+ if (inst.Op == x86_FLD || inst.Op == x86_FSTP) && x86_isMem(inst.Args[0]) {
+ op += "t"
+ }
+ case 4:
+ if x86_isFloatInt(inst.Op) {
+ op += "l"
+ } else {
+ op += "s"
+ }
+ case 8:
+ if x86_isFloatInt(inst.Op) {
+ op += "ll"
+ } else {
+ op += "l"
+ }
+ }
+ break
+ }
+
+ op += x86_byteSizeSuffix(inst.MemBytes)
+ }
+ }
+
+ // Adjust special case opcodes.
+ switch inst.Op {
+ case 0:
+ if inst.Prefix[0] != 0 {
+ return strings.ToLower(inst.Prefix[0].String())
+ }
+
+ case x86_INT:
+ if inst.Opcode>>24 == 0xCC {
+ inst.Args[0] = nil
+ op = "int3"
+ }
+
+ case x86_CMPPS, x86_CMPPD, x86_CMPSD_XMM, x86_CMPSS:
+ imm, ok := inst.Args[2].(x86_Imm)
+ if ok && 0 <= imm && imm < 8 {
+ inst.Args[2] = nil
+ op = x86_cmppsOps[imm] + op[3:]
+ }
+
+ case x86_PCLMULQDQ:
+ imm, ok := inst.Args[2].(x86_Imm)
+ if ok && imm&^0x11 == 0 {
+ inst.Args[2] = nil
+ op = x86_pclmulqOps[(imm&0x10)>>3|(imm&1)]
+ }
+
+ case x86_XLATB:
+ if x86_markLastImplicit(&inst, x86_PrefixAddrSize) {
+ op = "xlat" // not xlatb
+ }
+ }
+
+ // Build list of argument strings.
+ var (
+ usedPrefixes bool // segment prefixes consumed by Mem formatting
+ args []string // formatted arguments
+ )
+ for i, a := range inst.Args {
+ if a == nil {
+ break
+ }
+ switch inst.Op {
+ case x86_MOVSB, x86_MOVSW, x86_MOVSD, x86_MOVSQ, x86_OUTSB, x86_OUTSW, x86_OUTSD:
+ if i == 0 {
+ usedPrefixes = true // disable use of prefixes for first argument
+ } else {
+ usedPrefixes = false
+ }
+ }
+ if a == x86_Imm(1) && (inst.Opcode>>24)&^1 == 0xD0 {
+ continue
+ }
+ args = append(args, x86_gnuArg(&inst, a, &usedPrefixes))
+ }
+
+ // The default is to print the arguments in reverse Intel order.
+ // A few instructions inhibit this behavior.
+ switch inst.Op {
+ case x86_BOUND, x86_LCALL, x86_ENTER, x86_LJMP:
+ // no reverse
+ default:
+ // reverse args
+ for i, j := 0, len(args)-1; i < j; i, j = i+1, j-1 {
+ args[i], args[j] = args[j], args[i]
+ }
+ }
+
+ // Build prefix string.
+ // Must be after argument formatting, which can turn off segment prefixes.
+ var (
+ prefix = "" // output string
+ numAddr = 0
+ numData = 0
+ implicitData = false
+ )
+ for _, p := range inst.Prefix {
+ if p&0xFF == x86_PrefixDataSize && p&x86_PrefixImplicit != 0 {
+ implicitData = true
+ }
+ }
+ for _, p := range inst.Prefix {
+ if p == 0 {
+ break
+ }
+ if p&x86_PrefixImplicit != 0 {
+ continue
+ }
+ switch p &^ (x86_PrefixIgnored | x86_PrefixInvalid) {
+ default:
+ if p.IsREX() {
+ if p&0xFF == x86_PrefixREX {
+ prefix += "rex "
+ } else {
+ prefix += "rex." + p.String()[4:] + " "
+ }
+ break
+ }
+ prefix += strings.ToLower(p.String()) + " "
+
+ case x86_PrefixPN:
+ op += ",pn"
+ continue
+
+ case x86_PrefixPT:
+ op += ",pt"
+ continue
+
+ case x86_PrefixAddrSize, x86_PrefixAddr16, x86_PrefixAddr32:
+ // For unknown reasons, if the addr16 prefix is repeated,
+ // libopcodes displays all but the last as addr32, even though
+ // the addressing form used in a memory reference is clearly
+ // still 16-bit.
+ n := 32
+ if inst.Mode == 32 {
+ n = 16
+ }
+ numAddr++
+ if x86_countPrefix(&inst, x86_PrefixAddrSize) > numAddr {
+ n = inst.Mode
+ }
+ prefix += fmt.Sprintf("addr%d ", n)
+ continue
+
+ case x86_PrefixData16, x86_PrefixData32:
+ if implicitData && x86_countPrefix(&inst, x86_PrefixDataSize) > 1 {
+ // Similar to the addr32 logic above, but it only kicks in
+ // when something used the data size prefix (one is implicit).
+ n := 16
+ if inst.Mode == 16 {
+ n = 32
+ }
+ numData++
+ if x86_countPrefix(&inst, x86_PrefixDataSize) > numData {
+ if inst.Mode == 16 {
+ n = 16
+ } else {
+ n = 32
+ }
+ }
+ prefix += fmt.Sprintf("data%d ", n)
+ continue
+ }
+ prefix += strings.ToLower(p.String()) + " "
+ }
+ }
+
+ // Finally! Put it all together.
+ text := prefix + op
+ if args != nil {
+ text += " "
+ // Indirect call/jmp gets a star to distinguish from direct jump address.
+ if (inst.Op == x86_CALL || inst.Op == x86_JMP || inst.Op == x86_LJMP || inst.Op == x86_LCALL) && (x86_isMem(inst.Args[0]) || x86_isReg(inst.Args[0])) {
+ text += "*"
+ }
+ text += strings.Join(args, ",")
+ }
+ return text
+}
+
+// gnuArg returns the GNU syntax for the argument x from the instruction inst.
+// If *usedPrefixes is false and x is a Mem, then the formatting
+// includes any segment prefixes and sets *usedPrefixes to true.
+func x86_gnuArg(inst *x86_Inst, x x86_Arg, usedPrefixes *bool) string {
+ if x == nil {
+ return "<nil>"
+ }
+ switch x := x.(type) {
+ case x86_Reg:
+ switch inst.Op {
+ case x86_CVTSI2SS, x86_CVTSI2SD, x86_CVTSS2SI, x86_CVTSD2SI, x86_CVTTSD2SI, x86_CVTTSS2SI:
+ if inst.DataSize == 16 && x86_EAX <= x && x <= x86_R15L {
+ x -= x86_EAX - x86_AX
+ }
+
+ case x86_IN, x86_INSB, x86_INSW, x86_INSD, x86_OUT, x86_OUTSB, x86_OUTSW, x86_OUTSD:
+ // DX is the port, but libopcodes prints it as if it were a memory reference.
+ if x == x86_DX {
+ return "(%dx)"
+ }
+ }
+ return x86_gccRegName[x]
+ case x86_Mem:
+ seg := ""
+ var haveCS, haveDS, haveES, haveFS, haveGS, haveSS bool
+ switch x.Segment {
+ case x86_CS:
+ haveCS = true
+ case x86_DS:
+ haveDS = true
+ case x86_ES:
+ haveES = true
+ case x86_FS:
+ haveFS = true
+ case x86_GS:
+ haveGS = true
+ case x86_SS:
+ haveSS = true
+ }
+ switch inst.Op {
+ case x86_INSB, x86_INSW, x86_INSD, x86_STOSB, x86_STOSW, x86_STOSD, x86_STOSQ, x86_SCASB, x86_SCASW, x86_SCASD, x86_SCASQ:
+ // These do not accept segment prefixes, at least in the GNU rendering.
+ default:
+ if *usedPrefixes {
+ break
+ }
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ p := inst.Prefix[i] &^ x86_PrefixIgnored
+ if p == 0 {
+ continue
+ }
+ switch p {
+ case x86_PrefixCS:
+ if !haveCS {
+ haveCS = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ case x86_PrefixDS:
+ if !haveDS {
+ haveDS = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ case x86_PrefixES:
+ if !haveES {
+ haveES = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ case x86_PrefixFS:
+ if !haveFS {
+ haveFS = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ case x86_PrefixGS:
+ if !haveGS {
+ haveGS = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ case x86_PrefixSS:
+ if !haveSS {
+ haveSS = true
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ }
+ }
+ *usedPrefixes = true
+ }
+ if haveCS {
+ seg += "%cs:"
+ }
+ if haveDS {
+ seg += "%ds:"
+ }
+ if haveSS {
+ seg += "%ss:"
+ }
+ if haveES {
+ seg += "%es:"
+ }
+ if haveFS {
+ seg += "%fs:"
+ }
+ if haveGS {
+ seg += "%gs:"
+ }
+ disp := ""
+ if x.Disp != 0 {
+ disp = fmt.Sprintf("%#x", x.Disp)
+ }
+ if x.Scale == 0 || x.Index == 0 && x.Scale == 1 && (x.Base == x86_ESP || x.Base == x86_RSP || x.Base == 0 && inst.Mode == 64) {
+ if x.Base == 0 {
+ return seg + disp
+ }
+ return fmt.Sprintf("%s%s(%s)", seg, disp, x86_gccRegName[x.Base])
+ }
+ base := x86_gccRegName[x.Base]
+ if x.Base == 0 {
+ base = ""
+ }
+ index := x86_gccRegName[x.Index]
+ if x.Index == 0 {
+ if inst.AddrSize == 64 {
+ index = "%riz"
+ } else {
+ index = "%eiz"
+ }
+ }
+ if x86_AX <= x.Base && x.Base <= x86_DI {
+ // 16-bit addressing - no scale
+ return fmt.Sprintf("%s%s(%s,%s)", seg, disp, base, index)
+ }
+ return fmt.Sprintf("%s%s(%s,%s,%d)", seg, disp, base, index, x.Scale)
+ case x86_Rel:
+ return fmt.Sprintf(".%+#x", int32(x))
+ case x86_Imm:
+ if inst.Mode == 32 {
+ return fmt.Sprintf("$%#x", uint32(x))
+ }
+ return fmt.Sprintf("$%#x", int64(x))
+ }
+ return x.String()
+}
+
+var x86_gccRegName = [...]string{
+ 0: "REG0",
+ x86_AL: "%al",
+ x86_CL: "%cl",
+ x86_BL: "%bl",
+ x86_DL: "%dl",
+ x86_AH: "%ah",
+ x86_CH: "%ch",
+ x86_BH: "%bh",
+ x86_DH: "%dh",
+ x86_SPB: "%spl",
+ x86_BPB: "%bpl",
+ x86_SIB: "%sil",
+ x86_DIB: "%dil",
+ x86_R8B: "%r8b",
+ x86_R9B: "%r9b",
+ x86_R10B: "%r10b",
+ x86_R11B: "%r11b",
+ x86_R12B: "%r12b",
+ x86_R13B: "%r13b",
+ x86_R14B: "%r14b",
+ x86_R15B: "%r15b",
+ x86_AX: "%ax",
+ x86_CX: "%cx",
+ x86_BX: "%bx",
+ x86_DX: "%dx",
+ x86_SP: "%sp",
+ x86_BP: "%bp",
+ x86_SI: "%si",
+ x86_DI: "%di",
+ x86_R8W: "%r8w",
+ x86_R9W: "%r9w",
+ x86_R10W: "%r10w",
+ x86_R11W: "%r11w",
+ x86_R12W: "%r12w",
+ x86_R13W: "%r13w",
+ x86_R14W: "%r14w",
+ x86_R15W: "%r15w",
+ x86_EAX: "%eax",
+ x86_ECX: "%ecx",
+ x86_EDX: "%edx",
+ x86_EBX: "%ebx",
+ x86_ESP: "%esp",
+ x86_EBP: "%ebp",
+ x86_ESI: "%esi",
+ x86_EDI: "%edi",
+ x86_R8L: "%r8d",
+ x86_R9L: "%r9d",
+ x86_R10L: "%r10d",
+ x86_R11L: "%r11d",
+ x86_R12L: "%r12d",
+ x86_R13L: "%r13d",
+ x86_R14L: "%r14d",
+ x86_R15L: "%r15d",
+ x86_RAX: "%rax",
+ x86_RCX: "%rcx",
+ x86_RDX: "%rdx",
+ x86_RBX: "%rbx",
+ x86_RSP: "%rsp",
+ x86_RBP: "%rbp",
+ x86_RSI: "%rsi",
+ x86_RDI: "%rdi",
+ x86_R8: "%r8",
+ x86_R9: "%r9",
+ x86_R10: "%r10",
+ x86_R11: "%r11",
+ x86_R12: "%r12",
+ x86_R13: "%r13",
+ x86_R14: "%r14",
+ x86_R15: "%r15",
+ x86_IP: "%ip",
+ x86_EIP: "%eip",
+ x86_RIP: "%rip",
+ x86_F0: "%st",
+ x86_F1: "%st(1)",
+ x86_F2: "%st(2)",
+ x86_F3: "%st(3)",
+ x86_F4: "%st(4)",
+ x86_F5: "%st(5)",
+ x86_F6: "%st(6)",
+ x86_F7: "%st(7)",
+ x86_M0: "%mm0",
+ x86_M1: "%mm1",
+ x86_M2: "%mm2",
+ x86_M3: "%mm3",
+ x86_M4: "%mm4",
+ x86_M5: "%mm5",
+ x86_M6: "%mm6",
+ x86_M7: "%mm7",
+ x86_X0: "%xmm0",
+ x86_X1: "%xmm1",
+ x86_X2: "%xmm2",
+ x86_X3: "%xmm3",
+ x86_X4: "%xmm4",
+ x86_X5: "%xmm5",
+ x86_X6: "%xmm6",
+ x86_X7: "%xmm7",
+ x86_X8: "%xmm8",
+ x86_X9: "%xmm9",
+ x86_X10: "%xmm10",
+ x86_X11: "%xmm11",
+ x86_X12: "%xmm12",
+ x86_X13: "%xmm13",
+ x86_X14: "%xmm14",
+ x86_X15: "%xmm15",
+ x86_CS: "%cs",
+ x86_SS: "%ss",
+ x86_DS: "%ds",
+ x86_ES: "%es",
+ x86_FS: "%fs",
+ x86_GS: "%gs",
+ x86_GDTR: "%gdtr",
+ x86_IDTR: "%idtr",
+ x86_LDTR: "%ldtr",
+ x86_MSW: "%msw",
+ x86_TASK: "%task",
+ x86_CR0: "%cr0",
+ x86_CR1: "%cr1",
+ x86_CR2: "%cr2",
+ x86_CR3: "%cr3",
+ x86_CR4: "%cr4",
+ x86_CR5: "%cr5",
+ x86_CR6: "%cr6",
+ x86_CR7: "%cr7",
+ x86_CR8: "%cr8",
+ x86_CR9: "%cr9",
+ x86_CR10: "%cr10",
+ x86_CR11: "%cr11",
+ x86_CR12: "%cr12",
+ x86_CR13: "%cr13",
+ x86_CR14: "%cr14",
+ x86_CR15: "%cr15",
+ x86_DR0: "%db0",
+ x86_DR1: "%db1",
+ x86_DR2: "%db2",
+ x86_DR3: "%db3",
+ x86_DR4: "%db4",
+ x86_DR5: "%db5",
+ x86_DR6: "%db6",
+ x86_DR7: "%db7",
+ x86_TR0: "%tr0",
+ x86_TR1: "%tr1",
+ x86_TR2: "%tr2",
+ x86_TR3: "%tr3",
+ x86_TR4: "%tr4",
+ x86_TR5: "%tr5",
+ x86_TR6: "%tr6",
+ x86_TR7: "%tr7",
+}
+
+var x86_gnuOp = map[x86_Op]string{
+ x86_CBW: "cbtw",
+ x86_CDQ: "cltd",
+ x86_CMPSD: "cmpsl",
+ x86_CMPSD_XMM: "cmpsd",
+ x86_CWD: "cwtd",
+ x86_CWDE: "cwtl",
+ x86_CQO: "cqto",
+ x86_INSD: "insl",
+ x86_IRET: "iretw",
+ x86_IRETD: "iret",
+ x86_IRETQ: "iretq",
+ x86_LODSB: "lods",
+ x86_LODSD: "lods",
+ x86_LODSQ: "lods",
+ x86_LODSW: "lods",
+ x86_MOVSD: "movsl",
+ x86_MOVSD_XMM: "movsd",
+ x86_OUTSD: "outsl",
+ x86_POPA: "popaw",
+ x86_POPAD: "popa",
+ x86_POPF: "popfw",
+ x86_POPFD: "popf",
+ x86_PUSHA: "pushaw",
+ x86_PUSHAD: "pusha",
+ x86_PUSHF: "pushfw",
+ x86_PUSHFD: "pushf",
+ x86_SCASB: "scas",
+ x86_SCASD: "scas",
+ x86_SCASQ: "scas",
+ x86_SCASW: "scas",
+ x86_STOSB: "stos",
+ x86_STOSD: "stos",
+ x86_STOSQ: "stos",
+ x86_STOSW: "stos",
+ x86_XLATB: "xlat",
+}
+
+var x86_cmppsOps = []string{
+ "cmpeq",
+ "cmplt",
+ "cmple",
+ "cmpunord",
+ "cmpneq",
+ "cmpnlt",
+ "cmpnle",
+ "cmpord",
+}
+
+var x86_pclmulqOps = []string{
+ "pclmullqlqdq",
+ "pclmulhqlqdq",
+ "pclmullqhqdq",
+ "pclmulhqhqdq",
+}
+
+func x86_countPrefix(inst *x86_Inst, target x86_Prefix) int {
+ n := 0
+ for _, p := range inst.Prefix {
+ if p&0xFF == target&0xFF {
+ n++
+ }
+ }
+ return n
+}
+
+func x86_markLastImplicit(inst *x86_Inst, prefix x86_Prefix) bool {
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ p := inst.Prefix[i]
+ if p&0xFF == prefix {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ return true
+ }
+ }
+ return false
+}
+
+func x86_unmarkImplicit(inst *x86_Inst, prefix x86_Prefix) {
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ p := inst.Prefix[i]
+ if p&0xFF == prefix {
+ inst.Prefix[i] &^= x86_PrefixImplicit
+ }
+ }
+}
+
+func x86_byteSizeSuffix(b int) string {
+ switch b {
+ case 1:
+ return "b"
+ case 2:
+ return "w"
+ case 4:
+ return "l"
+ case 8:
+ return "q"
+ }
+ return ""
+}
+
+func x86_argBytes(inst *x86_Inst, arg x86_Arg) int {
+ if x86_isMem(arg) {
+ return inst.MemBytes
+ }
+ return x86_regBytes(arg)
+}
+
+func x86_isFloat(op x86_Op) bool {
+ switch op {
+ case x86_FADD, x86_FCOM, x86_FCOMP, x86_FDIV, x86_FDIVR, x86_FIADD, x86_FICOM, x86_FICOMP, x86_FIDIV, x86_FIDIVR, x86_FILD, x86_FIMUL, x86_FIST, x86_FISTP, x86_FISTTP, x86_FISUB, x86_FISUBR, x86_FLD, x86_FMUL, x86_FST, x86_FSTP, x86_FSUB, x86_FSUBR:
+ return true
+ }
+ return false
+}
+
+func x86_isFloatInt(op x86_Op) bool {
+ switch op {
+ case x86_FIADD, x86_FICOM, x86_FICOMP, x86_FIDIV, x86_FIDIVR, x86_FILD, x86_FIMUL, x86_FIST, x86_FISTP, x86_FISTTP, x86_FISUB, x86_FISUBR:
+ return true
+ }
+ return false
+}
+
+/* inst.go */
+
+// Copyright 2014 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// Package x86asm implements decoding of x86 machine code.
+
+// An Inst is a single instruction.
+type x86_Inst struct {
+ Prefix x86_Prefixes // Prefixes applied to the instruction.
+ Op x86_Op // Opcode mnemonic
+ Opcode uint32 // Encoded opcode bits, left aligned (first byte is Opcode>>24, etc)
+ Args x86_Args // Instruction arguments, in Intel order
+ Mode int // processor mode in bits: 16, 32, or 64
+ AddrSize int // address size in bits: 16, 32, or 64
+ DataSize int // operand size in bits: 16, 32, or 64
+ MemBytes int // size of memory argument in bytes: 1, 2, 4, 8, 16, and so on.
+ Len int // length of encoded instruction in bytes
+}
+
+// Prefixes is an array of prefixes associated with a single instruction.
+// The prefixes are listed in the same order as found in the instruction:
+// each prefix byte corresponds to one slot in the array. The first zero
+// in the array marks the end of the prefixes.
+type x86_Prefixes [14]x86_Prefix
+
+// A Prefix represents an Intel instruction prefix.
+// The low 8 bits are the actual prefix byte encoding,
+// and the top 8 bits contain distinguishing bits and metadata.
+type x86_Prefix uint16
+
+const (
+ // Metadata about the role of a prefix in an instruction.
+ x86_PrefixImplicit x86_Prefix = 0x8000 // prefix is implied by instruction text
+ x86_PrefixIgnored x86_Prefix = 0x4000 // prefix is ignored: either irrelevant or overridden by a later prefix
+ x86_PrefixInvalid x86_Prefix = 0x2000 // prefix makes entire instruction invalid (bad LOCK)
+
+ // Memory segment overrides.
+ x86_PrefixES x86_Prefix = 0x26 // ES segment override
+ x86_PrefixCS x86_Prefix = 0x2E // CS segment override
+ x86_PrefixSS x86_Prefix = 0x36 // SS segment override
+ x86_PrefixDS x86_Prefix = 0x3E // DS segment override
+ x86_PrefixFS x86_Prefix = 0x64 // FS segment override
+ x86_PrefixGS x86_Prefix = 0x65 // GS segment override
+
+ // Branch prediction.
+ x86_PrefixPN x86_Prefix = 0x12E // predict not taken (conditional branch only)
+ x86_PrefixPT x86_Prefix = 0x13E // predict taken (conditional branch only)
+
+ // Size attributes.
+ x86_PrefixDataSize x86_Prefix = 0x66 // operand size override
+ x86_PrefixData16 x86_Prefix = 0x166
+ x86_PrefixData32 x86_Prefix = 0x266
+ x86_PrefixAddrSize x86_Prefix = 0x67 // address size override
+ x86_PrefixAddr16 x86_Prefix = 0x167
+ x86_PrefixAddr32 x86_Prefix = 0x267
+
+ // One of a kind.
+ x86_PrefixLOCK x86_Prefix = 0xF0 // lock
+ x86_PrefixREPN x86_Prefix = 0xF2 // repeat not zero
+ x86_PrefixXACQUIRE x86_Prefix = 0x1F2
+ x86_PrefixBND x86_Prefix = 0x2F2
+ x86_PrefixREP x86_Prefix = 0xF3 // repeat
+ x86_PrefixXRELEASE x86_Prefix = 0x1F3
+
+ // The REX prefixes must be in the range [PrefixREX, PrefixREX+0x10).
+ // the other bits are set or not according to the intended use.
+ x86_PrefixREX x86_Prefix = 0x40 // REX 64-bit extension prefix
+ x86_PrefixREXW x86_Prefix = 0x08 // extension bit W (64-bit instruction width)
+ x86_PrefixREXR x86_Prefix = 0x04 // extension bit R (r field in modrm)
+ x86_PrefixREXX x86_Prefix = 0x02 // extension bit X (index field in sib)
+ x86_PrefixREXB x86_Prefix = 0x01 // extension bit B (r/m field in modrm or base field in sib)
+)
+
+// IsREX reports whether p is a REX prefix byte.
+func (p x86_Prefix) IsREX() bool {
+ return p&0xF0 == x86_PrefixREX
+}
+
+func (p x86_Prefix) String() string {
+ p &^= x86_PrefixImplicit | x86_PrefixIgnored | x86_PrefixInvalid
+ if s := x86_prefixNames[p]; s != "" {
+ return s
+ }
+
+ if p.IsREX() {
+ s := "REX."
+ if p&x86_PrefixREXW != 0 {
+ s += "W"
+ }
+ if p&x86_PrefixREXR != 0 {
+ s += "R"
+ }
+ if p&x86_PrefixREXX != 0 {
+ s += "X"
+ }
+ if p&x86_PrefixREXB != 0 {
+ s += "B"
+ }
+ return s
+ }
+
+ return fmt.Sprintf("Prefix(%#x)", int(p))
+}
+
+// An Op is an x86 opcode.
+type x86_Op uint32
+
+func (op x86_Op) String() string {
+ i := int(op)
+ if i < 0 || i >= len(x86_opNames) || x86_opNames[i] == "" {
+ return fmt.Sprintf("Op(%d)", i)
+ }
+ return x86_opNames[i]
+}
+
+// An Args holds the instruction arguments.
+// If an instruction has fewer than 4 arguments,
+// the final elements in the array are nil.
+type x86_Args [4]x86_Arg
+
+// An Arg is a single instruction argument,
+// one of these types: Reg, Mem, Imm, Rel.
+type x86_Arg interface {
+ String() string
+ isArg()
+}
+
+// Note that the implements of Arg that follow are all sized
+// so that on a 64-bit machine the data can be inlined in
+// the interface value instead of requiring an allocation.
+
+// A Reg is a single register.
+// The zero Reg value has no name but indicates ``no register.''
+type x86_Reg uint8
+
+const (
+ _ x86_Reg = iota
+
+ // 8-bit
+ x86_AL
+ x86_CL
+ x86_DL
+ x86_BL
+ x86_AH
+ x86_CH
+ x86_DH
+ x86_BH
+ x86_SPB
+ x86_BPB
+ x86_SIB
+ x86_DIB
+ x86_R8B
+ x86_R9B
+ x86_R10B
+ x86_R11B
+ x86_R12B
+ x86_R13B
+ x86_R14B
+ x86_R15B
+
+ // 16-bit
+ x86_AX
+ x86_CX
+ x86_DX
+ x86_BX
+ x86_SP
+ x86_BP
+ x86_SI
+ x86_DI
+ x86_R8W
+ x86_R9W
+ x86_R10W
+ x86_R11W
+ x86_R12W
+ x86_R13W
+ x86_R14W
+ x86_R15W
+
+ // 32-bit
+ x86_EAX
+ x86_ECX
+ x86_EDX
+ x86_EBX
+ x86_ESP
+ x86_EBP
+ x86_ESI
+ x86_EDI
+ x86_R8L
+ x86_R9L
+ x86_R10L
+ x86_R11L
+ x86_R12L
+ x86_R13L
+ x86_R14L
+ x86_R15L
+
+ // 64-bit
+ x86_RAX
+ x86_RCX
+ x86_RDX
+ x86_RBX
+ x86_RSP
+ x86_RBP
+ x86_RSI
+ x86_RDI
+ x86_R8
+ x86_R9
+ x86_R10
+ x86_R11
+ x86_R12
+ x86_R13
+ x86_R14
+ x86_R15
+
+ // Instruction pointer.
+ x86_IP // 16-bit
+ x86_EIP // 32-bit
+ x86_RIP // 64-bit
+
+ // 387 floating point registers.
+ x86_F0
+ x86_F1
+ x86_F2
+ x86_F3
+ x86_F4
+ x86_F5
+ x86_F6
+ x86_F7
+
+ // MMX registers.
+ x86_M0
+ x86_M1
+ x86_M2
+ x86_M3
+ x86_M4
+ x86_M5
+ x86_M6
+ x86_M7
+
+ // XMM registers.
+ x86_X0
+ x86_X1
+ x86_X2
+ x86_X3
+ x86_X4
+ x86_X5
+ x86_X6
+ x86_X7
+ x86_X8
+ x86_X9
+ x86_X10
+ x86_X11
+ x86_X12
+ x86_X13
+ x86_X14
+ x86_X15
+
+ // Segment registers.
+ x86_ES
+ x86_CS
+ x86_SS
+ x86_DS
+ x86_FS
+ x86_GS
+
+ // System registers.
+ x86_GDTR
+ x86_IDTR
+ x86_LDTR
+ x86_MSW
+ x86_TASK
+
+ // Control registers.
+ x86_CR0
+ x86_CR1
+ x86_CR2
+ x86_CR3
+ x86_CR4
+ x86_CR5
+ x86_CR6
+ x86_CR7
+ x86_CR8
+ x86_CR9
+ x86_CR10
+ x86_CR11
+ x86_CR12
+ x86_CR13
+ x86_CR14
+ x86_CR15
+
+ // Debug registers.
+ x86_DR0
+ x86_DR1
+ x86_DR2
+ x86_DR3
+ x86_DR4
+ x86_DR5
+ x86_DR6
+ x86_DR7
+ x86_DR8
+ x86_DR9
+ x86_DR10
+ x86_DR11
+ x86_DR12
+ x86_DR13
+ x86_DR14
+ x86_DR15
+
+ // Task registers.
+ x86_TR0
+ x86_TR1
+ x86_TR2
+ x86_TR3
+ x86_TR4
+ x86_TR5
+ x86_TR6
+ x86_TR7
+)
+
+const x86_regMax = x86_TR7
+
+func (x86_Reg) isArg() {}
+
+func (r x86_Reg) String() string {
+ i := int(r)
+ if i < 0 || i >= len(x86_regNames) || x86_regNames[i] == "" {
+ return fmt.Sprintf("Reg(%d)", i)
+ }
+ return x86_regNames[i]
+}
+
+// A Mem is a memory reference.
+// The general form is Segment:[Base+Scale*Index+Disp].
+type x86_Mem struct {
+ Segment x86_Reg
+ Base x86_Reg
+ Scale uint8
+ Index x86_Reg
+ Disp int64
+}
+
+func (x86_Mem) isArg() {}
+
+func (m x86_Mem) String() string {
+ var base, plus, scale, index, disp string
+
+ if m.Base != 0 {
+ base = m.Base.String()
+ }
+ if m.Scale != 0 {
+ if m.Base != 0 {
+ plus = "+"
+ }
+ if m.Scale > 1 {
+ scale = fmt.Sprintf("%d*", m.Scale)
+ }
+ index = m.Index.String()
+ }
+ if m.Disp != 0 || m.Base == 0 && m.Scale == 0 {
+ disp = fmt.Sprintf("%+#x", m.Disp)
+ }
+ return "[" + base + plus + scale + index + disp + "]"
+}
+
+// A Rel is an offset relative to the current instruction pointer.
+type x86_Rel int32
+
+func (x86_Rel) isArg() {}
+
+func (r x86_Rel) String() string {
+ return fmt.Sprintf(".%+d", r)
+}
+
+// An Imm is an integer constant.
+type x86_Imm int64
+
+func (x86_Imm) isArg() {}
+
+func (i x86_Imm) String() string {
+ return fmt.Sprintf("%#x", int64(i))
+}
+
+func (i x86_Inst) String() string {
+ var buf bytes.Buffer
+ for _, p := range i.Prefix {
+ if p == 0 {
+ break
+ }
+ if p&x86_PrefixImplicit != 0 {
+ continue
+ }
+ fmt.Fprintf(&buf, "%v ", p)
+ }
+ fmt.Fprintf(&buf, "%v", i.Op)
+ sep := " "
+ for _, v := range i.Args {
+ if v == nil {
+ break
+ }
+ fmt.Fprintf(&buf, "%s%v", sep, v)
+ sep = ", "
+ }
+ return buf.String()
+}
+
+func x86_isReg(a x86_Arg) bool {
+ _, ok := a.(x86_Reg)
+ return ok
+}
+
+func x86_isSegReg(a x86_Arg) bool {
+ r, ok := a.(x86_Reg)
+ return ok && x86_ES <= r && r <= x86_GS
+}
+
+func x86_isMem(a x86_Arg) bool {
+ _, ok := a.(x86_Mem)
+ return ok
+}
+
+func x86_isImm(a x86_Arg) bool {
+ _, ok := a.(x86_Imm)
+ return ok
+}
+
+func x86_regBytes(a x86_Arg) int {
+ r, ok := a.(x86_Reg)
+ if !ok {
+ return 0
+ }
+ if x86_AL <= r && r <= x86_R15B {
+ return 1
+ }
+ if x86_AX <= r && r <= x86_R15W {
+ return 2
+ }
+ if x86_EAX <= r && r <= x86_R15L {
+ return 4
+ }
+ if x86_RAX <= r && r <= x86_R15 {
+ return 8
+ }
+ return 0
+}
+
+func x86_isSegment(p x86_Prefix) bool {
+ switch p {
+ case x86_PrefixCS, x86_PrefixDS, x86_PrefixES, x86_PrefixFS, x86_PrefixGS, x86_PrefixSS:
+ return true
+ }
+ return false
+}
+
+// The Op definitions and string list are in tables.go.
+
+var x86_prefixNames = map[x86_Prefix]string{
+ x86_PrefixCS: "CS",
+ x86_PrefixDS: "DS",
+ x86_PrefixES: "ES",
+ x86_PrefixFS: "FS",
+ x86_PrefixGS: "GS",
+ x86_PrefixSS: "SS",
+ x86_PrefixLOCK: "LOCK",
+ x86_PrefixREP: "REP",
+ x86_PrefixREPN: "REPN",
+ x86_PrefixAddrSize: "ADDRSIZE",
+ x86_PrefixDataSize: "DATASIZE",
+ x86_PrefixAddr16: "ADDR16",
+ x86_PrefixData16: "DATA16",
+ x86_PrefixAddr32: "ADDR32",
+ x86_PrefixData32: "DATA32",
+ x86_PrefixBND: "BND",
+ x86_PrefixXACQUIRE: "XACQUIRE",
+ x86_PrefixXRELEASE: "XRELEASE",
+ x86_PrefixREX: "REX",
+ x86_PrefixPT: "PT",
+ x86_PrefixPN: "PN",
+}
+
+var x86_regNames = [...]string{
+ x86_AL: "AL",
+ x86_CL: "CL",
+ x86_BL: "BL",
+ x86_DL: "DL",
+ x86_AH: "AH",
+ x86_CH: "CH",
+ x86_BH: "BH",
+ x86_DH: "DH",
+ x86_SPB: "SPB",
+ x86_BPB: "BPB",
+ x86_SIB: "SIB",
+ x86_DIB: "DIB",
+ x86_R8B: "R8B",
+ x86_R9B: "R9B",
+ x86_R10B: "R10B",
+ x86_R11B: "R11B",
+ x86_R12B: "R12B",
+ x86_R13B: "R13B",
+ x86_R14B: "R14B",
+ x86_R15B: "R15B",
+ x86_AX: "AX",
+ x86_CX: "CX",
+ x86_BX: "BX",
+ x86_DX: "DX",
+ x86_SP: "SP",
+ x86_BP: "BP",
+ x86_SI: "SI",
+ x86_DI: "DI",
+ x86_R8W: "R8W",
+ x86_R9W: "R9W",
+ x86_R10W: "R10W",
+ x86_R11W: "R11W",
+ x86_R12W: "R12W",
+ x86_R13W: "R13W",
+ x86_R14W: "R14W",
+ x86_R15W: "R15W",
+ x86_EAX: "EAX",
+ x86_ECX: "ECX",
+ x86_EDX: "EDX",
+ x86_EBX: "EBX",
+ x86_ESP: "ESP",
+ x86_EBP: "EBP",
+ x86_ESI: "ESI",
+ x86_EDI: "EDI",
+ x86_R8L: "R8L",
+ x86_R9L: "R9L",
+ x86_R10L: "R10L",
+ x86_R11L: "R11L",
+ x86_R12L: "R12L",
+ x86_R13L: "R13L",
+ x86_R14L: "R14L",
+ x86_R15L: "R15L",
+ x86_RAX: "RAX",
+ x86_RCX: "RCX",
+ x86_RDX: "RDX",
+ x86_RBX: "RBX",
+ x86_RSP: "RSP",
+ x86_RBP: "RBP",
+ x86_RSI: "RSI",
+ x86_RDI: "RDI",
+ x86_R8: "R8",
+ x86_R9: "R9",
+ x86_R10: "R10",
+ x86_R11: "R11",
+ x86_R12: "R12",
+ x86_R13: "R13",
+ x86_R14: "R14",
+ x86_R15: "R15",
+ x86_IP: "IP",
+ x86_EIP: "EIP",
+ x86_RIP: "RIP",
+ x86_F0: "F0",
+ x86_F1: "F1",
+ x86_F2: "F2",
+ x86_F3: "F3",
+ x86_F4: "F4",
+ x86_F5: "F5",
+ x86_F6: "F6",
+ x86_F7: "F7",
+ x86_M0: "M0",
+ x86_M1: "M1",
+ x86_M2: "M2",
+ x86_M3: "M3",
+ x86_M4: "M4",
+ x86_M5: "M5",
+ x86_M6: "M6",
+ x86_M7: "M7",
+ x86_X0: "X0",
+ x86_X1: "X1",
+ x86_X2: "X2",
+ x86_X3: "X3",
+ x86_X4: "X4",
+ x86_X5: "X5",
+ x86_X6: "X6",
+ x86_X7: "X7",
+ x86_X8: "X8",
+ x86_X9: "X9",
+ x86_X10: "X10",
+ x86_X11: "X11",
+ x86_X12: "X12",
+ x86_X13: "X13",
+ x86_X14: "X14",
+ x86_X15: "X15",
+ x86_CS: "CS",
+ x86_SS: "SS",
+ x86_DS: "DS",
+ x86_ES: "ES",
+ x86_FS: "FS",
+ x86_GS: "GS",
+ x86_GDTR: "GDTR",
+ x86_IDTR: "IDTR",
+ x86_LDTR: "LDTR",
+ x86_MSW: "MSW",
+ x86_TASK: "TASK",
+ x86_CR0: "CR0",
+ x86_CR1: "CR1",
+ x86_CR2: "CR2",
+ x86_CR3: "CR3",
+ x86_CR4: "CR4",
+ x86_CR5: "CR5",
+ x86_CR6: "CR6",
+ x86_CR7: "CR7",
+ x86_CR8: "CR8",
+ x86_CR9: "CR9",
+ x86_CR10: "CR10",
+ x86_CR11: "CR11",
+ x86_CR12: "CR12",
+ x86_CR13: "CR13",
+ x86_CR14: "CR14",
+ x86_CR15: "CR15",
+ x86_DR0: "DR0",
+ x86_DR1: "DR1",
+ x86_DR2: "DR2",
+ x86_DR3: "DR3",
+ x86_DR4: "DR4",
+ x86_DR5: "DR5",
+ x86_DR6: "DR6",
+ x86_DR7: "DR7",
+ x86_DR8: "DR8",
+ x86_DR9: "DR9",
+ x86_DR10: "DR10",
+ x86_DR11: "DR11",
+ x86_DR12: "DR12",
+ x86_DR13: "DR13",
+ x86_DR14: "DR14",
+ x86_DR15: "DR15",
+ x86_TR0: "TR0",
+ x86_TR1: "TR1",
+ x86_TR2: "TR2",
+ x86_TR3: "TR3",
+ x86_TR4: "TR4",
+ x86_TR5: "TR5",
+ x86_TR6: "TR6",
+ x86_TR7: "TR7",
+}
+
+/* intel.go */
+
+// Copyright 2014 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// IntelSyntax returns the Intel assembler syntax for the instruction, as defined by Intel's XED tool.
+func x86_IntelSyntax(inst x86_Inst) string {
+ var iargs []x86_Arg
+ for _, a := range inst.Args {
+ if a == nil {
+ break
+ }
+ iargs = append(iargs, a)
+ }
+
+ switch inst.Op {
+ case x86_INSB, x86_INSD, x86_INSW, x86_OUTSB, x86_OUTSD, x86_OUTSW, x86_LOOPNE, x86_JCXZ, x86_JECXZ, x86_JRCXZ, x86_LOOP, x86_LOOPE, x86_MOV, x86_XLATB:
+ if inst.Op == x86_MOV && (inst.Opcode>>16)&0xFFFC != 0x0F20 {
+ break
+ }
+ for i, p := range inst.Prefix {
+ if p&0xFF == x86_PrefixAddrSize {
+ inst.Prefix[i] &^= x86_PrefixImplicit
+ }
+ }
+ }
+
+ switch inst.Op {
+ case x86_MOV:
+ dst, _ := inst.Args[0].(x86_Reg)
+ src, _ := inst.Args[1].(x86_Reg)
+ if x86_ES <= dst && dst <= x86_GS && x86_EAX <= src && src <= x86_R15L {
+ src -= x86_EAX - x86_AX
+ iargs[1] = src
+ }
+ if x86_ES <= dst && dst <= x86_GS && x86_RAX <= src && src <= x86_R15 {
+ src -= x86_RAX - x86_AX
+ iargs[1] = src
+ }
+
+ if inst.Opcode>>24&^3 == 0xA0 {
+ for i, p := range inst.Prefix {
+ if p&0xFF == x86_PrefixAddrSize {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ }
+ }
+ }
+
+ switch inst.Op {
+ case x86_AAM, x86_AAD:
+ if imm, ok := iargs[0].(x86_Imm); ok {
+ if inst.DataSize == 32 {
+ iargs[0] = x86_Imm(uint32(int8(imm)))
+ } else if inst.DataSize == 16 {
+ iargs[0] = x86_Imm(uint16(int8(imm)))
+ }
+ }
+
+ case x86_PUSH:
+ if imm, ok := iargs[0].(x86_Imm); ok {
+ iargs[0] = x86_Imm(uint32(imm))
+ }
+ }
+
+ for _, p := range inst.Prefix {
+ if p&x86_PrefixImplicit != 0 {
+ for j, pj := range inst.Prefix {
+ if pj&0xFF == p&0xFF {
+ inst.Prefix[j] |= x86_PrefixImplicit
+ }
+ }
+ }
+ }
+
+ if inst.Op != 0 {
+ for i, p := range inst.Prefix {
+ switch p &^ x86_PrefixIgnored {
+ case x86_PrefixData16, x86_PrefixData32, x86_PrefixCS, x86_PrefixDS, x86_PrefixES, x86_PrefixSS:
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ if p.IsREX() {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ }
+ }
+
+ if x86_isLoop[inst.Op] || inst.Op == x86_JCXZ || inst.Op == x86_JECXZ || inst.Op == x86_JRCXZ {
+ for i, p := range inst.Prefix {
+ if p == x86_PrefixPT || p == x86_PrefixPN {
+ inst.Prefix[i] |= x86_PrefixImplicit
+ }
+ }
+ }
+
+ switch inst.Op {
+ case x86_AAA, x86_AAS, x86_CBW, x86_CDQE, x86_CLC, x86_CLD, x86_CLI, x86_CLTS, x86_CMC, x86_CPUID, x86_CQO, x86_CWD, x86_DAA, x86_DAS,
+ x86_FDECSTP, x86_FINCSTP, x86_FNCLEX, x86_FNINIT, x86_FNOP, x86_FWAIT, x86_HLT,
+ x86_ICEBP, x86_INSB, x86_INSD, x86_INSW, x86_INT, x86_INTO, x86_INVD, x86_IRET, x86_IRETQ,
+ x86_LAHF, x86_LEAVE, x86_LRET, x86_MONITOR, x86_MWAIT, x86_NOP, x86_OUTSB, x86_OUTSD, x86_OUTSW,
+ x86_PAUSE, x86_POPA, x86_POPF, x86_POPFQ, x86_PUSHA, x86_PUSHF, x86_PUSHFQ,
+ x86_RDMSR, x86_RDPMC, x86_RDTSC, x86_RDTSCP, x86_RET, x86_RSM,
+ x86_SAHF, x86_STC, x86_STD, x86_STI, x86_SYSENTER, x86_SYSEXIT, x86_SYSRET,
+ x86_UD2, x86_WBINVD, x86_WRMSR, x86_XEND, x86_XLATB, x86_XTEST:
+
+ if inst.Op == x86_NOP && inst.Opcode>>24 != 0x90 {
+ break
+ }
+ if inst.Op == x86_RET && inst.Opcode>>24 != 0xC3 {
+ break
+ }
+ if inst.Op == x86_INT && inst.Opcode>>24 != 0xCC {
+ break
+ }
+ if inst.Op == x86_LRET && inst.Opcode>>24 != 0xcb {
+ break
+ }
+ for i, p := range inst.Prefix {
+ if p&0xFF == x86_PrefixDataSize {
+ inst.Prefix[i] &^= x86_PrefixImplicit | x86_PrefixIgnored
+ }
+ }
+
+ case 0:
+ // ok
+ }
+
+ switch inst.Op {
+ case x86_INSB, x86_INSD, x86_INSW, x86_OUTSB, x86_OUTSD, x86_OUTSW, x86_MONITOR, x86_MWAIT, x86_XLATB:
+ iargs = nil
+
+ case x86_STOSB, x86_STOSW, x86_STOSD, x86_STOSQ:
+ iargs = iargs[:1]
+
+ case x86_LODSB, x86_LODSW, x86_LODSD, x86_LODSQ, x86_SCASB, x86_SCASW, x86_SCASD, x86_SCASQ:
+ iargs = iargs[1:]
+ }
+
+ const (
+ haveData16 = 1 << iota
+ haveData32
+ haveAddr16
+ haveAddr32
+ haveXacquire
+ haveXrelease
+ haveLock
+ haveHintTaken
+ haveHintNotTaken
+ haveBnd
+ )
+ var prefixBits uint32
+ prefix := ""
+ for _, p := range inst.Prefix {
+ if p == 0 {
+ break
+ }
+ if p&0xFF == 0xF3 {
+ prefixBits &^= haveBnd
+ }
+ if p&(x86_PrefixImplicit|x86_PrefixIgnored) != 0 {
+ continue
+ }
+ switch p {
+ default:
+ prefix += strings.ToLower(p.String()) + " "
+ case x86_PrefixCS, x86_PrefixDS, x86_PrefixES, x86_PrefixFS, x86_PrefixGS, x86_PrefixSS:
+ if inst.Op == 0 {
+ prefix += strings.ToLower(p.String()) + " "
+ }
+ case x86_PrefixREPN:
+ prefix += "repne "
+ case x86_PrefixLOCK:
+ prefixBits |= haveLock
+ case x86_PrefixData16, x86_PrefixDataSize:
+ prefixBits |= haveData16
+ case x86_PrefixData32:
+ prefixBits |= haveData32
+ case x86_PrefixAddrSize, x86_PrefixAddr16:
+ prefixBits |= haveAddr16
+ case x86_PrefixAddr32:
+ prefixBits |= haveAddr32
+ case x86_PrefixXACQUIRE:
+ prefixBits |= haveXacquire
+ case x86_PrefixXRELEASE:
+ prefixBits |= haveXrelease
+ case x86_PrefixPT:
+ prefixBits |= haveHintTaken
+ case x86_PrefixPN:
+ prefixBits |= haveHintNotTaken
+ case x86_PrefixBND:
+ prefixBits |= haveBnd
+ }
+ }
+ switch inst.Op {
+ case x86_JMP:
+ if inst.Opcode>>24 == 0xEB {
+ prefixBits &^= haveBnd
+ }
+ case x86_RET, x86_LRET:
+ prefixBits &^= haveData16 | haveData32
+ }
+
+ if prefixBits&haveXacquire != 0 {
+ prefix += "xacquire "
+ }
+ if prefixBits&haveXrelease != 0 {
+ prefix += "xrelease "
+ }
+ if prefixBits&haveLock != 0 {
+ prefix += "lock "
+ }
+ if prefixBits&haveBnd != 0 {
+ prefix += "bnd "
+ }
+ if prefixBits&haveHintTaken != 0 {
+ prefix += "hint-taken "
+ }
+ if prefixBits&haveHintNotTaken != 0 {
+ prefix += "hint-not-taken "
+ }
+ if prefixBits&haveAddr16 != 0 {
+ prefix += "addr16 "
+ }
+ if prefixBits&haveAddr32 != 0 {
+ prefix += "addr32 "
+ }
+ if prefixBits&haveData16 != 0 {
+ prefix += "data16 "
+ }
+ if prefixBits&haveData32 != 0 {
+ prefix += "data32 "
+ }
+
+ if inst.Op == 0 {
+ if prefix == "" {
+ return "<no instruction>"
+ }
+ return prefix[:len(prefix)-1]
+ }
+
+ var args []string
+ for _, a := range iargs {
+ if a == nil {
+ break
+ }
+ args = append(args, x86_intelArg(&inst, a))
+ }
+
+ var op string
+ switch inst.Op {
+ case x86_NOP:
+ if inst.Opcode>>24 == 0x0F {
+ if inst.DataSize == 16 {
+ args = append(args, "ax")
+ } else {
+ args = append(args, "eax")
+ }
+ }
+
+ case x86_BLENDVPD, x86_BLENDVPS, x86_PBLENDVB:
+ args = args[:2]
+
+ case x86_INT:
+ if inst.Opcode>>24 == 0xCC {
+ args = nil
+ op = "int3"
+ }
+
+ case x86_LCALL, x86_LJMP:
+ if len(args) == 2 {
+ args[0], args[1] = args[1], args[0]
+ }
+
+ case x86_FCHS, x86_FABS, x86_FTST, x86_FLDPI, x86_FLDL2E, x86_FLDLG2, x86_F2XM1, x86_FXAM, x86_FLD1, x86_FLDL2T, x86_FSQRT, x86_FRNDINT, x86_FCOS, x86_FSIN:
+ if len(args) == 0 {
+ args = append(args, "st0")
+ }
+
+ case x86_FPTAN, x86_FSINCOS, x86_FUCOMPP, x86_FCOMPP, x86_FYL2X, x86_FPATAN, x86_FXTRACT, x86_FPREM1, x86_FPREM, x86_FYL2XP1, x86_FSCALE:
+ if len(args) == 0 {
+ args = []string{"st0", "st1"}
+ }
+
+ case x86_FST, x86_FSTP, x86_FISTTP, x86_FIST, x86_FISTP, x86_FBSTP:
+ if len(args) == 1 {
+ args = append(args, "st0")
+ }
+
+ case x86_FLD, x86_FXCH, x86_FCOM, x86_FCOMP, x86_FIADD, x86_FIMUL, x86_FICOM, x86_FICOMP, x86_FISUBR, x86_FIDIV, x86_FUCOM, x86_FUCOMP, x86_FILD, x86_FBLD, x86_FADD, x86_FMUL, x86_FSUB, x86_FSUBR, x86_FISUB, x86_FDIV, x86_FDIVR, x86_FIDIVR:
+ if len(args) == 1 {
+ args = []string{"st0", args[0]}
+ }
+
+ case x86_MASKMOVDQU, x86_MASKMOVQ, x86_XLATB, x86_OUTSB, x86_OUTSW, x86_OUTSD:
+ FixSegment:
+ for i := len(inst.Prefix) - 1; i >= 0; i-- {
+ p := inst.Prefix[i] & 0xFF
+ switch p {
+ case x86_PrefixCS, x86_PrefixES, x86_PrefixFS, x86_PrefixGS, x86_PrefixSS:
+ if inst.Mode != 64 || p == x86_PrefixFS || p == x86_PrefixGS {
+ args = append(args, strings.ToLower((inst.Prefix[i] & 0xFF).String()))
+ break FixSegment
+ }
+ case x86_PrefixDS:
+ if inst.Mode != 64 {
+ break FixSegment
+ }
+ }
+ }
+ }
+
+ if op == "" {
+ op = x86_intelOp[inst.Op]
+ }
+ if op == "" {
+ op = strings.ToLower(inst.Op.String())
+ }
+ if args != nil {
+ op += " " + strings.Join(args, ", ")
+ }
+ return prefix + op
+}
+
+func x86_intelArg(inst *x86_Inst, arg x86_Arg) string {
+ switch a := arg.(type) {
+ case x86_Imm:
+ if inst.Mode == 32 {
+ return fmt.Sprintf("%#x", uint32(a))
+ }
+ if x86_Imm(int32(a)) == a {
+ return fmt.Sprintf("%#x", int64(a))
+ }
+ return fmt.Sprintf("%#x", uint64(a))
+ case x86_Mem:
+ if a.Base == x86_EIP {
+ a.Base = x86_RIP
+ }
+ prefix := ""
+ switch inst.MemBytes {
+ case 1:
+ prefix = "byte "
+ case 2:
+ prefix = "word "
+ case 4:
+ prefix = "dword "
+ case 8:
+ prefix = "qword "
+ case 16:
+ prefix = "xmmword "
+ }
+ switch inst.Op {
+ case x86_INVLPG:
+ prefix = "byte "
+ case x86_STOSB, x86_MOVSB, x86_CMPSB, x86_LODSB, x86_SCASB:
+ prefix = "byte "
+ case x86_STOSW, x86_MOVSW, x86_CMPSW, x86_LODSW, x86_SCASW:
+ prefix = "word "
+ case x86_STOSD, x86_MOVSD, x86_CMPSD, x86_LODSD, x86_SCASD:
+ prefix = "dword "
+ case x86_STOSQ, x86_MOVSQ, x86_CMPSQ, x86_LODSQ, x86_SCASQ:
+ prefix = "qword "
+ case x86_LAR:
+ prefix = "word "
+ case x86_BOUND:
+ if inst.Mode == 32 {
+ prefix = "qword "
+ } else {
+ prefix = "dword "
+ }
+ case x86_PREFETCHW, x86_PREFETCHNTA, x86_PREFETCHT0, x86_PREFETCHT1, x86_PREFETCHT2, x86_CLFLUSH:
+ prefix = "zmmword "
+ }
+ switch inst.Op {
+ case x86_MOVSB, x86_MOVSW, x86_MOVSD, x86_MOVSQ, x86_CMPSB, x86_CMPSW, x86_CMPSD, x86_CMPSQ, x86_STOSB, x86_STOSW, x86_STOSD, x86_STOSQ, x86_SCASB, x86_SCASW, x86_SCASD, x86_SCASQ, x86_LODSB, x86_LODSW, x86_LODSD, x86_LODSQ:
+ switch a.Base {
+ case x86_DI, x86_EDI, x86_RDI:
+ if a.Segment == x86_ES {
+ a.Segment = 0
+ }
+ case x86_SI, x86_ESI, x86_RSI:
+ if a.Segment == x86_DS {
+ a.Segment = 0
+ }
+ }
+ case x86_LEA:
+ a.Segment = 0
+ default:
+ switch a.Base {
+ case x86_SP, x86_ESP, x86_RSP, x86_BP, x86_EBP, x86_RBP:
+ if a.Segment == x86_SS {
+ a.Segment = 0
+ }
+ default:
+ if a.Segment == x86_DS {
+ a.Segment = 0
+ }
+ }
+ }
+
+ if inst.Mode == 64 && a.Segment != x86_FS && a.Segment != x86_GS {
+ a.Segment = 0
+ }
+
+ prefix += "ptr "
+ if a.Segment != 0 {
+ prefix += strings.ToLower(a.Segment.String()) + ":"
+ }
+ prefix += "["
+ if a.Base != 0 {
+ prefix += x86_intelArg(inst, a.Base)
+ }
+ if a.Scale != 0 && a.Index != 0 {
+ if a.Base != 0 {
+ prefix += "+"
+ }
+ prefix += fmt.Sprintf("%s*%d", x86_intelArg(inst, a.Index), a.Scale)
+ }
+ if a.Disp != 0 {
+ if prefix[len(prefix)-1] == '[' && (a.Disp >= 0 || int64(int32(a.Disp)) != a.Disp) {
+ prefix += fmt.Sprintf("%#x", uint64(a.Disp))
+ } else {
+ prefix += fmt.Sprintf("%+#x", a.Disp)
+ }
+ }
+ prefix += "]"
+ return prefix
+ case x86_Rel:
+ return fmt.Sprintf(".%+#x", int64(a))
+ case x86_Reg:
+ if int(a) < len(x86_intelReg) && x86_intelReg[a] != "" {
+ return x86_intelReg[a]
+ }
+ }
+ return strings.ToLower(arg.String())
+}
+
+var x86_intelOp = map[x86_Op]string{
+ x86_JAE: "jnb",
+ x86_JA: "jnbe",
+ x86_JGE: "jnl",
+ x86_JNE: "jnz",
+ x86_JG: "jnle",
+ x86_JE: "jz",
+ x86_SETAE: "setnb",
+ x86_SETA: "setnbe",
+ x86_SETGE: "setnl",
+ x86_SETNE: "setnz",
+ x86_SETG: "setnle",
+ x86_SETE: "setz",
+ x86_CMOVAE: "cmovnb",
+ x86_CMOVA: "cmovnbe",
+ x86_CMOVGE: "cmovnl",
+ x86_CMOVNE: "cmovnz",
+ x86_CMOVG: "cmovnle",
+ x86_CMOVE: "cmovz",
+ x86_LCALL: "call far",
+ x86_LJMP: "jmp far",
+ x86_LRET: "ret far",
+ x86_ICEBP: "int1",
+ x86_MOVSD_XMM: "movsd",
+ x86_XLATB: "xlat",
+}
+
+var x86_intelReg = [...]string{
+ x86_F0: "st0",
+ x86_F1: "st1",
+ x86_F2: "st2",
+ x86_F3: "st3",
+ x86_F4: "st4",
+ x86_F5: "st5",
+ x86_F6: "st6",
+ x86_F7: "st7",
+ x86_M0: "mmx0",
+ x86_M1: "mmx1",
+ x86_M2: "mmx2",
+ x86_M3: "mmx3",
+ x86_M4: "mmx4",
+ x86_M5: "mmx5",
+ x86_M6: "mmx6",
+ x86_M7: "mmx7",
+ x86_X0: "xmm0",
+ x86_X1: "xmm1",
+ x86_X2: "xmm2",
+ x86_X3: "xmm3",
+ x86_X4: "xmm4",
+ x86_X5: "xmm5",
+ x86_X6: "xmm6",
+ x86_X7: "xmm7",
+ x86_X8: "xmm8",
+ x86_X9: "xmm9",
+ x86_X10: "xmm10",
+ x86_X11: "xmm11",
+ x86_X12: "xmm12",
+ x86_X13: "xmm13",
+ x86_X14: "xmm14",
+ x86_X15: "xmm15",
+
+ // TODO: Maybe the constants are named wrong.
+ x86_SPB: "spl",
+ x86_BPB: "bpl",
+ x86_SIB: "sil",
+ x86_DIB: "dil",
+
+ x86_R8L: "r8d",
+ x86_R9L: "r9d",
+ x86_R10L: "r10d",
+ x86_R11L: "r11d",
+ x86_R12L: "r12d",
+ x86_R13L: "r13d",
+ x86_R14L: "r14d",
+ x86_R15L: "r15d",
+}
+
+/* plan9x.go */
+
+// Copyright 2014 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// plan9Syntax returns the Go assembler syntax for the instruction.
+// The syntax was originally defined by Plan 9.
+// The pc is the program counter of the instruction, used for expanding
+// PC-relative addresses into absolute ones.
+// The symname function queries the symbol table for the program
+// being disassembled. Given a target address it returns the name and base
+// address of the symbol containing the target, if any; otherwise it returns "", 0.
+func x86_plan9Syntax(inst x86_Inst, pc uint64, symname func(uint64) (string, uint64)) string {
+ if symname == nil {
+ symname = func(uint64) (string, uint64) { return "", 0 }
+ }
+ var args []string
+ for i := len(inst.Args) - 1; i >= 0; i-- {
+ a := inst.Args[i]
+ if a == nil {
+ continue
+ }
+ args = append(args, x86_plan9Arg(&inst, pc, symname, a))
+ }
+
+ var last x86_Prefix
+ for _, p := range inst.Prefix {
+ if p == 0 || p.IsREX() {
+ break
+ }
+ last = p
+ }
+
+ prefix := ""
+ switch last & 0xFF {
+ case 0, 0x66, 0x67:
+ // ignore
+ case x86_PrefixREPN:
+ prefix += "REPNE "
+ default:
+ prefix += last.String() + " "
+ }
+
+ op := inst.Op.String()
+ if x86_plan9Suffix[inst.Op] {
+ switch inst.DataSize {
+ case 8:
+ op += "B"
+ case 16:
+ op += "W"
+ case 32:
+ op += "L"
+ case 64:
+ op += "Q"
+ }
+ }
+
+ if args != nil {
+ op += " " + strings.Join(args, ", ")
+ }
+
+ return prefix + op
+}
+
+func x86_plan9Arg(inst *x86_Inst, pc uint64, symname func(uint64) (string, uint64), arg x86_Arg) string {
+ switch a := arg.(type) {
+ case x86_Reg:
+ return x86_plan9Reg[a]
+ case x86_Rel:
+ if pc == 0 {
+ break
+ }
+ // If the absolute address is the start of a symbol, use the name.
+ // Otherwise use the raw address, so that things like relative
+ // jumps show up as JMP 0x123 instead of JMP f+10(SB).
+ // It is usually easier to search for 0x123 than to do the mental
+ // arithmetic to find f+10.
+ addr := pc + uint64(inst.Len) + uint64(a)
+ if s, base := symname(addr); s != "" && addr == base {
+ return fmt.Sprintf("%s(SB)", s)
+ }
+ return fmt.Sprintf("%#x", addr)
+
+ case x86_Imm:
+ if s, base := symname(uint64(a)); s != "" {
+ suffix := ""
+ if uint64(a) != base {
+ suffix = fmt.Sprintf("%+d", uint64(a)-base)
+ }
+ return fmt.Sprintf("$%s%s(SB)", s, suffix)
+ }
+ if inst.Mode == 32 {
+ return fmt.Sprintf("$%#x", uint32(a))
+ }
+ if x86_Imm(int32(a)) == a {
+ return fmt.Sprintf("$%#x", int64(a))
+ }
+ return fmt.Sprintf("$%#x", uint64(a))
+ case x86_Mem:
+ if a.Segment == 0 && a.Disp != 0 && a.Base == 0 && (a.Index == 0 || a.Scale == 0) {
+ if s, base := symname(uint64(a.Disp)); s != "" {
+ suffix := ""
+ if uint64(a.Disp) != base {
+ suffix = fmt.Sprintf("%+d", uint64(a.Disp)-base)
+ }
+ return fmt.Sprintf("%s%s(SB)", s, suffix)
+ }
+ }
+ s := ""
+ if a.Segment != 0 {
+ s += fmt.Sprintf("%s:", x86_plan9Reg[a.Segment])
+ }
+ if a.Disp != 0 {
+ s += fmt.Sprintf("%#x", a.Disp)
+ } else {
+ s += "0"
+ }
+ if a.Base != 0 {
+ s += fmt.Sprintf("(%s)", x86_plan9Reg[a.Base])
+ }
+ if a.Index != 0 && a.Scale != 0 {
+ s += fmt.Sprintf("(%s*%d)", x86_plan9Reg[a.Index], a.Scale)
+ }
+ return s
+ }
+ return arg.String()
+}
+
+var x86_plan9Suffix = [x86_maxOp + 1]bool{
+ x86_ADC: true,
+ x86_ADD: true,
+ x86_AND: true,
+ x86_BSF: true,
+ x86_BSR: true,
+ x86_BT: true,
+ x86_BTC: true,
+ x86_BTR: true,
+ x86_BTS: true,
+ x86_CMP: true,
+ x86_CMPXCHG: true,
+ x86_CVTSI2SD: true,
+ x86_CVTSI2SS: true,
+ x86_CVTSD2SI: true,
+ x86_CVTSS2SI: true,
+ x86_CVTTSD2SI: true,
+ x86_CVTTSS2SI: true,
+ x86_DEC: true,
+ x86_DIV: true,
+ x86_FLDENV: true,
+ x86_FRSTOR: true,
+ x86_IDIV: true,
+ x86_IMUL: true,
+ x86_IN: true,
+ x86_INC: true,
+ x86_LEA: true,
+ x86_MOV: true,
+ x86_MOVNTI: true,
+ x86_MUL: true,
+ x86_NEG: true,
+ x86_NOP: true,
+ x86_NOT: true,
+ x86_OR: true,
+ x86_OUT: true,
+ x86_POP: true,
+ x86_POPA: true,
+ x86_PUSH: true,
+ x86_PUSHA: true,
+ x86_RCL: true,
+ x86_RCR: true,
+ x86_ROL: true,
+ x86_ROR: true,
+ x86_SAR: true,
+ x86_SBB: true,
+ x86_SHL: true,
+ x86_SHLD: true,
+ x86_SHR: true,
+ x86_SHRD: true,
+ x86_SUB: true,
+ x86_TEST: true,
+ x86_XADD: true,
+ x86_XCHG: true,
+ x86_XOR: true,
+}
+
+var x86_plan9Reg = [...]string{
+ x86_AL: "AL",
+ x86_CL: "CL",
+ x86_BL: "BL",
+ x86_DL: "DL",
+ x86_AH: "AH",
+ x86_CH: "CH",
+ x86_BH: "BH",
+ x86_DH: "DH",
+ x86_SPB: "SP",
+ x86_BPB: "BP",
+ x86_SIB: "SI",
+ x86_DIB: "DI",
+ x86_R8B: "R8",
+ x86_R9B: "R9",
+ x86_R10B: "R10",
+ x86_R11B: "R11",
+ x86_R12B: "R12",
+ x86_R13B: "R13",
+ x86_R14B: "R14",
+ x86_R15B: "R15",
+ x86_AX: "AX",
+ x86_CX: "CX",
+ x86_BX: "BX",
+ x86_DX: "DX",
+ x86_SP: "SP",
+ x86_BP: "BP",
+ x86_SI: "SI",
+ x86_DI: "DI",
+ x86_R8W: "R8",
+ x86_R9W: "R9",
+ x86_R10W: "R10",
+ x86_R11W: "R11",
+ x86_R12W: "R12",
+ x86_R13W: "R13",
+ x86_R14W: "R14",
+ x86_R15W: "R15",
+ x86_EAX: "AX",
+ x86_ECX: "CX",
+ x86_EDX: "DX",
+ x86_EBX: "BX",
+ x86_ESP: "SP",
+ x86_EBP: "BP",
+ x86_ESI: "SI",
+ x86_EDI: "DI",
+ x86_R8L: "R8",
+ x86_R9L: "R9",
+ x86_R10L: "R10",
+ x86_R11L: "R11",
+ x86_R12L: "R12",
+ x86_R13L: "R13",
+ x86_R14L: "R14",
+ x86_R15L: "R15",
+ x86_RAX: "AX",
+ x86_RCX: "CX",
+ x86_RDX: "DX",
+ x86_RBX: "BX",
+ x86_RSP: "SP",
+ x86_RBP: "BP",
+ x86_RSI: "SI",
+ x86_RDI: "DI",
+ x86_R8: "R8",
+ x86_R9: "R9",
+ x86_R10: "R10",
+ x86_R11: "R11",
+ x86_R12: "R12",
+ x86_R13: "R13",
+ x86_R14: "R14",
+ x86_R15: "R15",
+ x86_IP: "IP",
+ x86_EIP: "IP",
+ x86_RIP: "IP",
+ x86_F0: "F0",
+ x86_F1: "F1",
+ x86_F2: "F2",
+ x86_F3: "F3",
+ x86_F4: "F4",
+ x86_F5: "F5",
+ x86_F6: "F6",
+ x86_F7: "F7",
+ x86_M0: "M0",
+ x86_M1: "M1",
+ x86_M2: "M2",
+ x86_M3: "M3",
+ x86_M4: "M4",
+ x86_M5: "M5",
+ x86_M6: "M6",
+ x86_M7: "M7",
+ x86_X0: "X0",
+ x86_X1: "X1",
+ x86_X2: "X2",
+ x86_X3: "X3",
+ x86_X4: "X4",
+ x86_X5: "X5",
+ x86_X6: "X6",
+ x86_X7: "X7",
+ x86_X8: "X8",
+ x86_X9: "X9",
+ x86_X10: "X10",
+ x86_X11: "X11",
+ x86_X12: "X12",
+ x86_X13: "X13",
+ x86_X14: "X14",
+ x86_X15: "X15",
+ x86_CS: "CS",
+ x86_SS: "SS",
+ x86_DS: "DS",
+ x86_ES: "ES",
+ x86_FS: "FS",
+ x86_GS: "GS",
+ x86_GDTR: "GDTR",
+ x86_IDTR: "IDTR",
+ x86_LDTR: "LDTR",
+ x86_MSW: "MSW",
+ x86_TASK: "TASK",
+ x86_CR0: "CR0",
+ x86_CR1: "CR1",
+ x86_CR2: "CR2",
+ x86_CR3: "CR3",
+ x86_CR4: "CR4",
+ x86_CR5: "CR5",
+ x86_CR6: "CR6",
+ x86_CR7: "CR7",
+ x86_CR8: "CR8",
+ x86_CR9: "CR9",
+ x86_CR10: "CR10",
+ x86_CR11: "CR11",
+ x86_CR12: "CR12",
+ x86_CR13: "CR13",
+ x86_CR14: "CR14",
+ x86_CR15: "CR15",
+ x86_DR0: "DR0",
+ x86_DR1: "DR1",
+ x86_DR2: "DR2",
+ x86_DR3: "DR3",
+ x86_DR4: "DR4",
+ x86_DR5: "DR5",
+ x86_DR6: "DR6",
+ x86_DR7: "DR7",
+ x86_DR8: "DR8",
+ x86_DR9: "DR9",
+ x86_DR10: "DR10",
+ x86_DR11: "DR11",
+ x86_DR12: "DR12",
+ x86_DR13: "DR13",
+ x86_DR14: "DR14",
+ x86_DR15: "DR15",
+ x86_TR0: "TR0",
+ x86_TR1: "TR1",
+ x86_TR2: "TR2",
+ x86_TR3: "TR3",
+ x86_TR4: "TR4",
+ x86_TR5: "TR5",
+ x86_TR6: "TR6",
+ x86_TR7: "TR7",
+}
+
+/* tables.go */
+
+// DO NOT EDIT
+// generated by: x86map -fmt=decoder ../x86.csv
+
+var x86_decoder = [...]uint16{
+ uint16(x86_xFail),
+ /*1*/ uint16(x86_xCondByte), 243,
+ 0x00, 490,
+ 0x01, 496,
+ 0x02, 525,
+ 0x03, 531,
+ 0x04, 560,
+ 0x05, 566,
+ 0x06, 595,
+ 0x07, 602,
+ 0x08, 609,
+ 0x09, 615,
+ 0x0A, 644,
+ 0x0B, 650,
+ 0x0C, 679,
+ 0x0D, 685,
+ 0x0E, 714,
+ 0x0F, 721,
+ 0x10, 8026,
+ 0x11, 8032,
+ 0x12, 8061,
+ 0x13, 8067,
+ 0x14, 8096,
+ 0x15, 8102,
+ 0x16, 8131,
+ 0x17, 8138,
+ 0x18, 8145,
+ 0x19, 8151,
+ 0x1A, 8180,
+ 0x1B, 8186,
+ 0x1C, 8215,
+ 0x1D, 8221,
+ 0x1E, 8250,
+ 0x1F, 8257,
+ 0x20, 8264,
+ 0x21, 8270,
+ 0x22, 8299,
+ 0x23, 8305,
+ 0x24, 8334,
+ 0x25, 8340,
+ 0x27, 8369,
+ 0x28, 8375,
+ 0x29, 8381,
+ 0x2A, 8410,
+ 0x2B, 8416,
+ 0x2C, 8445,
+ 0x2D, 8451,
+ 0x2F, 8480,
+ 0x30, 8486,
+ 0x31, 8492,
+ 0x32, 8521,
+ 0x33, 8527,
+ 0x34, 8556,
+ 0x35, 8562,
+ 0x37, 8591,
+ 0x38, 8597,
+ 0x39, 8603,
+ 0x3A, 8632,
+ 0x3B, 8638,
+ 0x3C, 8667,
+ 0x3D, 8673,
+ 0x3F, 8702,
+ 0x40, 8708,
+ 0x41, 8708,
+ 0x42, 8708,
+ 0x43, 8708,
+ 0x44, 8708,
+ 0x45, 8708,
+ 0x46, 8708,
+ 0x47, 8708,
+ 0x48, 8723,
+ 0x49, 8723,
+ 0x4a, 8723,
+ 0x4b, 8723,
+ 0x4c, 8723,
+ 0x4d, 8723,
+ 0x4e, 8723,
+ 0x4f, 8723,
+ 0x50, 8738,
+ 0x51, 8738,
+ 0x52, 8738,
+ 0x53, 8738,
+ 0x54, 8738,
+ 0x55, 8738,
+ 0x56, 8738,
+ 0x57, 8738,
+ 0x58, 8765,
+ 0x59, 8765,
+ 0x5a, 8765,
+ 0x5b, 8765,
+ 0x5c, 8765,
+ 0x5d, 8765,
+ 0x5e, 8765,
+ 0x5f, 8765,
+ 0x60, 8792,
+ 0x61, 8805,
+ 0x62, 8818,
+ 0x63, 8837,
+ 0x68, 8868,
+ 0x69, 8887,
+ 0x6A, 8922,
+ 0x6B, 8927,
+ 0x6C, 8962,
+ 0x6D, 8965,
+ 0x6E, 8978,
+ 0x6F, 8981,
+ 0x70, 8994,
+ 0x71, 8999,
+ 0x72, 9004,
+ 0x73, 9009,
+ 0x74, 9014,
+ 0x75, 9019,
+ 0x76, 9024,
+ 0x77, 9029,
+ 0x78, 9034,
+ 0x79, 9039,
+ 0x7A, 9044,
+ 0x7B, 9049,
+ 0x7C, 9054,
+ 0x7D, 9059,
+ 0x7E, 9064,
+ 0x7F, 9069,
+ 0x80, 9074,
+ 0x81, 9131,
+ 0x83, 9372,
+ 0x84, 9613,
+ 0x85, 9619,
+ 0x86, 9648,
+ 0x87, 9654,
+ 0x88, 9683,
+ 0x89, 9689,
+ 0x8A, 9711,
+ 0x8B, 9717,
+ 0x8C, 9739,
+ 0x8D, 9768,
+ 0x8E, 9797,
+ 0x8F, 9826,
+ 0x90, 9862,
+ 0x91, 9862,
+ 0x92, 9862,
+ 0x93, 9862,
+ 0x94, 9862,
+ 0x95, 9862,
+ 0x96, 9862,
+ 0x97, 9862,
+ 0x98, 9888,
+ 0x99, 9908,
+ 0x9A, 9928,
+ 0x9B, 9945,
+ 0x9C, 9948,
+ 0x9D, 9971,
+ 0x9E, 9994,
+ 0x9F, 9997,
+ 0xA0, 10000,
+ 0xA1, 10019,
+ 0xA2, 10041,
+ 0xA3, 10060,
+ 0xA4, 10082,
+ 0xA5, 10085,
+ 0xA6, 10105,
+ 0xA7, 10108,
+ 0xA8, 10128,
+ 0xA9, 10134,
+ 0xAA, 10163,
+ 0xAB, 10166,
+ 0xAC, 10186,
+ 0xAD, 10189,
+ 0xAE, 10209,
+ 0xAF, 10212,
+ 0xb0, 10232,
+ 0xb1, 10232,
+ 0xb2, 10232,
+ 0xb3, 10232,
+ 0xb4, 10232,
+ 0xb5, 10232,
+ 0xb6, 10232,
+ 0xb7, 10232,
+ 0xb8, 10238,
+ 0xb9, 10238,
+ 0xba, 10238,
+ 0xbb, 10238,
+ 0xbc, 10238,
+ 0xbd, 10238,
+ 0xbe, 10238,
+ 0xbf, 10238,
+ 0xC0, 10267,
+ 0xC1, 10318,
+ 0xC2, 10516,
+ 0xC3, 10521,
+ 0xC4, 10524,
+ 0xC5, 10543,
+ 0xC6, 10562,
+ 0xC7, 10586,
+ 0xC8, 10647,
+ 0xC9, 10654,
+ 0xCA, 10677,
+ 0xCB, 10682,
+ 0xCC, 10685,
+ 0xCD, 10689,
+ 0xCE, 10694,
+ 0xCF, 10700,
+ 0xD0, 10720,
+ 0xD1, 10764,
+ 0xD2, 10955,
+ 0xD3, 10999,
+ 0xD4, 11190,
+ 0xD5, 11198,
+ 0xD7, 11206,
+ 0xD8, 11219,
+ 0xD9, 11428,
+ 0xDA, 11637,
+ 0xDB, 11769,
+ 0xDC, 11940,
+ 0xDD, 12109,
+ 0xDE, 12248,
+ 0xDF, 12422,
+ 0xE0, 12533,
+ 0xE1, 12538,
+ 0xE2, 12543,
+ 0xE3, 12548,
+ 0xE4, 12574,
+ 0xE5, 12580,
+ 0xE6, 12602,
+ 0xE7, 12608,
+ 0xE8, 12630,
+ 0xE9, 12661,
+ 0xEA, 12692,
+ 0xEB, 12709,
+ 0xEC, 12714,
+ 0xED, 12719,
+ 0xEE, 12738,
+ 0xEF, 12743,
+ 0xF1, 12762,
+ 0xF4, 12765,
+ 0xF5, 12768,
+ 0xF6, 12771,
+ 0xF7, 12810,
+ 0xF8, 12986,
+ 0xF9, 12989,
+ 0xFA, 12992,
+ 0xFB, 12995,
+ 0xFC, 12998,
+ 0xFD, 13001,
+ 0xFE, 13004,
+ 0xFF, 13021,
+ uint16(x86_xFail),
+ /*490*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*492*/ uint16(x86_xReadSlashR),
+ /*493*/ uint16(x86_xArgRM8),
+ /*494*/ uint16(x86_xArgR8),
+ /*495*/ uint16(x86_xMatch),
+ /*496*/ uint16(x86_xCondIs64), 499, 515,
+ /*499*/ uint16(x86_xCondDataSize), 503, 509, 0,
+ /*503*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*505*/ uint16(x86_xReadSlashR),
+ /*506*/ uint16(x86_xArgRM16),
+ /*507*/ uint16(x86_xArgR16),
+ /*508*/ uint16(x86_xMatch),
+ /*509*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*511*/ uint16(x86_xReadSlashR),
+ /*512*/ uint16(x86_xArgRM32),
+ /*513*/ uint16(x86_xArgR32),
+ /*514*/ uint16(x86_xMatch),
+ /*515*/ uint16(x86_xCondDataSize), 503, 509, 519,
+ /*519*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*521*/ uint16(x86_xReadSlashR),
+ /*522*/ uint16(x86_xArgRM64),
+ /*523*/ uint16(x86_xArgR64),
+ /*524*/ uint16(x86_xMatch),
+ /*525*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*527*/ uint16(x86_xReadSlashR),
+ /*528*/ uint16(x86_xArgR8),
+ /*529*/ uint16(x86_xArgRM8),
+ /*530*/ uint16(x86_xMatch),
+ /*531*/ uint16(x86_xCondIs64), 534, 550,
+ /*534*/ uint16(x86_xCondDataSize), 538, 544, 0,
+ /*538*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*540*/ uint16(x86_xReadSlashR),
+ /*541*/ uint16(x86_xArgR16),
+ /*542*/ uint16(x86_xArgRM16),
+ /*543*/ uint16(x86_xMatch),
+ /*544*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*546*/ uint16(x86_xReadSlashR),
+ /*547*/ uint16(x86_xArgR32),
+ /*548*/ uint16(x86_xArgRM32),
+ /*549*/ uint16(x86_xMatch),
+ /*550*/ uint16(x86_xCondDataSize), 538, 544, 554,
+ /*554*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*556*/ uint16(x86_xReadSlashR),
+ /*557*/ uint16(x86_xArgR64),
+ /*558*/ uint16(x86_xArgRM64),
+ /*559*/ uint16(x86_xMatch),
+ /*560*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*562*/ uint16(x86_xReadIb),
+ /*563*/ uint16(x86_xArgAL),
+ /*564*/ uint16(x86_xArgImm8u),
+ /*565*/ uint16(x86_xMatch),
+ /*566*/ uint16(x86_xCondIs64), 569, 585,
+ /*569*/ uint16(x86_xCondDataSize), 573, 579, 0,
+ /*573*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*575*/ uint16(x86_xReadIw),
+ /*576*/ uint16(x86_xArgAX),
+ /*577*/ uint16(x86_xArgImm16),
+ /*578*/ uint16(x86_xMatch),
+ /*579*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*581*/ uint16(x86_xReadId),
+ /*582*/ uint16(x86_xArgEAX),
+ /*583*/ uint16(x86_xArgImm32),
+ /*584*/ uint16(x86_xMatch),
+ /*585*/ uint16(x86_xCondDataSize), 573, 579, 589,
+ /*589*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*591*/ uint16(x86_xReadId),
+ /*592*/ uint16(x86_xArgRAX),
+ /*593*/ uint16(x86_xArgImm32),
+ /*594*/ uint16(x86_xMatch),
+ /*595*/ uint16(x86_xCondIs64), 598, 0,
+ /*598*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*600*/ uint16(x86_xArgES),
+ /*601*/ uint16(x86_xMatch),
+ /*602*/ uint16(x86_xCondIs64), 605, 0,
+ /*605*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*607*/ uint16(x86_xArgES),
+ /*608*/ uint16(x86_xMatch),
+ /*609*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*611*/ uint16(x86_xReadSlashR),
+ /*612*/ uint16(x86_xArgRM8),
+ /*613*/ uint16(x86_xArgR8),
+ /*614*/ uint16(x86_xMatch),
+ /*615*/ uint16(x86_xCondIs64), 618, 634,
+ /*618*/ uint16(x86_xCondDataSize), 622, 628, 0,
+ /*622*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*624*/ uint16(x86_xReadSlashR),
+ /*625*/ uint16(x86_xArgRM16),
+ /*626*/ uint16(x86_xArgR16),
+ /*627*/ uint16(x86_xMatch),
+ /*628*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*630*/ uint16(x86_xReadSlashR),
+ /*631*/ uint16(x86_xArgRM32),
+ /*632*/ uint16(x86_xArgR32),
+ /*633*/ uint16(x86_xMatch),
+ /*634*/ uint16(x86_xCondDataSize), 622, 628, 638,
+ /*638*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*640*/ uint16(x86_xReadSlashR),
+ /*641*/ uint16(x86_xArgRM64),
+ /*642*/ uint16(x86_xArgR64),
+ /*643*/ uint16(x86_xMatch),
+ /*644*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*646*/ uint16(x86_xReadSlashR),
+ /*647*/ uint16(x86_xArgR8),
+ /*648*/ uint16(x86_xArgRM8),
+ /*649*/ uint16(x86_xMatch),
+ /*650*/ uint16(x86_xCondIs64), 653, 669,
+ /*653*/ uint16(x86_xCondDataSize), 657, 663, 0,
+ /*657*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*659*/ uint16(x86_xReadSlashR),
+ /*660*/ uint16(x86_xArgR16),
+ /*661*/ uint16(x86_xArgRM16),
+ /*662*/ uint16(x86_xMatch),
+ /*663*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*665*/ uint16(x86_xReadSlashR),
+ /*666*/ uint16(x86_xArgR32),
+ /*667*/ uint16(x86_xArgRM32),
+ /*668*/ uint16(x86_xMatch),
+ /*669*/ uint16(x86_xCondDataSize), 657, 663, 673,
+ /*673*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*675*/ uint16(x86_xReadSlashR),
+ /*676*/ uint16(x86_xArgR64),
+ /*677*/ uint16(x86_xArgRM64),
+ /*678*/ uint16(x86_xMatch),
+ /*679*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*681*/ uint16(x86_xReadIb),
+ /*682*/ uint16(x86_xArgAL),
+ /*683*/ uint16(x86_xArgImm8u),
+ /*684*/ uint16(x86_xMatch),
+ /*685*/ uint16(x86_xCondIs64), 688, 704,
+ /*688*/ uint16(x86_xCondDataSize), 692, 698, 0,
+ /*692*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*694*/ uint16(x86_xReadIw),
+ /*695*/ uint16(x86_xArgAX),
+ /*696*/ uint16(x86_xArgImm16),
+ /*697*/ uint16(x86_xMatch),
+ /*698*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*700*/ uint16(x86_xReadId),
+ /*701*/ uint16(x86_xArgEAX),
+ /*702*/ uint16(x86_xArgImm32),
+ /*703*/ uint16(x86_xMatch),
+ /*704*/ uint16(x86_xCondDataSize), 692, 698, 708,
+ /*708*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*710*/ uint16(x86_xReadId),
+ /*711*/ uint16(x86_xArgRAX),
+ /*712*/ uint16(x86_xArgImm32),
+ /*713*/ uint16(x86_xMatch),
+ /*714*/ uint16(x86_xCondIs64), 717, 0,
+ /*717*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*719*/ uint16(x86_xArgCS),
+ /*720*/ uint16(x86_xMatch),
+ /*721*/ uint16(x86_xCondByte), 228,
+ 0x00, 1180,
+ 0x01, 1237,
+ 0x02, 1345,
+ 0x03, 1367,
+ 0x05, 1389,
+ 0x06, 1395,
+ 0x07, 1398,
+ 0x08, 1404,
+ 0x09, 1407,
+ 0x0B, 1410,
+ 0x0D, 1413,
+ 0x10, 1426,
+ 0x11, 1460,
+ 0x12, 1494,
+ 0x13, 1537,
+ 0x14, 1555,
+ 0x15, 1573,
+ 0x16, 1591,
+ 0x17, 1626,
+ 0x18, 1644,
+ 0x1F, 1669,
+ 0x20, 1690,
+ 0x21, 1705,
+ 0x22, 1720,
+ 0x23, 1735,
+ 0x24, 1750,
+ 0x26, 1765,
+ 0x28, 1780,
+ 0x29, 1798,
+ 0x2A, 1816,
+ 0x2B, 1903,
+ 0x2C, 1937,
+ 0x2D, 2024,
+ 0x2E, 2111,
+ 0x2F, 2129,
+ 0x30, 2147,
+ 0x31, 2150,
+ 0x32, 2153,
+ 0x33, 2156,
+ 0x34, 2159,
+ 0x35, 2162,
+ 0x38, 2172,
+ 0x3A, 3073,
+ 0x40, 3484,
+ 0x41, 3513,
+ 0x42, 3542,
+ 0x43, 3571,
+ 0x44, 3600,
+ 0x45, 3629,
+ 0x46, 3658,
+ 0x47, 3687,
+ 0x48, 3716,
+ 0x49, 3745,
+ 0x4A, 3774,
+ 0x4B, 3803,
+ 0x4C, 3832,
+ 0x4D, 3861,
+ 0x4E, 3890,
+ 0x4F, 3919,
+ 0x50, 3948,
+ 0x51, 3966,
+ 0x52, 4000,
+ 0x53, 4018,
+ 0x54, 4036,
+ 0x55, 4054,
+ 0x56, 4072,
+ 0x57, 4090,
+ 0x58, 4108,
+ 0x59, 4142,
+ 0x5A, 4176,
+ 0x5B, 4210,
+ 0x5C, 4236,
+ 0x5D, 4270,
+ 0x5E, 4304,
+ 0x5F, 4338,
+ 0x60, 4372,
+ 0x61, 4390,
+ 0x62, 4408,
+ 0x63, 4426,
+ 0x64, 4444,
+ 0x65, 4462,
+ 0x66, 4480,
+ 0x67, 4498,
+ 0x68, 4516,
+ 0x69, 4534,
+ 0x6A, 4552,
+ 0x6B, 4570,
+ 0x6C, 4588,
+ 0x6D, 4598,
+ 0x6E, 4608,
+ 0x6F, 4675,
+ 0x70, 4701,
+ 0x71, 4743,
+ 0x72, 4806,
+ 0x73, 4869,
+ 0x74, 4934,
+ 0x75, 4952,
+ 0x76, 4970,
+ 0x77, 4988,
+ 0x7C, 4991,
+ 0x7D, 5009,
+ 0x7E, 5027,
+ 0x7F, 5104,
+ 0x80, 5130,
+ 0x81, 5161,
+ 0x82, 5192,
+ 0x83, 5223,
+ 0x84, 5254,
+ 0x85, 5285,
+ 0x86, 5316,
+ 0x87, 5347,
+ 0x88, 5378,
+ 0x89, 5409,
+ 0x8A, 5440,
+ 0x8B, 5471,
+ 0x8C, 5502,
+ 0x8D, 5533,
+ 0x8E, 5564,
+ 0x8F, 5595,
+ 0x90, 5626,
+ 0x91, 5631,
+ 0x92, 5636,
+ 0x93, 5641,
+ 0x94, 5646,
+ 0x95, 5651,
+ 0x96, 5656,
+ 0x97, 5661,
+ 0x98, 5666,
+ 0x99, 5671,
+ 0x9A, 5676,
+ 0x9B, 5681,
+ 0x9C, 5686,
+ 0x9D, 5691,
+ 0x9E, 5696,
+ 0x9F, 5701,
+ 0xA0, 5706,
+ 0xA1, 5710,
+ 0xA2, 5737,
+ 0xA3, 5740,
+ 0xA4, 5769,
+ 0xA5, 5804,
+ 0xA8, 5836,
+ 0xA9, 5840,
+ 0xAA, 5867,
+ 0xAB, 5870,
+ 0xAC, 5899,
+ 0xAD, 5934,
+ 0xAE, 5966,
+ 0xAF, 6224,
+ 0xB0, 6253,
+ 0xB1, 6259,
+ 0xB2, 6288,
+ 0xB3, 6317,
+ 0xB4, 6346,
+ 0xB5, 6375,
+ 0xB6, 6404,
+ 0xB7, 6433,
+ 0xB8, 6462,
+ 0xB9, 6499,
+ 0xBA, 6502,
+ 0xBB, 6627,
+ 0xBC, 6656,
+ 0xBD, 6723,
+ 0xBE, 6790,
+ 0xBF, 6819,
+ 0xC0, 6848,
+ 0xC1, 6854,
+ 0xC2, 6883,
+ 0xC3, 6925,
+ 0xC4, 6954,
+ 0xC5, 6976,
+ 0xC6, 6998,
+ 0xC7, 7020,
+ 0xc8, 7149,
+ 0xc9, 7149,
+ 0xca, 7149,
+ 0xcb, 7149,
+ 0xcc, 7149,
+ 0xcd, 7149,
+ 0xce, 7149,
+ 0xcf, 7149,
+ 0xD0, 7172,
+ 0xD1, 7190,
+ 0xD2, 7208,
+ 0xD3, 7226,
+ 0xD4, 7244,
+ 0xD5, 7262,
+ 0xD6, 7280,
+ 0xD7, 7306,
+ 0xD8, 7324,
+ 0xD9, 7342,
+ 0xDA, 7360,
+ 0xDB, 7378,
+ 0xDC, 7396,
+ 0xDD, 7414,
+ 0xDE, 7432,
+ 0xDF, 7450,
+ 0xE0, 7468,
+ 0xE1, 7486,
+ 0xE2, 7504,
+ 0xE3, 7522,
+ 0xE4, 7540,
+ 0xE5, 7558,
+ 0xE6, 7576,
+ 0xE7, 7602,
+ 0xE8, 7620,
+ 0xE9, 7638,
+ 0xEA, 7656,
+ 0xEB, 7674,
+ 0xEC, 7692,
+ 0xED, 7710,
+ 0xEE, 7728,
+ 0xEF, 7746,
+ 0xF0, 7764,
+ 0xF1, 7774,
+ 0xF2, 7792,
+ 0xF3, 7810,
+ 0xF4, 7828,
+ 0xF5, 7846,
+ 0xF6, 7864,
+ 0xF7, 7882,
+ 0xF8, 7900,
+ 0xF9, 7918,
+ 0xFA, 7936,
+ 0xFB, 7954,
+ 0xFC, 7972,
+ 0xFD, 7990,
+ 0xFE, 8008,
+ uint16(x86_xFail),
+ /*1180*/ uint16(x86_xCondSlashR),
+ 1189, // 0
+ 1205, // 1
+ 1221, // 2
+ 1225, // 3
+ 1229, // 4
+ 1233, // 5
+ 0, // 6
+ 0, // 7
+ /*1189*/ uint16(x86_xCondDataSize), 1193, 1197, 1201,
+ /*1193*/ uint16(x86_xSetOp), uint16(x86_SLDT),
+ /*1195*/ uint16(x86_xArgRM16),
+ /*1196*/ uint16(x86_xMatch),
+ /*1197*/ uint16(x86_xSetOp), uint16(x86_SLDT),
+ /*1199*/ uint16(x86_xArgR32M16),
+ /*1200*/ uint16(x86_xMatch),
+ /*1201*/ uint16(x86_xSetOp), uint16(x86_SLDT),
+ /*1203*/ uint16(x86_xArgR64M16),
+ /*1204*/ uint16(x86_xMatch),
+ /*1205*/ uint16(x86_xCondDataSize), 1209, 1213, 1217,
+ /*1209*/ uint16(x86_xSetOp), uint16(x86_STR),
+ /*1211*/ uint16(x86_xArgRM16),
+ /*1212*/ uint16(x86_xMatch),
+ /*1213*/ uint16(x86_xSetOp), uint16(x86_STR),
+ /*1215*/ uint16(x86_xArgR32M16),
+ /*1216*/ uint16(x86_xMatch),
+ /*1217*/ uint16(x86_xSetOp), uint16(x86_STR),
+ /*1219*/ uint16(x86_xArgR64M16),
+ /*1220*/ uint16(x86_xMatch),
+ /*1221*/ uint16(x86_xSetOp), uint16(x86_LLDT),
+ /*1223*/ uint16(x86_xArgRM16),
+ /*1224*/ uint16(x86_xMatch),
+ /*1225*/ uint16(x86_xSetOp), uint16(x86_LTR),
+ /*1227*/ uint16(x86_xArgRM16),
+ /*1228*/ uint16(x86_xMatch),
+ /*1229*/ uint16(x86_xSetOp), uint16(x86_VERR),
+ /*1231*/ uint16(x86_xArgRM16),
+ /*1232*/ uint16(x86_xMatch),
+ /*1233*/ uint16(x86_xSetOp), uint16(x86_VERW),
+ /*1235*/ uint16(x86_xArgRM16),
+ /*1236*/ uint16(x86_xMatch),
+ /*1237*/ uint16(x86_xCondByte), 8,
+ 0xC8, 1318,
+ 0xC9, 1321,
+ 0xD0, 1324,
+ 0xD1, 1327,
+ 0xD5, 1330,
+ 0xD6, 1333,
+ 0xF8, 1336,
+ 0xF9, 1342,
+ /*1255*/ uint16(x86_xCondSlashR),
+ 1264, // 0
+ 1268, // 1
+ 1272, // 2
+ 1283, // 3
+ 1294, // 4
+ 0, // 5
+ 1310, // 6
+ 1314, // 7
+ /*1264*/ uint16(x86_xSetOp), uint16(x86_SGDT),
+ /*1266*/ uint16(x86_xArgM),
+ /*1267*/ uint16(x86_xMatch),
+ /*1268*/ uint16(x86_xSetOp), uint16(x86_SIDT),
+ /*1270*/ uint16(x86_xArgM),
+ /*1271*/ uint16(x86_xMatch),
+ /*1272*/ uint16(x86_xCondIs64), 1275, 1279,
+ /*1275*/ uint16(x86_xSetOp), uint16(x86_LGDT),
+ /*1277*/ uint16(x86_xArgM16and32),
+ /*1278*/ uint16(x86_xMatch),
+ /*1279*/ uint16(x86_xSetOp), uint16(x86_LGDT),
+ /*1281*/ uint16(x86_xArgM16and64),
+ /*1282*/ uint16(x86_xMatch),
+ /*1283*/ uint16(x86_xCondIs64), 1286, 1290,
+ /*1286*/ uint16(x86_xSetOp), uint16(x86_LIDT),
+ /*1288*/ uint16(x86_xArgM16and32),
+ /*1289*/ uint16(x86_xMatch),
+ /*1290*/ uint16(x86_xSetOp), uint16(x86_LIDT),
+ /*1292*/ uint16(x86_xArgM16and64),
+ /*1293*/ uint16(x86_xMatch),
+ /*1294*/ uint16(x86_xCondDataSize), 1298, 1302, 1306,
+ /*1298*/ uint16(x86_xSetOp), uint16(x86_SMSW),
+ /*1300*/ uint16(x86_xArgRM16),
+ /*1301*/ uint16(x86_xMatch),
+ /*1302*/ uint16(x86_xSetOp), uint16(x86_SMSW),
+ /*1304*/ uint16(x86_xArgR32M16),
+ /*1305*/ uint16(x86_xMatch),
+ /*1306*/ uint16(x86_xSetOp), uint16(x86_SMSW),
+ /*1308*/ uint16(x86_xArgR64M16),
+ /*1309*/ uint16(x86_xMatch),
+ /*1310*/ uint16(x86_xSetOp), uint16(x86_LMSW),
+ /*1312*/ uint16(x86_xArgRM16),
+ /*1313*/ uint16(x86_xMatch),
+ /*1314*/ uint16(x86_xSetOp), uint16(x86_INVLPG),
+ /*1316*/ uint16(x86_xArgM),
+ /*1317*/ uint16(x86_xMatch),
+ /*1318*/ uint16(x86_xSetOp), uint16(x86_MONITOR),
+ /*1320*/ uint16(x86_xMatch),
+ /*1321*/ uint16(x86_xSetOp), uint16(x86_MWAIT),
+ /*1323*/ uint16(x86_xMatch),
+ /*1324*/ uint16(x86_xSetOp), uint16(x86_XGETBV),
+ /*1326*/ uint16(x86_xMatch),
+ /*1327*/ uint16(x86_xSetOp), uint16(x86_XSETBV),
+ /*1329*/ uint16(x86_xMatch),
+ /*1330*/ uint16(x86_xSetOp), uint16(x86_XEND),
+ /*1332*/ uint16(x86_xMatch),
+ /*1333*/ uint16(x86_xSetOp), uint16(x86_XTEST),
+ /*1335*/ uint16(x86_xMatch),
+ /*1336*/ uint16(x86_xCondIs64), 0, 1339,
+ /*1339*/ uint16(x86_xSetOp), uint16(x86_SWAPGS),
+ /*1341*/ uint16(x86_xMatch),
+ /*1342*/ uint16(x86_xSetOp), uint16(x86_RDTSCP),
+ /*1344*/ uint16(x86_xMatch),
+ /*1345*/ uint16(x86_xCondDataSize), 1349, 1355, 1361,
+ /*1349*/ uint16(x86_xSetOp), uint16(x86_LAR),
+ /*1351*/ uint16(x86_xReadSlashR),
+ /*1352*/ uint16(x86_xArgR16),
+ /*1353*/ uint16(x86_xArgRM16),
+ /*1354*/ uint16(x86_xMatch),
+ /*1355*/ uint16(x86_xSetOp), uint16(x86_LAR),
+ /*1357*/ uint16(x86_xReadSlashR),
+ /*1358*/ uint16(x86_xArgR32),
+ /*1359*/ uint16(x86_xArgR32M16),
+ /*1360*/ uint16(x86_xMatch),
+ /*1361*/ uint16(x86_xSetOp), uint16(x86_LAR),
+ /*1363*/ uint16(x86_xReadSlashR),
+ /*1364*/ uint16(x86_xArgR64),
+ /*1365*/ uint16(x86_xArgR64M16),
+ /*1366*/ uint16(x86_xMatch),
+ /*1367*/ uint16(x86_xCondDataSize), 1371, 1377, 1383,
+ /*1371*/ uint16(x86_xSetOp), uint16(x86_LSL),
+ /*1373*/ uint16(x86_xReadSlashR),
+ /*1374*/ uint16(x86_xArgR16),
+ /*1375*/ uint16(x86_xArgRM16),
+ /*1376*/ uint16(x86_xMatch),
+ /*1377*/ uint16(x86_xSetOp), uint16(x86_LSL),
+ /*1379*/ uint16(x86_xReadSlashR),
+ /*1380*/ uint16(x86_xArgR32),
+ /*1381*/ uint16(x86_xArgR32M16),
+ /*1382*/ uint16(x86_xMatch),
+ /*1383*/ uint16(x86_xSetOp), uint16(x86_LSL),
+ /*1385*/ uint16(x86_xReadSlashR),
+ /*1386*/ uint16(x86_xArgR64),
+ /*1387*/ uint16(x86_xArgR32M16),
+ /*1388*/ uint16(x86_xMatch),
+ /*1389*/ uint16(x86_xCondIs64), 0, 1392,
+ /*1392*/ uint16(x86_xSetOp), uint16(x86_SYSCALL),
+ /*1394*/ uint16(x86_xMatch),
+ /*1395*/ uint16(x86_xSetOp), uint16(x86_CLTS),
+ /*1397*/ uint16(x86_xMatch),
+ /*1398*/ uint16(x86_xCondIs64), 0, 1401,
+ /*1401*/ uint16(x86_xSetOp), uint16(x86_SYSRET),
+ /*1403*/ uint16(x86_xMatch),
+ /*1404*/ uint16(x86_xSetOp), uint16(x86_INVD),
+ /*1406*/ uint16(x86_xMatch),
+ /*1407*/ uint16(x86_xSetOp), uint16(x86_WBINVD),
+ /*1409*/ uint16(x86_xMatch),
+ /*1410*/ uint16(x86_xSetOp), uint16(x86_UD2),
+ /*1412*/ uint16(x86_xMatch),
+ /*1413*/ uint16(x86_xCondSlashR),
+ 0, // 0
+ 1422, // 1
+ 0, // 2
+ 0, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*1422*/ uint16(x86_xSetOp), uint16(x86_PREFETCHW),
+ /*1424*/ uint16(x86_xArgM8),
+ /*1425*/ uint16(x86_xMatch),
+ /*1426*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1454,
+ 0xF2, 1448,
+ 0x66, 1442,
+ 0x0, 1436,
+ /*1436*/ uint16(x86_xSetOp), uint16(x86_MOVUPS),
+ /*1438*/ uint16(x86_xReadSlashR),
+ /*1439*/ uint16(x86_xArgXmm1),
+ /*1440*/ uint16(x86_xArgXmm2M128),
+ /*1441*/ uint16(x86_xMatch),
+ /*1442*/ uint16(x86_xSetOp), uint16(x86_MOVUPD),
+ /*1444*/ uint16(x86_xReadSlashR),
+ /*1445*/ uint16(x86_xArgXmm1),
+ /*1446*/ uint16(x86_xArgXmm2M128),
+ /*1447*/ uint16(x86_xMatch),
+ /*1448*/ uint16(x86_xSetOp), uint16(x86_MOVSD_XMM),
+ /*1450*/ uint16(x86_xReadSlashR),
+ /*1451*/ uint16(x86_xArgXmm1),
+ /*1452*/ uint16(x86_xArgXmm2M64),
+ /*1453*/ uint16(x86_xMatch),
+ /*1454*/ uint16(x86_xSetOp), uint16(x86_MOVSS),
+ /*1456*/ uint16(x86_xReadSlashR),
+ /*1457*/ uint16(x86_xArgXmm1),
+ /*1458*/ uint16(x86_xArgXmm2M32),
+ /*1459*/ uint16(x86_xMatch),
+ /*1460*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1488,
+ 0xF2, 1482,
+ 0x66, 1476,
+ 0x0, 1470,
+ /*1470*/ uint16(x86_xSetOp), uint16(x86_MOVUPS),
+ /*1472*/ uint16(x86_xReadSlashR),
+ /*1473*/ uint16(x86_xArgXmm2M128),
+ /*1474*/ uint16(x86_xArgXmm1),
+ /*1475*/ uint16(x86_xMatch),
+ /*1476*/ uint16(x86_xSetOp), uint16(x86_MOVUPD),
+ /*1478*/ uint16(x86_xReadSlashR),
+ /*1479*/ uint16(x86_xArgXmm2M128),
+ /*1480*/ uint16(x86_xArgXmm),
+ /*1481*/ uint16(x86_xMatch),
+ /*1482*/ uint16(x86_xSetOp), uint16(x86_MOVSD_XMM),
+ /*1484*/ uint16(x86_xReadSlashR),
+ /*1485*/ uint16(x86_xArgXmm2M64),
+ /*1486*/ uint16(x86_xArgXmm1),
+ /*1487*/ uint16(x86_xMatch),
+ /*1488*/ uint16(x86_xSetOp), uint16(x86_MOVSS),
+ /*1490*/ uint16(x86_xReadSlashR),
+ /*1491*/ uint16(x86_xArgXmm2M32),
+ /*1492*/ uint16(x86_xArgXmm),
+ /*1493*/ uint16(x86_xMatch),
+ /*1494*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1531,
+ 0xF2, 1525,
+ 0x66, 1519,
+ 0x0, 1504,
+ /*1504*/ uint16(x86_xCondIsMem), 1507, 1513,
+ /*1507*/ uint16(x86_xSetOp), uint16(x86_MOVHLPS),
+ /*1509*/ uint16(x86_xReadSlashR),
+ /*1510*/ uint16(x86_xArgXmm1),
+ /*1511*/ uint16(x86_xArgXmm2),
+ /*1512*/ uint16(x86_xMatch),
+ /*1513*/ uint16(x86_xSetOp), uint16(x86_MOVLPS),
+ /*1515*/ uint16(x86_xReadSlashR),
+ /*1516*/ uint16(x86_xArgXmm),
+ /*1517*/ uint16(x86_xArgM64),
+ /*1518*/ uint16(x86_xMatch),
+ /*1519*/ uint16(x86_xSetOp), uint16(x86_MOVLPD),
+ /*1521*/ uint16(x86_xReadSlashR),
+ /*1522*/ uint16(x86_xArgXmm),
+ /*1523*/ uint16(x86_xArgXmm2M64),
+ /*1524*/ uint16(x86_xMatch),
+ /*1525*/ uint16(x86_xSetOp), uint16(x86_MOVDDUP),
+ /*1527*/ uint16(x86_xReadSlashR),
+ /*1528*/ uint16(x86_xArgXmm1),
+ /*1529*/ uint16(x86_xArgXmm2M64),
+ /*1530*/ uint16(x86_xMatch),
+ /*1531*/ uint16(x86_xSetOp), uint16(x86_MOVSLDUP),
+ /*1533*/ uint16(x86_xReadSlashR),
+ /*1534*/ uint16(x86_xArgXmm1),
+ /*1535*/ uint16(x86_xArgXmm2M128),
+ /*1536*/ uint16(x86_xMatch),
+ /*1537*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 1549,
+ 0x0, 1543,
+ /*1543*/ uint16(x86_xSetOp), uint16(x86_MOVLPS),
+ /*1545*/ uint16(x86_xReadSlashR),
+ /*1546*/ uint16(x86_xArgM64),
+ /*1547*/ uint16(x86_xArgXmm),
+ /*1548*/ uint16(x86_xMatch),
+ /*1549*/ uint16(x86_xSetOp), uint16(x86_MOVLPD),
+ /*1551*/ uint16(x86_xReadSlashR),
+ /*1552*/ uint16(x86_xArgXmm2M64),
+ /*1553*/ uint16(x86_xArgXmm),
+ /*1554*/ uint16(x86_xMatch),
+ /*1555*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 1567,
+ 0x0, 1561,
+ /*1561*/ uint16(x86_xSetOp), uint16(x86_UNPCKLPS),
+ /*1563*/ uint16(x86_xReadSlashR),
+ /*1564*/ uint16(x86_xArgXmm1),
+ /*1565*/ uint16(x86_xArgXmm2M128),
+ /*1566*/ uint16(x86_xMatch),
+ /*1567*/ uint16(x86_xSetOp), uint16(x86_UNPCKLPD),
+ /*1569*/ uint16(x86_xReadSlashR),
+ /*1570*/ uint16(x86_xArgXmm1),
+ /*1571*/ uint16(x86_xArgXmm2M128),
+ /*1572*/ uint16(x86_xMatch),
+ /*1573*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 1585,
+ 0x0, 1579,
+ /*1579*/ uint16(x86_xSetOp), uint16(x86_UNPCKHPS),
+ /*1581*/ uint16(x86_xReadSlashR),
+ /*1582*/ uint16(x86_xArgXmm1),
+ /*1583*/ uint16(x86_xArgXmm2M128),
+ /*1584*/ uint16(x86_xMatch),
+ /*1585*/ uint16(x86_xSetOp), uint16(x86_UNPCKHPD),
+ /*1587*/ uint16(x86_xReadSlashR),
+ /*1588*/ uint16(x86_xArgXmm1),
+ /*1589*/ uint16(x86_xArgXmm2M128),
+ /*1590*/ uint16(x86_xMatch),
+ /*1591*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 1620,
+ 0x66, 1614,
+ 0x0, 1599,
+ /*1599*/ uint16(x86_xCondIsMem), 1602, 1608,
+ /*1602*/ uint16(x86_xSetOp), uint16(x86_MOVLHPS),
+ /*1604*/ uint16(x86_xReadSlashR),
+ /*1605*/ uint16(x86_xArgXmm1),
+ /*1606*/ uint16(x86_xArgXmm2),
+ /*1607*/ uint16(x86_xMatch),
+ /*1608*/ uint16(x86_xSetOp), uint16(x86_MOVHPS),
+ /*1610*/ uint16(x86_xReadSlashR),
+ /*1611*/ uint16(x86_xArgXmm),
+ /*1612*/ uint16(x86_xArgM64),
+ /*1613*/ uint16(x86_xMatch),
+ /*1614*/ uint16(x86_xSetOp), uint16(x86_MOVHPD),
+ /*1616*/ uint16(x86_xReadSlashR),
+ /*1617*/ uint16(x86_xArgXmm),
+ /*1618*/ uint16(x86_xArgXmm2M64),
+ /*1619*/ uint16(x86_xMatch),
+ /*1620*/ uint16(x86_xSetOp), uint16(x86_MOVSHDUP),
+ /*1622*/ uint16(x86_xReadSlashR),
+ /*1623*/ uint16(x86_xArgXmm1),
+ /*1624*/ uint16(x86_xArgXmm2M128),
+ /*1625*/ uint16(x86_xMatch),
+ /*1626*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 1638,
+ 0x0, 1632,
+ /*1632*/ uint16(x86_xSetOp), uint16(x86_MOVHPS),
+ /*1634*/ uint16(x86_xReadSlashR),
+ /*1635*/ uint16(x86_xArgM64),
+ /*1636*/ uint16(x86_xArgXmm),
+ /*1637*/ uint16(x86_xMatch),
+ /*1638*/ uint16(x86_xSetOp), uint16(x86_MOVHPD),
+ /*1640*/ uint16(x86_xReadSlashR),
+ /*1641*/ uint16(x86_xArgXmm2M64),
+ /*1642*/ uint16(x86_xArgXmm),
+ /*1643*/ uint16(x86_xMatch),
+ /*1644*/ uint16(x86_xCondSlashR),
+ 1653, // 0
+ 1657, // 1
+ 1661, // 2
+ 1665, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*1653*/ uint16(x86_xSetOp), uint16(x86_PREFETCHNTA),
+ /*1655*/ uint16(x86_xArgM8),
+ /*1656*/ uint16(x86_xMatch),
+ /*1657*/ uint16(x86_xSetOp), uint16(x86_PREFETCHT0),
+ /*1659*/ uint16(x86_xArgM8),
+ /*1660*/ uint16(x86_xMatch),
+ /*1661*/ uint16(x86_xSetOp), uint16(x86_PREFETCHT1),
+ /*1663*/ uint16(x86_xArgM8),
+ /*1664*/ uint16(x86_xMatch),
+ /*1665*/ uint16(x86_xSetOp), uint16(x86_PREFETCHT2),
+ /*1667*/ uint16(x86_xArgM8),
+ /*1668*/ uint16(x86_xMatch),
+ /*1669*/ uint16(x86_xCondSlashR),
+ 1678, // 0
+ 0, // 1
+ 0, // 2
+ 0, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*1678*/ uint16(x86_xCondDataSize), 1682, 1686, 0,
+ /*1682*/ uint16(x86_xSetOp), uint16(x86_NOP),
+ /*1684*/ uint16(x86_xArgRM16),
+ /*1685*/ uint16(x86_xMatch),
+ /*1686*/ uint16(x86_xSetOp), uint16(x86_NOP),
+ /*1688*/ uint16(x86_xArgRM32),
+ /*1689*/ uint16(x86_xMatch),
+ /*1690*/ uint16(x86_xCondIs64), 1693, 1699,
+ /*1693*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1695*/ uint16(x86_xReadSlashR),
+ /*1696*/ uint16(x86_xArgRmf32),
+ /*1697*/ uint16(x86_xArgCR0dashCR7),
+ /*1698*/ uint16(x86_xMatch),
+ /*1699*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1701*/ uint16(x86_xReadSlashR),
+ /*1702*/ uint16(x86_xArgRmf64),
+ /*1703*/ uint16(x86_xArgCR0dashCR7),
+ /*1704*/ uint16(x86_xMatch),
+ /*1705*/ uint16(x86_xCondIs64), 1708, 1714,
+ /*1708*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1710*/ uint16(x86_xReadSlashR),
+ /*1711*/ uint16(x86_xArgRmf32),
+ /*1712*/ uint16(x86_xArgDR0dashDR7),
+ /*1713*/ uint16(x86_xMatch),
+ /*1714*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1716*/ uint16(x86_xReadSlashR),
+ /*1717*/ uint16(x86_xArgRmf64),
+ /*1718*/ uint16(x86_xArgDR0dashDR7),
+ /*1719*/ uint16(x86_xMatch),
+ /*1720*/ uint16(x86_xCondIs64), 1723, 1729,
+ /*1723*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1725*/ uint16(x86_xReadSlashR),
+ /*1726*/ uint16(x86_xArgCR0dashCR7),
+ /*1727*/ uint16(x86_xArgRmf32),
+ /*1728*/ uint16(x86_xMatch),
+ /*1729*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1731*/ uint16(x86_xReadSlashR),
+ /*1732*/ uint16(x86_xArgCR0dashCR7),
+ /*1733*/ uint16(x86_xArgRmf64),
+ /*1734*/ uint16(x86_xMatch),
+ /*1735*/ uint16(x86_xCondIs64), 1738, 1744,
+ /*1738*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1740*/ uint16(x86_xReadSlashR),
+ /*1741*/ uint16(x86_xArgDR0dashDR7),
+ /*1742*/ uint16(x86_xArgRmf32),
+ /*1743*/ uint16(x86_xMatch),
+ /*1744*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1746*/ uint16(x86_xReadSlashR),
+ /*1747*/ uint16(x86_xArgDR0dashDR7),
+ /*1748*/ uint16(x86_xArgRmf64),
+ /*1749*/ uint16(x86_xMatch),
+ /*1750*/ uint16(x86_xCondIs64), 1753, 1759,
+ /*1753*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1755*/ uint16(x86_xReadSlashR),
+ /*1756*/ uint16(x86_xArgRmf32),
+ /*1757*/ uint16(x86_xArgTR0dashTR7),
+ /*1758*/ uint16(x86_xMatch),
+ /*1759*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1761*/ uint16(x86_xReadSlashR),
+ /*1762*/ uint16(x86_xArgRmf64),
+ /*1763*/ uint16(x86_xArgTR0dashTR7),
+ /*1764*/ uint16(x86_xMatch),
+ /*1765*/ uint16(x86_xCondIs64), 1768, 1774,
+ /*1768*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1770*/ uint16(x86_xReadSlashR),
+ /*1771*/ uint16(x86_xArgTR0dashTR7),
+ /*1772*/ uint16(x86_xArgRmf32),
+ /*1773*/ uint16(x86_xMatch),
+ /*1774*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*1776*/ uint16(x86_xReadSlashR),
+ /*1777*/ uint16(x86_xArgTR0dashTR7),
+ /*1778*/ uint16(x86_xArgRmf64),
+ /*1779*/ uint16(x86_xMatch),
+ /*1780*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 1792,
+ 0x0, 1786,
+ /*1786*/ uint16(x86_xSetOp), uint16(x86_MOVAPS),
+ /*1788*/ uint16(x86_xReadSlashR),
+ /*1789*/ uint16(x86_xArgXmm1),
+ /*1790*/ uint16(x86_xArgXmm2M128),
+ /*1791*/ uint16(x86_xMatch),
+ /*1792*/ uint16(x86_xSetOp), uint16(x86_MOVAPD),
+ /*1794*/ uint16(x86_xReadSlashR),
+ /*1795*/ uint16(x86_xArgXmm1),
+ /*1796*/ uint16(x86_xArgXmm2M128),
+ /*1797*/ uint16(x86_xMatch),
+ /*1798*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 1810,
+ 0x0, 1804,
+ /*1804*/ uint16(x86_xSetOp), uint16(x86_MOVAPS),
+ /*1806*/ uint16(x86_xReadSlashR),
+ /*1807*/ uint16(x86_xArgXmm2M128),
+ /*1808*/ uint16(x86_xArgXmm1),
+ /*1809*/ uint16(x86_xMatch),
+ /*1810*/ uint16(x86_xSetOp), uint16(x86_MOVAPD),
+ /*1812*/ uint16(x86_xReadSlashR),
+ /*1813*/ uint16(x86_xArgXmm2M128),
+ /*1814*/ uint16(x86_xArgXmm1),
+ /*1815*/ uint16(x86_xMatch),
+ /*1816*/ uint16(x86_xCondIs64), 1819, 1873,
+ /*1819*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1857,
+ 0xF2, 1841,
+ 0x66, 1835,
+ 0x0, 1829,
+ /*1829*/ uint16(x86_xSetOp), uint16(x86_CVTPI2PS),
+ /*1831*/ uint16(x86_xReadSlashR),
+ /*1832*/ uint16(x86_xArgXmm),
+ /*1833*/ uint16(x86_xArgMmM64),
+ /*1834*/ uint16(x86_xMatch),
+ /*1835*/ uint16(x86_xSetOp), uint16(x86_CVTPI2PD),
+ /*1837*/ uint16(x86_xReadSlashR),
+ /*1838*/ uint16(x86_xArgXmm),
+ /*1839*/ uint16(x86_xArgMmM64),
+ /*1840*/ uint16(x86_xMatch),
+ /*1841*/ uint16(x86_xCondDataSize), 1845, 1851, 0,
+ /*1845*/ uint16(x86_xSetOp), uint16(x86_CVTSI2SD),
+ /*1847*/ uint16(x86_xReadSlashR),
+ /*1848*/ uint16(x86_xArgXmm),
+ /*1849*/ uint16(x86_xArgRM32),
+ /*1850*/ uint16(x86_xMatch),
+ /*1851*/ uint16(x86_xSetOp), uint16(x86_CVTSI2SD),
+ /*1853*/ uint16(x86_xReadSlashR),
+ /*1854*/ uint16(x86_xArgXmm),
+ /*1855*/ uint16(x86_xArgRM32),
+ /*1856*/ uint16(x86_xMatch),
+ /*1857*/ uint16(x86_xCondDataSize), 1861, 1867, 0,
+ /*1861*/ uint16(x86_xSetOp), uint16(x86_CVTSI2SS),
+ /*1863*/ uint16(x86_xReadSlashR),
+ /*1864*/ uint16(x86_xArgXmm),
+ /*1865*/ uint16(x86_xArgRM32),
+ /*1866*/ uint16(x86_xMatch),
+ /*1867*/ uint16(x86_xSetOp), uint16(x86_CVTSI2SS),
+ /*1869*/ uint16(x86_xReadSlashR),
+ /*1870*/ uint16(x86_xArgXmm),
+ /*1871*/ uint16(x86_xArgRM32),
+ /*1872*/ uint16(x86_xMatch),
+ /*1873*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1893,
+ 0xF2, 1883,
+ 0x66, 1835,
+ 0x0, 1829,
+ /*1883*/ uint16(x86_xCondDataSize), 1845, 1851, 1887,
+ /*1887*/ uint16(x86_xSetOp), uint16(x86_CVTSI2SD),
+ /*1889*/ uint16(x86_xReadSlashR),
+ /*1890*/ uint16(x86_xArgXmm),
+ /*1891*/ uint16(x86_xArgRM64),
+ /*1892*/ uint16(x86_xMatch),
+ /*1893*/ uint16(x86_xCondDataSize), 1861, 1867, 1897,
+ /*1897*/ uint16(x86_xSetOp), uint16(x86_CVTSI2SS),
+ /*1899*/ uint16(x86_xReadSlashR),
+ /*1900*/ uint16(x86_xArgXmm),
+ /*1901*/ uint16(x86_xArgRM64),
+ /*1902*/ uint16(x86_xMatch),
+ /*1903*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1931,
+ 0xF2, 1925,
+ 0x66, 1919,
+ 0x0, 1913,
+ /*1913*/ uint16(x86_xSetOp), uint16(x86_MOVNTPS),
+ /*1915*/ uint16(x86_xReadSlashR),
+ /*1916*/ uint16(x86_xArgM128),
+ /*1917*/ uint16(x86_xArgXmm),
+ /*1918*/ uint16(x86_xMatch),
+ /*1919*/ uint16(x86_xSetOp), uint16(x86_MOVNTPD),
+ /*1921*/ uint16(x86_xReadSlashR),
+ /*1922*/ uint16(x86_xArgM128),
+ /*1923*/ uint16(x86_xArgXmm),
+ /*1924*/ uint16(x86_xMatch),
+ /*1925*/ uint16(x86_xSetOp), uint16(x86_MOVNTSD),
+ /*1927*/ uint16(x86_xReadSlashR),
+ /*1928*/ uint16(x86_xArgM64),
+ /*1929*/ uint16(x86_xArgXmm),
+ /*1930*/ uint16(x86_xMatch),
+ /*1931*/ uint16(x86_xSetOp), uint16(x86_MOVNTSS),
+ /*1933*/ uint16(x86_xReadSlashR),
+ /*1934*/ uint16(x86_xArgM32),
+ /*1935*/ uint16(x86_xArgXmm),
+ /*1936*/ uint16(x86_xMatch),
+ /*1937*/ uint16(x86_xCondIs64), 1940, 1994,
+ /*1940*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 1978,
+ 0xF2, 1962,
+ 0x66, 1956,
+ 0x0, 1950,
+ /*1950*/ uint16(x86_xSetOp), uint16(x86_CVTTPS2PI),
+ /*1952*/ uint16(x86_xReadSlashR),
+ /*1953*/ uint16(x86_xArgMm),
+ /*1954*/ uint16(x86_xArgXmmM64),
+ /*1955*/ uint16(x86_xMatch),
+ /*1956*/ uint16(x86_xSetOp), uint16(x86_CVTTPD2PI),
+ /*1958*/ uint16(x86_xReadSlashR),
+ /*1959*/ uint16(x86_xArgMm),
+ /*1960*/ uint16(x86_xArgXmmM128),
+ /*1961*/ uint16(x86_xMatch),
+ /*1962*/ uint16(x86_xCondDataSize), 1966, 1972, 0,
+ /*1966*/ uint16(x86_xSetOp), uint16(x86_CVTTSD2SI),
+ /*1968*/ uint16(x86_xReadSlashR),
+ /*1969*/ uint16(x86_xArgR32),
+ /*1970*/ uint16(x86_xArgXmmM64),
+ /*1971*/ uint16(x86_xMatch),
+ /*1972*/ uint16(x86_xSetOp), uint16(x86_CVTTSD2SI),
+ /*1974*/ uint16(x86_xReadSlashR),
+ /*1975*/ uint16(x86_xArgR32),
+ /*1976*/ uint16(x86_xArgXmmM64),
+ /*1977*/ uint16(x86_xMatch),
+ /*1978*/ uint16(x86_xCondDataSize), 1982, 1988, 0,
+ /*1982*/ uint16(x86_xSetOp), uint16(x86_CVTTSS2SI),
+ /*1984*/ uint16(x86_xReadSlashR),
+ /*1985*/ uint16(x86_xArgR32),
+ /*1986*/ uint16(x86_xArgXmmM32),
+ /*1987*/ uint16(x86_xMatch),
+ /*1988*/ uint16(x86_xSetOp), uint16(x86_CVTTSS2SI),
+ /*1990*/ uint16(x86_xReadSlashR),
+ /*1991*/ uint16(x86_xArgR32),
+ /*1992*/ uint16(x86_xArgXmmM32),
+ /*1993*/ uint16(x86_xMatch),
+ /*1994*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 2014,
+ 0xF2, 2004,
+ 0x66, 1956,
+ 0x0, 1950,
+ /*2004*/ uint16(x86_xCondDataSize), 1966, 1972, 2008,
+ /*2008*/ uint16(x86_xSetOp), uint16(x86_CVTTSD2SI),
+ /*2010*/ uint16(x86_xReadSlashR),
+ /*2011*/ uint16(x86_xArgR64),
+ /*2012*/ uint16(x86_xArgXmmM64),
+ /*2013*/ uint16(x86_xMatch),
+ /*2014*/ uint16(x86_xCondDataSize), 1982, 1988, 2018,
+ /*2018*/ uint16(x86_xSetOp), uint16(x86_CVTTSS2SI),
+ /*2020*/ uint16(x86_xReadSlashR),
+ /*2021*/ uint16(x86_xArgR64),
+ /*2022*/ uint16(x86_xArgXmmM32),
+ /*2023*/ uint16(x86_xMatch),
+ /*2024*/ uint16(x86_xCondIs64), 2027, 2081,
+ /*2027*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 2065,
+ 0xF2, 2049,
+ 0x66, 2043,
+ 0x0, 2037,
+ /*2037*/ uint16(x86_xSetOp), uint16(x86_CVTPS2PI),
+ /*2039*/ uint16(x86_xReadSlashR),
+ /*2040*/ uint16(x86_xArgMm),
+ /*2041*/ uint16(x86_xArgXmmM64),
+ /*2042*/ uint16(x86_xMatch),
+ /*2043*/ uint16(x86_xSetOp), uint16(x86_CVTPD2PI),
+ /*2045*/ uint16(x86_xReadSlashR),
+ /*2046*/ uint16(x86_xArgMm),
+ /*2047*/ uint16(x86_xArgXmmM128),
+ /*2048*/ uint16(x86_xMatch),
+ /*2049*/ uint16(x86_xCondDataSize), 2053, 2059, 0,
+ /*2053*/ uint16(x86_xSetOp), uint16(x86_CVTSD2SI),
+ /*2055*/ uint16(x86_xReadSlashR),
+ /*2056*/ uint16(x86_xArgR32),
+ /*2057*/ uint16(x86_xArgXmmM64),
+ /*2058*/ uint16(x86_xMatch),
+ /*2059*/ uint16(x86_xSetOp), uint16(x86_CVTSD2SI),
+ /*2061*/ uint16(x86_xReadSlashR),
+ /*2062*/ uint16(x86_xArgR32),
+ /*2063*/ uint16(x86_xArgXmmM64),
+ /*2064*/ uint16(x86_xMatch),
+ /*2065*/ uint16(x86_xCondDataSize), 2069, 2075, 0,
+ /*2069*/ uint16(x86_xSetOp), uint16(x86_CVTSS2SI),
+ /*2071*/ uint16(x86_xReadSlashR),
+ /*2072*/ uint16(x86_xArgR32),
+ /*2073*/ uint16(x86_xArgXmmM32),
+ /*2074*/ uint16(x86_xMatch),
+ /*2075*/ uint16(x86_xSetOp), uint16(x86_CVTSS2SI),
+ /*2077*/ uint16(x86_xReadSlashR),
+ /*2078*/ uint16(x86_xArgR32),
+ /*2079*/ uint16(x86_xArgXmmM32),
+ /*2080*/ uint16(x86_xMatch),
+ /*2081*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 2101,
+ 0xF2, 2091,
+ 0x66, 2043,
+ 0x0, 2037,
+ /*2091*/ uint16(x86_xCondDataSize), 2053, 2059, 2095,
+ /*2095*/ uint16(x86_xSetOp), uint16(x86_CVTSD2SI),
+ /*2097*/ uint16(x86_xReadSlashR),
+ /*2098*/ uint16(x86_xArgR64),
+ /*2099*/ uint16(x86_xArgXmmM64),
+ /*2100*/ uint16(x86_xMatch),
+ /*2101*/ uint16(x86_xCondDataSize), 2069, 2075, 2105,
+ /*2105*/ uint16(x86_xSetOp), uint16(x86_CVTSS2SI),
+ /*2107*/ uint16(x86_xReadSlashR),
+ /*2108*/ uint16(x86_xArgR64),
+ /*2109*/ uint16(x86_xArgXmmM32),
+ /*2110*/ uint16(x86_xMatch),
+ /*2111*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2123,
+ 0x0, 2117,
+ /*2117*/ uint16(x86_xSetOp), uint16(x86_UCOMISS),
+ /*2119*/ uint16(x86_xReadSlashR),
+ /*2120*/ uint16(x86_xArgXmm1),
+ /*2121*/ uint16(x86_xArgXmm2M32),
+ /*2122*/ uint16(x86_xMatch),
+ /*2123*/ uint16(x86_xSetOp), uint16(x86_UCOMISD),
+ /*2125*/ uint16(x86_xReadSlashR),
+ /*2126*/ uint16(x86_xArgXmm1),
+ /*2127*/ uint16(x86_xArgXmm2M64),
+ /*2128*/ uint16(x86_xMatch),
+ /*2129*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2141,
+ 0x0, 2135,
+ /*2135*/ uint16(x86_xSetOp), uint16(x86_COMISS),
+ /*2137*/ uint16(x86_xReadSlashR),
+ /*2138*/ uint16(x86_xArgXmm1),
+ /*2139*/ uint16(x86_xArgXmm2M32),
+ /*2140*/ uint16(x86_xMatch),
+ /*2141*/ uint16(x86_xSetOp), uint16(x86_COMISD),
+ /*2143*/ uint16(x86_xReadSlashR),
+ /*2144*/ uint16(x86_xArgXmm1),
+ /*2145*/ uint16(x86_xArgXmm2M64),
+ /*2146*/ uint16(x86_xMatch),
+ /*2147*/ uint16(x86_xSetOp), uint16(x86_WRMSR),
+ /*2149*/ uint16(x86_xMatch),
+ /*2150*/ uint16(x86_xSetOp), uint16(x86_RDTSC),
+ /*2152*/ uint16(x86_xMatch),
+ /*2153*/ uint16(x86_xSetOp), uint16(x86_RDMSR),
+ /*2155*/ uint16(x86_xMatch),
+ /*2156*/ uint16(x86_xSetOp), uint16(x86_RDPMC),
+ /*2158*/ uint16(x86_xMatch),
+ /*2159*/ uint16(x86_xSetOp), uint16(x86_SYSENTER),
+ /*2161*/ uint16(x86_xMatch),
+ /*2162*/ uint16(x86_xCondDataSize), 2166, 2166, 2169,
+ /*2166*/ uint16(x86_xSetOp), uint16(x86_SYSEXIT),
+ /*2168*/ uint16(x86_xMatch),
+ /*2169*/ uint16(x86_xSetOp), uint16(x86_SYSEXIT),
+ /*2171*/ uint16(x86_xMatch),
+ /*2172*/ uint16(x86_xCondByte), 54,
+ 0x00, 2283,
+ 0x01, 2301,
+ 0x02, 2319,
+ 0x03, 2337,
+ 0x04, 2355,
+ 0x05, 2373,
+ 0x06, 2391,
+ 0x07, 2409,
+ 0x08, 2427,
+ 0x09, 2445,
+ 0x0A, 2463,
+ 0x0B, 2481,
+ 0x10, 2499,
+ 0x14, 2510,
+ 0x15, 2521,
+ 0x17, 2532,
+ 0x1C, 2542,
+ 0x1D, 2560,
+ 0x1E, 2578,
+ 0x20, 2596,
+ 0x21, 2606,
+ 0x22, 2616,
+ 0x23, 2626,
+ 0x24, 2636,
+ 0x25, 2646,
+ 0x28, 2656,
+ 0x29, 2666,
+ 0x2A, 2676,
+ 0x2B, 2686,
+ 0x30, 2696,
+ 0x31, 2706,
+ 0x32, 2716,
+ 0x33, 2726,
+ 0x34, 2736,
+ 0x35, 2746,
+ 0x37, 2756,
+ 0x38, 2766,
+ 0x39, 2776,
+ 0x3A, 2786,
+ 0x3B, 2796,
+ 0x3C, 2806,
+ 0x3D, 2816,
+ 0x3E, 2826,
+ 0x3F, 2836,
+ 0x40, 2846,
+ 0x41, 2856,
+ 0x82, 2866,
+ 0xDB, 2889,
+ 0xDC, 2899,
+ 0xDD, 2909,
+ 0xDE, 2919,
+ 0xDF, 2929,
+ 0xF0, 2939,
+ 0xF1, 3006,
+ uint16(x86_xFail),
+ /*2283*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2295,
+ 0x0, 2289,
+ /*2289*/ uint16(x86_xSetOp), uint16(x86_PSHUFB),
+ /*2291*/ uint16(x86_xReadSlashR),
+ /*2292*/ uint16(x86_xArgMm1),
+ /*2293*/ uint16(x86_xArgMm2M64),
+ /*2294*/ uint16(x86_xMatch),
+ /*2295*/ uint16(x86_xSetOp), uint16(x86_PSHUFB),
+ /*2297*/ uint16(x86_xReadSlashR),
+ /*2298*/ uint16(x86_xArgXmm1),
+ /*2299*/ uint16(x86_xArgXmm2M128),
+ /*2300*/ uint16(x86_xMatch),
+ /*2301*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2313,
+ 0x0, 2307,
+ /*2307*/ uint16(x86_xSetOp), uint16(x86_PHADDW),
+ /*2309*/ uint16(x86_xReadSlashR),
+ /*2310*/ uint16(x86_xArgMm1),
+ /*2311*/ uint16(x86_xArgMm2M64),
+ /*2312*/ uint16(x86_xMatch),
+ /*2313*/ uint16(x86_xSetOp), uint16(x86_PHADDW),
+ /*2315*/ uint16(x86_xReadSlashR),
+ /*2316*/ uint16(x86_xArgXmm1),
+ /*2317*/ uint16(x86_xArgXmm2M128),
+ /*2318*/ uint16(x86_xMatch),
+ /*2319*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2331,
+ 0x0, 2325,
+ /*2325*/ uint16(x86_xSetOp), uint16(x86_PHADDD),
+ /*2327*/ uint16(x86_xReadSlashR),
+ /*2328*/ uint16(x86_xArgMm1),
+ /*2329*/ uint16(x86_xArgMm2M64),
+ /*2330*/ uint16(x86_xMatch),
+ /*2331*/ uint16(x86_xSetOp), uint16(x86_PHADDD),
+ /*2333*/ uint16(x86_xReadSlashR),
+ /*2334*/ uint16(x86_xArgXmm1),
+ /*2335*/ uint16(x86_xArgXmm2M128),
+ /*2336*/ uint16(x86_xMatch),
+ /*2337*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2349,
+ 0x0, 2343,
+ /*2343*/ uint16(x86_xSetOp), uint16(x86_PHADDSW),
+ /*2345*/ uint16(x86_xReadSlashR),
+ /*2346*/ uint16(x86_xArgMm1),
+ /*2347*/ uint16(x86_xArgMm2M64),
+ /*2348*/ uint16(x86_xMatch),
+ /*2349*/ uint16(x86_xSetOp), uint16(x86_PHADDSW),
+ /*2351*/ uint16(x86_xReadSlashR),
+ /*2352*/ uint16(x86_xArgXmm1),
+ /*2353*/ uint16(x86_xArgXmm2M128),
+ /*2354*/ uint16(x86_xMatch),
+ /*2355*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2367,
+ 0x0, 2361,
+ /*2361*/ uint16(x86_xSetOp), uint16(x86_PMADDUBSW),
+ /*2363*/ uint16(x86_xReadSlashR),
+ /*2364*/ uint16(x86_xArgMm1),
+ /*2365*/ uint16(x86_xArgMm2M64),
+ /*2366*/ uint16(x86_xMatch),
+ /*2367*/ uint16(x86_xSetOp), uint16(x86_PMADDUBSW),
+ /*2369*/ uint16(x86_xReadSlashR),
+ /*2370*/ uint16(x86_xArgXmm1),
+ /*2371*/ uint16(x86_xArgXmm2M128),
+ /*2372*/ uint16(x86_xMatch),
+ /*2373*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2385,
+ 0x0, 2379,
+ /*2379*/ uint16(x86_xSetOp), uint16(x86_PHSUBW),
+ /*2381*/ uint16(x86_xReadSlashR),
+ /*2382*/ uint16(x86_xArgMm1),
+ /*2383*/ uint16(x86_xArgMm2M64),
+ /*2384*/ uint16(x86_xMatch),
+ /*2385*/ uint16(x86_xSetOp), uint16(x86_PHSUBW),
+ /*2387*/ uint16(x86_xReadSlashR),
+ /*2388*/ uint16(x86_xArgXmm1),
+ /*2389*/ uint16(x86_xArgXmm2M128),
+ /*2390*/ uint16(x86_xMatch),
+ /*2391*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2403,
+ 0x0, 2397,
+ /*2397*/ uint16(x86_xSetOp), uint16(x86_PHSUBD),
+ /*2399*/ uint16(x86_xReadSlashR),
+ /*2400*/ uint16(x86_xArgMm1),
+ /*2401*/ uint16(x86_xArgMm2M64),
+ /*2402*/ uint16(x86_xMatch),
+ /*2403*/ uint16(x86_xSetOp), uint16(x86_PHSUBD),
+ /*2405*/ uint16(x86_xReadSlashR),
+ /*2406*/ uint16(x86_xArgXmm1),
+ /*2407*/ uint16(x86_xArgXmm2M128),
+ /*2408*/ uint16(x86_xMatch),
+ /*2409*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2421,
+ 0x0, 2415,
+ /*2415*/ uint16(x86_xSetOp), uint16(x86_PHSUBSW),
+ /*2417*/ uint16(x86_xReadSlashR),
+ /*2418*/ uint16(x86_xArgMm1),
+ /*2419*/ uint16(x86_xArgMm2M64),
+ /*2420*/ uint16(x86_xMatch),
+ /*2421*/ uint16(x86_xSetOp), uint16(x86_PHSUBSW),
+ /*2423*/ uint16(x86_xReadSlashR),
+ /*2424*/ uint16(x86_xArgXmm1),
+ /*2425*/ uint16(x86_xArgXmm2M128),
+ /*2426*/ uint16(x86_xMatch),
+ /*2427*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2439,
+ 0x0, 2433,
+ /*2433*/ uint16(x86_xSetOp), uint16(x86_PSIGNB),
+ /*2435*/ uint16(x86_xReadSlashR),
+ /*2436*/ uint16(x86_xArgMm1),
+ /*2437*/ uint16(x86_xArgMm2M64),
+ /*2438*/ uint16(x86_xMatch),
+ /*2439*/ uint16(x86_xSetOp), uint16(x86_PSIGNB),
+ /*2441*/ uint16(x86_xReadSlashR),
+ /*2442*/ uint16(x86_xArgXmm1),
+ /*2443*/ uint16(x86_xArgXmm2M128),
+ /*2444*/ uint16(x86_xMatch),
+ /*2445*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2457,
+ 0x0, 2451,
+ /*2451*/ uint16(x86_xSetOp), uint16(x86_PSIGNW),
+ /*2453*/ uint16(x86_xReadSlashR),
+ /*2454*/ uint16(x86_xArgMm1),
+ /*2455*/ uint16(x86_xArgMm2M64),
+ /*2456*/ uint16(x86_xMatch),
+ /*2457*/ uint16(x86_xSetOp), uint16(x86_PSIGNW),
+ /*2459*/ uint16(x86_xReadSlashR),
+ /*2460*/ uint16(x86_xArgXmm1),
+ /*2461*/ uint16(x86_xArgXmm2M128),
+ /*2462*/ uint16(x86_xMatch),
+ /*2463*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2475,
+ 0x0, 2469,
+ /*2469*/ uint16(x86_xSetOp), uint16(x86_PSIGND),
+ /*2471*/ uint16(x86_xReadSlashR),
+ /*2472*/ uint16(x86_xArgMm1),
+ /*2473*/ uint16(x86_xArgMm2M64),
+ /*2474*/ uint16(x86_xMatch),
+ /*2475*/ uint16(x86_xSetOp), uint16(x86_PSIGND),
+ /*2477*/ uint16(x86_xReadSlashR),
+ /*2478*/ uint16(x86_xArgXmm1),
+ /*2479*/ uint16(x86_xArgXmm2M128),
+ /*2480*/ uint16(x86_xMatch),
+ /*2481*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2493,
+ 0x0, 2487,
+ /*2487*/ uint16(x86_xSetOp), uint16(x86_PMULHRSW),
+ /*2489*/ uint16(x86_xReadSlashR),
+ /*2490*/ uint16(x86_xArgMm1),
+ /*2491*/ uint16(x86_xArgMm2M64),
+ /*2492*/ uint16(x86_xMatch),
+ /*2493*/ uint16(x86_xSetOp), uint16(x86_PMULHRSW),
+ /*2495*/ uint16(x86_xReadSlashR),
+ /*2496*/ uint16(x86_xArgXmm1),
+ /*2497*/ uint16(x86_xArgXmm2M128),
+ /*2498*/ uint16(x86_xMatch),
+ /*2499*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2503,
+ /*2503*/ uint16(x86_xSetOp), uint16(x86_PBLENDVB),
+ /*2505*/ uint16(x86_xReadSlashR),
+ /*2506*/ uint16(x86_xArgXmm1),
+ /*2507*/ uint16(x86_xArgXmm2M128),
+ /*2508*/ uint16(x86_xArgXMM0),
+ /*2509*/ uint16(x86_xMatch),
+ /*2510*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2514,
+ /*2514*/ uint16(x86_xSetOp), uint16(x86_BLENDVPS),
+ /*2516*/ uint16(x86_xReadSlashR),
+ /*2517*/ uint16(x86_xArgXmm1),
+ /*2518*/ uint16(x86_xArgXmm2M128),
+ /*2519*/ uint16(x86_xArgXMM0),
+ /*2520*/ uint16(x86_xMatch),
+ /*2521*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2525,
+ /*2525*/ uint16(x86_xSetOp), uint16(x86_BLENDVPD),
+ /*2527*/ uint16(x86_xReadSlashR),
+ /*2528*/ uint16(x86_xArgXmm1),
+ /*2529*/ uint16(x86_xArgXmm2M128),
+ /*2530*/ uint16(x86_xArgXMM0),
+ /*2531*/ uint16(x86_xMatch),
+ /*2532*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2536,
+ /*2536*/ uint16(x86_xSetOp), uint16(x86_PTEST),
+ /*2538*/ uint16(x86_xReadSlashR),
+ /*2539*/ uint16(x86_xArgXmm1),
+ /*2540*/ uint16(x86_xArgXmm2M128),
+ /*2541*/ uint16(x86_xMatch),
+ /*2542*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2554,
+ 0x0, 2548,
+ /*2548*/ uint16(x86_xSetOp), uint16(x86_PABSB),
+ /*2550*/ uint16(x86_xReadSlashR),
+ /*2551*/ uint16(x86_xArgMm1),
+ /*2552*/ uint16(x86_xArgMm2M64),
+ /*2553*/ uint16(x86_xMatch),
+ /*2554*/ uint16(x86_xSetOp), uint16(x86_PABSB),
+ /*2556*/ uint16(x86_xReadSlashR),
+ /*2557*/ uint16(x86_xArgXmm1),
+ /*2558*/ uint16(x86_xArgXmm2M128),
+ /*2559*/ uint16(x86_xMatch),
+ /*2560*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2572,
+ 0x0, 2566,
+ /*2566*/ uint16(x86_xSetOp), uint16(x86_PABSW),
+ /*2568*/ uint16(x86_xReadSlashR),
+ /*2569*/ uint16(x86_xArgMm1),
+ /*2570*/ uint16(x86_xArgMm2M64),
+ /*2571*/ uint16(x86_xMatch),
+ /*2572*/ uint16(x86_xSetOp), uint16(x86_PABSW),
+ /*2574*/ uint16(x86_xReadSlashR),
+ /*2575*/ uint16(x86_xArgXmm1),
+ /*2576*/ uint16(x86_xArgXmm2M128),
+ /*2577*/ uint16(x86_xMatch),
+ /*2578*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 2590,
+ 0x0, 2584,
+ /*2584*/ uint16(x86_xSetOp), uint16(x86_PABSD),
+ /*2586*/ uint16(x86_xReadSlashR),
+ /*2587*/ uint16(x86_xArgMm1),
+ /*2588*/ uint16(x86_xArgMm2M64),
+ /*2589*/ uint16(x86_xMatch),
+ /*2590*/ uint16(x86_xSetOp), uint16(x86_PABSD),
+ /*2592*/ uint16(x86_xReadSlashR),
+ /*2593*/ uint16(x86_xArgXmm1),
+ /*2594*/ uint16(x86_xArgXmm2M128),
+ /*2595*/ uint16(x86_xMatch),
+ /*2596*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2600,
+ /*2600*/ uint16(x86_xSetOp), uint16(x86_PMOVSXBW),
+ /*2602*/ uint16(x86_xReadSlashR),
+ /*2603*/ uint16(x86_xArgXmm1),
+ /*2604*/ uint16(x86_xArgXmm2M64),
+ /*2605*/ uint16(x86_xMatch),
+ /*2606*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2610,
+ /*2610*/ uint16(x86_xSetOp), uint16(x86_PMOVSXBD),
+ /*2612*/ uint16(x86_xReadSlashR),
+ /*2613*/ uint16(x86_xArgXmm1),
+ /*2614*/ uint16(x86_xArgXmm2M32),
+ /*2615*/ uint16(x86_xMatch),
+ /*2616*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2620,
+ /*2620*/ uint16(x86_xSetOp), uint16(x86_PMOVSXBQ),
+ /*2622*/ uint16(x86_xReadSlashR),
+ /*2623*/ uint16(x86_xArgXmm1),
+ /*2624*/ uint16(x86_xArgXmm2M16),
+ /*2625*/ uint16(x86_xMatch),
+ /*2626*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2630,
+ /*2630*/ uint16(x86_xSetOp), uint16(x86_PMOVSXWD),
+ /*2632*/ uint16(x86_xReadSlashR),
+ /*2633*/ uint16(x86_xArgXmm1),
+ /*2634*/ uint16(x86_xArgXmm2M64),
+ /*2635*/ uint16(x86_xMatch),
+ /*2636*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2640,
+ /*2640*/ uint16(x86_xSetOp), uint16(x86_PMOVSXWQ),
+ /*2642*/ uint16(x86_xReadSlashR),
+ /*2643*/ uint16(x86_xArgXmm1),
+ /*2644*/ uint16(x86_xArgXmm2M32),
+ /*2645*/ uint16(x86_xMatch),
+ /*2646*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2650,
+ /*2650*/ uint16(x86_xSetOp), uint16(x86_PMOVSXDQ),
+ /*2652*/ uint16(x86_xReadSlashR),
+ /*2653*/ uint16(x86_xArgXmm1),
+ /*2654*/ uint16(x86_xArgXmm2M64),
+ /*2655*/ uint16(x86_xMatch),
+ /*2656*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2660,
+ /*2660*/ uint16(x86_xSetOp), uint16(x86_PMULDQ),
+ /*2662*/ uint16(x86_xReadSlashR),
+ /*2663*/ uint16(x86_xArgXmm1),
+ /*2664*/ uint16(x86_xArgXmm2M128),
+ /*2665*/ uint16(x86_xMatch),
+ /*2666*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2670,
+ /*2670*/ uint16(x86_xSetOp), uint16(x86_PCMPEQQ),
+ /*2672*/ uint16(x86_xReadSlashR),
+ /*2673*/ uint16(x86_xArgXmm1),
+ /*2674*/ uint16(x86_xArgXmm2M128),
+ /*2675*/ uint16(x86_xMatch),
+ /*2676*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2680,
+ /*2680*/ uint16(x86_xSetOp), uint16(x86_MOVNTDQA),
+ /*2682*/ uint16(x86_xReadSlashR),
+ /*2683*/ uint16(x86_xArgXmm1),
+ /*2684*/ uint16(x86_xArgM128),
+ /*2685*/ uint16(x86_xMatch),
+ /*2686*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2690,
+ /*2690*/ uint16(x86_xSetOp), uint16(x86_PACKUSDW),
+ /*2692*/ uint16(x86_xReadSlashR),
+ /*2693*/ uint16(x86_xArgXmm1),
+ /*2694*/ uint16(x86_xArgXmm2M128),
+ /*2695*/ uint16(x86_xMatch),
+ /*2696*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2700,
+ /*2700*/ uint16(x86_xSetOp), uint16(x86_PMOVZXBW),
+ /*2702*/ uint16(x86_xReadSlashR),
+ /*2703*/ uint16(x86_xArgXmm1),
+ /*2704*/ uint16(x86_xArgXmm2M64),
+ /*2705*/ uint16(x86_xMatch),
+ /*2706*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2710,
+ /*2710*/ uint16(x86_xSetOp), uint16(x86_PMOVZXBD),
+ /*2712*/ uint16(x86_xReadSlashR),
+ /*2713*/ uint16(x86_xArgXmm1),
+ /*2714*/ uint16(x86_xArgXmm2M32),
+ /*2715*/ uint16(x86_xMatch),
+ /*2716*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2720,
+ /*2720*/ uint16(x86_xSetOp), uint16(x86_PMOVZXBQ),
+ /*2722*/ uint16(x86_xReadSlashR),
+ /*2723*/ uint16(x86_xArgXmm1),
+ /*2724*/ uint16(x86_xArgXmm2M16),
+ /*2725*/ uint16(x86_xMatch),
+ /*2726*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2730,
+ /*2730*/ uint16(x86_xSetOp), uint16(x86_PMOVZXWD),
+ /*2732*/ uint16(x86_xReadSlashR),
+ /*2733*/ uint16(x86_xArgXmm1),
+ /*2734*/ uint16(x86_xArgXmm2M64),
+ /*2735*/ uint16(x86_xMatch),
+ /*2736*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2740,
+ /*2740*/ uint16(x86_xSetOp), uint16(x86_PMOVZXWQ),
+ /*2742*/ uint16(x86_xReadSlashR),
+ /*2743*/ uint16(x86_xArgXmm1),
+ /*2744*/ uint16(x86_xArgXmm2M32),
+ /*2745*/ uint16(x86_xMatch),
+ /*2746*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2750,
+ /*2750*/ uint16(x86_xSetOp), uint16(x86_PMOVZXDQ),
+ /*2752*/ uint16(x86_xReadSlashR),
+ /*2753*/ uint16(x86_xArgXmm1),
+ /*2754*/ uint16(x86_xArgXmm2M64),
+ /*2755*/ uint16(x86_xMatch),
+ /*2756*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2760,
+ /*2760*/ uint16(x86_xSetOp), uint16(x86_PCMPGTQ),
+ /*2762*/ uint16(x86_xReadSlashR),
+ /*2763*/ uint16(x86_xArgXmm1),
+ /*2764*/ uint16(x86_xArgXmm2M128),
+ /*2765*/ uint16(x86_xMatch),
+ /*2766*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2770,
+ /*2770*/ uint16(x86_xSetOp), uint16(x86_PMINSB),
+ /*2772*/ uint16(x86_xReadSlashR),
+ /*2773*/ uint16(x86_xArgXmm1),
+ /*2774*/ uint16(x86_xArgXmm2M128),
+ /*2775*/ uint16(x86_xMatch),
+ /*2776*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2780,
+ /*2780*/ uint16(x86_xSetOp), uint16(x86_PMINSD),
+ /*2782*/ uint16(x86_xReadSlashR),
+ /*2783*/ uint16(x86_xArgXmm1),
+ /*2784*/ uint16(x86_xArgXmm2M128),
+ /*2785*/ uint16(x86_xMatch),
+ /*2786*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2790,
+ /*2790*/ uint16(x86_xSetOp), uint16(x86_PMINUW),
+ /*2792*/ uint16(x86_xReadSlashR),
+ /*2793*/ uint16(x86_xArgXmm1),
+ /*2794*/ uint16(x86_xArgXmm2M128),
+ /*2795*/ uint16(x86_xMatch),
+ /*2796*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2800,
+ /*2800*/ uint16(x86_xSetOp), uint16(x86_PMINUD),
+ /*2802*/ uint16(x86_xReadSlashR),
+ /*2803*/ uint16(x86_xArgXmm1),
+ /*2804*/ uint16(x86_xArgXmm2M128),
+ /*2805*/ uint16(x86_xMatch),
+ /*2806*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2810,
+ /*2810*/ uint16(x86_xSetOp), uint16(x86_PMAXSB),
+ /*2812*/ uint16(x86_xReadSlashR),
+ /*2813*/ uint16(x86_xArgXmm1),
+ /*2814*/ uint16(x86_xArgXmm2M128),
+ /*2815*/ uint16(x86_xMatch),
+ /*2816*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2820,
+ /*2820*/ uint16(x86_xSetOp), uint16(x86_PMAXSD),
+ /*2822*/ uint16(x86_xReadSlashR),
+ /*2823*/ uint16(x86_xArgXmm1),
+ /*2824*/ uint16(x86_xArgXmm2M128),
+ /*2825*/ uint16(x86_xMatch),
+ /*2826*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2830,
+ /*2830*/ uint16(x86_xSetOp), uint16(x86_PMAXUW),
+ /*2832*/ uint16(x86_xReadSlashR),
+ /*2833*/ uint16(x86_xArgXmm1),
+ /*2834*/ uint16(x86_xArgXmm2M128),
+ /*2835*/ uint16(x86_xMatch),
+ /*2836*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2840,
+ /*2840*/ uint16(x86_xSetOp), uint16(x86_PMAXUD),
+ /*2842*/ uint16(x86_xReadSlashR),
+ /*2843*/ uint16(x86_xArgXmm1),
+ /*2844*/ uint16(x86_xArgXmm2M128),
+ /*2845*/ uint16(x86_xMatch),
+ /*2846*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2850,
+ /*2850*/ uint16(x86_xSetOp), uint16(x86_PMULLD),
+ /*2852*/ uint16(x86_xReadSlashR),
+ /*2853*/ uint16(x86_xArgXmm1),
+ /*2854*/ uint16(x86_xArgXmm2M128),
+ /*2855*/ uint16(x86_xMatch),
+ /*2856*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2860,
+ /*2860*/ uint16(x86_xSetOp), uint16(x86_PHMINPOSUW),
+ /*2862*/ uint16(x86_xReadSlashR),
+ /*2863*/ uint16(x86_xArgXmm1),
+ /*2864*/ uint16(x86_xArgXmm2M128),
+ /*2865*/ uint16(x86_xMatch),
+ /*2866*/ uint16(x86_xCondIs64), 2869, 2879,
+ /*2869*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2873,
+ /*2873*/ uint16(x86_xSetOp), uint16(x86_INVPCID),
+ /*2875*/ uint16(x86_xReadSlashR),
+ /*2876*/ uint16(x86_xArgR32),
+ /*2877*/ uint16(x86_xArgM128),
+ /*2878*/ uint16(x86_xMatch),
+ /*2879*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2883,
+ /*2883*/ uint16(x86_xSetOp), uint16(x86_INVPCID),
+ /*2885*/ uint16(x86_xReadSlashR),
+ /*2886*/ uint16(x86_xArgR64),
+ /*2887*/ uint16(x86_xArgM128),
+ /*2888*/ uint16(x86_xMatch),
+ /*2889*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2893,
+ /*2893*/ uint16(x86_xSetOp), uint16(x86_AESIMC),
+ /*2895*/ uint16(x86_xReadSlashR),
+ /*2896*/ uint16(x86_xArgXmm1),
+ /*2897*/ uint16(x86_xArgXmm2M128),
+ /*2898*/ uint16(x86_xMatch),
+ /*2899*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2903,
+ /*2903*/ uint16(x86_xSetOp), uint16(x86_AESENC),
+ /*2905*/ uint16(x86_xReadSlashR),
+ /*2906*/ uint16(x86_xArgXmm1),
+ /*2907*/ uint16(x86_xArgXmm2M128),
+ /*2908*/ uint16(x86_xMatch),
+ /*2909*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2913,
+ /*2913*/ uint16(x86_xSetOp), uint16(x86_AESENCLAST),
+ /*2915*/ uint16(x86_xReadSlashR),
+ /*2916*/ uint16(x86_xArgXmm1),
+ /*2917*/ uint16(x86_xArgXmm2M128),
+ /*2918*/ uint16(x86_xMatch),
+ /*2919*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2923,
+ /*2923*/ uint16(x86_xSetOp), uint16(x86_AESDEC),
+ /*2925*/ uint16(x86_xReadSlashR),
+ /*2926*/ uint16(x86_xArgXmm1),
+ /*2927*/ uint16(x86_xArgXmm2M128),
+ /*2928*/ uint16(x86_xMatch),
+ /*2929*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 2933,
+ /*2933*/ uint16(x86_xSetOp), uint16(x86_AESDECLAST),
+ /*2935*/ uint16(x86_xReadSlashR),
+ /*2936*/ uint16(x86_xArgXmm1),
+ /*2937*/ uint16(x86_xArgXmm2M128),
+ /*2938*/ uint16(x86_xMatch),
+ /*2939*/ uint16(x86_xCondIs64), 2942, 2980,
+ /*2942*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 2964,
+ 0x0, 2948,
+ /*2948*/ uint16(x86_xCondDataSize), 2952, 2958, 0,
+ /*2952*/ uint16(x86_xSetOp), uint16(x86_MOVBE),
+ /*2954*/ uint16(x86_xReadSlashR),
+ /*2955*/ uint16(x86_xArgR16),
+ /*2956*/ uint16(x86_xArgM16),
+ /*2957*/ uint16(x86_xMatch),
+ /*2958*/ uint16(x86_xSetOp), uint16(x86_MOVBE),
+ /*2960*/ uint16(x86_xReadSlashR),
+ /*2961*/ uint16(x86_xArgR32),
+ /*2962*/ uint16(x86_xArgM32),
+ /*2963*/ uint16(x86_xMatch),
+ /*2964*/ uint16(x86_xCondDataSize), 2968, 2974, 0,
+ /*2968*/ uint16(x86_xSetOp), uint16(x86_CRC32),
+ /*2970*/ uint16(x86_xReadSlashR),
+ /*2971*/ uint16(x86_xArgR32),
+ /*2972*/ uint16(x86_xArgRM8),
+ /*2973*/ uint16(x86_xMatch),
+ /*2974*/ uint16(x86_xSetOp), uint16(x86_CRC32),
+ /*2976*/ uint16(x86_xReadSlashR),
+ /*2977*/ uint16(x86_xArgR32),
+ /*2978*/ uint16(x86_xArgRM8),
+ /*2979*/ uint16(x86_xMatch),
+ /*2980*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 2996,
+ 0x0, 2986,
+ /*2986*/ uint16(x86_xCondDataSize), 2952, 2958, 2990,
+ /*2990*/ uint16(x86_xSetOp), uint16(x86_MOVBE),
+ /*2992*/ uint16(x86_xReadSlashR),
+ /*2993*/ uint16(x86_xArgR64),
+ /*2994*/ uint16(x86_xArgM64),
+ /*2995*/ uint16(x86_xMatch),
+ /*2996*/ uint16(x86_xCondDataSize), 2968, 2974, 3000,
+ /*3000*/ uint16(x86_xSetOp), uint16(x86_CRC32),
+ /*3002*/ uint16(x86_xReadSlashR),
+ /*3003*/ uint16(x86_xArgR64),
+ /*3004*/ uint16(x86_xArgRM8),
+ /*3005*/ uint16(x86_xMatch),
+ /*3006*/ uint16(x86_xCondIs64), 3009, 3047,
+ /*3009*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 3031,
+ 0x0, 3015,
+ /*3015*/ uint16(x86_xCondDataSize), 3019, 3025, 0,
+ /*3019*/ uint16(x86_xSetOp), uint16(x86_MOVBE),
+ /*3021*/ uint16(x86_xReadSlashR),
+ /*3022*/ uint16(x86_xArgM16),
+ /*3023*/ uint16(x86_xArgR16),
+ /*3024*/ uint16(x86_xMatch),
+ /*3025*/ uint16(x86_xSetOp), uint16(x86_MOVBE),
+ /*3027*/ uint16(x86_xReadSlashR),
+ /*3028*/ uint16(x86_xArgM32),
+ /*3029*/ uint16(x86_xArgR32),
+ /*3030*/ uint16(x86_xMatch),
+ /*3031*/ uint16(x86_xCondDataSize), 3035, 3041, 0,
+ /*3035*/ uint16(x86_xSetOp), uint16(x86_CRC32),
+ /*3037*/ uint16(x86_xReadSlashR),
+ /*3038*/ uint16(x86_xArgR32),
+ /*3039*/ uint16(x86_xArgRM16),
+ /*3040*/ uint16(x86_xMatch),
+ /*3041*/ uint16(x86_xSetOp), uint16(x86_CRC32),
+ /*3043*/ uint16(x86_xReadSlashR),
+ /*3044*/ uint16(x86_xArgR32),
+ /*3045*/ uint16(x86_xArgRM32),
+ /*3046*/ uint16(x86_xMatch),
+ /*3047*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 3063,
+ 0x0, 3053,
+ /*3053*/ uint16(x86_xCondDataSize), 3019, 3025, 3057,
+ /*3057*/ uint16(x86_xSetOp), uint16(x86_MOVBE),
+ /*3059*/ uint16(x86_xReadSlashR),
+ /*3060*/ uint16(x86_xArgM64),
+ /*3061*/ uint16(x86_xArgR64),
+ /*3062*/ uint16(x86_xMatch),
+ /*3063*/ uint16(x86_xCondDataSize), 3035, 3041, 3067,
+ /*3067*/ uint16(x86_xSetOp), uint16(x86_CRC32),
+ /*3069*/ uint16(x86_xReadSlashR),
+ /*3070*/ uint16(x86_xArgR64),
+ /*3071*/ uint16(x86_xArgRM64),
+ /*3072*/ uint16(x86_xMatch),
+ /*3073*/ uint16(x86_xCondByte), 24,
+ 0x08, 3124,
+ 0x09, 3136,
+ 0x0A, 3148,
+ 0x0B, 3160,
+ 0x0C, 3172,
+ 0x0D, 3184,
+ 0x0E, 3196,
+ 0x0F, 3208,
+ 0x14, 3230,
+ 0x15, 3242,
+ 0x16, 3254,
+ 0x17, 3297,
+ 0x20, 3309,
+ 0x21, 3321,
+ 0x22, 3333,
+ 0x40, 3376,
+ 0x41, 3388,
+ 0x42, 3400,
+ 0x44, 3412,
+ 0x60, 3424,
+ 0x61, 3436,
+ 0x62, 3448,
+ 0x63, 3460,
+ 0xDF, 3472,
+ uint16(x86_xFail),
+ /*3124*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3128,
+ /*3128*/ uint16(x86_xSetOp), uint16(x86_ROUNDPS),
+ /*3130*/ uint16(x86_xReadSlashR),
+ /*3131*/ uint16(x86_xReadIb),
+ /*3132*/ uint16(x86_xArgXmm1),
+ /*3133*/ uint16(x86_xArgXmm2M128),
+ /*3134*/ uint16(x86_xArgImm8u),
+ /*3135*/ uint16(x86_xMatch),
+ /*3136*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3140,
+ /*3140*/ uint16(x86_xSetOp), uint16(x86_ROUNDPD),
+ /*3142*/ uint16(x86_xReadSlashR),
+ /*3143*/ uint16(x86_xReadIb),
+ /*3144*/ uint16(x86_xArgXmm1),
+ /*3145*/ uint16(x86_xArgXmm2M128),
+ /*3146*/ uint16(x86_xArgImm8u),
+ /*3147*/ uint16(x86_xMatch),
+ /*3148*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3152,
+ /*3152*/ uint16(x86_xSetOp), uint16(x86_ROUNDSS),
+ /*3154*/ uint16(x86_xReadSlashR),
+ /*3155*/ uint16(x86_xReadIb),
+ /*3156*/ uint16(x86_xArgXmm1),
+ /*3157*/ uint16(x86_xArgXmm2M32),
+ /*3158*/ uint16(x86_xArgImm8u),
+ /*3159*/ uint16(x86_xMatch),
+ /*3160*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3164,
+ /*3164*/ uint16(x86_xSetOp), uint16(x86_ROUNDSD),
+ /*3166*/ uint16(x86_xReadSlashR),
+ /*3167*/ uint16(x86_xReadIb),
+ /*3168*/ uint16(x86_xArgXmm1),
+ /*3169*/ uint16(x86_xArgXmm2M64),
+ /*3170*/ uint16(x86_xArgImm8u),
+ /*3171*/ uint16(x86_xMatch),
+ /*3172*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3176,
+ /*3176*/ uint16(x86_xSetOp), uint16(x86_BLENDPS),
+ /*3178*/ uint16(x86_xReadSlashR),
+ /*3179*/ uint16(x86_xReadIb),
+ /*3180*/ uint16(x86_xArgXmm1),
+ /*3181*/ uint16(x86_xArgXmm2M128),
+ /*3182*/ uint16(x86_xArgImm8u),
+ /*3183*/ uint16(x86_xMatch),
+ /*3184*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3188,
+ /*3188*/ uint16(x86_xSetOp), uint16(x86_BLENDPD),
+ /*3190*/ uint16(x86_xReadSlashR),
+ /*3191*/ uint16(x86_xReadIb),
+ /*3192*/ uint16(x86_xArgXmm1),
+ /*3193*/ uint16(x86_xArgXmm2M128),
+ /*3194*/ uint16(x86_xArgImm8u),
+ /*3195*/ uint16(x86_xMatch),
+ /*3196*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3200,
+ /*3200*/ uint16(x86_xSetOp), uint16(x86_PBLENDW),
+ /*3202*/ uint16(x86_xReadSlashR),
+ /*3203*/ uint16(x86_xReadIb),
+ /*3204*/ uint16(x86_xArgXmm1),
+ /*3205*/ uint16(x86_xArgXmm2M128),
+ /*3206*/ uint16(x86_xArgImm8u),
+ /*3207*/ uint16(x86_xMatch),
+ /*3208*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 3222,
+ 0x0, 3214,
+ /*3214*/ uint16(x86_xSetOp), uint16(x86_PALIGNR),
+ /*3216*/ uint16(x86_xReadSlashR),
+ /*3217*/ uint16(x86_xReadIb),
+ /*3218*/ uint16(x86_xArgMm1),
+ /*3219*/ uint16(x86_xArgMm2M64),
+ /*3220*/ uint16(x86_xArgImm8u),
+ /*3221*/ uint16(x86_xMatch),
+ /*3222*/ uint16(x86_xSetOp), uint16(x86_PALIGNR),
+ /*3224*/ uint16(x86_xReadSlashR),
+ /*3225*/ uint16(x86_xReadIb),
+ /*3226*/ uint16(x86_xArgXmm1),
+ /*3227*/ uint16(x86_xArgXmm2M128),
+ /*3228*/ uint16(x86_xArgImm8u),
+ /*3229*/ uint16(x86_xMatch),
+ /*3230*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3234,
+ /*3234*/ uint16(x86_xSetOp), uint16(x86_PEXTRB),
+ /*3236*/ uint16(x86_xReadSlashR),
+ /*3237*/ uint16(x86_xReadIb),
+ /*3238*/ uint16(x86_xArgR32M8),
+ /*3239*/ uint16(x86_xArgXmm1),
+ /*3240*/ uint16(x86_xArgImm8u),
+ /*3241*/ uint16(x86_xMatch),
+ /*3242*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3246,
+ /*3246*/ uint16(x86_xSetOp), uint16(x86_PEXTRW),
+ /*3248*/ uint16(x86_xReadSlashR),
+ /*3249*/ uint16(x86_xReadIb),
+ /*3250*/ uint16(x86_xArgR32M16),
+ /*3251*/ uint16(x86_xArgXmm1),
+ /*3252*/ uint16(x86_xArgImm8u),
+ /*3253*/ uint16(x86_xMatch),
+ /*3254*/ uint16(x86_xCondIs64), 3257, 3281,
+ /*3257*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3261,
+ /*3261*/ uint16(x86_xCondDataSize), 3265, 3273, 0,
+ /*3265*/ uint16(x86_xSetOp), uint16(x86_PEXTRD),
+ /*3267*/ uint16(x86_xReadSlashR),
+ /*3268*/ uint16(x86_xReadIb),
+ /*3269*/ uint16(x86_xArgRM32),
+ /*3270*/ uint16(x86_xArgXmm1),
+ /*3271*/ uint16(x86_xArgImm8u),
+ /*3272*/ uint16(x86_xMatch),
+ /*3273*/ uint16(x86_xSetOp), uint16(x86_PEXTRD),
+ /*3275*/ uint16(x86_xReadSlashR),
+ /*3276*/ uint16(x86_xReadIb),
+ /*3277*/ uint16(x86_xArgRM32),
+ /*3278*/ uint16(x86_xArgXmm1),
+ /*3279*/ uint16(x86_xArgImm8u),
+ /*3280*/ uint16(x86_xMatch),
+ /*3281*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3285,
+ /*3285*/ uint16(x86_xCondDataSize), 3265, 3273, 3289,
+ /*3289*/ uint16(x86_xSetOp), uint16(x86_PEXTRQ),
+ /*3291*/ uint16(x86_xReadSlashR),
+ /*3292*/ uint16(x86_xReadIb),
+ /*3293*/ uint16(x86_xArgRM64),
+ /*3294*/ uint16(x86_xArgXmm1),
+ /*3295*/ uint16(x86_xArgImm8u),
+ /*3296*/ uint16(x86_xMatch),
+ /*3297*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3301,
+ /*3301*/ uint16(x86_xSetOp), uint16(x86_EXTRACTPS),
+ /*3303*/ uint16(x86_xReadSlashR),
+ /*3304*/ uint16(x86_xReadIb),
+ /*3305*/ uint16(x86_xArgRM32),
+ /*3306*/ uint16(x86_xArgXmm1),
+ /*3307*/ uint16(x86_xArgImm8u),
+ /*3308*/ uint16(x86_xMatch),
+ /*3309*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3313,
+ /*3313*/ uint16(x86_xSetOp), uint16(x86_PINSRB),
+ /*3315*/ uint16(x86_xReadSlashR),
+ /*3316*/ uint16(x86_xReadIb),
+ /*3317*/ uint16(x86_xArgXmm1),
+ /*3318*/ uint16(x86_xArgR32M8),
+ /*3319*/ uint16(x86_xArgImm8u),
+ /*3320*/ uint16(x86_xMatch),
+ /*3321*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3325,
+ /*3325*/ uint16(x86_xSetOp), uint16(x86_INSERTPS),
+ /*3327*/ uint16(x86_xReadSlashR),
+ /*3328*/ uint16(x86_xReadIb),
+ /*3329*/ uint16(x86_xArgXmm1),
+ /*3330*/ uint16(x86_xArgXmm2M32),
+ /*3331*/ uint16(x86_xArgImm8u),
+ /*3332*/ uint16(x86_xMatch),
+ /*3333*/ uint16(x86_xCondIs64), 3336, 3360,
+ /*3336*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3340,
+ /*3340*/ uint16(x86_xCondDataSize), 3344, 3352, 0,
+ /*3344*/ uint16(x86_xSetOp), uint16(x86_PINSRD),
+ /*3346*/ uint16(x86_xReadSlashR),
+ /*3347*/ uint16(x86_xReadIb),
+ /*3348*/ uint16(x86_xArgXmm1),
+ /*3349*/ uint16(x86_xArgRM32),
+ /*3350*/ uint16(x86_xArgImm8u),
+ /*3351*/ uint16(x86_xMatch),
+ /*3352*/ uint16(x86_xSetOp), uint16(x86_PINSRD),
+ /*3354*/ uint16(x86_xReadSlashR),
+ /*3355*/ uint16(x86_xReadIb),
+ /*3356*/ uint16(x86_xArgXmm1),
+ /*3357*/ uint16(x86_xArgRM32),
+ /*3358*/ uint16(x86_xArgImm8u),
+ /*3359*/ uint16(x86_xMatch),
+ /*3360*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3364,
+ /*3364*/ uint16(x86_xCondDataSize), 3344, 3352, 3368,
+ /*3368*/ uint16(x86_xSetOp), uint16(x86_PINSRQ),
+ /*3370*/ uint16(x86_xReadSlashR),
+ /*3371*/ uint16(x86_xReadIb),
+ /*3372*/ uint16(x86_xArgXmm1),
+ /*3373*/ uint16(x86_xArgRM64),
+ /*3374*/ uint16(x86_xArgImm8u),
+ /*3375*/ uint16(x86_xMatch),
+ /*3376*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3380,
+ /*3380*/ uint16(x86_xSetOp), uint16(x86_DPPS),
+ /*3382*/ uint16(x86_xReadSlashR),
+ /*3383*/ uint16(x86_xReadIb),
+ /*3384*/ uint16(x86_xArgXmm1),
+ /*3385*/ uint16(x86_xArgXmm2M128),
+ /*3386*/ uint16(x86_xArgImm8u),
+ /*3387*/ uint16(x86_xMatch),
+ /*3388*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3392,
+ /*3392*/ uint16(x86_xSetOp), uint16(x86_DPPD),
+ /*3394*/ uint16(x86_xReadSlashR),
+ /*3395*/ uint16(x86_xReadIb),
+ /*3396*/ uint16(x86_xArgXmm1),
+ /*3397*/ uint16(x86_xArgXmm2M128),
+ /*3398*/ uint16(x86_xArgImm8u),
+ /*3399*/ uint16(x86_xMatch),
+ /*3400*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3404,
+ /*3404*/ uint16(x86_xSetOp), uint16(x86_MPSADBW),
+ /*3406*/ uint16(x86_xReadSlashR),
+ /*3407*/ uint16(x86_xReadIb),
+ /*3408*/ uint16(x86_xArgXmm1),
+ /*3409*/ uint16(x86_xArgXmm2M128),
+ /*3410*/ uint16(x86_xArgImm8u),
+ /*3411*/ uint16(x86_xMatch),
+ /*3412*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3416,
+ /*3416*/ uint16(x86_xSetOp), uint16(x86_PCLMULQDQ),
+ /*3418*/ uint16(x86_xReadSlashR),
+ /*3419*/ uint16(x86_xReadIb),
+ /*3420*/ uint16(x86_xArgXmm1),
+ /*3421*/ uint16(x86_xArgXmm2M128),
+ /*3422*/ uint16(x86_xArgImm8u),
+ /*3423*/ uint16(x86_xMatch),
+ /*3424*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3428,
+ /*3428*/ uint16(x86_xSetOp), uint16(x86_PCMPESTRM),
+ /*3430*/ uint16(x86_xReadSlashR),
+ /*3431*/ uint16(x86_xReadIb),
+ /*3432*/ uint16(x86_xArgXmm1),
+ /*3433*/ uint16(x86_xArgXmm2M128),
+ /*3434*/ uint16(x86_xArgImm8u),
+ /*3435*/ uint16(x86_xMatch),
+ /*3436*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3440,
+ /*3440*/ uint16(x86_xSetOp), uint16(x86_PCMPESTRI),
+ /*3442*/ uint16(x86_xReadSlashR),
+ /*3443*/ uint16(x86_xReadIb),
+ /*3444*/ uint16(x86_xArgXmm1),
+ /*3445*/ uint16(x86_xArgXmm2M128),
+ /*3446*/ uint16(x86_xArgImm8u),
+ /*3447*/ uint16(x86_xMatch),
+ /*3448*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3452,
+ /*3452*/ uint16(x86_xSetOp), uint16(x86_PCMPISTRM),
+ /*3454*/ uint16(x86_xReadSlashR),
+ /*3455*/ uint16(x86_xReadIb),
+ /*3456*/ uint16(x86_xArgXmm1),
+ /*3457*/ uint16(x86_xArgXmm2M128),
+ /*3458*/ uint16(x86_xArgImm8u),
+ /*3459*/ uint16(x86_xMatch),
+ /*3460*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3464,
+ /*3464*/ uint16(x86_xSetOp), uint16(x86_PCMPISTRI),
+ /*3466*/ uint16(x86_xReadSlashR),
+ /*3467*/ uint16(x86_xReadIb),
+ /*3468*/ uint16(x86_xArgXmm1),
+ /*3469*/ uint16(x86_xArgXmm2M128),
+ /*3470*/ uint16(x86_xArgImm8u),
+ /*3471*/ uint16(x86_xMatch),
+ /*3472*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 3476,
+ /*3476*/ uint16(x86_xSetOp), uint16(x86_AESKEYGENASSIST),
+ /*3478*/ uint16(x86_xReadSlashR),
+ /*3479*/ uint16(x86_xReadIb),
+ /*3480*/ uint16(x86_xArgXmm1),
+ /*3481*/ uint16(x86_xArgXmm2M128),
+ /*3482*/ uint16(x86_xArgImm8u),
+ /*3483*/ uint16(x86_xMatch),
+ /*3484*/ uint16(x86_xCondIs64), 3487, 3503,
+ /*3487*/ uint16(x86_xCondDataSize), 3491, 3497, 0,
+ /*3491*/ uint16(x86_xSetOp), uint16(x86_CMOVO),
+ /*3493*/ uint16(x86_xReadSlashR),
+ /*3494*/ uint16(x86_xArgR16),
+ /*3495*/ uint16(x86_xArgRM16),
+ /*3496*/ uint16(x86_xMatch),
+ /*3497*/ uint16(x86_xSetOp), uint16(x86_CMOVO),
+ /*3499*/ uint16(x86_xReadSlashR),
+ /*3500*/ uint16(x86_xArgR32),
+ /*3501*/ uint16(x86_xArgRM32),
+ /*3502*/ uint16(x86_xMatch),
+ /*3503*/ uint16(x86_xCondDataSize), 3491, 3497, 3507,
+ /*3507*/ uint16(x86_xSetOp), uint16(x86_CMOVO),
+ /*3509*/ uint16(x86_xReadSlashR),
+ /*3510*/ uint16(x86_xArgR64),
+ /*3511*/ uint16(x86_xArgRM64),
+ /*3512*/ uint16(x86_xMatch),
+ /*3513*/ uint16(x86_xCondIs64), 3516, 3532,
+ /*3516*/ uint16(x86_xCondDataSize), 3520, 3526, 0,
+ /*3520*/ uint16(x86_xSetOp), uint16(x86_CMOVNO),
+ /*3522*/ uint16(x86_xReadSlashR),
+ /*3523*/ uint16(x86_xArgR16),
+ /*3524*/ uint16(x86_xArgRM16),
+ /*3525*/ uint16(x86_xMatch),
+ /*3526*/ uint16(x86_xSetOp), uint16(x86_CMOVNO),
+ /*3528*/ uint16(x86_xReadSlashR),
+ /*3529*/ uint16(x86_xArgR32),
+ /*3530*/ uint16(x86_xArgRM32),
+ /*3531*/ uint16(x86_xMatch),
+ /*3532*/ uint16(x86_xCondDataSize), 3520, 3526, 3536,
+ /*3536*/ uint16(x86_xSetOp), uint16(x86_CMOVNO),
+ /*3538*/ uint16(x86_xReadSlashR),
+ /*3539*/ uint16(x86_xArgR64),
+ /*3540*/ uint16(x86_xArgRM64),
+ /*3541*/ uint16(x86_xMatch),
+ /*3542*/ uint16(x86_xCondIs64), 3545, 3561,
+ /*3545*/ uint16(x86_xCondDataSize), 3549, 3555, 0,
+ /*3549*/ uint16(x86_xSetOp), uint16(x86_CMOVB),
+ /*3551*/ uint16(x86_xReadSlashR),
+ /*3552*/ uint16(x86_xArgR16),
+ /*3553*/ uint16(x86_xArgRM16),
+ /*3554*/ uint16(x86_xMatch),
+ /*3555*/ uint16(x86_xSetOp), uint16(x86_CMOVB),
+ /*3557*/ uint16(x86_xReadSlashR),
+ /*3558*/ uint16(x86_xArgR32),
+ /*3559*/ uint16(x86_xArgRM32),
+ /*3560*/ uint16(x86_xMatch),
+ /*3561*/ uint16(x86_xCondDataSize), 3549, 3555, 3565,
+ /*3565*/ uint16(x86_xSetOp), uint16(x86_CMOVB),
+ /*3567*/ uint16(x86_xReadSlashR),
+ /*3568*/ uint16(x86_xArgR64),
+ /*3569*/ uint16(x86_xArgRM64),
+ /*3570*/ uint16(x86_xMatch),
+ /*3571*/ uint16(x86_xCondIs64), 3574, 3590,
+ /*3574*/ uint16(x86_xCondDataSize), 3578, 3584, 0,
+ /*3578*/ uint16(x86_xSetOp), uint16(x86_CMOVAE),
+ /*3580*/ uint16(x86_xReadSlashR),
+ /*3581*/ uint16(x86_xArgR16),
+ /*3582*/ uint16(x86_xArgRM16),
+ /*3583*/ uint16(x86_xMatch),
+ /*3584*/ uint16(x86_xSetOp), uint16(x86_CMOVAE),
+ /*3586*/ uint16(x86_xReadSlashR),
+ /*3587*/ uint16(x86_xArgR32),
+ /*3588*/ uint16(x86_xArgRM32),
+ /*3589*/ uint16(x86_xMatch),
+ /*3590*/ uint16(x86_xCondDataSize), 3578, 3584, 3594,
+ /*3594*/ uint16(x86_xSetOp), uint16(x86_CMOVAE),
+ /*3596*/ uint16(x86_xReadSlashR),
+ /*3597*/ uint16(x86_xArgR64),
+ /*3598*/ uint16(x86_xArgRM64),
+ /*3599*/ uint16(x86_xMatch),
+ /*3600*/ uint16(x86_xCondIs64), 3603, 3619,
+ /*3603*/ uint16(x86_xCondDataSize), 3607, 3613, 0,
+ /*3607*/ uint16(x86_xSetOp), uint16(x86_CMOVE),
+ /*3609*/ uint16(x86_xReadSlashR),
+ /*3610*/ uint16(x86_xArgR16),
+ /*3611*/ uint16(x86_xArgRM16),
+ /*3612*/ uint16(x86_xMatch),
+ /*3613*/ uint16(x86_xSetOp), uint16(x86_CMOVE),
+ /*3615*/ uint16(x86_xReadSlashR),
+ /*3616*/ uint16(x86_xArgR32),
+ /*3617*/ uint16(x86_xArgRM32),
+ /*3618*/ uint16(x86_xMatch),
+ /*3619*/ uint16(x86_xCondDataSize), 3607, 3613, 3623,
+ /*3623*/ uint16(x86_xSetOp), uint16(x86_CMOVE),
+ /*3625*/ uint16(x86_xReadSlashR),
+ /*3626*/ uint16(x86_xArgR64),
+ /*3627*/ uint16(x86_xArgRM64),
+ /*3628*/ uint16(x86_xMatch),
+ /*3629*/ uint16(x86_xCondIs64), 3632, 3648,
+ /*3632*/ uint16(x86_xCondDataSize), 3636, 3642, 0,
+ /*3636*/ uint16(x86_xSetOp), uint16(x86_CMOVNE),
+ /*3638*/ uint16(x86_xReadSlashR),
+ /*3639*/ uint16(x86_xArgR16),
+ /*3640*/ uint16(x86_xArgRM16),
+ /*3641*/ uint16(x86_xMatch),
+ /*3642*/ uint16(x86_xSetOp), uint16(x86_CMOVNE),
+ /*3644*/ uint16(x86_xReadSlashR),
+ /*3645*/ uint16(x86_xArgR32),
+ /*3646*/ uint16(x86_xArgRM32),
+ /*3647*/ uint16(x86_xMatch),
+ /*3648*/ uint16(x86_xCondDataSize), 3636, 3642, 3652,
+ /*3652*/ uint16(x86_xSetOp), uint16(x86_CMOVNE),
+ /*3654*/ uint16(x86_xReadSlashR),
+ /*3655*/ uint16(x86_xArgR64),
+ /*3656*/ uint16(x86_xArgRM64),
+ /*3657*/ uint16(x86_xMatch),
+ /*3658*/ uint16(x86_xCondIs64), 3661, 3677,
+ /*3661*/ uint16(x86_xCondDataSize), 3665, 3671, 0,
+ /*3665*/ uint16(x86_xSetOp), uint16(x86_CMOVBE),
+ /*3667*/ uint16(x86_xReadSlashR),
+ /*3668*/ uint16(x86_xArgR16),
+ /*3669*/ uint16(x86_xArgRM16),
+ /*3670*/ uint16(x86_xMatch),
+ /*3671*/ uint16(x86_xSetOp), uint16(x86_CMOVBE),
+ /*3673*/ uint16(x86_xReadSlashR),
+ /*3674*/ uint16(x86_xArgR32),
+ /*3675*/ uint16(x86_xArgRM32),
+ /*3676*/ uint16(x86_xMatch),
+ /*3677*/ uint16(x86_xCondDataSize), 3665, 3671, 3681,
+ /*3681*/ uint16(x86_xSetOp), uint16(x86_CMOVBE),
+ /*3683*/ uint16(x86_xReadSlashR),
+ /*3684*/ uint16(x86_xArgR64),
+ /*3685*/ uint16(x86_xArgRM64),
+ /*3686*/ uint16(x86_xMatch),
+ /*3687*/ uint16(x86_xCondIs64), 3690, 3706,
+ /*3690*/ uint16(x86_xCondDataSize), 3694, 3700, 0,
+ /*3694*/ uint16(x86_xSetOp), uint16(x86_CMOVA),
+ /*3696*/ uint16(x86_xReadSlashR),
+ /*3697*/ uint16(x86_xArgR16),
+ /*3698*/ uint16(x86_xArgRM16),
+ /*3699*/ uint16(x86_xMatch),
+ /*3700*/ uint16(x86_xSetOp), uint16(x86_CMOVA),
+ /*3702*/ uint16(x86_xReadSlashR),
+ /*3703*/ uint16(x86_xArgR32),
+ /*3704*/ uint16(x86_xArgRM32),
+ /*3705*/ uint16(x86_xMatch),
+ /*3706*/ uint16(x86_xCondDataSize), 3694, 3700, 3710,
+ /*3710*/ uint16(x86_xSetOp), uint16(x86_CMOVA),
+ /*3712*/ uint16(x86_xReadSlashR),
+ /*3713*/ uint16(x86_xArgR64),
+ /*3714*/ uint16(x86_xArgRM64),
+ /*3715*/ uint16(x86_xMatch),
+ /*3716*/ uint16(x86_xCondIs64), 3719, 3735,
+ /*3719*/ uint16(x86_xCondDataSize), 3723, 3729, 0,
+ /*3723*/ uint16(x86_xSetOp), uint16(x86_CMOVS),
+ /*3725*/ uint16(x86_xReadSlashR),
+ /*3726*/ uint16(x86_xArgR16),
+ /*3727*/ uint16(x86_xArgRM16),
+ /*3728*/ uint16(x86_xMatch),
+ /*3729*/ uint16(x86_xSetOp), uint16(x86_CMOVS),
+ /*3731*/ uint16(x86_xReadSlashR),
+ /*3732*/ uint16(x86_xArgR32),
+ /*3733*/ uint16(x86_xArgRM32),
+ /*3734*/ uint16(x86_xMatch),
+ /*3735*/ uint16(x86_xCondDataSize), 3723, 3729, 3739,
+ /*3739*/ uint16(x86_xSetOp), uint16(x86_CMOVS),
+ /*3741*/ uint16(x86_xReadSlashR),
+ /*3742*/ uint16(x86_xArgR64),
+ /*3743*/ uint16(x86_xArgRM64),
+ /*3744*/ uint16(x86_xMatch),
+ /*3745*/ uint16(x86_xCondIs64), 3748, 3764,
+ /*3748*/ uint16(x86_xCondDataSize), 3752, 3758, 0,
+ /*3752*/ uint16(x86_xSetOp), uint16(x86_CMOVNS),
+ /*3754*/ uint16(x86_xReadSlashR),
+ /*3755*/ uint16(x86_xArgR16),
+ /*3756*/ uint16(x86_xArgRM16),
+ /*3757*/ uint16(x86_xMatch),
+ /*3758*/ uint16(x86_xSetOp), uint16(x86_CMOVNS),
+ /*3760*/ uint16(x86_xReadSlashR),
+ /*3761*/ uint16(x86_xArgR32),
+ /*3762*/ uint16(x86_xArgRM32),
+ /*3763*/ uint16(x86_xMatch),
+ /*3764*/ uint16(x86_xCondDataSize), 3752, 3758, 3768,
+ /*3768*/ uint16(x86_xSetOp), uint16(x86_CMOVNS),
+ /*3770*/ uint16(x86_xReadSlashR),
+ /*3771*/ uint16(x86_xArgR64),
+ /*3772*/ uint16(x86_xArgRM64),
+ /*3773*/ uint16(x86_xMatch),
+ /*3774*/ uint16(x86_xCondIs64), 3777, 3793,
+ /*3777*/ uint16(x86_xCondDataSize), 3781, 3787, 0,
+ /*3781*/ uint16(x86_xSetOp), uint16(x86_CMOVP),
+ /*3783*/ uint16(x86_xReadSlashR),
+ /*3784*/ uint16(x86_xArgR16),
+ /*3785*/ uint16(x86_xArgRM16),
+ /*3786*/ uint16(x86_xMatch),
+ /*3787*/ uint16(x86_xSetOp), uint16(x86_CMOVP),
+ /*3789*/ uint16(x86_xReadSlashR),
+ /*3790*/ uint16(x86_xArgR32),
+ /*3791*/ uint16(x86_xArgRM32),
+ /*3792*/ uint16(x86_xMatch),
+ /*3793*/ uint16(x86_xCondDataSize), 3781, 3787, 3797,
+ /*3797*/ uint16(x86_xSetOp), uint16(x86_CMOVP),
+ /*3799*/ uint16(x86_xReadSlashR),
+ /*3800*/ uint16(x86_xArgR64),
+ /*3801*/ uint16(x86_xArgRM64),
+ /*3802*/ uint16(x86_xMatch),
+ /*3803*/ uint16(x86_xCondIs64), 3806, 3822,
+ /*3806*/ uint16(x86_xCondDataSize), 3810, 3816, 0,
+ /*3810*/ uint16(x86_xSetOp), uint16(x86_CMOVNP),
+ /*3812*/ uint16(x86_xReadSlashR),
+ /*3813*/ uint16(x86_xArgR16),
+ /*3814*/ uint16(x86_xArgRM16),
+ /*3815*/ uint16(x86_xMatch),
+ /*3816*/ uint16(x86_xSetOp), uint16(x86_CMOVNP),
+ /*3818*/ uint16(x86_xReadSlashR),
+ /*3819*/ uint16(x86_xArgR32),
+ /*3820*/ uint16(x86_xArgRM32),
+ /*3821*/ uint16(x86_xMatch),
+ /*3822*/ uint16(x86_xCondDataSize), 3810, 3816, 3826,
+ /*3826*/ uint16(x86_xSetOp), uint16(x86_CMOVNP),
+ /*3828*/ uint16(x86_xReadSlashR),
+ /*3829*/ uint16(x86_xArgR64),
+ /*3830*/ uint16(x86_xArgRM64),
+ /*3831*/ uint16(x86_xMatch),
+ /*3832*/ uint16(x86_xCondIs64), 3835, 3851,
+ /*3835*/ uint16(x86_xCondDataSize), 3839, 3845, 0,
+ /*3839*/ uint16(x86_xSetOp), uint16(x86_CMOVL),
+ /*3841*/ uint16(x86_xReadSlashR),
+ /*3842*/ uint16(x86_xArgR16),
+ /*3843*/ uint16(x86_xArgRM16),
+ /*3844*/ uint16(x86_xMatch),
+ /*3845*/ uint16(x86_xSetOp), uint16(x86_CMOVL),
+ /*3847*/ uint16(x86_xReadSlashR),
+ /*3848*/ uint16(x86_xArgR32),
+ /*3849*/ uint16(x86_xArgRM32),
+ /*3850*/ uint16(x86_xMatch),
+ /*3851*/ uint16(x86_xCondDataSize), 3839, 3845, 3855,
+ /*3855*/ uint16(x86_xSetOp), uint16(x86_CMOVL),
+ /*3857*/ uint16(x86_xReadSlashR),
+ /*3858*/ uint16(x86_xArgR64),
+ /*3859*/ uint16(x86_xArgRM64),
+ /*3860*/ uint16(x86_xMatch),
+ /*3861*/ uint16(x86_xCondIs64), 3864, 3880,
+ /*3864*/ uint16(x86_xCondDataSize), 3868, 3874, 0,
+ /*3868*/ uint16(x86_xSetOp), uint16(x86_CMOVGE),
+ /*3870*/ uint16(x86_xReadSlashR),
+ /*3871*/ uint16(x86_xArgR16),
+ /*3872*/ uint16(x86_xArgRM16),
+ /*3873*/ uint16(x86_xMatch),
+ /*3874*/ uint16(x86_xSetOp), uint16(x86_CMOVGE),
+ /*3876*/ uint16(x86_xReadSlashR),
+ /*3877*/ uint16(x86_xArgR32),
+ /*3878*/ uint16(x86_xArgRM32),
+ /*3879*/ uint16(x86_xMatch),
+ /*3880*/ uint16(x86_xCondDataSize), 3868, 3874, 3884,
+ /*3884*/ uint16(x86_xSetOp), uint16(x86_CMOVGE),
+ /*3886*/ uint16(x86_xReadSlashR),
+ /*3887*/ uint16(x86_xArgR64),
+ /*3888*/ uint16(x86_xArgRM64),
+ /*3889*/ uint16(x86_xMatch),
+ /*3890*/ uint16(x86_xCondIs64), 3893, 3909,
+ /*3893*/ uint16(x86_xCondDataSize), 3897, 3903, 0,
+ /*3897*/ uint16(x86_xSetOp), uint16(x86_CMOVLE),
+ /*3899*/ uint16(x86_xReadSlashR),
+ /*3900*/ uint16(x86_xArgR16),
+ /*3901*/ uint16(x86_xArgRM16),
+ /*3902*/ uint16(x86_xMatch),
+ /*3903*/ uint16(x86_xSetOp), uint16(x86_CMOVLE),
+ /*3905*/ uint16(x86_xReadSlashR),
+ /*3906*/ uint16(x86_xArgR32),
+ /*3907*/ uint16(x86_xArgRM32),
+ /*3908*/ uint16(x86_xMatch),
+ /*3909*/ uint16(x86_xCondDataSize), 3897, 3903, 3913,
+ /*3913*/ uint16(x86_xSetOp), uint16(x86_CMOVLE),
+ /*3915*/ uint16(x86_xReadSlashR),
+ /*3916*/ uint16(x86_xArgR64),
+ /*3917*/ uint16(x86_xArgRM64),
+ /*3918*/ uint16(x86_xMatch),
+ /*3919*/ uint16(x86_xCondIs64), 3922, 3938,
+ /*3922*/ uint16(x86_xCondDataSize), 3926, 3932, 0,
+ /*3926*/ uint16(x86_xSetOp), uint16(x86_CMOVG),
+ /*3928*/ uint16(x86_xReadSlashR),
+ /*3929*/ uint16(x86_xArgR16),
+ /*3930*/ uint16(x86_xArgRM16),
+ /*3931*/ uint16(x86_xMatch),
+ /*3932*/ uint16(x86_xSetOp), uint16(x86_CMOVG),
+ /*3934*/ uint16(x86_xReadSlashR),
+ /*3935*/ uint16(x86_xArgR32),
+ /*3936*/ uint16(x86_xArgRM32),
+ /*3937*/ uint16(x86_xMatch),
+ /*3938*/ uint16(x86_xCondDataSize), 3926, 3932, 3942,
+ /*3942*/ uint16(x86_xSetOp), uint16(x86_CMOVG),
+ /*3944*/ uint16(x86_xReadSlashR),
+ /*3945*/ uint16(x86_xArgR64),
+ /*3946*/ uint16(x86_xArgRM64),
+ /*3947*/ uint16(x86_xMatch),
+ /*3948*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 3960,
+ 0x0, 3954,
+ /*3954*/ uint16(x86_xSetOp), uint16(x86_MOVMSKPS),
+ /*3956*/ uint16(x86_xReadSlashR),
+ /*3957*/ uint16(x86_xArgR32),
+ /*3958*/ uint16(x86_xArgXmm2),
+ /*3959*/ uint16(x86_xMatch),
+ /*3960*/ uint16(x86_xSetOp), uint16(x86_MOVMSKPD),
+ /*3962*/ uint16(x86_xReadSlashR),
+ /*3963*/ uint16(x86_xArgR32),
+ /*3964*/ uint16(x86_xArgXmm2),
+ /*3965*/ uint16(x86_xMatch),
+ /*3966*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 3994,
+ 0xF2, 3988,
+ 0x66, 3982,
+ 0x0, 3976,
+ /*3976*/ uint16(x86_xSetOp), uint16(x86_SQRTPS),
+ /*3978*/ uint16(x86_xReadSlashR),
+ /*3979*/ uint16(x86_xArgXmm1),
+ /*3980*/ uint16(x86_xArgXmm2M128),
+ /*3981*/ uint16(x86_xMatch),
+ /*3982*/ uint16(x86_xSetOp), uint16(x86_SQRTPD),
+ /*3984*/ uint16(x86_xReadSlashR),
+ /*3985*/ uint16(x86_xArgXmm1),
+ /*3986*/ uint16(x86_xArgXmm2M128),
+ /*3987*/ uint16(x86_xMatch),
+ /*3988*/ uint16(x86_xSetOp), uint16(x86_SQRTSD),
+ /*3990*/ uint16(x86_xReadSlashR),
+ /*3991*/ uint16(x86_xArgXmm1),
+ /*3992*/ uint16(x86_xArgXmm2M64),
+ /*3993*/ uint16(x86_xMatch),
+ /*3994*/ uint16(x86_xSetOp), uint16(x86_SQRTSS),
+ /*3996*/ uint16(x86_xReadSlashR),
+ /*3997*/ uint16(x86_xArgXmm1),
+ /*3998*/ uint16(x86_xArgXmm2M32),
+ /*3999*/ uint16(x86_xMatch),
+ /*4000*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 4012,
+ 0x0, 4006,
+ /*4006*/ uint16(x86_xSetOp), uint16(x86_RSQRTPS),
+ /*4008*/ uint16(x86_xReadSlashR),
+ /*4009*/ uint16(x86_xArgXmm1),
+ /*4010*/ uint16(x86_xArgXmm2M128),
+ /*4011*/ uint16(x86_xMatch),
+ /*4012*/ uint16(x86_xSetOp), uint16(x86_RSQRTSS),
+ /*4014*/ uint16(x86_xReadSlashR),
+ /*4015*/ uint16(x86_xArgXmm1),
+ /*4016*/ uint16(x86_xArgXmm2M32),
+ /*4017*/ uint16(x86_xMatch),
+ /*4018*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 4030,
+ 0x0, 4024,
+ /*4024*/ uint16(x86_xSetOp), uint16(x86_RCPPS),
+ /*4026*/ uint16(x86_xReadSlashR),
+ /*4027*/ uint16(x86_xArgXmm1),
+ /*4028*/ uint16(x86_xArgXmm2M128),
+ /*4029*/ uint16(x86_xMatch),
+ /*4030*/ uint16(x86_xSetOp), uint16(x86_RCPSS),
+ /*4032*/ uint16(x86_xReadSlashR),
+ /*4033*/ uint16(x86_xArgXmm1),
+ /*4034*/ uint16(x86_xArgXmm2M32),
+ /*4035*/ uint16(x86_xMatch),
+ /*4036*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4048,
+ 0x0, 4042,
+ /*4042*/ uint16(x86_xSetOp), uint16(x86_ANDPS),
+ /*4044*/ uint16(x86_xReadSlashR),
+ /*4045*/ uint16(x86_xArgXmm1),
+ /*4046*/ uint16(x86_xArgXmm2M128),
+ /*4047*/ uint16(x86_xMatch),
+ /*4048*/ uint16(x86_xSetOp), uint16(x86_ANDPD),
+ /*4050*/ uint16(x86_xReadSlashR),
+ /*4051*/ uint16(x86_xArgXmm1),
+ /*4052*/ uint16(x86_xArgXmm2M128),
+ /*4053*/ uint16(x86_xMatch),
+ /*4054*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4066,
+ 0x0, 4060,
+ /*4060*/ uint16(x86_xSetOp), uint16(x86_ANDNPS),
+ /*4062*/ uint16(x86_xReadSlashR),
+ /*4063*/ uint16(x86_xArgXmm1),
+ /*4064*/ uint16(x86_xArgXmm2M128),
+ /*4065*/ uint16(x86_xMatch),
+ /*4066*/ uint16(x86_xSetOp), uint16(x86_ANDNPD),
+ /*4068*/ uint16(x86_xReadSlashR),
+ /*4069*/ uint16(x86_xArgXmm1),
+ /*4070*/ uint16(x86_xArgXmm2M128),
+ /*4071*/ uint16(x86_xMatch),
+ /*4072*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4084,
+ 0x0, 4078,
+ /*4078*/ uint16(x86_xSetOp), uint16(x86_ORPS),
+ /*4080*/ uint16(x86_xReadSlashR),
+ /*4081*/ uint16(x86_xArgXmm1),
+ /*4082*/ uint16(x86_xArgXmm2M128),
+ /*4083*/ uint16(x86_xMatch),
+ /*4084*/ uint16(x86_xSetOp), uint16(x86_ORPD),
+ /*4086*/ uint16(x86_xReadSlashR),
+ /*4087*/ uint16(x86_xArgXmm1),
+ /*4088*/ uint16(x86_xArgXmm2M128),
+ /*4089*/ uint16(x86_xMatch),
+ /*4090*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4102,
+ 0x0, 4096,
+ /*4096*/ uint16(x86_xSetOp), uint16(x86_XORPS),
+ /*4098*/ uint16(x86_xReadSlashR),
+ /*4099*/ uint16(x86_xArgXmm1),
+ /*4100*/ uint16(x86_xArgXmm2M128),
+ /*4101*/ uint16(x86_xMatch),
+ /*4102*/ uint16(x86_xSetOp), uint16(x86_XORPD),
+ /*4104*/ uint16(x86_xReadSlashR),
+ /*4105*/ uint16(x86_xArgXmm1),
+ /*4106*/ uint16(x86_xArgXmm2M128),
+ /*4107*/ uint16(x86_xMatch),
+ /*4108*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4136,
+ 0xF2, 4130,
+ 0x66, 4124,
+ 0x0, 4118,
+ /*4118*/ uint16(x86_xSetOp), uint16(x86_ADDPS),
+ /*4120*/ uint16(x86_xReadSlashR),
+ /*4121*/ uint16(x86_xArgXmm1),
+ /*4122*/ uint16(x86_xArgXmm2M128),
+ /*4123*/ uint16(x86_xMatch),
+ /*4124*/ uint16(x86_xSetOp), uint16(x86_ADDPD),
+ /*4126*/ uint16(x86_xReadSlashR),
+ /*4127*/ uint16(x86_xArgXmm1),
+ /*4128*/ uint16(x86_xArgXmm2M128),
+ /*4129*/ uint16(x86_xMatch),
+ /*4130*/ uint16(x86_xSetOp), uint16(x86_ADDSD),
+ /*4132*/ uint16(x86_xReadSlashR),
+ /*4133*/ uint16(x86_xArgXmm1),
+ /*4134*/ uint16(x86_xArgXmm2M64),
+ /*4135*/ uint16(x86_xMatch),
+ /*4136*/ uint16(x86_xSetOp), uint16(x86_ADDSS),
+ /*4138*/ uint16(x86_xReadSlashR),
+ /*4139*/ uint16(x86_xArgXmm1),
+ /*4140*/ uint16(x86_xArgXmm2M32),
+ /*4141*/ uint16(x86_xMatch),
+ /*4142*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4170,
+ 0xF2, 4164,
+ 0x66, 4158,
+ 0x0, 4152,
+ /*4152*/ uint16(x86_xSetOp), uint16(x86_MULPS),
+ /*4154*/ uint16(x86_xReadSlashR),
+ /*4155*/ uint16(x86_xArgXmm1),
+ /*4156*/ uint16(x86_xArgXmm2M128),
+ /*4157*/ uint16(x86_xMatch),
+ /*4158*/ uint16(x86_xSetOp), uint16(x86_MULPD),
+ /*4160*/ uint16(x86_xReadSlashR),
+ /*4161*/ uint16(x86_xArgXmm1),
+ /*4162*/ uint16(x86_xArgXmm2M128),
+ /*4163*/ uint16(x86_xMatch),
+ /*4164*/ uint16(x86_xSetOp), uint16(x86_MULSD),
+ /*4166*/ uint16(x86_xReadSlashR),
+ /*4167*/ uint16(x86_xArgXmm1),
+ /*4168*/ uint16(x86_xArgXmm2M64),
+ /*4169*/ uint16(x86_xMatch),
+ /*4170*/ uint16(x86_xSetOp), uint16(x86_MULSS),
+ /*4172*/ uint16(x86_xReadSlashR),
+ /*4173*/ uint16(x86_xArgXmm1),
+ /*4174*/ uint16(x86_xArgXmm2M32),
+ /*4175*/ uint16(x86_xMatch),
+ /*4176*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4204,
+ 0xF2, 4198,
+ 0x66, 4192,
+ 0x0, 4186,
+ /*4186*/ uint16(x86_xSetOp), uint16(x86_CVTPS2PD),
+ /*4188*/ uint16(x86_xReadSlashR),
+ /*4189*/ uint16(x86_xArgXmm1),
+ /*4190*/ uint16(x86_xArgXmm2M64),
+ /*4191*/ uint16(x86_xMatch),
+ /*4192*/ uint16(x86_xSetOp), uint16(x86_CVTPD2PS),
+ /*4194*/ uint16(x86_xReadSlashR),
+ /*4195*/ uint16(x86_xArgXmm1),
+ /*4196*/ uint16(x86_xArgXmm2M128),
+ /*4197*/ uint16(x86_xMatch),
+ /*4198*/ uint16(x86_xSetOp), uint16(x86_CVTSD2SS),
+ /*4200*/ uint16(x86_xReadSlashR),
+ /*4201*/ uint16(x86_xArgXmm1),
+ /*4202*/ uint16(x86_xArgXmm2M64),
+ /*4203*/ uint16(x86_xMatch),
+ /*4204*/ uint16(x86_xSetOp), uint16(x86_CVTSS2SD),
+ /*4206*/ uint16(x86_xReadSlashR),
+ /*4207*/ uint16(x86_xArgXmm1),
+ /*4208*/ uint16(x86_xArgXmm2M32),
+ /*4209*/ uint16(x86_xMatch),
+ /*4210*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 4230,
+ 0x66, 4224,
+ 0x0, 4218,
+ /*4218*/ uint16(x86_xSetOp), uint16(x86_CVTDQ2PS),
+ /*4220*/ uint16(x86_xReadSlashR),
+ /*4221*/ uint16(x86_xArgXmm1),
+ /*4222*/ uint16(x86_xArgXmm2M128),
+ /*4223*/ uint16(x86_xMatch),
+ /*4224*/ uint16(x86_xSetOp), uint16(x86_CVTPS2DQ),
+ /*4226*/ uint16(x86_xReadSlashR),
+ /*4227*/ uint16(x86_xArgXmm1),
+ /*4228*/ uint16(x86_xArgXmm2M128),
+ /*4229*/ uint16(x86_xMatch),
+ /*4230*/ uint16(x86_xSetOp), uint16(x86_CVTTPS2DQ),
+ /*4232*/ uint16(x86_xReadSlashR),
+ /*4233*/ uint16(x86_xArgXmm1),
+ /*4234*/ uint16(x86_xArgXmm2M128),
+ /*4235*/ uint16(x86_xMatch),
+ /*4236*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4264,
+ 0xF2, 4258,
+ 0x66, 4252,
+ 0x0, 4246,
+ /*4246*/ uint16(x86_xSetOp), uint16(x86_SUBPS),
+ /*4248*/ uint16(x86_xReadSlashR),
+ /*4249*/ uint16(x86_xArgXmm1),
+ /*4250*/ uint16(x86_xArgXmm2M128),
+ /*4251*/ uint16(x86_xMatch),
+ /*4252*/ uint16(x86_xSetOp), uint16(x86_SUBPD),
+ /*4254*/ uint16(x86_xReadSlashR),
+ /*4255*/ uint16(x86_xArgXmm1),
+ /*4256*/ uint16(x86_xArgXmm2M128),
+ /*4257*/ uint16(x86_xMatch),
+ /*4258*/ uint16(x86_xSetOp), uint16(x86_SUBSD),
+ /*4260*/ uint16(x86_xReadSlashR),
+ /*4261*/ uint16(x86_xArgXmm1),
+ /*4262*/ uint16(x86_xArgXmm2M64),
+ /*4263*/ uint16(x86_xMatch),
+ /*4264*/ uint16(x86_xSetOp), uint16(x86_SUBSS),
+ /*4266*/ uint16(x86_xReadSlashR),
+ /*4267*/ uint16(x86_xArgXmm1),
+ /*4268*/ uint16(x86_xArgXmm2M32),
+ /*4269*/ uint16(x86_xMatch),
+ /*4270*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4298,
+ 0xF2, 4292,
+ 0x66, 4286,
+ 0x0, 4280,
+ /*4280*/ uint16(x86_xSetOp), uint16(x86_MINPS),
+ /*4282*/ uint16(x86_xReadSlashR),
+ /*4283*/ uint16(x86_xArgXmm1),
+ /*4284*/ uint16(x86_xArgXmm2M128),
+ /*4285*/ uint16(x86_xMatch),
+ /*4286*/ uint16(x86_xSetOp), uint16(x86_MINPD),
+ /*4288*/ uint16(x86_xReadSlashR),
+ /*4289*/ uint16(x86_xArgXmm1),
+ /*4290*/ uint16(x86_xArgXmm2M128),
+ /*4291*/ uint16(x86_xMatch),
+ /*4292*/ uint16(x86_xSetOp), uint16(x86_MINSD),
+ /*4294*/ uint16(x86_xReadSlashR),
+ /*4295*/ uint16(x86_xArgXmm1),
+ /*4296*/ uint16(x86_xArgXmm2M64),
+ /*4297*/ uint16(x86_xMatch),
+ /*4298*/ uint16(x86_xSetOp), uint16(x86_MINSS),
+ /*4300*/ uint16(x86_xReadSlashR),
+ /*4301*/ uint16(x86_xArgXmm1),
+ /*4302*/ uint16(x86_xArgXmm2M32),
+ /*4303*/ uint16(x86_xMatch),
+ /*4304*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4332,
+ 0xF2, 4326,
+ 0x66, 4320,
+ 0x0, 4314,
+ /*4314*/ uint16(x86_xSetOp), uint16(x86_DIVPS),
+ /*4316*/ uint16(x86_xReadSlashR),
+ /*4317*/ uint16(x86_xArgXmm1),
+ /*4318*/ uint16(x86_xArgXmm2M128),
+ /*4319*/ uint16(x86_xMatch),
+ /*4320*/ uint16(x86_xSetOp), uint16(x86_DIVPD),
+ /*4322*/ uint16(x86_xReadSlashR),
+ /*4323*/ uint16(x86_xArgXmm1),
+ /*4324*/ uint16(x86_xArgXmm2M128),
+ /*4325*/ uint16(x86_xMatch),
+ /*4326*/ uint16(x86_xSetOp), uint16(x86_DIVSD),
+ /*4328*/ uint16(x86_xReadSlashR),
+ /*4329*/ uint16(x86_xArgXmm1),
+ /*4330*/ uint16(x86_xArgXmm2M64),
+ /*4331*/ uint16(x86_xMatch),
+ /*4332*/ uint16(x86_xSetOp), uint16(x86_DIVSS),
+ /*4334*/ uint16(x86_xReadSlashR),
+ /*4335*/ uint16(x86_xArgXmm1),
+ /*4336*/ uint16(x86_xArgXmm2M32),
+ /*4337*/ uint16(x86_xMatch),
+ /*4338*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4366,
+ 0xF2, 4360,
+ 0x66, 4354,
+ 0x0, 4348,
+ /*4348*/ uint16(x86_xSetOp), uint16(x86_MAXPS),
+ /*4350*/ uint16(x86_xReadSlashR),
+ /*4351*/ uint16(x86_xArgXmm1),
+ /*4352*/ uint16(x86_xArgXmm2M128),
+ /*4353*/ uint16(x86_xMatch),
+ /*4354*/ uint16(x86_xSetOp), uint16(x86_MAXPD),
+ /*4356*/ uint16(x86_xReadSlashR),
+ /*4357*/ uint16(x86_xArgXmm1),
+ /*4358*/ uint16(x86_xArgXmm2M128),
+ /*4359*/ uint16(x86_xMatch),
+ /*4360*/ uint16(x86_xSetOp), uint16(x86_MAXSD),
+ /*4362*/ uint16(x86_xReadSlashR),
+ /*4363*/ uint16(x86_xArgXmm1),
+ /*4364*/ uint16(x86_xArgXmm2M64),
+ /*4365*/ uint16(x86_xMatch),
+ /*4366*/ uint16(x86_xSetOp), uint16(x86_MAXSS),
+ /*4368*/ uint16(x86_xReadSlashR),
+ /*4369*/ uint16(x86_xArgXmm1),
+ /*4370*/ uint16(x86_xArgXmm2M32),
+ /*4371*/ uint16(x86_xMatch),
+ /*4372*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4384,
+ 0x0, 4378,
+ /*4378*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLBW),
+ /*4380*/ uint16(x86_xReadSlashR),
+ /*4381*/ uint16(x86_xArgMm),
+ /*4382*/ uint16(x86_xArgMmM32),
+ /*4383*/ uint16(x86_xMatch),
+ /*4384*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLBW),
+ /*4386*/ uint16(x86_xReadSlashR),
+ /*4387*/ uint16(x86_xArgXmm1),
+ /*4388*/ uint16(x86_xArgXmm2M128),
+ /*4389*/ uint16(x86_xMatch),
+ /*4390*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4402,
+ 0x0, 4396,
+ /*4396*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLWD),
+ /*4398*/ uint16(x86_xReadSlashR),
+ /*4399*/ uint16(x86_xArgMm),
+ /*4400*/ uint16(x86_xArgMmM32),
+ /*4401*/ uint16(x86_xMatch),
+ /*4402*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLWD),
+ /*4404*/ uint16(x86_xReadSlashR),
+ /*4405*/ uint16(x86_xArgXmm1),
+ /*4406*/ uint16(x86_xArgXmm2M128),
+ /*4407*/ uint16(x86_xMatch),
+ /*4408*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4420,
+ 0x0, 4414,
+ /*4414*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLDQ),
+ /*4416*/ uint16(x86_xReadSlashR),
+ /*4417*/ uint16(x86_xArgMm),
+ /*4418*/ uint16(x86_xArgMmM32),
+ /*4419*/ uint16(x86_xMatch),
+ /*4420*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLDQ),
+ /*4422*/ uint16(x86_xReadSlashR),
+ /*4423*/ uint16(x86_xArgXmm1),
+ /*4424*/ uint16(x86_xArgXmm2M128),
+ /*4425*/ uint16(x86_xMatch),
+ /*4426*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4438,
+ 0x0, 4432,
+ /*4432*/ uint16(x86_xSetOp), uint16(x86_PACKSSWB),
+ /*4434*/ uint16(x86_xReadSlashR),
+ /*4435*/ uint16(x86_xArgMm1),
+ /*4436*/ uint16(x86_xArgMm2M64),
+ /*4437*/ uint16(x86_xMatch),
+ /*4438*/ uint16(x86_xSetOp), uint16(x86_PACKSSWB),
+ /*4440*/ uint16(x86_xReadSlashR),
+ /*4441*/ uint16(x86_xArgXmm1),
+ /*4442*/ uint16(x86_xArgXmm2M128),
+ /*4443*/ uint16(x86_xMatch),
+ /*4444*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4456,
+ 0x0, 4450,
+ /*4450*/ uint16(x86_xSetOp), uint16(x86_PCMPGTB),
+ /*4452*/ uint16(x86_xReadSlashR),
+ /*4453*/ uint16(x86_xArgMm),
+ /*4454*/ uint16(x86_xArgMmM64),
+ /*4455*/ uint16(x86_xMatch),
+ /*4456*/ uint16(x86_xSetOp), uint16(x86_PCMPGTB),
+ /*4458*/ uint16(x86_xReadSlashR),
+ /*4459*/ uint16(x86_xArgXmm1),
+ /*4460*/ uint16(x86_xArgXmm2M128),
+ /*4461*/ uint16(x86_xMatch),
+ /*4462*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4474,
+ 0x0, 4468,
+ /*4468*/ uint16(x86_xSetOp), uint16(x86_PCMPGTW),
+ /*4470*/ uint16(x86_xReadSlashR),
+ /*4471*/ uint16(x86_xArgMm),
+ /*4472*/ uint16(x86_xArgMmM64),
+ /*4473*/ uint16(x86_xMatch),
+ /*4474*/ uint16(x86_xSetOp), uint16(x86_PCMPGTW),
+ /*4476*/ uint16(x86_xReadSlashR),
+ /*4477*/ uint16(x86_xArgXmm1),
+ /*4478*/ uint16(x86_xArgXmm2M128),
+ /*4479*/ uint16(x86_xMatch),
+ /*4480*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4492,
+ 0x0, 4486,
+ /*4486*/ uint16(x86_xSetOp), uint16(x86_PCMPGTD),
+ /*4488*/ uint16(x86_xReadSlashR),
+ /*4489*/ uint16(x86_xArgMm),
+ /*4490*/ uint16(x86_xArgMmM64),
+ /*4491*/ uint16(x86_xMatch),
+ /*4492*/ uint16(x86_xSetOp), uint16(x86_PCMPGTD),
+ /*4494*/ uint16(x86_xReadSlashR),
+ /*4495*/ uint16(x86_xArgXmm1),
+ /*4496*/ uint16(x86_xArgXmm2M128),
+ /*4497*/ uint16(x86_xMatch),
+ /*4498*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4510,
+ 0x0, 4504,
+ /*4504*/ uint16(x86_xSetOp), uint16(x86_PACKUSWB),
+ /*4506*/ uint16(x86_xReadSlashR),
+ /*4507*/ uint16(x86_xArgMm),
+ /*4508*/ uint16(x86_xArgMmM64),
+ /*4509*/ uint16(x86_xMatch),
+ /*4510*/ uint16(x86_xSetOp), uint16(x86_PACKUSWB),
+ /*4512*/ uint16(x86_xReadSlashR),
+ /*4513*/ uint16(x86_xArgXmm1),
+ /*4514*/ uint16(x86_xArgXmm2M128),
+ /*4515*/ uint16(x86_xMatch),
+ /*4516*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4528,
+ 0x0, 4522,
+ /*4522*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHBW),
+ /*4524*/ uint16(x86_xReadSlashR),
+ /*4525*/ uint16(x86_xArgMm),
+ /*4526*/ uint16(x86_xArgMmM64),
+ /*4527*/ uint16(x86_xMatch),
+ /*4528*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHBW),
+ /*4530*/ uint16(x86_xReadSlashR),
+ /*4531*/ uint16(x86_xArgXmm1),
+ /*4532*/ uint16(x86_xArgXmm2M128),
+ /*4533*/ uint16(x86_xMatch),
+ /*4534*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4546,
+ 0x0, 4540,
+ /*4540*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHWD),
+ /*4542*/ uint16(x86_xReadSlashR),
+ /*4543*/ uint16(x86_xArgMm),
+ /*4544*/ uint16(x86_xArgMmM64),
+ /*4545*/ uint16(x86_xMatch),
+ /*4546*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHWD),
+ /*4548*/ uint16(x86_xReadSlashR),
+ /*4549*/ uint16(x86_xArgXmm1),
+ /*4550*/ uint16(x86_xArgXmm2M128),
+ /*4551*/ uint16(x86_xMatch),
+ /*4552*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4564,
+ 0x0, 4558,
+ /*4558*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHDQ),
+ /*4560*/ uint16(x86_xReadSlashR),
+ /*4561*/ uint16(x86_xArgMm),
+ /*4562*/ uint16(x86_xArgMmM64),
+ /*4563*/ uint16(x86_xMatch),
+ /*4564*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHDQ),
+ /*4566*/ uint16(x86_xReadSlashR),
+ /*4567*/ uint16(x86_xArgXmm1),
+ /*4568*/ uint16(x86_xArgXmm2M128),
+ /*4569*/ uint16(x86_xMatch),
+ /*4570*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4582,
+ 0x0, 4576,
+ /*4576*/ uint16(x86_xSetOp), uint16(x86_PACKSSDW),
+ /*4578*/ uint16(x86_xReadSlashR),
+ /*4579*/ uint16(x86_xArgMm1),
+ /*4580*/ uint16(x86_xArgMm2M64),
+ /*4581*/ uint16(x86_xMatch),
+ /*4582*/ uint16(x86_xSetOp), uint16(x86_PACKSSDW),
+ /*4584*/ uint16(x86_xReadSlashR),
+ /*4585*/ uint16(x86_xArgXmm1),
+ /*4586*/ uint16(x86_xArgXmm2M128),
+ /*4587*/ uint16(x86_xMatch),
+ /*4588*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 4592,
+ /*4592*/ uint16(x86_xSetOp), uint16(x86_PUNPCKLQDQ),
+ /*4594*/ uint16(x86_xReadSlashR),
+ /*4595*/ uint16(x86_xArgXmm1),
+ /*4596*/ uint16(x86_xArgXmm2M128),
+ /*4597*/ uint16(x86_xMatch),
+ /*4598*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 4602,
+ /*4602*/ uint16(x86_xSetOp), uint16(x86_PUNPCKHQDQ),
+ /*4604*/ uint16(x86_xReadSlashR),
+ /*4605*/ uint16(x86_xArgXmm1),
+ /*4606*/ uint16(x86_xArgXmm2M128),
+ /*4607*/ uint16(x86_xMatch),
+ /*4608*/ uint16(x86_xCondIs64), 4611, 4649,
+ /*4611*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4633,
+ 0x0, 4617,
+ /*4617*/ uint16(x86_xCondDataSize), 4621, 4627, 0,
+ /*4621*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*4623*/ uint16(x86_xReadSlashR),
+ /*4624*/ uint16(x86_xArgMm),
+ /*4625*/ uint16(x86_xArgRM32),
+ /*4626*/ uint16(x86_xMatch),
+ /*4627*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*4629*/ uint16(x86_xReadSlashR),
+ /*4630*/ uint16(x86_xArgMm),
+ /*4631*/ uint16(x86_xArgRM32),
+ /*4632*/ uint16(x86_xMatch),
+ /*4633*/ uint16(x86_xCondDataSize), 4637, 4643, 0,
+ /*4637*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*4639*/ uint16(x86_xReadSlashR),
+ /*4640*/ uint16(x86_xArgXmm),
+ /*4641*/ uint16(x86_xArgRM32),
+ /*4642*/ uint16(x86_xMatch),
+ /*4643*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*4645*/ uint16(x86_xReadSlashR),
+ /*4646*/ uint16(x86_xArgXmm),
+ /*4647*/ uint16(x86_xArgRM32),
+ /*4648*/ uint16(x86_xMatch),
+ /*4649*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4665,
+ 0x0, 4655,
+ /*4655*/ uint16(x86_xCondDataSize), 4621, 4627, 4659,
+ /*4659*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*4661*/ uint16(x86_xReadSlashR),
+ /*4662*/ uint16(x86_xArgMm),
+ /*4663*/ uint16(x86_xArgRM64),
+ /*4664*/ uint16(x86_xMatch),
+ /*4665*/ uint16(x86_xCondDataSize), 4637, 4643, 4669,
+ /*4669*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*4671*/ uint16(x86_xReadSlashR),
+ /*4672*/ uint16(x86_xArgXmm),
+ /*4673*/ uint16(x86_xArgRM64),
+ /*4674*/ uint16(x86_xMatch),
+ /*4675*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 4695,
+ 0x66, 4689,
+ 0x0, 4683,
+ /*4683*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*4685*/ uint16(x86_xReadSlashR),
+ /*4686*/ uint16(x86_xArgMm),
+ /*4687*/ uint16(x86_xArgMmM64),
+ /*4688*/ uint16(x86_xMatch),
+ /*4689*/ uint16(x86_xSetOp), uint16(x86_MOVDQA),
+ /*4691*/ uint16(x86_xReadSlashR),
+ /*4692*/ uint16(x86_xArgXmm1),
+ /*4693*/ uint16(x86_xArgXmm2M128),
+ /*4694*/ uint16(x86_xMatch),
+ /*4695*/ uint16(x86_xSetOp), uint16(x86_MOVDQU),
+ /*4697*/ uint16(x86_xReadSlashR),
+ /*4698*/ uint16(x86_xArgXmm1),
+ /*4699*/ uint16(x86_xArgXmm2M128),
+ /*4700*/ uint16(x86_xMatch),
+ /*4701*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 4735,
+ 0xF2, 4727,
+ 0x66, 4719,
+ 0x0, 4711,
+ /*4711*/ uint16(x86_xSetOp), uint16(x86_PSHUFW),
+ /*4713*/ uint16(x86_xReadSlashR),
+ /*4714*/ uint16(x86_xReadIb),
+ /*4715*/ uint16(x86_xArgMm1),
+ /*4716*/ uint16(x86_xArgMm2M64),
+ /*4717*/ uint16(x86_xArgImm8u),
+ /*4718*/ uint16(x86_xMatch),
+ /*4719*/ uint16(x86_xSetOp), uint16(x86_PSHUFD),
+ /*4721*/ uint16(x86_xReadSlashR),
+ /*4722*/ uint16(x86_xReadIb),
+ /*4723*/ uint16(x86_xArgXmm1),
+ /*4724*/ uint16(x86_xArgXmm2M128),
+ /*4725*/ uint16(x86_xArgImm8u),
+ /*4726*/ uint16(x86_xMatch),
+ /*4727*/ uint16(x86_xSetOp), uint16(x86_PSHUFLW),
+ /*4729*/ uint16(x86_xReadSlashR),
+ /*4730*/ uint16(x86_xReadIb),
+ /*4731*/ uint16(x86_xArgXmm1),
+ /*4732*/ uint16(x86_xArgXmm2M128),
+ /*4733*/ uint16(x86_xArgImm8u),
+ /*4734*/ uint16(x86_xMatch),
+ /*4735*/ uint16(x86_xSetOp), uint16(x86_PSHUFHW),
+ /*4737*/ uint16(x86_xReadSlashR),
+ /*4738*/ uint16(x86_xReadIb),
+ /*4739*/ uint16(x86_xArgXmm1),
+ /*4740*/ uint16(x86_xArgXmm2M128),
+ /*4741*/ uint16(x86_xArgImm8u),
+ /*4742*/ uint16(x86_xMatch),
+ /*4743*/ uint16(x86_xCondSlashR),
+ 0, // 0
+ 0, // 1
+ 4752, // 2
+ 0, // 3
+ 4770, // 4
+ 0, // 5
+ 4788, // 6
+ 0, // 7
+ /*4752*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4764,
+ 0x0, 4758,
+ /*4758*/ uint16(x86_xSetOp), uint16(x86_PSRLW),
+ /*4760*/ uint16(x86_xReadIb),
+ /*4761*/ uint16(x86_xArgMm2),
+ /*4762*/ uint16(x86_xArgImm8u),
+ /*4763*/ uint16(x86_xMatch),
+ /*4764*/ uint16(x86_xSetOp), uint16(x86_PSRLW),
+ /*4766*/ uint16(x86_xReadIb),
+ /*4767*/ uint16(x86_xArgXmm2),
+ /*4768*/ uint16(x86_xArgImm8u),
+ /*4769*/ uint16(x86_xMatch),
+ /*4770*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4782,
+ 0x0, 4776,
+ /*4776*/ uint16(x86_xSetOp), uint16(x86_PSRAW),
+ /*4778*/ uint16(x86_xReadIb),
+ /*4779*/ uint16(x86_xArgMm2),
+ /*4780*/ uint16(x86_xArgImm8u),
+ /*4781*/ uint16(x86_xMatch),
+ /*4782*/ uint16(x86_xSetOp), uint16(x86_PSRAW),
+ /*4784*/ uint16(x86_xReadIb),
+ /*4785*/ uint16(x86_xArgXmm2),
+ /*4786*/ uint16(x86_xArgImm8u),
+ /*4787*/ uint16(x86_xMatch),
+ /*4788*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4800,
+ 0x0, 4794,
+ /*4794*/ uint16(x86_xSetOp), uint16(x86_PSLLW),
+ /*4796*/ uint16(x86_xReadIb),
+ /*4797*/ uint16(x86_xArgMm2),
+ /*4798*/ uint16(x86_xArgImm8u),
+ /*4799*/ uint16(x86_xMatch),
+ /*4800*/ uint16(x86_xSetOp), uint16(x86_PSLLW),
+ /*4802*/ uint16(x86_xReadIb),
+ /*4803*/ uint16(x86_xArgXmm2),
+ /*4804*/ uint16(x86_xArgImm8u),
+ /*4805*/ uint16(x86_xMatch),
+ /*4806*/ uint16(x86_xCondSlashR),
+ 0, // 0
+ 0, // 1
+ 4815, // 2
+ 0, // 3
+ 4833, // 4
+ 0, // 5
+ 4851, // 6
+ 0, // 7
+ /*4815*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4827,
+ 0x0, 4821,
+ /*4821*/ uint16(x86_xSetOp), uint16(x86_PSRLD),
+ /*4823*/ uint16(x86_xReadIb),
+ /*4824*/ uint16(x86_xArgMm2),
+ /*4825*/ uint16(x86_xArgImm8u),
+ /*4826*/ uint16(x86_xMatch),
+ /*4827*/ uint16(x86_xSetOp), uint16(x86_PSRLD),
+ /*4829*/ uint16(x86_xReadIb),
+ /*4830*/ uint16(x86_xArgXmm2),
+ /*4831*/ uint16(x86_xArgImm8u),
+ /*4832*/ uint16(x86_xMatch),
+ /*4833*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4845,
+ 0x0, 4839,
+ /*4839*/ uint16(x86_xSetOp), uint16(x86_PSRAD),
+ /*4841*/ uint16(x86_xReadIb),
+ /*4842*/ uint16(x86_xArgMm2),
+ /*4843*/ uint16(x86_xArgImm8u),
+ /*4844*/ uint16(x86_xMatch),
+ /*4845*/ uint16(x86_xSetOp), uint16(x86_PSRAD),
+ /*4847*/ uint16(x86_xReadIb),
+ /*4848*/ uint16(x86_xArgXmm2),
+ /*4849*/ uint16(x86_xArgImm8u),
+ /*4850*/ uint16(x86_xMatch),
+ /*4851*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4863,
+ 0x0, 4857,
+ /*4857*/ uint16(x86_xSetOp), uint16(x86_PSLLD),
+ /*4859*/ uint16(x86_xReadIb),
+ /*4860*/ uint16(x86_xArgMm2),
+ /*4861*/ uint16(x86_xArgImm8u),
+ /*4862*/ uint16(x86_xMatch),
+ /*4863*/ uint16(x86_xSetOp), uint16(x86_PSLLD),
+ /*4865*/ uint16(x86_xReadIb),
+ /*4866*/ uint16(x86_xArgXmm2),
+ /*4867*/ uint16(x86_xArgImm8u),
+ /*4868*/ uint16(x86_xMatch),
+ /*4869*/ uint16(x86_xCondSlashR),
+ 0, // 0
+ 0, // 1
+ 4878, // 2
+ 4896, // 3
+ 0, // 4
+ 0, // 5
+ 4906, // 6
+ 4924, // 7
+ /*4878*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4890,
+ 0x0, 4884,
+ /*4884*/ uint16(x86_xSetOp), uint16(x86_PSRLQ),
+ /*4886*/ uint16(x86_xReadIb),
+ /*4887*/ uint16(x86_xArgMm2),
+ /*4888*/ uint16(x86_xArgImm8u),
+ /*4889*/ uint16(x86_xMatch),
+ /*4890*/ uint16(x86_xSetOp), uint16(x86_PSRLQ),
+ /*4892*/ uint16(x86_xReadIb),
+ /*4893*/ uint16(x86_xArgXmm2),
+ /*4894*/ uint16(x86_xArgImm8u),
+ /*4895*/ uint16(x86_xMatch),
+ /*4896*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 4900,
+ /*4900*/ uint16(x86_xSetOp), uint16(x86_PSRLDQ),
+ /*4902*/ uint16(x86_xReadIb),
+ /*4903*/ uint16(x86_xArgXmm2),
+ /*4904*/ uint16(x86_xArgImm8u),
+ /*4905*/ uint16(x86_xMatch),
+ /*4906*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4918,
+ 0x0, 4912,
+ /*4912*/ uint16(x86_xSetOp), uint16(x86_PSLLQ),
+ /*4914*/ uint16(x86_xReadIb),
+ /*4915*/ uint16(x86_xArgMm2),
+ /*4916*/ uint16(x86_xArgImm8u),
+ /*4917*/ uint16(x86_xMatch),
+ /*4918*/ uint16(x86_xSetOp), uint16(x86_PSLLQ),
+ /*4920*/ uint16(x86_xReadIb),
+ /*4921*/ uint16(x86_xArgXmm2),
+ /*4922*/ uint16(x86_xArgImm8u),
+ /*4923*/ uint16(x86_xMatch),
+ /*4924*/ uint16(x86_xCondPrefix), 1,
+ 0x66, 4928,
+ /*4928*/ uint16(x86_xSetOp), uint16(x86_PSLLDQ),
+ /*4930*/ uint16(x86_xReadIb),
+ /*4931*/ uint16(x86_xArgXmm2),
+ /*4932*/ uint16(x86_xArgImm8u),
+ /*4933*/ uint16(x86_xMatch),
+ /*4934*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4946,
+ 0x0, 4940,
+ /*4940*/ uint16(x86_xSetOp), uint16(x86_PCMPEQB),
+ /*4942*/ uint16(x86_xReadSlashR),
+ /*4943*/ uint16(x86_xArgMm),
+ /*4944*/ uint16(x86_xArgMmM64),
+ /*4945*/ uint16(x86_xMatch),
+ /*4946*/ uint16(x86_xSetOp), uint16(x86_PCMPEQB),
+ /*4948*/ uint16(x86_xReadSlashR),
+ /*4949*/ uint16(x86_xArgXmm1),
+ /*4950*/ uint16(x86_xArgXmm2M128),
+ /*4951*/ uint16(x86_xMatch),
+ /*4952*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4964,
+ 0x0, 4958,
+ /*4958*/ uint16(x86_xSetOp), uint16(x86_PCMPEQW),
+ /*4960*/ uint16(x86_xReadSlashR),
+ /*4961*/ uint16(x86_xArgMm),
+ /*4962*/ uint16(x86_xArgMmM64),
+ /*4963*/ uint16(x86_xMatch),
+ /*4964*/ uint16(x86_xSetOp), uint16(x86_PCMPEQW),
+ /*4966*/ uint16(x86_xReadSlashR),
+ /*4967*/ uint16(x86_xArgXmm1),
+ /*4968*/ uint16(x86_xArgXmm2M128),
+ /*4969*/ uint16(x86_xMatch),
+ /*4970*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 4982,
+ 0x0, 4976,
+ /*4976*/ uint16(x86_xSetOp), uint16(x86_PCMPEQD),
+ /*4978*/ uint16(x86_xReadSlashR),
+ /*4979*/ uint16(x86_xArgMm),
+ /*4980*/ uint16(x86_xArgMmM64),
+ /*4981*/ uint16(x86_xMatch),
+ /*4982*/ uint16(x86_xSetOp), uint16(x86_PCMPEQD),
+ /*4984*/ uint16(x86_xReadSlashR),
+ /*4985*/ uint16(x86_xArgXmm1),
+ /*4986*/ uint16(x86_xArgXmm2M128),
+ /*4987*/ uint16(x86_xMatch),
+ /*4988*/ uint16(x86_xSetOp), uint16(x86_EMMS),
+ /*4990*/ uint16(x86_xMatch),
+ /*4991*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 5003,
+ 0x66, 4997,
+ /*4997*/ uint16(x86_xSetOp), uint16(x86_HADDPD),
+ /*4999*/ uint16(x86_xReadSlashR),
+ /*5000*/ uint16(x86_xArgXmm1),
+ /*5001*/ uint16(x86_xArgXmm2M128),
+ /*5002*/ uint16(x86_xMatch),
+ /*5003*/ uint16(x86_xSetOp), uint16(x86_HADDPS),
+ /*5005*/ uint16(x86_xReadSlashR),
+ /*5006*/ uint16(x86_xArgXmm1),
+ /*5007*/ uint16(x86_xArgXmm2M128),
+ /*5008*/ uint16(x86_xMatch),
+ /*5009*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 5021,
+ 0x66, 5015,
+ /*5015*/ uint16(x86_xSetOp), uint16(x86_HSUBPD),
+ /*5017*/ uint16(x86_xReadSlashR),
+ /*5018*/ uint16(x86_xArgXmm1),
+ /*5019*/ uint16(x86_xArgXmm2M128),
+ /*5020*/ uint16(x86_xMatch),
+ /*5021*/ uint16(x86_xSetOp), uint16(x86_HSUBPS),
+ /*5023*/ uint16(x86_xReadSlashR),
+ /*5024*/ uint16(x86_xArgXmm1),
+ /*5025*/ uint16(x86_xArgXmm2M128),
+ /*5026*/ uint16(x86_xMatch),
+ /*5027*/ uint16(x86_xCondIs64), 5030, 5076,
+ /*5030*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 5070,
+ 0x66, 5054,
+ 0x0, 5038,
+ /*5038*/ uint16(x86_xCondDataSize), 5042, 5048, 0,
+ /*5042*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*5044*/ uint16(x86_xReadSlashR),
+ /*5045*/ uint16(x86_xArgRM32),
+ /*5046*/ uint16(x86_xArgMm),
+ /*5047*/ uint16(x86_xMatch),
+ /*5048*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*5050*/ uint16(x86_xReadSlashR),
+ /*5051*/ uint16(x86_xArgRM32),
+ /*5052*/ uint16(x86_xArgMm),
+ /*5053*/ uint16(x86_xMatch),
+ /*5054*/ uint16(x86_xCondDataSize), 5058, 5064, 0,
+ /*5058*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*5060*/ uint16(x86_xReadSlashR),
+ /*5061*/ uint16(x86_xArgRM32),
+ /*5062*/ uint16(x86_xArgXmm),
+ /*5063*/ uint16(x86_xMatch),
+ /*5064*/ uint16(x86_xSetOp), uint16(x86_MOVD),
+ /*5066*/ uint16(x86_xReadSlashR),
+ /*5067*/ uint16(x86_xArgRM32),
+ /*5068*/ uint16(x86_xArgXmm),
+ /*5069*/ uint16(x86_xMatch),
+ /*5070*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*5072*/ uint16(x86_xReadSlashR),
+ /*5073*/ uint16(x86_xArgXmm1),
+ /*5074*/ uint16(x86_xArgXmm2M64),
+ /*5075*/ uint16(x86_xMatch),
+ /*5076*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 5070,
+ 0x66, 5094,
+ 0x0, 5084,
+ /*5084*/ uint16(x86_xCondDataSize), 5042, 5048, 5088,
+ /*5088*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*5090*/ uint16(x86_xReadSlashR),
+ /*5091*/ uint16(x86_xArgRM64),
+ /*5092*/ uint16(x86_xArgMm),
+ /*5093*/ uint16(x86_xMatch),
+ /*5094*/ uint16(x86_xCondDataSize), 5058, 5064, 5098,
+ /*5098*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*5100*/ uint16(x86_xReadSlashR),
+ /*5101*/ uint16(x86_xArgRM64),
+ /*5102*/ uint16(x86_xArgXmm),
+ /*5103*/ uint16(x86_xMatch),
+ /*5104*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 5124,
+ 0x66, 5118,
+ 0x0, 5112,
+ /*5112*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*5114*/ uint16(x86_xReadSlashR),
+ /*5115*/ uint16(x86_xArgMmM64),
+ /*5116*/ uint16(x86_xArgMm),
+ /*5117*/ uint16(x86_xMatch),
+ /*5118*/ uint16(x86_xSetOp), uint16(x86_MOVDQA),
+ /*5120*/ uint16(x86_xReadSlashR),
+ /*5121*/ uint16(x86_xArgXmm2M128),
+ /*5122*/ uint16(x86_xArgXmm1),
+ /*5123*/ uint16(x86_xMatch),
+ /*5124*/ uint16(x86_xSetOp), uint16(x86_MOVDQU),
+ /*5126*/ uint16(x86_xReadSlashR),
+ /*5127*/ uint16(x86_xArgXmm2M128),
+ /*5128*/ uint16(x86_xArgXmm1),
+ /*5129*/ uint16(x86_xMatch),
+ /*5130*/ uint16(x86_xCondIs64), 5133, 5147,
+ /*5133*/ uint16(x86_xCondDataSize), 5137, 5142, 0,
+ /*5137*/ uint16(x86_xSetOp), uint16(x86_JO),
+ /*5139*/ uint16(x86_xReadCw),
+ /*5140*/ uint16(x86_xArgRel16),
+ /*5141*/ uint16(x86_xMatch),
+ /*5142*/ uint16(x86_xSetOp), uint16(x86_JO),
+ /*5144*/ uint16(x86_xReadCd),
+ /*5145*/ uint16(x86_xArgRel32),
+ /*5146*/ uint16(x86_xMatch),
+ /*5147*/ uint16(x86_xCondDataSize), 5151, 5142, 5156,
+ /*5151*/ uint16(x86_xSetOp), uint16(x86_JO),
+ /*5153*/ uint16(x86_xReadCd),
+ /*5154*/ uint16(x86_xArgRel32),
+ /*5155*/ uint16(x86_xMatch),
+ /*5156*/ uint16(x86_xSetOp), uint16(x86_JO),
+ /*5158*/ uint16(x86_xReadCd),
+ /*5159*/ uint16(x86_xArgRel32),
+ /*5160*/ uint16(x86_xMatch),
+ /*5161*/ uint16(x86_xCondIs64), 5164, 5178,
+ /*5164*/ uint16(x86_xCondDataSize), 5168, 5173, 0,
+ /*5168*/ uint16(x86_xSetOp), uint16(x86_JNO),
+ /*5170*/ uint16(x86_xReadCw),
+ /*5171*/ uint16(x86_xArgRel16),
+ /*5172*/ uint16(x86_xMatch),
+ /*5173*/ uint16(x86_xSetOp), uint16(x86_JNO),
+ /*5175*/ uint16(x86_xReadCd),
+ /*5176*/ uint16(x86_xArgRel32),
+ /*5177*/ uint16(x86_xMatch),
+ /*5178*/ uint16(x86_xCondDataSize), 5182, 5173, 5187,
+ /*5182*/ uint16(x86_xSetOp), uint16(x86_JNO),
+ /*5184*/ uint16(x86_xReadCd),
+ /*5185*/ uint16(x86_xArgRel32),
+ /*5186*/ uint16(x86_xMatch),
+ /*5187*/ uint16(x86_xSetOp), uint16(x86_JNO),
+ /*5189*/ uint16(x86_xReadCd),
+ /*5190*/ uint16(x86_xArgRel32),
+ /*5191*/ uint16(x86_xMatch),
+ /*5192*/ uint16(x86_xCondIs64), 5195, 5209,
+ /*5195*/ uint16(x86_xCondDataSize), 5199, 5204, 0,
+ /*5199*/ uint16(x86_xSetOp), uint16(x86_JB),
+ /*5201*/ uint16(x86_xReadCw),
+ /*5202*/ uint16(x86_xArgRel16),
+ /*5203*/ uint16(x86_xMatch),
+ /*5204*/ uint16(x86_xSetOp), uint16(x86_JB),
+ /*5206*/ uint16(x86_xReadCd),
+ /*5207*/ uint16(x86_xArgRel32),
+ /*5208*/ uint16(x86_xMatch),
+ /*5209*/ uint16(x86_xCondDataSize), 5213, 5204, 5218,
+ /*5213*/ uint16(x86_xSetOp), uint16(x86_JB),
+ /*5215*/ uint16(x86_xReadCd),
+ /*5216*/ uint16(x86_xArgRel32),
+ /*5217*/ uint16(x86_xMatch),
+ /*5218*/ uint16(x86_xSetOp), uint16(x86_JB),
+ /*5220*/ uint16(x86_xReadCd),
+ /*5221*/ uint16(x86_xArgRel32),
+ /*5222*/ uint16(x86_xMatch),
+ /*5223*/ uint16(x86_xCondIs64), 5226, 5240,
+ /*5226*/ uint16(x86_xCondDataSize), 5230, 5235, 0,
+ /*5230*/ uint16(x86_xSetOp), uint16(x86_JAE),
+ /*5232*/ uint16(x86_xReadCw),
+ /*5233*/ uint16(x86_xArgRel16),
+ /*5234*/ uint16(x86_xMatch),
+ /*5235*/ uint16(x86_xSetOp), uint16(x86_JAE),
+ /*5237*/ uint16(x86_xReadCd),
+ /*5238*/ uint16(x86_xArgRel32),
+ /*5239*/ uint16(x86_xMatch),
+ /*5240*/ uint16(x86_xCondDataSize), 5244, 5235, 5249,
+ /*5244*/ uint16(x86_xSetOp), uint16(x86_JAE),
+ /*5246*/ uint16(x86_xReadCd),
+ /*5247*/ uint16(x86_xArgRel32),
+ /*5248*/ uint16(x86_xMatch),
+ /*5249*/ uint16(x86_xSetOp), uint16(x86_JAE),
+ /*5251*/ uint16(x86_xReadCd),
+ /*5252*/ uint16(x86_xArgRel32),
+ /*5253*/ uint16(x86_xMatch),
+ /*5254*/ uint16(x86_xCondIs64), 5257, 5271,
+ /*5257*/ uint16(x86_xCondDataSize), 5261, 5266, 0,
+ /*5261*/ uint16(x86_xSetOp), uint16(x86_JE),
+ /*5263*/ uint16(x86_xReadCw),
+ /*5264*/ uint16(x86_xArgRel16),
+ /*5265*/ uint16(x86_xMatch),
+ /*5266*/ uint16(x86_xSetOp), uint16(x86_JE),
+ /*5268*/ uint16(x86_xReadCd),
+ /*5269*/ uint16(x86_xArgRel32),
+ /*5270*/ uint16(x86_xMatch),
+ /*5271*/ uint16(x86_xCondDataSize), 5275, 5266, 5280,
+ /*5275*/ uint16(x86_xSetOp), uint16(x86_JE),
+ /*5277*/ uint16(x86_xReadCd),
+ /*5278*/ uint16(x86_xArgRel32),
+ /*5279*/ uint16(x86_xMatch),
+ /*5280*/ uint16(x86_xSetOp), uint16(x86_JE),
+ /*5282*/ uint16(x86_xReadCd),
+ /*5283*/ uint16(x86_xArgRel32),
+ /*5284*/ uint16(x86_xMatch),
+ /*5285*/ uint16(x86_xCondIs64), 5288, 5302,
+ /*5288*/ uint16(x86_xCondDataSize), 5292, 5297, 0,
+ /*5292*/ uint16(x86_xSetOp), uint16(x86_JNE),
+ /*5294*/ uint16(x86_xReadCw),
+ /*5295*/ uint16(x86_xArgRel16),
+ /*5296*/ uint16(x86_xMatch),
+ /*5297*/ uint16(x86_xSetOp), uint16(x86_JNE),
+ /*5299*/ uint16(x86_xReadCd),
+ /*5300*/ uint16(x86_xArgRel32),
+ /*5301*/ uint16(x86_xMatch),
+ /*5302*/ uint16(x86_xCondDataSize), 5306, 5297, 5311,
+ /*5306*/ uint16(x86_xSetOp), uint16(x86_JNE),
+ /*5308*/ uint16(x86_xReadCd),
+ /*5309*/ uint16(x86_xArgRel32),
+ /*5310*/ uint16(x86_xMatch),
+ /*5311*/ uint16(x86_xSetOp), uint16(x86_JNE),
+ /*5313*/ uint16(x86_xReadCd),
+ /*5314*/ uint16(x86_xArgRel32),
+ /*5315*/ uint16(x86_xMatch),
+ /*5316*/ uint16(x86_xCondIs64), 5319, 5333,
+ /*5319*/ uint16(x86_xCondDataSize), 5323, 5328, 0,
+ /*5323*/ uint16(x86_xSetOp), uint16(x86_JBE),
+ /*5325*/ uint16(x86_xReadCw),
+ /*5326*/ uint16(x86_xArgRel16),
+ /*5327*/ uint16(x86_xMatch),
+ /*5328*/ uint16(x86_xSetOp), uint16(x86_JBE),
+ /*5330*/ uint16(x86_xReadCd),
+ /*5331*/ uint16(x86_xArgRel32),
+ /*5332*/ uint16(x86_xMatch),
+ /*5333*/ uint16(x86_xCondDataSize), 5337, 5328, 5342,
+ /*5337*/ uint16(x86_xSetOp), uint16(x86_JBE),
+ /*5339*/ uint16(x86_xReadCd),
+ /*5340*/ uint16(x86_xArgRel32),
+ /*5341*/ uint16(x86_xMatch),
+ /*5342*/ uint16(x86_xSetOp), uint16(x86_JBE),
+ /*5344*/ uint16(x86_xReadCd),
+ /*5345*/ uint16(x86_xArgRel32),
+ /*5346*/ uint16(x86_xMatch),
+ /*5347*/ uint16(x86_xCondIs64), 5350, 5364,
+ /*5350*/ uint16(x86_xCondDataSize), 5354, 5359, 0,
+ /*5354*/ uint16(x86_xSetOp), uint16(x86_JA),
+ /*5356*/ uint16(x86_xReadCw),
+ /*5357*/ uint16(x86_xArgRel16),
+ /*5358*/ uint16(x86_xMatch),
+ /*5359*/ uint16(x86_xSetOp), uint16(x86_JA),
+ /*5361*/ uint16(x86_xReadCd),
+ /*5362*/ uint16(x86_xArgRel32),
+ /*5363*/ uint16(x86_xMatch),
+ /*5364*/ uint16(x86_xCondDataSize), 5368, 5359, 5373,
+ /*5368*/ uint16(x86_xSetOp), uint16(x86_JA),
+ /*5370*/ uint16(x86_xReadCd),
+ /*5371*/ uint16(x86_xArgRel32),
+ /*5372*/ uint16(x86_xMatch),
+ /*5373*/ uint16(x86_xSetOp), uint16(x86_JA),
+ /*5375*/ uint16(x86_xReadCd),
+ /*5376*/ uint16(x86_xArgRel32),
+ /*5377*/ uint16(x86_xMatch),
+ /*5378*/ uint16(x86_xCondIs64), 5381, 5395,
+ /*5381*/ uint16(x86_xCondDataSize), 5385, 5390, 0,
+ /*5385*/ uint16(x86_xSetOp), uint16(x86_JS),
+ /*5387*/ uint16(x86_xReadCw),
+ /*5388*/ uint16(x86_xArgRel16),
+ /*5389*/ uint16(x86_xMatch),
+ /*5390*/ uint16(x86_xSetOp), uint16(x86_JS),
+ /*5392*/ uint16(x86_xReadCd),
+ /*5393*/ uint16(x86_xArgRel32),
+ /*5394*/ uint16(x86_xMatch),
+ /*5395*/ uint16(x86_xCondDataSize), 5399, 5390, 5404,
+ /*5399*/ uint16(x86_xSetOp), uint16(x86_JS),
+ /*5401*/ uint16(x86_xReadCd),
+ /*5402*/ uint16(x86_xArgRel32),
+ /*5403*/ uint16(x86_xMatch),
+ /*5404*/ uint16(x86_xSetOp), uint16(x86_JS),
+ /*5406*/ uint16(x86_xReadCd),
+ /*5407*/ uint16(x86_xArgRel32),
+ /*5408*/ uint16(x86_xMatch),
+ /*5409*/ uint16(x86_xCondIs64), 5412, 5426,
+ /*5412*/ uint16(x86_xCondDataSize), 5416, 5421, 0,
+ /*5416*/ uint16(x86_xSetOp), uint16(x86_JNS),
+ /*5418*/ uint16(x86_xReadCw),
+ /*5419*/ uint16(x86_xArgRel16),
+ /*5420*/ uint16(x86_xMatch),
+ /*5421*/ uint16(x86_xSetOp), uint16(x86_JNS),
+ /*5423*/ uint16(x86_xReadCd),
+ /*5424*/ uint16(x86_xArgRel32),
+ /*5425*/ uint16(x86_xMatch),
+ /*5426*/ uint16(x86_xCondDataSize), 5430, 5421, 5435,
+ /*5430*/ uint16(x86_xSetOp), uint16(x86_JNS),
+ /*5432*/ uint16(x86_xReadCd),
+ /*5433*/ uint16(x86_xArgRel32),
+ /*5434*/ uint16(x86_xMatch),
+ /*5435*/ uint16(x86_xSetOp), uint16(x86_JNS),
+ /*5437*/ uint16(x86_xReadCd),
+ /*5438*/ uint16(x86_xArgRel32),
+ /*5439*/ uint16(x86_xMatch),
+ /*5440*/ uint16(x86_xCondIs64), 5443, 5457,
+ /*5443*/ uint16(x86_xCondDataSize), 5447, 5452, 0,
+ /*5447*/ uint16(x86_xSetOp), uint16(x86_JP),
+ /*5449*/ uint16(x86_xReadCw),
+ /*5450*/ uint16(x86_xArgRel16),
+ /*5451*/ uint16(x86_xMatch),
+ /*5452*/ uint16(x86_xSetOp), uint16(x86_JP),
+ /*5454*/ uint16(x86_xReadCd),
+ /*5455*/ uint16(x86_xArgRel32),
+ /*5456*/ uint16(x86_xMatch),
+ /*5457*/ uint16(x86_xCondDataSize), 5461, 5452, 5466,
+ /*5461*/ uint16(x86_xSetOp), uint16(x86_JP),
+ /*5463*/ uint16(x86_xReadCd),
+ /*5464*/ uint16(x86_xArgRel32),
+ /*5465*/ uint16(x86_xMatch),
+ /*5466*/ uint16(x86_xSetOp), uint16(x86_JP),
+ /*5468*/ uint16(x86_xReadCd),
+ /*5469*/ uint16(x86_xArgRel32),
+ /*5470*/ uint16(x86_xMatch),
+ /*5471*/ uint16(x86_xCondIs64), 5474, 5488,
+ /*5474*/ uint16(x86_xCondDataSize), 5478, 5483, 0,
+ /*5478*/ uint16(x86_xSetOp), uint16(x86_JNP),
+ /*5480*/ uint16(x86_xReadCw),
+ /*5481*/ uint16(x86_xArgRel16),
+ /*5482*/ uint16(x86_xMatch),
+ /*5483*/ uint16(x86_xSetOp), uint16(x86_JNP),
+ /*5485*/ uint16(x86_xReadCd),
+ /*5486*/ uint16(x86_xArgRel32),
+ /*5487*/ uint16(x86_xMatch),
+ /*5488*/ uint16(x86_xCondDataSize), 5492, 5483, 5497,
+ /*5492*/ uint16(x86_xSetOp), uint16(x86_JNP),
+ /*5494*/ uint16(x86_xReadCd),
+ /*5495*/ uint16(x86_xArgRel32),
+ /*5496*/ uint16(x86_xMatch),
+ /*5497*/ uint16(x86_xSetOp), uint16(x86_JNP),
+ /*5499*/ uint16(x86_xReadCd),
+ /*5500*/ uint16(x86_xArgRel32),
+ /*5501*/ uint16(x86_xMatch),
+ /*5502*/ uint16(x86_xCondIs64), 5505, 5519,
+ /*5505*/ uint16(x86_xCondDataSize), 5509, 5514, 0,
+ /*5509*/ uint16(x86_xSetOp), uint16(x86_JL),
+ /*5511*/ uint16(x86_xReadCw),
+ /*5512*/ uint16(x86_xArgRel16),
+ /*5513*/ uint16(x86_xMatch),
+ /*5514*/ uint16(x86_xSetOp), uint16(x86_JL),
+ /*5516*/ uint16(x86_xReadCd),
+ /*5517*/ uint16(x86_xArgRel32),
+ /*5518*/ uint16(x86_xMatch),
+ /*5519*/ uint16(x86_xCondDataSize), 5523, 5514, 5528,
+ /*5523*/ uint16(x86_xSetOp), uint16(x86_JL),
+ /*5525*/ uint16(x86_xReadCd),
+ /*5526*/ uint16(x86_xArgRel32),
+ /*5527*/ uint16(x86_xMatch),
+ /*5528*/ uint16(x86_xSetOp), uint16(x86_JL),
+ /*5530*/ uint16(x86_xReadCd),
+ /*5531*/ uint16(x86_xArgRel32),
+ /*5532*/ uint16(x86_xMatch),
+ /*5533*/ uint16(x86_xCondIs64), 5536, 5550,
+ /*5536*/ uint16(x86_xCondDataSize), 5540, 5545, 0,
+ /*5540*/ uint16(x86_xSetOp), uint16(x86_JGE),
+ /*5542*/ uint16(x86_xReadCw),
+ /*5543*/ uint16(x86_xArgRel16),
+ /*5544*/ uint16(x86_xMatch),
+ /*5545*/ uint16(x86_xSetOp), uint16(x86_JGE),
+ /*5547*/ uint16(x86_xReadCd),
+ /*5548*/ uint16(x86_xArgRel32),
+ /*5549*/ uint16(x86_xMatch),
+ /*5550*/ uint16(x86_xCondDataSize), 5554, 5545, 5559,
+ /*5554*/ uint16(x86_xSetOp), uint16(x86_JGE),
+ /*5556*/ uint16(x86_xReadCd),
+ /*5557*/ uint16(x86_xArgRel32),
+ /*5558*/ uint16(x86_xMatch),
+ /*5559*/ uint16(x86_xSetOp), uint16(x86_JGE),
+ /*5561*/ uint16(x86_xReadCd),
+ /*5562*/ uint16(x86_xArgRel32),
+ /*5563*/ uint16(x86_xMatch),
+ /*5564*/ uint16(x86_xCondIs64), 5567, 5581,
+ /*5567*/ uint16(x86_xCondDataSize), 5571, 5576, 0,
+ /*5571*/ uint16(x86_xSetOp), uint16(x86_JLE),
+ /*5573*/ uint16(x86_xReadCw),
+ /*5574*/ uint16(x86_xArgRel16),
+ /*5575*/ uint16(x86_xMatch),
+ /*5576*/ uint16(x86_xSetOp), uint16(x86_JLE),
+ /*5578*/ uint16(x86_xReadCd),
+ /*5579*/ uint16(x86_xArgRel32),
+ /*5580*/ uint16(x86_xMatch),
+ /*5581*/ uint16(x86_xCondDataSize), 5585, 5576, 5590,
+ /*5585*/ uint16(x86_xSetOp), uint16(x86_JLE),
+ /*5587*/ uint16(x86_xReadCd),
+ /*5588*/ uint16(x86_xArgRel32),
+ /*5589*/ uint16(x86_xMatch),
+ /*5590*/ uint16(x86_xSetOp), uint16(x86_JLE),
+ /*5592*/ uint16(x86_xReadCd),
+ /*5593*/ uint16(x86_xArgRel32),
+ /*5594*/ uint16(x86_xMatch),
+ /*5595*/ uint16(x86_xCondIs64), 5598, 5612,
+ /*5598*/ uint16(x86_xCondDataSize), 5602, 5607, 0,
+ /*5602*/ uint16(x86_xSetOp), uint16(x86_JG),
+ /*5604*/ uint16(x86_xReadCw),
+ /*5605*/ uint16(x86_xArgRel16),
+ /*5606*/ uint16(x86_xMatch),
+ /*5607*/ uint16(x86_xSetOp), uint16(x86_JG),
+ /*5609*/ uint16(x86_xReadCd),
+ /*5610*/ uint16(x86_xArgRel32),
+ /*5611*/ uint16(x86_xMatch),
+ /*5612*/ uint16(x86_xCondDataSize), 5616, 5607, 5621,
+ /*5616*/ uint16(x86_xSetOp), uint16(x86_JG),
+ /*5618*/ uint16(x86_xReadCd),
+ /*5619*/ uint16(x86_xArgRel32),
+ /*5620*/ uint16(x86_xMatch),
+ /*5621*/ uint16(x86_xSetOp), uint16(x86_JG),
+ /*5623*/ uint16(x86_xReadCd),
+ /*5624*/ uint16(x86_xArgRel32),
+ /*5625*/ uint16(x86_xMatch),
+ /*5626*/ uint16(x86_xSetOp), uint16(x86_SETO),
+ /*5628*/ uint16(x86_xReadSlashR),
+ /*5629*/ uint16(x86_xArgRM8),
+ /*5630*/ uint16(x86_xMatch),
+ /*5631*/ uint16(x86_xSetOp), uint16(x86_SETNO),
+ /*5633*/ uint16(x86_xReadSlashR),
+ /*5634*/ uint16(x86_xArgRM8),
+ /*5635*/ uint16(x86_xMatch),
+ /*5636*/ uint16(x86_xSetOp), uint16(x86_SETB),
+ /*5638*/ uint16(x86_xReadSlashR),
+ /*5639*/ uint16(x86_xArgRM8),
+ /*5640*/ uint16(x86_xMatch),
+ /*5641*/ uint16(x86_xSetOp), uint16(x86_SETAE),
+ /*5643*/ uint16(x86_xReadSlashR),
+ /*5644*/ uint16(x86_xArgRM8),
+ /*5645*/ uint16(x86_xMatch),
+ /*5646*/ uint16(x86_xSetOp), uint16(x86_SETE),
+ /*5648*/ uint16(x86_xReadSlashR),
+ /*5649*/ uint16(x86_xArgRM8),
+ /*5650*/ uint16(x86_xMatch),
+ /*5651*/ uint16(x86_xSetOp), uint16(x86_SETNE),
+ /*5653*/ uint16(x86_xReadSlashR),
+ /*5654*/ uint16(x86_xArgRM8),
+ /*5655*/ uint16(x86_xMatch),
+ /*5656*/ uint16(x86_xSetOp), uint16(x86_SETBE),
+ /*5658*/ uint16(x86_xReadSlashR),
+ /*5659*/ uint16(x86_xArgRM8),
+ /*5660*/ uint16(x86_xMatch),
+ /*5661*/ uint16(x86_xSetOp), uint16(x86_SETA),
+ /*5663*/ uint16(x86_xReadSlashR),
+ /*5664*/ uint16(x86_xArgRM8),
+ /*5665*/ uint16(x86_xMatch),
+ /*5666*/ uint16(x86_xSetOp), uint16(x86_SETS),
+ /*5668*/ uint16(x86_xReadSlashR),
+ /*5669*/ uint16(x86_xArgRM8),
+ /*5670*/ uint16(x86_xMatch),
+ /*5671*/ uint16(x86_xSetOp), uint16(x86_SETNS),
+ /*5673*/ uint16(x86_xReadSlashR),
+ /*5674*/ uint16(x86_xArgRM8),
+ /*5675*/ uint16(x86_xMatch),
+ /*5676*/ uint16(x86_xSetOp), uint16(x86_SETP),
+ /*5678*/ uint16(x86_xReadSlashR),
+ /*5679*/ uint16(x86_xArgRM8),
+ /*5680*/ uint16(x86_xMatch),
+ /*5681*/ uint16(x86_xSetOp), uint16(x86_SETNP),
+ /*5683*/ uint16(x86_xReadSlashR),
+ /*5684*/ uint16(x86_xArgRM8),
+ /*5685*/ uint16(x86_xMatch),
+ /*5686*/ uint16(x86_xSetOp), uint16(x86_SETL),
+ /*5688*/ uint16(x86_xReadSlashR),
+ /*5689*/ uint16(x86_xArgRM8),
+ /*5690*/ uint16(x86_xMatch),
+ /*5691*/ uint16(x86_xSetOp), uint16(x86_SETGE),
+ /*5693*/ uint16(x86_xReadSlashR),
+ /*5694*/ uint16(x86_xArgRM8),
+ /*5695*/ uint16(x86_xMatch),
+ /*5696*/ uint16(x86_xSetOp), uint16(x86_SETLE),
+ /*5698*/ uint16(x86_xReadSlashR),
+ /*5699*/ uint16(x86_xArgRM8),
+ /*5700*/ uint16(x86_xMatch),
+ /*5701*/ uint16(x86_xSetOp), uint16(x86_SETG),
+ /*5703*/ uint16(x86_xReadSlashR),
+ /*5704*/ uint16(x86_xArgRM8),
+ /*5705*/ uint16(x86_xMatch),
+ /*5706*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*5708*/ uint16(x86_xArgFS),
+ /*5709*/ uint16(x86_xMatch),
+ /*5710*/ uint16(x86_xCondIs64), 5713, 5725,
+ /*5713*/ uint16(x86_xCondDataSize), 5717, 5721, 0,
+ /*5717*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5719*/ uint16(x86_xArgFS),
+ /*5720*/ uint16(x86_xMatch),
+ /*5721*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5723*/ uint16(x86_xArgFS),
+ /*5724*/ uint16(x86_xMatch),
+ /*5725*/ uint16(x86_xCondDataSize), 5717, 5729, 5733,
+ /*5729*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5731*/ uint16(x86_xArgFS),
+ /*5732*/ uint16(x86_xMatch),
+ /*5733*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5735*/ uint16(x86_xArgFS),
+ /*5736*/ uint16(x86_xMatch),
+ /*5737*/ uint16(x86_xSetOp), uint16(x86_CPUID),
+ /*5739*/ uint16(x86_xMatch),
+ /*5740*/ uint16(x86_xCondIs64), 5743, 5759,
+ /*5743*/ uint16(x86_xCondDataSize), 5747, 5753, 0,
+ /*5747*/ uint16(x86_xSetOp), uint16(x86_BT),
+ /*5749*/ uint16(x86_xReadSlashR),
+ /*5750*/ uint16(x86_xArgRM16),
+ /*5751*/ uint16(x86_xArgR16),
+ /*5752*/ uint16(x86_xMatch),
+ /*5753*/ uint16(x86_xSetOp), uint16(x86_BT),
+ /*5755*/ uint16(x86_xReadSlashR),
+ /*5756*/ uint16(x86_xArgRM32),
+ /*5757*/ uint16(x86_xArgR32),
+ /*5758*/ uint16(x86_xMatch),
+ /*5759*/ uint16(x86_xCondDataSize), 5747, 5753, 5763,
+ /*5763*/ uint16(x86_xSetOp), uint16(x86_BT),
+ /*5765*/ uint16(x86_xReadSlashR),
+ /*5766*/ uint16(x86_xArgRM64),
+ /*5767*/ uint16(x86_xArgR64),
+ /*5768*/ uint16(x86_xMatch),
+ /*5769*/ uint16(x86_xCondIs64), 5772, 5792,
+ /*5772*/ uint16(x86_xCondDataSize), 5776, 5784, 0,
+ /*5776*/ uint16(x86_xSetOp), uint16(x86_SHLD),
+ /*5778*/ uint16(x86_xReadSlashR),
+ /*5779*/ uint16(x86_xReadIb),
+ /*5780*/ uint16(x86_xArgRM16),
+ /*5781*/ uint16(x86_xArgR16),
+ /*5782*/ uint16(x86_xArgImm8u),
+ /*5783*/ uint16(x86_xMatch),
+ /*5784*/ uint16(x86_xSetOp), uint16(x86_SHLD),
+ /*5786*/ uint16(x86_xReadSlashR),
+ /*5787*/ uint16(x86_xReadIb),
+ /*5788*/ uint16(x86_xArgRM32),
+ /*5789*/ uint16(x86_xArgR32),
+ /*5790*/ uint16(x86_xArgImm8u),
+ /*5791*/ uint16(x86_xMatch),
+ /*5792*/ uint16(x86_xCondDataSize), 5776, 5784, 5796,
+ /*5796*/ uint16(x86_xSetOp), uint16(x86_SHLD),
+ /*5798*/ uint16(x86_xReadSlashR),
+ /*5799*/ uint16(x86_xReadIb),
+ /*5800*/ uint16(x86_xArgRM64),
+ /*5801*/ uint16(x86_xArgR64),
+ /*5802*/ uint16(x86_xArgImm8u),
+ /*5803*/ uint16(x86_xMatch),
+ /*5804*/ uint16(x86_xCondIs64), 5807, 5825,
+ /*5807*/ uint16(x86_xCondDataSize), 5811, 5818, 0,
+ /*5811*/ uint16(x86_xSetOp), uint16(x86_SHLD),
+ /*5813*/ uint16(x86_xReadSlashR),
+ /*5814*/ uint16(x86_xArgRM16),
+ /*5815*/ uint16(x86_xArgR16),
+ /*5816*/ uint16(x86_xArgCL),
+ /*5817*/ uint16(x86_xMatch),
+ /*5818*/ uint16(x86_xSetOp), uint16(x86_SHLD),
+ /*5820*/ uint16(x86_xReadSlashR),
+ /*5821*/ uint16(x86_xArgRM32),
+ /*5822*/ uint16(x86_xArgR32),
+ /*5823*/ uint16(x86_xArgCL),
+ /*5824*/ uint16(x86_xMatch),
+ /*5825*/ uint16(x86_xCondDataSize), 5811, 5818, 5829,
+ /*5829*/ uint16(x86_xSetOp), uint16(x86_SHLD),
+ /*5831*/ uint16(x86_xReadSlashR),
+ /*5832*/ uint16(x86_xArgRM64),
+ /*5833*/ uint16(x86_xArgR64),
+ /*5834*/ uint16(x86_xArgCL),
+ /*5835*/ uint16(x86_xMatch),
+ /*5836*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*5838*/ uint16(x86_xArgGS),
+ /*5839*/ uint16(x86_xMatch),
+ /*5840*/ uint16(x86_xCondIs64), 5843, 5855,
+ /*5843*/ uint16(x86_xCondDataSize), 5847, 5851, 0,
+ /*5847*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5849*/ uint16(x86_xArgGS),
+ /*5850*/ uint16(x86_xMatch),
+ /*5851*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5853*/ uint16(x86_xArgGS),
+ /*5854*/ uint16(x86_xMatch),
+ /*5855*/ uint16(x86_xCondDataSize), 5847, 5859, 5863,
+ /*5859*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5861*/ uint16(x86_xArgGS),
+ /*5862*/ uint16(x86_xMatch),
+ /*5863*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*5865*/ uint16(x86_xArgGS),
+ /*5866*/ uint16(x86_xMatch),
+ /*5867*/ uint16(x86_xSetOp), uint16(x86_RSM),
+ /*5869*/ uint16(x86_xMatch),
+ /*5870*/ uint16(x86_xCondIs64), 5873, 5889,
+ /*5873*/ uint16(x86_xCondDataSize), 5877, 5883, 0,
+ /*5877*/ uint16(x86_xSetOp), uint16(x86_BTS),
+ /*5879*/ uint16(x86_xReadSlashR),
+ /*5880*/ uint16(x86_xArgRM16),
+ /*5881*/ uint16(x86_xArgR16),
+ /*5882*/ uint16(x86_xMatch),
+ /*5883*/ uint16(x86_xSetOp), uint16(x86_BTS),
+ /*5885*/ uint16(x86_xReadSlashR),
+ /*5886*/ uint16(x86_xArgRM32),
+ /*5887*/ uint16(x86_xArgR32),
+ /*5888*/ uint16(x86_xMatch),
+ /*5889*/ uint16(x86_xCondDataSize), 5877, 5883, 5893,
+ /*5893*/ uint16(x86_xSetOp), uint16(x86_BTS),
+ /*5895*/ uint16(x86_xReadSlashR),
+ /*5896*/ uint16(x86_xArgRM64),
+ /*5897*/ uint16(x86_xArgR64),
+ /*5898*/ uint16(x86_xMatch),
+ /*5899*/ uint16(x86_xCondIs64), 5902, 5922,
+ /*5902*/ uint16(x86_xCondDataSize), 5906, 5914, 0,
+ /*5906*/ uint16(x86_xSetOp), uint16(x86_SHRD),
+ /*5908*/ uint16(x86_xReadSlashR),
+ /*5909*/ uint16(x86_xReadIb),
+ /*5910*/ uint16(x86_xArgRM16),
+ /*5911*/ uint16(x86_xArgR16),
+ /*5912*/ uint16(x86_xArgImm8u),
+ /*5913*/ uint16(x86_xMatch),
+ /*5914*/ uint16(x86_xSetOp), uint16(x86_SHRD),
+ /*5916*/ uint16(x86_xReadSlashR),
+ /*5917*/ uint16(x86_xReadIb),
+ /*5918*/ uint16(x86_xArgRM32),
+ /*5919*/ uint16(x86_xArgR32),
+ /*5920*/ uint16(x86_xArgImm8u),
+ /*5921*/ uint16(x86_xMatch),
+ /*5922*/ uint16(x86_xCondDataSize), 5906, 5914, 5926,
+ /*5926*/ uint16(x86_xSetOp), uint16(x86_SHRD),
+ /*5928*/ uint16(x86_xReadSlashR),
+ /*5929*/ uint16(x86_xReadIb),
+ /*5930*/ uint16(x86_xArgRM64),
+ /*5931*/ uint16(x86_xArgR64),
+ /*5932*/ uint16(x86_xArgImm8u),
+ /*5933*/ uint16(x86_xMatch),
+ /*5934*/ uint16(x86_xCondIs64), 5937, 5955,
+ /*5937*/ uint16(x86_xCondDataSize), 5941, 5948, 0,
+ /*5941*/ uint16(x86_xSetOp), uint16(x86_SHRD),
+ /*5943*/ uint16(x86_xReadSlashR),
+ /*5944*/ uint16(x86_xArgRM16),
+ /*5945*/ uint16(x86_xArgR16),
+ /*5946*/ uint16(x86_xArgCL),
+ /*5947*/ uint16(x86_xMatch),
+ /*5948*/ uint16(x86_xSetOp), uint16(x86_SHRD),
+ /*5950*/ uint16(x86_xReadSlashR),
+ /*5951*/ uint16(x86_xArgRM32),
+ /*5952*/ uint16(x86_xArgR32),
+ /*5953*/ uint16(x86_xArgCL),
+ /*5954*/ uint16(x86_xMatch),
+ /*5955*/ uint16(x86_xCondDataSize), 5941, 5948, 5959,
+ /*5959*/ uint16(x86_xSetOp), uint16(x86_SHRD),
+ /*5961*/ uint16(x86_xReadSlashR),
+ /*5962*/ uint16(x86_xArgRM64),
+ /*5963*/ uint16(x86_xArgR64),
+ /*5964*/ uint16(x86_xArgCL),
+ /*5965*/ uint16(x86_xMatch),
+ /*5966*/ uint16(x86_xCondByte), 3,
+ 0xE8, 6215,
+ 0xF0, 6218,
+ 0xF8, 6221,
+ /*5974*/ uint16(x86_xCondSlashR),
+ 5983, // 0
+ 6037, // 1
+ 6091, // 2
+ 6120, // 3
+ 6149, // 4
+ 6172, // 5
+ 6195, // 6
+ 6211, // 7
+ /*5983*/ uint16(x86_xCondIs64), 5986, 5998,
+ /*5986*/ uint16(x86_xCondDataSize), 5990, 5994, 0,
+ /*5990*/ uint16(x86_xSetOp), uint16(x86_FXSAVE),
+ /*5992*/ uint16(x86_xArgM512byte),
+ /*5993*/ uint16(x86_xMatch),
+ /*5994*/ uint16(x86_xSetOp), uint16(x86_FXSAVE),
+ /*5996*/ uint16(x86_xArgM512byte),
+ /*5997*/ uint16(x86_xMatch),
+ /*5998*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6012,
+ 0x0, 6004,
+ /*6004*/ uint16(x86_xCondDataSize), 5990, 5994, 6008,
+ /*6008*/ uint16(x86_xSetOp), uint16(x86_FXSAVE64),
+ /*6010*/ uint16(x86_xArgM512byte),
+ /*6011*/ uint16(x86_xMatch),
+ /*6012*/ uint16(x86_xCondDataSize), 6016, 6023, 6030,
+ /*6016*/ uint16(x86_xCondIsMem), 6019, 0,
+ /*6019*/ uint16(x86_xSetOp), uint16(x86_RDFSBASE),
+ /*6021*/ uint16(x86_xArgRM32),
+ /*6022*/ uint16(x86_xMatch),
+ /*6023*/ uint16(x86_xCondIsMem), 6026, 0,
+ /*6026*/ uint16(x86_xSetOp), uint16(x86_RDFSBASE),
+ /*6028*/ uint16(x86_xArgRM32),
+ /*6029*/ uint16(x86_xMatch),
+ /*6030*/ uint16(x86_xCondIsMem), 6033, 0,
+ /*6033*/ uint16(x86_xSetOp), uint16(x86_RDFSBASE),
+ /*6035*/ uint16(x86_xArgRM64),
+ /*6036*/ uint16(x86_xMatch),
+ /*6037*/ uint16(x86_xCondIs64), 6040, 6052,
+ /*6040*/ uint16(x86_xCondDataSize), 6044, 6048, 0,
+ /*6044*/ uint16(x86_xSetOp), uint16(x86_FXRSTOR),
+ /*6046*/ uint16(x86_xArgM512byte),
+ /*6047*/ uint16(x86_xMatch),
+ /*6048*/ uint16(x86_xSetOp), uint16(x86_FXRSTOR),
+ /*6050*/ uint16(x86_xArgM512byte),
+ /*6051*/ uint16(x86_xMatch),
+ /*6052*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6066,
+ 0x0, 6058,
+ /*6058*/ uint16(x86_xCondDataSize), 6044, 6048, 6062,
+ /*6062*/ uint16(x86_xSetOp), uint16(x86_FXRSTOR64),
+ /*6064*/ uint16(x86_xArgM512byte),
+ /*6065*/ uint16(x86_xMatch),
+ /*6066*/ uint16(x86_xCondDataSize), 6070, 6077, 6084,
+ /*6070*/ uint16(x86_xCondIsMem), 6073, 0,
+ /*6073*/ uint16(x86_xSetOp), uint16(x86_RDGSBASE),
+ /*6075*/ uint16(x86_xArgRM32),
+ /*6076*/ uint16(x86_xMatch),
+ /*6077*/ uint16(x86_xCondIsMem), 6080, 0,
+ /*6080*/ uint16(x86_xSetOp), uint16(x86_RDGSBASE),
+ /*6082*/ uint16(x86_xArgRM32),
+ /*6083*/ uint16(x86_xMatch),
+ /*6084*/ uint16(x86_xCondIsMem), 6087, 0,
+ /*6087*/ uint16(x86_xSetOp), uint16(x86_RDGSBASE),
+ /*6089*/ uint16(x86_xArgRM64),
+ /*6090*/ uint16(x86_xMatch),
+ /*6091*/ uint16(x86_xCondIs64), 6094, 6098,
+ /*6094*/ uint16(x86_xSetOp), uint16(x86_LDMXCSR),
+ /*6096*/ uint16(x86_xArgM32),
+ /*6097*/ uint16(x86_xMatch),
+ /*6098*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6104,
+ 0x0, 6094,
+ /*6104*/ uint16(x86_xCondDataSize), 6108, 6112, 6116,
+ /*6108*/ uint16(x86_xSetOp), uint16(x86_WRFSBASE),
+ /*6110*/ uint16(x86_xArgRM32),
+ /*6111*/ uint16(x86_xMatch),
+ /*6112*/ uint16(x86_xSetOp), uint16(x86_WRFSBASE),
+ /*6114*/ uint16(x86_xArgRM32),
+ /*6115*/ uint16(x86_xMatch),
+ /*6116*/ uint16(x86_xSetOp), uint16(x86_WRFSBASE),
+ /*6118*/ uint16(x86_xArgRM64),
+ /*6119*/ uint16(x86_xMatch),
+ /*6120*/ uint16(x86_xCondIs64), 6123, 6127,
+ /*6123*/ uint16(x86_xSetOp), uint16(x86_STMXCSR),
+ /*6125*/ uint16(x86_xArgM32),
+ /*6126*/ uint16(x86_xMatch),
+ /*6127*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6133,
+ 0x0, 6123,
+ /*6133*/ uint16(x86_xCondDataSize), 6137, 6141, 6145,
+ /*6137*/ uint16(x86_xSetOp), uint16(x86_WRGSBASE),
+ /*6139*/ uint16(x86_xArgRM32),
+ /*6140*/ uint16(x86_xMatch),
+ /*6141*/ uint16(x86_xSetOp), uint16(x86_WRGSBASE),
+ /*6143*/ uint16(x86_xArgRM32),
+ /*6144*/ uint16(x86_xMatch),
+ /*6145*/ uint16(x86_xSetOp), uint16(x86_WRGSBASE),
+ /*6147*/ uint16(x86_xArgRM64),
+ /*6148*/ uint16(x86_xMatch),
+ /*6149*/ uint16(x86_xCondIs64), 6152, 6164,
+ /*6152*/ uint16(x86_xCondDataSize), 6156, 6160, 0,
+ /*6156*/ uint16(x86_xSetOp), uint16(x86_XSAVE),
+ /*6158*/ uint16(x86_xArgMem),
+ /*6159*/ uint16(x86_xMatch),
+ /*6160*/ uint16(x86_xSetOp), uint16(x86_XSAVE),
+ /*6162*/ uint16(x86_xArgMem),
+ /*6163*/ uint16(x86_xMatch),
+ /*6164*/ uint16(x86_xCondDataSize), 6156, 6160, 6168,
+ /*6168*/ uint16(x86_xSetOp), uint16(x86_XSAVE64),
+ /*6170*/ uint16(x86_xArgMem),
+ /*6171*/ uint16(x86_xMatch),
+ /*6172*/ uint16(x86_xCondIs64), 6175, 6187,
+ /*6175*/ uint16(x86_xCondDataSize), 6179, 6183, 0,
+ /*6179*/ uint16(x86_xSetOp), uint16(x86_XRSTOR),
+ /*6181*/ uint16(x86_xArgMem),
+ /*6182*/ uint16(x86_xMatch),
+ /*6183*/ uint16(x86_xSetOp), uint16(x86_XRSTOR),
+ /*6185*/ uint16(x86_xArgMem),
+ /*6186*/ uint16(x86_xMatch),
+ /*6187*/ uint16(x86_xCondDataSize), 6179, 6183, 6191,
+ /*6191*/ uint16(x86_xSetOp), uint16(x86_XRSTOR64),
+ /*6193*/ uint16(x86_xArgMem),
+ /*6194*/ uint16(x86_xMatch),
+ /*6195*/ uint16(x86_xCondDataSize), 6199, 6203, 6207,
+ /*6199*/ uint16(x86_xSetOp), uint16(x86_XSAVEOPT),
+ /*6201*/ uint16(x86_xArgMem),
+ /*6202*/ uint16(x86_xMatch),
+ /*6203*/ uint16(x86_xSetOp), uint16(x86_XSAVEOPT),
+ /*6205*/ uint16(x86_xArgMem),
+ /*6206*/ uint16(x86_xMatch),
+ /*6207*/ uint16(x86_xSetOp), uint16(x86_XSAVEOPT64),
+ /*6209*/ uint16(x86_xArgMem),
+ /*6210*/ uint16(x86_xMatch),
+ /*6211*/ uint16(x86_xSetOp), uint16(x86_CLFLUSH),
+ /*6213*/ uint16(x86_xArgM8),
+ /*6214*/ uint16(x86_xMatch),
+ /*6215*/ uint16(x86_xSetOp), uint16(x86_LFENCE),
+ /*6217*/ uint16(x86_xMatch),
+ /*6218*/ uint16(x86_xSetOp), uint16(x86_MFENCE),
+ /*6220*/ uint16(x86_xMatch),
+ /*6221*/ uint16(x86_xSetOp), uint16(x86_SFENCE),
+ /*6223*/ uint16(x86_xMatch),
+ /*6224*/ uint16(x86_xCondIs64), 6227, 6243,
+ /*6227*/ uint16(x86_xCondDataSize), 6231, 6237, 0,
+ /*6231*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*6233*/ uint16(x86_xReadSlashR),
+ /*6234*/ uint16(x86_xArgR16),
+ /*6235*/ uint16(x86_xArgRM16),
+ /*6236*/ uint16(x86_xMatch),
+ /*6237*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*6239*/ uint16(x86_xReadSlashR),
+ /*6240*/ uint16(x86_xArgR32),
+ /*6241*/ uint16(x86_xArgRM32),
+ /*6242*/ uint16(x86_xMatch),
+ /*6243*/ uint16(x86_xCondDataSize), 6231, 6237, 6247,
+ /*6247*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*6249*/ uint16(x86_xReadSlashR),
+ /*6250*/ uint16(x86_xArgR64),
+ /*6251*/ uint16(x86_xArgRM64),
+ /*6252*/ uint16(x86_xMatch),
+ /*6253*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG),
+ /*6255*/ uint16(x86_xReadSlashR),
+ /*6256*/ uint16(x86_xArgRM8),
+ /*6257*/ uint16(x86_xArgR8),
+ /*6258*/ uint16(x86_xMatch),
+ /*6259*/ uint16(x86_xCondIs64), 6262, 6278,
+ /*6262*/ uint16(x86_xCondDataSize), 6266, 6272, 0,
+ /*6266*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG),
+ /*6268*/ uint16(x86_xReadSlashR),
+ /*6269*/ uint16(x86_xArgRM16),
+ /*6270*/ uint16(x86_xArgR16),
+ /*6271*/ uint16(x86_xMatch),
+ /*6272*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG),
+ /*6274*/ uint16(x86_xReadSlashR),
+ /*6275*/ uint16(x86_xArgRM32),
+ /*6276*/ uint16(x86_xArgR32),
+ /*6277*/ uint16(x86_xMatch),
+ /*6278*/ uint16(x86_xCondDataSize), 6266, 6272, 6282,
+ /*6282*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG),
+ /*6284*/ uint16(x86_xReadSlashR),
+ /*6285*/ uint16(x86_xArgRM64),
+ /*6286*/ uint16(x86_xArgR64),
+ /*6287*/ uint16(x86_xMatch),
+ /*6288*/ uint16(x86_xCondIs64), 6291, 6307,
+ /*6291*/ uint16(x86_xCondDataSize), 6295, 6301, 0,
+ /*6295*/ uint16(x86_xSetOp), uint16(x86_LSS),
+ /*6297*/ uint16(x86_xReadSlashR),
+ /*6298*/ uint16(x86_xArgR16),
+ /*6299*/ uint16(x86_xArgM16colon16),
+ /*6300*/ uint16(x86_xMatch),
+ /*6301*/ uint16(x86_xSetOp), uint16(x86_LSS),
+ /*6303*/ uint16(x86_xReadSlashR),
+ /*6304*/ uint16(x86_xArgR32),
+ /*6305*/ uint16(x86_xArgM16colon32),
+ /*6306*/ uint16(x86_xMatch),
+ /*6307*/ uint16(x86_xCondDataSize), 6295, 6301, 6311,
+ /*6311*/ uint16(x86_xSetOp), uint16(x86_LSS),
+ /*6313*/ uint16(x86_xReadSlashR),
+ /*6314*/ uint16(x86_xArgR64),
+ /*6315*/ uint16(x86_xArgM16colon64),
+ /*6316*/ uint16(x86_xMatch),
+ /*6317*/ uint16(x86_xCondIs64), 6320, 6336,
+ /*6320*/ uint16(x86_xCondDataSize), 6324, 6330, 0,
+ /*6324*/ uint16(x86_xSetOp), uint16(x86_BTR),
+ /*6326*/ uint16(x86_xReadSlashR),
+ /*6327*/ uint16(x86_xArgRM16),
+ /*6328*/ uint16(x86_xArgR16),
+ /*6329*/ uint16(x86_xMatch),
+ /*6330*/ uint16(x86_xSetOp), uint16(x86_BTR),
+ /*6332*/ uint16(x86_xReadSlashR),
+ /*6333*/ uint16(x86_xArgRM32),
+ /*6334*/ uint16(x86_xArgR32),
+ /*6335*/ uint16(x86_xMatch),
+ /*6336*/ uint16(x86_xCondDataSize), 6324, 6330, 6340,
+ /*6340*/ uint16(x86_xSetOp), uint16(x86_BTR),
+ /*6342*/ uint16(x86_xReadSlashR),
+ /*6343*/ uint16(x86_xArgRM64),
+ /*6344*/ uint16(x86_xArgR64),
+ /*6345*/ uint16(x86_xMatch),
+ /*6346*/ uint16(x86_xCondIs64), 6349, 6365,
+ /*6349*/ uint16(x86_xCondDataSize), 6353, 6359, 0,
+ /*6353*/ uint16(x86_xSetOp), uint16(x86_LFS),
+ /*6355*/ uint16(x86_xReadSlashR),
+ /*6356*/ uint16(x86_xArgR16),
+ /*6357*/ uint16(x86_xArgM16colon16),
+ /*6358*/ uint16(x86_xMatch),
+ /*6359*/ uint16(x86_xSetOp), uint16(x86_LFS),
+ /*6361*/ uint16(x86_xReadSlashR),
+ /*6362*/ uint16(x86_xArgR32),
+ /*6363*/ uint16(x86_xArgM16colon32),
+ /*6364*/ uint16(x86_xMatch),
+ /*6365*/ uint16(x86_xCondDataSize), 6353, 6359, 6369,
+ /*6369*/ uint16(x86_xSetOp), uint16(x86_LFS),
+ /*6371*/ uint16(x86_xReadSlashR),
+ /*6372*/ uint16(x86_xArgR64),
+ /*6373*/ uint16(x86_xArgM16colon64),
+ /*6374*/ uint16(x86_xMatch),
+ /*6375*/ uint16(x86_xCondIs64), 6378, 6394,
+ /*6378*/ uint16(x86_xCondDataSize), 6382, 6388, 0,
+ /*6382*/ uint16(x86_xSetOp), uint16(x86_LGS),
+ /*6384*/ uint16(x86_xReadSlashR),
+ /*6385*/ uint16(x86_xArgR16),
+ /*6386*/ uint16(x86_xArgM16colon16),
+ /*6387*/ uint16(x86_xMatch),
+ /*6388*/ uint16(x86_xSetOp), uint16(x86_LGS),
+ /*6390*/ uint16(x86_xReadSlashR),
+ /*6391*/ uint16(x86_xArgR32),
+ /*6392*/ uint16(x86_xArgM16colon32),
+ /*6393*/ uint16(x86_xMatch),
+ /*6394*/ uint16(x86_xCondDataSize), 6382, 6388, 6398,
+ /*6398*/ uint16(x86_xSetOp), uint16(x86_LGS),
+ /*6400*/ uint16(x86_xReadSlashR),
+ /*6401*/ uint16(x86_xArgR64),
+ /*6402*/ uint16(x86_xArgM16colon64),
+ /*6403*/ uint16(x86_xMatch),
+ /*6404*/ uint16(x86_xCondIs64), 6407, 6423,
+ /*6407*/ uint16(x86_xCondDataSize), 6411, 6417, 0,
+ /*6411*/ uint16(x86_xSetOp), uint16(x86_MOVZX),
+ /*6413*/ uint16(x86_xReadSlashR),
+ /*6414*/ uint16(x86_xArgR16),
+ /*6415*/ uint16(x86_xArgRM8),
+ /*6416*/ uint16(x86_xMatch),
+ /*6417*/ uint16(x86_xSetOp), uint16(x86_MOVZX),
+ /*6419*/ uint16(x86_xReadSlashR),
+ /*6420*/ uint16(x86_xArgR32),
+ /*6421*/ uint16(x86_xArgRM8),
+ /*6422*/ uint16(x86_xMatch),
+ /*6423*/ uint16(x86_xCondDataSize), 6411, 6417, 6427,
+ /*6427*/ uint16(x86_xSetOp), uint16(x86_MOVZX),
+ /*6429*/ uint16(x86_xReadSlashR),
+ /*6430*/ uint16(x86_xArgR64),
+ /*6431*/ uint16(x86_xArgRM8),
+ /*6432*/ uint16(x86_xMatch),
+ /*6433*/ uint16(x86_xCondIs64), 6436, 6452,
+ /*6436*/ uint16(x86_xCondDataSize), 6440, 6446, 0,
+ /*6440*/ uint16(x86_xSetOp), uint16(x86_MOVZX),
+ /*6442*/ uint16(x86_xReadSlashR),
+ /*6443*/ uint16(x86_xArgR16),
+ /*6444*/ uint16(x86_xArgRM16),
+ /*6445*/ uint16(x86_xMatch),
+ /*6446*/ uint16(x86_xSetOp), uint16(x86_MOVZX),
+ /*6448*/ uint16(x86_xReadSlashR),
+ /*6449*/ uint16(x86_xArgR32),
+ /*6450*/ uint16(x86_xArgRM16),
+ /*6451*/ uint16(x86_xMatch),
+ /*6452*/ uint16(x86_xCondDataSize), 6440, 6446, 6456,
+ /*6456*/ uint16(x86_xSetOp), uint16(x86_MOVZX),
+ /*6458*/ uint16(x86_xReadSlashR),
+ /*6459*/ uint16(x86_xArgR64),
+ /*6460*/ uint16(x86_xArgRM16),
+ /*6461*/ uint16(x86_xMatch),
+ /*6462*/ uint16(x86_xCondIs64), 6465, 6485,
+ /*6465*/ uint16(x86_xCondPrefix), 1,
+ 0xF3, 6469,
+ /*6469*/ uint16(x86_xCondDataSize), 6473, 6479, 0,
+ /*6473*/ uint16(x86_xSetOp), uint16(x86_POPCNT),
+ /*6475*/ uint16(x86_xReadSlashR),
+ /*6476*/ uint16(x86_xArgR16),
+ /*6477*/ uint16(x86_xArgRM16),
+ /*6478*/ uint16(x86_xMatch),
+ /*6479*/ uint16(x86_xSetOp), uint16(x86_POPCNT),
+ /*6481*/ uint16(x86_xReadSlashR),
+ /*6482*/ uint16(x86_xArgR32),
+ /*6483*/ uint16(x86_xArgRM32),
+ /*6484*/ uint16(x86_xMatch),
+ /*6485*/ uint16(x86_xCondPrefix), 1,
+ 0xF3, 6489,
+ /*6489*/ uint16(x86_xCondDataSize), 6473, 6479, 6493,
+ /*6493*/ uint16(x86_xSetOp), uint16(x86_POPCNT),
+ /*6495*/ uint16(x86_xReadSlashR),
+ /*6496*/ uint16(x86_xArgR64),
+ /*6497*/ uint16(x86_xArgRM64),
+ /*6498*/ uint16(x86_xMatch),
+ /*6499*/ uint16(x86_xSetOp), uint16(x86_UD1),
+ /*6501*/ uint16(x86_xMatch),
+ /*6502*/ uint16(x86_xCondSlashR),
+ 0, // 0
+ 0, // 1
+ 0, // 2
+ 0, // 3
+ 6511, // 4
+ 6540, // 5
+ 6569, // 6
+ 6598, // 7
+ /*6511*/ uint16(x86_xCondIs64), 6514, 6530,
+ /*6514*/ uint16(x86_xCondDataSize), 6518, 6524, 0,
+ /*6518*/ uint16(x86_xSetOp), uint16(x86_BT),
+ /*6520*/ uint16(x86_xReadIb),
+ /*6521*/ uint16(x86_xArgRM16),
+ /*6522*/ uint16(x86_xArgImm8u),
+ /*6523*/ uint16(x86_xMatch),
+ /*6524*/ uint16(x86_xSetOp), uint16(x86_BT),
+ /*6526*/ uint16(x86_xReadIb),
+ /*6527*/ uint16(x86_xArgRM32),
+ /*6528*/ uint16(x86_xArgImm8u),
+ /*6529*/ uint16(x86_xMatch),
+ /*6530*/ uint16(x86_xCondDataSize), 6518, 6524, 6534,
+ /*6534*/ uint16(x86_xSetOp), uint16(x86_BT),
+ /*6536*/ uint16(x86_xReadIb),
+ /*6537*/ uint16(x86_xArgRM64),
+ /*6538*/ uint16(x86_xArgImm8u),
+ /*6539*/ uint16(x86_xMatch),
+ /*6540*/ uint16(x86_xCondIs64), 6543, 6559,
+ /*6543*/ uint16(x86_xCondDataSize), 6547, 6553, 0,
+ /*6547*/ uint16(x86_xSetOp), uint16(x86_BTS),
+ /*6549*/ uint16(x86_xReadIb),
+ /*6550*/ uint16(x86_xArgRM16),
+ /*6551*/ uint16(x86_xArgImm8u),
+ /*6552*/ uint16(x86_xMatch),
+ /*6553*/ uint16(x86_xSetOp), uint16(x86_BTS),
+ /*6555*/ uint16(x86_xReadIb),
+ /*6556*/ uint16(x86_xArgRM32),
+ /*6557*/ uint16(x86_xArgImm8u),
+ /*6558*/ uint16(x86_xMatch),
+ /*6559*/ uint16(x86_xCondDataSize), 6547, 6553, 6563,
+ /*6563*/ uint16(x86_xSetOp), uint16(x86_BTS),
+ /*6565*/ uint16(x86_xReadIb),
+ /*6566*/ uint16(x86_xArgRM64),
+ /*6567*/ uint16(x86_xArgImm8u),
+ /*6568*/ uint16(x86_xMatch),
+ /*6569*/ uint16(x86_xCondIs64), 6572, 6588,
+ /*6572*/ uint16(x86_xCondDataSize), 6576, 6582, 0,
+ /*6576*/ uint16(x86_xSetOp), uint16(x86_BTR),
+ /*6578*/ uint16(x86_xReadIb),
+ /*6579*/ uint16(x86_xArgRM16),
+ /*6580*/ uint16(x86_xArgImm8u),
+ /*6581*/ uint16(x86_xMatch),
+ /*6582*/ uint16(x86_xSetOp), uint16(x86_BTR),
+ /*6584*/ uint16(x86_xReadIb),
+ /*6585*/ uint16(x86_xArgRM32),
+ /*6586*/ uint16(x86_xArgImm8u),
+ /*6587*/ uint16(x86_xMatch),
+ /*6588*/ uint16(x86_xCondDataSize), 6576, 6582, 6592,
+ /*6592*/ uint16(x86_xSetOp), uint16(x86_BTR),
+ /*6594*/ uint16(x86_xReadIb),
+ /*6595*/ uint16(x86_xArgRM64),
+ /*6596*/ uint16(x86_xArgImm8u),
+ /*6597*/ uint16(x86_xMatch),
+ /*6598*/ uint16(x86_xCondIs64), 6601, 6617,
+ /*6601*/ uint16(x86_xCondDataSize), 6605, 6611, 0,
+ /*6605*/ uint16(x86_xSetOp), uint16(x86_BTC),
+ /*6607*/ uint16(x86_xReadIb),
+ /*6608*/ uint16(x86_xArgRM16),
+ /*6609*/ uint16(x86_xArgImm8u),
+ /*6610*/ uint16(x86_xMatch),
+ /*6611*/ uint16(x86_xSetOp), uint16(x86_BTC),
+ /*6613*/ uint16(x86_xReadIb),
+ /*6614*/ uint16(x86_xArgRM32),
+ /*6615*/ uint16(x86_xArgImm8u),
+ /*6616*/ uint16(x86_xMatch),
+ /*6617*/ uint16(x86_xCondDataSize), 6605, 6611, 6621,
+ /*6621*/ uint16(x86_xSetOp), uint16(x86_BTC),
+ /*6623*/ uint16(x86_xReadIb),
+ /*6624*/ uint16(x86_xArgRM64),
+ /*6625*/ uint16(x86_xArgImm8u),
+ /*6626*/ uint16(x86_xMatch),
+ /*6627*/ uint16(x86_xCondIs64), 6630, 6646,
+ /*6630*/ uint16(x86_xCondDataSize), 6634, 6640, 0,
+ /*6634*/ uint16(x86_xSetOp), uint16(x86_BTC),
+ /*6636*/ uint16(x86_xReadSlashR),
+ /*6637*/ uint16(x86_xArgRM16),
+ /*6638*/ uint16(x86_xArgR16),
+ /*6639*/ uint16(x86_xMatch),
+ /*6640*/ uint16(x86_xSetOp), uint16(x86_BTC),
+ /*6642*/ uint16(x86_xReadSlashR),
+ /*6643*/ uint16(x86_xArgRM32),
+ /*6644*/ uint16(x86_xArgR32),
+ /*6645*/ uint16(x86_xMatch),
+ /*6646*/ uint16(x86_xCondDataSize), 6634, 6640, 6650,
+ /*6650*/ uint16(x86_xSetOp), uint16(x86_BTC),
+ /*6652*/ uint16(x86_xReadSlashR),
+ /*6653*/ uint16(x86_xArgRM64),
+ /*6654*/ uint16(x86_xArgR64),
+ /*6655*/ uint16(x86_xMatch),
+ /*6656*/ uint16(x86_xCondIs64), 6659, 6697,
+ /*6659*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6681,
+ 0x0, 6665,
+ /*6665*/ uint16(x86_xCondDataSize), 6669, 6675, 0,
+ /*6669*/ uint16(x86_xSetOp), uint16(x86_BSF),
+ /*6671*/ uint16(x86_xReadSlashR),
+ /*6672*/ uint16(x86_xArgR16),
+ /*6673*/ uint16(x86_xArgRM16),
+ /*6674*/ uint16(x86_xMatch),
+ /*6675*/ uint16(x86_xSetOp), uint16(x86_BSF),
+ /*6677*/ uint16(x86_xReadSlashR),
+ /*6678*/ uint16(x86_xArgR32),
+ /*6679*/ uint16(x86_xArgRM32),
+ /*6680*/ uint16(x86_xMatch),
+ /*6681*/ uint16(x86_xCondDataSize), 6685, 6691, 0,
+ /*6685*/ uint16(x86_xSetOp), uint16(x86_TZCNT),
+ /*6687*/ uint16(x86_xReadSlashR),
+ /*6688*/ uint16(x86_xArgR16),
+ /*6689*/ uint16(x86_xArgRM16),
+ /*6690*/ uint16(x86_xMatch),
+ /*6691*/ uint16(x86_xSetOp), uint16(x86_TZCNT),
+ /*6693*/ uint16(x86_xReadSlashR),
+ /*6694*/ uint16(x86_xArgR32),
+ /*6695*/ uint16(x86_xArgRM32),
+ /*6696*/ uint16(x86_xMatch),
+ /*6697*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6713,
+ 0x0, 6703,
+ /*6703*/ uint16(x86_xCondDataSize), 6669, 6675, 6707,
+ /*6707*/ uint16(x86_xSetOp), uint16(x86_BSF),
+ /*6709*/ uint16(x86_xReadSlashR),
+ /*6710*/ uint16(x86_xArgR64),
+ /*6711*/ uint16(x86_xArgRM64),
+ /*6712*/ uint16(x86_xMatch),
+ /*6713*/ uint16(x86_xCondDataSize), 6685, 6691, 6717,
+ /*6717*/ uint16(x86_xSetOp), uint16(x86_TZCNT),
+ /*6719*/ uint16(x86_xReadSlashR),
+ /*6720*/ uint16(x86_xArgR64),
+ /*6721*/ uint16(x86_xArgRM64),
+ /*6722*/ uint16(x86_xMatch),
+ /*6723*/ uint16(x86_xCondIs64), 6726, 6764,
+ /*6726*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6748,
+ 0x0, 6732,
+ /*6732*/ uint16(x86_xCondDataSize), 6736, 6742, 0,
+ /*6736*/ uint16(x86_xSetOp), uint16(x86_BSR),
+ /*6738*/ uint16(x86_xReadSlashR),
+ /*6739*/ uint16(x86_xArgR16),
+ /*6740*/ uint16(x86_xArgRM16),
+ /*6741*/ uint16(x86_xMatch),
+ /*6742*/ uint16(x86_xSetOp), uint16(x86_BSR),
+ /*6744*/ uint16(x86_xReadSlashR),
+ /*6745*/ uint16(x86_xArgR32),
+ /*6746*/ uint16(x86_xArgRM32),
+ /*6747*/ uint16(x86_xMatch),
+ /*6748*/ uint16(x86_xCondDataSize), 6752, 6758, 0,
+ /*6752*/ uint16(x86_xSetOp), uint16(x86_LZCNT),
+ /*6754*/ uint16(x86_xReadSlashR),
+ /*6755*/ uint16(x86_xArgR16),
+ /*6756*/ uint16(x86_xArgRM16),
+ /*6757*/ uint16(x86_xMatch),
+ /*6758*/ uint16(x86_xSetOp), uint16(x86_LZCNT),
+ /*6760*/ uint16(x86_xReadSlashR),
+ /*6761*/ uint16(x86_xArgR32),
+ /*6762*/ uint16(x86_xArgRM32),
+ /*6763*/ uint16(x86_xMatch),
+ /*6764*/ uint16(x86_xCondPrefix), 2,
+ 0xF3, 6780,
+ 0x0, 6770,
+ /*6770*/ uint16(x86_xCondDataSize), 6736, 6742, 6774,
+ /*6774*/ uint16(x86_xSetOp), uint16(x86_BSR),
+ /*6776*/ uint16(x86_xReadSlashR),
+ /*6777*/ uint16(x86_xArgR64),
+ /*6778*/ uint16(x86_xArgRM64),
+ /*6779*/ uint16(x86_xMatch),
+ /*6780*/ uint16(x86_xCondDataSize), 6752, 6758, 6784,
+ /*6784*/ uint16(x86_xSetOp), uint16(x86_LZCNT),
+ /*6786*/ uint16(x86_xReadSlashR),
+ /*6787*/ uint16(x86_xArgR64),
+ /*6788*/ uint16(x86_xArgRM64),
+ /*6789*/ uint16(x86_xMatch),
+ /*6790*/ uint16(x86_xCondIs64), 6793, 6809,
+ /*6793*/ uint16(x86_xCondDataSize), 6797, 6803, 0,
+ /*6797*/ uint16(x86_xSetOp), uint16(x86_MOVSX),
+ /*6799*/ uint16(x86_xReadSlashR),
+ /*6800*/ uint16(x86_xArgR16),
+ /*6801*/ uint16(x86_xArgRM8),
+ /*6802*/ uint16(x86_xMatch),
+ /*6803*/ uint16(x86_xSetOp), uint16(x86_MOVSX),
+ /*6805*/ uint16(x86_xReadSlashR),
+ /*6806*/ uint16(x86_xArgR32),
+ /*6807*/ uint16(x86_xArgRM8),
+ /*6808*/ uint16(x86_xMatch),
+ /*6809*/ uint16(x86_xCondDataSize), 6797, 6803, 6813,
+ /*6813*/ uint16(x86_xSetOp), uint16(x86_MOVSX),
+ /*6815*/ uint16(x86_xReadSlashR),
+ /*6816*/ uint16(x86_xArgR64),
+ /*6817*/ uint16(x86_xArgRM8),
+ /*6818*/ uint16(x86_xMatch),
+ /*6819*/ uint16(x86_xCondIs64), 6822, 6838,
+ /*6822*/ uint16(x86_xCondDataSize), 6826, 6832, 0,
+ /*6826*/ uint16(x86_xSetOp), uint16(x86_MOVSX),
+ /*6828*/ uint16(x86_xReadSlashR),
+ /*6829*/ uint16(x86_xArgR16),
+ /*6830*/ uint16(x86_xArgRM16),
+ /*6831*/ uint16(x86_xMatch),
+ /*6832*/ uint16(x86_xSetOp), uint16(x86_MOVSX),
+ /*6834*/ uint16(x86_xReadSlashR),
+ /*6835*/ uint16(x86_xArgR32),
+ /*6836*/ uint16(x86_xArgRM16),
+ /*6837*/ uint16(x86_xMatch),
+ /*6838*/ uint16(x86_xCondDataSize), 6826, 6832, 6842,
+ /*6842*/ uint16(x86_xSetOp), uint16(x86_MOVSX),
+ /*6844*/ uint16(x86_xReadSlashR),
+ /*6845*/ uint16(x86_xArgR64),
+ /*6846*/ uint16(x86_xArgRM16),
+ /*6847*/ uint16(x86_xMatch),
+ /*6848*/ uint16(x86_xSetOp), uint16(x86_XADD),
+ /*6850*/ uint16(x86_xReadSlashR),
+ /*6851*/ uint16(x86_xArgRM8),
+ /*6852*/ uint16(x86_xArgR8),
+ /*6853*/ uint16(x86_xMatch),
+ /*6854*/ uint16(x86_xCondIs64), 6857, 6873,
+ /*6857*/ uint16(x86_xCondDataSize), 6861, 6867, 0,
+ /*6861*/ uint16(x86_xSetOp), uint16(x86_XADD),
+ /*6863*/ uint16(x86_xReadSlashR),
+ /*6864*/ uint16(x86_xArgRM16),
+ /*6865*/ uint16(x86_xArgR16),
+ /*6866*/ uint16(x86_xMatch),
+ /*6867*/ uint16(x86_xSetOp), uint16(x86_XADD),
+ /*6869*/ uint16(x86_xReadSlashR),
+ /*6870*/ uint16(x86_xArgRM32),
+ /*6871*/ uint16(x86_xArgR32),
+ /*6872*/ uint16(x86_xMatch),
+ /*6873*/ uint16(x86_xCondDataSize), 6861, 6867, 6877,
+ /*6877*/ uint16(x86_xSetOp), uint16(x86_XADD),
+ /*6879*/ uint16(x86_xReadSlashR),
+ /*6880*/ uint16(x86_xArgRM64),
+ /*6881*/ uint16(x86_xArgR64),
+ /*6882*/ uint16(x86_xMatch),
+ /*6883*/ uint16(x86_xCondPrefix), 4,
+ 0xF3, 6917,
+ 0xF2, 6909,
+ 0x66, 6901,
+ 0x0, 6893,
+ /*6893*/ uint16(x86_xSetOp), uint16(x86_CMPPS),
+ /*6895*/ uint16(x86_xReadSlashR),
+ /*6896*/ uint16(x86_xReadIb),
+ /*6897*/ uint16(x86_xArgXmm1),
+ /*6898*/ uint16(x86_xArgXmm2M128),
+ /*6899*/ uint16(x86_xArgImm8u),
+ /*6900*/ uint16(x86_xMatch),
+ /*6901*/ uint16(x86_xSetOp), uint16(x86_CMPPD),
+ /*6903*/ uint16(x86_xReadSlashR),
+ /*6904*/ uint16(x86_xReadIb),
+ /*6905*/ uint16(x86_xArgXmm1),
+ /*6906*/ uint16(x86_xArgXmm2M128),
+ /*6907*/ uint16(x86_xArgImm8u),
+ /*6908*/ uint16(x86_xMatch),
+ /*6909*/ uint16(x86_xSetOp), uint16(x86_CMPSD_XMM),
+ /*6911*/ uint16(x86_xReadSlashR),
+ /*6912*/ uint16(x86_xReadIb),
+ /*6913*/ uint16(x86_xArgXmm1),
+ /*6914*/ uint16(x86_xArgXmm2M64),
+ /*6915*/ uint16(x86_xArgImm8u),
+ /*6916*/ uint16(x86_xMatch),
+ /*6917*/ uint16(x86_xSetOp), uint16(x86_CMPSS),
+ /*6919*/ uint16(x86_xReadSlashR),
+ /*6920*/ uint16(x86_xReadIb),
+ /*6921*/ uint16(x86_xArgXmm1),
+ /*6922*/ uint16(x86_xArgXmm2M32),
+ /*6923*/ uint16(x86_xArgImm8u),
+ /*6924*/ uint16(x86_xMatch),
+ /*6925*/ uint16(x86_xCondIs64), 6928, 6944,
+ /*6928*/ uint16(x86_xCondDataSize), 6932, 6938, 0,
+ /*6932*/ uint16(x86_xSetOp), uint16(x86_MOVNTI),
+ /*6934*/ uint16(x86_xReadSlashR),
+ /*6935*/ uint16(x86_xArgM32),
+ /*6936*/ uint16(x86_xArgR32),
+ /*6937*/ uint16(x86_xMatch),
+ /*6938*/ uint16(x86_xSetOp), uint16(x86_MOVNTI),
+ /*6940*/ uint16(x86_xReadSlashR),
+ /*6941*/ uint16(x86_xArgM32),
+ /*6942*/ uint16(x86_xArgR32),
+ /*6943*/ uint16(x86_xMatch),
+ /*6944*/ uint16(x86_xCondDataSize), 6932, 6938, 6948,
+ /*6948*/ uint16(x86_xSetOp), uint16(x86_MOVNTI),
+ /*6950*/ uint16(x86_xReadSlashR),
+ /*6951*/ uint16(x86_xArgM64),
+ /*6952*/ uint16(x86_xArgR64),
+ /*6953*/ uint16(x86_xMatch),
+ /*6954*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 6968,
+ 0x0, 6960,
+ /*6960*/ uint16(x86_xSetOp), uint16(x86_PINSRW),
+ /*6962*/ uint16(x86_xReadSlashR),
+ /*6963*/ uint16(x86_xReadIb),
+ /*6964*/ uint16(x86_xArgMm),
+ /*6965*/ uint16(x86_xArgR32M16),
+ /*6966*/ uint16(x86_xArgImm8u),
+ /*6967*/ uint16(x86_xMatch),
+ /*6968*/ uint16(x86_xSetOp), uint16(x86_PINSRW),
+ /*6970*/ uint16(x86_xReadSlashR),
+ /*6971*/ uint16(x86_xReadIb),
+ /*6972*/ uint16(x86_xArgXmm),
+ /*6973*/ uint16(x86_xArgR32M16),
+ /*6974*/ uint16(x86_xArgImm8u),
+ /*6975*/ uint16(x86_xMatch),
+ /*6976*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 6990,
+ 0x0, 6982,
+ /*6982*/ uint16(x86_xSetOp), uint16(x86_PEXTRW),
+ /*6984*/ uint16(x86_xReadSlashR),
+ /*6985*/ uint16(x86_xReadIb),
+ /*6986*/ uint16(x86_xArgR32),
+ /*6987*/ uint16(x86_xArgMm2),
+ /*6988*/ uint16(x86_xArgImm8u),
+ /*6989*/ uint16(x86_xMatch),
+ /*6990*/ uint16(x86_xSetOp), uint16(x86_PEXTRW),
+ /*6992*/ uint16(x86_xReadSlashR),
+ /*6993*/ uint16(x86_xReadIb),
+ /*6994*/ uint16(x86_xArgR32),
+ /*6995*/ uint16(x86_xArgXmm2),
+ /*6996*/ uint16(x86_xArgImm8u),
+ /*6997*/ uint16(x86_xMatch),
+ /*6998*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7012,
+ 0x0, 7004,
+ /*7004*/ uint16(x86_xSetOp), uint16(x86_SHUFPS),
+ /*7006*/ uint16(x86_xReadSlashR),
+ /*7007*/ uint16(x86_xReadIb),
+ /*7008*/ uint16(x86_xArgXmm1),
+ /*7009*/ uint16(x86_xArgXmm2M128),
+ /*7010*/ uint16(x86_xArgImm8u),
+ /*7011*/ uint16(x86_xMatch),
+ /*7012*/ uint16(x86_xSetOp), uint16(x86_SHUFPD),
+ /*7014*/ uint16(x86_xReadSlashR),
+ /*7015*/ uint16(x86_xReadIb),
+ /*7016*/ uint16(x86_xArgXmm1),
+ /*7017*/ uint16(x86_xArgXmm2M128),
+ /*7018*/ uint16(x86_xArgImm8u),
+ /*7019*/ uint16(x86_xMatch),
+ /*7020*/ uint16(x86_xCondSlashR),
+ 0, // 0
+ 7029, // 1
+ 0, // 2
+ 7052, // 3
+ 7075, // 4
+ 7098, // 5
+ 7121, // 6
+ 0, // 7
+ /*7029*/ uint16(x86_xCondIs64), 7032, 7044,
+ /*7032*/ uint16(x86_xCondDataSize), 7036, 7040, 0,
+ /*7036*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG8B),
+ /*7038*/ uint16(x86_xArgM64),
+ /*7039*/ uint16(x86_xMatch),
+ /*7040*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG8B),
+ /*7042*/ uint16(x86_xArgM64),
+ /*7043*/ uint16(x86_xMatch),
+ /*7044*/ uint16(x86_xCondDataSize), 7036, 7040, 7048,
+ /*7048*/ uint16(x86_xSetOp), uint16(x86_CMPXCHG16B),
+ /*7050*/ uint16(x86_xArgM128),
+ /*7051*/ uint16(x86_xMatch),
+ /*7052*/ uint16(x86_xCondIs64), 7055, 7067,
+ /*7055*/ uint16(x86_xCondDataSize), 7059, 7063, 0,
+ /*7059*/ uint16(x86_xSetOp), uint16(x86_XRSTORS),
+ /*7061*/ uint16(x86_xArgMem),
+ /*7062*/ uint16(x86_xMatch),
+ /*7063*/ uint16(x86_xSetOp), uint16(x86_XRSTORS),
+ /*7065*/ uint16(x86_xArgMem),
+ /*7066*/ uint16(x86_xMatch),
+ /*7067*/ uint16(x86_xCondDataSize), 7059, 7063, 7071,
+ /*7071*/ uint16(x86_xSetOp), uint16(x86_XRSTORS64),
+ /*7073*/ uint16(x86_xArgMem),
+ /*7074*/ uint16(x86_xMatch),
+ /*7075*/ uint16(x86_xCondIs64), 7078, 7090,
+ /*7078*/ uint16(x86_xCondDataSize), 7082, 7086, 0,
+ /*7082*/ uint16(x86_xSetOp), uint16(x86_XSAVEC),
+ /*7084*/ uint16(x86_xArgMem),
+ /*7085*/ uint16(x86_xMatch),
+ /*7086*/ uint16(x86_xSetOp), uint16(x86_XSAVEC),
+ /*7088*/ uint16(x86_xArgMem),
+ /*7089*/ uint16(x86_xMatch),
+ /*7090*/ uint16(x86_xCondDataSize), 7082, 7086, 7094,
+ /*7094*/ uint16(x86_xSetOp), uint16(x86_XSAVEC64),
+ /*7096*/ uint16(x86_xArgMem),
+ /*7097*/ uint16(x86_xMatch),
+ /*7098*/ uint16(x86_xCondIs64), 7101, 7113,
+ /*7101*/ uint16(x86_xCondDataSize), 7105, 7109, 0,
+ /*7105*/ uint16(x86_xSetOp), uint16(x86_XSAVES),
+ /*7107*/ uint16(x86_xArgMem),
+ /*7108*/ uint16(x86_xMatch),
+ /*7109*/ uint16(x86_xSetOp), uint16(x86_XSAVES),
+ /*7111*/ uint16(x86_xArgMem),
+ /*7112*/ uint16(x86_xMatch),
+ /*7113*/ uint16(x86_xCondDataSize), 7105, 7109, 7117,
+ /*7117*/ uint16(x86_xSetOp), uint16(x86_XSAVES64),
+ /*7119*/ uint16(x86_xArgMem),
+ /*7120*/ uint16(x86_xMatch),
+ /*7121*/ uint16(x86_xCondIs64), 7124, 7142,
+ /*7124*/ uint16(x86_xCondDataSize), 7128, 7135, 0,
+ /*7128*/ uint16(x86_xCondIsMem), 7131, 0,
+ /*7131*/ uint16(x86_xSetOp), uint16(x86_RDRAND),
+ /*7133*/ uint16(x86_xArgRmf16),
+ /*7134*/ uint16(x86_xMatch),
+ /*7135*/ uint16(x86_xCondIsMem), 7138, 0,
+ /*7138*/ uint16(x86_xSetOp), uint16(x86_RDRAND),
+ /*7140*/ uint16(x86_xArgRmf32),
+ /*7141*/ uint16(x86_xMatch),
+ /*7142*/ uint16(x86_xCondDataSize), 7128, 7135, 7146,
+ /*7146*/ uint16(x86_xSetOp), uint16(x86_RDRAND),
+ /*7148*/ uint16(x86_xMatch),
+ /*7149*/ uint16(x86_xCondIs64), 7152, 7164,
+ /*7152*/ uint16(x86_xCondDataSize), 7156, 7160, 0,
+ /*7156*/ uint16(x86_xSetOp), uint16(x86_BSWAP),
+ /*7158*/ uint16(x86_xArgR16op),
+ /*7159*/ uint16(x86_xMatch),
+ /*7160*/ uint16(x86_xSetOp), uint16(x86_BSWAP),
+ /*7162*/ uint16(x86_xArgR32op),
+ /*7163*/ uint16(x86_xMatch),
+ /*7164*/ uint16(x86_xCondDataSize), 7156, 7160, 7168,
+ /*7168*/ uint16(x86_xSetOp), uint16(x86_BSWAP),
+ /*7170*/ uint16(x86_xArgR64op),
+ /*7171*/ uint16(x86_xMatch),
+ /*7172*/ uint16(x86_xCondPrefix), 2,
+ 0xF2, 7184,
+ 0x66, 7178,
+ /*7178*/ uint16(x86_xSetOp), uint16(x86_ADDSUBPD),
+ /*7180*/ uint16(x86_xReadSlashR),
+ /*7181*/ uint16(x86_xArgXmm1),
+ /*7182*/ uint16(x86_xArgXmm2M128),
+ /*7183*/ uint16(x86_xMatch),
+ /*7184*/ uint16(x86_xSetOp), uint16(x86_ADDSUBPS),
+ /*7186*/ uint16(x86_xReadSlashR),
+ /*7187*/ uint16(x86_xArgXmm1),
+ /*7188*/ uint16(x86_xArgXmm2M128),
+ /*7189*/ uint16(x86_xMatch),
+ /*7190*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7202,
+ 0x0, 7196,
+ /*7196*/ uint16(x86_xSetOp), uint16(x86_PSRLW),
+ /*7198*/ uint16(x86_xReadSlashR),
+ /*7199*/ uint16(x86_xArgMm),
+ /*7200*/ uint16(x86_xArgMmM64),
+ /*7201*/ uint16(x86_xMatch),
+ /*7202*/ uint16(x86_xSetOp), uint16(x86_PSRLW),
+ /*7204*/ uint16(x86_xReadSlashR),
+ /*7205*/ uint16(x86_xArgXmm1),
+ /*7206*/ uint16(x86_xArgXmm2M128),
+ /*7207*/ uint16(x86_xMatch),
+ /*7208*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7220,
+ 0x0, 7214,
+ /*7214*/ uint16(x86_xSetOp), uint16(x86_PSRLD),
+ /*7216*/ uint16(x86_xReadSlashR),
+ /*7217*/ uint16(x86_xArgMm),
+ /*7218*/ uint16(x86_xArgMmM64),
+ /*7219*/ uint16(x86_xMatch),
+ /*7220*/ uint16(x86_xSetOp), uint16(x86_PSRLD),
+ /*7222*/ uint16(x86_xReadSlashR),
+ /*7223*/ uint16(x86_xArgXmm1),
+ /*7224*/ uint16(x86_xArgXmm2M128),
+ /*7225*/ uint16(x86_xMatch),
+ /*7226*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7238,
+ 0x0, 7232,
+ /*7232*/ uint16(x86_xSetOp), uint16(x86_PSRLQ),
+ /*7234*/ uint16(x86_xReadSlashR),
+ /*7235*/ uint16(x86_xArgMm),
+ /*7236*/ uint16(x86_xArgMmM64),
+ /*7237*/ uint16(x86_xMatch),
+ /*7238*/ uint16(x86_xSetOp), uint16(x86_PSRLQ),
+ /*7240*/ uint16(x86_xReadSlashR),
+ /*7241*/ uint16(x86_xArgXmm1),
+ /*7242*/ uint16(x86_xArgXmm2M128),
+ /*7243*/ uint16(x86_xMatch),
+ /*7244*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7256,
+ 0x0, 7250,
+ /*7250*/ uint16(x86_xSetOp), uint16(x86_PADDQ),
+ /*7252*/ uint16(x86_xReadSlashR),
+ /*7253*/ uint16(x86_xArgMm1),
+ /*7254*/ uint16(x86_xArgMm2M64),
+ /*7255*/ uint16(x86_xMatch),
+ /*7256*/ uint16(x86_xSetOp), uint16(x86_PADDQ),
+ /*7258*/ uint16(x86_xReadSlashR),
+ /*7259*/ uint16(x86_xArgXmm1),
+ /*7260*/ uint16(x86_xArgXmm2M128),
+ /*7261*/ uint16(x86_xMatch),
+ /*7262*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7274,
+ 0x0, 7268,
+ /*7268*/ uint16(x86_xSetOp), uint16(x86_PMULLW),
+ /*7270*/ uint16(x86_xReadSlashR),
+ /*7271*/ uint16(x86_xArgMm),
+ /*7272*/ uint16(x86_xArgMmM64),
+ /*7273*/ uint16(x86_xMatch),
+ /*7274*/ uint16(x86_xSetOp), uint16(x86_PMULLW),
+ /*7276*/ uint16(x86_xReadSlashR),
+ /*7277*/ uint16(x86_xArgXmm1),
+ /*7278*/ uint16(x86_xArgXmm2M128),
+ /*7279*/ uint16(x86_xMatch),
+ /*7280*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 7300,
+ 0xF2, 7294,
+ 0x66, 7288,
+ /*7288*/ uint16(x86_xSetOp), uint16(x86_MOVQ),
+ /*7290*/ uint16(x86_xReadSlashR),
+ /*7291*/ uint16(x86_xArgXmm2M64),
+ /*7292*/ uint16(x86_xArgXmm1),
+ /*7293*/ uint16(x86_xMatch),
+ /*7294*/ uint16(x86_xSetOp), uint16(x86_MOVDQ2Q),
+ /*7296*/ uint16(x86_xReadSlashR),
+ /*7297*/ uint16(x86_xArgMm),
+ /*7298*/ uint16(x86_xArgXmm2),
+ /*7299*/ uint16(x86_xMatch),
+ /*7300*/ uint16(x86_xSetOp), uint16(x86_MOVQ2DQ),
+ /*7302*/ uint16(x86_xReadSlashR),
+ /*7303*/ uint16(x86_xArgXmm1),
+ /*7304*/ uint16(x86_xArgMm2),
+ /*7305*/ uint16(x86_xMatch),
+ /*7306*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7318,
+ 0x0, 7312,
+ /*7312*/ uint16(x86_xSetOp), uint16(x86_PMOVMSKB),
+ /*7314*/ uint16(x86_xReadSlashR),
+ /*7315*/ uint16(x86_xArgR32),
+ /*7316*/ uint16(x86_xArgMm2),
+ /*7317*/ uint16(x86_xMatch),
+ /*7318*/ uint16(x86_xSetOp), uint16(x86_PMOVMSKB),
+ /*7320*/ uint16(x86_xReadSlashR),
+ /*7321*/ uint16(x86_xArgR32),
+ /*7322*/ uint16(x86_xArgXmm2),
+ /*7323*/ uint16(x86_xMatch),
+ /*7324*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7336,
+ 0x0, 7330,
+ /*7330*/ uint16(x86_xSetOp), uint16(x86_PSUBUSB),
+ /*7332*/ uint16(x86_xReadSlashR),
+ /*7333*/ uint16(x86_xArgMm),
+ /*7334*/ uint16(x86_xArgMmM64),
+ /*7335*/ uint16(x86_xMatch),
+ /*7336*/ uint16(x86_xSetOp), uint16(x86_PSUBUSB),
+ /*7338*/ uint16(x86_xReadSlashR),
+ /*7339*/ uint16(x86_xArgXmm1),
+ /*7340*/ uint16(x86_xArgXmm2M128),
+ /*7341*/ uint16(x86_xMatch),
+ /*7342*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7354,
+ 0x0, 7348,
+ /*7348*/ uint16(x86_xSetOp), uint16(x86_PSUBUSW),
+ /*7350*/ uint16(x86_xReadSlashR),
+ /*7351*/ uint16(x86_xArgMm),
+ /*7352*/ uint16(x86_xArgMmM64),
+ /*7353*/ uint16(x86_xMatch),
+ /*7354*/ uint16(x86_xSetOp), uint16(x86_PSUBUSW),
+ /*7356*/ uint16(x86_xReadSlashR),
+ /*7357*/ uint16(x86_xArgXmm1),
+ /*7358*/ uint16(x86_xArgXmm2M128),
+ /*7359*/ uint16(x86_xMatch),
+ /*7360*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7372,
+ 0x0, 7366,
+ /*7366*/ uint16(x86_xSetOp), uint16(x86_PMINUB),
+ /*7368*/ uint16(x86_xReadSlashR),
+ /*7369*/ uint16(x86_xArgMm1),
+ /*7370*/ uint16(x86_xArgMm2M64),
+ /*7371*/ uint16(x86_xMatch),
+ /*7372*/ uint16(x86_xSetOp), uint16(x86_PMINUB),
+ /*7374*/ uint16(x86_xReadSlashR),
+ /*7375*/ uint16(x86_xArgXmm1),
+ /*7376*/ uint16(x86_xArgXmm2M128),
+ /*7377*/ uint16(x86_xMatch),
+ /*7378*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7390,
+ 0x0, 7384,
+ /*7384*/ uint16(x86_xSetOp), uint16(x86_PAND),
+ /*7386*/ uint16(x86_xReadSlashR),
+ /*7387*/ uint16(x86_xArgMm),
+ /*7388*/ uint16(x86_xArgMmM64),
+ /*7389*/ uint16(x86_xMatch),
+ /*7390*/ uint16(x86_xSetOp), uint16(x86_PAND),
+ /*7392*/ uint16(x86_xReadSlashR),
+ /*7393*/ uint16(x86_xArgXmm1),
+ /*7394*/ uint16(x86_xArgXmm2M128),
+ /*7395*/ uint16(x86_xMatch),
+ /*7396*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7408,
+ 0x0, 7402,
+ /*7402*/ uint16(x86_xSetOp), uint16(x86_PADDUSB),
+ /*7404*/ uint16(x86_xReadSlashR),
+ /*7405*/ uint16(x86_xArgMm),
+ /*7406*/ uint16(x86_xArgMmM64),
+ /*7407*/ uint16(x86_xMatch),
+ /*7408*/ uint16(x86_xSetOp), uint16(x86_PADDUSB),
+ /*7410*/ uint16(x86_xReadSlashR),
+ /*7411*/ uint16(x86_xArgXmm1),
+ /*7412*/ uint16(x86_xArgXmm2M128),
+ /*7413*/ uint16(x86_xMatch),
+ /*7414*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7426,
+ 0x0, 7420,
+ /*7420*/ uint16(x86_xSetOp), uint16(x86_PADDUSW),
+ /*7422*/ uint16(x86_xReadSlashR),
+ /*7423*/ uint16(x86_xArgMm),
+ /*7424*/ uint16(x86_xArgMmM64),
+ /*7425*/ uint16(x86_xMatch),
+ /*7426*/ uint16(x86_xSetOp), uint16(x86_PADDUSW),
+ /*7428*/ uint16(x86_xReadSlashR),
+ /*7429*/ uint16(x86_xArgXmm1),
+ /*7430*/ uint16(x86_xArgXmm2M128),
+ /*7431*/ uint16(x86_xMatch),
+ /*7432*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7444,
+ 0x0, 7438,
+ /*7438*/ uint16(x86_xSetOp), uint16(x86_PMAXUB),
+ /*7440*/ uint16(x86_xReadSlashR),
+ /*7441*/ uint16(x86_xArgMm1),
+ /*7442*/ uint16(x86_xArgMm2M64),
+ /*7443*/ uint16(x86_xMatch),
+ /*7444*/ uint16(x86_xSetOp), uint16(x86_PMAXUB),
+ /*7446*/ uint16(x86_xReadSlashR),
+ /*7447*/ uint16(x86_xArgXmm1),
+ /*7448*/ uint16(x86_xArgXmm2M128),
+ /*7449*/ uint16(x86_xMatch),
+ /*7450*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7462,
+ 0x0, 7456,
+ /*7456*/ uint16(x86_xSetOp), uint16(x86_PANDN),
+ /*7458*/ uint16(x86_xReadSlashR),
+ /*7459*/ uint16(x86_xArgMm),
+ /*7460*/ uint16(x86_xArgMmM64),
+ /*7461*/ uint16(x86_xMatch),
+ /*7462*/ uint16(x86_xSetOp), uint16(x86_PANDN),
+ /*7464*/ uint16(x86_xReadSlashR),
+ /*7465*/ uint16(x86_xArgXmm1),
+ /*7466*/ uint16(x86_xArgXmm2M128),
+ /*7467*/ uint16(x86_xMatch),
+ /*7468*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7480,
+ 0x0, 7474,
+ /*7474*/ uint16(x86_xSetOp), uint16(x86_PAVGB),
+ /*7476*/ uint16(x86_xReadSlashR),
+ /*7477*/ uint16(x86_xArgMm1),
+ /*7478*/ uint16(x86_xArgMm2M64),
+ /*7479*/ uint16(x86_xMatch),
+ /*7480*/ uint16(x86_xSetOp), uint16(x86_PAVGB),
+ /*7482*/ uint16(x86_xReadSlashR),
+ /*7483*/ uint16(x86_xArgXmm1),
+ /*7484*/ uint16(x86_xArgXmm2M128),
+ /*7485*/ uint16(x86_xMatch),
+ /*7486*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7498,
+ 0x0, 7492,
+ /*7492*/ uint16(x86_xSetOp), uint16(x86_PSRAW),
+ /*7494*/ uint16(x86_xReadSlashR),
+ /*7495*/ uint16(x86_xArgMm),
+ /*7496*/ uint16(x86_xArgMmM64),
+ /*7497*/ uint16(x86_xMatch),
+ /*7498*/ uint16(x86_xSetOp), uint16(x86_PSRAW),
+ /*7500*/ uint16(x86_xReadSlashR),
+ /*7501*/ uint16(x86_xArgXmm1),
+ /*7502*/ uint16(x86_xArgXmm2M128),
+ /*7503*/ uint16(x86_xMatch),
+ /*7504*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7516,
+ 0x0, 7510,
+ /*7510*/ uint16(x86_xSetOp), uint16(x86_PSRAD),
+ /*7512*/ uint16(x86_xReadSlashR),
+ /*7513*/ uint16(x86_xArgMm),
+ /*7514*/ uint16(x86_xArgMmM64),
+ /*7515*/ uint16(x86_xMatch),
+ /*7516*/ uint16(x86_xSetOp), uint16(x86_PSRAD),
+ /*7518*/ uint16(x86_xReadSlashR),
+ /*7519*/ uint16(x86_xArgXmm1),
+ /*7520*/ uint16(x86_xArgXmm2M128),
+ /*7521*/ uint16(x86_xMatch),
+ /*7522*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7534,
+ 0x0, 7528,
+ /*7528*/ uint16(x86_xSetOp), uint16(x86_PAVGW),
+ /*7530*/ uint16(x86_xReadSlashR),
+ /*7531*/ uint16(x86_xArgMm1),
+ /*7532*/ uint16(x86_xArgMm2M64),
+ /*7533*/ uint16(x86_xMatch),
+ /*7534*/ uint16(x86_xSetOp), uint16(x86_PAVGW),
+ /*7536*/ uint16(x86_xReadSlashR),
+ /*7537*/ uint16(x86_xArgXmm1),
+ /*7538*/ uint16(x86_xArgXmm2M128),
+ /*7539*/ uint16(x86_xMatch),
+ /*7540*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7552,
+ 0x0, 7546,
+ /*7546*/ uint16(x86_xSetOp), uint16(x86_PMULHUW),
+ /*7548*/ uint16(x86_xReadSlashR),
+ /*7549*/ uint16(x86_xArgMm1),
+ /*7550*/ uint16(x86_xArgMm2M64),
+ /*7551*/ uint16(x86_xMatch),
+ /*7552*/ uint16(x86_xSetOp), uint16(x86_PMULHUW),
+ /*7554*/ uint16(x86_xReadSlashR),
+ /*7555*/ uint16(x86_xArgXmm1),
+ /*7556*/ uint16(x86_xArgXmm2M128),
+ /*7557*/ uint16(x86_xMatch),
+ /*7558*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7570,
+ 0x0, 7564,
+ /*7564*/ uint16(x86_xSetOp), uint16(x86_PMULHW),
+ /*7566*/ uint16(x86_xReadSlashR),
+ /*7567*/ uint16(x86_xArgMm),
+ /*7568*/ uint16(x86_xArgMmM64),
+ /*7569*/ uint16(x86_xMatch),
+ /*7570*/ uint16(x86_xSetOp), uint16(x86_PMULHW),
+ /*7572*/ uint16(x86_xReadSlashR),
+ /*7573*/ uint16(x86_xArgXmm1),
+ /*7574*/ uint16(x86_xArgXmm2M128),
+ /*7575*/ uint16(x86_xMatch),
+ /*7576*/ uint16(x86_xCondPrefix), 3,
+ 0xF3, 7596,
+ 0xF2, 7590,
+ 0x66, 7584,
+ /*7584*/ uint16(x86_xSetOp), uint16(x86_CVTTPD2DQ),
+ /*7586*/ uint16(x86_xReadSlashR),
+ /*7587*/ uint16(x86_xArgXmm1),
+ /*7588*/ uint16(x86_xArgXmm2M128),
+ /*7589*/ uint16(x86_xMatch),
+ /*7590*/ uint16(x86_xSetOp), uint16(x86_CVTPD2DQ),
+ /*7592*/ uint16(x86_xReadSlashR),
+ /*7593*/ uint16(x86_xArgXmm1),
+ /*7594*/ uint16(x86_xArgXmm2M128),
+ /*7595*/ uint16(x86_xMatch),
+ /*7596*/ uint16(x86_xSetOp), uint16(x86_CVTDQ2PD),
+ /*7598*/ uint16(x86_xReadSlashR),
+ /*7599*/ uint16(x86_xArgXmm1),
+ /*7600*/ uint16(x86_xArgXmm2M64),
+ /*7601*/ uint16(x86_xMatch),
+ /*7602*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7614,
+ 0x0, 7608,
+ /*7608*/ uint16(x86_xSetOp), uint16(x86_MOVNTQ),
+ /*7610*/ uint16(x86_xReadSlashR),
+ /*7611*/ uint16(x86_xArgM64),
+ /*7612*/ uint16(x86_xArgMm),
+ /*7613*/ uint16(x86_xMatch),
+ /*7614*/ uint16(x86_xSetOp), uint16(x86_MOVNTDQ),
+ /*7616*/ uint16(x86_xReadSlashR),
+ /*7617*/ uint16(x86_xArgM128),
+ /*7618*/ uint16(x86_xArgXmm),
+ /*7619*/ uint16(x86_xMatch),
+ /*7620*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7632,
+ 0x0, 7626,
+ /*7626*/ uint16(x86_xSetOp), uint16(x86_PSUBSB),
+ /*7628*/ uint16(x86_xReadSlashR),
+ /*7629*/ uint16(x86_xArgMm),
+ /*7630*/ uint16(x86_xArgMmM64),
+ /*7631*/ uint16(x86_xMatch),
+ /*7632*/ uint16(x86_xSetOp), uint16(x86_PSUBSB),
+ /*7634*/ uint16(x86_xReadSlashR),
+ /*7635*/ uint16(x86_xArgXmm1),
+ /*7636*/ uint16(x86_xArgXmm2M128),
+ /*7637*/ uint16(x86_xMatch),
+ /*7638*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7650,
+ 0x0, 7644,
+ /*7644*/ uint16(x86_xSetOp), uint16(x86_PSUBSW),
+ /*7646*/ uint16(x86_xReadSlashR),
+ /*7647*/ uint16(x86_xArgMm),
+ /*7648*/ uint16(x86_xArgMmM64),
+ /*7649*/ uint16(x86_xMatch),
+ /*7650*/ uint16(x86_xSetOp), uint16(x86_PSUBSW),
+ /*7652*/ uint16(x86_xReadSlashR),
+ /*7653*/ uint16(x86_xArgXmm1),
+ /*7654*/ uint16(x86_xArgXmm2M128),
+ /*7655*/ uint16(x86_xMatch),
+ /*7656*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7668,
+ 0x0, 7662,
+ /*7662*/ uint16(x86_xSetOp), uint16(x86_PMINSW),
+ /*7664*/ uint16(x86_xReadSlashR),
+ /*7665*/ uint16(x86_xArgMm1),
+ /*7666*/ uint16(x86_xArgMm2M64),
+ /*7667*/ uint16(x86_xMatch),
+ /*7668*/ uint16(x86_xSetOp), uint16(x86_PMINSW),
+ /*7670*/ uint16(x86_xReadSlashR),
+ /*7671*/ uint16(x86_xArgXmm1),
+ /*7672*/ uint16(x86_xArgXmm2M128),
+ /*7673*/ uint16(x86_xMatch),
+ /*7674*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7686,
+ 0x0, 7680,
+ /*7680*/ uint16(x86_xSetOp), uint16(x86_POR),
+ /*7682*/ uint16(x86_xReadSlashR),
+ /*7683*/ uint16(x86_xArgMm),
+ /*7684*/ uint16(x86_xArgMmM64),
+ /*7685*/ uint16(x86_xMatch),
+ /*7686*/ uint16(x86_xSetOp), uint16(x86_POR),
+ /*7688*/ uint16(x86_xReadSlashR),
+ /*7689*/ uint16(x86_xArgXmm1),
+ /*7690*/ uint16(x86_xArgXmm2M128),
+ /*7691*/ uint16(x86_xMatch),
+ /*7692*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7704,
+ 0x0, 7698,
+ /*7698*/ uint16(x86_xSetOp), uint16(x86_PADDSB),
+ /*7700*/ uint16(x86_xReadSlashR),
+ /*7701*/ uint16(x86_xArgMm),
+ /*7702*/ uint16(x86_xArgMmM64),
+ /*7703*/ uint16(x86_xMatch),
+ /*7704*/ uint16(x86_xSetOp), uint16(x86_PADDSB),
+ /*7706*/ uint16(x86_xReadSlashR),
+ /*7707*/ uint16(x86_xArgXmm1),
+ /*7708*/ uint16(x86_xArgXmm2M128),
+ /*7709*/ uint16(x86_xMatch),
+ /*7710*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7722,
+ 0x0, 7716,
+ /*7716*/ uint16(x86_xSetOp), uint16(x86_PADDSW),
+ /*7718*/ uint16(x86_xReadSlashR),
+ /*7719*/ uint16(x86_xArgMm),
+ /*7720*/ uint16(x86_xArgMmM64),
+ /*7721*/ uint16(x86_xMatch),
+ /*7722*/ uint16(x86_xSetOp), uint16(x86_PADDSW),
+ /*7724*/ uint16(x86_xReadSlashR),
+ /*7725*/ uint16(x86_xArgXmm1),
+ /*7726*/ uint16(x86_xArgXmm2M128),
+ /*7727*/ uint16(x86_xMatch),
+ /*7728*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7740,
+ 0x0, 7734,
+ /*7734*/ uint16(x86_xSetOp), uint16(x86_PMAXSW),
+ /*7736*/ uint16(x86_xReadSlashR),
+ /*7737*/ uint16(x86_xArgMm1),
+ /*7738*/ uint16(x86_xArgMm2M64),
+ /*7739*/ uint16(x86_xMatch),
+ /*7740*/ uint16(x86_xSetOp), uint16(x86_PMAXSW),
+ /*7742*/ uint16(x86_xReadSlashR),
+ /*7743*/ uint16(x86_xArgXmm1),
+ /*7744*/ uint16(x86_xArgXmm2M128),
+ /*7745*/ uint16(x86_xMatch),
+ /*7746*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7758,
+ 0x0, 7752,
+ /*7752*/ uint16(x86_xSetOp), uint16(x86_PXOR),
+ /*7754*/ uint16(x86_xReadSlashR),
+ /*7755*/ uint16(x86_xArgMm),
+ /*7756*/ uint16(x86_xArgMmM64),
+ /*7757*/ uint16(x86_xMatch),
+ /*7758*/ uint16(x86_xSetOp), uint16(x86_PXOR),
+ /*7760*/ uint16(x86_xReadSlashR),
+ /*7761*/ uint16(x86_xArgXmm1),
+ /*7762*/ uint16(x86_xArgXmm2M128),
+ /*7763*/ uint16(x86_xMatch),
+ /*7764*/ uint16(x86_xCondPrefix), 1,
+ 0xF2, 7768,
+ /*7768*/ uint16(x86_xSetOp), uint16(x86_LDDQU),
+ /*7770*/ uint16(x86_xReadSlashR),
+ /*7771*/ uint16(x86_xArgXmm1),
+ /*7772*/ uint16(x86_xArgM128),
+ /*7773*/ uint16(x86_xMatch),
+ /*7774*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7786,
+ 0x0, 7780,
+ /*7780*/ uint16(x86_xSetOp), uint16(x86_PSLLW),
+ /*7782*/ uint16(x86_xReadSlashR),
+ /*7783*/ uint16(x86_xArgMm),
+ /*7784*/ uint16(x86_xArgMmM64),
+ /*7785*/ uint16(x86_xMatch),
+ /*7786*/ uint16(x86_xSetOp), uint16(x86_PSLLW),
+ /*7788*/ uint16(x86_xReadSlashR),
+ /*7789*/ uint16(x86_xArgXmm1),
+ /*7790*/ uint16(x86_xArgXmm2M128),
+ /*7791*/ uint16(x86_xMatch),
+ /*7792*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7804,
+ 0x0, 7798,
+ /*7798*/ uint16(x86_xSetOp), uint16(x86_PSLLD),
+ /*7800*/ uint16(x86_xReadSlashR),
+ /*7801*/ uint16(x86_xArgMm),
+ /*7802*/ uint16(x86_xArgMmM64),
+ /*7803*/ uint16(x86_xMatch),
+ /*7804*/ uint16(x86_xSetOp), uint16(x86_PSLLD),
+ /*7806*/ uint16(x86_xReadSlashR),
+ /*7807*/ uint16(x86_xArgXmm1),
+ /*7808*/ uint16(x86_xArgXmm2M128),
+ /*7809*/ uint16(x86_xMatch),
+ /*7810*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7822,
+ 0x0, 7816,
+ /*7816*/ uint16(x86_xSetOp), uint16(x86_PSLLQ),
+ /*7818*/ uint16(x86_xReadSlashR),
+ /*7819*/ uint16(x86_xArgMm),
+ /*7820*/ uint16(x86_xArgMmM64),
+ /*7821*/ uint16(x86_xMatch),
+ /*7822*/ uint16(x86_xSetOp), uint16(x86_PSLLQ),
+ /*7824*/ uint16(x86_xReadSlashR),
+ /*7825*/ uint16(x86_xArgXmm1),
+ /*7826*/ uint16(x86_xArgXmm2M128),
+ /*7827*/ uint16(x86_xMatch),
+ /*7828*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7840,
+ 0x0, 7834,
+ /*7834*/ uint16(x86_xSetOp), uint16(x86_PMULUDQ),
+ /*7836*/ uint16(x86_xReadSlashR),
+ /*7837*/ uint16(x86_xArgMm1),
+ /*7838*/ uint16(x86_xArgMm2M64),
+ /*7839*/ uint16(x86_xMatch),
+ /*7840*/ uint16(x86_xSetOp), uint16(x86_PMULUDQ),
+ /*7842*/ uint16(x86_xReadSlashR),
+ /*7843*/ uint16(x86_xArgXmm1),
+ /*7844*/ uint16(x86_xArgXmm2M128),
+ /*7845*/ uint16(x86_xMatch),
+ /*7846*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7858,
+ 0x0, 7852,
+ /*7852*/ uint16(x86_xSetOp), uint16(x86_PMADDWD),
+ /*7854*/ uint16(x86_xReadSlashR),
+ /*7855*/ uint16(x86_xArgMm),
+ /*7856*/ uint16(x86_xArgMmM64),
+ /*7857*/ uint16(x86_xMatch),
+ /*7858*/ uint16(x86_xSetOp), uint16(x86_PMADDWD),
+ /*7860*/ uint16(x86_xReadSlashR),
+ /*7861*/ uint16(x86_xArgXmm1),
+ /*7862*/ uint16(x86_xArgXmm2M128),
+ /*7863*/ uint16(x86_xMatch),
+ /*7864*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7876,
+ 0x0, 7870,
+ /*7870*/ uint16(x86_xSetOp), uint16(x86_PSADBW),
+ /*7872*/ uint16(x86_xReadSlashR),
+ /*7873*/ uint16(x86_xArgMm1),
+ /*7874*/ uint16(x86_xArgMm2M64),
+ /*7875*/ uint16(x86_xMatch),
+ /*7876*/ uint16(x86_xSetOp), uint16(x86_PSADBW),
+ /*7878*/ uint16(x86_xReadSlashR),
+ /*7879*/ uint16(x86_xArgXmm1),
+ /*7880*/ uint16(x86_xArgXmm2M128),
+ /*7881*/ uint16(x86_xMatch),
+ /*7882*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7894,
+ 0x0, 7888,
+ /*7888*/ uint16(x86_xSetOp), uint16(x86_MASKMOVQ),
+ /*7890*/ uint16(x86_xReadSlashR),
+ /*7891*/ uint16(x86_xArgMm1),
+ /*7892*/ uint16(x86_xArgMm2),
+ /*7893*/ uint16(x86_xMatch),
+ /*7894*/ uint16(x86_xSetOp), uint16(x86_MASKMOVDQU),
+ /*7896*/ uint16(x86_xReadSlashR),
+ /*7897*/ uint16(x86_xArgXmm1),
+ /*7898*/ uint16(x86_xArgXmm2),
+ /*7899*/ uint16(x86_xMatch),
+ /*7900*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7912,
+ 0x0, 7906,
+ /*7906*/ uint16(x86_xSetOp), uint16(x86_PSUBB),
+ /*7908*/ uint16(x86_xReadSlashR),
+ /*7909*/ uint16(x86_xArgMm),
+ /*7910*/ uint16(x86_xArgMmM64),
+ /*7911*/ uint16(x86_xMatch),
+ /*7912*/ uint16(x86_xSetOp), uint16(x86_PSUBB),
+ /*7914*/ uint16(x86_xReadSlashR),
+ /*7915*/ uint16(x86_xArgXmm1),
+ /*7916*/ uint16(x86_xArgXmm2M128),
+ /*7917*/ uint16(x86_xMatch),
+ /*7918*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7930,
+ 0x0, 7924,
+ /*7924*/ uint16(x86_xSetOp), uint16(x86_PSUBW),
+ /*7926*/ uint16(x86_xReadSlashR),
+ /*7927*/ uint16(x86_xArgMm),
+ /*7928*/ uint16(x86_xArgMmM64),
+ /*7929*/ uint16(x86_xMatch),
+ /*7930*/ uint16(x86_xSetOp), uint16(x86_PSUBW),
+ /*7932*/ uint16(x86_xReadSlashR),
+ /*7933*/ uint16(x86_xArgXmm1),
+ /*7934*/ uint16(x86_xArgXmm2M128),
+ /*7935*/ uint16(x86_xMatch),
+ /*7936*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7948,
+ 0x0, 7942,
+ /*7942*/ uint16(x86_xSetOp), uint16(x86_PSUBD),
+ /*7944*/ uint16(x86_xReadSlashR),
+ /*7945*/ uint16(x86_xArgMm),
+ /*7946*/ uint16(x86_xArgMmM64),
+ /*7947*/ uint16(x86_xMatch),
+ /*7948*/ uint16(x86_xSetOp), uint16(x86_PSUBD),
+ /*7950*/ uint16(x86_xReadSlashR),
+ /*7951*/ uint16(x86_xArgXmm1),
+ /*7952*/ uint16(x86_xArgXmm2M128),
+ /*7953*/ uint16(x86_xMatch),
+ /*7954*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7966,
+ 0x0, 7960,
+ /*7960*/ uint16(x86_xSetOp), uint16(x86_PSUBQ),
+ /*7962*/ uint16(x86_xReadSlashR),
+ /*7963*/ uint16(x86_xArgMm1),
+ /*7964*/ uint16(x86_xArgMm2M64),
+ /*7965*/ uint16(x86_xMatch),
+ /*7966*/ uint16(x86_xSetOp), uint16(x86_PSUBQ),
+ /*7968*/ uint16(x86_xReadSlashR),
+ /*7969*/ uint16(x86_xArgXmm1),
+ /*7970*/ uint16(x86_xArgXmm2M128),
+ /*7971*/ uint16(x86_xMatch),
+ /*7972*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 7984,
+ 0x0, 7978,
+ /*7978*/ uint16(x86_xSetOp), uint16(x86_PADDB),
+ /*7980*/ uint16(x86_xReadSlashR),
+ /*7981*/ uint16(x86_xArgMm),
+ /*7982*/ uint16(x86_xArgMmM64),
+ /*7983*/ uint16(x86_xMatch),
+ /*7984*/ uint16(x86_xSetOp), uint16(x86_PADDB),
+ /*7986*/ uint16(x86_xReadSlashR),
+ /*7987*/ uint16(x86_xArgXmm1),
+ /*7988*/ uint16(x86_xArgXmm2M128),
+ /*7989*/ uint16(x86_xMatch),
+ /*7990*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 8002,
+ 0x0, 7996,
+ /*7996*/ uint16(x86_xSetOp), uint16(x86_PADDW),
+ /*7998*/ uint16(x86_xReadSlashR),
+ /*7999*/ uint16(x86_xArgMm),
+ /*8000*/ uint16(x86_xArgMmM64),
+ /*8001*/ uint16(x86_xMatch),
+ /*8002*/ uint16(x86_xSetOp), uint16(x86_PADDW),
+ /*8004*/ uint16(x86_xReadSlashR),
+ /*8005*/ uint16(x86_xArgXmm1),
+ /*8006*/ uint16(x86_xArgXmm2M128),
+ /*8007*/ uint16(x86_xMatch),
+ /*8008*/ uint16(x86_xCondPrefix), 2,
+ 0x66, 8020,
+ 0x0, 8014,
+ /*8014*/ uint16(x86_xSetOp), uint16(x86_PADDD),
+ /*8016*/ uint16(x86_xReadSlashR),
+ /*8017*/ uint16(x86_xArgMm),
+ /*8018*/ uint16(x86_xArgMmM64),
+ /*8019*/ uint16(x86_xMatch),
+ /*8020*/ uint16(x86_xSetOp), uint16(x86_PADDD),
+ /*8022*/ uint16(x86_xReadSlashR),
+ /*8023*/ uint16(x86_xArgXmm1),
+ /*8024*/ uint16(x86_xArgXmm2M128),
+ /*8025*/ uint16(x86_xMatch),
+ /*8026*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8028*/ uint16(x86_xReadSlashR),
+ /*8029*/ uint16(x86_xArgRM8),
+ /*8030*/ uint16(x86_xArgR8),
+ /*8031*/ uint16(x86_xMatch),
+ /*8032*/ uint16(x86_xCondIs64), 8035, 8051,
+ /*8035*/ uint16(x86_xCondDataSize), 8039, 8045, 0,
+ /*8039*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8041*/ uint16(x86_xReadSlashR),
+ /*8042*/ uint16(x86_xArgRM16),
+ /*8043*/ uint16(x86_xArgR16),
+ /*8044*/ uint16(x86_xMatch),
+ /*8045*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8047*/ uint16(x86_xReadSlashR),
+ /*8048*/ uint16(x86_xArgRM32),
+ /*8049*/ uint16(x86_xArgR32),
+ /*8050*/ uint16(x86_xMatch),
+ /*8051*/ uint16(x86_xCondDataSize), 8039, 8045, 8055,
+ /*8055*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8057*/ uint16(x86_xReadSlashR),
+ /*8058*/ uint16(x86_xArgRM64),
+ /*8059*/ uint16(x86_xArgR64),
+ /*8060*/ uint16(x86_xMatch),
+ /*8061*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8063*/ uint16(x86_xReadSlashR),
+ /*8064*/ uint16(x86_xArgR8),
+ /*8065*/ uint16(x86_xArgRM8),
+ /*8066*/ uint16(x86_xMatch),
+ /*8067*/ uint16(x86_xCondIs64), 8070, 8086,
+ /*8070*/ uint16(x86_xCondDataSize), 8074, 8080, 0,
+ /*8074*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8076*/ uint16(x86_xReadSlashR),
+ /*8077*/ uint16(x86_xArgR16),
+ /*8078*/ uint16(x86_xArgRM16),
+ /*8079*/ uint16(x86_xMatch),
+ /*8080*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8082*/ uint16(x86_xReadSlashR),
+ /*8083*/ uint16(x86_xArgR32),
+ /*8084*/ uint16(x86_xArgRM32),
+ /*8085*/ uint16(x86_xMatch),
+ /*8086*/ uint16(x86_xCondDataSize), 8074, 8080, 8090,
+ /*8090*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8092*/ uint16(x86_xReadSlashR),
+ /*8093*/ uint16(x86_xArgR64),
+ /*8094*/ uint16(x86_xArgRM64),
+ /*8095*/ uint16(x86_xMatch),
+ /*8096*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8098*/ uint16(x86_xReadIb),
+ /*8099*/ uint16(x86_xArgAL),
+ /*8100*/ uint16(x86_xArgImm8u),
+ /*8101*/ uint16(x86_xMatch),
+ /*8102*/ uint16(x86_xCondIs64), 8105, 8121,
+ /*8105*/ uint16(x86_xCondDataSize), 8109, 8115, 0,
+ /*8109*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8111*/ uint16(x86_xReadIw),
+ /*8112*/ uint16(x86_xArgAX),
+ /*8113*/ uint16(x86_xArgImm16),
+ /*8114*/ uint16(x86_xMatch),
+ /*8115*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8117*/ uint16(x86_xReadId),
+ /*8118*/ uint16(x86_xArgEAX),
+ /*8119*/ uint16(x86_xArgImm32),
+ /*8120*/ uint16(x86_xMatch),
+ /*8121*/ uint16(x86_xCondDataSize), 8109, 8115, 8125,
+ /*8125*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*8127*/ uint16(x86_xReadId),
+ /*8128*/ uint16(x86_xArgRAX),
+ /*8129*/ uint16(x86_xArgImm32),
+ /*8130*/ uint16(x86_xMatch),
+ /*8131*/ uint16(x86_xCondIs64), 8134, 0,
+ /*8134*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8136*/ uint16(x86_xArgSS),
+ /*8137*/ uint16(x86_xMatch),
+ /*8138*/ uint16(x86_xCondIs64), 8141, 0,
+ /*8141*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*8143*/ uint16(x86_xArgSS),
+ /*8144*/ uint16(x86_xMatch),
+ /*8145*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8147*/ uint16(x86_xReadSlashR),
+ /*8148*/ uint16(x86_xArgRM8),
+ /*8149*/ uint16(x86_xArgR8),
+ /*8150*/ uint16(x86_xMatch),
+ /*8151*/ uint16(x86_xCondIs64), 8154, 8170,
+ /*8154*/ uint16(x86_xCondDataSize), 8158, 8164, 0,
+ /*8158*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8160*/ uint16(x86_xReadSlashR),
+ /*8161*/ uint16(x86_xArgRM16),
+ /*8162*/ uint16(x86_xArgR16),
+ /*8163*/ uint16(x86_xMatch),
+ /*8164*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8166*/ uint16(x86_xReadSlashR),
+ /*8167*/ uint16(x86_xArgRM32),
+ /*8168*/ uint16(x86_xArgR32),
+ /*8169*/ uint16(x86_xMatch),
+ /*8170*/ uint16(x86_xCondDataSize), 8158, 8164, 8174,
+ /*8174*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8176*/ uint16(x86_xReadSlashR),
+ /*8177*/ uint16(x86_xArgRM64),
+ /*8178*/ uint16(x86_xArgR64),
+ /*8179*/ uint16(x86_xMatch),
+ /*8180*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8182*/ uint16(x86_xReadSlashR),
+ /*8183*/ uint16(x86_xArgR8),
+ /*8184*/ uint16(x86_xArgRM8),
+ /*8185*/ uint16(x86_xMatch),
+ /*8186*/ uint16(x86_xCondIs64), 8189, 8205,
+ /*8189*/ uint16(x86_xCondDataSize), 8193, 8199, 0,
+ /*8193*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8195*/ uint16(x86_xReadSlashR),
+ /*8196*/ uint16(x86_xArgR16),
+ /*8197*/ uint16(x86_xArgRM16),
+ /*8198*/ uint16(x86_xMatch),
+ /*8199*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8201*/ uint16(x86_xReadSlashR),
+ /*8202*/ uint16(x86_xArgR32),
+ /*8203*/ uint16(x86_xArgRM32),
+ /*8204*/ uint16(x86_xMatch),
+ /*8205*/ uint16(x86_xCondDataSize), 8193, 8199, 8209,
+ /*8209*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8211*/ uint16(x86_xReadSlashR),
+ /*8212*/ uint16(x86_xArgR64),
+ /*8213*/ uint16(x86_xArgRM64),
+ /*8214*/ uint16(x86_xMatch),
+ /*8215*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8217*/ uint16(x86_xReadIb),
+ /*8218*/ uint16(x86_xArgAL),
+ /*8219*/ uint16(x86_xArgImm8u),
+ /*8220*/ uint16(x86_xMatch),
+ /*8221*/ uint16(x86_xCondIs64), 8224, 8240,
+ /*8224*/ uint16(x86_xCondDataSize), 8228, 8234, 0,
+ /*8228*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8230*/ uint16(x86_xReadIw),
+ /*8231*/ uint16(x86_xArgAX),
+ /*8232*/ uint16(x86_xArgImm16),
+ /*8233*/ uint16(x86_xMatch),
+ /*8234*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8236*/ uint16(x86_xReadId),
+ /*8237*/ uint16(x86_xArgEAX),
+ /*8238*/ uint16(x86_xArgImm32),
+ /*8239*/ uint16(x86_xMatch),
+ /*8240*/ uint16(x86_xCondDataSize), 8228, 8234, 8244,
+ /*8244*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*8246*/ uint16(x86_xReadId),
+ /*8247*/ uint16(x86_xArgRAX),
+ /*8248*/ uint16(x86_xArgImm32),
+ /*8249*/ uint16(x86_xMatch),
+ /*8250*/ uint16(x86_xCondIs64), 8253, 0,
+ /*8253*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8255*/ uint16(x86_xArgDS),
+ /*8256*/ uint16(x86_xMatch),
+ /*8257*/ uint16(x86_xCondIs64), 8260, 0,
+ /*8260*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*8262*/ uint16(x86_xArgDS),
+ /*8263*/ uint16(x86_xMatch),
+ /*8264*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8266*/ uint16(x86_xReadSlashR),
+ /*8267*/ uint16(x86_xArgRM8),
+ /*8268*/ uint16(x86_xArgR8),
+ /*8269*/ uint16(x86_xMatch),
+ /*8270*/ uint16(x86_xCondIs64), 8273, 8289,
+ /*8273*/ uint16(x86_xCondDataSize), 8277, 8283, 0,
+ /*8277*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8279*/ uint16(x86_xReadSlashR),
+ /*8280*/ uint16(x86_xArgRM16),
+ /*8281*/ uint16(x86_xArgR16),
+ /*8282*/ uint16(x86_xMatch),
+ /*8283*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8285*/ uint16(x86_xReadSlashR),
+ /*8286*/ uint16(x86_xArgRM32),
+ /*8287*/ uint16(x86_xArgR32),
+ /*8288*/ uint16(x86_xMatch),
+ /*8289*/ uint16(x86_xCondDataSize), 8277, 8283, 8293,
+ /*8293*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8295*/ uint16(x86_xReadSlashR),
+ /*8296*/ uint16(x86_xArgRM64),
+ /*8297*/ uint16(x86_xArgR64),
+ /*8298*/ uint16(x86_xMatch),
+ /*8299*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8301*/ uint16(x86_xReadSlashR),
+ /*8302*/ uint16(x86_xArgR8),
+ /*8303*/ uint16(x86_xArgRM8),
+ /*8304*/ uint16(x86_xMatch),
+ /*8305*/ uint16(x86_xCondIs64), 8308, 8324,
+ /*8308*/ uint16(x86_xCondDataSize), 8312, 8318, 0,
+ /*8312*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8314*/ uint16(x86_xReadSlashR),
+ /*8315*/ uint16(x86_xArgR16),
+ /*8316*/ uint16(x86_xArgRM16),
+ /*8317*/ uint16(x86_xMatch),
+ /*8318*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8320*/ uint16(x86_xReadSlashR),
+ /*8321*/ uint16(x86_xArgR32),
+ /*8322*/ uint16(x86_xArgRM32),
+ /*8323*/ uint16(x86_xMatch),
+ /*8324*/ uint16(x86_xCondDataSize), 8312, 8318, 8328,
+ /*8328*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8330*/ uint16(x86_xReadSlashR),
+ /*8331*/ uint16(x86_xArgR64),
+ /*8332*/ uint16(x86_xArgRM64),
+ /*8333*/ uint16(x86_xMatch),
+ /*8334*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8336*/ uint16(x86_xReadIb),
+ /*8337*/ uint16(x86_xArgAL),
+ /*8338*/ uint16(x86_xArgImm8u),
+ /*8339*/ uint16(x86_xMatch),
+ /*8340*/ uint16(x86_xCondIs64), 8343, 8359,
+ /*8343*/ uint16(x86_xCondDataSize), 8347, 8353, 0,
+ /*8347*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8349*/ uint16(x86_xReadIw),
+ /*8350*/ uint16(x86_xArgAX),
+ /*8351*/ uint16(x86_xArgImm16),
+ /*8352*/ uint16(x86_xMatch),
+ /*8353*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8355*/ uint16(x86_xReadId),
+ /*8356*/ uint16(x86_xArgEAX),
+ /*8357*/ uint16(x86_xArgImm32),
+ /*8358*/ uint16(x86_xMatch),
+ /*8359*/ uint16(x86_xCondDataSize), 8347, 8353, 8363,
+ /*8363*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*8365*/ uint16(x86_xReadId),
+ /*8366*/ uint16(x86_xArgRAX),
+ /*8367*/ uint16(x86_xArgImm32),
+ /*8368*/ uint16(x86_xMatch),
+ /*8369*/ uint16(x86_xCondIs64), 8372, 0,
+ /*8372*/ uint16(x86_xSetOp), uint16(x86_DAA),
+ /*8374*/ uint16(x86_xMatch),
+ /*8375*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8377*/ uint16(x86_xReadSlashR),
+ /*8378*/ uint16(x86_xArgRM8),
+ /*8379*/ uint16(x86_xArgR8),
+ /*8380*/ uint16(x86_xMatch),
+ /*8381*/ uint16(x86_xCondIs64), 8384, 8400,
+ /*8384*/ uint16(x86_xCondDataSize), 8388, 8394, 0,
+ /*8388*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8390*/ uint16(x86_xReadSlashR),
+ /*8391*/ uint16(x86_xArgRM16),
+ /*8392*/ uint16(x86_xArgR16),
+ /*8393*/ uint16(x86_xMatch),
+ /*8394*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8396*/ uint16(x86_xReadSlashR),
+ /*8397*/ uint16(x86_xArgRM32),
+ /*8398*/ uint16(x86_xArgR32),
+ /*8399*/ uint16(x86_xMatch),
+ /*8400*/ uint16(x86_xCondDataSize), 8388, 8394, 8404,
+ /*8404*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8406*/ uint16(x86_xReadSlashR),
+ /*8407*/ uint16(x86_xArgRM64),
+ /*8408*/ uint16(x86_xArgR64),
+ /*8409*/ uint16(x86_xMatch),
+ /*8410*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8412*/ uint16(x86_xReadSlashR),
+ /*8413*/ uint16(x86_xArgR8),
+ /*8414*/ uint16(x86_xArgRM8),
+ /*8415*/ uint16(x86_xMatch),
+ /*8416*/ uint16(x86_xCondIs64), 8419, 8435,
+ /*8419*/ uint16(x86_xCondDataSize), 8423, 8429, 0,
+ /*8423*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8425*/ uint16(x86_xReadSlashR),
+ /*8426*/ uint16(x86_xArgR16),
+ /*8427*/ uint16(x86_xArgRM16),
+ /*8428*/ uint16(x86_xMatch),
+ /*8429*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8431*/ uint16(x86_xReadSlashR),
+ /*8432*/ uint16(x86_xArgR32),
+ /*8433*/ uint16(x86_xArgRM32),
+ /*8434*/ uint16(x86_xMatch),
+ /*8435*/ uint16(x86_xCondDataSize), 8423, 8429, 8439,
+ /*8439*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8441*/ uint16(x86_xReadSlashR),
+ /*8442*/ uint16(x86_xArgR64),
+ /*8443*/ uint16(x86_xArgRM64),
+ /*8444*/ uint16(x86_xMatch),
+ /*8445*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8447*/ uint16(x86_xReadIb),
+ /*8448*/ uint16(x86_xArgAL),
+ /*8449*/ uint16(x86_xArgImm8u),
+ /*8450*/ uint16(x86_xMatch),
+ /*8451*/ uint16(x86_xCondIs64), 8454, 8470,
+ /*8454*/ uint16(x86_xCondDataSize), 8458, 8464, 0,
+ /*8458*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8460*/ uint16(x86_xReadIw),
+ /*8461*/ uint16(x86_xArgAX),
+ /*8462*/ uint16(x86_xArgImm16),
+ /*8463*/ uint16(x86_xMatch),
+ /*8464*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8466*/ uint16(x86_xReadId),
+ /*8467*/ uint16(x86_xArgEAX),
+ /*8468*/ uint16(x86_xArgImm32),
+ /*8469*/ uint16(x86_xMatch),
+ /*8470*/ uint16(x86_xCondDataSize), 8458, 8464, 8474,
+ /*8474*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*8476*/ uint16(x86_xReadId),
+ /*8477*/ uint16(x86_xArgRAX),
+ /*8478*/ uint16(x86_xArgImm32),
+ /*8479*/ uint16(x86_xMatch),
+ /*8480*/ uint16(x86_xCondIs64), 8483, 0,
+ /*8483*/ uint16(x86_xSetOp), uint16(x86_DAS),
+ /*8485*/ uint16(x86_xMatch),
+ /*8486*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8488*/ uint16(x86_xReadSlashR),
+ /*8489*/ uint16(x86_xArgRM8),
+ /*8490*/ uint16(x86_xArgR8),
+ /*8491*/ uint16(x86_xMatch),
+ /*8492*/ uint16(x86_xCondIs64), 8495, 8511,
+ /*8495*/ uint16(x86_xCondDataSize), 8499, 8505, 0,
+ /*8499*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8501*/ uint16(x86_xReadSlashR),
+ /*8502*/ uint16(x86_xArgRM16),
+ /*8503*/ uint16(x86_xArgR16),
+ /*8504*/ uint16(x86_xMatch),
+ /*8505*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8507*/ uint16(x86_xReadSlashR),
+ /*8508*/ uint16(x86_xArgRM32),
+ /*8509*/ uint16(x86_xArgR32),
+ /*8510*/ uint16(x86_xMatch),
+ /*8511*/ uint16(x86_xCondDataSize), 8499, 8505, 8515,
+ /*8515*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8517*/ uint16(x86_xReadSlashR),
+ /*8518*/ uint16(x86_xArgRM64),
+ /*8519*/ uint16(x86_xArgR64),
+ /*8520*/ uint16(x86_xMatch),
+ /*8521*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8523*/ uint16(x86_xReadSlashR),
+ /*8524*/ uint16(x86_xArgR8),
+ /*8525*/ uint16(x86_xArgRM8),
+ /*8526*/ uint16(x86_xMatch),
+ /*8527*/ uint16(x86_xCondIs64), 8530, 8546,
+ /*8530*/ uint16(x86_xCondDataSize), 8534, 8540, 0,
+ /*8534*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8536*/ uint16(x86_xReadSlashR),
+ /*8537*/ uint16(x86_xArgR16),
+ /*8538*/ uint16(x86_xArgRM16),
+ /*8539*/ uint16(x86_xMatch),
+ /*8540*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8542*/ uint16(x86_xReadSlashR),
+ /*8543*/ uint16(x86_xArgR32),
+ /*8544*/ uint16(x86_xArgRM32),
+ /*8545*/ uint16(x86_xMatch),
+ /*8546*/ uint16(x86_xCondDataSize), 8534, 8540, 8550,
+ /*8550*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8552*/ uint16(x86_xReadSlashR),
+ /*8553*/ uint16(x86_xArgR64),
+ /*8554*/ uint16(x86_xArgRM64),
+ /*8555*/ uint16(x86_xMatch),
+ /*8556*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8558*/ uint16(x86_xReadIb),
+ /*8559*/ uint16(x86_xArgAL),
+ /*8560*/ uint16(x86_xArgImm8u),
+ /*8561*/ uint16(x86_xMatch),
+ /*8562*/ uint16(x86_xCondIs64), 8565, 8581,
+ /*8565*/ uint16(x86_xCondDataSize), 8569, 8575, 0,
+ /*8569*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8571*/ uint16(x86_xReadIw),
+ /*8572*/ uint16(x86_xArgAX),
+ /*8573*/ uint16(x86_xArgImm16),
+ /*8574*/ uint16(x86_xMatch),
+ /*8575*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8577*/ uint16(x86_xReadId),
+ /*8578*/ uint16(x86_xArgEAX),
+ /*8579*/ uint16(x86_xArgImm32),
+ /*8580*/ uint16(x86_xMatch),
+ /*8581*/ uint16(x86_xCondDataSize), 8569, 8575, 8585,
+ /*8585*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*8587*/ uint16(x86_xReadId),
+ /*8588*/ uint16(x86_xArgRAX),
+ /*8589*/ uint16(x86_xArgImm32),
+ /*8590*/ uint16(x86_xMatch),
+ /*8591*/ uint16(x86_xCondIs64), 8594, 0,
+ /*8594*/ uint16(x86_xSetOp), uint16(x86_AAA),
+ /*8596*/ uint16(x86_xMatch),
+ /*8597*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8599*/ uint16(x86_xReadSlashR),
+ /*8600*/ uint16(x86_xArgRM8),
+ /*8601*/ uint16(x86_xArgR8),
+ /*8602*/ uint16(x86_xMatch),
+ /*8603*/ uint16(x86_xCondIs64), 8606, 8622,
+ /*8606*/ uint16(x86_xCondDataSize), 8610, 8616, 0,
+ /*8610*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8612*/ uint16(x86_xReadSlashR),
+ /*8613*/ uint16(x86_xArgRM16),
+ /*8614*/ uint16(x86_xArgR16),
+ /*8615*/ uint16(x86_xMatch),
+ /*8616*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8618*/ uint16(x86_xReadSlashR),
+ /*8619*/ uint16(x86_xArgRM32),
+ /*8620*/ uint16(x86_xArgR32),
+ /*8621*/ uint16(x86_xMatch),
+ /*8622*/ uint16(x86_xCondDataSize), 8610, 8616, 8626,
+ /*8626*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8628*/ uint16(x86_xReadSlashR),
+ /*8629*/ uint16(x86_xArgRM64),
+ /*8630*/ uint16(x86_xArgR64),
+ /*8631*/ uint16(x86_xMatch),
+ /*8632*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8634*/ uint16(x86_xReadSlashR),
+ /*8635*/ uint16(x86_xArgR8),
+ /*8636*/ uint16(x86_xArgRM8),
+ /*8637*/ uint16(x86_xMatch),
+ /*8638*/ uint16(x86_xCondIs64), 8641, 8657,
+ /*8641*/ uint16(x86_xCondDataSize), 8645, 8651, 0,
+ /*8645*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8647*/ uint16(x86_xReadSlashR),
+ /*8648*/ uint16(x86_xArgR16),
+ /*8649*/ uint16(x86_xArgRM16),
+ /*8650*/ uint16(x86_xMatch),
+ /*8651*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8653*/ uint16(x86_xReadSlashR),
+ /*8654*/ uint16(x86_xArgR32),
+ /*8655*/ uint16(x86_xArgRM32),
+ /*8656*/ uint16(x86_xMatch),
+ /*8657*/ uint16(x86_xCondDataSize), 8645, 8651, 8661,
+ /*8661*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8663*/ uint16(x86_xReadSlashR),
+ /*8664*/ uint16(x86_xArgR64),
+ /*8665*/ uint16(x86_xArgRM64),
+ /*8666*/ uint16(x86_xMatch),
+ /*8667*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8669*/ uint16(x86_xReadIb),
+ /*8670*/ uint16(x86_xArgAL),
+ /*8671*/ uint16(x86_xArgImm8u),
+ /*8672*/ uint16(x86_xMatch),
+ /*8673*/ uint16(x86_xCondIs64), 8676, 8692,
+ /*8676*/ uint16(x86_xCondDataSize), 8680, 8686, 0,
+ /*8680*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8682*/ uint16(x86_xReadIw),
+ /*8683*/ uint16(x86_xArgAX),
+ /*8684*/ uint16(x86_xArgImm16),
+ /*8685*/ uint16(x86_xMatch),
+ /*8686*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8688*/ uint16(x86_xReadId),
+ /*8689*/ uint16(x86_xArgEAX),
+ /*8690*/ uint16(x86_xArgImm32),
+ /*8691*/ uint16(x86_xMatch),
+ /*8692*/ uint16(x86_xCondDataSize), 8680, 8686, 8696,
+ /*8696*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*8698*/ uint16(x86_xReadId),
+ /*8699*/ uint16(x86_xArgRAX),
+ /*8700*/ uint16(x86_xArgImm32),
+ /*8701*/ uint16(x86_xMatch),
+ /*8702*/ uint16(x86_xCondIs64), 8705, 0,
+ /*8705*/ uint16(x86_xSetOp), uint16(x86_AAS),
+ /*8707*/ uint16(x86_xMatch),
+ /*8708*/ uint16(x86_xCondIs64), 8711, 0,
+ /*8711*/ uint16(x86_xCondDataSize), 8715, 8719, 0,
+ /*8715*/ uint16(x86_xSetOp), uint16(x86_INC),
+ /*8717*/ uint16(x86_xArgR16op),
+ /*8718*/ uint16(x86_xMatch),
+ /*8719*/ uint16(x86_xSetOp), uint16(x86_INC),
+ /*8721*/ uint16(x86_xArgR32op),
+ /*8722*/ uint16(x86_xMatch),
+ /*8723*/ uint16(x86_xCondIs64), 8726, 0,
+ /*8726*/ uint16(x86_xCondDataSize), 8730, 8734, 0,
+ /*8730*/ uint16(x86_xSetOp), uint16(x86_DEC),
+ /*8732*/ uint16(x86_xArgR16op),
+ /*8733*/ uint16(x86_xMatch),
+ /*8734*/ uint16(x86_xSetOp), uint16(x86_DEC),
+ /*8736*/ uint16(x86_xArgR32op),
+ /*8737*/ uint16(x86_xMatch),
+ /*8738*/ uint16(x86_xCondIs64), 8741, 8753,
+ /*8741*/ uint16(x86_xCondDataSize), 8745, 8749, 0,
+ /*8745*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8747*/ uint16(x86_xArgR16op),
+ /*8748*/ uint16(x86_xMatch),
+ /*8749*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8751*/ uint16(x86_xArgR32op),
+ /*8752*/ uint16(x86_xMatch),
+ /*8753*/ uint16(x86_xCondDataSize), 8745, 8757, 8761,
+ /*8757*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8759*/ uint16(x86_xArgR64op),
+ /*8760*/ uint16(x86_xMatch),
+ /*8761*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8763*/ uint16(x86_xArgR64op),
+ /*8764*/ uint16(x86_xMatch),
+ /*8765*/ uint16(x86_xCondIs64), 8768, 8780,
+ /*8768*/ uint16(x86_xCondDataSize), 8772, 8776, 0,
+ /*8772*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*8774*/ uint16(x86_xArgR16op),
+ /*8775*/ uint16(x86_xMatch),
+ /*8776*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*8778*/ uint16(x86_xArgR32op),
+ /*8779*/ uint16(x86_xMatch),
+ /*8780*/ uint16(x86_xCondDataSize), 8772, 8784, 8788,
+ /*8784*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*8786*/ uint16(x86_xArgR64op),
+ /*8787*/ uint16(x86_xMatch),
+ /*8788*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*8790*/ uint16(x86_xArgR64op),
+ /*8791*/ uint16(x86_xMatch),
+ /*8792*/ uint16(x86_xCondIs64), 8795, 0,
+ /*8795*/ uint16(x86_xCondDataSize), 8799, 8802, 0,
+ /*8799*/ uint16(x86_xSetOp), uint16(x86_PUSHA),
+ /*8801*/ uint16(x86_xMatch),
+ /*8802*/ uint16(x86_xSetOp), uint16(x86_PUSHAD),
+ /*8804*/ uint16(x86_xMatch),
+ /*8805*/ uint16(x86_xCondIs64), 8808, 0,
+ /*8808*/ uint16(x86_xCondDataSize), 8812, 8815, 0,
+ /*8812*/ uint16(x86_xSetOp), uint16(x86_POPA),
+ /*8814*/ uint16(x86_xMatch),
+ /*8815*/ uint16(x86_xSetOp), uint16(x86_POPAD),
+ /*8817*/ uint16(x86_xMatch),
+ /*8818*/ uint16(x86_xCondIs64), 8821, 0,
+ /*8821*/ uint16(x86_xCondDataSize), 8825, 8831, 0,
+ /*8825*/ uint16(x86_xSetOp), uint16(x86_BOUND),
+ /*8827*/ uint16(x86_xReadSlashR),
+ /*8828*/ uint16(x86_xArgR16),
+ /*8829*/ uint16(x86_xArgM16and16),
+ /*8830*/ uint16(x86_xMatch),
+ /*8831*/ uint16(x86_xSetOp), uint16(x86_BOUND),
+ /*8833*/ uint16(x86_xReadSlashR),
+ /*8834*/ uint16(x86_xArgR32),
+ /*8835*/ uint16(x86_xArgM32and32),
+ /*8836*/ uint16(x86_xMatch),
+ /*8837*/ uint16(x86_xCondIs64), 8840, 8846,
+ /*8840*/ uint16(x86_xSetOp), uint16(x86_ARPL),
+ /*8842*/ uint16(x86_xReadSlashR),
+ /*8843*/ uint16(x86_xArgRM16),
+ /*8844*/ uint16(x86_xArgR16),
+ /*8845*/ uint16(x86_xMatch),
+ /*8846*/ uint16(x86_xCondDataSize), 8850, 8856, 8862,
+ /*8850*/ uint16(x86_xSetOp), uint16(x86_MOVSXD),
+ /*8852*/ uint16(x86_xReadSlashR),
+ /*8853*/ uint16(x86_xArgR16),
+ /*8854*/ uint16(x86_xArgRM32),
+ /*8855*/ uint16(x86_xMatch),
+ /*8856*/ uint16(x86_xSetOp), uint16(x86_MOVSXD),
+ /*8858*/ uint16(x86_xReadSlashR),
+ /*8859*/ uint16(x86_xArgR32),
+ /*8860*/ uint16(x86_xArgRM32),
+ /*8861*/ uint16(x86_xMatch),
+ /*8862*/ uint16(x86_xSetOp), uint16(x86_MOVSXD),
+ /*8864*/ uint16(x86_xReadSlashR),
+ /*8865*/ uint16(x86_xArgR64),
+ /*8866*/ uint16(x86_xArgRM32),
+ /*8867*/ uint16(x86_xMatch),
+ /*8868*/ uint16(x86_xCondDataSize), 8872, 8877, 8882,
+ /*8872*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8874*/ uint16(x86_xReadIw),
+ /*8875*/ uint16(x86_xArgImm16),
+ /*8876*/ uint16(x86_xMatch),
+ /*8877*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8879*/ uint16(x86_xReadId),
+ /*8880*/ uint16(x86_xArgImm32),
+ /*8881*/ uint16(x86_xMatch),
+ /*8882*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8884*/ uint16(x86_xReadId),
+ /*8885*/ uint16(x86_xArgImm32),
+ /*8886*/ uint16(x86_xMatch),
+ /*8887*/ uint16(x86_xCondIs64), 8890, 8910,
+ /*8890*/ uint16(x86_xCondDataSize), 8894, 8902, 0,
+ /*8894*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*8896*/ uint16(x86_xReadSlashR),
+ /*8897*/ uint16(x86_xReadIw),
+ /*8898*/ uint16(x86_xArgR16),
+ /*8899*/ uint16(x86_xArgRM16),
+ /*8900*/ uint16(x86_xArgImm16),
+ /*8901*/ uint16(x86_xMatch),
+ /*8902*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*8904*/ uint16(x86_xReadSlashR),
+ /*8905*/ uint16(x86_xReadId),
+ /*8906*/ uint16(x86_xArgR32),
+ /*8907*/ uint16(x86_xArgRM32),
+ /*8908*/ uint16(x86_xArgImm32),
+ /*8909*/ uint16(x86_xMatch),
+ /*8910*/ uint16(x86_xCondDataSize), 8894, 8902, 8914,
+ /*8914*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*8916*/ uint16(x86_xReadSlashR),
+ /*8917*/ uint16(x86_xReadId),
+ /*8918*/ uint16(x86_xArgR64),
+ /*8919*/ uint16(x86_xArgRM64),
+ /*8920*/ uint16(x86_xArgImm32),
+ /*8921*/ uint16(x86_xMatch),
+ /*8922*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*8924*/ uint16(x86_xReadIb),
+ /*8925*/ uint16(x86_xArgImm8),
+ /*8926*/ uint16(x86_xMatch),
+ /*8927*/ uint16(x86_xCondIs64), 8930, 8950,
+ /*8930*/ uint16(x86_xCondDataSize), 8934, 8942, 0,
+ /*8934*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*8936*/ uint16(x86_xReadSlashR),
+ /*8937*/ uint16(x86_xReadIb),
+ /*8938*/ uint16(x86_xArgR16),
+ /*8939*/ uint16(x86_xArgRM16),
+ /*8940*/ uint16(x86_xArgImm8),
+ /*8941*/ uint16(x86_xMatch),
+ /*8942*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*8944*/ uint16(x86_xReadSlashR),
+ /*8945*/ uint16(x86_xReadIb),
+ /*8946*/ uint16(x86_xArgR32),
+ /*8947*/ uint16(x86_xArgRM32),
+ /*8948*/ uint16(x86_xArgImm8),
+ /*8949*/ uint16(x86_xMatch),
+ /*8950*/ uint16(x86_xCondDataSize), 8934, 8942, 8954,
+ /*8954*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*8956*/ uint16(x86_xReadSlashR),
+ /*8957*/ uint16(x86_xReadIb),
+ /*8958*/ uint16(x86_xArgR64),
+ /*8959*/ uint16(x86_xArgRM64),
+ /*8960*/ uint16(x86_xArgImm8),
+ /*8961*/ uint16(x86_xMatch),
+ /*8962*/ uint16(x86_xSetOp), uint16(x86_INSB),
+ /*8964*/ uint16(x86_xMatch),
+ /*8965*/ uint16(x86_xCondDataSize), 8969, 8972, 8975,
+ /*8969*/ uint16(x86_xSetOp), uint16(x86_INSW),
+ /*8971*/ uint16(x86_xMatch),
+ /*8972*/ uint16(x86_xSetOp), uint16(x86_INSD),
+ /*8974*/ uint16(x86_xMatch),
+ /*8975*/ uint16(x86_xSetOp), uint16(x86_INSD),
+ /*8977*/ uint16(x86_xMatch),
+ /*8978*/ uint16(x86_xSetOp), uint16(x86_OUTSB),
+ /*8980*/ uint16(x86_xMatch),
+ /*8981*/ uint16(x86_xCondDataSize), 8985, 8988, 8991,
+ /*8985*/ uint16(x86_xSetOp), uint16(x86_OUTSW),
+ /*8987*/ uint16(x86_xMatch),
+ /*8988*/ uint16(x86_xSetOp), uint16(x86_OUTSD),
+ /*8990*/ uint16(x86_xMatch),
+ /*8991*/ uint16(x86_xSetOp), uint16(x86_OUTSD),
+ /*8993*/ uint16(x86_xMatch),
+ /*8994*/ uint16(x86_xSetOp), uint16(x86_JO),
+ /*8996*/ uint16(x86_xReadCb),
+ /*8997*/ uint16(x86_xArgRel8),
+ /*8998*/ uint16(x86_xMatch),
+ /*8999*/ uint16(x86_xSetOp), uint16(x86_JNO),
+ /*9001*/ uint16(x86_xReadCb),
+ /*9002*/ uint16(x86_xArgRel8),
+ /*9003*/ uint16(x86_xMatch),
+ /*9004*/ uint16(x86_xSetOp), uint16(x86_JB),
+ /*9006*/ uint16(x86_xReadCb),
+ /*9007*/ uint16(x86_xArgRel8),
+ /*9008*/ uint16(x86_xMatch),
+ /*9009*/ uint16(x86_xSetOp), uint16(x86_JAE),
+ /*9011*/ uint16(x86_xReadCb),
+ /*9012*/ uint16(x86_xArgRel8),
+ /*9013*/ uint16(x86_xMatch),
+ /*9014*/ uint16(x86_xSetOp), uint16(x86_JE),
+ /*9016*/ uint16(x86_xReadCb),
+ /*9017*/ uint16(x86_xArgRel8),
+ /*9018*/ uint16(x86_xMatch),
+ /*9019*/ uint16(x86_xSetOp), uint16(x86_JNE),
+ /*9021*/ uint16(x86_xReadCb),
+ /*9022*/ uint16(x86_xArgRel8),
+ /*9023*/ uint16(x86_xMatch),
+ /*9024*/ uint16(x86_xSetOp), uint16(x86_JBE),
+ /*9026*/ uint16(x86_xReadCb),
+ /*9027*/ uint16(x86_xArgRel8),
+ /*9028*/ uint16(x86_xMatch),
+ /*9029*/ uint16(x86_xSetOp), uint16(x86_JA),
+ /*9031*/ uint16(x86_xReadCb),
+ /*9032*/ uint16(x86_xArgRel8),
+ /*9033*/ uint16(x86_xMatch),
+ /*9034*/ uint16(x86_xSetOp), uint16(x86_JS),
+ /*9036*/ uint16(x86_xReadCb),
+ /*9037*/ uint16(x86_xArgRel8),
+ /*9038*/ uint16(x86_xMatch),
+ /*9039*/ uint16(x86_xSetOp), uint16(x86_JNS),
+ /*9041*/ uint16(x86_xReadCb),
+ /*9042*/ uint16(x86_xArgRel8),
+ /*9043*/ uint16(x86_xMatch),
+ /*9044*/ uint16(x86_xSetOp), uint16(x86_JP),
+ /*9046*/ uint16(x86_xReadCb),
+ /*9047*/ uint16(x86_xArgRel8),
+ /*9048*/ uint16(x86_xMatch),
+ /*9049*/ uint16(x86_xSetOp), uint16(x86_JNP),
+ /*9051*/ uint16(x86_xReadCb),
+ /*9052*/ uint16(x86_xArgRel8),
+ /*9053*/ uint16(x86_xMatch),
+ /*9054*/ uint16(x86_xSetOp), uint16(x86_JL),
+ /*9056*/ uint16(x86_xReadCb),
+ /*9057*/ uint16(x86_xArgRel8),
+ /*9058*/ uint16(x86_xMatch),
+ /*9059*/ uint16(x86_xSetOp), uint16(x86_JGE),
+ /*9061*/ uint16(x86_xReadCb),
+ /*9062*/ uint16(x86_xArgRel8),
+ /*9063*/ uint16(x86_xMatch),
+ /*9064*/ uint16(x86_xSetOp), uint16(x86_JLE),
+ /*9066*/ uint16(x86_xReadCb),
+ /*9067*/ uint16(x86_xArgRel8),
+ /*9068*/ uint16(x86_xMatch),
+ /*9069*/ uint16(x86_xSetOp), uint16(x86_JG),
+ /*9071*/ uint16(x86_xReadCb),
+ /*9072*/ uint16(x86_xArgRel8),
+ /*9073*/ uint16(x86_xMatch),
+ /*9074*/ uint16(x86_xCondSlashR),
+ 9083, // 0
+ 9089, // 1
+ 9095, // 2
+ 9101, // 3
+ 9107, // 4
+ 9113, // 5
+ 9119, // 6
+ 9125, // 7
+ /*9083*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9085*/ uint16(x86_xReadIb),
+ /*9086*/ uint16(x86_xArgRM8),
+ /*9087*/ uint16(x86_xArgImm8u),
+ /*9088*/ uint16(x86_xMatch),
+ /*9089*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9091*/ uint16(x86_xReadIb),
+ /*9092*/ uint16(x86_xArgRM8),
+ /*9093*/ uint16(x86_xArgImm8u),
+ /*9094*/ uint16(x86_xMatch),
+ /*9095*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9097*/ uint16(x86_xReadIb),
+ /*9098*/ uint16(x86_xArgRM8),
+ /*9099*/ uint16(x86_xArgImm8u),
+ /*9100*/ uint16(x86_xMatch),
+ /*9101*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9103*/ uint16(x86_xReadIb),
+ /*9104*/ uint16(x86_xArgRM8),
+ /*9105*/ uint16(x86_xArgImm8u),
+ /*9106*/ uint16(x86_xMatch),
+ /*9107*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9109*/ uint16(x86_xReadIb),
+ /*9110*/ uint16(x86_xArgRM8),
+ /*9111*/ uint16(x86_xArgImm8u),
+ /*9112*/ uint16(x86_xMatch),
+ /*9113*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9115*/ uint16(x86_xReadIb),
+ /*9116*/ uint16(x86_xArgRM8),
+ /*9117*/ uint16(x86_xArgImm8u),
+ /*9118*/ uint16(x86_xMatch),
+ /*9119*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9121*/ uint16(x86_xReadIb),
+ /*9122*/ uint16(x86_xArgRM8),
+ /*9123*/ uint16(x86_xArgImm8u),
+ /*9124*/ uint16(x86_xMatch),
+ /*9125*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9127*/ uint16(x86_xReadIb),
+ /*9128*/ uint16(x86_xArgRM8),
+ /*9129*/ uint16(x86_xArgImm8u),
+ /*9130*/ uint16(x86_xMatch),
+ /*9131*/ uint16(x86_xCondSlashR),
+ 9140, // 0
+ 9169, // 1
+ 9198, // 2
+ 9227, // 3
+ 9256, // 4
+ 9285, // 5
+ 9314, // 6
+ 9343, // 7
+ /*9140*/ uint16(x86_xCondIs64), 9143, 9159,
+ /*9143*/ uint16(x86_xCondDataSize), 9147, 9153, 0,
+ /*9147*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9149*/ uint16(x86_xReadIw),
+ /*9150*/ uint16(x86_xArgRM16),
+ /*9151*/ uint16(x86_xArgImm16),
+ /*9152*/ uint16(x86_xMatch),
+ /*9153*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9155*/ uint16(x86_xReadId),
+ /*9156*/ uint16(x86_xArgRM32),
+ /*9157*/ uint16(x86_xArgImm32),
+ /*9158*/ uint16(x86_xMatch),
+ /*9159*/ uint16(x86_xCondDataSize), 9147, 9153, 9163,
+ /*9163*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9165*/ uint16(x86_xReadId),
+ /*9166*/ uint16(x86_xArgRM64),
+ /*9167*/ uint16(x86_xArgImm32),
+ /*9168*/ uint16(x86_xMatch),
+ /*9169*/ uint16(x86_xCondIs64), 9172, 9188,
+ /*9172*/ uint16(x86_xCondDataSize), 9176, 9182, 0,
+ /*9176*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9178*/ uint16(x86_xReadIw),
+ /*9179*/ uint16(x86_xArgRM16),
+ /*9180*/ uint16(x86_xArgImm16),
+ /*9181*/ uint16(x86_xMatch),
+ /*9182*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9184*/ uint16(x86_xReadId),
+ /*9185*/ uint16(x86_xArgRM32),
+ /*9186*/ uint16(x86_xArgImm32),
+ /*9187*/ uint16(x86_xMatch),
+ /*9188*/ uint16(x86_xCondDataSize), 9176, 9182, 9192,
+ /*9192*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9194*/ uint16(x86_xReadId),
+ /*9195*/ uint16(x86_xArgRM64),
+ /*9196*/ uint16(x86_xArgImm32),
+ /*9197*/ uint16(x86_xMatch),
+ /*9198*/ uint16(x86_xCondIs64), 9201, 9217,
+ /*9201*/ uint16(x86_xCondDataSize), 9205, 9211, 0,
+ /*9205*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9207*/ uint16(x86_xReadIw),
+ /*9208*/ uint16(x86_xArgRM16),
+ /*9209*/ uint16(x86_xArgImm16),
+ /*9210*/ uint16(x86_xMatch),
+ /*9211*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9213*/ uint16(x86_xReadId),
+ /*9214*/ uint16(x86_xArgRM32),
+ /*9215*/ uint16(x86_xArgImm32),
+ /*9216*/ uint16(x86_xMatch),
+ /*9217*/ uint16(x86_xCondDataSize), 9205, 9211, 9221,
+ /*9221*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9223*/ uint16(x86_xReadId),
+ /*9224*/ uint16(x86_xArgRM64),
+ /*9225*/ uint16(x86_xArgImm32),
+ /*9226*/ uint16(x86_xMatch),
+ /*9227*/ uint16(x86_xCondIs64), 9230, 9246,
+ /*9230*/ uint16(x86_xCondDataSize), 9234, 9240, 0,
+ /*9234*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9236*/ uint16(x86_xReadIw),
+ /*9237*/ uint16(x86_xArgRM16),
+ /*9238*/ uint16(x86_xArgImm16),
+ /*9239*/ uint16(x86_xMatch),
+ /*9240*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9242*/ uint16(x86_xReadId),
+ /*9243*/ uint16(x86_xArgRM32),
+ /*9244*/ uint16(x86_xArgImm32),
+ /*9245*/ uint16(x86_xMatch),
+ /*9246*/ uint16(x86_xCondDataSize), 9234, 9240, 9250,
+ /*9250*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9252*/ uint16(x86_xReadId),
+ /*9253*/ uint16(x86_xArgRM64),
+ /*9254*/ uint16(x86_xArgImm32),
+ /*9255*/ uint16(x86_xMatch),
+ /*9256*/ uint16(x86_xCondIs64), 9259, 9275,
+ /*9259*/ uint16(x86_xCondDataSize), 9263, 9269, 0,
+ /*9263*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9265*/ uint16(x86_xReadIw),
+ /*9266*/ uint16(x86_xArgRM16),
+ /*9267*/ uint16(x86_xArgImm16),
+ /*9268*/ uint16(x86_xMatch),
+ /*9269*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9271*/ uint16(x86_xReadId),
+ /*9272*/ uint16(x86_xArgRM32),
+ /*9273*/ uint16(x86_xArgImm32),
+ /*9274*/ uint16(x86_xMatch),
+ /*9275*/ uint16(x86_xCondDataSize), 9263, 9269, 9279,
+ /*9279*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9281*/ uint16(x86_xReadId),
+ /*9282*/ uint16(x86_xArgRM64),
+ /*9283*/ uint16(x86_xArgImm32),
+ /*9284*/ uint16(x86_xMatch),
+ /*9285*/ uint16(x86_xCondIs64), 9288, 9304,
+ /*9288*/ uint16(x86_xCondDataSize), 9292, 9298, 0,
+ /*9292*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9294*/ uint16(x86_xReadIw),
+ /*9295*/ uint16(x86_xArgRM16),
+ /*9296*/ uint16(x86_xArgImm16),
+ /*9297*/ uint16(x86_xMatch),
+ /*9298*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9300*/ uint16(x86_xReadId),
+ /*9301*/ uint16(x86_xArgRM32),
+ /*9302*/ uint16(x86_xArgImm32),
+ /*9303*/ uint16(x86_xMatch),
+ /*9304*/ uint16(x86_xCondDataSize), 9292, 9298, 9308,
+ /*9308*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9310*/ uint16(x86_xReadId),
+ /*9311*/ uint16(x86_xArgRM64),
+ /*9312*/ uint16(x86_xArgImm32),
+ /*9313*/ uint16(x86_xMatch),
+ /*9314*/ uint16(x86_xCondIs64), 9317, 9333,
+ /*9317*/ uint16(x86_xCondDataSize), 9321, 9327, 0,
+ /*9321*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9323*/ uint16(x86_xReadIw),
+ /*9324*/ uint16(x86_xArgRM16),
+ /*9325*/ uint16(x86_xArgImm16),
+ /*9326*/ uint16(x86_xMatch),
+ /*9327*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9329*/ uint16(x86_xReadId),
+ /*9330*/ uint16(x86_xArgRM32),
+ /*9331*/ uint16(x86_xArgImm32),
+ /*9332*/ uint16(x86_xMatch),
+ /*9333*/ uint16(x86_xCondDataSize), 9321, 9327, 9337,
+ /*9337*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9339*/ uint16(x86_xReadId),
+ /*9340*/ uint16(x86_xArgRM64),
+ /*9341*/ uint16(x86_xArgImm32),
+ /*9342*/ uint16(x86_xMatch),
+ /*9343*/ uint16(x86_xCondIs64), 9346, 9362,
+ /*9346*/ uint16(x86_xCondDataSize), 9350, 9356, 0,
+ /*9350*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9352*/ uint16(x86_xReadIw),
+ /*9353*/ uint16(x86_xArgRM16),
+ /*9354*/ uint16(x86_xArgImm16),
+ /*9355*/ uint16(x86_xMatch),
+ /*9356*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9358*/ uint16(x86_xReadId),
+ /*9359*/ uint16(x86_xArgRM32),
+ /*9360*/ uint16(x86_xArgImm32),
+ /*9361*/ uint16(x86_xMatch),
+ /*9362*/ uint16(x86_xCondDataSize), 9350, 9356, 9366,
+ /*9366*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9368*/ uint16(x86_xReadId),
+ /*9369*/ uint16(x86_xArgRM64),
+ /*9370*/ uint16(x86_xArgImm32),
+ /*9371*/ uint16(x86_xMatch),
+ /*9372*/ uint16(x86_xCondSlashR),
+ 9381, // 0
+ 9410, // 1
+ 9439, // 2
+ 9468, // 3
+ 9497, // 4
+ 9526, // 5
+ 9555, // 6
+ 9584, // 7
+ /*9381*/ uint16(x86_xCondIs64), 9384, 9400,
+ /*9384*/ uint16(x86_xCondDataSize), 9388, 9394, 0,
+ /*9388*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9390*/ uint16(x86_xReadIb),
+ /*9391*/ uint16(x86_xArgRM16),
+ /*9392*/ uint16(x86_xArgImm8),
+ /*9393*/ uint16(x86_xMatch),
+ /*9394*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9396*/ uint16(x86_xReadIb),
+ /*9397*/ uint16(x86_xArgRM32),
+ /*9398*/ uint16(x86_xArgImm8),
+ /*9399*/ uint16(x86_xMatch),
+ /*9400*/ uint16(x86_xCondDataSize), 9388, 9394, 9404,
+ /*9404*/ uint16(x86_xSetOp), uint16(x86_ADD),
+ /*9406*/ uint16(x86_xReadIb),
+ /*9407*/ uint16(x86_xArgRM64),
+ /*9408*/ uint16(x86_xArgImm8),
+ /*9409*/ uint16(x86_xMatch),
+ /*9410*/ uint16(x86_xCondIs64), 9413, 9429,
+ /*9413*/ uint16(x86_xCondDataSize), 9417, 9423, 0,
+ /*9417*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9419*/ uint16(x86_xReadIb),
+ /*9420*/ uint16(x86_xArgRM16),
+ /*9421*/ uint16(x86_xArgImm8),
+ /*9422*/ uint16(x86_xMatch),
+ /*9423*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9425*/ uint16(x86_xReadIb),
+ /*9426*/ uint16(x86_xArgRM32),
+ /*9427*/ uint16(x86_xArgImm8),
+ /*9428*/ uint16(x86_xMatch),
+ /*9429*/ uint16(x86_xCondDataSize), 9417, 9423, 9433,
+ /*9433*/ uint16(x86_xSetOp), uint16(x86_OR),
+ /*9435*/ uint16(x86_xReadIb),
+ /*9436*/ uint16(x86_xArgRM64),
+ /*9437*/ uint16(x86_xArgImm8),
+ /*9438*/ uint16(x86_xMatch),
+ /*9439*/ uint16(x86_xCondIs64), 9442, 9458,
+ /*9442*/ uint16(x86_xCondDataSize), 9446, 9452, 0,
+ /*9446*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9448*/ uint16(x86_xReadIb),
+ /*9449*/ uint16(x86_xArgRM16),
+ /*9450*/ uint16(x86_xArgImm8),
+ /*9451*/ uint16(x86_xMatch),
+ /*9452*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9454*/ uint16(x86_xReadIb),
+ /*9455*/ uint16(x86_xArgRM32),
+ /*9456*/ uint16(x86_xArgImm8),
+ /*9457*/ uint16(x86_xMatch),
+ /*9458*/ uint16(x86_xCondDataSize), 9446, 9452, 9462,
+ /*9462*/ uint16(x86_xSetOp), uint16(x86_ADC),
+ /*9464*/ uint16(x86_xReadIb),
+ /*9465*/ uint16(x86_xArgRM64),
+ /*9466*/ uint16(x86_xArgImm8),
+ /*9467*/ uint16(x86_xMatch),
+ /*9468*/ uint16(x86_xCondIs64), 9471, 9487,
+ /*9471*/ uint16(x86_xCondDataSize), 9475, 9481, 0,
+ /*9475*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9477*/ uint16(x86_xReadIb),
+ /*9478*/ uint16(x86_xArgRM16),
+ /*9479*/ uint16(x86_xArgImm8),
+ /*9480*/ uint16(x86_xMatch),
+ /*9481*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9483*/ uint16(x86_xReadIb),
+ /*9484*/ uint16(x86_xArgRM32),
+ /*9485*/ uint16(x86_xArgImm8),
+ /*9486*/ uint16(x86_xMatch),
+ /*9487*/ uint16(x86_xCondDataSize), 9475, 9481, 9491,
+ /*9491*/ uint16(x86_xSetOp), uint16(x86_SBB),
+ /*9493*/ uint16(x86_xReadIb),
+ /*9494*/ uint16(x86_xArgRM64),
+ /*9495*/ uint16(x86_xArgImm8),
+ /*9496*/ uint16(x86_xMatch),
+ /*9497*/ uint16(x86_xCondIs64), 9500, 9516,
+ /*9500*/ uint16(x86_xCondDataSize), 9504, 9510, 0,
+ /*9504*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9506*/ uint16(x86_xReadIb),
+ /*9507*/ uint16(x86_xArgRM16),
+ /*9508*/ uint16(x86_xArgImm8),
+ /*9509*/ uint16(x86_xMatch),
+ /*9510*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9512*/ uint16(x86_xReadIb),
+ /*9513*/ uint16(x86_xArgRM32),
+ /*9514*/ uint16(x86_xArgImm8),
+ /*9515*/ uint16(x86_xMatch),
+ /*9516*/ uint16(x86_xCondDataSize), 9504, 9510, 9520,
+ /*9520*/ uint16(x86_xSetOp), uint16(x86_AND),
+ /*9522*/ uint16(x86_xReadIb),
+ /*9523*/ uint16(x86_xArgRM64),
+ /*9524*/ uint16(x86_xArgImm8),
+ /*9525*/ uint16(x86_xMatch),
+ /*9526*/ uint16(x86_xCondIs64), 9529, 9545,
+ /*9529*/ uint16(x86_xCondDataSize), 9533, 9539, 0,
+ /*9533*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9535*/ uint16(x86_xReadIb),
+ /*9536*/ uint16(x86_xArgRM16),
+ /*9537*/ uint16(x86_xArgImm8),
+ /*9538*/ uint16(x86_xMatch),
+ /*9539*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9541*/ uint16(x86_xReadIb),
+ /*9542*/ uint16(x86_xArgRM32),
+ /*9543*/ uint16(x86_xArgImm8),
+ /*9544*/ uint16(x86_xMatch),
+ /*9545*/ uint16(x86_xCondDataSize), 9533, 9539, 9549,
+ /*9549*/ uint16(x86_xSetOp), uint16(x86_SUB),
+ /*9551*/ uint16(x86_xReadIb),
+ /*9552*/ uint16(x86_xArgRM64),
+ /*9553*/ uint16(x86_xArgImm8),
+ /*9554*/ uint16(x86_xMatch),
+ /*9555*/ uint16(x86_xCondIs64), 9558, 9574,
+ /*9558*/ uint16(x86_xCondDataSize), 9562, 9568, 0,
+ /*9562*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9564*/ uint16(x86_xReadIb),
+ /*9565*/ uint16(x86_xArgRM16),
+ /*9566*/ uint16(x86_xArgImm8),
+ /*9567*/ uint16(x86_xMatch),
+ /*9568*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9570*/ uint16(x86_xReadIb),
+ /*9571*/ uint16(x86_xArgRM32),
+ /*9572*/ uint16(x86_xArgImm8),
+ /*9573*/ uint16(x86_xMatch),
+ /*9574*/ uint16(x86_xCondDataSize), 9562, 9568, 9578,
+ /*9578*/ uint16(x86_xSetOp), uint16(x86_XOR),
+ /*9580*/ uint16(x86_xReadIb),
+ /*9581*/ uint16(x86_xArgRM64),
+ /*9582*/ uint16(x86_xArgImm8),
+ /*9583*/ uint16(x86_xMatch),
+ /*9584*/ uint16(x86_xCondIs64), 9587, 9603,
+ /*9587*/ uint16(x86_xCondDataSize), 9591, 9597, 0,
+ /*9591*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9593*/ uint16(x86_xReadIb),
+ /*9594*/ uint16(x86_xArgRM16),
+ /*9595*/ uint16(x86_xArgImm8),
+ /*9596*/ uint16(x86_xMatch),
+ /*9597*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9599*/ uint16(x86_xReadIb),
+ /*9600*/ uint16(x86_xArgRM32),
+ /*9601*/ uint16(x86_xArgImm8),
+ /*9602*/ uint16(x86_xMatch),
+ /*9603*/ uint16(x86_xCondDataSize), 9591, 9597, 9607,
+ /*9607*/ uint16(x86_xSetOp), uint16(x86_CMP),
+ /*9609*/ uint16(x86_xReadIb),
+ /*9610*/ uint16(x86_xArgRM64),
+ /*9611*/ uint16(x86_xArgImm8),
+ /*9612*/ uint16(x86_xMatch),
+ /*9613*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*9615*/ uint16(x86_xReadSlashR),
+ /*9616*/ uint16(x86_xArgRM8),
+ /*9617*/ uint16(x86_xArgR8),
+ /*9618*/ uint16(x86_xMatch),
+ /*9619*/ uint16(x86_xCondIs64), 9622, 9638,
+ /*9622*/ uint16(x86_xCondDataSize), 9626, 9632, 0,
+ /*9626*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*9628*/ uint16(x86_xReadSlashR),
+ /*9629*/ uint16(x86_xArgRM16),
+ /*9630*/ uint16(x86_xArgR16),
+ /*9631*/ uint16(x86_xMatch),
+ /*9632*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*9634*/ uint16(x86_xReadSlashR),
+ /*9635*/ uint16(x86_xArgRM32),
+ /*9636*/ uint16(x86_xArgR32),
+ /*9637*/ uint16(x86_xMatch),
+ /*9638*/ uint16(x86_xCondDataSize), 9626, 9632, 9642,
+ /*9642*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*9644*/ uint16(x86_xReadSlashR),
+ /*9645*/ uint16(x86_xArgRM64),
+ /*9646*/ uint16(x86_xArgR64),
+ /*9647*/ uint16(x86_xMatch),
+ /*9648*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9650*/ uint16(x86_xReadSlashR),
+ /*9651*/ uint16(x86_xArgRM8),
+ /*9652*/ uint16(x86_xArgR8),
+ /*9653*/ uint16(x86_xMatch),
+ /*9654*/ uint16(x86_xCondIs64), 9657, 9673,
+ /*9657*/ uint16(x86_xCondDataSize), 9661, 9667, 0,
+ /*9661*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9663*/ uint16(x86_xReadSlashR),
+ /*9664*/ uint16(x86_xArgRM16),
+ /*9665*/ uint16(x86_xArgR16),
+ /*9666*/ uint16(x86_xMatch),
+ /*9667*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9669*/ uint16(x86_xReadSlashR),
+ /*9670*/ uint16(x86_xArgRM32),
+ /*9671*/ uint16(x86_xArgR32),
+ /*9672*/ uint16(x86_xMatch),
+ /*9673*/ uint16(x86_xCondDataSize), 9661, 9667, 9677,
+ /*9677*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9679*/ uint16(x86_xReadSlashR),
+ /*9680*/ uint16(x86_xArgRM64),
+ /*9681*/ uint16(x86_xArgR64),
+ /*9682*/ uint16(x86_xMatch),
+ /*9683*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9685*/ uint16(x86_xReadSlashR),
+ /*9686*/ uint16(x86_xArgRM8),
+ /*9687*/ uint16(x86_xArgR8),
+ /*9688*/ uint16(x86_xMatch),
+ /*9689*/ uint16(x86_xCondDataSize), 9693, 9699, 9705,
+ /*9693*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9695*/ uint16(x86_xReadSlashR),
+ /*9696*/ uint16(x86_xArgRM16),
+ /*9697*/ uint16(x86_xArgR16),
+ /*9698*/ uint16(x86_xMatch),
+ /*9699*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9701*/ uint16(x86_xReadSlashR),
+ /*9702*/ uint16(x86_xArgRM32),
+ /*9703*/ uint16(x86_xArgR32),
+ /*9704*/ uint16(x86_xMatch),
+ /*9705*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9707*/ uint16(x86_xReadSlashR),
+ /*9708*/ uint16(x86_xArgRM64),
+ /*9709*/ uint16(x86_xArgR64),
+ /*9710*/ uint16(x86_xMatch),
+ /*9711*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9713*/ uint16(x86_xReadSlashR),
+ /*9714*/ uint16(x86_xArgR8),
+ /*9715*/ uint16(x86_xArgRM8),
+ /*9716*/ uint16(x86_xMatch),
+ /*9717*/ uint16(x86_xCondDataSize), 9721, 9727, 9733,
+ /*9721*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9723*/ uint16(x86_xReadSlashR),
+ /*9724*/ uint16(x86_xArgR16),
+ /*9725*/ uint16(x86_xArgRM16),
+ /*9726*/ uint16(x86_xMatch),
+ /*9727*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9729*/ uint16(x86_xReadSlashR),
+ /*9730*/ uint16(x86_xArgR32),
+ /*9731*/ uint16(x86_xArgRM32),
+ /*9732*/ uint16(x86_xMatch),
+ /*9733*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9735*/ uint16(x86_xReadSlashR),
+ /*9736*/ uint16(x86_xArgR64),
+ /*9737*/ uint16(x86_xArgRM64),
+ /*9738*/ uint16(x86_xMatch),
+ /*9739*/ uint16(x86_xCondIs64), 9742, 9758,
+ /*9742*/ uint16(x86_xCondDataSize), 9746, 9752, 0,
+ /*9746*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9748*/ uint16(x86_xReadSlashR),
+ /*9749*/ uint16(x86_xArgRM16),
+ /*9750*/ uint16(x86_xArgSreg),
+ /*9751*/ uint16(x86_xMatch),
+ /*9752*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9754*/ uint16(x86_xReadSlashR),
+ /*9755*/ uint16(x86_xArgR32M16),
+ /*9756*/ uint16(x86_xArgSreg),
+ /*9757*/ uint16(x86_xMatch),
+ /*9758*/ uint16(x86_xCondDataSize), 9746, 9752, 9762,
+ /*9762*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9764*/ uint16(x86_xReadSlashR),
+ /*9765*/ uint16(x86_xArgR64M16),
+ /*9766*/ uint16(x86_xArgSreg),
+ /*9767*/ uint16(x86_xMatch),
+ /*9768*/ uint16(x86_xCondIs64), 9771, 9787,
+ /*9771*/ uint16(x86_xCondDataSize), 9775, 9781, 0,
+ /*9775*/ uint16(x86_xSetOp), uint16(x86_LEA),
+ /*9777*/ uint16(x86_xReadSlashR),
+ /*9778*/ uint16(x86_xArgR16),
+ /*9779*/ uint16(x86_xArgM),
+ /*9780*/ uint16(x86_xMatch),
+ /*9781*/ uint16(x86_xSetOp), uint16(x86_LEA),
+ /*9783*/ uint16(x86_xReadSlashR),
+ /*9784*/ uint16(x86_xArgR32),
+ /*9785*/ uint16(x86_xArgM),
+ /*9786*/ uint16(x86_xMatch),
+ /*9787*/ uint16(x86_xCondDataSize), 9775, 9781, 9791,
+ /*9791*/ uint16(x86_xSetOp), uint16(x86_LEA),
+ /*9793*/ uint16(x86_xReadSlashR),
+ /*9794*/ uint16(x86_xArgR64),
+ /*9795*/ uint16(x86_xArgM),
+ /*9796*/ uint16(x86_xMatch),
+ /*9797*/ uint16(x86_xCondIs64), 9800, 9816,
+ /*9800*/ uint16(x86_xCondDataSize), 9804, 9810, 0,
+ /*9804*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9806*/ uint16(x86_xReadSlashR),
+ /*9807*/ uint16(x86_xArgSreg),
+ /*9808*/ uint16(x86_xArgRM16),
+ /*9809*/ uint16(x86_xMatch),
+ /*9810*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9812*/ uint16(x86_xReadSlashR),
+ /*9813*/ uint16(x86_xArgSreg),
+ /*9814*/ uint16(x86_xArgR32M16),
+ /*9815*/ uint16(x86_xMatch),
+ /*9816*/ uint16(x86_xCondDataSize), 9804, 9810, 9820,
+ /*9820*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*9822*/ uint16(x86_xReadSlashR),
+ /*9823*/ uint16(x86_xArgSreg),
+ /*9824*/ uint16(x86_xArgR64M16),
+ /*9825*/ uint16(x86_xMatch),
+ /*9826*/ uint16(x86_xCondSlashR),
+ 9835, // 0
+ 0, // 1
+ 0, // 2
+ 0, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*9835*/ uint16(x86_xCondIs64), 9838, 9850,
+ /*9838*/ uint16(x86_xCondDataSize), 9842, 9846, 0,
+ /*9842*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*9844*/ uint16(x86_xArgRM16),
+ /*9845*/ uint16(x86_xMatch),
+ /*9846*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*9848*/ uint16(x86_xArgRM32),
+ /*9849*/ uint16(x86_xMatch),
+ /*9850*/ uint16(x86_xCondDataSize), 9842, 9854, 9858,
+ /*9854*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*9856*/ uint16(x86_xArgRM64),
+ /*9857*/ uint16(x86_xMatch),
+ /*9858*/ uint16(x86_xSetOp), uint16(x86_POP),
+ /*9860*/ uint16(x86_xArgRM64),
+ /*9861*/ uint16(x86_xMatch),
+ /*9862*/ uint16(x86_xCondIs64), 9865, 9879,
+ /*9865*/ uint16(x86_xCondDataSize), 9869, 9874, 0,
+ /*9869*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9871*/ uint16(x86_xArgR16op),
+ /*9872*/ uint16(x86_xArgAX),
+ /*9873*/ uint16(x86_xMatch),
+ /*9874*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9876*/ uint16(x86_xArgR32op),
+ /*9877*/ uint16(x86_xArgEAX),
+ /*9878*/ uint16(x86_xMatch),
+ /*9879*/ uint16(x86_xCondDataSize), 9869, 9874, 9883,
+ /*9883*/ uint16(x86_xSetOp), uint16(x86_XCHG),
+ /*9885*/ uint16(x86_xArgR64op),
+ /*9886*/ uint16(x86_xArgRAX),
+ /*9887*/ uint16(x86_xMatch),
+ /*9888*/ uint16(x86_xCondIs64), 9891, 9901,
+ /*9891*/ uint16(x86_xCondDataSize), 9895, 9898, 0,
+ /*9895*/ uint16(x86_xSetOp), uint16(x86_CBW),
+ /*9897*/ uint16(x86_xMatch),
+ /*9898*/ uint16(x86_xSetOp), uint16(x86_CWDE),
+ /*9900*/ uint16(x86_xMatch),
+ /*9901*/ uint16(x86_xCondDataSize), 9895, 9898, 9905,
+ /*9905*/ uint16(x86_xSetOp), uint16(x86_CDQE),
+ /*9907*/ uint16(x86_xMatch),
+ /*9908*/ uint16(x86_xCondIs64), 9911, 9921,
+ /*9911*/ uint16(x86_xCondDataSize), 9915, 9918, 0,
+ /*9915*/ uint16(x86_xSetOp), uint16(x86_CWD),
+ /*9917*/ uint16(x86_xMatch),
+ /*9918*/ uint16(x86_xSetOp), uint16(x86_CDQ),
+ /*9920*/ uint16(x86_xMatch),
+ /*9921*/ uint16(x86_xCondDataSize), 9915, 9918, 9925,
+ /*9925*/ uint16(x86_xSetOp), uint16(x86_CQO),
+ /*9927*/ uint16(x86_xMatch),
+ /*9928*/ uint16(x86_xCondIs64), 9931, 0,
+ /*9931*/ uint16(x86_xCondDataSize), 9935, 9940, 0,
+ /*9935*/ uint16(x86_xSetOp), uint16(x86_LCALL),
+ /*9937*/ uint16(x86_xReadCd),
+ /*9938*/ uint16(x86_xArgPtr16colon16),
+ /*9939*/ uint16(x86_xMatch),
+ /*9940*/ uint16(x86_xSetOp), uint16(x86_LCALL),
+ /*9942*/ uint16(x86_xReadCp),
+ /*9943*/ uint16(x86_xArgPtr16colon32),
+ /*9944*/ uint16(x86_xMatch),
+ /*9945*/ uint16(x86_xSetOp), uint16(x86_FWAIT),
+ /*9947*/ uint16(x86_xMatch),
+ /*9948*/ uint16(x86_xCondIs64), 9951, 9961,
+ /*9951*/ uint16(x86_xCondDataSize), 9955, 9958, 0,
+ /*9955*/ uint16(x86_xSetOp), uint16(x86_PUSHF),
+ /*9957*/ uint16(x86_xMatch),
+ /*9958*/ uint16(x86_xSetOp), uint16(x86_PUSHFD),
+ /*9960*/ uint16(x86_xMatch),
+ /*9961*/ uint16(x86_xCondDataSize), 9955, 9965, 9968,
+ /*9965*/ uint16(x86_xSetOp), uint16(x86_PUSHFQ),
+ /*9967*/ uint16(x86_xMatch),
+ /*9968*/ uint16(x86_xSetOp), uint16(x86_PUSHFQ),
+ /*9970*/ uint16(x86_xMatch),
+ /*9971*/ uint16(x86_xCondIs64), 9974, 9984,
+ /*9974*/ uint16(x86_xCondDataSize), 9978, 9981, 0,
+ /*9978*/ uint16(x86_xSetOp), uint16(x86_POPF),
+ /*9980*/ uint16(x86_xMatch),
+ /*9981*/ uint16(x86_xSetOp), uint16(x86_POPFD),
+ /*9983*/ uint16(x86_xMatch),
+ /*9984*/ uint16(x86_xCondDataSize), 9978, 9988, 9991,
+ /*9988*/ uint16(x86_xSetOp), uint16(x86_POPFQ),
+ /*9990*/ uint16(x86_xMatch),
+ /*9991*/ uint16(x86_xSetOp), uint16(x86_POPFQ),
+ /*9993*/ uint16(x86_xMatch),
+ /*9994*/ uint16(x86_xSetOp), uint16(x86_SAHF),
+ /*9996*/ uint16(x86_xMatch),
+ /*9997*/ uint16(x86_xSetOp), uint16(x86_LAHF),
+ /*9999*/ uint16(x86_xMatch),
+ /*10000*/ uint16(x86_xCondIs64), 10003, 10009,
+ /*10003*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10005*/ uint16(x86_xReadCm),
+ /*10006*/ uint16(x86_xArgAL),
+ /*10007*/ uint16(x86_xArgMoffs8),
+ /*10008*/ uint16(x86_xMatch),
+ /*10009*/ uint16(x86_xCondDataSize), 10003, 10003, 10013,
+ /*10013*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10015*/ uint16(x86_xReadCm),
+ /*10016*/ uint16(x86_xArgAL),
+ /*10017*/ uint16(x86_xArgMoffs8),
+ /*10018*/ uint16(x86_xMatch),
+ /*10019*/ uint16(x86_xCondDataSize), 10023, 10029, 10035,
+ /*10023*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10025*/ uint16(x86_xReadCm),
+ /*10026*/ uint16(x86_xArgAX),
+ /*10027*/ uint16(x86_xArgMoffs16),
+ /*10028*/ uint16(x86_xMatch),
+ /*10029*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10031*/ uint16(x86_xReadCm),
+ /*10032*/ uint16(x86_xArgEAX),
+ /*10033*/ uint16(x86_xArgMoffs32),
+ /*10034*/ uint16(x86_xMatch),
+ /*10035*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10037*/ uint16(x86_xReadCm),
+ /*10038*/ uint16(x86_xArgRAX),
+ /*10039*/ uint16(x86_xArgMoffs64),
+ /*10040*/ uint16(x86_xMatch),
+ /*10041*/ uint16(x86_xCondIs64), 10044, 10050,
+ /*10044*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10046*/ uint16(x86_xReadCm),
+ /*10047*/ uint16(x86_xArgMoffs8),
+ /*10048*/ uint16(x86_xArgAL),
+ /*10049*/ uint16(x86_xMatch),
+ /*10050*/ uint16(x86_xCondDataSize), 10044, 10044, 10054,
+ /*10054*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10056*/ uint16(x86_xReadCm),
+ /*10057*/ uint16(x86_xArgMoffs8),
+ /*10058*/ uint16(x86_xArgAL),
+ /*10059*/ uint16(x86_xMatch),
+ /*10060*/ uint16(x86_xCondDataSize), 10064, 10070, 10076,
+ /*10064*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10066*/ uint16(x86_xReadCm),
+ /*10067*/ uint16(x86_xArgMoffs16),
+ /*10068*/ uint16(x86_xArgAX),
+ /*10069*/ uint16(x86_xMatch),
+ /*10070*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10072*/ uint16(x86_xReadCm),
+ /*10073*/ uint16(x86_xArgMoffs32),
+ /*10074*/ uint16(x86_xArgEAX),
+ /*10075*/ uint16(x86_xMatch),
+ /*10076*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10078*/ uint16(x86_xReadCm),
+ /*10079*/ uint16(x86_xArgMoffs64),
+ /*10080*/ uint16(x86_xArgRAX),
+ /*10081*/ uint16(x86_xMatch),
+ /*10082*/ uint16(x86_xSetOp), uint16(x86_MOVSB),
+ /*10084*/ uint16(x86_xMatch),
+ /*10085*/ uint16(x86_xCondIs64), 10088, 10098,
+ /*10088*/ uint16(x86_xCondDataSize), 10092, 10095, 0,
+ /*10092*/ uint16(x86_xSetOp), uint16(x86_MOVSW),
+ /*10094*/ uint16(x86_xMatch),
+ /*10095*/ uint16(x86_xSetOp), uint16(x86_MOVSD),
+ /*10097*/ uint16(x86_xMatch),
+ /*10098*/ uint16(x86_xCondDataSize), 10092, 10095, 10102,
+ /*10102*/ uint16(x86_xSetOp), uint16(x86_MOVSQ),
+ /*10104*/ uint16(x86_xMatch),
+ /*10105*/ uint16(x86_xSetOp), uint16(x86_CMPSB),
+ /*10107*/ uint16(x86_xMatch),
+ /*10108*/ uint16(x86_xCondIs64), 10111, 10121,
+ /*10111*/ uint16(x86_xCondDataSize), 10115, 10118, 0,
+ /*10115*/ uint16(x86_xSetOp), uint16(x86_CMPSW),
+ /*10117*/ uint16(x86_xMatch),
+ /*10118*/ uint16(x86_xSetOp), uint16(x86_CMPSD),
+ /*10120*/ uint16(x86_xMatch),
+ /*10121*/ uint16(x86_xCondDataSize), 10115, 10118, 10125,
+ /*10125*/ uint16(x86_xSetOp), uint16(x86_CMPSQ),
+ /*10127*/ uint16(x86_xMatch),
+ /*10128*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*10130*/ uint16(x86_xReadIb),
+ /*10131*/ uint16(x86_xArgAL),
+ /*10132*/ uint16(x86_xArgImm8u),
+ /*10133*/ uint16(x86_xMatch),
+ /*10134*/ uint16(x86_xCondIs64), 10137, 10153,
+ /*10137*/ uint16(x86_xCondDataSize), 10141, 10147, 0,
+ /*10141*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*10143*/ uint16(x86_xReadIw),
+ /*10144*/ uint16(x86_xArgAX),
+ /*10145*/ uint16(x86_xArgImm16),
+ /*10146*/ uint16(x86_xMatch),
+ /*10147*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*10149*/ uint16(x86_xReadId),
+ /*10150*/ uint16(x86_xArgEAX),
+ /*10151*/ uint16(x86_xArgImm32),
+ /*10152*/ uint16(x86_xMatch),
+ /*10153*/ uint16(x86_xCondDataSize), 10141, 10147, 10157,
+ /*10157*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*10159*/ uint16(x86_xReadId),
+ /*10160*/ uint16(x86_xArgRAX),
+ /*10161*/ uint16(x86_xArgImm32),
+ /*10162*/ uint16(x86_xMatch),
+ /*10163*/ uint16(x86_xSetOp), uint16(x86_STOSB),
+ /*10165*/ uint16(x86_xMatch),
+ /*10166*/ uint16(x86_xCondIs64), 10169, 10179,
+ /*10169*/ uint16(x86_xCondDataSize), 10173, 10176, 0,
+ /*10173*/ uint16(x86_xSetOp), uint16(x86_STOSW),
+ /*10175*/ uint16(x86_xMatch),
+ /*10176*/ uint16(x86_xSetOp), uint16(x86_STOSD),
+ /*10178*/ uint16(x86_xMatch),
+ /*10179*/ uint16(x86_xCondDataSize), 10173, 10176, 10183,
+ /*10183*/ uint16(x86_xSetOp), uint16(x86_STOSQ),
+ /*10185*/ uint16(x86_xMatch),
+ /*10186*/ uint16(x86_xSetOp), uint16(x86_LODSB),
+ /*10188*/ uint16(x86_xMatch),
+ /*10189*/ uint16(x86_xCondIs64), 10192, 10202,
+ /*10192*/ uint16(x86_xCondDataSize), 10196, 10199, 0,
+ /*10196*/ uint16(x86_xSetOp), uint16(x86_LODSW),
+ /*10198*/ uint16(x86_xMatch),
+ /*10199*/ uint16(x86_xSetOp), uint16(x86_LODSD),
+ /*10201*/ uint16(x86_xMatch),
+ /*10202*/ uint16(x86_xCondDataSize), 10196, 10199, 10206,
+ /*10206*/ uint16(x86_xSetOp), uint16(x86_LODSQ),
+ /*10208*/ uint16(x86_xMatch),
+ /*10209*/ uint16(x86_xSetOp), uint16(x86_SCASB),
+ /*10211*/ uint16(x86_xMatch),
+ /*10212*/ uint16(x86_xCondIs64), 10215, 10225,
+ /*10215*/ uint16(x86_xCondDataSize), 10219, 10222, 0,
+ /*10219*/ uint16(x86_xSetOp), uint16(x86_SCASW),
+ /*10221*/ uint16(x86_xMatch),
+ /*10222*/ uint16(x86_xSetOp), uint16(x86_SCASD),
+ /*10224*/ uint16(x86_xMatch),
+ /*10225*/ uint16(x86_xCondDataSize), 10219, 10222, 10229,
+ /*10229*/ uint16(x86_xSetOp), uint16(x86_SCASQ),
+ /*10231*/ uint16(x86_xMatch),
+ /*10232*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10234*/ uint16(x86_xReadIb),
+ /*10235*/ uint16(x86_xArgR8op),
+ /*10236*/ uint16(x86_xArgImm8u),
+ /*10237*/ uint16(x86_xMatch),
+ /*10238*/ uint16(x86_xCondIs64), 10241, 10257,
+ /*10241*/ uint16(x86_xCondDataSize), 10245, 10251, 0,
+ /*10245*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10247*/ uint16(x86_xReadIw),
+ /*10248*/ uint16(x86_xArgR16op),
+ /*10249*/ uint16(x86_xArgImm16),
+ /*10250*/ uint16(x86_xMatch),
+ /*10251*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10253*/ uint16(x86_xReadId),
+ /*10254*/ uint16(x86_xArgR32op),
+ /*10255*/ uint16(x86_xArgImm32),
+ /*10256*/ uint16(x86_xMatch),
+ /*10257*/ uint16(x86_xCondDataSize), 10245, 10251, 10261,
+ /*10261*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10263*/ uint16(x86_xReadIo),
+ /*10264*/ uint16(x86_xArgR64op),
+ /*10265*/ uint16(x86_xArgImm64),
+ /*10266*/ uint16(x86_xMatch),
+ /*10267*/ uint16(x86_xCondSlashR),
+ 10276, // 0
+ 10282, // 1
+ 10288, // 2
+ 10294, // 3
+ 10300, // 4
+ 10306, // 5
+ 0, // 6
+ 10312, // 7
+ /*10276*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10278*/ uint16(x86_xReadIb),
+ /*10279*/ uint16(x86_xArgRM8),
+ /*10280*/ uint16(x86_xArgImm8u),
+ /*10281*/ uint16(x86_xMatch),
+ /*10282*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10284*/ uint16(x86_xReadIb),
+ /*10285*/ uint16(x86_xArgRM8),
+ /*10286*/ uint16(x86_xArgImm8u),
+ /*10287*/ uint16(x86_xMatch),
+ /*10288*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10290*/ uint16(x86_xReadIb),
+ /*10291*/ uint16(x86_xArgRM8),
+ /*10292*/ uint16(x86_xArgImm8u),
+ /*10293*/ uint16(x86_xMatch),
+ /*10294*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10296*/ uint16(x86_xReadIb),
+ /*10297*/ uint16(x86_xArgRM8),
+ /*10298*/ uint16(x86_xArgImm8u),
+ /*10299*/ uint16(x86_xMatch),
+ /*10300*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10302*/ uint16(x86_xReadIb),
+ /*10303*/ uint16(x86_xArgRM8),
+ /*10304*/ uint16(x86_xArgImm8u),
+ /*10305*/ uint16(x86_xMatch),
+ /*10306*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10308*/ uint16(x86_xReadIb),
+ /*10309*/ uint16(x86_xArgRM8),
+ /*10310*/ uint16(x86_xArgImm8u),
+ /*10311*/ uint16(x86_xMatch),
+ /*10312*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10314*/ uint16(x86_xReadIb),
+ /*10315*/ uint16(x86_xArgRM8),
+ /*10316*/ uint16(x86_xArgImm8u),
+ /*10317*/ uint16(x86_xMatch),
+ /*10318*/ uint16(x86_xCondSlashR),
+ 10327, // 0
+ 10349, // 1
+ 10371, // 2
+ 10400, // 3
+ 10429, // 4
+ 10458, // 5
+ 0, // 6
+ 10487, // 7
+ /*10327*/ uint16(x86_xCondDataSize), 10331, 10337, 10343,
+ /*10331*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10333*/ uint16(x86_xReadIb),
+ /*10334*/ uint16(x86_xArgRM16),
+ /*10335*/ uint16(x86_xArgImm8u),
+ /*10336*/ uint16(x86_xMatch),
+ /*10337*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10339*/ uint16(x86_xReadIb),
+ /*10340*/ uint16(x86_xArgRM32),
+ /*10341*/ uint16(x86_xArgImm8u),
+ /*10342*/ uint16(x86_xMatch),
+ /*10343*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10345*/ uint16(x86_xReadIb),
+ /*10346*/ uint16(x86_xArgRM64),
+ /*10347*/ uint16(x86_xArgImm8u),
+ /*10348*/ uint16(x86_xMatch),
+ /*10349*/ uint16(x86_xCondDataSize), 10353, 10359, 10365,
+ /*10353*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10355*/ uint16(x86_xReadIb),
+ /*10356*/ uint16(x86_xArgRM16),
+ /*10357*/ uint16(x86_xArgImm8u),
+ /*10358*/ uint16(x86_xMatch),
+ /*10359*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10361*/ uint16(x86_xReadIb),
+ /*10362*/ uint16(x86_xArgRM32),
+ /*10363*/ uint16(x86_xArgImm8u),
+ /*10364*/ uint16(x86_xMatch),
+ /*10365*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10367*/ uint16(x86_xReadIb),
+ /*10368*/ uint16(x86_xArgRM64),
+ /*10369*/ uint16(x86_xArgImm8u),
+ /*10370*/ uint16(x86_xMatch),
+ /*10371*/ uint16(x86_xCondIs64), 10374, 10390,
+ /*10374*/ uint16(x86_xCondDataSize), 10378, 10384, 0,
+ /*10378*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10380*/ uint16(x86_xReadIb),
+ /*10381*/ uint16(x86_xArgRM16),
+ /*10382*/ uint16(x86_xArgImm8u),
+ /*10383*/ uint16(x86_xMatch),
+ /*10384*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10386*/ uint16(x86_xReadIb),
+ /*10387*/ uint16(x86_xArgRM32),
+ /*10388*/ uint16(x86_xArgImm8u),
+ /*10389*/ uint16(x86_xMatch),
+ /*10390*/ uint16(x86_xCondDataSize), 10378, 10384, 10394,
+ /*10394*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10396*/ uint16(x86_xReadIb),
+ /*10397*/ uint16(x86_xArgRM64),
+ /*10398*/ uint16(x86_xArgImm8u),
+ /*10399*/ uint16(x86_xMatch),
+ /*10400*/ uint16(x86_xCondIs64), 10403, 10419,
+ /*10403*/ uint16(x86_xCondDataSize), 10407, 10413, 0,
+ /*10407*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10409*/ uint16(x86_xReadIb),
+ /*10410*/ uint16(x86_xArgRM16),
+ /*10411*/ uint16(x86_xArgImm8u),
+ /*10412*/ uint16(x86_xMatch),
+ /*10413*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10415*/ uint16(x86_xReadIb),
+ /*10416*/ uint16(x86_xArgRM32),
+ /*10417*/ uint16(x86_xArgImm8u),
+ /*10418*/ uint16(x86_xMatch),
+ /*10419*/ uint16(x86_xCondDataSize), 10407, 10413, 10423,
+ /*10423*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10425*/ uint16(x86_xReadIb),
+ /*10426*/ uint16(x86_xArgRM64),
+ /*10427*/ uint16(x86_xArgImm8u),
+ /*10428*/ uint16(x86_xMatch),
+ /*10429*/ uint16(x86_xCondIs64), 10432, 10448,
+ /*10432*/ uint16(x86_xCondDataSize), 10436, 10442, 0,
+ /*10436*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10438*/ uint16(x86_xReadIb),
+ /*10439*/ uint16(x86_xArgRM16),
+ /*10440*/ uint16(x86_xArgImm8u),
+ /*10441*/ uint16(x86_xMatch),
+ /*10442*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10444*/ uint16(x86_xReadIb),
+ /*10445*/ uint16(x86_xArgRM32),
+ /*10446*/ uint16(x86_xArgImm8u),
+ /*10447*/ uint16(x86_xMatch),
+ /*10448*/ uint16(x86_xCondDataSize), 10436, 10442, 10452,
+ /*10452*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10454*/ uint16(x86_xReadIb),
+ /*10455*/ uint16(x86_xArgRM64),
+ /*10456*/ uint16(x86_xArgImm8u),
+ /*10457*/ uint16(x86_xMatch),
+ /*10458*/ uint16(x86_xCondIs64), 10461, 10477,
+ /*10461*/ uint16(x86_xCondDataSize), 10465, 10471, 0,
+ /*10465*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10467*/ uint16(x86_xReadIb),
+ /*10468*/ uint16(x86_xArgRM16),
+ /*10469*/ uint16(x86_xArgImm8u),
+ /*10470*/ uint16(x86_xMatch),
+ /*10471*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10473*/ uint16(x86_xReadIb),
+ /*10474*/ uint16(x86_xArgRM32),
+ /*10475*/ uint16(x86_xArgImm8u),
+ /*10476*/ uint16(x86_xMatch),
+ /*10477*/ uint16(x86_xCondDataSize), 10465, 10471, 10481,
+ /*10481*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10483*/ uint16(x86_xReadIb),
+ /*10484*/ uint16(x86_xArgRM64),
+ /*10485*/ uint16(x86_xArgImm8u),
+ /*10486*/ uint16(x86_xMatch),
+ /*10487*/ uint16(x86_xCondIs64), 10490, 10506,
+ /*10490*/ uint16(x86_xCondDataSize), 10494, 10500, 0,
+ /*10494*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10496*/ uint16(x86_xReadIb),
+ /*10497*/ uint16(x86_xArgRM16),
+ /*10498*/ uint16(x86_xArgImm8u),
+ /*10499*/ uint16(x86_xMatch),
+ /*10500*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10502*/ uint16(x86_xReadIb),
+ /*10503*/ uint16(x86_xArgRM32),
+ /*10504*/ uint16(x86_xArgImm8u),
+ /*10505*/ uint16(x86_xMatch),
+ /*10506*/ uint16(x86_xCondDataSize), 10494, 10500, 10510,
+ /*10510*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10512*/ uint16(x86_xReadIb),
+ /*10513*/ uint16(x86_xArgRM64),
+ /*10514*/ uint16(x86_xArgImm8u),
+ /*10515*/ uint16(x86_xMatch),
+ /*10516*/ uint16(x86_xSetOp), uint16(x86_RET),
+ /*10518*/ uint16(x86_xReadIw),
+ /*10519*/ uint16(x86_xArgImm16u),
+ /*10520*/ uint16(x86_xMatch),
+ /*10521*/ uint16(x86_xSetOp), uint16(x86_RET),
+ /*10523*/ uint16(x86_xMatch),
+ /*10524*/ uint16(x86_xCondIs64), 10527, 0,
+ /*10527*/ uint16(x86_xCondDataSize), 10531, 10537, 0,
+ /*10531*/ uint16(x86_xSetOp), uint16(x86_LES),
+ /*10533*/ uint16(x86_xReadSlashR),
+ /*10534*/ uint16(x86_xArgR16),
+ /*10535*/ uint16(x86_xArgM16colon16),
+ /*10536*/ uint16(x86_xMatch),
+ /*10537*/ uint16(x86_xSetOp), uint16(x86_LES),
+ /*10539*/ uint16(x86_xReadSlashR),
+ /*10540*/ uint16(x86_xArgR32),
+ /*10541*/ uint16(x86_xArgM16colon32),
+ /*10542*/ uint16(x86_xMatch),
+ /*10543*/ uint16(x86_xCondIs64), 10546, 0,
+ /*10546*/ uint16(x86_xCondDataSize), 10550, 10556, 0,
+ /*10550*/ uint16(x86_xSetOp), uint16(x86_LDS),
+ /*10552*/ uint16(x86_xReadSlashR),
+ /*10553*/ uint16(x86_xArgR16),
+ /*10554*/ uint16(x86_xArgM16colon16),
+ /*10555*/ uint16(x86_xMatch),
+ /*10556*/ uint16(x86_xSetOp), uint16(x86_LDS),
+ /*10558*/ uint16(x86_xReadSlashR),
+ /*10559*/ uint16(x86_xArgR32),
+ /*10560*/ uint16(x86_xArgM16colon32),
+ /*10561*/ uint16(x86_xMatch),
+ /*10562*/ uint16(x86_xCondByte), 1,
+ 0xF8, 10581,
+ /*10566*/ uint16(x86_xCondSlashR),
+ 10575, // 0
+ 0, // 1
+ 0, // 2
+ 0, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*10575*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10577*/ uint16(x86_xReadIb),
+ /*10578*/ uint16(x86_xArgRM8),
+ /*10579*/ uint16(x86_xArgImm8u),
+ /*10580*/ uint16(x86_xMatch),
+ /*10581*/ uint16(x86_xSetOp), uint16(x86_XABORT),
+ /*10583*/ uint16(x86_xReadIb),
+ /*10584*/ uint16(x86_xArgImm8u),
+ /*10585*/ uint16(x86_xMatch),
+ /*10586*/ uint16(x86_xCondByte), 1,
+ 0xF8, 10628,
+ /*10590*/ uint16(x86_xCondSlashR),
+ 10599, // 0
+ 0, // 1
+ 0, // 2
+ 0, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*10599*/ uint16(x86_xCondIs64), 10602, 10618,
+ /*10602*/ uint16(x86_xCondDataSize), 10606, 10612, 0,
+ /*10606*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10608*/ uint16(x86_xReadIw),
+ /*10609*/ uint16(x86_xArgRM16),
+ /*10610*/ uint16(x86_xArgImm16),
+ /*10611*/ uint16(x86_xMatch),
+ /*10612*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10614*/ uint16(x86_xReadId),
+ /*10615*/ uint16(x86_xArgRM32),
+ /*10616*/ uint16(x86_xArgImm32),
+ /*10617*/ uint16(x86_xMatch),
+ /*10618*/ uint16(x86_xCondDataSize), 10606, 10612, 10622,
+ /*10622*/ uint16(x86_xSetOp), uint16(x86_MOV),
+ /*10624*/ uint16(x86_xReadId),
+ /*10625*/ uint16(x86_xArgRM64),
+ /*10626*/ uint16(x86_xArgImm32),
+ /*10627*/ uint16(x86_xMatch),
+ /*10628*/ uint16(x86_xCondDataSize), 10632, 10637, 10642,
+ /*10632*/ uint16(x86_xSetOp), uint16(x86_XBEGIN),
+ /*10634*/ uint16(x86_xReadCw),
+ /*10635*/ uint16(x86_xArgRel16),
+ /*10636*/ uint16(x86_xMatch),
+ /*10637*/ uint16(x86_xSetOp), uint16(x86_XBEGIN),
+ /*10639*/ uint16(x86_xReadCd),
+ /*10640*/ uint16(x86_xArgRel32),
+ /*10641*/ uint16(x86_xMatch),
+ /*10642*/ uint16(x86_xSetOp), uint16(x86_XBEGIN),
+ /*10644*/ uint16(x86_xReadCd),
+ /*10645*/ uint16(x86_xArgRel32),
+ /*10646*/ uint16(x86_xMatch),
+ /*10647*/ uint16(x86_xSetOp), uint16(x86_ENTER),
+ /*10649*/ uint16(x86_xReadIw),
+ /*10650*/ uint16(x86_xReadIb),
+ /*10651*/ uint16(x86_xArgImm16u),
+ /*10652*/ uint16(x86_xArgImm8u),
+ /*10653*/ uint16(x86_xMatch),
+ /*10654*/ uint16(x86_xCondIs64), 10657, 10667,
+ /*10657*/ uint16(x86_xCondDataSize), 10661, 10664, 0,
+ /*10661*/ uint16(x86_xSetOp), uint16(x86_LEAVE),
+ /*10663*/ uint16(x86_xMatch),
+ /*10664*/ uint16(x86_xSetOp), uint16(x86_LEAVE),
+ /*10666*/ uint16(x86_xMatch),
+ /*10667*/ uint16(x86_xCondDataSize), 10661, 10671, 10674,
+ /*10671*/ uint16(x86_xSetOp), uint16(x86_LEAVE),
+ /*10673*/ uint16(x86_xMatch),
+ /*10674*/ uint16(x86_xSetOp), uint16(x86_LEAVE),
+ /*10676*/ uint16(x86_xMatch),
+ /*10677*/ uint16(x86_xSetOp), uint16(x86_LRET),
+ /*10679*/ uint16(x86_xReadIw),
+ /*10680*/ uint16(x86_xArgImm16u),
+ /*10681*/ uint16(x86_xMatch),
+ /*10682*/ uint16(x86_xSetOp), uint16(x86_LRET),
+ /*10684*/ uint16(x86_xMatch),
+ /*10685*/ uint16(x86_xSetOp), uint16(x86_INT),
+ /*10687*/ uint16(x86_xArg3),
+ /*10688*/ uint16(x86_xMatch),
+ /*10689*/ uint16(x86_xSetOp), uint16(x86_INT),
+ /*10691*/ uint16(x86_xReadIb),
+ /*10692*/ uint16(x86_xArgImm8u),
+ /*10693*/ uint16(x86_xMatch),
+ /*10694*/ uint16(x86_xCondIs64), 10697, 0,
+ /*10697*/ uint16(x86_xSetOp), uint16(x86_INTO),
+ /*10699*/ uint16(x86_xMatch),
+ /*10700*/ uint16(x86_xCondIs64), 10703, 10713,
+ /*10703*/ uint16(x86_xCondDataSize), 10707, 10710, 0,
+ /*10707*/ uint16(x86_xSetOp), uint16(x86_IRET),
+ /*10709*/ uint16(x86_xMatch),
+ /*10710*/ uint16(x86_xSetOp), uint16(x86_IRETD),
+ /*10712*/ uint16(x86_xMatch),
+ /*10713*/ uint16(x86_xCondDataSize), 10707, 10710, 10717,
+ /*10717*/ uint16(x86_xSetOp), uint16(x86_IRETQ),
+ /*10719*/ uint16(x86_xMatch),
+ /*10720*/ uint16(x86_xCondSlashR),
+ 10729, // 0
+ 10734, // 1
+ 10739, // 2
+ 10744, // 3
+ 10749, // 4
+ 10754, // 5
+ 0, // 6
+ 10759, // 7
+ /*10729*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10731*/ uint16(x86_xArgRM8),
+ /*10732*/ uint16(x86_xArg1),
+ /*10733*/ uint16(x86_xMatch),
+ /*10734*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10736*/ uint16(x86_xArgRM8),
+ /*10737*/ uint16(x86_xArg1),
+ /*10738*/ uint16(x86_xMatch),
+ /*10739*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10741*/ uint16(x86_xArgRM8),
+ /*10742*/ uint16(x86_xArg1),
+ /*10743*/ uint16(x86_xMatch),
+ /*10744*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10746*/ uint16(x86_xArgRM8),
+ /*10747*/ uint16(x86_xArg1),
+ /*10748*/ uint16(x86_xMatch),
+ /*10749*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10751*/ uint16(x86_xArgRM8),
+ /*10752*/ uint16(x86_xArg1),
+ /*10753*/ uint16(x86_xMatch),
+ /*10754*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10756*/ uint16(x86_xArgRM8),
+ /*10757*/ uint16(x86_xArg1),
+ /*10758*/ uint16(x86_xMatch),
+ /*10759*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10761*/ uint16(x86_xArgRM8),
+ /*10762*/ uint16(x86_xArg1),
+ /*10763*/ uint16(x86_xMatch),
+ /*10764*/ uint16(x86_xCondSlashR),
+ 10773, // 0
+ 10799, // 1
+ 10825, // 2
+ 10851, // 3
+ 10877, // 4
+ 10903, // 5
+ 0, // 6
+ 10929, // 7
+ /*10773*/ uint16(x86_xCondIs64), 10776, 10790,
+ /*10776*/ uint16(x86_xCondDataSize), 10780, 10785, 0,
+ /*10780*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10782*/ uint16(x86_xArgRM16),
+ /*10783*/ uint16(x86_xArg1),
+ /*10784*/ uint16(x86_xMatch),
+ /*10785*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10787*/ uint16(x86_xArgRM32),
+ /*10788*/ uint16(x86_xArg1),
+ /*10789*/ uint16(x86_xMatch),
+ /*10790*/ uint16(x86_xCondDataSize), 10780, 10785, 10794,
+ /*10794*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10796*/ uint16(x86_xArgRM64),
+ /*10797*/ uint16(x86_xArg1),
+ /*10798*/ uint16(x86_xMatch),
+ /*10799*/ uint16(x86_xCondIs64), 10802, 10816,
+ /*10802*/ uint16(x86_xCondDataSize), 10806, 10811, 0,
+ /*10806*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10808*/ uint16(x86_xArgRM16),
+ /*10809*/ uint16(x86_xArg1),
+ /*10810*/ uint16(x86_xMatch),
+ /*10811*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10813*/ uint16(x86_xArgRM32),
+ /*10814*/ uint16(x86_xArg1),
+ /*10815*/ uint16(x86_xMatch),
+ /*10816*/ uint16(x86_xCondDataSize), 10806, 10811, 10820,
+ /*10820*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10822*/ uint16(x86_xArgRM64),
+ /*10823*/ uint16(x86_xArg1),
+ /*10824*/ uint16(x86_xMatch),
+ /*10825*/ uint16(x86_xCondIs64), 10828, 10842,
+ /*10828*/ uint16(x86_xCondDataSize), 10832, 10837, 0,
+ /*10832*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10834*/ uint16(x86_xArgRM16),
+ /*10835*/ uint16(x86_xArg1),
+ /*10836*/ uint16(x86_xMatch),
+ /*10837*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10839*/ uint16(x86_xArgRM32),
+ /*10840*/ uint16(x86_xArg1),
+ /*10841*/ uint16(x86_xMatch),
+ /*10842*/ uint16(x86_xCondDataSize), 10832, 10837, 10846,
+ /*10846*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10848*/ uint16(x86_xArgRM64),
+ /*10849*/ uint16(x86_xArg1),
+ /*10850*/ uint16(x86_xMatch),
+ /*10851*/ uint16(x86_xCondIs64), 10854, 10868,
+ /*10854*/ uint16(x86_xCondDataSize), 10858, 10863, 0,
+ /*10858*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10860*/ uint16(x86_xArgRM16),
+ /*10861*/ uint16(x86_xArg1),
+ /*10862*/ uint16(x86_xMatch),
+ /*10863*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10865*/ uint16(x86_xArgRM32),
+ /*10866*/ uint16(x86_xArg1),
+ /*10867*/ uint16(x86_xMatch),
+ /*10868*/ uint16(x86_xCondDataSize), 10858, 10863, 10872,
+ /*10872*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10874*/ uint16(x86_xArgRM64),
+ /*10875*/ uint16(x86_xArg1),
+ /*10876*/ uint16(x86_xMatch),
+ /*10877*/ uint16(x86_xCondIs64), 10880, 10894,
+ /*10880*/ uint16(x86_xCondDataSize), 10884, 10889, 0,
+ /*10884*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10886*/ uint16(x86_xArgRM16),
+ /*10887*/ uint16(x86_xArg1),
+ /*10888*/ uint16(x86_xMatch),
+ /*10889*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10891*/ uint16(x86_xArgRM32),
+ /*10892*/ uint16(x86_xArg1),
+ /*10893*/ uint16(x86_xMatch),
+ /*10894*/ uint16(x86_xCondDataSize), 10884, 10889, 10898,
+ /*10898*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10900*/ uint16(x86_xArgRM64),
+ /*10901*/ uint16(x86_xArg1),
+ /*10902*/ uint16(x86_xMatch),
+ /*10903*/ uint16(x86_xCondIs64), 10906, 10920,
+ /*10906*/ uint16(x86_xCondDataSize), 10910, 10915, 0,
+ /*10910*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10912*/ uint16(x86_xArgRM16),
+ /*10913*/ uint16(x86_xArg1),
+ /*10914*/ uint16(x86_xMatch),
+ /*10915*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10917*/ uint16(x86_xArgRM32),
+ /*10918*/ uint16(x86_xArg1),
+ /*10919*/ uint16(x86_xMatch),
+ /*10920*/ uint16(x86_xCondDataSize), 10910, 10915, 10924,
+ /*10924*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10926*/ uint16(x86_xArgRM64),
+ /*10927*/ uint16(x86_xArg1),
+ /*10928*/ uint16(x86_xMatch),
+ /*10929*/ uint16(x86_xCondIs64), 10932, 10946,
+ /*10932*/ uint16(x86_xCondDataSize), 10936, 10941, 0,
+ /*10936*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10938*/ uint16(x86_xArgRM16),
+ /*10939*/ uint16(x86_xArg1),
+ /*10940*/ uint16(x86_xMatch),
+ /*10941*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10943*/ uint16(x86_xArgRM32),
+ /*10944*/ uint16(x86_xArg1),
+ /*10945*/ uint16(x86_xMatch),
+ /*10946*/ uint16(x86_xCondDataSize), 10936, 10941, 10950,
+ /*10950*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10952*/ uint16(x86_xArgRM64),
+ /*10953*/ uint16(x86_xArg1),
+ /*10954*/ uint16(x86_xMatch),
+ /*10955*/ uint16(x86_xCondSlashR),
+ 10964, // 0
+ 10969, // 1
+ 10974, // 2
+ 10979, // 3
+ 10984, // 4
+ 10989, // 5
+ 0, // 6
+ 10994, // 7
+ /*10964*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*10966*/ uint16(x86_xArgRM8),
+ /*10967*/ uint16(x86_xArgCL),
+ /*10968*/ uint16(x86_xMatch),
+ /*10969*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*10971*/ uint16(x86_xArgRM8),
+ /*10972*/ uint16(x86_xArgCL),
+ /*10973*/ uint16(x86_xMatch),
+ /*10974*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*10976*/ uint16(x86_xArgRM8),
+ /*10977*/ uint16(x86_xArgCL),
+ /*10978*/ uint16(x86_xMatch),
+ /*10979*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*10981*/ uint16(x86_xArgRM8),
+ /*10982*/ uint16(x86_xArgCL),
+ /*10983*/ uint16(x86_xMatch),
+ /*10984*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*10986*/ uint16(x86_xArgRM8),
+ /*10987*/ uint16(x86_xArgCL),
+ /*10988*/ uint16(x86_xMatch),
+ /*10989*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*10991*/ uint16(x86_xArgRM8),
+ /*10992*/ uint16(x86_xArgCL),
+ /*10993*/ uint16(x86_xMatch),
+ /*10994*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*10996*/ uint16(x86_xArgRM8),
+ /*10997*/ uint16(x86_xArgCL),
+ /*10998*/ uint16(x86_xMatch),
+ /*10999*/ uint16(x86_xCondSlashR),
+ 11008, // 0
+ 11034, // 1
+ 11060, // 2
+ 11086, // 3
+ 11112, // 4
+ 11138, // 5
+ 0, // 6
+ 11164, // 7
+ /*11008*/ uint16(x86_xCondIs64), 11011, 11025,
+ /*11011*/ uint16(x86_xCondDataSize), 11015, 11020, 0,
+ /*11015*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*11017*/ uint16(x86_xArgRM16),
+ /*11018*/ uint16(x86_xArgCL),
+ /*11019*/ uint16(x86_xMatch),
+ /*11020*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*11022*/ uint16(x86_xArgRM32),
+ /*11023*/ uint16(x86_xArgCL),
+ /*11024*/ uint16(x86_xMatch),
+ /*11025*/ uint16(x86_xCondDataSize), 11015, 11020, 11029,
+ /*11029*/ uint16(x86_xSetOp), uint16(x86_ROL),
+ /*11031*/ uint16(x86_xArgRM64),
+ /*11032*/ uint16(x86_xArgCL),
+ /*11033*/ uint16(x86_xMatch),
+ /*11034*/ uint16(x86_xCondIs64), 11037, 11051,
+ /*11037*/ uint16(x86_xCondDataSize), 11041, 11046, 0,
+ /*11041*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*11043*/ uint16(x86_xArgRM16),
+ /*11044*/ uint16(x86_xArgCL),
+ /*11045*/ uint16(x86_xMatch),
+ /*11046*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*11048*/ uint16(x86_xArgRM32),
+ /*11049*/ uint16(x86_xArgCL),
+ /*11050*/ uint16(x86_xMatch),
+ /*11051*/ uint16(x86_xCondDataSize), 11041, 11046, 11055,
+ /*11055*/ uint16(x86_xSetOp), uint16(x86_ROR),
+ /*11057*/ uint16(x86_xArgRM64),
+ /*11058*/ uint16(x86_xArgCL),
+ /*11059*/ uint16(x86_xMatch),
+ /*11060*/ uint16(x86_xCondIs64), 11063, 11077,
+ /*11063*/ uint16(x86_xCondDataSize), 11067, 11072, 0,
+ /*11067*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*11069*/ uint16(x86_xArgRM16),
+ /*11070*/ uint16(x86_xArgCL),
+ /*11071*/ uint16(x86_xMatch),
+ /*11072*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*11074*/ uint16(x86_xArgRM32),
+ /*11075*/ uint16(x86_xArgCL),
+ /*11076*/ uint16(x86_xMatch),
+ /*11077*/ uint16(x86_xCondDataSize), 11067, 11072, 11081,
+ /*11081*/ uint16(x86_xSetOp), uint16(x86_RCL),
+ /*11083*/ uint16(x86_xArgRM64),
+ /*11084*/ uint16(x86_xArgCL),
+ /*11085*/ uint16(x86_xMatch),
+ /*11086*/ uint16(x86_xCondIs64), 11089, 11103,
+ /*11089*/ uint16(x86_xCondDataSize), 11093, 11098, 0,
+ /*11093*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*11095*/ uint16(x86_xArgRM16),
+ /*11096*/ uint16(x86_xArgCL),
+ /*11097*/ uint16(x86_xMatch),
+ /*11098*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*11100*/ uint16(x86_xArgRM32),
+ /*11101*/ uint16(x86_xArgCL),
+ /*11102*/ uint16(x86_xMatch),
+ /*11103*/ uint16(x86_xCondDataSize), 11093, 11098, 11107,
+ /*11107*/ uint16(x86_xSetOp), uint16(x86_RCR),
+ /*11109*/ uint16(x86_xArgRM64),
+ /*11110*/ uint16(x86_xArgCL),
+ /*11111*/ uint16(x86_xMatch),
+ /*11112*/ uint16(x86_xCondIs64), 11115, 11129,
+ /*11115*/ uint16(x86_xCondDataSize), 11119, 11124, 0,
+ /*11119*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*11121*/ uint16(x86_xArgRM16),
+ /*11122*/ uint16(x86_xArgCL),
+ /*11123*/ uint16(x86_xMatch),
+ /*11124*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*11126*/ uint16(x86_xArgRM32),
+ /*11127*/ uint16(x86_xArgCL),
+ /*11128*/ uint16(x86_xMatch),
+ /*11129*/ uint16(x86_xCondDataSize), 11119, 11124, 11133,
+ /*11133*/ uint16(x86_xSetOp), uint16(x86_SHL),
+ /*11135*/ uint16(x86_xArgRM64),
+ /*11136*/ uint16(x86_xArgCL),
+ /*11137*/ uint16(x86_xMatch),
+ /*11138*/ uint16(x86_xCondIs64), 11141, 11155,
+ /*11141*/ uint16(x86_xCondDataSize), 11145, 11150, 0,
+ /*11145*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*11147*/ uint16(x86_xArgRM16),
+ /*11148*/ uint16(x86_xArgCL),
+ /*11149*/ uint16(x86_xMatch),
+ /*11150*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*11152*/ uint16(x86_xArgRM32),
+ /*11153*/ uint16(x86_xArgCL),
+ /*11154*/ uint16(x86_xMatch),
+ /*11155*/ uint16(x86_xCondDataSize), 11145, 11150, 11159,
+ /*11159*/ uint16(x86_xSetOp), uint16(x86_SHR),
+ /*11161*/ uint16(x86_xArgRM64),
+ /*11162*/ uint16(x86_xArgCL),
+ /*11163*/ uint16(x86_xMatch),
+ /*11164*/ uint16(x86_xCondIs64), 11167, 11181,
+ /*11167*/ uint16(x86_xCondDataSize), 11171, 11176, 0,
+ /*11171*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*11173*/ uint16(x86_xArgRM16),
+ /*11174*/ uint16(x86_xArgCL),
+ /*11175*/ uint16(x86_xMatch),
+ /*11176*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*11178*/ uint16(x86_xArgRM32),
+ /*11179*/ uint16(x86_xArgCL),
+ /*11180*/ uint16(x86_xMatch),
+ /*11181*/ uint16(x86_xCondDataSize), 11171, 11176, 11185,
+ /*11185*/ uint16(x86_xSetOp), uint16(x86_SAR),
+ /*11187*/ uint16(x86_xArgRM64),
+ /*11188*/ uint16(x86_xArgCL),
+ /*11189*/ uint16(x86_xMatch),
+ /*11190*/ uint16(x86_xCondIs64), 11193, 0,
+ /*11193*/ uint16(x86_xSetOp), uint16(x86_AAM),
+ /*11195*/ uint16(x86_xReadIb),
+ /*11196*/ uint16(x86_xArgImm8u),
+ /*11197*/ uint16(x86_xMatch),
+ /*11198*/ uint16(x86_xCondIs64), 11201, 0,
+ /*11201*/ uint16(x86_xSetOp), uint16(x86_AAD),
+ /*11203*/ uint16(x86_xReadIb),
+ /*11204*/ uint16(x86_xArgImm8u),
+ /*11205*/ uint16(x86_xMatch),
+ /*11206*/ uint16(x86_xCondIs64), 11209, 11212,
+ /*11209*/ uint16(x86_xSetOp), uint16(x86_XLATB),
+ /*11211*/ uint16(x86_xMatch),
+ /*11212*/ uint16(x86_xCondDataSize), 11209, 11209, 11216,
+ /*11216*/ uint16(x86_xSetOp), uint16(x86_XLATB),
+ /*11218*/ uint16(x86_xMatch),
+ /*11219*/ uint16(x86_xCondByte), 64,
+ 0xc0, 11390,
+ 0xc1, 11390,
+ 0xc2, 11390,
+ 0xc3, 11390,
+ 0xc4, 11390,
+ 0xc5, 11390,
+ 0xc6, 11390,
+ 0xc7, 11390,
+ 0xc8, 11395,
+ 0xc9, 11395,
+ 0xca, 11395,
+ 0xcb, 11395,
+ 0xcc, 11395,
+ 0xcd, 11395,
+ 0xce, 11395,
+ 0xcf, 11395,
+ 0xd0, 11400,
+ 0xd1, 11400,
+ 0xd2, 11400,
+ 0xd3, 11400,
+ 0xd4, 11400,
+ 0xd5, 11400,
+ 0xd6, 11400,
+ 0xd7, 11400,
+ 0xd8, 11404,
+ 0xd9, 11404,
+ 0xda, 11404,
+ 0xdb, 11404,
+ 0xdc, 11404,
+ 0xdd, 11404,
+ 0xde, 11404,
+ 0xdf, 11404,
+ 0xe0, 11408,
+ 0xe1, 11408,
+ 0xe2, 11408,
+ 0xe3, 11408,
+ 0xe4, 11408,
+ 0xe5, 11408,
+ 0xe6, 11408,
+ 0xe7, 11408,
+ 0xe8, 11413,
+ 0xe9, 11413,
+ 0xea, 11413,
+ 0xeb, 11413,
+ 0xec, 11413,
+ 0xed, 11413,
+ 0xee, 11413,
+ 0xef, 11413,
+ 0xf0, 11418,
+ 0xf1, 11418,
+ 0xf2, 11418,
+ 0xf3, 11418,
+ 0xf4, 11418,
+ 0xf5, 11418,
+ 0xf6, 11418,
+ 0xf7, 11418,
+ 0xf8, 11423,
+ 0xf9, 11423,
+ 0xfa, 11423,
+ 0xfb, 11423,
+ 0xfc, 11423,
+ 0xfd, 11423,
+ 0xfe, 11423,
+ 0xff, 11423,
+ /*11349*/ uint16(x86_xCondSlashR),
+ 11358, // 0
+ 11362, // 1
+ 11366, // 2
+ 11370, // 3
+ 11374, // 4
+ 11378, // 5
+ 11382, // 6
+ 11386, // 7
+ /*11358*/ uint16(x86_xSetOp), uint16(x86_FADD),
+ /*11360*/ uint16(x86_xArgM32fp),
+ /*11361*/ uint16(x86_xMatch),
+ /*11362*/ uint16(x86_xSetOp), uint16(x86_FMUL),
+ /*11364*/ uint16(x86_xArgM32fp),
+ /*11365*/ uint16(x86_xMatch),
+ /*11366*/ uint16(x86_xSetOp), uint16(x86_FCOM),
+ /*11368*/ uint16(x86_xArgM32fp),
+ /*11369*/ uint16(x86_xMatch),
+ /*11370*/ uint16(x86_xSetOp), uint16(x86_FCOMP),
+ /*11372*/ uint16(x86_xArgM32fp),
+ /*11373*/ uint16(x86_xMatch),
+ /*11374*/ uint16(x86_xSetOp), uint16(x86_FSUB),
+ /*11376*/ uint16(x86_xArgM32fp),
+ /*11377*/ uint16(x86_xMatch),
+ /*11378*/ uint16(x86_xSetOp), uint16(x86_FSUBR),
+ /*11380*/ uint16(x86_xArgM32fp),
+ /*11381*/ uint16(x86_xMatch),
+ /*11382*/ uint16(x86_xSetOp), uint16(x86_FDIV),
+ /*11384*/ uint16(x86_xArgM32fp),
+ /*11385*/ uint16(x86_xMatch),
+ /*11386*/ uint16(x86_xSetOp), uint16(x86_FDIVR),
+ /*11388*/ uint16(x86_xArgM32fp),
+ /*11389*/ uint16(x86_xMatch),
+ /*11390*/ uint16(x86_xSetOp), uint16(x86_FADD),
+ /*11392*/ uint16(x86_xArgST),
+ /*11393*/ uint16(x86_xArgSTi),
+ /*11394*/ uint16(x86_xMatch),
+ /*11395*/ uint16(x86_xSetOp), uint16(x86_FMUL),
+ /*11397*/ uint16(x86_xArgST),
+ /*11398*/ uint16(x86_xArgSTi),
+ /*11399*/ uint16(x86_xMatch),
+ /*11400*/ uint16(x86_xSetOp), uint16(x86_FCOM),
+ /*11402*/ uint16(x86_xArgSTi),
+ /*11403*/ uint16(x86_xMatch),
+ /*11404*/ uint16(x86_xSetOp), uint16(x86_FCOMP),
+ /*11406*/ uint16(x86_xArgSTi),
+ /*11407*/ uint16(x86_xMatch),
+ /*11408*/ uint16(x86_xSetOp), uint16(x86_FSUB),
+ /*11410*/ uint16(x86_xArgST),
+ /*11411*/ uint16(x86_xArgSTi),
+ /*11412*/ uint16(x86_xMatch),
+ /*11413*/ uint16(x86_xSetOp), uint16(x86_FSUBR),
+ /*11415*/ uint16(x86_xArgST),
+ /*11416*/ uint16(x86_xArgSTi),
+ /*11417*/ uint16(x86_xMatch),
+ /*11418*/ uint16(x86_xSetOp), uint16(x86_FDIV),
+ /*11420*/ uint16(x86_xArgST),
+ /*11421*/ uint16(x86_xArgSTi),
+ /*11422*/ uint16(x86_xMatch),
+ /*11423*/ uint16(x86_xSetOp), uint16(x86_FDIVR),
+ /*11425*/ uint16(x86_xArgST),
+ /*11426*/ uint16(x86_xArgSTi),
+ /*11427*/ uint16(x86_xMatch),
+ /*11428*/ uint16(x86_xCondByte), 42,
+ 0xc0, 11551,
+ 0xc1, 11551,
+ 0xc2, 11551,
+ 0xc3, 11551,
+ 0xc4, 11551,
+ 0xc5, 11551,
+ 0xc6, 11551,
+ 0xc7, 11551,
+ 0xc8, 11555,
+ 0xc9, 11555,
+ 0xca, 11555,
+ 0xcb, 11555,
+ 0xcc, 11555,
+ 0xcd, 11555,
+ 0xce, 11555,
+ 0xcf, 11555,
+ 0xD0, 11559,
+ 0xE0, 11562,
+ 0xE1, 11565,
+ 0xE4, 11568,
+ 0xE5, 11571,
+ 0xE8, 11574,
+ 0xE9, 11577,
+ 0xEA, 11580,
+ 0xEB, 11583,
+ 0xEC, 11586,
+ 0xF0, 11589,
+ 0xF1, 11592,
+ 0xF2, 11595,
+ 0xF3, 11598,
+ 0xF4, 11601,
+ 0xF5, 11604,
+ 0xF6, 11607,
+ 0xF7, 11610,
+ 0xF8, 11613,
+ 0xF9, 11616,
+ 0xFA, 11619,
+ 0xFB, 11622,
+ 0xFC, 11625,
+ 0xFD, 11628,
+ 0xFE, 11631,
+ 0xFF, 11634,
+ /*11514*/ uint16(x86_xCondSlashR),
+ 11523, // 0
+ 0, // 1
+ 11527, // 2
+ 11531, // 3
+ 11535, // 4
+ 11539, // 5
+ 11543, // 6
+ 11547, // 7
+ /*11523*/ uint16(x86_xSetOp), uint16(x86_FLD),
+ /*11525*/ uint16(x86_xArgM32fp),
+ /*11526*/ uint16(x86_xMatch),
+ /*11527*/ uint16(x86_xSetOp), uint16(x86_FST),
+ /*11529*/ uint16(x86_xArgM32fp),
+ /*11530*/ uint16(x86_xMatch),
+ /*11531*/ uint16(x86_xSetOp), uint16(x86_FSTP),
+ /*11533*/ uint16(x86_xArgM32fp),
+ /*11534*/ uint16(x86_xMatch),
+ /*11535*/ uint16(x86_xSetOp), uint16(x86_FLDENV),
+ /*11537*/ uint16(x86_xArgM1428byte),
+ /*11538*/ uint16(x86_xMatch),
+ /*11539*/ uint16(x86_xSetOp), uint16(x86_FLDCW),
+ /*11541*/ uint16(x86_xArgM2byte),
+ /*11542*/ uint16(x86_xMatch),
+ /*11543*/ uint16(x86_xSetOp), uint16(x86_FNSTENV),
+ /*11545*/ uint16(x86_xArgM1428byte),
+ /*11546*/ uint16(x86_xMatch),
+ /*11547*/ uint16(x86_xSetOp), uint16(x86_FNSTCW),
+ /*11549*/ uint16(x86_xArgM2byte),
+ /*11550*/ uint16(x86_xMatch),
+ /*11551*/ uint16(x86_xSetOp), uint16(x86_FLD),
+ /*11553*/ uint16(x86_xArgSTi),
+ /*11554*/ uint16(x86_xMatch),
+ /*11555*/ uint16(x86_xSetOp), uint16(x86_FXCH),
+ /*11557*/ uint16(x86_xArgSTi),
+ /*11558*/ uint16(x86_xMatch),
+ /*11559*/ uint16(x86_xSetOp), uint16(x86_FNOP),
+ /*11561*/ uint16(x86_xMatch),
+ /*11562*/ uint16(x86_xSetOp), uint16(x86_FCHS),
+ /*11564*/ uint16(x86_xMatch),
+ /*11565*/ uint16(x86_xSetOp), uint16(x86_FABS),
+ /*11567*/ uint16(x86_xMatch),
+ /*11568*/ uint16(x86_xSetOp), uint16(x86_FTST),
+ /*11570*/ uint16(x86_xMatch),
+ /*11571*/ uint16(x86_xSetOp), uint16(x86_FXAM),
+ /*11573*/ uint16(x86_xMatch),
+ /*11574*/ uint16(x86_xSetOp), uint16(x86_FLD1),
+ /*11576*/ uint16(x86_xMatch),
+ /*11577*/ uint16(x86_xSetOp), uint16(x86_FLDL2T),
+ /*11579*/ uint16(x86_xMatch),
+ /*11580*/ uint16(x86_xSetOp), uint16(x86_FLDL2E),
+ /*11582*/ uint16(x86_xMatch),
+ /*11583*/ uint16(x86_xSetOp), uint16(x86_FLDPI),
+ /*11585*/ uint16(x86_xMatch),
+ /*11586*/ uint16(x86_xSetOp), uint16(x86_FLDLG2),
+ /*11588*/ uint16(x86_xMatch),
+ /*11589*/ uint16(x86_xSetOp), uint16(x86_F2XM1),
+ /*11591*/ uint16(x86_xMatch),
+ /*11592*/ uint16(x86_xSetOp), uint16(x86_FYL2X),
+ /*11594*/ uint16(x86_xMatch),
+ /*11595*/ uint16(x86_xSetOp), uint16(x86_FPTAN),
+ /*11597*/ uint16(x86_xMatch),
+ /*11598*/ uint16(x86_xSetOp), uint16(x86_FPATAN),
+ /*11600*/ uint16(x86_xMatch),
+ /*11601*/ uint16(x86_xSetOp), uint16(x86_FXTRACT),
+ /*11603*/ uint16(x86_xMatch),
+ /*11604*/ uint16(x86_xSetOp), uint16(x86_FPREM1),
+ /*11606*/ uint16(x86_xMatch),
+ /*11607*/ uint16(x86_xSetOp), uint16(x86_FDECSTP),
+ /*11609*/ uint16(x86_xMatch),
+ /*11610*/ uint16(x86_xSetOp), uint16(x86_FINCSTP),
+ /*11612*/ uint16(x86_xMatch),
+ /*11613*/ uint16(x86_xSetOp), uint16(x86_FPREM),
+ /*11615*/ uint16(x86_xMatch),
+ /*11616*/ uint16(x86_xSetOp), uint16(x86_FYL2XP1),
+ /*11618*/ uint16(x86_xMatch),
+ /*11619*/ uint16(x86_xSetOp), uint16(x86_FSQRT),
+ /*11621*/ uint16(x86_xMatch),
+ /*11622*/ uint16(x86_xSetOp), uint16(x86_FSINCOS),
+ /*11624*/ uint16(x86_xMatch),
+ /*11625*/ uint16(x86_xSetOp), uint16(x86_FRNDINT),
+ /*11627*/ uint16(x86_xMatch),
+ /*11628*/ uint16(x86_xSetOp), uint16(x86_FSCALE),
+ /*11630*/ uint16(x86_xMatch),
+ /*11631*/ uint16(x86_xSetOp), uint16(x86_FSIN),
+ /*11633*/ uint16(x86_xMatch),
+ /*11634*/ uint16(x86_xSetOp), uint16(x86_FCOS),
+ /*11636*/ uint16(x86_xMatch),
+ /*11637*/ uint16(x86_xCondByte), 33,
+ 0xc0, 11746,
+ 0xc1, 11746,
+ 0xc2, 11746,
+ 0xc3, 11746,
+ 0xc4, 11746,
+ 0xc5, 11746,
+ 0xc6, 11746,
+ 0xc7, 11746,
+ 0xc8, 11751,
+ 0xc9, 11751,
+ 0xca, 11751,
+ 0xcb, 11751,
+ 0xcc, 11751,
+ 0xcd, 11751,
+ 0xce, 11751,
+ 0xcf, 11751,
+ 0xd0, 11756,
+ 0xd1, 11756,
+ 0xd2, 11756,
+ 0xd3, 11756,
+ 0xd4, 11756,
+ 0xd5, 11756,
+ 0xd6, 11756,
+ 0xd7, 11756,
+ 0xd8, 11761,
+ 0xd9, 11761,
+ 0xda, 11761,
+ 0xdb, 11761,
+ 0xdc, 11761,
+ 0xdd, 11761,
+ 0xde, 11761,
+ 0xdf, 11761,
+ 0xE9, 11766,
+ /*11705*/ uint16(x86_xCondSlashR),
+ 11714, // 0
+ 11718, // 1
+ 11722, // 2
+ 11726, // 3
+ 11730, // 4
+ 11734, // 5
+ 11738, // 6
+ 11742, // 7
+ /*11714*/ uint16(x86_xSetOp), uint16(x86_FIADD),
+ /*11716*/ uint16(x86_xArgM32int),
+ /*11717*/ uint16(x86_xMatch),
+ /*11718*/ uint16(x86_xSetOp), uint16(x86_FIMUL),
+ /*11720*/ uint16(x86_xArgM32int),
+ /*11721*/ uint16(x86_xMatch),
+ /*11722*/ uint16(x86_xSetOp), uint16(x86_FICOM),
+ /*11724*/ uint16(x86_xArgM32int),
+ /*11725*/ uint16(x86_xMatch),
+ /*11726*/ uint16(x86_xSetOp), uint16(x86_FICOMP),
+ /*11728*/ uint16(x86_xArgM32int),
+ /*11729*/ uint16(x86_xMatch),
+ /*11730*/ uint16(x86_xSetOp), uint16(x86_FISUB),
+ /*11732*/ uint16(x86_xArgM32int),
+ /*11733*/ uint16(x86_xMatch),
+ /*11734*/ uint16(x86_xSetOp), uint16(x86_FISUBR),
+ /*11736*/ uint16(x86_xArgM32int),
+ /*11737*/ uint16(x86_xMatch),
+ /*11738*/ uint16(x86_xSetOp), uint16(x86_FIDIV),
+ /*11740*/ uint16(x86_xArgM32int),
+ /*11741*/ uint16(x86_xMatch),
+ /*11742*/ uint16(x86_xSetOp), uint16(x86_FIDIVR),
+ /*11744*/ uint16(x86_xArgM32int),
+ /*11745*/ uint16(x86_xMatch),
+ /*11746*/ uint16(x86_xSetOp), uint16(x86_FCMOVB),
+ /*11748*/ uint16(x86_xArgST),
+ /*11749*/ uint16(x86_xArgSTi),
+ /*11750*/ uint16(x86_xMatch),
+ /*11751*/ uint16(x86_xSetOp), uint16(x86_FCMOVE),
+ /*11753*/ uint16(x86_xArgST),
+ /*11754*/ uint16(x86_xArgSTi),
+ /*11755*/ uint16(x86_xMatch),
+ /*11756*/ uint16(x86_xSetOp), uint16(x86_FCMOVBE),
+ /*11758*/ uint16(x86_xArgST),
+ /*11759*/ uint16(x86_xArgSTi),
+ /*11760*/ uint16(x86_xMatch),
+ /*11761*/ uint16(x86_xSetOp), uint16(x86_FCMOVU),
+ /*11763*/ uint16(x86_xArgST),
+ /*11764*/ uint16(x86_xArgSTi),
+ /*11765*/ uint16(x86_xMatch),
+ /*11766*/ uint16(x86_xSetOp), uint16(x86_FUCOMPP),
+ /*11768*/ uint16(x86_xMatch),
+ /*11769*/ uint16(x86_xCondByte), 50,
+ 0xc0, 11904,
+ 0xc1, 11904,
+ 0xc2, 11904,
+ 0xc3, 11904,
+ 0xc4, 11904,
+ 0xc5, 11904,
+ 0xc6, 11904,
+ 0xc7, 11904,
+ 0xc8, 11909,
+ 0xc9, 11909,
+ 0xca, 11909,
+ 0xcb, 11909,
+ 0xcc, 11909,
+ 0xcd, 11909,
+ 0xce, 11909,
+ 0xcf, 11909,
+ 0xd0, 11914,
+ 0xd1, 11914,
+ 0xd2, 11914,
+ 0xd3, 11914,
+ 0xd4, 11914,
+ 0xd5, 11914,
+ 0xd6, 11914,
+ 0xd7, 11914,
+ 0xd8, 11919,
+ 0xd9, 11919,
+ 0xda, 11919,
+ 0xdb, 11919,
+ 0xdc, 11919,
+ 0xdd, 11919,
+ 0xde, 11919,
+ 0xdf, 11919,
+ 0xE2, 11924,
+ 0xE3, 11927,
+ 0xe8, 11930,
+ 0xe9, 11930,
+ 0xea, 11930,
+ 0xeb, 11930,
+ 0xec, 11930,
+ 0xed, 11930,
+ 0xee, 11930,
+ 0xef, 11930,
+ 0xf0, 11935,
+ 0xf1, 11935,
+ 0xf2, 11935,
+ 0xf3, 11935,
+ 0xf4, 11935,
+ 0xf5, 11935,
+ 0xf6, 11935,
+ 0xf7, 11935,
+ /*11871*/ uint16(x86_xCondSlashR),
+ 11880, // 0
+ 11884, // 1
+ 11888, // 2
+ 11892, // 3
+ 0, // 4
+ 11896, // 5
+ 0, // 6
+ 11900, // 7
+ /*11880*/ uint16(x86_xSetOp), uint16(x86_FILD),
+ /*11882*/ uint16(x86_xArgM32int),
+ /*11883*/ uint16(x86_xMatch),
+ /*11884*/ uint16(x86_xSetOp), uint16(x86_FISTTP),
+ /*11886*/ uint16(x86_xArgM32int),
+ /*11887*/ uint16(x86_xMatch),
+ /*11888*/ uint16(x86_xSetOp), uint16(x86_FIST),
+ /*11890*/ uint16(x86_xArgM32int),
+ /*11891*/ uint16(x86_xMatch),
+ /*11892*/ uint16(x86_xSetOp), uint16(x86_FISTP),
+ /*11894*/ uint16(x86_xArgM32int),
+ /*11895*/ uint16(x86_xMatch),
+ /*11896*/ uint16(x86_xSetOp), uint16(x86_FLD),
+ /*11898*/ uint16(x86_xArgM80fp),
+ /*11899*/ uint16(x86_xMatch),
+ /*11900*/ uint16(x86_xSetOp), uint16(x86_FSTP),
+ /*11902*/ uint16(x86_xArgM80fp),
+ /*11903*/ uint16(x86_xMatch),
+ /*11904*/ uint16(x86_xSetOp), uint16(x86_FCMOVNB),
+ /*11906*/ uint16(x86_xArgST),
+ /*11907*/ uint16(x86_xArgSTi),
+ /*11908*/ uint16(x86_xMatch),
+ /*11909*/ uint16(x86_xSetOp), uint16(x86_FCMOVNE),
+ /*11911*/ uint16(x86_xArgST),
+ /*11912*/ uint16(x86_xArgSTi),
+ /*11913*/ uint16(x86_xMatch),
+ /*11914*/ uint16(x86_xSetOp), uint16(x86_FCMOVNBE),
+ /*11916*/ uint16(x86_xArgST),
+ /*11917*/ uint16(x86_xArgSTi),
+ /*11918*/ uint16(x86_xMatch),
+ /*11919*/ uint16(x86_xSetOp), uint16(x86_FCMOVNU),
+ /*11921*/ uint16(x86_xArgST),
+ /*11922*/ uint16(x86_xArgSTi),
+ /*11923*/ uint16(x86_xMatch),
+ /*11924*/ uint16(x86_xSetOp), uint16(x86_FNCLEX),
+ /*11926*/ uint16(x86_xMatch),
+ /*11927*/ uint16(x86_xSetOp), uint16(x86_FNINIT),
+ /*11929*/ uint16(x86_xMatch),
+ /*11930*/ uint16(x86_xSetOp), uint16(x86_FUCOMI),
+ /*11932*/ uint16(x86_xArgST),
+ /*11933*/ uint16(x86_xArgSTi),
+ /*11934*/ uint16(x86_xMatch),
+ /*11935*/ uint16(x86_xSetOp), uint16(x86_FCOMI),
+ /*11937*/ uint16(x86_xArgST),
+ /*11938*/ uint16(x86_xArgSTi),
+ /*11939*/ uint16(x86_xMatch),
+ /*11940*/ uint16(x86_xCondByte), 48,
+ 0xc0, 12079,
+ 0xc1, 12079,
+ 0xc2, 12079,
+ 0xc3, 12079,
+ 0xc4, 12079,
+ 0xc5, 12079,
+ 0xc6, 12079,
+ 0xc7, 12079,
+ 0xc8, 12084,
+ 0xc9, 12084,
+ 0xca, 12084,
+ 0xcb, 12084,
+ 0xcc, 12084,
+ 0xcd, 12084,
+ 0xce, 12084,
+ 0xcf, 12084,
+ 0xe0, 12089,
+ 0xe1, 12089,
+ 0xe2, 12089,
+ 0xe3, 12089,
+ 0xe4, 12089,
+ 0xe5, 12089,
+ 0xe6, 12089,
+ 0xe7, 12089,
+ 0xe8, 12094,
+ 0xe9, 12094,
+ 0xea, 12094,
+ 0xeb, 12094,
+ 0xec, 12094,
+ 0xed, 12094,
+ 0xee, 12094,
+ 0xef, 12094,
+ 0xf0, 12099,
+ 0xf1, 12099,
+ 0xf2, 12099,
+ 0xf3, 12099,
+ 0xf4, 12099,
+ 0xf5, 12099,
+ 0xf6, 12099,
+ 0xf7, 12099,
+ 0xf8, 12104,
+ 0xf9, 12104,
+ 0xfa, 12104,
+ 0xfb, 12104,
+ 0xfc, 12104,
+ 0xfd, 12104,
+ 0xfe, 12104,
+ 0xff, 12104,
+ /*12038*/ uint16(x86_xCondSlashR),
+ 12047, // 0
+ 12051, // 1
+ 12055, // 2
+ 12059, // 3
+ 12063, // 4
+ 12067, // 5
+ 12071, // 6
+ 12075, // 7
+ /*12047*/ uint16(x86_xSetOp), uint16(x86_FADD),
+ /*12049*/ uint16(x86_xArgM64fp),
+ /*12050*/ uint16(x86_xMatch),
+ /*12051*/ uint16(x86_xSetOp), uint16(x86_FMUL),
+ /*12053*/ uint16(x86_xArgM64fp),
+ /*12054*/ uint16(x86_xMatch),
+ /*12055*/ uint16(x86_xSetOp), uint16(x86_FCOM),
+ /*12057*/ uint16(x86_xArgM64fp),
+ /*12058*/ uint16(x86_xMatch),
+ /*12059*/ uint16(x86_xSetOp), uint16(x86_FCOMP),
+ /*12061*/ uint16(x86_xArgM64fp),
+ /*12062*/ uint16(x86_xMatch),
+ /*12063*/ uint16(x86_xSetOp), uint16(x86_FSUB),
+ /*12065*/ uint16(x86_xArgM64fp),
+ /*12066*/ uint16(x86_xMatch),
+ /*12067*/ uint16(x86_xSetOp), uint16(x86_FSUBR),
+ /*12069*/ uint16(x86_xArgM64fp),
+ /*12070*/ uint16(x86_xMatch),
+ /*12071*/ uint16(x86_xSetOp), uint16(x86_FDIV),
+ /*12073*/ uint16(x86_xArgM64fp),
+ /*12074*/ uint16(x86_xMatch),
+ /*12075*/ uint16(x86_xSetOp), uint16(x86_FDIVR),
+ /*12077*/ uint16(x86_xArgM64fp),
+ /*12078*/ uint16(x86_xMatch),
+ /*12079*/ uint16(x86_xSetOp), uint16(x86_FADD),
+ /*12081*/ uint16(x86_xArgSTi),
+ /*12082*/ uint16(x86_xArgST),
+ /*12083*/ uint16(x86_xMatch),
+ /*12084*/ uint16(x86_xSetOp), uint16(x86_FMUL),
+ /*12086*/ uint16(x86_xArgSTi),
+ /*12087*/ uint16(x86_xArgST),
+ /*12088*/ uint16(x86_xMatch),
+ /*12089*/ uint16(x86_xSetOp), uint16(x86_FSUBR),
+ /*12091*/ uint16(x86_xArgSTi),
+ /*12092*/ uint16(x86_xArgST),
+ /*12093*/ uint16(x86_xMatch),
+ /*12094*/ uint16(x86_xSetOp), uint16(x86_FSUB),
+ /*12096*/ uint16(x86_xArgSTi),
+ /*12097*/ uint16(x86_xArgST),
+ /*12098*/ uint16(x86_xMatch),
+ /*12099*/ uint16(x86_xSetOp), uint16(x86_FDIVR),
+ /*12101*/ uint16(x86_xArgSTi),
+ /*12102*/ uint16(x86_xArgST),
+ /*12103*/ uint16(x86_xMatch),
+ /*12104*/ uint16(x86_xSetOp), uint16(x86_FDIV),
+ /*12106*/ uint16(x86_xArgSTi),
+ /*12107*/ uint16(x86_xArgST),
+ /*12108*/ uint16(x86_xMatch),
+ /*12109*/ uint16(x86_xCondByte), 40,
+ 0xc0, 12228,
+ 0xc1, 12228,
+ 0xc2, 12228,
+ 0xc3, 12228,
+ 0xc4, 12228,
+ 0xc5, 12228,
+ 0xc6, 12228,
+ 0xc7, 12228,
+ 0xd0, 12232,
+ 0xd1, 12232,
+ 0xd2, 12232,
+ 0xd3, 12232,
+ 0xd4, 12232,
+ 0xd5, 12232,
+ 0xd6, 12232,
+ 0xd7, 12232,
+ 0xd8, 12236,
+ 0xd9, 12236,
+ 0xda, 12236,
+ 0xdb, 12236,
+ 0xdc, 12236,
+ 0xdd, 12236,
+ 0xde, 12236,
+ 0xdf, 12236,
+ 0xe0, 12240,
+ 0xe1, 12240,
+ 0xe2, 12240,
+ 0xe3, 12240,
+ 0xe4, 12240,
+ 0xe5, 12240,
+ 0xe6, 12240,
+ 0xe7, 12240,
+ 0xe8, 12244,
+ 0xe9, 12244,
+ 0xea, 12244,
+ 0xeb, 12244,
+ 0xec, 12244,
+ 0xed, 12244,
+ 0xee, 12244,
+ 0xef, 12244,
+ /*12191*/ uint16(x86_xCondSlashR),
+ 12200, // 0
+ 12204, // 1
+ 12208, // 2
+ 12212, // 3
+ 12216, // 4
+ 0, // 5
+ 12220, // 6
+ 12224, // 7
+ /*12200*/ uint16(x86_xSetOp), uint16(x86_FLD),
+ /*12202*/ uint16(x86_xArgM64fp),
+ /*12203*/ uint16(x86_xMatch),
+ /*12204*/ uint16(x86_xSetOp), uint16(x86_FISTTP),
+ /*12206*/ uint16(x86_xArgM64int),
+ /*12207*/ uint16(x86_xMatch),
+ /*12208*/ uint16(x86_xSetOp), uint16(x86_FST),
+ /*12210*/ uint16(x86_xArgM64fp),
+ /*12211*/ uint16(x86_xMatch),
+ /*12212*/ uint16(x86_xSetOp), uint16(x86_FSTP),
+ /*12214*/ uint16(x86_xArgM64fp),
+ /*12215*/ uint16(x86_xMatch),
+ /*12216*/ uint16(x86_xSetOp), uint16(x86_FRSTOR),
+ /*12218*/ uint16(x86_xArgM94108byte),
+ /*12219*/ uint16(x86_xMatch),
+ /*12220*/ uint16(x86_xSetOp), uint16(x86_FNSAVE),
+ /*12222*/ uint16(x86_xArgM94108byte),
+ /*12223*/ uint16(x86_xMatch),
+ /*12224*/ uint16(x86_xSetOp), uint16(x86_FNSTSW),
+ /*12226*/ uint16(x86_xArgM2byte),
+ /*12227*/ uint16(x86_xMatch),
+ /*12228*/ uint16(x86_xSetOp), uint16(x86_FFREE),
+ /*12230*/ uint16(x86_xArgSTi),
+ /*12231*/ uint16(x86_xMatch),
+ /*12232*/ uint16(x86_xSetOp), uint16(x86_FST),
+ /*12234*/ uint16(x86_xArgSTi),
+ /*12235*/ uint16(x86_xMatch),
+ /*12236*/ uint16(x86_xSetOp), uint16(x86_FSTP),
+ /*12238*/ uint16(x86_xArgSTi),
+ /*12239*/ uint16(x86_xMatch),
+ /*12240*/ uint16(x86_xSetOp), uint16(x86_FUCOM),
+ /*12242*/ uint16(x86_xArgSTi),
+ /*12243*/ uint16(x86_xMatch),
+ /*12244*/ uint16(x86_xSetOp), uint16(x86_FUCOMP),
+ /*12246*/ uint16(x86_xArgSTi),
+ /*12247*/ uint16(x86_xMatch),
+ /*12248*/ uint16(x86_xCondByte), 49,
+ 0xc0, 12389,
+ 0xc1, 12389,
+ 0xc2, 12389,
+ 0xc3, 12389,
+ 0xc4, 12389,
+ 0xc5, 12389,
+ 0xc6, 12389,
+ 0xc7, 12389,
+ 0xc8, 12394,
+ 0xc9, 12394,
+ 0xca, 12394,
+ 0xcb, 12394,
+ 0xcc, 12394,
+ 0xcd, 12394,
+ 0xce, 12394,
+ 0xcf, 12394,
+ 0xD9, 12399,
+ 0xe0, 12402,
+ 0xe1, 12402,
+ 0xe2, 12402,
+ 0xe3, 12402,
+ 0xe4, 12402,
+ 0xe5, 12402,
+ 0xe6, 12402,
+ 0xe7, 12402,
+ 0xe8, 12407,
+ 0xe9, 12407,
+ 0xea, 12407,
+ 0xeb, 12407,
+ 0xec, 12407,
+ 0xed, 12407,
+ 0xee, 12407,
+ 0xef, 12407,
+ 0xf0, 12412,
+ 0xf1, 12412,
+ 0xf2, 12412,
+ 0xf3, 12412,
+ 0xf4, 12412,
+ 0xf5, 12412,
+ 0xf6, 12412,
+ 0xf7, 12412,
+ 0xf8, 12417,
+ 0xf9, 12417,
+ 0xfa, 12417,
+ 0xfb, 12417,
+ 0xfc, 12417,
+ 0xfd, 12417,
+ 0xfe, 12417,
+ 0xff, 12417,
+ /*12348*/ uint16(x86_xCondSlashR),
+ 12357, // 0
+ 12361, // 1
+ 12365, // 2
+ 12369, // 3
+ 12373, // 4
+ 12377, // 5
+ 12381, // 6
+ 12385, // 7
+ /*12357*/ uint16(x86_xSetOp), uint16(x86_FIADD),
+ /*12359*/ uint16(x86_xArgM16int),
+ /*12360*/ uint16(x86_xMatch),
+ /*12361*/ uint16(x86_xSetOp), uint16(x86_FIMUL),
+ /*12363*/ uint16(x86_xArgM16int),
+ /*12364*/ uint16(x86_xMatch),
+ /*12365*/ uint16(x86_xSetOp), uint16(x86_FICOM),
+ /*12367*/ uint16(x86_xArgM16int),
+ /*12368*/ uint16(x86_xMatch),
+ /*12369*/ uint16(x86_xSetOp), uint16(x86_FICOMP),
+ /*12371*/ uint16(x86_xArgM16int),
+ /*12372*/ uint16(x86_xMatch),
+ /*12373*/ uint16(x86_xSetOp), uint16(x86_FISUB),
+ /*12375*/ uint16(x86_xArgM16int),
+ /*12376*/ uint16(x86_xMatch),
+ /*12377*/ uint16(x86_xSetOp), uint16(x86_FISUBR),
+ /*12379*/ uint16(x86_xArgM16int),
+ /*12380*/ uint16(x86_xMatch),
+ /*12381*/ uint16(x86_xSetOp), uint16(x86_FIDIV),
+ /*12383*/ uint16(x86_xArgM16int),
+ /*12384*/ uint16(x86_xMatch),
+ /*12385*/ uint16(x86_xSetOp), uint16(x86_FIDIVR),
+ /*12387*/ uint16(x86_xArgM16int),
+ /*12388*/ uint16(x86_xMatch),
+ /*12389*/ uint16(x86_xSetOp), uint16(x86_FADDP),
+ /*12391*/ uint16(x86_xArgSTi),
+ /*12392*/ uint16(x86_xArgST),
+ /*12393*/ uint16(x86_xMatch),
+ /*12394*/ uint16(x86_xSetOp), uint16(x86_FMULP),
+ /*12396*/ uint16(x86_xArgSTi),
+ /*12397*/ uint16(x86_xArgST),
+ /*12398*/ uint16(x86_xMatch),
+ /*12399*/ uint16(x86_xSetOp), uint16(x86_FCOMPP),
+ /*12401*/ uint16(x86_xMatch),
+ /*12402*/ uint16(x86_xSetOp), uint16(x86_FSUBRP),
+ /*12404*/ uint16(x86_xArgSTi),
+ /*12405*/ uint16(x86_xArgST),
+ /*12406*/ uint16(x86_xMatch),
+ /*12407*/ uint16(x86_xSetOp), uint16(x86_FSUBP),
+ /*12409*/ uint16(x86_xArgSTi),
+ /*12410*/ uint16(x86_xArgST),
+ /*12411*/ uint16(x86_xMatch),
+ /*12412*/ uint16(x86_xSetOp), uint16(x86_FDIVRP),
+ /*12414*/ uint16(x86_xArgSTi),
+ /*12415*/ uint16(x86_xArgST),
+ /*12416*/ uint16(x86_xMatch),
+ /*12417*/ uint16(x86_xSetOp), uint16(x86_FDIVP),
+ /*12419*/ uint16(x86_xArgSTi),
+ /*12420*/ uint16(x86_xArgST),
+ /*12421*/ uint16(x86_xMatch),
+ /*12422*/ uint16(x86_xCondByte), 25,
+ 0xc0, 12515,
+ 0xc1, 12515,
+ 0xc2, 12515,
+ 0xc3, 12515,
+ 0xc4, 12515,
+ 0xc5, 12515,
+ 0xc6, 12515,
+ 0xc7, 12515,
+ 0xE0, 12519,
+ 0xe8, 12523,
+ 0xe9, 12523,
+ 0xea, 12523,
+ 0xeb, 12523,
+ 0xec, 12523,
+ 0xed, 12523,
+ 0xee, 12523,
+ 0xef, 12523,
+ 0xf0, 12528,
+ 0xf1, 12528,
+ 0xf2, 12528,
+ 0xf3, 12528,
+ 0xf4, 12528,
+ 0xf5, 12528,
+ 0xf6, 12528,
+ 0xf7, 12528,
+ /*12474*/ uint16(x86_xCondSlashR),
+ 12483, // 0
+ 12487, // 1
+ 12491, // 2
+ 12495, // 3
+ 12499, // 4
+ 12503, // 5
+ 12507, // 6
+ 12511, // 7
+ /*12483*/ uint16(x86_xSetOp), uint16(x86_FILD),
+ /*12485*/ uint16(x86_xArgM16int),
+ /*12486*/ uint16(x86_xMatch),
+ /*12487*/ uint16(x86_xSetOp), uint16(x86_FISTTP),
+ /*12489*/ uint16(x86_xArgM16int),
+ /*12490*/ uint16(x86_xMatch),
+ /*12491*/ uint16(x86_xSetOp), uint16(x86_FIST),
+ /*12493*/ uint16(x86_xArgM16int),
+ /*12494*/ uint16(x86_xMatch),
+ /*12495*/ uint16(x86_xSetOp), uint16(x86_FISTP),
+ /*12497*/ uint16(x86_xArgM16int),
+ /*12498*/ uint16(x86_xMatch),
+ /*12499*/ uint16(x86_xSetOp), uint16(x86_FBLD),
+ /*12501*/ uint16(x86_xArgM80dec),
+ /*12502*/ uint16(x86_xMatch),
+ /*12503*/ uint16(x86_xSetOp), uint16(x86_FILD),
+ /*12505*/ uint16(x86_xArgM64int),
+ /*12506*/ uint16(x86_xMatch),
+ /*12507*/ uint16(x86_xSetOp), uint16(x86_FBSTP),
+ /*12509*/ uint16(x86_xArgM80bcd),
+ /*12510*/ uint16(x86_xMatch),
+ /*12511*/ uint16(x86_xSetOp), uint16(x86_FISTP),
+ /*12513*/ uint16(x86_xArgM64int),
+ /*12514*/ uint16(x86_xMatch),
+ /*12515*/ uint16(x86_xSetOp), uint16(x86_FFREEP),
+ /*12517*/ uint16(x86_xArgSTi),
+ /*12518*/ uint16(x86_xMatch),
+ /*12519*/ uint16(x86_xSetOp), uint16(x86_FNSTSW),
+ /*12521*/ uint16(x86_xArgAX),
+ /*12522*/ uint16(x86_xMatch),
+ /*12523*/ uint16(x86_xSetOp), uint16(x86_FUCOMIP),
+ /*12525*/ uint16(x86_xArgST),
+ /*12526*/ uint16(x86_xArgSTi),
+ /*12527*/ uint16(x86_xMatch),
+ /*12528*/ uint16(x86_xSetOp), uint16(x86_FCOMIP),
+ /*12530*/ uint16(x86_xArgST),
+ /*12531*/ uint16(x86_xArgSTi),
+ /*12532*/ uint16(x86_xMatch),
+ /*12533*/ uint16(x86_xSetOp), uint16(x86_LOOPNE),
+ /*12535*/ uint16(x86_xReadCb),
+ /*12536*/ uint16(x86_xArgRel8),
+ /*12537*/ uint16(x86_xMatch),
+ /*12538*/ uint16(x86_xSetOp), uint16(x86_LOOPE),
+ /*12540*/ uint16(x86_xReadCb),
+ /*12541*/ uint16(x86_xArgRel8),
+ /*12542*/ uint16(x86_xMatch),
+ /*12543*/ uint16(x86_xSetOp), uint16(x86_LOOP),
+ /*12545*/ uint16(x86_xReadCb),
+ /*12546*/ uint16(x86_xArgRel8),
+ /*12547*/ uint16(x86_xMatch),
+ /*12548*/ uint16(x86_xCondIs64), 12551, 12565,
+ /*12551*/ uint16(x86_xCondAddrSize), 12555, 12560, 0,
+ /*12555*/ uint16(x86_xSetOp), uint16(x86_JCXZ),
+ /*12557*/ uint16(x86_xReadCb),
+ /*12558*/ uint16(x86_xArgRel8),
+ /*12559*/ uint16(x86_xMatch),
+ /*12560*/ uint16(x86_xSetOp), uint16(x86_JECXZ),
+ /*12562*/ uint16(x86_xReadCb),
+ /*12563*/ uint16(x86_xArgRel8),
+ /*12564*/ uint16(x86_xMatch),
+ /*12565*/ uint16(x86_xCondAddrSize), 0, 12560, 12569,
+ /*12569*/ uint16(x86_xSetOp), uint16(x86_JRCXZ),
+ /*12571*/ uint16(x86_xReadCb),
+ /*12572*/ uint16(x86_xArgRel8),
+ /*12573*/ uint16(x86_xMatch),
+ /*12574*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12576*/ uint16(x86_xReadIb),
+ /*12577*/ uint16(x86_xArgAL),
+ /*12578*/ uint16(x86_xArgImm8u),
+ /*12579*/ uint16(x86_xMatch),
+ /*12580*/ uint16(x86_xCondDataSize), 12584, 12590, 12596,
+ /*12584*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12586*/ uint16(x86_xReadIb),
+ /*12587*/ uint16(x86_xArgAX),
+ /*12588*/ uint16(x86_xArgImm8u),
+ /*12589*/ uint16(x86_xMatch),
+ /*12590*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12592*/ uint16(x86_xReadIb),
+ /*12593*/ uint16(x86_xArgEAX),
+ /*12594*/ uint16(x86_xArgImm8u),
+ /*12595*/ uint16(x86_xMatch),
+ /*12596*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12598*/ uint16(x86_xReadIb),
+ /*12599*/ uint16(x86_xArgEAX),
+ /*12600*/ uint16(x86_xArgImm8u),
+ /*12601*/ uint16(x86_xMatch),
+ /*12602*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12604*/ uint16(x86_xReadIb),
+ /*12605*/ uint16(x86_xArgImm8u),
+ /*12606*/ uint16(x86_xArgAL),
+ /*12607*/ uint16(x86_xMatch),
+ /*12608*/ uint16(x86_xCondDataSize), 12612, 12618, 12624,
+ /*12612*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12614*/ uint16(x86_xReadIb),
+ /*12615*/ uint16(x86_xArgImm8u),
+ /*12616*/ uint16(x86_xArgAX),
+ /*12617*/ uint16(x86_xMatch),
+ /*12618*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12620*/ uint16(x86_xReadIb),
+ /*12621*/ uint16(x86_xArgImm8u),
+ /*12622*/ uint16(x86_xArgEAX),
+ /*12623*/ uint16(x86_xMatch),
+ /*12624*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12626*/ uint16(x86_xReadIb),
+ /*12627*/ uint16(x86_xArgImm8u),
+ /*12628*/ uint16(x86_xArgEAX),
+ /*12629*/ uint16(x86_xMatch),
+ /*12630*/ uint16(x86_xCondIs64), 12633, 12647,
+ /*12633*/ uint16(x86_xCondDataSize), 12637, 12642, 0,
+ /*12637*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*12639*/ uint16(x86_xReadCw),
+ /*12640*/ uint16(x86_xArgRel16),
+ /*12641*/ uint16(x86_xMatch),
+ /*12642*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*12644*/ uint16(x86_xReadCd),
+ /*12645*/ uint16(x86_xArgRel32),
+ /*12646*/ uint16(x86_xMatch),
+ /*12647*/ uint16(x86_xCondDataSize), 12651, 12642, 12656,
+ /*12651*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*12653*/ uint16(x86_xReadCd),
+ /*12654*/ uint16(x86_xArgRel32),
+ /*12655*/ uint16(x86_xMatch),
+ /*12656*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*12658*/ uint16(x86_xReadCd),
+ /*12659*/ uint16(x86_xArgRel32),
+ /*12660*/ uint16(x86_xMatch),
+ /*12661*/ uint16(x86_xCondIs64), 12664, 12678,
+ /*12664*/ uint16(x86_xCondDataSize), 12668, 12673, 0,
+ /*12668*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*12670*/ uint16(x86_xReadCw),
+ /*12671*/ uint16(x86_xArgRel16),
+ /*12672*/ uint16(x86_xMatch),
+ /*12673*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*12675*/ uint16(x86_xReadCd),
+ /*12676*/ uint16(x86_xArgRel32),
+ /*12677*/ uint16(x86_xMatch),
+ /*12678*/ uint16(x86_xCondDataSize), 12682, 12673, 12687,
+ /*12682*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*12684*/ uint16(x86_xReadCd),
+ /*12685*/ uint16(x86_xArgRel32),
+ /*12686*/ uint16(x86_xMatch),
+ /*12687*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*12689*/ uint16(x86_xReadCd),
+ /*12690*/ uint16(x86_xArgRel32),
+ /*12691*/ uint16(x86_xMatch),
+ /*12692*/ uint16(x86_xCondIs64), 12695, 0,
+ /*12695*/ uint16(x86_xCondDataSize), 12699, 12704, 0,
+ /*12699*/ uint16(x86_xSetOp), uint16(x86_LJMP),
+ /*12701*/ uint16(x86_xReadCd),
+ /*12702*/ uint16(x86_xArgPtr16colon16),
+ /*12703*/ uint16(x86_xMatch),
+ /*12704*/ uint16(x86_xSetOp), uint16(x86_LJMP),
+ /*12706*/ uint16(x86_xReadCp),
+ /*12707*/ uint16(x86_xArgPtr16colon32),
+ /*12708*/ uint16(x86_xMatch),
+ /*12709*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*12711*/ uint16(x86_xReadCb),
+ /*12712*/ uint16(x86_xArgRel8),
+ /*12713*/ uint16(x86_xMatch),
+ /*12714*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12716*/ uint16(x86_xArgAL),
+ /*12717*/ uint16(x86_xArgDX),
+ /*12718*/ uint16(x86_xMatch),
+ /*12719*/ uint16(x86_xCondDataSize), 12723, 12728, 12733,
+ /*12723*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12725*/ uint16(x86_xArgAX),
+ /*12726*/ uint16(x86_xArgDX),
+ /*12727*/ uint16(x86_xMatch),
+ /*12728*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12730*/ uint16(x86_xArgEAX),
+ /*12731*/ uint16(x86_xArgDX),
+ /*12732*/ uint16(x86_xMatch),
+ /*12733*/ uint16(x86_xSetOp), uint16(x86_IN),
+ /*12735*/ uint16(x86_xArgEAX),
+ /*12736*/ uint16(x86_xArgDX),
+ /*12737*/ uint16(x86_xMatch),
+ /*12738*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12740*/ uint16(x86_xArgDX),
+ /*12741*/ uint16(x86_xArgAL),
+ /*12742*/ uint16(x86_xMatch),
+ /*12743*/ uint16(x86_xCondDataSize), 12747, 12752, 12757,
+ /*12747*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12749*/ uint16(x86_xArgDX),
+ /*12750*/ uint16(x86_xArgAX),
+ /*12751*/ uint16(x86_xMatch),
+ /*12752*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12754*/ uint16(x86_xArgDX),
+ /*12755*/ uint16(x86_xArgEAX),
+ /*12756*/ uint16(x86_xMatch),
+ /*12757*/ uint16(x86_xSetOp), uint16(x86_OUT),
+ /*12759*/ uint16(x86_xArgDX),
+ /*12760*/ uint16(x86_xArgEAX),
+ /*12761*/ uint16(x86_xMatch),
+ /*12762*/ uint16(x86_xSetOp), uint16(x86_ICEBP),
+ /*12764*/ uint16(x86_xMatch),
+ /*12765*/ uint16(x86_xSetOp), uint16(x86_HLT),
+ /*12767*/ uint16(x86_xMatch),
+ /*12768*/ uint16(x86_xSetOp), uint16(x86_CMC),
+ /*12770*/ uint16(x86_xMatch),
+ /*12771*/ uint16(x86_xCondSlashR),
+ 12780, // 0
+ 0, // 1
+ 12786, // 2
+ 12790, // 3
+ 12794, // 4
+ 12798, // 5
+ 12802, // 6
+ 12806, // 7
+ /*12780*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*12782*/ uint16(x86_xReadIb),
+ /*12783*/ uint16(x86_xArgRM8),
+ /*12784*/ uint16(x86_xArgImm8u),
+ /*12785*/ uint16(x86_xMatch),
+ /*12786*/ uint16(x86_xSetOp), uint16(x86_NOT),
+ /*12788*/ uint16(x86_xArgRM8),
+ /*12789*/ uint16(x86_xMatch),
+ /*12790*/ uint16(x86_xSetOp), uint16(x86_NEG),
+ /*12792*/ uint16(x86_xArgRM8),
+ /*12793*/ uint16(x86_xMatch),
+ /*12794*/ uint16(x86_xSetOp), uint16(x86_MUL),
+ /*12796*/ uint16(x86_xArgRM8),
+ /*12797*/ uint16(x86_xMatch),
+ /*12798*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*12800*/ uint16(x86_xArgRM8),
+ /*12801*/ uint16(x86_xMatch),
+ /*12802*/ uint16(x86_xSetOp), uint16(x86_DIV),
+ /*12804*/ uint16(x86_xArgRM8),
+ /*12805*/ uint16(x86_xMatch),
+ /*12806*/ uint16(x86_xSetOp), uint16(x86_IDIV),
+ /*12808*/ uint16(x86_xArgRM8),
+ /*12809*/ uint16(x86_xMatch),
+ /*12810*/ uint16(x86_xCondSlashR),
+ 12819, // 0
+ 0, // 1
+ 12848, // 2
+ 12871, // 3
+ 12894, // 4
+ 12917, // 5
+ 12940, // 6
+ 12963, // 7
+ /*12819*/ uint16(x86_xCondIs64), 12822, 12838,
+ /*12822*/ uint16(x86_xCondDataSize), 12826, 12832, 0,
+ /*12826*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*12828*/ uint16(x86_xReadIw),
+ /*12829*/ uint16(x86_xArgRM16),
+ /*12830*/ uint16(x86_xArgImm16),
+ /*12831*/ uint16(x86_xMatch),
+ /*12832*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*12834*/ uint16(x86_xReadId),
+ /*12835*/ uint16(x86_xArgRM32),
+ /*12836*/ uint16(x86_xArgImm32),
+ /*12837*/ uint16(x86_xMatch),
+ /*12838*/ uint16(x86_xCondDataSize), 12826, 12832, 12842,
+ /*12842*/ uint16(x86_xSetOp), uint16(x86_TEST),
+ /*12844*/ uint16(x86_xReadId),
+ /*12845*/ uint16(x86_xArgRM64),
+ /*12846*/ uint16(x86_xArgImm32),
+ /*12847*/ uint16(x86_xMatch),
+ /*12848*/ uint16(x86_xCondIs64), 12851, 12863,
+ /*12851*/ uint16(x86_xCondDataSize), 12855, 12859, 0,
+ /*12855*/ uint16(x86_xSetOp), uint16(x86_NOT),
+ /*12857*/ uint16(x86_xArgRM16),
+ /*12858*/ uint16(x86_xMatch),
+ /*12859*/ uint16(x86_xSetOp), uint16(x86_NOT),
+ /*12861*/ uint16(x86_xArgRM32),
+ /*12862*/ uint16(x86_xMatch),
+ /*12863*/ uint16(x86_xCondDataSize), 12855, 12859, 12867,
+ /*12867*/ uint16(x86_xSetOp), uint16(x86_NOT),
+ /*12869*/ uint16(x86_xArgRM64),
+ /*12870*/ uint16(x86_xMatch),
+ /*12871*/ uint16(x86_xCondIs64), 12874, 12886,
+ /*12874*/ uint16(x86_xCondDataSize), 12878, 12882, 0,
+ /*12878*/ uint16(x86_xSetOp), uint16(x86_NEG),
+ /*12880*/ uint16(x86_xArgRM16),
+ /*12881*/ uint16(x86_xMatch),
+ /*12882*/ uint16(x86_xSetOp), uint16(x86_NEG),
+ /*12884*/ uint16(x86_xArgRM32),
+ /*12885*/ uint16(x86_xMatch),
+ /*12886*/ uint16(x86_xCondDataSize), 12878, 12882, 12890,
+ /*12890*/ uint16(x86_xSetOp), uint16(x86_NEG),
+ /*12892*/ uint16(x86_xArgRM64),
+ /*12893*/ uint16(x86_xMatch),
+ /*12894*/ uint16(x86_xCondIs64), 12897, 12909,
+ /*12897*/ uint16(x86_xCondDataSize), 12901, 12905, 0,
+ /*12901*/ uint16(x86_xSetOp), uint16(x86_MUL),
+ /*12903*/ uint16(x86_xArgRM16),
+ /*12904*/ uint16(x86_xMatch),
+ /*12905*/ uint16(x86_xSetOp), uint16(x86_MUL),
+ /*12907*/ uint16(x86_xArgRM32),
+ /*12908*/ uint16(x86_xMatch),
+ /*12909*/ uint16(x86_xCondDataSize), 12901, 12905, 12913,
+ /*12913*/ uint16(x86_xSetOp), uint16(x86_MUL),
+ /*12915*/ uint16(x86_xArgRM64),
+ /*12916*/ uint16(x86_xMatch),
+ /*12917*/ uint16(x86_xCondIs64), 12920, 12932,
+ /*12920*/ uint16(x86_xCondDataSize), 12924, 12928, 0,
+ /*12924*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*12926*/ uint16(x86_xArgRM16),
+ /*12927*/ uint16(x86_xMatch),
+ /*12928*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*12930*/ uint16(x86_xArgRM32),
+ /*12931*/ uint16(x86_xMatch),
+ /*12932*/ uint16(x86_xCondDataSize), 12924, 12928, 12936,
+ /*12936*/ uint16(x86_xSetOp), uint16(x86_IMUL),
+ /*12938*/ uint16(x86_xArgRM64),
+ /*12939*/ uint16(x86_xMatch),
+ /*12940*/ uint16(x86_xCondIs64), 12943, 12955,
+ /*12943*/ uint16(x86_xCondDataSize), 12947, 12951, 0,
+ /*12947*/ uint16(x86_xSetOp), uint16(x86_DIV),
+ /*12949*/ uint16(x86_xArgRM16),
+ /*12950*/ uint16(x86_xMatch),
+ /*12951*/ uint16(x86_xSetOp), uint16(x86_DIV),
+ /*12953*/ uint16(x86_xArgRM32),
+ /*12954*/ uint16(x86_xMatch),
+ /*12955*/ uint16(x86_xCondDataSize), 12947, 12951, 12959,
+ /*12959*/ uint16(x86_xSetOp), uint16(x86_DIV),
+ /*12961*/ uint16(x86_xArgRM64),
+ /*12962*/ uint16(x86_xMatch),
+ /*12963*/ uint16(x86_xCondIs64), 12966, 12978,
+ /*12966*/ uint16(x86_xCondDataSize), 12970, 12974, 0,
+ /*12970*/ uint16(x86_xSetOp), uint16(x86_IDIV),
+ /*12972*/ uint16(x86_xArgRM16),
+ /*12973*/ uint16(x86_xMatch),
+ /*12974*/ uint16(x86_xSetOp), uint16(x86_IDIV),
+ /*12976*/ uint16(x86_xArgRM32),
+ /*12977*/ uint16(x86_xMatch),
+ /*12978*/ uint16(x86_xCondDataSize), 12970, 12974, 12982,
+ /*12982*/ uint16(x86_xSetOp), uint16(x86_IDIV),
+ /*12984*/ uint16(x86_xArgRM64),
+ /*12985*/ uint16(x86_xMatch),
+ /*12986*/ uint16(x86_xSetOp), uint16(x86_CLC),
+ /*12988*/ uint16(x86_xMatch),
+ /*12989*/ uint16(x86_xSetOp), uint16(x86_STC),
+ /*12991*/ uint16(x86_xMatch),
+ /*12992*/ uint16(x86_xSetOp), uint16(x86_CLI),
+ /*12994*/ uint16(x86_xMatch),
+ /*12995*/ uint16(x86_xSetOp), uint16(x86_STI),
+ /*12997*/ uint16(x86_xMatch),
+ /*12998*/ uint16(x86_xSetOp), uint16(x86_CLD),
+ /*13000*/ uint16(x86_xMatch),
+ /*13001*/ uint16(x86_xSetOp), uint16(x86_STD),
+ /*13003*/ uint16(x86_xMatch),
+ /*13004*/ uint16(x86_xCondSlashR),
+ 13013, // 0
+ 13017, // 1
+ 0, // 2
+ 0, // 3
+ 0, // 4
+ 0, // 5
+ 0, // 6
+ 0, // 7
+ /*13013*/ uint16(x86_xSetOp), uint16(x86_INC),
+ /*13015*/ uint16(x86_xArgRM8),
+ /*13016*/ uint16(x86_xMatch),
+ /*13017*/ uint16(x86_xSetOp), uint16(x86_DEC),
+ /*13019*/ uint16(x86_xArgRM8),
+ /*13020*/ uint16(x86_xMatch),
+ /*13021*/ uint16(x86_xCondSlashR),
+ 13030, // 0
+ 13053, // 1
+ 13076, // 2
+ 13095, // 3
+ 13118, // 4
+ 13137, // 5
+ 13160, // 6
+ 0, // 7
+ /*13030*/ uint16(x86_xCondIs64), 13033, 13045,
+ /*13033*/ uint16(x86_xCondDataSize), 13037, 13041, 0,
+ /*13037*/ uint16(x86_xSetOp), uint16(x86_INC),
+ /*13039*/ uint16(x86_xArgRM16),
+ /*13040*/ uint16(x86_xMatch),
+ /*13041*/ uint16(x86_xSetOp), uint16(x86_INC),
+ /*13043*/ uint16(x86_xArgRM32),
+ /*13044*/ uint16(x86_xMatch),
+ /*13045*/ uint16(x86_xCondDataSize), 13037, 13041, 13049,
+ /*13049*/ uint16(x86_xSetOp), uint16(x86_INC),
+ /*13051*/ uint16(x86_xArgRM64),
+ /*13052*/ uint16(x86_xMatch),
+ /*13053*/ uint16(x86_xCondIs64), 13056, 13068,
+ /*13056*/ uint16(x86_xCondDataSize), 13060, 13064, 0,
+ /*13060*/ uint16(x86_xSetOp), uint16(x86_DEC),
+ /*13062*/ uint16(x86_xArgRM16),
+ /*13063*/ uint16(x86_xMatch),
+ /*13064*/ uint16(x86_xSetOp), uint16(x86_DEC),
+ /*13066*/ uint16(x86_xArgRM32),
+ /*13067*/ uint16(x86_xMatch),
+ /*13068*/ uint16(x86_xCondDataSize), 13060, 13064, 13072,
+ /*13072*/ uint16(x86_xSetOp), uint16(x86_DEC),
+ /*13074*/ uint16(x86_xArgRM64),
+ /*13075*/ uint16(x86_xMatch),
+ /*13076*/ uint16(x86_xCondIs64), 13079, 13091,
+ /*13079*/ uint16(x86_xCondDataSize), 13083, 13087, 0,
+ /*13083*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*13085*/ uint16(x86_xArgRM16),
+ /*13086*/ uint16(x86_xMatch),
+ /*13087*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*13089*/ uint16(x86_xArgRM32),
+ /*13090*/ uint16(x86_xMatch),
+ /*13091*/ uint16(x86_xSetOp), uint16(x86_CALL),
+ /*13093*/ uint16(x86_xArgRM64),
+ /*13094*/ uint16(x86_xMatch),
+ /*13095*/ uint16(x86_xCondIs64), 13098, 13110,
+ /*13098*/ uint16(x86_xCondDataSize), 13102, 13106, 0,
+ /*13102*/ uint16(x86_xSetOp), uint16(x86_LCALL),
+ /*13104*/ uint16(x86_xArgM16colon16),
+ /*13105*/ uint16(x86_xMatch),
+ /*13106*/ uint16(x86_xSetOp), uint16(x86_LCALL),
+ /*13108*/ uint16(x86_xArgM16colon32),
+ /*13109*/ uint16(x86_xMatch),
+ /*13110*/ uint16(x86_xCondDataSize), 13102, 13106, 13114,
+ /*13114*/ uint16(x86_xSetOp), uint16(x86_LCALL),
+ /*13116*/ uint16(x86_xArgM16colon64),
+ /*13117*/ uint16(x86_xMatch),
+ /*13118*/ uint16(x86_xCondIs64), 13121, 13133,
+ /*13121*/ uint16(x86_xCondDataSize), 13125, 13129, 0,
+ /*13125*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*13127*/ uint16(x86_xArgRM16),
+ /*13128*/ uint16(x86_xMatch),
+ /*13129*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*13131*/ uint16(x86_xArgRM32),
+ /*13132*/ uint16(x86_xMatch),
+ /*13133*/ uint16(x86_xSetOp), uint16(x86_JMP),
+ /*13135*/ uint16(x86_xArgRM64),
+ /*13136*/ uint16(x86_xMatch),
+ /*13137*/ uint16(x86_xCondIs64), 13140, 13152,
+ /*13140*/ uint16(x86_xCondDataSize), 13144, 13148, 0,
+ /*13144*/ uint16(x86_xSetOp), uint16(x86_LJMP),
+ /*13146*/ uint16(x86_xArgM16colon16),
+ /*13147*/ uint16(x86_xMatch),
+ /*13148*/ uint16(x86_xSetOp), uint16(x86_LJMP),
+ /*13150*/ uint16(x86_xArgM16colon32),
+ /*13151*/ uint16(x86_xMatch),
+ /*13152*/ uint16(x86_xCondDataSize), 13144, 13148, 13156,
+ /*13156*/ uint16(x86_xSetOp), uint16(x86_LJMP),
+ /*13158*/ uint16(x86_xArgM16colon64),
+ /*13159*/ uint16(x86_xMatch),
+ /*13160*/ uint16(x86_xCondIs64), 13163, 13175,
+ /*13163*/ uint16(x86_xCondDataSize), 13167, 13171, 0,
+ /*13167*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*13169*/ uint16(x86_xArgRM16),
+ /*13170*/ uint16(x86_xMatch),
+ /*13171*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*13173*/ uint16(x86_xArgRM32),
+ /*13174*/ uint16(x86_xMatch),
+ /*13175*/ uint16(x86_xCondDataSize), 13167, 13179, 13183,
+ /*13179*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*13181*/ uint16(x86_xArgRM64),
+ /*13182*/ uint16(x86_xMatch),
+ /*13183*/ uint16(x86_xSetOp), uint16(x86_PUSH),
+ /*13185*/ uint16(x86_xArgRM64),
+ /*13186*/ uint16(x86_xMatch),
+}
+
+const (
+ _ x86_Op = iota
+
+ x86_AAA
+ x86_AAD
+ x86_AAM
+ x86_AAS
+ x86_ADC
+ x86_ADD
+ x86_ADDPD
+ x86_ADDPS
+ x86_ADDSD
+ x86_ADDSS
+ x86_ADDSUBPD
+ x86_ADDSUBPS
+ x86_AESDEC
+ x86_AESDECLAST
+ x86_AESENC
+ x86_AESENCLAST
+ x86_AESIMC
+ x86_AESKEYGENASSIST
+ x86_AND
+ x86_ANDNPD
+ x86_ANDNPS
+ x86_ANDPD
+ x86_ANDPS
+ x86_ARPL
+ x86_BLENDPD
+ x86_BLENDPS
+ x86_BLENDVPD
+ x86_BLENDVPS
+ x86_BOUND
+ x86_BSF
+ x86_BSR
+ x86_BSWAP
+ x86_BT
+ x86_BTC
+ x86_BTR
+ x86_BTS
+ x86_CALL
+ x86_CBW
+ x86_CDQ
+ x86_CDQE
+ x86_CLC
+ x86_CLD
+ x86_CLFLUSH
+ x86_CLI
+ x86_CLTS
+ x86_CMC
+ x86_CMOVA
+ x86_CMOVAE
+ x86_CMOVB
+ x86_CMOVBE
+ x86_CMOVE
+ x86_CMOVG
+ x86_CMOVGE
+ x86_CMOVL
+ x86_CMOVLE
+ x86_CMOVNE
+ x86_CMOVNO
+ x86_CMOVNP
+ x86_CMOVNS
+ x86_CMOVO
+ x86_CMOVP
+ x86_CMOVS
+ x86_CMP
+ x86_CMPPD
+ x86_CMPPS
+ x86_CMPSB
+ x86_CMPSD
+ x86_CMPSD_XMM
+ x86_CMPSQ
+ x86_CMPSS
+ x86_CMPSW
+ x86_CMPXCHG
+ x86_CMPXCHG16B
+ x86_CMPXCHG8B
+ x86_COMISD
+ x86_COMISS
+ x86_CPUID
+ x86_CQO
+ x86_CRC32
+ x86_CVTDQ2PD
+ x86_CVTDQ2PS
+ x86_CVTPD2DQ
+ x86_CVTPD2PI
+ x86_CVTPD2PS
+ x86_CVTPI2PD
+ x86_CVTPI2PS
+ x86_CVTPS2DQ
+ x86_CVTPS2PD
+ x86_CVTPS2PI
+ x86_CVTSD2SI
+ x86_CVTSD2SS
+ x86_CVTSI2SD
+ x86_CVTSI2SS
+ x86_CVTSS2SD
+ x86_CVTSS2SI
+ x86_CVTTPD2DQ
+ x86_CVTTPD2PI
+ x86_CVTTPS2DQ
+ x86_CVTTPS2PI
+ x86_CVTTSD2SI
+ x86_CVTTSS2SI
+ x86_CWD
+ x86_CWDE
+ x86_DAA
+ x86_DAS
+ x86_DEC
+ x86_DIV
+ x86_DIVPD
+ x86_DIVPS
+ x86_DIVSD
+ x86_DIVSS
+ x86_DPPD
+ x86_DPPS
+ x86_EMMS
+ x86_ENTER
+ x86_EXTRACTPS
+ x86_F2XM1
+ x86_FABS
+ x86_FADD
+ x86_FADDP
+ x86_FBLD
+ x86_FBSTP
+ x86_FCHS
+ x86_FCMOVB
+ x86_FCMOVBE
+ x86_FCMOVE
+ x86_FCMOVNB
+ x86_FCMOVNBE
+ x86_FCMOVNE
+ x86_FCMOVNU
+ x86_FCMOVU
+ x86_FCOM
+ x86_FCOMI
+ x86_FCOMIP
+ x86_FCOMP
+ x86_FCOMPP
+ x86_FCOS
+ x86_FDECSTP
+ x86_FDIV
+ x86_FDIVP
+ x86_FDIVR
+ x86_FDIVRP
+ x86_FFREE
+ x86_FFREEP
+ x86_FIADD
+ x86_FICOM
+ x86_FICOMP
+ x86_FIDIV
+ x86_FIDIVR
+ x86_FILD
+ x86_FIMUL
+ x86_FINCSTP
+ x86_FIST
+ x86_FISTP
+ x86_FISTTP
+ x86_FISUB
+ x86_FISUBR
+ x86_FLD
+ x86_FLD1
+ x86_FLDCW
+ x86_FLDENV
+ x86_FLDL2E
+ x86_FLDL2T
+ x86_FLDLG2
+ x86_FLDPI
+ x86_FMUL
+ x86_FMULP
+ x86_FNCLEX
+ x86_FNINIT
+ x86_FNOP
+ x86_FNSAVE
+ x86_FNSTCW
+ x86_FNSTENV
+ x86_FNSTSW
+ x86_FPATAN
+ x86_FPREM
+ x86_FPREM1
+ x86_FPTAN
+ x86_FRNDINT
+ x86_FRSTOR
+ x86_FSCALE
+ x86_FSIN
+ x86_FSINCOS
+ x86_FSQRT
+ x86_FST
+ x86_FSTP
+ x86_FSUB
+ x86_FSUBP
+ x86_FSUBR
+ x86_FSUBRP
+ x86_FTST
+ x86_FUCOM
+ x86_FUCOMI
+ x86_FUCOMIP
+ x86_FUCOMP
+ x86_FUCOMPP
+ x86_FWAIT
+ x86_FXAM
+ x86_FXCH
+ x86_FXRSTOR
+ x86_FXRSTOR64
+ x86_FXSAVE
+ x86_FXSAVE64
+ x86_FXTRACT
+ x86_FYL2X
+ x86_FYL2XP1
+ x86_HADDPD
+ x86_HADDPS
+ x86_HLT
+ x86_HSUBPD
+ x86_HSUBPS
+ x86_ICEBP
+ x86_IDIV
+ x86_IMUL
+ x86_IN
+ x86_INC
+ x86_INSB
+ x86_INSD
+ x86_INSERTPS
+ x86_INSW
+ x86_INT
+ x86_INTO
+ x86_INVD
+ x86_INVLPG
+ x86_INVPCID
+ x86_IRET
+ x86_IRETD
+ x86_IRETQ
+ x86_JA
+ x86_JAE
+ x86_JB
+ x86_JBE
+ x86_JCXZ
+ x86_JE
+ x86_JECXZ
+ x86_JG
+ x86_JGE
+ x86_JL
+ x86_JLE
+ x86_JMP
+ x86_JNE
+ x86_JNO
+ x86_JNP
+ x86_JNS
+ x86_JO
+ x86_JP
+ x86_JRCXZ
+ x86_JS
+ x86_LAHF
+ x86_LAR
+ x86_LCALL
+ x86_LDDQU
+ x86_LDMXCSR
+ x86_LDS
+ x86_LEA
+ x86_LEAVE
+ x86_LES
+ x86_LFENCE
+ x86_LFS
+ x86_LGDT
+ x86_LGS
+ x86_LIDT
+ x86_LJMP
+ x86_LLDT
+ x86_LMSW
+ x86_LODSB
+ x86_LODSD
+ x86_LODSQ
+ x86_LODSW
+ x86_LOOP
+ x86_LOOPE
+ x86_LOOPNE
+ x86_LRET
+ x86_LSL
+ x86_LSS
+ x86_LTR
+ x86_LZCNT
+ x86_MASKMOVDQU
+ x86_MASKMOVQ
+ x86_MAXPD
+ x86_MAXPS
+ x86_MAXSD
+ x86_MAXSS
+ x86_MFENCE
+ x86_MINPD
+ x86_MINPS
+ x86_MINSD
+ x86_MINSS
+ x86_MONITOR
+ x86_MOV
+ x86_MOVAPD
+ x86_MOVAPS
+ x86_MOVBE
+ x86_MOVD
+ x86_MOVDDUP
+ x86_MOVDQ2Q
+ x86_MOVDQA
+ x86_MOVDQU
+ x86_MOVHLPS
+ x86_MOVHPD
+ x86_MOVHPS
+ x86_MOVLHPS
+ x86_MOVLPD
+ x86_MOVLPS
+ x86_MOVMSKPD
+ x86_MOVMSKPS
+ x86_MOVNTDQ
+ x86_MOVNTDQA
+ x86_MOVNTI
+ x86_MOVNTPD
+ x86_MOVNTPS
+ x86_MOVNTQ
+ x86_MOVNTSD
+ x86_MOVNTSS
+ x86_MOVQ
+ x86_MOVQ2DQ
+ x86_MOVSB
+ x86_MOVSD
+ x86_MOVSD_XMM
+ x86_MOVSHDUP
+ x86_MOVSLDUP
+ x86_MOVSQ
+ x86_MOVSS
+ x86_MOVSW
+ x86_MOVSX
+ x86_MOVSXD
+ x86_MOVUPD
+ x86_MOVUPS
+ x86_MOVZX
+ x86_MPSADBW
+ x86_MUL
+ x86_MULPD
+ x86_MULPS
+ x86_MULSD
+ x86_MULSS
+ x86_MWAIT
+ x86_NEG
+ x86_NOP
+ x86_NOT
+ x86_OR
+ x86_ORPD
+ x86_ORPS
+ x86_OUT
+ x86_OUTSB
+ x86_OUTSD
+ x86_OUTSW
+ x86_PABSB
+ x86_PABSD
+ x86_PABSW
+ x86_PACKSSDW
+ x86_PACKSSWB
+ x86_PACKUSDW
+ x86_PACKUSWB
+ x86_PADDB
+ x86_PADDD
+ x86_PADDQ
+ x86_PADDSB
+ x86_PADDSW
+ x86_PADDUSB
+ x86_PADDUSW
+ x86_PADDW
+ x86_PALIGNR
+ x86_PAND
+ x86_PANDN
+ x86_PAUSE
+ x86_PAVGB
+ x86_PAVGW
+ x86_PBLENDVB
+ x86_PBLENDW
+ x86_PCLMULQDQ
+ x86_PCMPEQB
+ x86_PCMPEQD
+ x86_PCMPEQQ
+ x86_PCMPEQW
+ x86_PCMPESTRI
+ x86_PCMPESTRM
+ x86_PCMPGTB
+ x86_PCMPGTD
+ x86_PCMPGTQ
+ x86_PCMPGTW
+ x86_PCMPISTRI
+ x86_PCMPISTRM
+ x86_PEXTRB
+ x86_PEXTRD
+ x86_PEXTRQ
+ x86_PEXTRW
+ x86_PHADDD
+ x86_PHADDSW
+ x86_PHADDW
+ x86_PHMINPOSUW
+ x86_PHSUBD
+ x86_PHSUBSW
+ x86_PHSUBW
+ x86_PINSRB
+ x86_PINSRD
+ x86_PINSRQ
+ x86_PINSRW
+ x86_PMADDUBSW
+ x86_PMADDWD
+ x86_PMAXSB
+ x86_PMAXSD
+ x86_PMAXSW
+ x86_PMAXUB
+ x86_PMAXUD
+ x86_PMAXUW
+ x86_PMINSB
+ x86_PMINSD
+ x86_PMINSW
+ x86_PMINUB
+ x86_PMINUD
+ x86_PMINUW
+ x86_PMOVMSKB
+ x86_PMOVSXBD
+ x86_PMOVSXBQ
+ x86_PMOVSXBW
+ x86_PMOVSXDQ
+ x86_PMOVSXWD
+ x86_PMOVSXWQ
+ x86_PMOVZXBD
+ x86_PMOVZXBQ
+ x86_PMOVZXBW
+ x86_PMOVZXDQ
+ x86_PMOVZXWD
+ x86_PMOVZXWQ
+ x86_PMULDQ
+ x86_PMULHRSW
+ x86_PMULHUW
+ x86_PMULHW
+ x86_PMULLD
+ x86_PMULLW
+ x86_PMULUDQ
+ x86_POP
+ x86_POPA
+ x86_POPAD
+ x86_POPCNT
+ x86_POPF
+ x86_POPFD
+ x86_POPFQ
+ x86_POR
+ x86_PREFETCHNTA
+ x86_PREFETCHT0
+ x86_PREFETCHT1
+ x86_PREFETCHT2
+ x86_PREFETCHW
+ x86_PSADBW
+ x86_PSHUFB
+ x86_PSHUFD
+ x86_PSHUFHW
+ x86_PSHUFLW
+ x86_PSHUFW
+ x86_PSIGNB
+ x86_PSIGND
+ x86_PSIGNW
+ x86_PSLLD
+ x86_PSLLDQ
+ x86_PSLLQ
+ x86_PSLLW
+ x86_PSRAD
+ x86_PSRAW
+ x86_PSRLD
+ x86_PSRLDQ
+ x86_PSRLQ
+ x86_PSRLW
+ x86_PSUBB
+ x86_PSUBD
+ x86_PSUBQ
+ x86_PSUBSB
+ x86_PSUBSW
+ x86_PSUBUSB
+ x86_PSUBUSW
+ x86_PSUBW
+ x86_PTEST
+ x86_PUNPCKHBW
+ x86_PUNPCKHDQ
+ x86_PUNPCKHQDQ
+ x86_PUNPCKHWD
+ x86_PUNPCKLBW
+ x86_PUNPCKLDQ
+ x86_PUNPCKLQDQ
+ x86_PUNPCKLWD
+ x86_PUSH
+ x86_PUSHA
+ x86_PUSHAD
+ x86_PUSHF
+ x86_PUSHFD
+ x86_PUSHFQ
+ x86_PXOR
+ x86_RCL
+ x86_RCPPS
+ x86_RCPSS
+ x86_RCR
+ x86_RDFSBASE
+ x86_RDGSBASE
+ x86_RDMSR
+ x86_RDPMC
+ x86_RDRAND
+ x86_RDTSC
+ x86_RDTSCP
+ x86_RET
+ x86_ROL
+ x86_ROR
+ x86_ROUNDPD
+ x86_ROUNDPS
+ x86_ROUNDSD
+ x86_ROUNDSS
+ x86_RSM
+ x86_RSQRTPS
+ x86_RSQRTSS
+ x86_SAHF
+ x86_SAR
+ x86_SBB
+ x86_SCASB
+ x86_SCASD
+ x86_SCASQ
+ x86_SCASW
+ x86_SETA
+ x86_SETAE
+ x86_SETB
+ x86_SETBE
+ x86_SETE
+ x86_SETG
+ x86_SETGE
+ x86_SETL
+ x86_SETLE
+ x86_SETNE
+ x86_SETNO
+ x86_SETNP
+ x86_SETNS
+ x86_SETO
+ x86_SETP
+ x86_SETS
+ x86_SFENCE
+ x86_SGDT
+ x86_SHL
+ x86_SHLD
+ x86_SHR
+ x86_SHRD
+ x86_SHUFPD
+ x86_SHUFPS
+ x86_SIDT
+ x86_SLDT
+ x86_SMSW
+ x86_SQRTPD
+ x86_SQRTPS
+ x86_SQRTSD
+ x86_SQRTSS
+ x86_STC
+ x86_STD
+ x86_STI
+ x86_STMXCSR
+ x86_STOSB
+ x86_STOSD
+ x86_STOSQ
+ x86_STOSW
+ x86_STR
+ x86_SUB
+ x86_SUBPD
+ x86_SUBPS
+ x86_SUBSD
+ x86_SUBSS
+ x86_SWAPGS
+ x86_SYSCALL
+ x86_SYSENTER
+ x86_SYSEXIT
+ x86_SYSRET
+ x86_TEST
+ x86_TZCNT
+ x86_UCOMISD
+ x86_UCOMISS
+ x86_UD1
+ x86_UD2
+ x86_UNPCKHPD
+ x86_UNPCKHPS
+ x86_UNPCKLPD
+ x86_UNPCKLPS
+ x86_VERR
+ x86_VERW
+ x86_WBINVD
+ x86_WRFSBASE
+ x86_WRGSBASE
+ x86_WRMSR
+ x86_XABORT
+ x86_XADD
+ x86_XBEGIN
+ x86_XCHG
+ x86_XEND
+ x86_XGETBV
+ x86_XLATB
+ x86_XOR
+ x86_XORPD
+ x86_XORPS
+ x86_XRSTOR
+ x86_XRSTOR64
+ x86_XRSTORS
+ x86_XRSTORS64
+ x86_XSAVE
+ x86_XSAVE64
+ x86_XSAVEC
+ x86_XSAVEC64
+ x86_XSAVEOPT
+ x86_XSAVEOPT64
+ x86_XSAVES
+ x86_XSAVES64
+ x86_XSETBV
+ x86_XTEST
+)
+
+const x86_maxOp = x86_XTEST
+
+var x86_opNames = [...]string{
+ x86_AAA: "AAA",
+ x86_AAD: "AAD",
+ x86_AAM: "AAM",
+ x86_AAS: "AAS",
+ x86_ADC: "ADC",
+ x86_ADD: "ADD",
+ x86_ADDPD: "ADDPD",
+ x86_ADDPS: "ADDPS",
+ x86_ADDSD: "ADDSD",
+ x86_ADDSS: "ADDSS",
+ x86_ADDSUBPD: "ADDSUBPD",
+ x86_ADDSUBPS: "ADDSUBPS",
+ x86_AESDEC: "AESDEC",
+ x86_AESDECLAST: "AESDECLAST",
+ x86_AESENC: "AESENC",
+ x86_AESENCLAST: "AESENCLAST",
+ x86_AESIMC: "AESIMC",
+ x86_AESKEYGENASSIST: "AESKEYGENASSIST",
+ x86_AND: "AND",
+ x86_ANDNPD: "ANDNPD",
+ x86_ANDNPS: "ANDNPS",
+ x86_ANDPD: "ANDPD",
+ x86_ANDPS: "ANDPS",
+ x86_ARPL: "ARPL",
+ x86_BLENDPD: "BLENDPD",
+ x86_BLENDPS: "BLENDPS",
+ x86_BLENDVPD: "BLENDVPD",
+ x86_BLENDVPS: "BLENDVPS",
+ x86_BOUND: "BOUND",
+ x86_BSF: "BSF",
+ x86_BSR: "BSR",
+ x86_BSWAP: "BSWAP",
+ x86_BT: "BT",
+ x86_BTC: "BTC",
+ x86_BTR: "BTR",
+ x86_BTS: "BTS",
+ x86_CALL: "CALL",
+ x86_CBW: "CBW",
+ x86_CDQ: "CDQ",
+ x86_CDQE: "CDQE",
+ x86_CLC: "CLC",
+ x86_CLD: "CLD",
+ x86_CLFLUSH: "CLFLUSH",
+ x86_CLI: "CLI",
+ x86_CLTS: "CLTS",
+ x86_CMC: "CMC",
+ x86_CMOVA: "CMOVA",
+ x86_CMOVAE: "CMOVAE",
+ x86_CMOVB: "CMOVB",
+ x86_CMOVBE: "CMOVBE",
+ x86_CMOVE: "CMOVE",
+ x86_CMOVG: "CMOVG",
+ x86_CMOVGE: "CMOVGE",
+ x86_CMOVL: "CMOVL",
+ x86_CMOVLE: "CMOVLE",
+ x86_CMOVNE: "CMOVNE",
+ x86_CMOVNO: "CMOVNO",
+ x86_CMOVNP: "CMOVNP",
+ x86_CMOVNS: "CMOVNS",
+ x86_CMOVO: "CMOVO",
+ x86_CMOVP: "CMOVP",
+ x86_CMOVS: "CMOVS",
+ x86_CMP: "CMP",
+ x86_CMPPD: "CMPPD",
+ x86_CMPPS: "CMPPS",
+ x86_CMPSB: "CMPSB",
+ x86_CMPSD: "CMPSD",
+ x86_CMPSD_XMM: "CMPSD_XMM",
+ x86_CMPSQ: "CMPSQ",
+ x86_CMPSS: "CMPSS",
+ x86_CMPSW: "CMPSW",
+ x86_CMPXCHG: "CMPXCHG",
+ x86_CMPXCHG16B: "CMPXCHG16B",
+ x86_CMPXCHG8B: "CMPXCHG8B",
+ x86_COMISD: "COMISD",
+ x86_COMISS: "COMISS",
+ x86_CPUID: "CPUID",
+ x86_CQO: "CQO",
+ x86_CRC32: "CRC32",
+ x86_CVTDQ2PD: "CVTDQ2PD",
+ x86_CVTDQ2PS: "CVTDQ2PS",
+ x86_CVTPD2DQ: "CVTPD2DQ",
+ x86_CVTPD2PI: "CVTPD2PI",
+ x86_CVTPD2PS: "CVTPD2PS",
+ x86_CVTPI2PD: "CVTPI2PD",
+ x86_CVTPI2PS: "CVTPI2PS",
+ x86_CVTPS2DQ: "CVTPS2DQ",
+ x86_CVTPS2PD: "CVTPS2PD",
+ x86_CVTPS2PI: "CVTPS2PI",
+ x86_CVTSD2SI: "CVTSD2SI",
+ x86_CVTSD2SS: "CVTSD2SS",
+ x86_CVTSI2SD: "CVTSI2SD",
+ x86_CVTSI2SS: "CVTSI2SS",
+ x86_CVTSS2SD: "CVTSS2SD",
+ x86_CVTSS2SI: "CVTSS2SI",
+ x86_CVTTPD2DQ: "CVTTPD2DQ",
+ x86_CVTTPD2PI: "CVTTPD2PI",
+ x86_CVTTPS2DQ: "CVTTPS2DQ",
+ x86_CVTTPS2PI: "CVTTPS2PI",
+ x86_CVTTSD2SI: "CVTTSD2SI",
+ x86_CVTTSS2SI: "CVTTSS2SI",
+ x86_CWD: "CWD",
+ x86_CWDE: "CWDE",
+ x86_DAA: "DAA",
+ x86_DAS: "DAS",
+ x86_DEC: "DEC",
+ x86_DIV: "DIV",
+ x86_DIVPD: "DIVPD",
+ x86_DIVPS: "DIVPS",
+ x86_DIVSD: "DIVSD",
+ x86_DIVSS: "DIVSS",
+ x86_DPPD: "DPPD",
+ x86_DPPS: "DPPS",
+ x86_EMMS: "EMMS",
+ x86_ENTER: "ENTER",
+ x86_EXTRACTPS: "EXTRACTPS",
+ x86_F2XM1: "F2XM1",
+ x86_FABS: "FABS",
+ x86_FADD: "FADD",
+ x86_FADDP: "FADDP",
+ x86_FBLD: "FBLD",
+ x86_FBSTP: "FBSTP",
+ x86_FCHS: "FCHS",
+ x86_FCMOVB: "FCMOVB",
+ x86_FCMOVBE: "FCMOVBE",
+ x86_FCMOVE: "FCMOVE",
+ x86_FCMOVNB: "FCMOVNB",
+ x86_FCMOVNBE: "FCMOVNBE",
+ x86_FCMOVNE: "FCMOVNE",
+ x86_FCMOVNU: "FCMOVNU",
+ x86_FCMOVU: "FCMOVU",
+ x86_FCOM: "FCOM",
+ x86_FCOMI: "FCOMI",
+ x86_FCOMIP: "FCOMIP",
+ x86_FCOMP: "FCOMP",
+ x86_FCOMPP: "FCOMPP",
+ x86_FCOS: "FCOS",
+ x86_FDECSTP: "FDECSTP",
+ x86_FDIV: "FDIV",
+ x86_FDIVP: "FDIVP",
+ x86_FDIVR: "FDIVR",
+ x86_FDIVRP: "FDIVRP",
+ x86_FFREE: "FFREE",
+ x86_FFREEP: "FFREEP",
+ x86_FIADD: "FIADD",
+ x86_FICOM: "FICOM",
+ x86_FICOMP: "FICOMP",
+ x86_FIDIV: "FIDIV",
+ x86_FIDIVR: "FIDIVR",
+ x86_FILD: "FILD",
+ x86_FIMUL: "FIMUL",
+ x86_FINCSTP: "FINCSTP",
+ x86_FIST: "FIST",
+ x86_FISTP: "FISTP",
+ x86_FISTTP: "FISTTP",
+ x86_FISUB: "FISUB",
+ x86_FISUBR: "FISUBR",
+ x86_FLD: "FLD",
+ x86_FLD1: "FLD1",
+ x86_FLDCW: "FLDCW",
+ x86_FLDENV: "FLDENV",
+ x86_FLDL2E: "FLDL2E",
+ x86_FLDL2T: "FLDL2T",
+ x86_FLDLG2: "FLDLG2",
+ x86_FLDPI: "FLDPI",
+ x86_FMUL: "FMUL",
+ x86_FMULP: "FMULP",
+ x86_FNCLEX: "FNCLEX",
+ x86_FNINIT: "FNINIT",
+ x86_FNOP: "FNOP",
+ x86_FNSAVE: "FNSAVE",
+ x86_FNSTCW: "FNSTCW",
+ x86_FNSTENV: "FNSTENV",
+ x86_FNSTSW: "FNSTSW",
+ x86_FPATAN: "FPATAN",
+ x86_FPREM: "FPREM",
+ x86_FPREM1: "FPREM1",
+ x86_FPTAN: "FPTAN",
+ x86_FRNDINT: "FRNDINT",
+ x86_FRSTOR: "FRSTOR",
+ x86_FSCALE: "FSCALE",
+ x86_FSIN: "FSIN",
+ x86_FSINCOS: "FSINCOS",
+ x86_FSQRT: "FSQRT",
+ x86_FST: "FST",
+ x86_FSTP: "FSTP",
+ x86_FSUB: "FSUB",
+ x86_FSUBP: "FSUBP",
+ x86_FSUBR: "FSUBR",
+ x86_FSUBRP: "FSUBRP",
+ x86_FTST: "FTST",
+ x86_FUCOM: "FUCOM",
+ x86_FUCOMI: "FUCOMI",
+ x86_FUCOMIP: "FUCOMIP",
+ x86_FUCOMP: "FUCOMP",
+ x86_FUCOMPP: "FUCOMPP",
+ x86_FWAIT: "FWAIT",
+ x86_FXAM: "FXAM",
+ x86_FXCH: "FXCH",
+ x86_FXRSTOR: "FXRSTOR",
+ x86_FXRSTOR64: "FXRSTOR64",
+ x86_FXSAVE: "FXSAVE",
+ x86_FXSAVE64: "FXSAVE64",
+ x86_FXTRACT: "FXTRACT",
+ x86_FYL2X: "FYL2X",
+ x86_FYL2XP1: "FYL2XP1",
+ x86_HADDPD: "HADDPD",
+ x86_HADDPS: "HADDPS",
+ x86_HLT: "HLT",
+ x86_HSUBPD: "HSUBPD",
+ x86_HSUBPS: "HSUBPS",
+ x86_ICEBP: "ICEBP",
+ x86_IDIV: "IDIV",
+ x86_IMUL: "IMUL",
+ x86_IN: "IN",
+ x86_INC: "INC",
+ x86_INSB: "INSB",
+ x86_INSD: "INSD",
+ x86_INSERTPS: "INSERTPS",
+ x86_INSW: "INSW",
+ x86_INT: "INT",
+ x86_INTO: "INTO",
+ x86_INVD: "INVD",
+ x86_INVLPG: "INVLPG",
+ x86_INVPCID: "INVPCID",
+ x86_IRET: "IRET",
+ x86_IRETD: "IRETD",
+ x86_IRETQ: "IRETQ",
+ x86_JA: "JA",
+ x86_JAE: "JAE",
+ x86_JB: "JB",
+ x86_JBE: "JBE",
+ x86_JCXZ: "JCXZ",
+ x86_JE: "JE",
+ x86_JECXZ: "JECXZ",
+ x86_JG: "JG",
+ x86_JGE: "JGE",
+ x86_JL: "JL",
+ x86_JLE: "JLE",
+ x86_JMP: "JMP",
+ x86_JNE: "JNE",
+ x86_JNO: "JNO",
+ x86_JNP: "JNP",
+ x86_JNS: "JNS",
+ x86_JO: "JO",
+ x86_JP: "JP",
+ x86_JRCXZ: "JRCXZ",
+ x86_JS: "JS",
+ x86_LAHF: "LAHF",
+ x86_LAR: "LAR",
+ x86_LCALL: "LCALL",
+ x86_LDDQU: "LDDQU",
+ x86_LDMXCSR: "LDMXCSR",
+ x86_LDS: "LDS",
+ x86_LEA: "LEA",
+ x86_LEAVE: "LEAVE",
+ x86_LES: "LES",
+ x86_LFENCE: "LFENCE",
+ x86_LFS: "LFS",
+ x86_LGDT: "LGDT",
+ x86_LGS: "LGS",
+ x86_LIDT: "LIDT",
+ x86_LJMP: "LJMP",
+ x86_LLDT: "LLDT",
+ x86_LMSW: "LMSW",
+ x86_LODSB: "LODSB",
+ x86_LODSD: "LODSD",
+ x86_LODSQ: "LODSQ",
+ x86_LODSW: "LODSW",
+ x86_LOOP: "LOOP",
+ x86_LOOPE: "LOOPE",
+ x86_LOOPNE: "LOOPNE",
+ x86_LRET: "LRET",
+ x86_LSL: "LSL",
+ x86_LSS: "LSS",
+ x86_LTR: "LTR",
+ x86_LZCNT: "LZCNT",
+ x86_MASKMOVDQU: "MASKMOVDQU",
+ x86_MASKMOVQ: "MASKMOVQ",
+ x86_MAXPD: "MAXPD",
+ x86_MAXPS: "MAXPS",
+ x86_MAXSD: "MAXSD",
+ x86_MAXSS: "MAXSS",
+ x86_MFENCE: "MFENCE",
+ x86_MINPD: "MINPD",
+ x86_MINPS: "MINPS",
+ x86_MINSD: "MINSD",
+ x86_MINSS: "MINSS",
+ x86_MONITOR: "MONITOR",
+ x86_MOV: "MOV",
+ x86_MOVAPD: "MOVAPD",
+ x86_MOVAPS: "MOVAPS",
+ x86_MOVBE: "MOVBE",
+ x86_MOVD: "MOVD",
+ x86_MOVDDUP: "MOVDDUP",
+ x86_MOVDQ2Q: "MOVDQ2Q",
+ x86_MOVDQA: "MOVDQA",
+ x86_MOVDQU: "MOVDQU",
+ x86_MOVHLPS: "MOVHLPS",
+ x86_MOVHPD: "MOVHPD",
+ x86_MOVHPS: "MOVHPS",
+ x86_MOVLHPS: "MOVLHPS",
+ x86_MOVLPD: "MOVLPD",
+ x86_MOVLPS: "MOVLPS",
+ x86_MOVMSKPD: "MOVMSKPD",
+ x86_MOVMSKPS: "MOVMSKPS",
+ x86_MOVNTDQ: "MOVNTDQ",
+ x86_MOVNTDQA: "MOVNTDQA",
+ x86_MOVNTI: "MOVNTI",
+ x86_MOVNTPD: "MOVNTPD",
+ x86_MOVNTPS: "MOVNTPS",
+ x86_MOVNTQ: "MOVNTQ",
+ x86_MOVNTSD: "MOVNTSD",
+ x86_MOVNTSS: "MOVNTSS",
+ x86_MOVQ: "MOVQ",
+ x86_MOVQ2DQ: "MOVQ2DQ",
+ x86_MOVSB: "MOVSB",
+ x86_MOVSD: "MOVSD",
+ x86_MOVSD_XMM: "MOVSD_XMM",
+ x86_MOVSHDUP: "MOVSHDUP",
+ x86_MOVSLDUP: "MOVSLDUP",
+ x86_MOVSQ: "MOVSQ",
+ x86_MOVSS: "MOVSS",
+ x86_MOVSW: "MOVSW",
+ x86_MOVSX: "MOVSX",
+ x86_MOVSXD: "MOVSXD",
+ x86_MOVUPD: "MOVUPD",
+ x86_MOVUPS: "MOVUPS",
+ x86_MOVZX: "MOVZX",
+ x86_MPSADBW: "MPSADBW",
+ x86_MUL: "MUL",
+ x86_MULPD: "MULPD",
+ x86_MULPS: "MULPS",
+ x86_MULSD: "MULSD",
+ x86_MULSS: "MULSS",
+ x86_MWAIT: "MWAIT",
+ x86_NEG: "NEG",
+ x86_NOP: "NOP",
+ x86_NOT: "NOT",
+ x86_OR: "OR",
+ x86_ORPD: "ORPD",
+ x86_ORPS: "ORPS",
+ x86_OUT: "OUT",
+ x86_OUTSB: "OUTSB",
+ x86_OUTSD: "OUTSD",
+ x86_OUTSW: "OUTSW",
+ x86_PABSB: "PABSB",
+ x86_PABSD: "PABSD",
+ x86_PABSW: "PABSW",
+ x86_PACKSSDW: "PACKSSDW",
+ x86_PACKSSWB: "PACKSSWB",
+ x86_PACKUSDW: "PACKUSDW",
+ x86_PACKUSWB: "PACKUSWB",
+ x86_PADDB: "PADDB",
+ x86_PADDD: "PADDD",
+ x86_PADDQ: "PADDQ",
+ x86_PADDSB: "PADDSB",
+ x86_PADDSW: "PADDSW",
+ x86_PADDUSB: "PADDUSB",
+ x86_PADDUSW: "PADDUSW",
+ x86_PADDW: "PADDW",
+ x86_PALIGNR: "PALIGNR",
+ x86_PAND: "PAND",
+ x86_PANDN: "PANDN",
+ x86_PAUSE: "PAUSE",
+ x86_PAVGB: "PAVGB",
+ x86_PAVGW: "PAVGW",
+ x86_PBLENDVB: "PBLENDVB",
+ x86_PBLENDW: "PBLENDW",
+ x86_PCLMULQDQ: "PCLMULQDQ",
+ x86_PCMPEQB: "PCMPEQB",
+ x86_PCMPEQD: "PCMPEQD",
+ x86_PCMPEQQ: "PCMPEQQ",
+ x86_PCMPEQW: "PCMPEQW",
+ x86_PCMPESTRI: "PCMPESTRI",
+ x86_PCMPESTRM: "PCMPESTRM",
+ x86_PCMPGTB: "PCMPGTB",
+ x86_PCMPGTD: "PCMPGTD",
+ x86_PCMPGTQ: "PCMPGTQ",
+ x86_PCMPGTW: "PCMPGTW",
+ x86_PCMPISTRI: "PCMPISTRI",
+ x86_PCMPISTRM: "PCMPISTRM",
+ x86_PEXTRB: "PEXTRB",
+ x86_PEXTRD: "PEXTRD",
+ x86_PEXTRQ: "PEXTRQ",
+ x86_PEXTRW: "PEXTRW",
+ x86_PHADDD: "PHADDD",
+ x86_PHADDSW: "PHADDSW",
+ x86_PHADDW: "PHADDW",
+ x86_PHMINPOSUW: "PHMINPOSUW",
+ x86_PHSUBD: "PHSUBD",
+ x86_PHSUBSW: "PHSUBSW",
+ x86_PHSUBW: "PHSUBW",
+ x86_PINSRB: "PINSRB",
+ x86_PINSRD: "PINSRD",
+ x86_PINSRQ: "PINSRQ",
+ x86_PINSRW: "PINSRW",
+ x86_PMADDUBSW: "PMADDUBSW",
+ x86_PMADDWD: "PMADDWD",
+ x86_PMAXSB: "PMAXSB",
+ x86_PMAXSD: "PMAXSD",
+ x86_PMAXSW: "PMAXSW",
+ x86_PMAXUB: "PMAXUB",
+ x86_PMAXUD: "PMAXUD",
+ x86_PMAXUW: "PMAXUW",
+ x86_PMINSB: "PMINSB",
+ x86_PMINSD: "PMINSD",
+ x86_PMINSW: "PMINSW",
+ x86_PMINUB: "PMINUB",
+ x86_PMINUD: "PMINUD",
+ x86_PMINUW: "PMINUW",
+ x86_PMOVMSKB: "PMOVMSKB",
+ x86_PMOVSXBD: "PMOVSXBD",
+ x86_PMOVSXBQ: "PMOVSXBQ",
+ x86_PMOVSXBW: "PMOVSXBW",
+ x86_PMOVSXDQ: "PMOVSXDQ",
+ x86_PMOVSXWD: "PMOVSXWD",
+ x86_PMOVSXWQ: "PMOVSXWQ",
+ x86_PMOVZXBD: "PMOVZXBD",
+ x86_PMOVZXBQ: "PMOVZXBQ",
+ x86_PMOVZXBW: "PMOVZXBW",
+ x86_PMOVZXDQ: "PMOVZXDQ",
+ x86_PMOVZXWD: "PMOVZXWD",
+ x86_PMOVZXWQ: "PMOVZXWQ",
+ x86_PMULDQ: "PMULDQ",
+ x86_PMULHRSW: "PMULHRSW",
+ x86_PMULHUW: "PMULHUW",
+ x86_PMULHW: "PMULHW",
+ x86_PMULLD: "PMULLD",
+ x86_PMULLW: "PMULLW",
+ x86_PMULUDQ: "PMULUDQ",
+ x86_POP: "POP",
+ x86_POPA: "POPA",
+ x86_POPAD: "POPAD",
+ x86_POPCNT: "POPCNT",
+ x86_POPF: "POPF",
+ x86_POPFD: "POPFD",
+ x86_POPFQ: "POPFQ",
+ x86_POR: "POR",
+ x86_PREFETCHNTA: "PREFETCHNTA",
+ x86_PREFETCHT0: "PREFETCHT0",
+ x86_PREFETCHT1: "PREFETCHT1",
+ x86_PREFETCHT2: "PREFETCHT2",
+ x86_PREFETCHW: "PREFETCHW",
+ x86_PSADBW: "PSADBW",
+ x86_PSHUFB: "PSHUFB",
+ x86_PSHUFD: "PSHUFD",
+ x86_PSHUFHW: "PSHUFHW",
+ x86_PSHUFLW: "PSHUFLW",
+ x86_PSHUFW: "PSHUFW",
+ x86_PSIGNB: "PSIGNB",
+ x86_PSIGND: "PSIGND",
+ x86_PSIGNW: "PSIGNW",
+ x86_PSLLD: "PSLLD",
+ x86_PSLLDQ: "PSLLDQ",
+ x86_PSLLQ: "PSLLQ",
+ x86_PSLLW: "PSLLW",
+ x86_PSRAD: "PSRAD",
+ x86_PSRAW: "PSRAW",
+ x86_PSRLD: "PSRLD",
+ x86_PSRLDQ: "PSRLDQ",
+ x86_PSRLQ: "PSRLQ",
+ x86_PSRLW: "PSRLW",
+ x86_PSUBB: "PSUBB",
+ x86_PSUBD: "PSUBD",
+ x86_PSUBQ: "PSUBQ",
+ x86_PSUBSB: "PSUBSB",
+ x86_PSUBSW: "PSUBSW",
+ x86_PSUBUSB: "PSUBUSB",
+ x86_PSUBUSW: "PSUBUSW",
+ x86_PSUBW: "PSUBW",
+ x86_PTEST: "PTEST",
+ x86_PUNPCKHBW: "PUNPCKHBW",
+ x86_PUNPCKHDQ: "PUNPCKHDQ",
+ x86_PUNPCKHQDQ: "PUNPCKHQDQ",
+ x86_PUNPCKHWD: "PUNPCKHWD",
+ x86_PUNPCKLBW: "PUNPCKLBW",
+ x86_PUNPCKLDQ: "PUNPCKLDQ",
+ x86_PUNPCKLQDQ: "PUNPCKLQDQ",
+ x86_PUNPCKLWD: "PUNPCKLWD",
+ x86_PUSH: "PUSH",
+ x86_PUSHA: "PUSHA",
+ x86_PUSHAD: "PUSHAD",
+ x86_PUSHF: "PUSHF",
+ x86_PUSHFD: "PUSHFD",
+ x86_PUSHFQ: "PUSHFQ",
+ x86_PXOR: "PXOR",
+ x86_RCL: "RCL",
+ x86_RCPPS: "RCPPS",
+ x86_RCPSS: "RCPSS",
+ x86_RCR: "RCR",
+ x86_RDFSBASE: "RDFSBASE",
+ x86_RDGSBASE: "RDGSBASE",
+ x86_RDMSR: "RDMSR",
+ x86_RDPMC: "RDPMC",
+ x86_RDRAND: "RDRAND",
+ x86_RDTSC: "RDTSC",
+ x86_RDTSCP: "RDTSCP",
+ x86_RET: "RET",
+ x86_ROL: "ROL",
+ x86_ROR: "ROR",
+ x86_ROUNDPD: "ROUNDPD",
+ x86_ROUNDPS: "ROUNDPS",
+ x86_ROUNDSD: "ROUNDSD",
+ x86_ROUNDSS: "ROUNDSS",
+ x86_RSM: "RSM",
+ x86_RSQRTPS: "RSQRTPS",
+ x86_RSQRTSS: "RSQRTSS",
+ x86_SAHF: "SAHF",
+ x86_SAR: "SAR",
+ x86_SBB: "SBB",
+ x86_SCASB: "SCASB",
+ x86_SCASD: "SCASD",
+ x86_SCASQ: "SCASQ",
+ x86_SCASW: "SCASW",
+ x86_SETA: "SETA",
+ x86_SETAE: "SETAE",
+ x86_SETB: "SETB",
+ x86_SETBE: "SETBE",
+ x86_SETE: "SETE",
+ x86_SETG: "SETG",
+ x86_SETGE: "SETGE",
+ x86_SETL: "SETL",
+ x86_SETLE: "SETLE",
+ x86_SETNE: "SETNE",
+ x86_SETNO: "SETNO",
+ x86_SETNP: "SETNP",
+ x86_SETNS: "SETNS",
+ x86_SETO: "SETO",
+ x86_SETP: "SETP",
+ x86_SETS: "SETS",
+ x86_SFENCE: "SFENCE",
+ x86_SGDT: "SGDT",
+ x86_SHL: "SHL",
+ x86_SHLD: "SHLD",
+ x86_SHR: "SHR",
+ x86_SHRD: "SHRD",
+ x86_SHUFPD: "SHUFPD",
+ x86_SHUFPS: "SHUFPS",
+ x86_SIDT: "SIDT",
+ x86_SLDT: "SLDT",
+ x86_SMSW: "SMSW",
+ x86_SQRTPD: "SQRTPD",
+ x86_SQRTPS: "SQRTPS",
+ x86_SQRTSD: "SQRTSD",
+ x86_SQRTSS: "SQRTSS",
+ x86_STC: "STC",
+ x86_STD: "STD",
+ x86_STI: "STI",
+ x86_STMXCSR: "STMXCSR",
+ x86_STOSB: "STOSB",
+ x86_STOSD: "STOSD",
+ x86_STOSQ: "STOSQ",
+ x86_STOSW: "STOSW",
+ x86_STR: "STR",
+ x86_SUB: "SUB",
+ x86_SUBPD: "SUBPD",
+ x86_SUBPS: "SUBPS",
+ x86_SUBSD: "SUBSD",
+ x86_SUBSS: "SUBSS",
+ x86_SWAPGS: "SWAPGS",
+ x86_SYSCALL: "SYSCALL",
+ x86_SYSENTER: "SYSENTER",
+ x86_SYSEXIT: "SYSEXIT",
+ x86_SYSRET: "SYSRET",
+ x86_TEST: "TEST",
+ x86_TZCNT: "TZCNT",
+ x86_UCOMISD: "UCOMISD",
+ x86_UCOMISS: "UCOMISS",
+ x86_UD1: "UD1",
+ x86_UD2: "UD2",
+ x86_UNPCKHPD: "UNPCKHPD",
+ x86_UNPCKHPS: "UNPCKHPS",
+ x86_UNPCKLPD: "UNPCKLPD",
+ x86_UNPCKLPS: "UNPCKLPS",
+ x86_VERR: "VERR",
+ x86_VERW: "VERW",
+ x86_WBINVD: "WBINVD",
+ x86_WRFSBASE: "WRFSBASE",
+ x86_WRGSBASE: "WRGSBASE",
+ x86_WRMSR: "WRMSR",
+ x86_XABORT: "XABORT",
+ x86_XADD: "XADD",
+ x86_XBEGIN: "XBEGIN",
+ x86_XCHG: "XCHG",
+ x86_XEND: "XEND",
+ x86_XGETBV: "XGETBV",
+ x86_XLATB: "XLATB",
+ x86_XOR: "XOR",
+ x86_XORPD: "XORPD",
+ x86_XORPS: "XORPS",
+ x86_XRSTOR: "XRSTOR",
+ x86_XRSTOR64: "XRSTOR64",
+ x86_XRSTORS: "XRSTORS",
+ x86_XRSTORS64: "XRSTORS64",
+ x86_XSAVE: "XSAVE",
+ x86_XSAVE64: "XSAVE64",
+ x86_XSAVEC: "XSAVEC",
+ x86_XSAVEC64: "XSAVEC64",
+ x86_XSAVEOPT: "XSAVEOPT",
+ x86_XSAVEOPT64: "XSAVEOPT64",
+ x86_XSAVES: "XSAVES",
+ x86_XSAVES64: "XSAVES64",
+ x86_XSETBV: "XSETBV",
+ x86_XTEST: "XTEST",
+}