getVersionString()1 const char *getVersionString() const { return "5.78"; }
adc(const Operand & op,uint32 imm)2 void adc(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x10, 2); }
adc(const Operand & op1,const Operand & op2)3 void adc(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x10); }
adcx(const Reg32e & reg,const Operand & op)4 void adcx(const Reg32e& reg, const Operand& op) { opGen(reg, op, 0xF6, 0x66, isREG32_REG32orMEM, NONE, 0x38); }
add(const Operand & op,uint32 imm)5 void add(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x00, 0); }
add(const Operand & op1,const Operand & op2)6 void add(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x00); }
addpd(const Xmm & xmm,const Operand & op)7 void addpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x58, 0x66, isXMM_XMMorMEM); }
addps(const Xmm & xmm,const Operand & op)8 void addps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x58, 0x100, isXMM_XMMorMEM); }
addsd(const Xmm & xmm,const Operand & op)9 void addsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x58, 0xF2, isXMM_XMMorMEM); }
addss(const Xmm & xmm,const Operand & op)10 void addss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x58, 0xF3, isXMM_XMMorMEM); }
addsubpd(const Xmm & xmm,const Operand & op)11 void addsubpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xD0, 0x66, isXMM_XMMorMEM); }
addsubps(const Xmm & xmm,const Operand & op)12 void addsubps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xD0, 0xF2, isXMM_XMMorMEM); }
adox(const Reg32e & reg,const Operand & op)13 void adox(const Reg32e& reg, const Operand& op) { opGen(reg, op, 0xF6, 0xF3, isREG32_REG32orMEM, NONE, 0x38); }
aesdec(const Xmm & xmm,const Operand & op)14 void aesdec(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xDE, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
aesdeclast(const Xmm & xmm,const Operand & op)15 void aesdeclast(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xDF, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
aesenc(const Xmm & xmm,const Operand & op)16 void aesenc(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xDC, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
aesenclast(const Xmm & xmm,const Operand & op)17 void aesenclast(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xDD, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
aesimc(const Xmm & xmm,const Operand & op)18 void aesimc(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xDB, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
aeskeygenassist(const Xmm & xmm,const Operand & op,uint8 imm)19 void aeskeygenassist(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0xDF, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
and_(const Operand & op,uint32 imm)20 void and_(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x20, 4); }
and_(const Operand & op1,const Operand & op2)21 void and_(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x20); }
andn(const Reg32e & r1,const Reg32e & r2,const Operand & op)22 void andn(const Reg32e& r1, const Reg32e& r2, const Operand& op) { opGpr(r1, r2, op, T_0F38, 0xf2, true); }
andnpd(const Xmm & xmm,const Operand & op)23 void andnpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x55, 0x66, isXMM_XMMorMEM); }
andnps(const Xmm & xmm,const Operand & op)24 void andnps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x55, 0x100, isXMM_XMMorMEM); }
andpd(const Xmm & xmm,const Operand & op)25 void andpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x54, 0x66, isXMM_XMMorMEM); }
andps(const Xmm & xmm,const Operand & op)26 void andps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x54, 0x100, isXMM_XMMorMEM); }
bextr(const Reg32e & r1,const Operand & op,const Reg32e & r2)27 void bextr(const Reg32e& r1, const Operand& op, const Reg32e& r2) { opGpr(r1, op, r2, T_0F38, 0xf7, false); }
blendpd(const Xmm & xmm,const Operand & op,int imm)28 void blendpd(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x0D, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
blendps(const Xmm & xmm,const Operand & op,int imm)29 void blendps(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x0C, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
blendvpd(const Xmm & xmm,const Operand & op)30 void blendvpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x15, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
blendvps(const Xmm & xmm,const Operand & op)31 void blendvps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x14, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
blsi(const Reg32e & r,const Operand & op)32 void blsi(const Reg32e& r, const Operand& op) { opGpr(Reg32e(3, r.getBit()), op, r, T_0F38, 0xf3, false); }
blsmsk(const Reg32e & r,const Operand & op)33 void blsmsk(const Reg32e& r, const Operand& op) { opGpr(Reg32e(2, r.getBit()), op, r, T_0F38, 0xf3, false); }
blsr(const Reg32e & r,const Operand & op)34 void blsr(const Reg32e& r, const Operand& op) { opGpr(Reg32e(1, r.getBit()), op, r, T_0F38, 0xf3, false); }
bnd()35 void bnd() { db(0xF2); }
bndcl(const BoundsReg & bnd,const Operand & op)36 void bndcl(const BoundsReg& bnd, const Operand& op) { db(0xF3); opR_ModM(op, i32e, bnd.getIdx(), 0x0F, 0x1A, NONE, !op.isMEM()); }
bndcn(const BoundsReg & bnd,const Operand & op)37 void bndcn(const BoundsReg& bnd, const Operand& op) { db(0xF2); opR_ModM(op, i32e, bnd.getIdx(), 0x0F, 0x1B, NONE, !op.isMEM()); }
bndcu(const BoundsReg & bnd,const Operand & op)38 void bndcu(const BoundsReg& bnd, const Operand& op) { db(0xF2); opR_ModM(op, i32e, bnd.getIdx(), 0x0F, 0x1A, NONE, !op.isMEM()); }
bndldx(const BoundsReg & bnd,const Address & addr)39 void bndldx(const BoundsReg& bnd, const Address& addr) { opMIB(addr, bnd, 0x0F, 0x1A); }
bndmk(const BoundsReg & bnd,const Address & addr)40 void bndmk(const BoundsReg& bnd, const Address& addr) { db(0xF3); opModM(addr, bnd, 0x0F, 0x1B); }
bndmov(const Address & addr,const BoundsReg & bnd)41 void bndmov(const Address& addr, const BoundsReg& bnd) { db(0x66); opModM(addr, bnd, 0x0F, 0x1B); }
bndmov(const BoundsReg & bnd,const Operand & op)42 void bndmov(const BoundsReg& bnd, const Operand& op) { db(0x66); opModRM(bnd, op, op.isBNDREG(), op.isMEM(), 0x0F, 0x1A); }
bndstx(const Address & addr,const BoundsReg & bnd)43 void bndstx(const Address& addr, const BoundsReg& bnd) { opMIB(addr, bnd, 0x0F, 0x1B); }
bsf(const Reg & reg,const Operand & op)44 void bsf(const Reg&reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0xBC); }
bsr(const Reg & reg,const Operand & op)45 void bsr(const Reg&reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0xBD); }
bswap(const Reg32e & reg)46 void bswap(const Reg32e& reg) { opModR(Reg32(1), reg, 0x0F); }
bt(const Operand & op,const Reg & reg)47 void bt(const Operand& op, const Reg& reg) { opModRM(reg, op, op.isREG(16|32|64) && op.getBit() == reg.getBit(), op.isMEM(), 0x0f, 0xA3); }
bt(const Operand & op,uint8 imm)48 void bt(const Operand& op, uint8 imm) { opR_ModM(op, 16|32|64, 4, 0x0f, 0xba, NONE, false, 1); db(imm); }
btc(const Operand & op,const Reg & reg)49 void btc(const Operand& op, const Reg& reg) { opModRM(reg, op, op.isREG(16|32|64) && op.getBit() == reg.getBit(), op.isMEM(), 0x0f, 0xBB); }
btc(const Operand & op,uint8 imm)50 void btc(const Operand& op, uint8 imm) { opR_ModM(op, 16|32|64, 7, 0x0f, 0xba, NONE, false, 1); db(imm); }
btr(const Operand & op,const Reg & reg)51 void btr(const Operand& op, const Reg& reg) { opModRM(reg, op, op.isREG(16|32|64) && op.getBit() == reg.getBit(), op.isMEM(), 0x0f, 0xB3); }
btr(const Operand & op,uint8 imm)52 void btr(const Operand& op, uint8 imm) { opR_ModM(op, 16|32|64, 6, 0x0f, 0xba, NONE, false, 1); db(imm); }
bts(const Operand & op,const Reg & reg)53 void bts(const Operand& op, const Reg& reg) { opModRM(reg, op, op.isREG(16|32|64) && op.getBit() == reg.getBit(), op.isMEM(), 0x0f, 0xAB); }
bts(const Operand & op,uint8 imm)54 void bts(const Operand& op, uint8 imm) { opR_ModM(op, 16|32|64, 5, 0x0f, 0xba, NONE, false, 1); db(imm); }
bzhi(const Reg32e & r1,const Operand & op,const Reg32e & r2)55 void bzhi(const Reg32e& r1, const Operand& op, const Reg32e& r2) { opGpr(r1, op, r2, T_0F38, 0xf5, false); }
cbw()56 void cbw() { db(0x66); db(0x98); }
cdq()57 void cdq() { db(0x99); }
clc()58 void clc() { db(0xF8); }
cld()59 void cld() { db(0xFC); }
clflush(const Address & addr)60 void clflush(const Address& addr) { opModM(addr, Reg32(7), 0x0F, 0xAE); }
cli()61 void cli() { db(0xFA); }
cmc()62 void cmc() { db(0xF5); }
cmova(const Reg & reg,const Operand & op)63 void cmova(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 7); }//-V524
cmovae(const Reg & reg,const Operand & op)64 void cmovae(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 3); }//-V524
cmovb(const Reg & reg,const Operand & op)65 void cmovb(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 2); }//-V524
cmovbe(const Reg & reg,const Operand & op)66 void cmovbe(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 6); }//-V524
cmovc(const Reg & reg,const Operand & op)67 void cmovc(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 2); }//-V524
cmove(const Reg & reg,const Operand & op)68 void cmove(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 4); }//-V524
cmovg(const Reg & reg,const Operand & op)69 void cmovg(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 15); }//-V524
cmovge(const Reg & reg,const Operand & op)70 void cmovge(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 13); }//-V524
cmovl(const Reg & reg,const Operand & op)71 void cmovl(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 12); }//-V524
cmovle(const Reg & reg,const Operand & op)72 void cmovle(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 14); }//-V524
cmovna(const Reg & reg,const Operand & op)73 void cmovna(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 6); }//-V524
cmovnae(const Reg & reg,const Operand & op)74 void cmovnae(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 2); }//-V524
cmovnb(const Reg & reg,const Operand & op)75 void cmovnb(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 3); }//-V524
cmovnbe(const Reg & reg,const Operand & op)76 void cmovnbe(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 7); }//-V524
cmovnc(const Reg & reg,const Operand & op)77 void cmovnc(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 3); }//-V524
cmovne(const Reg & reg,const Operand & op)78 void cmovne(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 5); }//-V524
cmovng(const Reg & reg,const Operand & op)79 void cmovng(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 14); }//-V524
cmovnge(const Reg & reg,const Operand & op)80 void cmovnge(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 12); }//-V524
cmovnl(const Reg & reg,const Operand & op)81 void cmovnl(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 13); }//-V524
cmovnle(const Reg & reg,const Operand & op)82 void cmovnle(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 15); }//-V524
cmovno(const Reg & reg,const Operand & op)83 void cmovno(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 1); }//-V524
cmovnp(const Reg & reg,const Operand & op)84 void cmovnp(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 11); }//-V524
cmovns(const Reg & reg,const Operand & op)85 void cmovns(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 9); }//-V524
cmovnz(const Reg & reg,const Operand & op)86 void cmovnz(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 5); }//-V524
cmovo(const Reg & reg,const Operand & op)87 void cmovo(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 0); }//-V524
cmovp(const Reg & reg,const Operand & op)88 void cmovp(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 10); }//-V524
cmovpe(const Reg & reg,const Operand & op)89 void cmovpe(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 10); }//-V524
cmovpo(const Reg & reg,const Operand & op)90 void cmovpo(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 11); }//-V524
cmovs(const Reg & reg,const Operand & op)91 void cmovs(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 8); }//-V524
cmovz(const Reg & reg,const Operand & op)92 void cmovz(const Reg& reg, const Operand& op) { opModRM(reg, op, op.isREG(16 | i32e), op.isMEM(), 0x0F, 0x40 | 4); }//-V524
cmp(const Operand & op,uint32 imm)93 void cmp(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x38, 7); }
cmp(const Operand & op1,const Operand & op2)94 void cmp(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x38); }
cmpeqpd(const Xmm & x,const Operand & op)95 void cmpeqpd(const Xmm& x, const Operand& op) { cmppd(x, op, 0); }
cmpeqps(const Xmm & x,const Operand & op)96 void cmpeqps(const Xmm& x, const Operand& op) { cmpps(x, op, 0); }
cmpeqsd(const Xmm & x,const Operand & op)97 void cmpeqsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 0); }
cmpeqss(const Xmm & x,const Operand & op)98 void cmpeqss(const Xmm& x, const Operand& op) { cmpss(x, op, 0); }
cmplepd(const Xmm & x,const Operand & op)99 void cmplepd(const Xmm& x, const Operand& op) { cmppd(x, op, 2); }
cmpleps(const Xmm & x,const Operand & op)100 void cmpleps(const Xmm& x, const Operand& op) { cmpps(x, op, 2); }
cmplesd(const Xmm & x,const Operand & op)101 void cmplesd(const Xmm& x, const Operand& op) { cmpsd(x, op, 2); }
cmpless(const Xmm & x,const Operand & op)102 void cmpless(const Xmm& x, const Operand& op) { cmpss(x, op, 2); }
cmpltpd(const Xmm & x,const Operand & op)103 void cmpltpd(const Xmm& x, const Operand& op) { cmppd(x, op, 1); }
cmpltps(const Xmm & x,const Operand & op)104 void cmpltps(const Xmm& x, const Operand& op) { cmpps(x, op, 1); }
cmpltsd(const Xmm & x,const Operand & op)105 void cmpltsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 1); }
cmpltss(const Xmm & x,const Operand & op)106 void cmpltss(const Xmm& x, const Operand& op) { cmpss(x, op, 1); }
cmpneqpd(const Xmm & x,const Operand & op)107 void cmpneqpd(const Xmm& x, const Operand& op) { cmppd(x, op, 4); }
cmpneqps(const Xmm & x,const Operand & op)108 void cmpneqps(const Xmm& x, const Operand& op) { cmpps(x, op, 4); }
cmpneqsd(const Xmm & x,const Operand & op)109 void cmpneqsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 4); }
cmpneqss(const Xmm & x,const Operand & op)110 void cmpneqss(const Xmm& x, const Operand& op) { cmpss(x, op, 4); }
cmpnlepd(const Xmm & x,const Operand & op)111 void cmpnlepd(const Xmm& x, const Operand& op) { cmppd(x, op, 6); }
cmpnleps(const Xmm & x,const Operand & op)112 void cmpnleps(const Xmm& x, const Operand& op) { cmpps(x, op, 6); }
cmpnlesd(const Xmm & x,const Operand & op)113 void cmpnlesd(const Xmm& x, const Operand& op) { cmpsd(x, op, 6); }
cmpnless(const Xmm & x,const Operand & op)114 void cmpnless(const Xmm& x, const Operand& op) { cmpss(x, op, 6); }
cmpnltpd(const Xmm & x,const Operand & op)115 void cmpnltpd(const Xmm& x, const Operand& op) { cmppd(x, op, 5); }
cmpnltps(const Xmm & x,const Operand & op)116 void cmpnltps(const Xmm& x, const Operand& op) { cmpps(x, op, 5); }
cmpnltsd(const Xmm & x,const Operand & op)117 void cmpnltsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 5); }
cmpnltss(const Xmm & x,const Operand & op)118 void cmpnltss(const Xmm& x, const Operand& op) { cmpss(x, op, 5); }
cmpordpd(const Xmm & x,const Operand & op)119 void cmpordpd(const Xmm& x, const Operand& op) { cmppd(x, op, 7); }
cmpordps(const Xmm & x,const Operand & op)120 void cmpordps(const Xmm& x, const Operand& op) { cmpps(x, op, 7); }
cmpordsd(const Xmm & x,const Operand & op)121 void cmpordsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 7); }
cmpordss(const Xmm & x,const Operand & op)122 void cmpordss(const Xmm& x, const Operand& op) { cmpss(x, op, 7); }
cmppd(const Xmm & xmm,const Operand & op,uint8 imm8)123 void cmppd(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC2, 0x66, isXMM_XMMorMEM, imm8); }
cmpps(const Xmm & xmm,const Operand & op,uint8 imm8)124 void cmpps(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC2, 0x100, isXMM_XMMorMEM, imm8); }
cmpsb()125 void cmpsb() { db(0xA6); }
cmpsd()126 void cmpsd() { db(0xA7); }
cmpsd(const Xmm & xmm,const Operand & op,uint8 imm8)127 void cmpsd(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC2, 0xF2, isXMM_XMMorMEM, imm8); }
cmpss(const Xmm & xmm,const Operand & op,uint8 imm8)128 void cmpss(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC2, 0xF3, isXMM_XMMorMEM, imm8); }
cmpsw()129 void cmpsw() { db(0x66); db(0xA7); }
cmpunordpd(const Xmm & x,const Operand & op)130 void cmpunordpd(const Xmm& x, const Operand& op) { cmppd(x, op, 3); }
cmpunordps(const Xmm & x,const Operand & op)131 void cmpunordps(const Xmm& x, const Operand& op) { cmpps(x, op, 3); }
cmpunordsd(const Xmm & x,const Operand & op)132 void cmpunordsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 3); }
cmpunordss(const Xmm & x,const Operand & op)133 void cmpunordss(const Xmm& x, const Operand& op) { cmpss(x, op, 3); }
cmpxchg(const Operand & op,const Reg & reg)134 void cmpxchg(const Operand& op, const Reg& reg) { opModRM(reg, op, (op.isREG() && reg.isREG() && op.getBit() == reg.getBit()), op.isMEM(), 0x0F, 0xB0 | (reg.isBit(8) ? 0 : 1)); }
cmpxchg8b(const Address & addr)135 void cmpxchg8b(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0xC7); }
comisd(const Xmm & xmm,const Operand & op)136 void comisd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2F, 0x66, isXMM_XMMorMEM); }
comiss(const Xmm & xmm,const Operand & op)137 void comiss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2F, 0x100, isXMM_XMMorMEM); }
cpuid()138 void cpuid() { db(0x0F); db(0xA2); }
crc32(const Reg32e & reg,const Operand & op)139 void crc32(const Reg32e& reg, const Operand& op) { if (reg.isBit(32) && op.isBit(16)) db(0x66); db(0xF2); opModRM(reg, op, op.isREG(), op.isMEM(), 0x0F, 0x38, 0xF0 | (op.isBit(8) ? 0 : 1)); }
cvtdq2pd(const Xmm & xmm,const Operand & op)140 void cvtdq2pd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xE6, 0xF3, isXMM_XMMorMEM); }
cvtdq2ps(const Xmm & xmm,const Operand & op)141 void cvtdq2ps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5B, 0x100, isXMM_XMMorMEM); }
cvtpd2dq(const Xmm & xmm,const Operand & op)142 void cvtpd2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xE6, 0xF2, isXMM_XMMorMEM); }
cvtpd2pi(const Operand & reg,const Operand & op)143 void cvtpd2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0x66, isMMX_XMMorMEM); }
cvtpd2ps(const Xmm & xmm,const Operand & op)144 void cvtpd2ps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0x66, isXMM_XMMorMEM); }
cvtpi2pd(const Operand & reg,const Operand & op)145 void cvtpi2pd(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0x66, isXMM_MMXorMEM); }
cvtpi2ps(const Operand & reg,const Operand & op)146 void cvtpi2ps(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0x100, isXMM_MMXorMEM); }
cvtps2dq(const Xmm & xmm,const Operand & op)147 void cvtps2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5B, 0x66, isXMM_XMMorMEM); }
cvtps2pd(const Xmm & xmm,const Operand & op)148 void cvtps2pd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0x100, isXMM_XMMorMEM); }
cvtps2pi(const Operand & reg,const Operand & op)149 void cvtps2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0x100, isMMX_XMMorMEM); }
cvtsd2si(const Operand & reg,const Operand & op)150 void cvtsd2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0xF2, isREG32_XMMorMEM); }
cvtsd2ss(const Xmm & xmm,const Operand & op)151 void cvtsd2ss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0xF2, isXMM_XMMorMEM); }
cvtsi2sd(const Operand & reg,const Operand & op)152 void cvtsi2sd(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0xF2, isXMM_REG32orMEM); }
cvtsi2ss(const Operand & reg,const Operand & op)153 void cvtsi2ss(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0xF3, isXMM_REG32orMEM); }
cvtss2sd(const Xmm & xmm,const Operand & op)154 void cvtss2sd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0xF3, isXMM_XMMorMEM); }
cvtss2si(const Operand & reg,const Operand & op)155 void cvtss2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0xF3, isREG32_XMMorMEM); }
cvttpd2dq(const Xmm & xmm,const Operand & op)156 void cvttpd2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xE6, 0x66, isXMM_XMMorMEM); }
cvttpd2pi(const Operand & reg,const Operand & op)157 void cvttpd2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0x66, isMMX_XMMorMEM); }
cvttps2dq(const Xmm & xmm,const Operand & op)158 void cvttps2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5B, 0xF3, isXMM_XMMorMEM); }
cvttps2pi(const Operand & reg,const Operand & op)159 void cvttps2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0x100, isMMX_XMMorMEM); }
cvttsd2si(const Operand & reg,const Operand & op)160 void cvttsd2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0xF2, isREG32_XMMorMEM); }
cvttss2si(const Operand & reg,const Operand & op)161 void cvttss2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0xF3, isREG32_XMMorMEM); }
cwd()162 void cwd() { db(0x66); db(0x99); }
cwde()163 void cwde() { db(0x98); }
dec(const Operand & op)164 void dec(const Operand& op) { opIncDec(op, 0x48, 1); }
div(const Operand & op)165 void div(const Operand& op) { opR_ModM(op, 0, 6, 0xF6); }
divpd(const Xmm & xmm,const Operand & op)166 void divpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0x66, isXMM_XMMorMEM); }
divps(const Xmm & xmm,const Operand & op)167 void divps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0x100, isXMM_XMMorMEM); }
divsd(const Xmm & xmm,const Operand & op)168 void divsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0xF2, isXMM_XMMorMEM); }
divss(const Xmm & xmm,const Operand & op)169 void divss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0xF3, isXMM_XMMorMEM); }
dppd(const Xmm & xmm,const Operand & op,int imm)170 void dppd(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x41, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
dpps(const Xmm & xmm,const Operand & op,int imm)171 void dpps(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x40, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
emms()172 void emms() { db(0x0F); db(0x77); }
extractps(const Operand & op,const Xmm & xmm,uint8 imm)173 void extractps(const Operand& op, const Xmm& xmm, uint8 imm) { opExt(op, xmm, 0x17, imm); }
f2xm1()174 void f2xm1() { db(0xD9); db(0xF0); }
fabs()175 void fabs() { db(0xD9); db(0xE1); }
fadd(const Address & addr)176 void fadd(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 0, 0); }
fadd(const Fpu & reg1)177 void fadd(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8C0, 0xDCC0); }
fadd(const Fpu & reg1,const Fpu & reg2)178 void fadd(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8C0, 0xDCC0); }
faddp()179 void faddp() { db(0xDE); db(0xC1); }
faddp(const Fpu & reg1)180 void faddp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEC0); }
faddp(const Fpu & reg1,const Fpu & reg2)181 void faddp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEC0); }
fchs()182 void fchs() { db(0xD9); db(0xE0); }
fcmovb(const Fpu & reg1)183 void fcmovb(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAC0, 0x00C0); }
fcmovb(const Fpu & reg1,const Fpu & reg2)184 void fcmovb(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAC0, 0x00C0); }
fcmovbe(const Fpu & reg1)185 void fcmovbe(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAD0, 0x00D0); }
fcmovbe(const Fpu & reg1,const Fpu & reg2)186 void fcmovbe(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAD0, 0x00D0); }
fcmove(const Fpu & reg1)187 void fcmove(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAC8, 0x00C8); }
fcmove(const Fpu & reg1,const Fpu & reg2)188 void fcmove(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAC8, 0x00C8); }
fcmovnb(const Fpu & reg1)189 void fcmovnb(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBC0, 0x00C0); }
fcmovnb(const Fpu & reg1,const Fpu & reg2)190 void fcmovnb(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBC0, 0x00C0); }
fcmovnbe(const Fpu & reg1)191 void fcmovnbe(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBD0, 0x00D0); }
fcmovnbe(const Fpu & reg1,const Fpu & reg2)192 void fcmovnbe(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBD0, 0x00D0); }
fcmovne(const Fpu & reg1)193 void fcmovne(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBC8, 0x00C8); }
fcmovne(const Fpu & reg1,const Fpu & reg2)194 void fcmovne(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBC8, 0x00C8); }
fcmovnu(const Fpu & reg1)195 void fcmovnu(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBD8, 0x00D8); }
fcmovnu(const Fpu & reg1,const Fpu & reg2)196 void fcmovnu(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBD8, 0x00D8); }
fcmovu(const Fpu & reg1)197 void fcmovu(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAD8, 0x00D8); }
fcmovu(const Fpu & reg1,const Fpu & reg2)198 void fcmovu(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAD8, 0x00D8); }
fcom()199 void fcom() { db(0xD8); db(0xD1); }
fcom(const Address & addr)200 void fcom(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 2, 0); }
fcom(const Fpu & reg)201 void fcom(const Fpu& reg) { opFpu(reg, 0xD8, 0xD0); }
fcomi(const Fpu & reg1)202 void fcomi(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBF0, 0x00F0); }
fcomi(const Fpu & reg1,const Fpu & reg2)203 void fcomi(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBF0, 0x00F0); }
fcomip(const Fpu & reg1)204 void fcomip(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDFF0, 0x00F0); }
fcomip(const Fpu & reg1,const Fpu & reg2)205 void fcomip(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDFF0, 0x00F0); }
fcomp()206 void fcomp() { db(0xD8); db(0xD9); }
fcomp(const Address & addr)207 void fcomp(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 3, 0); }
fcomp(const Fpu & reg)208 void fcomp(const Fpu& reg) { opFpu(reg, 0xD8, 0xD8); }
fcompp()209 void fcompp() { db(0xDE); db(0xD9); }
fcos()210 void fcos() { db(0xD9); db(0xFF); }
fdecstp()211 void fdecstp() { db(0xD9); db(0xF6); }
fdiv(const Address & addr)212 void fdiv(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 6, 0); }
fdiv(const Fpu & reg1)213 void fdiv(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8F0, 0xDCF8); }
fdiv(const Fpu & reg1,const Fpu & reg2)214 void fdiv(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8F0, 0xDCF8); }
fdivp()215 void fdivp() { db(0xDE); db(0xF9); }
fdivp(const Fpu & reg1)216 void fdivp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEF8); }
fdivp(const Fpu & reg1,const Fpu & reg2)217 void fdivp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEF8); }
fdivr(const Address & addr)218 void fdivr(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 7, 0); }
fdivr(const Fpu & reg1)219 void fdivr(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8F8, 0xDCF0); }
fdivr(const Fpu & reg1,const Fpu & reg2)220 void fdivr(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8F8, 0xDCF0); }
fdivrp()221 void fdivrp() { db(0xDE); db(0xF1); }
fdivrp(const Fpu & reg1)222 void fdivrp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEF0); }
fdivrp(const Fpu & reg1,const Fpu & reg2)223 void fdivrp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEF0); }
ffree(const Fpu & reg)224 void ffree(const Fpu& reg) { opFpu(reg, 0xDD, 0xC0); }
fiadd(const Address & addr)225 void fiadd(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 0, 0); }
ficom(const Address & addr)226 void ficom(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 2, 0); }
ficomp(const Address & addr)227 void ficomp(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 3, 0); }
fidiv(const Address & addr)228 void fidiv(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 6, 0); }
fidivr(const Address & addr)229 void fidivr(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 7, 0); }
fild(const Address & addr)230 void fild(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0xDF, 0, 5); }
fimul(const Address & addr)231 void fimul(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 1, 0); }
fincstp()232 void fincstp() { db(0xD9); db(0xF7); }
finit()233 void finit() { db(0x9B); db(0xDB); db(0xE3); }
fist(const Address & addr)234 void fist(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0x00, 2, 0); }
fistp(const Address & addr)235 void fistp(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0xDF, 3, 7); }
fisttp(const Address & addr)236 void fisttp(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0xDD, 1, 0); }
fisub(const Address & addr)237 void fisub(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 4, 0); }
fisubr(const Address & addr)238 void fisubr(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 5, 0); }
fld(const Address & addr)239 void fld(const Address& addr) { opFpuMem(addr, 0x00, 0xD9, 0xDD, 0, 0); }
fld(const Fpu & reg)240 void fld(const Fpu& reg) { opFpu(reg, 0xD9, 0xC0); }
fld1()241 void fld1() { db(0xD9); db(0xE8); }
fldcw(const Address & addr)242 void fldcw(const Address& addr) { opModM(addr, Reg32(5), 0xD9, 0x100); }
fldl2e()243 void fldl2e() { db(0xD9); db(0xEA); }
fldl2t()244 void fldl2t() { db(0xD9); db(0xE9); }
fldlg2()245 void fldlg2() { db(0xD9); db(0xEC); }
fldln2()246 void fldln2() { db(0xD9); db(0xED); }
fldpi()247 void fldpi() { db(0xD9); db(0xEB); }
fldz()248 void fldz() { db(0xD9); db(0xEE); }
fmul(const Address & addr)249 void fmul(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 1, 0); }
fmul(const Fpu & reg1)250 void fmul(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8C8, 0xDCC8); }
fmul(const Fpu & reg1,const Fpu & reg2)251 void fmul(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8C8, 0xDCC8); }
fmulp()252 void fmulp() { db(0xDE); db(0xC9); }
fmulp(const Fpu & reg1)253 void fmulp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEC8); }
fmulp(const Fpu & reg1,const Fpu & reg2)254 void fmulp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEC8); }
fninit()255 void fninit() { db(0xDB); db(0xE3); }
fnop()256 void fnop() { db(0xD9); db(0xD0); }
fpatan()257 void fpatan() { db(0xD9); db(0xF3); }
fprem()258 void fprem() { db(0xD9); db(0xF8); }
fprem1()259 void fprem1() { db(0xD9); db(0xF5); }
fptan()260 void fptan() { db(0xD9); db(0xF2); }
frndint()261 void frndint() { db(0xD9); db(0xFC); }
fscale()262 void fscale() { db(0xD9); db(0xFD); }
fsin()263 void fsin() { db(0xD9); db(0xFE); }
fsincos()264 void fsincos() { db(0xD9); db(0xFB); }
fsqrt()265 void fsqrt() { db(0xD9); db(0xFA); }
fst(const Address & addr)266 void fst(const Address& addr) { opFpuMem(addr, 0x00, 0xD9, 0xDD, 2, 0); }
fst(const Fpu & reg)267 void fst(const Fpu& reg) { opFpu(reg, 0xDD, 0xD0); }
fstcw(const Address & addr)268 void fstcw(const Address& addr) { db(0x9B); opModM(addr, Reg32(7), 0xD9, NONE); }
fstp(const Address & addr)269 void fstp(const Address& addr) { opFpuMem(addr, 0x00, 0xD9, 0xDD, 3, 0); }
fstp(const Fpu & reg)270 void fstp(const Fpu& reg) { opFpu(reg, 0xDD, 0xD8); }
fsub(const Address & addr)271 void fsub(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 4, 0); }
fsub(const Fpu & reg1)272 void fsub(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8E0, 0xDCE8); }
fsub(const Fpu & reg1,const Fpu & reg2)273 void fsub(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8E0, 0xDCE8); }
fsubp()274 void fsubp() { db(0xDE); db(0xE9); }
fsubp(const Fpu & reg1)275 void fsubp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEE8); }
fsubp(const Fpu & reg1,const Fpu & reg2)276 void fsubp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEE8); }
fsubr(const Address & addr)277 void fsubr(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 5, 0); }
fsubr(const Fpu & reg1)278 void fsubr(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8E8, 0xDCE0); }
fsubr(const Fpu & reg1,const Fpu & reg2)279 void fsubr(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8E8, 0xDCE0); }
fsubrp()280 void fsubrp() { db(0xDE); db(0xE1); }
fsubrp(const Fpu & reg1)281 void fsubrp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEE0); }
fsubrp(const Fpu & reg1,const Fpu & reg2)282 void fsubrp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEE0); }
ftst()283 void ftst() { db(0xD9); db(0xE4); }
fucom()284 void fucom() { db(0xDD); db(0xE1); }
fucom(const Fpu & reg)285 void fucom(const Fpu& reg) { opFpu(reg, 0xDD, 0xE0); }
fucomi(const Fpu & reg1)286 void fucomi(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBE8, 0x00E8); }
fucomi(const Fpu & reg1,const Fpu & reg2)287 void fucomi(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBE8, 0x00E8); }
fucomip(const Fpu & reg1)288 void fucomip(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDFE8, 0x00E8); }
fucomip(const Fpu & reg1,const Fpu & reg2)289 void fucomip(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDFE8, 0x00E8); }
fucomp()290 void fucomp() { db(0xDD); db(0xE9); }
fucomp(const Fpu & reg)291 void fucomp(const Fpu& reg) { opFpu(reg, 0xDD, 0xE8); }
fucompp()292 void fucompp() { db(0xDA); db(0xE9); }
fwait()293 void fwait() { db(0x9B); }
fxam()294 void fxam() { db(0xD9); db(0xE5); }
fxch()295 void fxch() { db(0xD9); db(0xC9); }
fxch(const Fpu & reg)296 void fxch(const Fpu& reg) { opFpu(reg, 0xD9, 0xC8); }
fxtract()297 void fxtract() { db(0xD9); db(0xF4); }
fyl2x()298 void fyl2x() { db(0xD9); db(0xF1); }
fyl2xp1()299 void fyl2xp1() { db(0xD9); db(0xF9); }
gf2p8affineinvqb(const Xmm & xmm,const Operand & op,int imm)300 void gf2p8affineinvqb(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0xCF, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
gf2p8affineqb(const Xmm & xmm,const Operand & op,int imm)301 void gf2p8affineqb(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0xCE, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
gf2p8mulb(const Xmm & xmm,const Operand & op)302 void gf2p8mulb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCF, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
haddpd(const Xmm & xmm,const Operand & op)303 void haddpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7C, 0x66, isXMM_XMMorMEM); }
haddps(const Xmm & xmm,const Operand & op)304 void haddps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7C, 0xF2, isXMM_XMMorMEM); }
hsubpd(const Xmm & xmm,const Operand & op)305 void hsubpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7D, 0x66, isXMM_XMMorMEM); }
hsubps(const Xmm & xmm,const Operand & op)306 void hsubps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7D, 0xF2, isXMM_XMMorMEM); }
idiv(const Operand & op)307 void idiv(const Operand& op) { opR_ModM(op, 0, 7, 0xF6); }
imul(const Operand & op)308 void imul(const Operand& op) { opR_ModM(op, 0, 5, 0xF6); }
inc(const Operand & op)309 void inc(const Operand& op) { opIncDec(op, 0x40, 0); }
insertps(const Xmm & xmm,const Operand & op,uint8 imm)310 void insertps(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x21, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
311 void ja(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
312 void ja(const char *label, LabelType type = T_AUTO) { ja(std::string(label), type); }//-V524
ja(const void * addr)313 void ja(const void *addr) { opJmpAbs(addr, T_NEAR, 0x77, 0x87, 0x0F); }//-V524
314 void ja(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
315 void jae(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
316 void jae(const char *label, LabelType type = T_AUTO) { jae(std::string(label), type); }//-V524
jae(const void * addr)317 void jae(const void *addr) { opJmpAbs(addr, T_NEAR, 0x73, 0x83, 0x0F); }//-V524
318 void jae(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
319 void jb(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
320 void jb(const char *label, LabelType type = T_AUTO) { jb(std::string(label), type); }//-V524
jb(const void * addr)321 void jb(const void *addr) { opJmpAbs(addr, T_NEAR, 0x72, 0x82, 0x0F); }//-V524
322 void jb(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
323 void jbe(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
324 void jbe(const char *label, LabelType type = T_AUTO) { jbe(std::string(label), type); }//-V524
jbe(const void * addr)325 void jbe(const void *addr) { opJmpAbs(addr, T_NEAR, 0x76, 0x86, 0x0F); }//-V524
326 void jbe(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
327 void jc(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
328 void jc(const char *label, LabelType type = T_AUTO) { jc(std::string(label), type); }//-V524
jc(const void * addr)329 void jc(const void *addr) { opJmpAbs(addr, T_NEAR, 0x72, 0x82, 0x0F); }//-V524
330 void jc(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
331 void je(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
332 void je(const char *label, LabelType type = T_AUTO) { je(std::string(label), type); }//-V524
je(const void * addr)333 void je(const void *addr) { opJmpAbs(addr, T_NEAR, 0x74, 0x84, 0x0F); }//-V524
334 void je(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
335 void jg(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
336 void jg(const char *label, LabelType type = T_AUTO) { jg(std::string(label), type); }//-V524
jg(const void * addr)337 void jg(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7F, 0x8F, 0x0F); }//-V524
338 void jg(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
339 void jge(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
340 void jge(const char *label, LabelType type = T_AUTO) { jge(std::string(label), type); }//-V524
jge(const void * addr)341 void jge(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7D, 0x8D, 0x0F); }//-V524
342 void jge(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
343 void jl(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
344 void jl(const char *label, LabelType type = T_AUTO) { jl(std::string(label), type); }//-V524
jl(const void * addr)345 void jl(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7C, 0x8C, 0x0F); }//-V524
346 void jl(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
347 void jle(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
348 void jle(const char *label, LabelType type = T_AUTO) { jle(std::string(label), type); }//-V524
jle(const void * addr)349 void jle(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7E, 0x8E, 0x0F); }//-V524
350 void jle(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
351 void jna(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
352 void jna(const char *label, LabelType type = T_AUTO) { jna(std::string(label), type); }//-V524
jna(const void * addr)353 void jna(const void *addr) { opJmpAbs(addr, T_NEAR, 0x76, 0x86, 0x0F); }//-V524
354 void jna(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
355 void jnae(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
356 void jnae(const char *label, LabelType type = T_AUTO) { jnae(std::string(label), type); }//-V524
jnae(const void * addr)357 void jnae(const void *addr) { opJmpAbs(addr, T_NEAR, 0x72, 0x82, 0x0F); }//-V524
358 void jnae(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
359 void jnb(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
360 void jnb(const char *label, LabelType type = T_AUTO) { jnb(std::string(label), type); }//-V524
jnb(const void * addr)361 void jnb(const void *addr) { opJmpAbs(addr, T_NEAR, 0x73, 0x83, 0x0F); }//-V524
362 void jnb(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
363 void jnbe(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
364 void jnbe(const char *label, LabelType type = T_AUTO) { jnbe(std::string(label), type); }//-V524
jnbe(const void * addr)365 void jnbe(const void *addr) { opJmpAbs(addr, T_NEAR, 0x77, 0x87, 0x0F); }//-V524
366 void jnbe(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
367 void jnc(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
368 void jnc(const char *label, LabelType type = T_AUTO) { jnc(std::string(label), type); }//-V524
jnc(const void * addr)369 void jnc(const void *addr) { opJmpAbs(addr, T_NEAR, 0x73, 0x83, 0x0F); }//-V524
370 void jnc(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
371 void jne(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
372 void jne(const char *label, LabelType type = T_AUTO) { jne(std::string(label), type); }//-V524
jne(const void * addr)373 void jne(const void *addr) { opJmpAbs(addr, T_NEAR, 0x75, 0x85, 0x0F); }//-V524
374 void jne(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
375 void jng(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
376 void jng(const char *label, LabelType type = T_AUTO) { jng(std::string(label), type); }//-V524
jng(const void * addr)377 void jng(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7E, 0x8E, 0x0F); }//-V524
378 void jng(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
379 void jnge(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
380 void jnge(const char *label, LabelType type = T_AUTO) { jnge(std::string(label), type); }//-V524
jnge(const void * addr)381 void jnge(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7C, 0x8C, 0x0F); }//-V524
382 void jnge(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
383 void jnl(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
384 void jnl(const char *label, LabelType type = T_AUTO) { jnl(std::string(label), type); }//-V524
jnl(const void * addr)385 void jnl(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7D, 0x8D, 0x0F); }//-V524
386 void jnl(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
387 void jnle(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
388 void jnle(const char *label, LabelType type = T_AUTO) { jnle(std::string(label), type); }//-V524
jnle(const void * addr)389 void jnle(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7F, 0x8F, 0x0F); }//-V524
390 void jnle(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
391 void jno(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x71, 0x81, 0x0F); }//-V524
392 void jno(const char *label, LabelType type = T_AUTO) { jno(std::string(label), type); }//-V524
jno(const void * addr)393 void jno(const void *addr) { opJmpAbs(addr, T_NEAR, 0x71, 0x81, 0x0F); }//-V524
394 void jno(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x71, 0x81, 0x0F); }//-V524
395 void jnp(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
396 void jnp(const char *label, LabelType type = T_AUTO) { jnp(std::string(label), type); }//-V524
jnp(const void * addr)397 void jnp(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7B, 0x8B, 0x0F); }//-V524
398 void jnp(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
399 void jns(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x79, 0x89, 0x0F); }//-V524
400 void jns(const char *label, LabelType type = T_AUTO) { jns(std::string(label), type); }//-V524
jns(const void * addr)401 void jns(const void *addr) { opJmpAbs(addr, T_NEAR, 0x79, 0x89, 0x0F); }//-V524
402 void jns(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x79, 0x89, 0x0F); }//-V524
403 void jnz(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
404 void jnz(const char *label, LabelType type = T_AUTO) { jnz(std::string(label), type); }//-V524
jnz(const void * addr)405 void jnz(const void *addr) { opJmpAbs(addr, T_NEAR, 0x75, 0x85, 0x0F); }//-V524
406 void jnz(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
407 void jo(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x70, 0x80, 0x0F); }//-V524
408 void jo(const char *label, LabelType type = T_AUTO) { jo(std::string(label), type); }//-V524
jo(const void * addr)409 void jo(const void *addr) { opJmpAbs(addr, T_NEAR, 0x70, 0x80, 0x0F); }//-V524
410 void jo(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x70, 0x80, 0x0F); }//-V524
411 void jp(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
412 void jp(const char *label, LabelType type = T_AUTO) { jp(std::string(label), type); }//-V524
jp(const void * addr)413 void jp(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7A, 0x8A, 0x0F); }//-V524
414 void jp(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
415 void jpe(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
416 void jpe(const char *label, LabelType type = T_AUTO) { jpe(std::string(label), type); }//-V524
jpe(const void * addr)417 void jpe(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7A, 0x8A, 0x0F); }//-V524
418 void jpe(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
419 void jpo(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
420 void jpo(const char *label, LabelType type = T_AUTO) { jpo(std::string(label), type); }//-V524
jpo(const void * addr)421 void jpo(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7B, 0x8B, 0x0F); }//-V524
422 void jpo(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
423 void js(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x78, 0x88, 0x0F); }//-V524
424 void js(const char *label, LabelType type = T_AUTO) { js(std::string(label), type); }//-V524
js(const void * addr)425 void js(const void *addr) { opJmpAbs(addr, T_NEAR, 0x78, 0x88, 0x0F); }//-V524
426 void js(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x78, 0x88, 0x0F); }//-V524
427 void jz(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
428 void jz(const char *label, LabelType type = T_AUTO) { jz(std::string(label), type); }//-V524
jz(const void * addr)429 void jz(const void *addr) { opJmpAbs(addr, T_NEAR, 0x74, 0x84, 0x0F); }//-V524
430 void jz(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
lahf()431 void lahf() { db(0x9F); }
lddqu(const Xmm & xmm,const Address & addr)432 void lddqu(const Xmm& xmm, const Address& addr) { db(0xF2); opModM(addr, xmm, 0x0F, 0xF0); }
ldmxcsr(const Address & addr)433 void ldmxcsr(const Address& addr) { opModM(addr, Reg32(2), 0x0F, 0xAE); }
lea(const Reg & reg,const Address & addr)434 void lea(const Reg& reg, const Address& addr) { if (!reg.isBit(16 | i32e)) throw Error(ERR_BAD_SIZE_OF_REGISTER); opModM(addr, reg, 0x8D); }
lfence()435 void lfence() { db(0x0F); db(0xAE); db(0xE8); }
lock()436 void lock() { db(0xF0); }
lzcnt(const Reg & reg,const Operand & op)437 void lzcnt(const Reg&reg, const Operand& op) { opSp1(reg, op, 0xF3, 0x0F, 0xBD); }
maskmovdqu(const Xmm & reg1,const Xmm & reg2)438 void maskmovdqu(const Xmm& reg1, const Xmm& reg2) { db(0x66);  opModR(reg1, reg2, 0x0F, 0xF7); }
maskmovq(const Mmx & reg1,const Mmx & reg2)439 void maskmovq(const Mmx& reg1, const Mmx& reg2) { if (!reg1.isMMX() || !reg2.isMMX()) throw Error(ERR_BAD_COMBINATION); opModR(reg1, reg2, 0x0F, 0xF7); }
maxpd(const Xmm & xmm,const Operand & op)440 void maxpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0x66, isXMM_XMMorMEM); }
maxps(const Xmm & xmm,const Operand & op)441 void maxps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0x100, isXMM_XMMorMEM); }
maxsd(const Xmm & xmm,const Operand & op)442 void maxsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0xF2, isXMM_XMMorMEM); }
maxss(const Xmm & xmm,const Operand & op)443 void maxss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0xF3, isXMM_XMMorMEM); }
mfence()444 void mfence() { db(0x0F); db(0xAE); db(0xF0); }
minpd(const Xmm & xmm,const Operand & op)445 void minpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0x66, isXMM_XMMorMEM); }
minps(const Xmm & xmm,const Operand & op)446 void minps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0x100, isXMM_XMMorMEM); }
minsd(const Xmm & xmm,const Operand & op)447 void minsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0xF2, isXMM_XMMorMEM); }
minss(const Xmm & xmm,const Operand & op)448 void minss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0xF3, isXMM_XMMorMEM); }
monitor()449 void monitor() { db(0x0F); db(0x01); db(0xC8); }
movapd(const Address & addr,const Xmm & xmm)450 void movapd(const Address& addr, const Xmm& xmm) { db(0x66); opModM(addr, xmm, 0x0F, 0x29); }
movapd(const Xmm & xmm,const Operand & op)451 void movapd(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x28, 0x66); }
movaps(const Address & addr,const Xmm & xmm)452 void movaps(const Address& addr, const Xmm& xmm) { opModM(addr, xmm, 0x0F, 0x29); }
movaps(const Xmm & xmm,const Operand & op)453 void movaps(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x28, 0x100); }
movbe(const Address & addr,const Reg & reg)454 void movbe(const Address& addr, const Reg& reg) { opModM(addr, reg, 0x0F, 0x38, 0xF1); }
movbe(const Reg & reg,const Address & addr)455 void movbe(const Reg& reg, const Address& addr) { opModM(addr, reg, 0x0F, 0x38, 0xF0); }
movd(const Address & addr,const Mmx & mmx)456 void movd(const Address& addr, const Mmx& mmx) { if (mmx.isXMM()) db(0x66); opModM(addr, mmx, 0x0F, 0x7E); }
movd(const Mmx & mmx,const Address & addr)457 void movd(const Mmx& mmx, const Address& addr) { if (mmx.isXMM()) db(0x66); opModM(addr, mmx, 0x0F, 0x6E); }
movd(const Mmx & mmx,const Reg32 & reg)458 void movd(const Mmx& mmx, const Reg32& reg) { if (mmx.isXMM()) db(0x66); opModR(mmx, reg, 0x0F, 0x6E); }
movd(const Reg32 & reg,const Mmx & mmx)459 void movd(const Reg32& reg, const Mmx& mmx) { if (mmx.isXMM()) db(0x66); opModR(mmx, reg, 0x0F, 0x7E); }
movddup(const Xmm & xmm,const Operand & op)460 void movddup(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x12, 0xF2, isXMM_XMMorMEM, NONE, NONE); }
movdq2q(const Mmx & mmx,const Xmm & xmm)461 void movdq2q(const Mmx& mmx, const Xmm& xmm) { db(0xF2); opModR(mmx, xmm, 0x0F, 0xD6); }
movdqa(const Address & addr,const Xmm & xmm)462 void movdqa(const Address& addr, const Xmm& xmm) { db(0x66); opModM(addr, xmm, 0x0F, 0x7F); }
movdqa(const Xmm & xmm,const Operand & op)463 void movdqa(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x6F, 0x66); }
movdqu(const Address & addr,const Xmm & xmm)464 void movdqu(const Address& addr, const Xmm& xmm) { db(0xF3); opModM(addr, xmm, 0x0F, 0x7F); }
movdqu(const Xmm & xmm,const Operand & op)465 void movdqu(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x6F, 0xF3); }
movhlps(const Xmm & reg1,const Xmm & reg2)466 void movhlps(const Xmm& reg1, const Xmm& reg2) {  opModR(reg1, reg2, 0x0F, 0x12); }
movhpd(const Operand & op1,const Operand & op2)467 void movhpd(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x16, 0x66); }
movhps(const Operand & op1,const Operand & op2)468 void movhps(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x16, 0x100); }
movlhps(const Xmm & reg1,const Xmm & reg2)469 void movlhps(const Xmm& reg1, const Xmm& reg2) {  opModR(reg1, reg2, 0x0F, 0x16); }
movlpd(const Operand & op1,const Operand & op2)470 void movlpd(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x12, 0x66); }
movlps(const Operand & op1,const Operand & op2)471 void movlps(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x12, 0x100); }
movmskpd(const Reg32e & reg,const Xmm & xmm)472 void movmskpd(const Reg32e& reg, const Xmm& xmm) { db(0x66); movmskps(reg, xmm); }
movmskps(const Reg32e & reg,const Xmm & xmm)473 void movmskps(const Reg32e& reg, const Xmm& xmm) { opModR(reg, xmm, 0x0F, 0x50); }
movntdq(const Address & addr,const Xmm & reg)474 void movntdq(const Address& addr, const Xmm& reg) { opModM(addr, Reg16(reg.getIdx()), 0x0F, 0xE7); }
movntdqa(const Xmm & xmm,const Address & addr)475 void movntdqa(const Xmm& xmm, const Address& addr) { db(0x66); opModM(addr, xmm, 0x0F, 0x38, 0x2A); }
movnti(const Address & addr,const Reg32e & reg)476 void movnti(const Address& addr, const Reg32e& reg) { opModM(addr, reg, 0x0F, 0xC3); }
movntpd(const Address & addr,const Xmm & reg)477 void movntpd(const Address& addr, const Xmm& reg) { opModM(addr, Reg16(reg.getIdx()), 0x0F, 0x2B); }
movntps(const Address & addr,const Xmm & xmm)478 void movntps(const Address& addr, const Xmm& xmm) { opModM(addr, Mmx(xmm.getIdx()), 0x0F, 0x2B); }
movntq(const Address & addr,const Mmx & mmx)479 void movntq(const Address& addr, const Mmx& mmx) { if (!mmx.isMMX()) throw Error(ERR_BAD_COMBINATION); opModM(addr, mmx, 0x0F, 0xE7); }
movq(const Address & addr,const Mmx & mmx)480 void movq(const Address& addr, const Mmx& mmx) { if (mmx.isXMM()) db(0x66); opModM(addr, mmx, 0x0F, mmx.isXMM() ? 0xD6 : 0x7F); }
movq(const Mmx & mmx,const Operand & op)481 void movq(const Mmx& mmx, const Operand& op) { if (mmx.isXMM()) db(0xF3); opModRM(mmx, op, (mmx.getKind() == op.getKind()), op.isMEM(), 0x0F, mmx.isXMM() ? 0x7E : 0x6F); }
movq2dq(const Xmm & xmm,const Mmx & mmx)482 void movq2dq(const Xmm& xmm, const Mmx& mmx) { db(0xF3); opModR(xmm, mmx, 0x0F, 0xD6); }
movsb()483 void movsb() { db(0xA4); }
movsd()484 void movsd() { db(0xA5); }
movsd(const Address & addr,const Xmm & xmm)485 void movsd(const Address& addr, const Xmm& xmm) { db(0xF2); opModM(addr, xmm, 0x0F, 0x11); }
movsd(const Xmm & xmm,const Operand & op)486 void movsd(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0xF2); }
movshdup(const Xmm & xmm,const Operand & op)487 void movshdup(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x16, 0xF3, isXMM_XMMorMEM, NONE, NONE); }
movsldup(const Xmm & xmm,const Operand & op)488 void movsldup(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x12, 0xF3, isXMM_XMMorMEM, NONE, NONE); }
movss(const Address & addr,const Xmm & xmm)489 void movss(const Address& addr, const Xmm& xmm) { db(0xF3); opModM(addr, xmm, 0x0F, 0x11); }
movss(const Xmm & xmm,const Operand & op)490 void movss(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0xF3); }
movsw()491 void movsw() { db(0x66); db(0xA5); }
movsx(const Reg & reg,const Operand & op)492 void movsx(const Reg& reg, const Operand& op) { opMovxx(reg, op, 0xBE); }
movupd(const Address & addr,const Xmm & xmm)493 void movupd(const Address& addr, const Xmm& xmm) { db(0x66); opModM(addr, xmm, 0x0F, 0x11); }
movupd(const Xmm & xmm,const Operand & op)494 void movupd(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0x66); }
movups(const Address & addr,const Xmm & xmm)495 void movups(const Address& addr, const Xmm& xmm) { opModM(addr, xmm, 0x0F, 0x11); }
movups(const Xmm & xmm,const Operand & op)496 void movups(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0x100); }
movzx(const Reg & reg,const Operand & op)497 void movzx(const Reg& reg, const Operand& op) { opMovxx(reg, op, 0xB6); }
mpsadbw(const Xmm & xmm,const Operand & op,int imm)498 void mpsadbw(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x42, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
mul(const Operand & op)499 void mul(const Operand& op) { opR_ModM(op, 0, 4, 0xF6); }
mulpd(const Xmm & xmm,const Operand & op)500 void mulpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0x66, isXMM_XMMorMEM); }
mulps(const Xmm & xmm,const Operand & op)501 void mulps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0x100, isXMM_XMMorMEM); }
mulsd(const Xmm & xmm,const Operand & op)502 void mulsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0xF2, isXMM_XMMorMEM); }
mulss(const Xmm & xmm,const Operand & op)503 void mulss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0xF3, isXMM_XMMorMEM); }
mulx(const Reg32e & r1,const Reg32e & r2,const Operand & op)504 void mulx(const Reg32e& r1, const Reg32e& r2, const Operand& op) { opGpr(r1, r2, op, T_F2 | T_0F38, 0xf6, true); }
mwait()505 void mwait() { db(0x0F); db(0x01); db(0xC9); }
neg(const Operand & op)506 void neg(const Operand& op) { opR_ModM(op, 0, 3, 0xF6); }
not_(const Operand & op)507 void not_(const Operand& op) { opR_ModM(op, 0, 2, 0xF6); }
or_(const Operand & op,uint32 imm)508 void or_(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x08, 1); }
or_(const Operand & op1,const Operand & op2)509 void or_(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x08); }
orpd(const Xmm & xmm,const Operand & op)510 void orpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x56, 0x66, isXMM_XMMorMEM); }
orps(const Xmm & xmm,const Operand & op)511 void orps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x56, 0x100, isXMM_XMMorMEM); }
pabsb(const Mmx & mmx,const Operand & op)512 void pabsb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x1C, 0x66, NONE, 0x38); }
pabsd(const Mmx & mmx,const Operand & op)513 void pabsd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x1E, 0x66, NONE, 0x38); }
pabsw(const Mmx & mmx,const Operand & op)514 void pabsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x1D, 0x66, NONE, 0x38); }
packssdw(const Mmx & mmx,const Operand & op)515 void packssdw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x6B); }
packsswb(const Mmx & mmx,const Operand & op)516 void packsswb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x63); }
packusdw(const Xmm & xmm,const Operand & op)517 void packusdw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2B, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
packuswb(const Mmx & mmx,const Operand & op)518 void packuswb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x67); }
paddb(const Mmx & mmx,const Operand & op)519 void paddb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFC); }
paddd(const Mmx & mmx,const Operand & op)520 void paddd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFE); }
paddq(const Mmx & mmx,const Operand & op)521 void paddq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD4); }
paddsb(const Mmx & mmx,const Operand & op)522 void paddsb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEC); }
paddsw(const Mmx & mmx,const Operand & op)523 void paddsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xED); }
paddusb(const Mmx & mmx,const Operand & op)524 void paddusb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDC); }
paddusw(const Mmx & mmx,const Operand & op)525 void paddusw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDD); }
paddw(const Mmx & mmx,const Operand & op)526 void paddw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFD); }
palignr(const Mmx & mmx,const Operand & op,int imm)527 void palignr(const Mmx& mmx, const Operand& op, int imm) { opMMX(mmx, op, 0x0f, 0x66, static_cast<uint8>(imm), 0x3a); }
pand(const Mmx & mmx,const Operand & op)528 void pand(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDB); }
pandn(const Mmx & mmx,const Operand & op)529 void pandn(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDF); }
pause()530 void pause() { db(0xF3); db(0x90); }
pavgb(const Mmx & mmx,const Operand & op)531 void pavgb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE0); }
pavgw(const Mmx & mmx,const Operand & op)532 void pavgw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE3); }
pblendvb(const Xmm & xmm,const Operand & op)533 void pblendvb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x10, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pblendw(const Xmm & xmm,const Operand & op,int imm)534 void pblendw(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x0E, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
pclmulhqhdq(const Xmm & xmm,const Operand & op)535 void pclmulhqhdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x11); }
pclmulhqlqdq(const Xmm & xmm,const Operand & op)536 void pclmulhqlqdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x01); }
pclmullqhdq(const Xmm & xmm,const Operand & op)537 void pclmullqhdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x10); }
pclmullqlqdq(const Xmm & xmm,const Operand & op)538 void pclmullqlqdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x00); }
pclmulqdq(const Xmm & xmm,const Operand & op,int imm)539 void pclmulqdq(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x44, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
pcmpeqb(const Mmx & mmx,const Operand & op)540 void pcmpeqb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x74); }
pcmpeqd(const Mmx & mmx,const Operand & op)541 void pcmpeqd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x76); }
pcmpeqq(const Xmm & xmm,const Operand & op)542 void pcmpeqq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x29, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pcmpeqw(const Mmx & mmx,const Operand & op)543 void pcmpeqw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x75); }
pcmpestri(const Xmm & xmm,const Operand & op,uint8 imm)544 void pcmpestri(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x61, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
pcmpestrm(const Xmm & xmm,const Operand & op,uint8 imm)545 void pcmpestrm(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x60, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
pcmpgtb(const Mmx & mmx,const Operand & op)546 void pcmpgtb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x64); }
pcmpgtd(const Mmx & mmx,const Operand & op)547 void pcmpgtd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x66); }
pcmpgtq(const Xmm & xmm,const Operand & op)548 void pcmpgtq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x37, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pcmpgtw(const Mmx & mmx,const Operand & op)549 void pcmpgtw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x65); }
pcmpistri(const Xmm & xmm,const Operand & op,uint8 imm)550 void pcmpistri(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x63, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
pcmpistrm(const Xmm & xmm,const Operand & op,uint8 imm)551 void pcmpistrm(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x62, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
pdep(const Reg32e & r1,const Reg32e & r2,const Operand & op)552 void pdep(const Reg32e& r1, const Reg32e& r2, const Operand& op) { opGpr(r1, r2, op, T_F2 | T_0F38, 0xf5, true); }
pext(const Reg32e & r1,const Reg32e & r2,const Operand & op)553 void pext(const Reg32e& r1, const Reg32e& r2, const Operand& op) { opGpr(r1, r2, op, T_F3 | T_0F38, 0xf5, true); }
pextrb(const Operand & op,const Xmm & xmm,uint8 imm)554 void pextrb(const Operand& op, const Xmm& xmm, uint8 imm) { opExt(op, xmm, 0x14, imm); }
pextrd(const Operand & op,const Xmm & xmm,uint8 imm)555 void pextrd(const Operand& op, const Xmm& xmm, uint8 imm) { opExt(op, xmm, 0x16, imm); }
pextrw(const Operand & op,const Mmx & xmm,uint8 imm)556 void pextrw(const Operand& op, const Mmx& xmm, uint8 imm) { opExt(op, xmm, 0x15, imm, true); }
phaddd(const Mmx & mmx,const Operand & op)557 void phaddd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x02, 0x66, NONE, 0x38); }
phaddsw(const Mmx & mmx,const Operand & op)558 void phaddsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x03, 0x66, NONE, 0x38); }
phaddw(const Mmx & mmx,const Operand & op)559 void phaddw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x01, 0x66, NONE, 0x38); }
phminposuw(const Xmm & xmm,const Operand & op)560 void phminposuw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x41, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
phsubd(const Mmx & mmx,const Operand & op)561 void phsubd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x06, 0x66, NONE, 0x38); }
phsubsw(const Mmx & mmx,const Operand & op)562 void phsubsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x07, 0x66, NONE, 0x38); }
phsubw(const Mmx & mmx,const Operand & op)563 void phsubw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x05, 0x66, NONE, 0x38); }
pinsrb(const Xmm & xmm,const Operand & op,uint8 imm)564 void pinsrb(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x20, 0x66, isXMM_REG32orMEM, imm, 0x3A); }
pinsrd(const Xmm & xmm,const Operand & op,uint8 imm)565 void pinsrd(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x22, 0x66, isXMM_REG32orMEM, imm, 0x3A); }
pinsrw(const Mmx & mmx,const Operand & op,int imm)566 void pinsrw(const Mmx& mmx, const Operand& op, int imm) { if (!op.isREG(32) && !op.isMEM()) throw Error(ERR_BAD_COMBINATION); opGen(mmx, op, 0xC4, mmx.isXMM() ? 0x66 : NONE, 0, imm); }
pmaddubsw(const Mmx & mmx,const Operand & op)567 void pmaddubsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x04, 0x66, NONE, 0x38); }
pmaddwd(const Mmx & mmx,const Operand & op)568 void pmaddwd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF5); }
pmaxsb(const Xmm & xmm,const Operand & op)569 void pmaxsb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3C, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmaxsd(const Xmm & xmm,const Operand & op)570 void pmaxsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3D, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmaxsw(const Mmx & mmx,const Operand & op)571 void pmaxsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEE); }
pmaxub(const Mmx & mmx,const Operand & op)572 void pmaxub(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDE); }
pmaxud(const Xmm & xmm,const Operand & op)573 void pmaxud(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3F, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmaxuw(const Xmm & xmm,const Operand & op)574 void pmaxuw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3E, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminsb(const Xmm & xmm,const Operand & op)575 void pminsb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x38, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminsd(const Xmm & xmm,const Operand & op)576 void pminsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x39, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminsw(const Mmx & mmx,const Operand & op)577 void pminsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEA); }
pminub(const Mmx & mmx,const Operand & op)578 void pminub(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDA); }
pminud(const Xmm & xmm,const Operand & op)579 void pminud(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3B, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminuw(const Xmm & xmm,const Operand & op)580 void pminuw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3A, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovmskb(const Reg32e & reg,const Mmx & mmx)581 void pmovmskb(const Reg32e& reg, const Mmx& mmx) { if (mmx.isXMM()) db(0x66); opModR(reg, mmx, 0x0F, 0xD7); }
pmovsxbd(const Xmm & xmm,const Operand & op)582 void pmovsxbd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x21, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxbq(const Xmm & xmm,const Operand & op)583 void pmovsxbq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x22, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxbw(const Xmm & xmm,const Operand & op)584 void pmovsxbw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x20, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxdq(const Xmm & xmm,const Operand & op)585 void pmovsxdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x25, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxwd(const Xmm & xmm,const Operand & op)586 void pmovsxwd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x23, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxwq(const Xmm & xmm,const Operand & op)587 void pmovsxwq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x24, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxbd(const Xmm & xmm,const Operand & op)588 void pmovzxbd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x31, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxbq(const Xmm & xmm,const Operand & op)589 void pmovzxbq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x32, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxbw(const Xmm & xmm,const Operand & op)590 void pmovzxbw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x30, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxdq(const Xmm & xmm,const Operand & op)591 void pmovzxdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x35, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxwd(const Xmm & xmm,const Operand & op)592 void pmovzxwd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x33, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxwq(const Xmm & xmm,const Operand & op)593 void pmovzxwq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x34, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmuldq(const Xmm & xmm,const Operand & op)594 void pmuldq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x28, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmulhrsw(const Mmx & mmx,const Operand & op)595 void pmulhrsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x0B, 0x66, NONE, 0x38); }
pmulhuw(const Mmx & mmx,const Operand & op)596 void pmulhuw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE4); }
pmulhw(const Mmx & mmx,const Operand & op)597 void pmulhw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE5); }
pmulld(const Xmm & xmm,const Operand & op)598 void pmulld(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x40, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmullw(const Mmx & mmx,const Operand & op)599 void pmullw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD5); }
pmuludq(const Mmx & mmx,const Operand & op)600 void pmuludq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF4); }
popcnt(const Reg & reg,const Operand & op)601 void popcnt(const Reg&reg, const Operand& op) { opSp1(reg, op, 0xF3, 0x0F, 0xB8); }
popf()602 void popf() { db(0x9D); }
por(const Mmx & mmx,const Operand & op)603 void por(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEB); }
prefetchnta(const Address & addr)604 void prefetchnta(const Address& addr) { opModM(addr, Reg32(0), 0x0F, 0x18); }
prefetcht0(const Address & addr)605 void prefetcht0(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0x18); }
prefetcht1(const Address & addr)606 void prefetcht1(const Address& addr) { opModM(addr, Reg32(2), 0x0F, 0x18); }
prefetcht2(const Address & addr)607 void prefetcht2(const Address& addr) { opModM(addr, Reg32(3), 0x0F, 0x18); }
prefetchw(const Address & addr)608 void prefetchw(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0x0D); }
prefetchwt1(const Address & addr)609 void prefetchwt1(const Address& addr) { opModM(addr, Reg32(2), 0x0F, 0x0D); }
psadbw(const Mmx & mmx,const Operand & op)610 void psadbw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF6); }
pshufb(const Mmx & mmx,const Operand & op)611 void pshufb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x00, 0x66, NONE, 0x38); }
pshufd(const Mmx & mmx,const Operand & op,uint8 imm8)612 void pshufd(const Mmx& mmx, const Operand& op, uint8 imm8) { opMMX(mmx, op, 0x70, 0x66, imm8); }
pshufhw(const Mmx & mmx,const Operand & op,uint8 imm8)613 void pshufhw(const Mmx& mmx, const Operand& op, uint8 imm8) { opMMX(mmx, op, 0x70, 0xF3, imm8); }
pshuflw(const Mmx & mmx,const Operand & op,uint8 imm8)614 void pshuflw(const Mmx& mmx, const Operand& op, uint8 imm8) { opMMX(mmx, op, 0x70, 0xF2, imm8); }
pshufw(const Mmx & mmx,const Operand & op,uint8 imm8)615 void pshufw(const Mmx& mmx, const Operand& op, uint8 imm8) { opMMX(mmx, op, 0x70, 0x00, imm8); }
psignb(const Mmx & mmx,const Operand & op)616 void psignb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x08, 0x66, NONE, 0x38); }
psignd(const Mmx & mmx,const Operand & op)617 void psignd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x0A, 0x66, NONE, 0x38); }
psignw(const Mmx & mmx,const Operand & op)618 void psignw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x09, 0x66, NONE, 0x38); }
pslld(const Mmx & mmx,const Operand & op)619 void pslld(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF2); }
pslld(const Mmx & mmx,int imm8)620 void pslld(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x72, 6); }
pslldq(const Xmm & xmm,int imm8)621 void pslldq(const Xmm& xmm, int imm8) { opMMX_IMM(xmm, imm8, 0x73, 7); }
psllq(const Mmx & mmx,const Operand & op)622 void psllq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF3); }
psllq(const Mmx & mmx,int imm8)623 void psllq(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x73, 6); }
psllw(const Mmx & mmx,const Operand & op)624 void psllw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF1); }
psllw(const Mmx & mmx,int imm8)625 void psllw(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x71, 6); }
psrad(const Mmx & mmx,const Operand & op)626 void psrad(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE2); }
psrad(const Mmx & mmx,int imm8)627 void psrad(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x72, 4); }
psraw(const Mmx & mmx,const Operand & op)628 void psraw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE1); }
psraw(const Mmx & mmx,int imm8)629 void psraw(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x71, 4); }
psrld(const Mmx & mmx,const Operand & op)630 void psrld(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD2); }
psrld(const Mmx & mmx,int imm8)631 void psrld(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x72, 2); }
psrldq(const Xmm & xmm,int imm8)632 void psrldq(const Xmm& xmm, int imm8) { opMMX_IMM(xmm, imm8, 0x73, 3); }
psrlq(const Mmx & mmx,const Operand & op)633 void psrlq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD3); }
psrlq(const Mmx & mmx,int imm8)634 void psrlq(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x73, 2); }
psrlw(const Mmx & mmx,const Operand & op)635 void psrlw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD1); }
psrlw(const Mmx & mmx,int imm8)636 void psrlw(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x71, 2); }
psubb(const Mmx & mmx,const Operand & op)637 void psubb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF8); }
psubd(const Mmx & mmx,const Operand & op)638 void psubd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFA); }
psubq(const Mmx & mmx,const Operand & op)639 void psubq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFB); }
psubsb(const Mmx & mmx,const Operand & op)640 void psubsb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE8); }
psubsw(const Mmx & mmx,const Operand & op)641 void psubsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE9); }
psubusb(const Mmx & mmx,const Operand & op)642 void psubusb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD8); }
psubusw(const Mmx & mmx,const Operand & op)643 void psubusw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD9); }
psubw(const Mmx & mmx,const Operand & op)644 void psubw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF9); }
ptest(const Xmm & xmm,const Operand & op)645 void ptest(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x17, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
punpckhbw(const Mmx & mmx,const Operand & op)646 void punpckhbw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x68); }
punpckhdq(const Mmx & mmx,const Operand & op)647 void punpckhdq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x6A); }
punpckhqdq(const Xmm & xmm,const Operand & op)648 void punpckhqdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x6D, 0x66, isXMM_XMMorMEM); }
punpckhwd(const Mmx & mmx,const Operand & op)649 void punpckhwd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x69); }
punpcklbw(const Mmx & mmx,const Operand & op)650 void punpcklbw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x60); }
punpckldq(const Mmx & mmx,const Operand & op)651 void punpckldq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x62); }
punpcklqdq(const Xmm & xmm,const Operand & op)652 void punpcklqdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x6C, 0x66, isXMM_XMMorMEM); }
punpcklwd(const Mmx & mmx,const Operand & op)653 void punpcklwd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x61); }
pushf()654 void pushf() { db(0x9C); }
pxor(const Mmx & mmx,const Operand & op)655 void pxor(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEF); }
rcl(const Operand & op,const Reg8 & _cl)656 void rcl(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 2); }
rcl(const Operand & op,int imm)657 void rcl(const Operand& op, int imm) { opShift(op, imm, 2); }
rcpps(const Xmm & xmm,const Operand & op)658 void rcpps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x53, 0x100, isXMM_XMMorMEM); }
rcpss(const Xmm & xmm,const Operand & op)659 void rcpss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x53, 0xF3, isXMM_XMMorMEM); }
rcr(const Operand & op,const Reg8 & _cl)660 void rcr(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 3); }
rcr(const Operand & op,int imm)661 void rcr(const Operand& op, int imm) { opShift(op, imm, 3); }
rdmsr()662 void rdmsr() { db(0x0F); db(0x32); }
rdpmc()663 void rdpmc() { db(0x0F); db(0x33); }
rdrand(const Reg & r)664 void rdrand(const Reg& r) { if (r.isBit(8)) throw Error(ERR_BAD_SIZE_OF_REGISTER); opModR(Reg(6, Operand::REG, r.getBit()), r, 0x0F, 0xC7); }
rdseed(const Reg & r)665 void rdseed(const Reg& r) { if (r.isBit(8)) throw Error(ERR_BAD_SIZE_OF_REGISTER); opModR(Reg(7, Operand::REG, r.getBit()), r, 0x0F, 0xC7); }
rdtsc()666 void rdtsc() { db(0x0F); db(0x31); }
rdtscp()667 void rdtscp() { db(0x0F); db(0x01); db(0xF9); }
rep()668 void rep() { db(0xF3); }
669 void ret(int imm = 0) { if (imm) { db(0xC2); dw(imm); } else { db(0xC3); } }
rol(const Operand & op,const Reg8 & _cl)670 void rol(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 0); }
rol(const Operand & op,int imm)671 void rol(const Operand& op, int imm) { opShift(op, imm, 0); }
ror(const Operand & op,const Reg8 & _cl)672 void ror(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 1); }
ror(const Operand & op,int imm)673 void ror(const Operand& op, int imm) { opShift(op, imm, 1); }
rorx(const Reg32e & r,const Operand & op,uint8 imm)674 void rorx(const Reg32e& r, const Operand& op, uint8 imm) { opGpr(r, op, Reg32e(0, r.getBit()), T_0F3A | T_F2, 0xF0, false, imm); }
roundpd(const Xmm & xmm,const Operand & op,uint8 imm)675 void roundpd(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x09, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
roundps(const Xmm & xmm,const Operand & op,uint8 imm)676 void roundps(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x08, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
roundsd(const Xmm & xmm,const Operand & op,int imm)677 void roundsd(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x0B, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
roundss(const Xmm & xmm,const Operand & op,int imm)678 void roundss(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x0A, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
rsqrtps(const Xmm & xmm,const Operand & op)679 void rsqrtps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x52, 0x100, isXMM_XMMorMEM); }
rsqrtss(const Xmm & xmm,const Operand & op)680 void rsqrtss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x52, 0xF3, isXMM_XMMorMEM); }
sahf()681 void sahf() { db(0x9E); }
sal(const Operand & op,const Reg8 & _cl)682 void sal(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 4); }
sal(const Operand & op,int imm)683 void sal(const Operand& op, int imm) { opShift(op, imm, 4); }
sar(const Operand & op,const Reg8 & _cl)684 void sar(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 7); }
sar(const Operand & op,int imm)685 void sar(const Operand& op, int imm) { opShift(op, imm, 7); }
sarx(const Reg32e & r1,const Operand & op,const Reg32e & r2)686 void sarx(const Reg32e& r1, const Operand& op, const Reg32e& r2) { opGpr(r1, op, r2, T_F3 | T_0F38, 0xf7, false); }
sbb(const Operand & op,uint32 imm)687 void sbb(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x18, 3); }
sbb(const Operand & op1,const Operand & op2)688 void sbb(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x18); }
scasb()689 void scasb() { db(0xAE); }
scasd()690 void scasd() { db(0xAF); }
scasw()691 void scasw() { db(0x66); db(0xAF); }
seta(const Operand & op)692 void seta(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 7); }//-V524
setae(const Operand & op)693 void setae(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 3); }//-V524
setb(const Operand & op)694 void setb(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 2); }//-V524
setbe(const Operand & op)695 void setbe(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 6); }//-V524
setc(const Operand & op)696 void setc(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 2); }//-V524
sete(const Operand & op)697 void sete(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 4); }//-V524
setg(const Operand & op)698 void setg(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 15); }//-V524
setge(const Operand & op)699 void setge(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 13); }//-V524
setl(const Operand & op)700 void setl(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 12); }//-V524
setle(const Operand & op)701 void setle(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 14); }//-V524
setna(const Operand & op)702 void setna(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 6); }//-V524
setnae(const Operand & op)703 void setnae(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 2); }//-V524
setnb(const Operand & op)704 void setnb(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 3); }//-V524
setnbe(const Operand & op)705 void setnbe(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 7); }//-V524
setnc(const Operand & op)706 void setnc(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 3); }//-V524
setne(const Operand & op)707 void setne(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 5); }//-V524
setng(const Operand & op)708 void setng(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 14); }//-V524
setnge(const Operand & op)709 void setnge(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 12); }//-V524
setnl(const Operand & op)710 void setnl(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 13); }//-V524
setnle(const Operand & op)711 void setnle(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 15); }//-V524
setno(const Operand & op)712 void setno(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 1); }//-V524
setnp(const Operand & op)713 void setnp(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 11); }//-V524
setns(const Operand & op)714 void setns(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 9); }//-V524
setnz(const Operand & op)715 void setnz(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 5); }//-V524
seto(const Operand & op)716 void seto(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 0); }//-V524
setp(const Operand & op)717 void setp(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 10); }//-V524
setpe(const Operand & op)718 void setpe(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 10); }//-V524
setpo(const Operand & op)719 void setpo(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 11); }//-V524
sets(const Operand & op)720 void sets(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 8); }//-V524
setz(const Operand & op)721 void setz(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 4); }//-V524
sfence()722 void sfence() { db(0x0F); db(0xAE); db(0xF8); }
sha1msg1(const Xmm & xmm,const Operand & op)723 void sha1msg1(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xC9, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha1msg2(const Xmm & xmm,const Operand & op)724 void sha1msg2(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCA, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha1nexte(const Xmm & xmm,const Operand & op)725 void sha1nexte(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xC8, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha1rnds4(const Xmm & xmm,const Operand & op,uint8 imm)726 void sha1rnds4(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0xCC, NONE, isXMM_XMMorMEM, imm, 0x3A); }
sha256msg1(const Xmm & xmm,const Operand & op)727 void sha256msg1(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCC, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha256msg2(const Xmm & xmm,const Operand & op)728 void sha256msg2(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCD, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha256rnds2(const Xmm & xmm,const Operand & op)729 void sha256rnds2(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCB, NONE, isXMM_XMMorMEM, NONE, 0x38); }
shl(const Operand & op,const Reg8 & _cl)730 void shl(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 4); }
shl(const Operand & op,int imm)731 void shl(const Operand& op, int imm) { opShift(op, imm, 4); }
shld(const Operand & op,const Reg & reg,const Reg8 & _cl)732 void shld(const Operand& op, const Reg& reg, const Reg8& _cl) { opShxd(op, reg, 0, 0xA4, &_cl); }
shld(const Operand & op,const Reg & reg,uint8 imm)733 void shld(const Operand& op, const Reg& reg, uint8 imm) { opShxd(op, reg, imm, 0xA4); }
shlx(const Reg32e & r1,const Operand & op,const Reg32e & r2)734 void shlx(const Reg32e& r1, const Operand& op, const Reg32e& r2) { opGpr(r1, op, r2, T_66 | T_0F38, 0xf7, false); }
shr(const Operand & op,const Reg8 & _cl)735 void shr(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 5); }
shr(const Operand & op,int imm)736 void shr(const Operand& op, int imm) { opShift(op, imm, 5); }
shrd(const Operand & op,const Reg & reg,const Reg8 & _cl)737 void shrd(const Operand& op, const Reg& reg, const Reg8& _cl) { opShxd(op, reg, 0, 0xAC, &_cl); }
shrd(const Operand & op,const Reg & reg,uint8 imm)738 void shrd(const Operand& op, const Reg& reg, uint8 imm) { opShxd(op, reg, imm, 0xAC); }
shrx(const Reg32e & r1,const Operand & op,const Reg32e & r2)739 void shrx(const Reg32e& r1, const Operand& op, const Reg32e& r2) { opGpr(r1, op, r2, T_F2 | T_0F38, 0xf7, false); }
shufpd(const Xmm & xmm,const Operand & op,uint8 imm8)740 void shufpd(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC6, 0x66, isXMM_XMMorMEM, imm8); }
shufps(const Xmm & xmm,const Operand & op,uint8 imm8)741 void shufps(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC6, 0x100, isXMM_XMMorMEM, imm8); }
sqrtpd(const Xmm & xmm,const Operand & op)742 void sqrtpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0x66, isXMM_XMMorMEM); }
sqrtps(const Xmm & xmm,const Operand & op)743 void sqrtps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0x100, isXMM_XMMorMEM); }
sqrtsd(const Xmm & xmm,const Operand & op)744 void sqrtsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0xF2, isXMM_XMMorMEM); }
sqrtss(const Xmm & xmm,const Operand & op)745 void sqrtss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0xF3, isXMM_XMMorMEM); }
stac()746 void stac() { db(0x0F); db(0x01); db(0xCB); }
stc()747 void stc() { db(0xF9); }
std()748 void std() { db(0xFD); }
sti()749 void sti() { db(0xFB); }
stmxcsr(const Address & addr)750 void stmxcsr(const Address& addr) { opModM(addr, Reg32(3), 0x0F, 0xAE); }
stosb()751 void stosb() { db(0xAA); }
stosd()752 void stosd() { db(0xAB); }
stosw()753 void stosw() { db(0x66); db(0xAB); }
sub(const Operand & op,uint32 imm)754 void sub(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x28, 5); }
sub(const Operand & op1,const Operand & op2)755 void sub(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x28); }
subpd(const Xmm & xmm,const Operand & op)756 void subpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0x66, isXMM_XMMorMEM); }
subps(const Xmm & xmm,const Operand & op)757 void subps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0x100, isXMM_XMMorMEM); }
subsd(const Xmm & xmm,const Operand & op)758 void subsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0xF2, isXMM_XMMorMEM); }
subss(const Xmm & xmm,const Operand & op)759 void subss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0xF3, isXMM_XMMorMEM); }
tzcnt(const Reg & reg,const Operand & op)760 void tzcnt(const Reg&reg, const Operand& op) { opSp1(reg, op, 0xF3, 0x0F, 0xBC); }
ucomisd(const Xmm & xmm,const Operand & op)761 void ucomisd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2E, 0x66, isXMM_XMMorMEM); }
ucomiss(const Xmm & xmm,const Operand & op)762 void ucomiss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2E, 0x100, isXMM_XMMorMEM); }
ud2()763 void ud2() { db(0x0F); db(0x0B); }
unpckhpd(const Xmm & xmm,const Operand & op)764 void unpckhpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x15, 0x66, isXMM_XMMorMEM); }
unpckhps(const Xmm & xmm,const Operand & op)765 void unpckhps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x15, 0x100, isXMM_XMMorMEM); }
unpcklpd(const Xmm & xmm,const Operand & op)766 void unpcklpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x14, 0x66, isXMM_XMMorMEM); }
unpcklps(const Xmm & xmm,const Operand & op)767 void unpcklps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x14, 0x100, isXMM_XMMorMEM); }
768 void vaddpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x58); }
769 void vaddps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x58); }
770 void vaddsd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F2 | T_EW1 | T_EVEX | T_ER_Z | T_N8, 0x58); }
771 void vaddss(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F3 | T_EW0 | T_EVEX | T_ER_Z | T_N4, 0x58); }
772 void vaddsubpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F | T_YMM, 0xD0); }
773 void vaddsubps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_F2 | T_0F | T_YMM, 0xD0); }
774 void vaesdec(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F38 | T_YMM | T_EVEX, 0xDE); }
775 void vaesdeclast(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F38 | T_YMM | T_EVEX, 0xDF); }
776 void vaesenc(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F38 | T_YMM | T_EVEX, 0xDC); }
777 void vaesenclast(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F38 | T_YMM | T_EVEX, 0xDD); }
vaesimc(const Xmm & xm,const Operand & op)778 void vaesimc(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_W0, 0xDB); }
vaeskeygenassist(const Xmm & xm,const Operand & op,uint8 imm)779 void vaeskeygenassist(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A, 0xDF, imm); }
780 void vandnpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x55); }
781 void vandnps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x55); }
782 void vandpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x54); }
783 void vandps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x54); }
vblendpd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)784 void vblendpd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM, 0x0D, imm); }
vblendps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)785 void vblendps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM, 0x0C, imm); }
vblendvpd(const Xmm & x1,const Xmm & x2,const Operand & op,const Xmm & x4)786 void vblendvpd(const Xmm& x1, const Xmm& x2, const Operand& op, const Xmm& x4) { opAVX_X_X_XM(x1, x2, op, T_0F3A | T_66 | T_YMM, 0x4B, x4.getIdx() << 4); }
vblendvps(const Xmm & x1,const Xmm & x2,const Operand & op,const Xmm & x4)787 void vblendvps(const Xmm& x1, const Xmm& x2, const Operand& op, const Xmm& x4) { opAVX_X_X_XM(x1, x2, op, T_0F3A | T_66 | T_YMM, 0x4A, x4.getIdx() << 4); }
vbroadcastf128(const Ymm & y,const Address & addr)788 void vbroadcastf128(const Ymm& y, const Address& addr) { opAVX_X_XM_IMM(y, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x1A); }
vbroadcasti128(const Ymm & y,const Address & addr)789 void vbroadcasti128(const Ymm& y, const Address& addr) { opAVX_X_XM_IMM(y, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x5A); }
vbroadcastsd(const Ymm & y,const Operand & op)790 void vbroadcastsd(const Ymm& y, const Operand& op) { if (!op.isMEM() && !(y.isYMM() && op.isXMM()) && !(y.isZMM() && op.isXMM())) throw Error(ERR_BAD_COMBINATION); opAVX_X_XM_IMM(y, op, T_0F38 | T_66 | T_W0 | T_YMM | T_EVEX | T_EW1 | T_N8, 0x19); }
vbroadcastss(const Xmm & x,const Operand & op)791 void vbroadcastss(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) throw Error(ERR_BAD_COMBINATION); opAVX_X_XM_IMM(x, op, T_N4 | T_66 | T_0F38 | T_W0 | T_YMM | T_EVEX, 0x18); }
vcmpeq_ospd(const Xmm & x1,const Xmm & x2,const Operand & op)792 void vcmpeq_ospd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 16); }
vcmpeq_osps(const Xmm & x1,const Xmm & x2,const Operand & op)793 void vcmpeq_osps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 16); }
vcmpeq_ossd(const Xmm & x1,const Xmm & x2,const Operand & op)794 void vcmpeq_ossd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 16); }
vcmpeq_osss(const Xmm & x1,const Xmm & x2,const Operand & op)795 void vcmpeq_osss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 16); }
vcmpeq_uqpd(const Xmm & x1,const Xmm & x2,const Operand & op)796 void vcmpeq_uqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 8); }
vcmpeq_uqps(const Xmm & x1,const Xmm & x2,const Operand & op)797 void vcmpeq_uqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 8); }
vcmpeq_uqsd(const Xmm & x1,const Xmm & x2,const Operand & op)798 void vcmpeq_uqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 8); }
vcmpeq_uqss(const Xmm & x1,const Xmm & x2,const Operand & op)799 void vcmpeq_uqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 8); }
vcmpeq_uspd(const Xmm & x1,const Xmm & x2,const Operand & op)800 void vcmpeq_uspd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 24); }
vcmpeq_usps(const Xmm & x1,const Xmm & x2,const Operand & op)801 void vcmpeq_usps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 24); }
vcmpeq_ussd(const Xmm & x1,const Xmm & x2,const Operand & op)802 void vcmpeq_ussd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 24); }
vcmpeq_usss(const Xmm & x1,const Xmm & x2,const Operand & op)803 void vcmpeq_usss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 24); }
vcmpeqpd(const Xmm & x1,const Xmm & x2,const Operand & op)804 void vcmpeqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 0); }
vcmpeqps(const Xmm & x1,const Xmm & x2,const Operand & op)805 void vcmpeqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 0); }
vcmpeqsd(const Xmm & x1,const Xmm & x2,const Operand & op)806 void vcmpeqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 0); }
vcmpeqss(const Xmm & x1,const Xmm & x2,const Operand & op)807 void vcmpeqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 0); }
vcmpfalse_ospd(const Xmm & x1,const Xmm & x2,const Operand & op)808 void vcmpfalse_ospd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 27); }
vcmpfalse_osps(const Xmm & x1,const Xmm & x2,const Operand & op)809 void vcmpfalse_osps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 27); }
vcmpfalse_ossd(const Xmm & x1,const Xmm & x2,const Operand & op)810 void vcmpfalse_ossd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 27); }
vcmpfalse_osss(const Xmm & x1,const Xmm & x2,const Operand & op)811 void vcmpfalse_osss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 27); }
vcmpfalsepd(const Xmm & x1,const Xmm & x2,const Operand & op)812 void vcmpfalsepd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 11); }
vcmpfalseps(const Xmm & x1,const Xmm & x2,const Operand & op)813 void vcmpfalseps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 11); }
vcmpfalsesd(const Xmm & x1,const Xmm & x2,const Operand & op)814 void vcmpfalsesd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 11); }
vcmpfalsess(const Xmm & x1,const Xmm & x2,const Operand & op)815 void vcmpfalsess(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 11); }
vcmpge_oqpd(const Xmm & x1,const Xmm & x2,const Operand & op)816 void vcmpge_oqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 29); }
vcmpge_oqps(const Xmm & x1,const Xmm & x2,const Operand & op)817 void vcmpge_oqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 29); }
vcmpge_oqsd(const Xmm & x1,const Xmm & x2,const Operand & op)818 void vcmpge_oqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 29); }
vcmpge_oqss(const Xmm & x1,const Xmm & x2,const Operand & op)819 void vcmpge_oqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 29); }
vcmpgepd(const Xmm & x1,const Xmm & x2,const Operand & op)820 void vcmpgepd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 13); }
vcmpgeps(const Xmm & x1,const Xmm & x2,const Operand & op)821 void vcmpgeps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 13); }
vcmpgesd(const Xmm & x1,const Xmm & x2,const Operand & op)822 void vcmpgesd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 13); }
vcmpgess(const Xmm & x1,const Xmm & x2,const Operand & op)823 void vcmpgess(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 13); }
vcmpgt_oqpd(const Xmm & x1,const Xmm & x2,const Operand & op)824 void vcmpgt_oqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 30); }
vcmpgt_oqps(const Xmm & x1,const Xmm & x2,const Operand & op)825 void vcmpgt_oqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 30); }
vcmpgt_oqsd(const Xmm & x1,const Xmm & x2,const Operand & op)826 void vcmpgt_oqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 30); }
vcmpgt_oqss(const Xmm & x1,const Xmm & x2,const Operand & op)827 void vcmpgt_oqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 30); }
vcmpgtpd(const Xmm & x1,const Xmm & x2,const Operand & op)828 void vcmpgtpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 14); }
vcmpgtps(const Xmm & x1,const Xmm & x2,const Operand & op)829 void vcmpgtps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 14); }
vcmpgtsd(const Xmm & x1,const Xmm & x2,const Operand & op)830 void vcmpgtsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 14); }
vcmpgtss(const Xmm & x1,const Xmm & x2,const Operand & op)831 void vcmpgtss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 14); }
vcmple_oqpd(const Xmm & x1,const Xmm & x2,const Operand & op)832 void vcmple_oqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 18); }
vcmple_oqps(const Xmm & x1,const Xmm & x2,const Operand & op)833 void vcmple_oqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 18); }
vcmple_oqsd(const Xmm & x1,const Xmm & x2,const Operand & op)834 void vcmple_oqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 18); }
vcmple_oqss(const Xmm & x1,const Xmm & x2,const Operand & op)835 void vcmple_oqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 18); }
vcmplepd(const Xmm & x1,const Xmm & x2,const Operand & op)836 void vcmplepd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 2); }
vcmpleps(const Xmm & x1,const Xmm & x2,const Operand & op)837 void vcmpleps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 2); }
vcmplesd(const Xmm & x1,const Xmm & x2,const Operand & op)838 void vcmplesd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 2); }
vcmpless(const Xmm & x1,const Xmm & x2,const Operand & op)839 void vcmpless(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 2); }
vcmplt_oqpd(const Xmm & x1,const Xmm & x2,const Operand & op)840 void vcmplt_oqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 17); }
vcmplt_oqps(const Xmm & x1,const Xmm & x2,const Operand & op)841 void vcmplt_oqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 17); }
vcmplt_oqsd(const Xmm & x1,const Xmm & x2,const Operand & op)842 void vcmplt_oqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 17); }
vcmplt_oqss(const Xmm & x1,const Xmm & x2,const Operand & op)843 void vcmplt_oqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 17); }
vcmpltpd(const Xmm & x1,const Xmm & x2,const Operand & op)844 void vcmpltpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 1); }
vcmpltps(const Xmm & x1,const Xmm & x2,const Operand & op)845 void vcmpltps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 1); }
vcmpltsd(const Xmm & x1,const Xmm & x2,const Operand & op)846 void vcmpltsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 1); }
vcmpltss(const Xmm & x1,const Xmm & x2,const Operand & op)847 void vcmpltss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 1); }
vcmpneq_oqpd(const Xmm & x1,const Xmm & x2,const Operand & op)848 void vcmpneq_oqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 12); }
vcmpneq_oqps(const Xmm & x1,const Xmm & x2,const Operand & op)849 void vcmpneq_oqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 12); }
vcmpneq_oqsd(const Xmm & x1,const Xmm & x2,const Operand & op)850 void vcmpneq_oqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 12); }
vcmpneq_oqss(const Xmm & x1,const Xmm & x2,const Operand & op)851 void vcmpneq_oqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 12); }
vcmpneq_ospd(const Xmm & x1,const Xmm & x2,const Operand & op)852 void vcmpneq_ospd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 28); }
vcmpneq_osps(const Xmm & x1,const Xmm & x2,const Operand & op)853 void vcmpneq_osps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 28); }
vcmpneq_ossd(const Xmm & x1,const Xmm & x2,const Operand & op)854 void vcmpneq_ossd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 28); }
vcmpneq_osss(const Xmm & x1,const Xmm & x2,const Operand & op)855 void vcmpneq_osss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 28); }
vcmpneq_uspd(const Xmm & x1,const Xmm & x2,const Operand & op)856 void vcmpneq_uspd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 20); }
vcmpneq_usps(const Xmm & x1,const Xmm & x2,const Operand & op)857 void vcmpneq_usps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 20); }
vcmpneq_ussd(const Xmm & x1,const Xmm & x2,const Operand & op)858 void vcmpneq_ussd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 20); }
vcmpneq_usss(const Xmm & x1,const Xmm & x2,const Operand & op)859 void vcmpneq_usss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 20); }
vcmpneqpd(const Xmm & x1,const Xmm & x2,const Operand & op)860 void vcmpneqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 4); }
vcmpneqps(const Xmm & x1,const Xmm & x2,const Operand & op)861 void vcmpneqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 4); }
vcmpneqsd(const Xmm & x1,const Xmm & x2,const Operand & op)862 void vcmpneqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 4); }
vcmpneqss(const Xmm & x1,const Xmm & x2,const Operand & op)863 void vcmpneqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 4); }
vcmpnge_uqpd(const Xmm & x1,const Xmm & x2,const Operand & op)864 void vcmpnge_uqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 25); }
vcmpnge_uqps(const Xmm & x1,const Xmm & x2,const Operand & op)865 void vcmpnge_uqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 25); }
vcmpnge_uqsd(const Xmm & x1,const Xmm & x2,const Operand & op)866 void vcmpnge_uqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 25); }
vcmpnge_uqss(const Xmm & x1,const Xmm & x2,const Operand & op)867 void vcmpnge_uqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 25); }
vcmpngepd(const Xmm & x1,const Xmm & x2,const Operand & op)868 void vcmpngepd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 9); }
vcmpngeps(const Xmm & x1,const Xmm & x2,const Operand & op)869 void vcmpngeps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 9); }
vcmpngesd(const Xmm & x1,const Xmm & x2,const Operand & op)870 void vcmpngesd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 9); }
vcmpngess(const Xmm & x1,const Xmm & x2,const Operand & op)871 void vcmpngess(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 9); }
vcmpngt_uqpd(const Xmm & x1,const Xmm & x2,const Operand & op)872 void vcmpngt_uqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 26); }
vcmpngt_uqps(const Xmm & x1,const Xmm & x2,const Operand & op)873 void vcmpngt_uqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 26); }
vcmpngt_uqsd(const Xmm & x1,const Xmm & x2,const Operand & op)874 void vcmpngt_uqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 26); }
vcmpngt_uqss(const Xmm & x1,const Xmm & x2,const Operand & op)875 void vcmpngt_uqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 26); }
vcmpngtpd(const Xmm & x1,const Xmm & x2,const Operand & op)876 void vcmpngtpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 10); }
vcmpngtps(const Xmm & x1,const Xmm & x2,const Operand & op)877 void vcmpngtps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 10); }
vcmpngtsd(const Xmm & x1,const Xmm & x2,const Operand & op)878 void vcmpngtsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 10); }
vcmpngtss(const Xmm & x1,const Xmm & x2,const Operand & op)879 void vcmpngtss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 10); }
vcmpnle_uqpd(const Xmm & x1,const Xmm & x2,const Operand & op)880 void vcmpnle_uqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 22); }
vcmpnle_uqps(const Xmm & x1,const Xmm & x2,const Operand & op)881 void vcmpnle_uqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 22); }
vcmpnle_uqsd(const Xmm & x1,const Xmm & x2,const Operand & op)882 void vcmpnle_uqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 22); }
vcmpnle_uqss(const Xmm & x1,const Xmm & x2,const Operand & op)883 void vcmpnle_uqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 22); }
vcmpnlepd(const Xmm & x1,const Xmm & x2,const Operand & op)884 void vcmpnlepd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 6); }
vcmpnleps(const Xmm & x1,const Xmm & x2,const Operand & op)885 void vcmpnleps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 6); }
vcmpnlesd(const Xmm & x1,const Xmm & x2,const Operand & op)886 void vcmpnlesd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 6); }
vcmpnless(const Xmm & x1,const Xmm & x2,const Operand & op)887 void vcmpnless(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 6); }
vcmpnlt_uqpd(const Xmm & x1,const Xmm & x2,const Operand & op)888 void vcmpnlt_uqpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 21); }
vcmpnlt_uqps(const Xmm & x1,const Xmm & x2,const Operand & op)889 void vcmpnlt_uqps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 21); }
vcmpnlt_uqsd(const Xmm & x1,const Xmm & x2,const Operand & op)890 void vcmpnlt_uqsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 21); }
vcmpnlt_uqss(const Xmm & x1,const Xmm & x2,const Operand & op)891 void vcmpnlt_uqss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 21); }
vcmpnltpd(const Xmm & x1,const Xmm & x2,const Operand & op)892 void vcmpnltpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 5); }
vcmpnltps(const Xmm & x1,const Xmm & x2,const Operand & op)893 void vcmpnltps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 5); }
vcmpnltsd(const Xmm & x1,const Xmm & x2,const Operand & op)894 void vcmpnltsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 5); }
vcmpnltss(const Xmm & x1,const Xmm & x2,const Operand & op)895 void vcmpnltss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 5); }
vcmpord_spd(const Xmm & x1,const Xmm & x2,const Operand & op)896 void vcmpord_spd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 23); }
vcmpord_sps(const Xmm & x1,const Xmm & x2,const Operand & op)897 void vcmpord_sps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 23); }
vcmpord_ssd(const Xmm & x1,const Xmm & x2,const Operand & op)898 void vcmpord_ssd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 23); }
vcmpord_sss(const Xmm & x1,const Xmm & x2,const Operand & op)899 void vcmpord_sss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 23); }
vcmpordpd(const Xmm & x1,const Xmm & x2,const Operand & op)900 void vcmpordpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 7); }
vcmpordps(const Xmm & x1,const Xmm & x2,const Operand & op)901 void vcmpordps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 7); }
vcmpordsd(const Xmm & x1,const Xmm & x2,const Operand & op)902 void vcmpordsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 7); }
vcmpordss(const Xmm & x1,const Xmm & x2,const Operand & op)903 void vcmpordss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 7); }
vcmppd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)904 void vcmppd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0xC2, imm); }
vcmpps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)905 void vcmpps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_0F | T_YMM, 0xC2, imm); }
vcmpsd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)906 void vcmpsd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_F2 | T_0F, 0xC2, imm); }
vcmpss(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)907 void vcmpss(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_F3 | T_0F, 0xC2, imm); }
vcmptrue_uspd(const Xmm & x1,const Xmm & x2,const Operand & op)908 void vcmptrue_uspd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 31); }
vcmptrue_usps(const Xmm & x1,const Xmm & x2,const Operand & op)909 void vcmptrue_usps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 31); }
vcmptrue_ussd(const Xmm & x1,const Xmm & x2,const Operand & op)910 void vcmptrue_ussd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 31); }
vcmptrue_usss(const Xmm & x1,const Xmm & x2,const Operand & op)911 void vcmptrue_usss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 31); }
vcmptruepd(const Xmm & x1,const Xmm & x2,const Operand & op)912 void vcmptruepd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 15); }
vcmptrueps(const Xmm & x1,const Xmm & x2,const Operand & op)913 void vcmptrueps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 15); }
vcmptruesd(const Xmm & x1,const Xmm & x2,const Operand & op)914 void vcmptruesd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 15); }
vcmptruess(const Xmm & x1,const Xmm & x2,const Operand & op)915 void vcmptruess(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 15); }
vcmpunord_spd(const Xmm & x1,const Xmm & x2,const Operand & op)916 void vcmpunord_spd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 19); }
vcmpunord_sps(const Xmm & x1,const Xmm & x2,const Operand & op)917 void vcmpunord_sps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 19); }
vcmpunord_ssd(const Xmm & x1,const Xmm & x2,const Operand & op)918 void vcmpunord_ssd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 19); }
vcmpunord_sss(const Xmm & x1,const Xmm & x2,const Operand & op)919 void vcmpunord_sss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 19); }
vcmpunordpd(const Xmm & x1,const Xmm & x2,const Operand & op)920 void vcmpunordpd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmppd(x1, x2, op, 3); }
vcmpunordps(const Xmm & x1,const Xmm & x2,const Operand & op)921 void vcmpunordps(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpps(x1, x2, op, 3); }
vcmpunordsd(const Xmm & x1,const Xmm & x2,const Operand & op)922 void vcmpunordsd(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpsd(x1, x2, op, 3); }
vcmpunordss(const Xmm & x1,const Xmm & x2,const Operand & op)923 void vcmpunordss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 3); }
vcomisd(const Xmm & xm,const Operand & op)924 void vcomisd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_66 | T_0F | T_EW1 | T_EVEX | T_SAE_X, 0x2F); }
vcomiss(const Xmm & xm,const Operand & op)925 void vcomiss(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N4 | T_0F | T_EW0 | T_EVEX | T_SAE_X, 0x2F); }
vcvtdq2pd(const Xmm & x,const Operand & op)926 void vcvtdq2pd(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_0F | T_F3 | T_YMM | T_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL, 0xE6); }
vcvtdq2ps(const Xmm & xm,const Operand & op)927 void vcvtdq2ps(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x5B); }
vcvtpd2dq(const Xmm & x,const Operand & op)928 void vcvtpd2dq(const Xmm& x, const Operand& op) { opCvt2(x, op, T_0F | T_F2 | T_YMM | T_EVEX | T_EW1 | T_B64 | T_ER_Z, 0xE6); }
vcvtpd2ps(const Xmm & x,const Operand & op)929 void vcvtpd2ps(const Xmm& x, const Operand& op) { opCvt2(x, op, T_0F | T_66 | T_YMM | T_EVEX | T_EW1 | T_B64 | T_ER_Z, 0x5A); }
vcvtph2ps(const Xmm & x,const Operand & op)930 void vcvtph2ps(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_0F38 | T_66 | T_W0 | T_EVEX | T_EW0 | T_N8 | T_N_VL | T_SAE_Y, 0x13); }
vcvtps2dq(const Xmm & xm,const Operand & op)931 void vcvtps2dq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x5B); }
vcvtps2pd(const Xmm & x,const Operand & op)932 void vcvtps2pd(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_0F | T_YMM | T_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL | T_SAE_Y, 0x5A); }
vcvtps2ph(const Operand & op,const Xmm & x,uint8 imm)933 void vcvtps2ph(const Operand& op, const Xmm& x, uint8 imm) { checkCvt1(x, op); opVex(x, 0, op, T_0F3A | T_66 | T_W0 | T_EVEX | T_EW0 | T_N8 | T_N_VL | T_SAE_Y, 0x1D, imm); }
vcvtsd2si(const Reg32 & r,const Operand & op)934 void vcvtsd2si(const Reg32& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F2 | T_W0 | T_EVEX | T_EW0 | T_N4 | T_ER_X, 0x2D); }
vcvtsd2ss(const Xmm & x1,const Xmm & x2,const Operand & op)935 void vcvtsd2ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_F2 | T_0F | T_EW1 | T_EVEX | T_ER_X, 0x5A); }
vcvtsi2sd(const Xmm & x1,const Xmm & x2,const Operand & op)936 void vcvtsi2sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opCvt3(x1, x2, op, T_0F | T_F2 | T_EVEX, T_W1 | T_EW1 | T_ER_X | T_N8, T_W0 | T_EW0 | T_N4, 0x2A); }
vcvtsi2ss(const Xmm & x1,const Xmm & x2,const Operand & op)937 void vcvtsi2ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opCvt3(x1, x2, op, T_0F | T_F3 | T_EVEX | T_ER_X, T_W1 | T_EW1 | T_N8, T_W0 | T_EW0 | T_N4, 0x2A); }
vcvtss2sd(const Xmm & x1,const Xmm & x2,const Operand & op)938 void vcvtss2sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_F3 | T_0F | T_EW0 | T_EVEX | T_SAE_X, 0x5A); }
vcvtss2si(const Reg32 & r,const Operand & op)939 void vcvtss2si(const Reg32& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F3 | T_W0 | T_EVEX | T_EW0 | T_ER_X | T_N8, 0x2D); }
vcvttpd2dq(const Xmm & x,const Operand & op)940 void vcvttpd2dq(const Xmm& x, const Operand& op) { opCvt2(x, op, T_66 | T_0F | T_YMM | T_EVEX |T_EW1 | T_B64 | T_ER_Z, 0xE6); }
vcvttps2dq(const Xmm & xm,const Operand & op)941 void vcvttps2dq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_F3 | T_0F | T_EW0 | T_YMM | T_EVEX | T_SAE_Z | T_B32, 0x5B); }
vcvttsd2si(const Reg32 & r,const Operand & op)942 void vcvttsd2si(const Reg32& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F2 | T_W0 | T_EVEX | T_EW0 | T_N4 | T_SAE_X, 0x2C); }
vcvttss2si(const Reg32 & r,const Operand & op)943 void vcvttss2si(const Reg32& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F3 | T_W0 | T_EVEX | T_EW0 | T_SAE_X | T_N8, 0x2C); }
944 void vdivpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x5E); }
945 void vdivps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x5E); }
946 void vdivsd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F2 | T_EW1 | T_EVEX | T_ER_Z | T_N8, 0x5E); }
947 void vdivss(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F3 | T_EW0 | T_EVEX | T_ER_Z | T_N4, 0x5E); }
vdppd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)948 void vdppd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0, 0x41, imm); }
vdpps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)949 void vdpps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM, 0x40, imm); }
vextractf128(const Operand & op,const Ymm & y,uint8 imm)950 void vextractf128(const Operand& op, const Ymm& y, uint8 imm) { if (!(op.isXMEM() && y.isYMM())) throw Error(ERR_BAD_COMBINATION); opVex(y, 0, op, T_0F3A | T_66 | T_W0 | T_YMM, 0x19, imm); }
vextracti128(const Operand & op,const Ymm & y,uint8 imm)951 void vextracti128(const Operand& op, const Ymm& y, uint8 imm) { if (!(op.isXMEM() && y.isYMM())) throw Error(ERR_BAD_COMBINATION); opVex(y, 0, op, T_0F3A | T_66 | T_W0 | T_YMM, 0x39, imm); }
vextractps(const Operand & op,const Xmm & x,uint8 imm)952 void vextractps(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(32) || op.isMEM()) && x.isXMM())) throw Error(ERR_BAD_COMBINATION); opVex(x, 0, op, T_0F3A | T_66 | T_W0 | T_EVEX | T_N4, 0x17, imm); }
vfmadd132pd(const Xmm & x1,const Xmm & x2,const Operand & op)953 void vfmadd132pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x98); }
vfmadd132ps(const Xmm & x1,const Xmm & x2,const Operand & op)954 void vfmadd132ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x98); }
vfmadd132sd(const Xmm & x1,const Xmm & x2,const Operand & op)955 void vfmadd132sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0x99); }
vfmadd132ss(const Xmm & x1,const Xmm & x2,const Operand & op)956 void vfmadd132ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0x99); }
vfmadd213pd(const Xmm & x1,const Xmm & x2,const Operand & op)957 void vfmadd213pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xA8); }
vfmadd213ps(const Xmm & x1,const Xmm & x2,const Operand & op)958 void vfmadd213ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xA8); }
vfmadd213sd(const Xmm & x1,const Xmm & x2,const Operand & op)959 void vfmadd213sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xA9); }
vfmadd213ss(const Xmm & x1,const Xmm & x2,const Operand & op)960 void vfmadd213ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xA9); }
vfmadd231pd(const Xmm & x1,const Xmm & x2,const Operand & op)961 void vfmadd231pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xB8); }
vfmadd231ps(const Xmm & x1,const Xmm & x2,const Operand & op)962 void vfmadd231ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xB8); }
vfmadd231sd(const Xmm & x1,const Xmm & x2,const Operand & op)963 void vfmadd231sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xB9); }
vfmadd231ss(const Xmm & x1,const Xmm & x2,const Operand & op)964 void vfmadd231ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xB9); }
vfmaddsub132pd(const Xmm & x1,const Xmm & x2,const Operand & op)965 void vfmaddsub132pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x96); }
vfmaddsub132ps(const Xmm & x1,const Xmm & x2,const Operand & op)966 void vfmaddsub132ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x96); }
vfmaddsub213pd(const Xmm & x1,const Xmm & x2,const Operand & op)967 void vfmaddsub213pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xA6); }
vfmaddsub213ps(const Xmm & x1,const Xmm & x2,const Operand & op)968 void vfmaddsub213ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xA6); }
vfmaddsub231pd(const Xmm & x1,const Xmm & x2,const Operand & op)969 void vfmaddsub231pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xB6); }
vfmaddsub231ps(const Xmm & x1,const Xmm & x2,const Operand & op)970 void vfmaddsub231ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xB6); }
vfmsub132pd(const Xmm & x1,const Xmm & x2,const Operand & op)971 void vfmsub132pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x9A); }
vfmsub132ps(const Xmm & x1,const Xmm & x2,const Operand & op)972 void vfmsub132ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x9A); }
vfmsub132sd(const Xmm & x1,const Xmm & x2,const Operand & op)973 void vfmsub132sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0x9B); }
vfmsub132ss(const Xmm & x1,const Xmm & x2,const Operand & op)974 void vfmsub132ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0x9B); }
vfmsub213pd(const Xmm & x1,const Xmm & x2,const Operand & op)975 void vfmsub213pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xAA); }
vfmsub213ps(const Xmm & x1,const Xmm & x2,const Operand & op)976 void vfmsub213ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xAA); }
vfmsub213sd(const Xmm & x1,const Xmm & x2,const Operand & op)977 void vfmsub213sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xAB); }
vfmsub213ss(const Xmm & x1,const Xmm & x2,const Operand & op)978 void vfmsub213ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xAB); }
vfmsub231pd(const Xmm & x1,const Xmm & x2,const Operand & op)979 void vfmsub231pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xBA); }
vfmsub231ps(const Xmm & x1,const Xmm & x2,const Operand & op)980 void vfmsub231ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xBA); }
vfmsub231sd(const Xmm & x1,const Xmm & x2,const Operand & op)981 void vfmsub231sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xBB); }
vfmsub231ss(const Xmm & x1,const Xmm & x2,const Operand & op)982 void vfmsub231ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xBB); }
vfmsubadd132pd(const Xmm & x1,const Xmm & x2,const Operand & op)983 void vfmsubadd132pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x97); }
vfmsubadd132ps(const Xmm & x1,const Xmm & x2,const Operand & op)984 void vfmsubadd132ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x97); }
vfmsubadd213pd(const Xmm & x1,const Xmm & x2,const Operand & op)985 void vfmsubadd213pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xA7); }
vfmsubadd213ps(const Xmm & x1,const Xmm & x2,const Operand & op)986 void vfmsubadd213ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xA7); }
vfmsubadd231pd(const Xmm & x1,const Xmm & x2,const Operand & op)987 void vfmsubadd231pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xB7); }
vfmsubadd231ps(const Xmm & x1,const Xmm & x2,const Operand & op)988 void vfmsubadd231ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xB7); }
vfnmadd132pd(const Xmm & x1,const Xmm & x2,const Operand & op)989 void vfnmadd132pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x9C); }
vfnmadd132ps(const Xmm & x1,const Xmm & x2,const Operand & op)990 void vfnmadd132ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x9C); }
vfnmadd132sd(const Xmm & x1,const Xmm & x2,const Operand & op)991 void vfnmadd132sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0x9D); }
vfnmadd132ss(const Xmm & x1,const Xmm & x2,const Operand & op)992 void vfnmadd132ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0x9D); }
vfnmadd213pd(const Xmm & x1,const Xmm & x2,const Operand & op)993 void vfnmadd213pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xAC); }
vfnmadd213ps(const Xmm & x1,const Xmm & x2,const Operand & op)994 void vfnmadd213ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xAC); }
vfnmadd213sd(const Xmm & x1,const Xmm & x2,const Operand & op)995 void vfnmadd213sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xAD); }
vfnmadd213ss(const Xmm & x1,const Xmm & x2,const Operand & op)996 void vfnmadd213ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xAD); }
vfnmadd231pd(const Xmm & x1,const Xmm & x2,const Operand & op)997 void vfnmadd231pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xBC); }
vfnmadd231ps(const Xmm & x1,const Xmm & x2,const Operand & op)998 void vfnmadd231ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xBC); }
vfnmadd231sd(const Xmm & x1,const Xmm & x2,const Operand & op)999 void vfnmadd231sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xBD); }
vfnmadd231ss(const Xmm & x1,const Xmm & x2,const Operand & op)1000 void vfnmadd231ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xBD); }
vfnmsub132pd(const Xmm & x1,const Xmm & x2,const Operand & op)1001 void vfnmsub132pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x9E); }
vfnmsub132ps(const Xmm & x1,const Xmm & x2,const Operand & op)1002 void vfnmsub132ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x9E); }
vfnmsub132sd(const Xmm & x1,const Xmm & x2,const Operand & op)1003 void vfnmsub132sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0x9F); }
vfnmsub132ss(const Xmm & x1,const Xmm & x2,const Operand & op)1004 void vfnmsub132ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0x9F); }
vfnmsub213pd(const Xmm & x1,const Xmm & x2,const Operand & op)1005 void vfnmsub213pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xAE); }
vfnmsub213ps(const Xmm & x1,const Xmm & x2,const Operand & op)1006 void vfnmsub213ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xAE); }
vfnmsub213sd(const Xmm & x1,const Xmm & x2,const Operand & op)1007 void vfnmsub213sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xAF); }
vfnmsub213ss(const Xmm & x1,const Xmm & x2,const Operand & op)1008 void vfnmsub213ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xAF); }
vfnmsub231pd(const Xmm & x1,const Xmm & x2,const Operand & op)1009 void vfnmsub231pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0xBE); }
vfnmsub231ps(const Xmm & x1,const Xmm & x2,const Operand & op)1010 void vfnmsub231ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0xBE); }
vfnmsub231sd(const Xmm & x1,const Xmm & x2,const Operand & op)1011 void vfnmsub231sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_W1 | T_EW1 | T_EVEX | T_ER_X, 0xBF); }
vfnmsub231ss(const Xmm & x1,const Xmm & x2,const Operand & op)1012 void vfnmsub231ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_W0 | T_EW0 | T_EVEX | T_ER_X, 0xBF); }
vgatherdpd(const Xmm & x1,const Address & addr,const Xmm & x2)1013 void vgatherdpd(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W1, 0x92, 0); }
vgatherdps(const Xmm & x1,const Address & addr,const Xmm & x2)1014 void vgatherdps(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W0, 0x92, 1); }
vgatherqpd(const Xmm & x1,const Address & addr,const Xmm & x2)1015 void vgatherqpd(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W1, 0x93, 1); }
vgatherqps(const Xmm & x1,const Address & addr,const Xmm & x2)1016 void vgatherqps(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W0, 0x93, 2); }
vgf2p8affineinvqb(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1017 void vgf2p8affineinvqb(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W1 | T_EW1 | T_YMM | T_EVEX | T_SAE_Z | T_B64, 0xCF, imm); }
vgf2p8affineqb(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1018 void vgf2p8affineqb(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W1 | T_EW1 | T_YMM | T_EVEX | T_SAE_Z | T_B64, 0xCE, imm); }
vgf2p8mulb(const Xmm & x1,const Xmm & x2,const Operand & op)1019 void vgf2p8mulb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_SAE_Z, 0xCF); }
1020 void vhaddpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F | T_YMM, 0x7C); }
1021 void vhaddps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_F2 | T_0F | T_YMM, 0x7C); }
1022 void vhsubpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_66 | T_0F | T_YMM, 0x7D); }
1023 void vhsubps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_F2 | T_0F | T_YMM, 0x7D); }
vinsertf128(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1024 void vinsertf128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isXMEM())) throw Error(ERR_BAD_COMBINATION); opVex(y1, &y2, op, T_0F3A | T_66 | T_W0 | T_YMM, 0x18, imm); }
vinserti128(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1025 void vinserti128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isXMEM())) throw Error(ERR_BAD_COMBINATION); opVex(y1, &y2, op, T_0F3A | T_66 | T_W0 | T_YMM, 0x38, imm); }
vinsertps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1026 void vinsertps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F3A | T_W0 | T_EW0 | T_EVEX, 0x21, imm); }
vlddqu(const Xmm & x,const Address & addr)1027 void vlddqu(const Xmm& x, const Address& addr) { opAVX_X_X_XM(x, cvtIdx0(x), addr, T_0F | T_F2 | T_W0 | T_YMM, 0xF0); }
vldmxcsr(const Address & addr)1028 void vldmxcsr(const Address& addr) { opAVX_X_X_XM(xm2, xm0, addr, T_0F, 0xAE); }
vmaskmovdqu(const Xmm & x1,const Xmm & x2)1029 void vmaskmovdqu(const Xmm& x1, const Xmm& x2) { opAVX_X_X_XM(x1, xm0, x2, T_0F | T_66, 0xF7); }
vmaskmovpd(const Address & addr,const Xmm & x1,const Xmm & x2)1030 void vmaskmovpd(const Address& addr, const Xmm& x1, const Xmm& x2) { opAVX_X_X_XM(x2, x1, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x2F); }
vmaskmovpd(const Xmm & x1,const Xmm & x2,const Address & addr)1031 void vmaskmovpd(const Xmm& x1, const Xmm& x2, const Address& addr) { opAVX_X_X_XM(x1, x2, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x2D); }
vmaskmovps(const Address & addr,const Xmm & x1,const Xmm & x2)1032 void vmaskmovps(const Address& addr, const Xmm& x1, const Xmm& x2) { opAVX_X_X_XM(x2, x1, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x2E); }
vmaskmovps(const Xmm & x1,const Xmm & x2,const Address & addr)1033 void vmaskmovps(const Xmm& x1, const Xmm& x2, const Address& addr) { opAVX_X_X_XM(x1, x2, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x2C); }
1034 void vmaxpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x5F); }
1035 void vmaxps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x5F); }
1036 void vmaxsd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F2 | T_EW1 | T_EVEX | T_ER_Z | T_N8, 0x5F); }
1037 void vmaxss(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F3 | T_EW0 | T_EVEX | T_ER_Z | T_N4, 0x5F); }
1038 void vminpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x5D); }
1039 void vminps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x5D); }
1040 void vminsd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F2 | T_EW1 | T_EVEX | T_ER_Z | T_N8, 0x5D); }
1041 void vminss(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F3 | T_EW0 | T_EVEX | T_ER_Z | T_N4, 0x5D); }
vmovapd(const Address & addr,const Xmm & xmm)1042 void vmovapd(const Address& addr, const Xmm& xmm) { opAVX_X_XM_IMM(xmm, addr, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_M_K, 0x29); }
vmovapd(const Xmm & xm,const Operand & op)1043 void vmovapd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX, 0x28); }
vmovaps(const Address & addr,const Xmm & xmm)1044 void vmovaps(const Address& addr, const Xmm& xmm) { opAVX_X_XM_IMM(xmm, addr, T_0F | T_EW0 | T_YMM | T_EVEX | T_M_K, 0x29); }
vmovaps(const Xmm & xm,const Operand & op)1045 void vmovaps(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_0F | T_EW0 | T_YMM | T_EVEX, 0x28); }
vmovd(const Operand & op,const Xmm & x)1046 void vmovd(const Operand& op, const Xmm& x) { if (!op.isREG(32) && !op.isMEM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x, xm0, op, T_0F | T_66 | T_W0 | T_EVEX | T_N4, 0x7E); }
vmovd(const Xmm & x,const Operand & op)1047 void vmovd(const Xmm& x, const Operand& op) { if (!op.isREG(32) && !op.isMEM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x, xm0, op, T_0F | T_66 | T_W0 | T_EVEX | T_N4, 0x6E); }
vmovddup(const Xmm & xm,const Operand & op)1048 void vmovddup(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_DUP | T_F2 | T_0F | T_EW1 | T_YMM | T_EVEX | T_ER_X | T_ER_Y | T_ER_Z, 0x12); }
vmovdqa(const Address & addr,const Xmm & xmm)1049 void vmovdqa(const Address& addr, const Xmm& xmm) { opAVX_X_XM_IMM(xmm, addr, T_66 | T_0F | T_YMM, 0x7F); }
vmovdqa(const Xmm & xm,const Operand & op)1050 void vmovdqa(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F | T_YMM, 0x6F); }
vmovdqu(const Address & addr,const Xmm & xmm)1051 void vmovdqu(const Address& addr, const Xmm& xmm) { opAVX_X_XM_IMM(xmm, addr, T_F3 | T_0F | T_YMM, 0x7F); }
vmovdqu(const Xmm & xm,const Operand & op)1052 void vmovdqu(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_F3 | T_0F | T_YMM, 0x6F); }
1053 void vmovhlps(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x1, x2, op, T_0F | T_EVEX | T_EW0, 0x12); }
vmovhpd(const Address & addr,const Xmm & x)1054 void vmovhpd(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_66 | T_EVEX | T_EW1 | T_N8, 0x17); }
1055 void vmovhpd(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x, op1, op2, T_0F | T_66 | T_EVEX | T_EW1 | T_N8, 0x16); }
vmovhps(const Address & addr,const Xmm & x)1056 void vmovhps(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_EVEX | T_EW0 | T_N8, 0x17); }
1057 void vmovhps(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x, op1, op2, T_0F | T_EVEX | T_EW0 | T_N8, 0x16); }
1058 void vmovlhps(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x1, x2, op, T_0F | T_EVEX | T_EW0, 0x16); }
vmovlpd(const Address & addr,const Xmm & x)1059 void vmovlpd(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_66 | T_EVEX | T_EW1 | T_N8, 0x13); }
1060 void vmovlpd(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x, op1, op2, T_0F | T_66 | T_EVEX | T_EW1 | T_N8, 0x12); }
vmovlps(const Address & addr,const Xmm & x)1061 void vmovlps(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_EVEX | T_EW0 | T_N8, 0x13); }
1062 void vmovlps(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x, op1, op2, T_0F | T_EVEX | T_EW0 | T_N8, 0x12); }
vmovmskpd(const Reg & r,const Xmm & x)1063 void vmovmskpd(const Reg& r, const Xmm& x) { if (!r.isBit(i32e)) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x.isXMM() ? Xmm(r.getIdx()) : Ymm(r.getIdx()), cvtIdx0(x), x, T_0F | T_66 | T_W0 | T_YMM, 0x50); }
vmovmskps(const Reg & r,const Xmm & x)1064 void vmovmskps(const Reg& r, const Xmm& x) { if (!r.isBit(i32e)) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x.isXMM() ? Xmm(r.getIdx()) : Ymm(r.getIdx()), cvtIdx0(x), x, T_0F | T_W0 | T_YMM, 0x50); }
vmovntdq(const Address & addr,const Xmm & x)1065 void vmovntdq(const Address& addr, const Xmm& x) { opVex(x, 0, addr, T_0F | T_66 | T_YMM | T_EVEX | T_EW0, 0xE7); }
vmovntdqa(const Xmm & x,const Address & addr)1066 void vmovntdqa(const Xmm& x, const Address& addr) { opVex(x, 0, addr, T_0F38 | T_66 | T_YMM | T_EVEX | T_EW0, 0x2A); }
vmovntpd(const Address & addr,const Xmm & x)1067 void vmovntpd(const Address& addr, const Xmm& x) { opVex(x, 0, addr, T_0F | T_66 | T_YMM | T_EVEX | T_EW1, 0x2B); }
vmovntps(const Address & addr,const Xmm & x)1068 void vmovntps(const Address& addr, const Xmm& x) { opVex(x, 0, addr, T_0F | T_YMM | T_EVEX | T_EW0, 0x2B); }
vmovq(const Address & addr,const Xmm & x)1069 void vmovq(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_66 | T_EVEX | T_EW1 | T_N8, x.getIdx() < 16 ? 0xD6 : 0x7E); }
vmovq(const Xmm & x,const Address & addr)1070 void vmovq(const Xmm& x, const Address& addr) { int type, code; if (x.getIdx() < 16) { type = T_0F | T_F3; code = 0x7E; } else { type = T_0F | T_66 | T_EVEX | T_EW1 | T_N8; code = 0x6E; } opAVX_X_X_XM(x, xm0, addr, type, code); }
vmovq(const Xmm & x1,const Xmm & x2)1071 void vmovq(const Xmm& x1, const Xmm& x2) { opAVX_X_X_XM(x1, xm0, x2, T_0F | T_F3 | T_EVEX | T_EW1 | T_N8, 0x7E); }
vmovsd(const Address & addr,const Xmm & x)1072 void vmovsd(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_N8 | T_F2 | T_0F | T_EW1 | T_EVEX | T_M_K, 0x11); }
vmovsd(const Xmm & x,const Address & addr)1073 void vmovsd(const Xmm& x, const Address& addr) { opAVX_X_X_XM(x, xm0, addr, T_N8 | T_F2 | T_0F | T_EW1 | T_EVEX, 0x10); }
1074 void vmovsd(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x1, x2, op, T_N8 | T_F2 | T_0F | T_EW1 | T_EVEX, 0x10); }
vmovshdup(const Xmm & xm,const Operand & op)1075 void vmovshdup(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_F3 | T_0F | T_EW0 | T_YMM | T_EVEX, 0x16); }
vmovsldup(const Xmm & xm,const Operand & op)1076 void vmovsldup(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_F3 | T_0F | T_EW0 | T_YMM | T_EVEX, 0x12); }
vmovss(const Address & addr,const Xmm & x)1077 void vmovss(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_N4 | T_F3 | T_0F | T_EW0 | T_EVEX | T_M_K, 0x11); }
vmovss(const Xmm & x,const Address & addr)1078 void vmovss(const Xmm& x, const Address& addr) { opAVX_X_X_XM(x, xm0, addr, T_N4 | T_F3 | T_0F | T_EW0 | T_EVEX, 0x10); }
1079 void vmovss(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) throw Error(ERR_BAD_COMBINATION); opAVX_X_X_XM(x1, x2, op, T_N4 | T_F3 | T_0F | T_EW0 | T_EVEX, 0x10); }
vmovupd(const Address & addr,const Xmm & xmm)1080 void vmovupd(const Address& addr, const Xmm& xmm) { opAVX_X_XM_IMM(xmm, addr, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_M_K, 0x11); }
vmovupd(const Xmm & xm,const Operand & op)1081 void vmovupd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX, 0x10); }
vmovups(const Address & addr,const Xmm & xmm)1082 void vmovups(const Address& addr, const Xmm& xmm) { opAVX_X_XM_IMM(xmm, addr, T_0F | T_EW0 | T_YMM | T_EVEX | T_M_K, 0x11); }
vmovups(const Xmm & xm,const Operand & op)1083 void vmovups(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_0F | T_EW0 | T_YMM | T_EVEX, 0x10); }
vmpsadbw(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1084 void vmpsadbw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM, 0x42, imm); }
1085 void vmulpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x59); }
1086 void vmulps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x59); }
1087 void vmulsd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F2 | T_EW1 | T_EVEX | T_ER_Z | T_N8, 0x59); }
1088 void vmulss(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F3 | T_EW0 | T_EVEX | T_ER_Z | T_N4, 0x59); }
1089 void vorpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x56); }
1090 void vorps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x56); }
vpabsb(const Xmm & xm,const Operand & op)1091 void vpabsb(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x1C); }
vpabsd(const Xmm & xm,const Operand & op)1092 void vpabsd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x1E); }
vpabsw(const Xmm & xm,const Operand & op)1093 void vpabsw(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x1D); }
vpackssdw(const Xmm & x1,const Xmm & x2,const Operand & op)1094 void vpackssdw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0x6B); }
vpacksswb(const Xmm & x1,const Xmm & x2,const Operand & op)1095 void vpacksswb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0x63); }
vpackusdw(const Xmm & x1,const Xmm & x2,const Operand & op)1096 void vpackusdw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x2B); }
vpackuswb(const Xmm & x1,const Xmm & x2,const Operand & op)1097 void vpackuswb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0x67); }
vpaddb(const Xmm & x1,const Xmm & x2,const Operand & op)1098 void vpaddb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xFC); }
vpaddd(const Xmm & x1,const Xmm & x2,const Operand & op)1099 void vpaddd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0xFE); }
vpaddq(const Xmm & x1,const Xmm & x2,const Operand & op)1100 void vpaddq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0xD4); }
vpaddsb(const Xmm & x1,const Xmm & x2,const Operand & op)1101 void vpaddsb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xEC); }
vpaddsw(const Xmm & x1,const Xmm & x2,const Operand & op)1102 void vpaddsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xED); }
vpaddusb(const Xmm & x1,const Xmm & x2,const Operand & op)1103 void vpaddusb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xDC); }
vpaddusw(const Xmm & x1,const Xmm & x2,const Operand & op)1104 void vpaddusw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xDD); }
vpaddw(const Xmm & x1,const Xmm & x2,const Operand & op)1105 void vpaddw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xFD); }
vpalignr(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1106 void vpalignr(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_YMM | T_EVEX, 0x0F, imm); }
vpand(const Xmm & x1,const Xmm & x2,const Operand & op)1107 void vpand(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0xDB); }
vpandn(const Xmm & x1,const Xmm & x2,const Operand & op)1108 void vpandn(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0xDF); }
vpavgb(const Xmm & x1,const Xmm & x2,const Operand & op)1109 void vpavgb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xE0); }
vpavgw(const Xmm & x1,const Xmm & x2,const Operand & op)1110 void vpavgw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xE3); }
vpblendd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1111 void vpblendd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM, 0x02, imm); }
vpblendvb(const Xmm & x1,const Xmm & x2,const Operand & op,const Xmm & x4)1112 void vpblendvb(const Xmm& x1, const Xmm& x2, const Operand& op, const Xmm& x4) { opAVX_X_X_XM(x1, x2, op, T_0F3A | T_66 | T_YMM, 0x4C, x4.getIdx() << 4); }
vpblendw(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1113 void vpblendw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM, 0x0E, imm); }
vpbroadcastb(const Xmm & x,const Operand & op)1114 void vpbroadcastb(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) throw Error(ERR_BAD_COMBINATION); opAVX_X_XM_IMM(x, op, T_N1 | T_66 | T_0F38 | T_W0 | T_YMM | T_EVEX, 0x78); }
vpbroadcastd(const Xmm & x,const Operand & op)1115 void vpbroadcastd(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) throw Error(ERR_BAD_COMBINATION); opAVX_X_XM_IMM(x, op, T_N4 | T_66 | T_0F38 | T_W0 | T_YMM | T_EVEX, 0x58); }
vpbroadcastq(const Xmm & x,const Operand & op)1116 void vpbroadcastq(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) throw Error(ERR_BAD_COMBINATION); opAVX_X_XM_IMM(x, op, T_N8 | T_66 | T_0F38 | T_W0 | T_EW1 | T_YMM | T_EVEX, 0x59); }
vpbroadcastw(const Xmm & x,const Operand & op)1117 void vpbroadcastw(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) throw Error(ERR_BAD_COMBINATION); opAVX_X_XM_IMM(x, op, T_N2 | T_66 | T_0F38 | T_W0 | T_YMM | T_EVEX, 0x79); }
vpclmulqdq(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1118 void vpclmulqdq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0 | T_YMM | T_EVEX, 0x44, imm); }
vpcmpeqb(const Xmm & x1,const Xmm & x2,const Operand & op)1119 void vpcmpeqb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0x74); }
vpcmpeqd(const Xmm & x1,const Xmm & x2,const Operand & op)1120 void vpcmpeqd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0x76); }
vpcmpeqq(const Xmm & x1,const Xmm & x2,const Operand & op)1121 void vpcmpeqq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x29); }
vpcmpeqw(const Xmm & x1,const Xmm & x2,const Operand & op)1122 void vpcmpeqw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0x75); }
vpcmpestri(const Xmm & xm,const Operand & op,uint8 imm)1123 void vpcmpestri(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A, 0x61, imm); }
vpcmpestrm(const Xmm & xm,const Operand & op,uint8 imm)1124 void vpcmpestrm(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A, 0x60, imm); }
vpcmpgtb(const Xmm & x1,const Xmm & x2,const Operand & op)1125 void vpcmpgtb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0x64); }
vpcmpgtd(const Xmm & x1,const Xmm & x2,const Operand & op)1126 void vpcmpgtd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0x66); }
vpcmpgtq(const Xmm & x1,const Xmm & x2,const Operand & op)1127 void vpcmpgtq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x37); }
vpcmpgtw(const Xmm & x1,const Xmm & x2,const Operand & op)1128 void vpcmpgtw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0x65); }
vpcmpistri(const Xmm & xm,const Operand & op,uint8 imm)1129 void vpcmpistri(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A, 0x63, imm); }
vpcmpistrm(const Xmm & xm,const Operand & op,uint8 imm)1130 void vpcmpistrm(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A, 0x62, imm); }
vperm2f128(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1131 void vperm2f128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isYMEM())) throw Error(ERR_BAD_COMBINATION); opVex(y1, &y2, op, T_0F3A | T_66 | T_W0 | T_YMM, 0x06, imm); }
vperm2i128(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1132 void vperm2i128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isYMEM())) throw Error(ERR_BAD_COMBINATION); opVex(y1, &y2, op, T_0F3A | T_66 | T_W0 | T_YMM, 0x46, imm); }
vpermd(const Ymm & y1,const Ymm & y2,const Operand & op)1133 void vpermd(const Ymm& y1, const Ymm& y2, const Operand& op) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x36); }
vpermilpd(const Xmm & x1,const Xmm & x2,const Operand & op)1134 void vpermilpd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x0D); }
vpermilpd(const Xmm & xm,const Operand & op,uint8 imm)1135 void vpermilpd(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_EVEX | T_B64, 0x05, imm); }
vpermilps(const Xmm & x1,const Xmm & x2,const Operand & op)1136 void vpermilps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x0C); }
vpermilps(const Xmm & xm,const Operand & op,uint8 imm)1137 void vpermilps(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_EVEX | T_B32, 0x04, imm); }
vpermpd(const Ymm & y,const Operand & op,uint8 imm)1138 void vpermpd(const Ymm& y, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(y, op, T_66 | T_0F3A | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x01, imm); }
vpermpd(const Ymm & y1,const Ymm & y2,const Operand & op)1139 void vpermpd(const Ymm& y1, const Ymm& y2, const Operand& op) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x16); }
vpermps(const Ymm & y1,const Ymm & y2,const Operand & op)1140 void vpermps(const Ymm& y1, const Ymm& y2, const Operand& op) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x16); }
vpermq(const Ymm & y,const Operand & op,uint8 imm)1141 void vpermq(const Ymm& y, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(y, op, T_66 | T_0F3A | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x00, imm); }
vpermq(const Ymm & y1,const Ymm & y2,const Operand & op)1142 void vpermq(const Ymm& y1, const Ymm& y2, const Operand& op) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F38 | T_W0 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x36); }
vpextrb(const Operand & op,const Xmm & x,uint8 imm)1143 void vpextrb(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(8|16|i32e) || op.isMEM()) && x.isXMM())) throw Error(ERR_BAD_COMBINATION); opVex(x, 0, op, T_0F3A | T_66 | T_EVEX | T_N1, 0x14, imm); }
vpextrd(const Operand & op,const Xmm & x,uint8 imm)1144 void vpextrd(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(32) || op.isMEM()) && x.isXMM())) throw Error(ERR_BAD_COMBINATION); opVex(x, 0, op, T_0F3A | T_66 | T_W0 | T_EVEX | T_EW0 | T_N4, 0x16, imm); }
vpextrq(const Operand & op,const Xmm & x,uint8 imm)1145 void vpextrq(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(64) || op.isMEM()) && x.isXMM())) throw Error(ERR_BAD_COMBINATION); opVex(x, 0, op, T_0F3A | T_66 | T_W1 | T_EVEX | T_EW1 | T_N8, 0x16, imm); }
vpextrw(const Operand & op,const Xmm & x,uint8 imm)1146 void vpextrw(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(16|i32e) || op.isMEM()) && x.isXMM())) throw Error(ERR_BAD_COMBINATION); if (op.isREG() && x.getIdx() < 16) { opAVX_X_X_XM(Xmm(op.getIdx()), xm0, x, T_0F | T_66, 0xC5, imm); } else { opVex(x, 0, op, T_0F3A | T_66 | T_EVEX | T_N2, 0x15, imm); } }
vpgatherdd(const Xmm & x1,const Address & addr,const Xmm & x2)1147 void vpgatherdd(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W0, 0x90, 1); }
vpgatherdq(const Xmm & x1,const Address & addr,const Xmm & x2)1148 void vpgatherdq(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W1, 0x90, 0); }
vpgatherqd(const Xmm & x1,const Address & addr,const Xmm & x2)1149 void vpgatherqd(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W0, 0x91, 2); }
vpgatherqq(const Xmm & x1,const Address & addr,const Xmm & x2)1150 void vpgatherqq(const Xmm& x1, const Address& addr, const Xmm& x2) { opGather(x1, addr, x2, T_0F38 | T_66 | T_YMM | T_VSIB | T_W1, 0x91, 1); }
vphaddd(const Xmm & x1,const Xmm & x2,const Operand & op)1151 void vphaddd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x02); }
vphaddsw(const Xmm & x1,const Xmm & x2,const Operand & op)1152 void vphaddsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x03); }
vphaddw(const Xmm & x1,const Xmm & x2,const Operand & op)1153 void vphaddw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x01); }
vphminposuw(const Xmm & xm,const Operand & op)1154 void vphminposuw(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38, 0x41); }
vphsubd(const Xmm & x1,const Xmm & x2,const Operand & op)1155 void vphsubd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x06); }
vphsubsw(const Xmm & x1,const Xmm & x2,const Operand & op)1156 void vphsubsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x07); }
vphsubw(const Xmm & x1,const Xmm & x2,const Operand & op)1157 void vphsubw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x05); }
vpinsrb(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1158 void vpinsrb(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(32) || op.isMEM()))) throw Error(ERR_BAD_COMBINATION); opVex(x1, &x2, op, T_0F3A | T_66 | T_EVEX | T_N1, 0x20, imm); }
vpinsrd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1159 void vpinsrd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(32) || op.isMEM()))) throw Error(ERR_BAD_COMBINATION); opVex(x1, &x2, op, T_0F3A | T_66 | T_W0 | T_EVEX | T_EW0 | T_N4, 0x22, imm); }
vpinsrq(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1160 void vpinsrq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(64) || op.isMEM()))) throw Error(ERR_BAD_COMBINATION); opVex(x1, &x2, op, T_0F3A | T_66 | T_W1 | T_EVEX | T_EW1 | T_N8, 0x22, imm); }
vpinsrw(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1161 void vpinsrw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(32) || op.isMEM()))) throw Error(ERR_BAD_COMBINATION); opVex(x1, &x2, op, T_0F | T_66 | T_EVEX | T_N2, 0xC4, imm); }
vpmaddubsw(const Xmm & x1,const Xmm & x2,const Operand & op)1162 void vpmaddubsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x04); }
vpmaddwd(const Xmm & x1,const Xmm & x2,const Operand & op)1163 void vpmaddwd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xF5); }
vpmaskmovd(const Address & addr,const Xmm & x1,const Xmm & x2)1164 void vpmaskmovd(const Address& addr, const Xmm& x1, const Xmm& x2) { opAVX_X_X_XM(x2, x1, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x8E); }
vpmaskmovd(const Xmm & x1,const Xmm & x2,const Address & addr)1165 void vpmaskmovd(const Xmm& x1, const Xmm& x2, const Address& addr) { opAVX_X_X_XM(x1, x2, addr, T_0F38 | T_66 | T_W0 | T_YMM, 0x8C); }
vpmaskmovq(const Address & addr,const Xmm & x1,const Xmm & x2)1166 void vpmaskmovq(const Address& addr, const Xmm& x1, const Xmm& x2) { opAVX_X_X_XM(x2, x1, addr, T_0F38 | T_66 | T_W1 | T_YMM, 0x8E); }
vpmaskmovq(const Xmm & x1,const Xmm & x2,const Address & addr)1167 void vpmaskmovq(const Xmm& x1, const Xmm& x2, const Address& addr) { opAVX_X_X_XM(x1, x2, addr, T_0F38 | T_66 | T_W1 | T_YMM, 0x8C); }
vpmaxsb(const Xmm & x1,const Xmm & x2,const Operand & op)1168 void vpmaxsb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x3C); }
vpmaxsd(const Xmm & x1,const Xmm & x2,const Operand & op)1169 void vpmaxsd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x3D); }
vpmaxsw(const Xmm & x1,const Xmm & x2,const Operand & op)1170 void vpmaxsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xEE); }
vpmaxub(const Xmm & x1,const Xmm & x2,const Operand & op)1171 void vpmaxub(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xDE); }
vpmaxud(const Xmm & x1,const Xmm & x2,const Operand & op)1172 void vpmaxud(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x3F); }
vpmaxuw(const Xmm & x1,const Xmm & x2,const Operand & op)1173 void vpmaxuw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x3E); }
vpminsb(const Xmm & x1,const Xmm & x2,const Operand & op)1174 void vpminsb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x38); }
vpminsd(const Xmm & x1,const Xmm & x2,const Operand & op)1175 void vpminsd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x39); }
vpminsw(const Xmm & x1,const Xmm & x2,const Operand & op)1176 void vpminsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xEA); }
vpminub(const Xmm & x1,const Xmm & x2,const Operand & op)1177 void vpminub(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xDA); }
vpminud(const Xmm & x1,const Xmm & x2,const Operand & op)1178 void vpminud(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x3B); }
vpminuw(const Xmm & x1,const Xmm & x2,const Operand & op)1179 void vpminuw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x3A); }
vpmovmskb(const Reg32e & r,const Xmm & x)1180 void vpmovmskb(const Reg32e& r, const Xmm& x) { if (!x.is(Operand::XMM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(x.isYMM() ? Ymm(r.getIdx()) : Xmm(r.getIdx()), 0, x, T_0F | T_66 | T_YMM, 0xD7); }
vpmovsxbd(const Xmm & xm,const Operand & op)1181 void vpmovsxbd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N4 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x21); }
vpmovsxbq(const Xmm & xm,const Operand & op)1182 void vpmovsxbq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N2 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x22); }
vpmovsxbw(const Xmm & xm,const Operand & op)1183 void vpmovsxbw(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x20); }
vpmovsxdq(const Xmm & xm,const Operand & op)1184 void vpmovsxdq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_N_VL | T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX, 0x25); }
vpmovsxwd(const Xmm & xm,const Operand & op)1185 void vpmovsxwd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x23); }
vpmovsxwq(const Xmm & xm,const Operand & op)1186 void vpmovsxwq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N4 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x24); }
vpmovzxbd(const Xmm & xm,const Operand & op)1187 void vpmovzxbd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N4 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x31); }
vpmovzxbq(const Xmm & xm,const Operand & op)1188 void vpmovzxbq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N2 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x32); }
vpmovzxbw(const Xmm & xm,const Operand & op)1189 void vpmovzxbw(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x30); }
vpmovzxdq(const Xmm & xm,const Operand & op)1190 void vpmovzxdq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_N_VL | T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX, 0x35); }
vpmovzxwd(const Xmm & xm,const Operand & op)1191 void vpmovzxwd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x33); }
vpmovzxwq(const Xmm & xm,const Operand & op)1192 void vpmovzxwq(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N4 | T_N_VL | T_66 | T_0F38 | T_YMM | T_EVEX, 0x34); }
vpmuldq(const Xmm & x1,const Xmm & x2,const Operand & op)1193 void vpmuldq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x28); }
vpmulhrsw(const Xmm & x1,const Xmm & x2,const Operand & op)1194 void vpmulhrsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x0B); }
vpmulhuw(const Xmm & x1,const Xmm & x2,const Operand & op)1195 void vpmulhuw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xE4); }
vpmulhw(const Xmm & x1,const Xmm & x2,const Operand & op)1196 void vpmulhw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xE5); }
vpmulld(const Xmm & x1,const Xmm & x2,const Operand & op)1197 void vpmulld(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x40); }
vpmullw(const Xmm & x1,const Xmm & x2,const Operand & op)1198 void vpmullw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xD5); }
vpmuludq(const Xmm & x1,const Xmm & x2,const Operand & op)1199 void vpmuludq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0xF4); }
vpor(const Xmm & x1,const Xmm & x2,const Operand & op)1200 void vpor(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0xEB); }
vpsadbw(const Xmm & x1,const Xmm & x2,const Operand & op)1201 void vpsadbw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xF6); }
vpshufb(const Xmm & x1,const Xmm & x2,const Operand & op)1202 void vpshufb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM | T_EVEX, 0x00); }
vpshufd(const Xmm & xm,const Operand & op,uint8 imm)1203 void vpshufd(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0x70, imm); }
vpshufhw(const Xmm & xm,const Operand & op,uint8 imm)1204 void vpshufhw(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_F3 | T_0F | T_YMM | T_EVEX, 0x70, imm); }
vpshuflw(const Xmm & xm,const Operand & op,uint8 imm)1205 void vpshuflw(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_F2 | T_0F | T_YMM | T_EVEX, 0x70, imm); }
vpsignb(const Xmm & x1,const Xmm & x2,const Operand & op)1206 void vpsignb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x08); }
vpsignd(const Xmm & x1,const Xmm & x2,const Operand & op)1207 void vpsignd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x0A); }
vpsignw(const Xmm & x1,const Xmm & x2,const Operand & op)1208 void vpsignw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_YMM, 0x09); }
vpslld(const Xmm & x,const Operand & op,uint8 imm)1209 void vpslld(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 6), x, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32 | T_MEM_EVEX, 0x72, imm); }
vpslld(const Xmm & x1,const Xmm & x2,const Operand & op)1210 void vpslld(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_EW0 | T_YMM | T_EVEX, 0xF2); }
vpslldq(const Xmm & x,const Operand & op,uint8 imm)1211 void vpslldq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 7), x, op, T_66 | T_0F | T_YMM | T_EVEX | T_MEM_EVEX, 0x73, imm); }
vpsllq(const Xmm & x,const Operand & op,uint8 imm)1212 void vpsllq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 6), x, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64 | T_MEM_EVEX, 0x73, imm); }
vpsllq(const Xmm & x1,const Xmm & x2,const Operand & op)1213 void vpsllq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_EW1 | T_YMM | T_EVEX, 0xF3); }
vpsllvd(const Xmm & x1,const Xmm & x2,const Operand & op)1214 void vpsllvd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x47); }
vpsllvq(const Xmm & x1,const Xmm & x2,const Operand & op)1215 void vpsllvq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x47); }
vpsllw(const Xmm & x,const Operand & op,uint8 imm)1216 void vpsllw(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 6), x, op, T_66 | T_0F | T_YMM | T_EVEX | T_MEM_EVEX, 0x71, imm); }
vpsllw(const Xmm & x1,const Xmm & x2,const Operand & op)1217 void vpsllw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_YMM | T_EVEX, 0xF1); }
vpsrad(const Xmm & x,const Operand & op,uint8 imm)1218 void vpsrad(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 4), x, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32 | T_MEM_EVEX, 0x72, imm); }
vpsrad(const Xmm & x1,const Xmm & x2,const Operand & op)1219 void vpsrad(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_EW0 | T_YMM | T_EVEX, 0xE2); }
vpsravd(const Xmm & x1,const Xmm & x2,const Operand & op)1220 void vpsravd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x46); }
vpsraw(const Xmm & x,const Operand & op,uint8 imm)1221 void vpsraw(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 4), x, op, T_66 | T_0F | T_YMM | T_EVEX | T_MEM_EVEX, 0x71, imm); }
vpsraw(const Xmm & x1,const Xmm & x2,const Operand & op)1222 void vpsraw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_YMM | T_EVEX, 0xE1); }
vpsrld(const Xmm & x,const Operand & op,uint8 imm)1223 void vpsrld(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 2), x, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32 | T_MEM_EVEX, 0x72, imm); }
vpsrld(const Xmm & x1,const Xmm & x2,const Operand & op)1224 void vpsrld(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_EW0 | T_YMM | T_EVEX, 0xD2); }
vpsrldq(const Xmm & x,const Operand & op,uint8 imm)1225 void vpsrldq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 3), x, op, T_66 | T_0F | T_YMM | T_EVEX | T_MEM_EVEX, 0x73, imm); }
vpsrlq(const Xmm & x,const Operand & op,uint8 imm)1226 void vpsrlq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 2), x, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64 | T_MEM_EVEX, 0x73, imm); }
vpsrlq(const Xmm & x1,const Xmm & x2,const Operand & op)1227 void vpsrlq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_EW1 | T_YMM | T_EVEX, 0xD3); }
vpsrlvd(const Xmm & x1,const Xmm & x2,const Operand & op)1228 void vpsrlvd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W0 | T_EW0 | T_YMM | T_EVEX | T_B32, 0x45); }
vpsrlvq(const Xmm & x1,const Xmm & x2,const Operand & op)1229 void vpsrlvq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_W1 | T_EW1 | T_YMM | T_EVEX | T_B64, 0x45); }
vpsrlw(const Xmm & x,const Operand & op,uint8 imm)1230 void vpsrlw(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 2), x, op, T_66 | T_0F | T_YMM | T_EVEX | T_MEM_EVEX, 0x71, imm); }
vpsrlw(const Xmm & x1,const Xmm & x2,const Operand & op)1231 void vpsrlw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_YMM | T_EVEX, 0xD1); }
vpsubb(const Xmm & x1,const Xmm & x2,const Operand & op)1232 void vpsubb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xF8); }
vpsubd(const Xmm & x1,const Xmm & x2,const Operand & op)1233 void vpsubd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0xFA); }
vpsubq(const Xmm & x1,const Xmm & x2,const Operand & op)1234 void vpsubq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0xFB); }
vpsubsb(const Xmm & x1,const Xmm & x2,const Operand & op)1235 void vpsubsb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xE8); }
vpsubsw(const Xmm & x1,const Xmm & x2,const Operand & op)1236 void vpsubsw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xE9); }
vpsubusb(const Xmm & x1,const Xmm & x2,const Operand & op)1237 void vpsubusb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xD8); }
vpsubusw(const Xmm & x1,const Xmm & x2,const Operand & op)1238 void vpsubusw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xD9); }
vpsubw(const Xmm & x1,const Xmm & x2,const Operand & op)1239 void vpsubw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0xF9); }
vptest(const Xmm & xm,const Operand & op)1240 void vptest(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_YMM, 0x17); }
vpunpckhbw(const Xmm & x1,const Xmm & x2,const Operand & op)1241 void vpunpckhbw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0x68); }
vpunpckhdq(const Xmm & x1,const Xmm & x2,const Operand & op)1242 void vpunpckhdq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0x6A); }
vpunpckhqdq(const Xmm & x1,const Xmm & x2,const Operand & op)1243 void vpunpckhqdq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0x6D); }
vpunpckhwd(const Xmm & x1,const Xmm & x2,const Operand & op)1244 void vpunpckhwd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0x69); }
vpunpcklbw(const Xmm & x1,const Xmm & x2,const Operand & op)1245 void vpunpcklbw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0x60); }
vpunpckldq(const Xmm & x1,const Xmm & x2,const Operand & op)1246 void vpunpckldq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0x62); }
vpunpcklqdq(const Xmm & x1,const Xmm & x2,const Operand & op)1247 void vpunpcklqdq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0x6C); }
vpunpcklwd(const Xmm & x1,const Xmm & x2,const Operand & op)1248 void vpunpcklwd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM | T_EVEX, 0x61); }
vpxor(const Xmm & x1,const Xmm & x2,const Operand & op)1249 void vpxor(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_YMM, 0xEF); }
vrcpps(const Xmm & xm,const Operand & op)1250 void vrcpps(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_0F | T_YMM, 0x53); }
vrcpss(const Xmm & x1,const Xmm & x2,const Operand & op)1251 void vrcpss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_F3 | T_0F, 0x53); }
vroundpd(const Xmm & xm,const Operand & op,uint8 imm)1252 void vroundpd(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A | T_YMM, 0x09, imm); }
vroundps(const Xmm & xm,const Operand & op,uint8 imm)1253 void vroundps(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A | T_YMM, 0x08, imm); }
vroundsd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1254 void vroundsd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0, 0x0B, imm); }
vroundss(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1255 void vroundss(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_W0, 0x0A, imm); }
vrsqrtps(const Xmm & xm,const Operand & op)1256 void vrsqrtps(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_0F | T_YMM, 0x52); }
vrsqrtss(const Xmm & x1,const Xmm & x2,const Operand & op)1257 void vrsqrtss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_F3 | T_0F, 0x52); }
vshufpd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1258 void vshufpd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0xC6, imm); }
vshufps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1259 void vshufps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0xC6, imm); }
vsqrtpd(const Xmm & xm,const Operand & op)1260 void vsqrtpd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x51); }
vsqrtps(const Xmm & xm,const Operand & op)1261 void vsqrtps(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x51); }
vsqrtsd(const Xmm & x1,const Xmm & x2,const Operand & op)1262 void vsqrtsd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_F2 | T_0F | T_EW1 | T_EVEX | T_ER_X, 0x51); }
vsqrtss(const Xmm & x1,const Xmm & x2,const Operand & op)1263 void vsqrtss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_F3 | T_0F | T_EW0 | T_EVEX | T_ER_X, 0x51); }
vstmxcsr(const Address & addr)1264 void vstmxcsr(const Address& addr) { opAVX_X_X_XM(xm3, xm0, addr, T_0F, 0xAE); }
1265 void vsubpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x5C); }
1266 void vsubps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x5C); }
1267 void vsubsd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F2 | T_EW1 | T_EVEX | T_ER_Z | T_N8, 0x5C); }
1268 void vsubss(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_F3 | T_EW0 | T_EVEX | T_ER_Z | T_N4, 0x5C); }
vtestpd(const Xmm & xm,const Operand & op)1269 void vtestpd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_YMM, 0x0F); }
vtestps(const Xmm & xm,const Operand & op)1270 void vtestps(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F38 | T_YMM, 0x0E); }
vucomisd(const Xmm & xm,const Operand & op)1271 void vucomisd(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N8 | T_66 | T_0F | T_EW1 | T_EVEX | T_SAE_X, 0x2E); }
vucomiss(const Xmm & xm,const Operand & op)1272 void vucomiss(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_N4 | T_0F | T_EW0 | T_EVEX | T_SAE_X, 0x2E); }
vunpckhpd(const Xmm & x1,const Xmm & x2,const Operand & op)1273 void vunpckhpd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0x15); }
vunpckhps(const Xmm & x1,const Xmm & x2,const Operand & op)1274 void vunpckhps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0x15); }
vunpcklpd(const Xmm & x1,const Xmm & x2,const Operand & op)1275 void vunpcklpd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_EVEX | T_B64, 0x14); }
vunpcklps(const Xmm & x1,const Xmm & x2,const Operand & op)1276 void vunpcklps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_0F | T_EW0 | T_YMM | T_EVEX | T_B32, 0x14); }
1277 void vxorpd(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_66 | T_EW1 | T_YMM | T_EVEX | T_ER_Z | T_B64, 0x57); }
1278 void vxorps(const Xmm& xmm, const Operand& op1, const Operand& op2 = Operand()) { opAVX_X_X_XM(xmm, op1, op2, T_0F | T_EW0 | T_YMM | T_EVEX | T_ER_Z | T_B32, 0x57); }
vzeroall()1279 void vzeroall() { db(0xC5); db(0xFC); db(0x77); }
vzeroupper()1280 void vzeroupper() { db(0xC5); db(0xF8); db(0x77); }
wait()1281 void wait() { db(0x9B); }
wbinvd()1282 void wbinvd() { db(0x0F); db(0x09); }
wrmsr()1283 void wrmsr() { db(0x0F); db(0x30); }
xadd(const Operand & op,const Reg & reg)1284 void xadd(const Operand& op, const Reg& reg) { opModRM(reg, op, (op.isREG() && reg.isREG() && op.getBit() == reg.getBit()), op.isMEM(), 0x0F, 0xC0 | (reg.isBit(8) ? 0 : 1)); }
xgetbv()1285 void xgetbv() { db(0x0F); db(0x01); db(0xD0); }
xlatb()1286 void xlatb() { db(0xD7); }
xor_(const Operand & op,uint32 imm)1287 void xor_(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x30, 6); }
xor_(const Operand & op1,const Operand & op2)1288 void xor_(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x30); }
xorpd(const Xmm & xmm,const Operand & op)1289 void xorpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x57, 0x66, isXMM_XMMorMEM); }
xorps(const Xmm & xmm,const Operand & op)1290 void xorps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x57, 0x100, isXMM_XMMorMEM); }
1291 #ifdef XBYAK_ENABLE_OMITTED_OPERAND
vblendpd(const Xmm & x,const Operand & op,uint8 imm)1292 void vblendpd(const Xmm& x, const Operand& op, uint8 imm) { vblendpd(x, x, op, imm); }
vblendps(const Xmm & x,const Operand & op,uint8 imm)1293 void vblendps(const Xmm& x, const Operand& op, uint8 imm) { vblendps(x, x, op, imm); }
vblendvpd(const Xmm & x1,const Operand & op,const Xmm & x4)1294 void vblendvpd(const Xmm& x1, const Operand& op, const Xmm& x4) { vblendvpd(x1, x1, op, x4); }
vblendvps(const Xmm & x1,const Operand & op,const Xmm & x4)1295 void vblendvps(const Xmm& x1, const Operand& op, const Xmm& x4) { vblendvps(x1, x1, op, x4); }
vcmpeq_ospd(const Xmm & x,const Operand & op)1296 void vcmpeq_ospd(const Xmm& x, const Operand& op) { vcmpeq_ospd(x, x, op); }
vcmpeq_osps(const Xmm & x,const Operand & op)1297 void vcmpeq_osps(const Xmm& x, const Operand& op) { vcmpeq_osps(x, x, op); }
vcmpeq_ossd(const Xmm & x,const Operand & op)1298 void vcmpeq_ossd(const Xmm& x, const Operand& op) { vcmpeq_ossd(x, x, op); }
vcmpeq_osss(const Xmm & x,const Operand & op)1299 void vcmpeq_osss(const Xmm& x, const Operand& op) { vcmpeq_osss(x, x, op); }
vcmpeq_uqpd(const Xmm & x,const Operand & op)1300 void vcmpeq_uqpd(const Xmm& x, const Operand& op) { vcmpeq_uqpd(x, x, op); }
vcmpeq_uqps(const Xmm & x,const Operand & op)1301 void vcmpeq_uqps(const Xmm& x, const Operand& op) { vcmpeq_uqps(x, x, op); }
vcmpeq_uqsd(const Xmm & x,const Operand & op)1302 void vcmpeq_uqsd(const Xmm& x, const Operand& op) { vcmpeq_uqsd(x, x, op); }
vcmpeq_uqss(const Xmm & x,const Operand & op)1303 void vcmpeq_uqss(const Xmm& x, const Operand& op) { vcmpeq_uqss(x, x, op); }
vcmpeq_uspd(const Xmm & x,const Operand & op)1304 void vcmpeq_uspd(const Xmm& x, const Operand& op) { vcmpeq_uspd(x, x, op); }
vcmpeq_usps(const Xmm & x,const Operand & op)1305 void vcmpeq_usps(const Xmm& x, const Operand& op) { vcmpeq_usps(x, x, op); }
vcmpeq_ussd(const Xmm & x,const Operand & op)1306 void vcmpeq_ussd(const Xmm& x, const Operand& op) { vcmpeq_ussd(x, x, op); }
vcmpeq_usss(const Xmm & x,const Operand & op)1307 void vcmpeq_usss(const Xmm& x, const Operand& op) { vcmpeq_usss(x, x, op); }
vcmpeqpd(const Xmm & x,const Operand & op)1308 void vcmpeqpd(const Xmm& x, const Operand& op) { vcmpeqpd(x, x, op); }
vcmpeqps(const Xmm & x,const Operand & op)1309 void vcmpeqps(const Xmm& x, const Operand& op) { vcmpeqps(x, x, op); }
vcmpeqsd(const Xmm & x,const Operand & op)1310 void vcmpeqsd(const Xmm& x, const Operand& op) { vcmpeqsd(x, x, op); }
vcmpeqss(const Xmm & x,const Operand & op)1311 void vcmpeqss(const Xmm& x, const Operand& op) { vcmpeqss(x, x, op); }
vcmpfalse_ospd(const Xmm & x,const Operand & op)1312 void vcmpfalse_ospd(const Xmm& x, const Operand& op) { vcmpfalse_ospd(x, x, op); }
vcmpfalse_osps(const Xmm & x,const Operand & op)1313 void vcmpfalse_osps(const Xmm& x, const Operand& op) { vcmpfalse_osps(x, x, op); }
vcmpfalse_ossd(const Xmm & x,const Operand & op)1314 void vcmpfalse_ossd(const Xmm& x, const Operand& op) { vcmpfalse_ossd(x, x, op); }
vcmpfalse_osss(const Xmm & x,const Operand & op)1315 void vcmpfalse_osss(const Xmm& x, const Operand& op) { vcmpfalse_osss(x, x, op); }
vcmpfalsepd(const Xmm & x,const Operand & op)1316 void vcmpfalsepd(const Xmm& x, const Operand& op) { vcmpfalsepd(x, x, op); }
vcmpfalseps(const Xmm & x,const Operand & op)1317 void vcmpfalseps(const Xmm& x, const Operand& op) { vcmpfalseps(x, x, op); }
vcmpfalsesd(const Xmm & x,const Operand & op)1318 void vcmpfalsesd(const Xmm& x, const Operand& op) { vcmpfalsesd(x, x, op); }
vcmpfalsess(const Xmm & x,const Operand & op)1319 void vcmpfalsess(const Xmm& x, const Operand& op) { vcmpfalsess(x, x, op); }
vcmpge_oqpd(const Xmm & x,const Operand & op)1320 void vcmpge_oqpd(const Xmm& x, const Operand& op) { vcmpge_oqpd(x, x, op); }
vcmpge_oqps(const Xmm & x,const Operand & op)1321 void vcmpge_oqps(const Xmm& x, const Operand& op) { vcmpge_oqps(x, x, op); }
vcmpge_oqsd(const Xmm & x,const Operand & op)1322 void vcmpge_oqsd(const Xmm& x, const Operand& op) { vcmpge_oqsd(x, x, op); }
vcmpge_oqss(const Xmm & x,const Operand & op)1323 void vcmpge_oqss(const Xmm& x, const Operand& op) { vcmpge_oqss(x, x, op); }
vcmpgepd(const Xmm & x,const Operand & op)1324 void vcmpgepd(const Xmm& x, const Operand& op) { vcmpgepd(x, x, op); }
vcmpgeps(const Xmm & x,const Operand & op)1325 void vcmpgeps(const Xmm& x, const Operand& op) { vcmpgeps(x, x, op); }
vcmpgesd(const Xmm & x,const Operand & op)1326 void vcmpgesd(const Xmm& x, const Operand& op) { vcmpgesd(x, x, op); }
vcmpgess(const Xmm & x,const Operand & op)1327 void vcmpgess(const Xmm& x, const Operand& op) { vcmpgess(x, x, op); }
vcmpgt_oqpd(const Xmm & x,const Operand & op)1328 void vcmpgt_oqpd(const Xmm& x, const Operand& op) { vcmpgt_oqpd(x, x, op); }
vcmpgt_oqps(const Xmm & x,const Operand & op)1329 void vcmpgt_oqps(const Xmm& x, const Operand& op) { vcmpgt_oqps(x, x, op); }
vcmpgt_oqsd(const Xmm & x,const Operand & op)1330 void vcmpgt_oqsd(const Xmm& x, const Operand& op) { vcmpgt_oqsd(x, x, op); }
vcmpgt_oqss(const Xmm & x,const Operand & op)1331 void vcmpgt_oqss(const Xmm& x, const Operand& op) { vcmpgt_oqss(x, x, op); }
vcmpgtpd(const Xmm & x,const Operand & op)1332 void vcmpgtpd(const Xmm& x, const Operand& op) { vcmpgtpd(x, x, op); }
vcmpgtps(const Xmm & x,const Operand & op)1333 void vcmpgtps(const Xmm& x, const Operand& op) { vcmpgtps(x, x, op); }
vcmpgtsd(const Xmm & x,const Operand & op)1334 void vcmpgtsd(const Xmm& x, const Operand& op) { vcmpgtsd(x, x, op); }
vcmpgtss(const Xmm & x,const Operand & op)1335 void vcmpgtss(const Xmm& x, const Operand& op) { vcmpgtss(x, x, op); }
vcmple_oqpd(const Xmm & x,const Operand & op)1336 void vcmple_oqpd(const Xmm& x, const Operand& op) { vcmple_oqpd(x, x, op); }
vcmple_oqps(const Xmm & x,const Operand & op)1337 void vcmple_oqps(const Xmm& x, const Operand& op) { vcmple_oqps(x, x, op); }
vcmple_oqsd(const Xmm & x,const Operand & op)1338 void vcmple_oqsd(const Xmm& x, const Operand& op) { vcmple_oqsd(x, x, op); }
vcmple_oqss(const Xmm & x,const Operand & op)1339 void vcmple_oqss(const Xmm& x, const Operand& op) { vcmple_oqss(x, x, op); }
vcmplepd(const Xmm & x,const Operand & op)1340 void vcmplepd(const Xmm& x, const Operand& op) { vcmplepd(x, x, op); }
vcmpleps(const Xmm & x,const Operand & op)1341 void vcmpleps(const Xmm& x, const Operand& op) { vcmpleps(x, x, op); }
vcmplesd(const Xmm & x,const Operand & op)1342 void vcmplesd(const Xmm& x, const Operand& op) { vcmplesd(x, x, op); }
vcmpless(const Xmm & x,const Operand & op)1343 void vcmpless(const Xmm& x, const Operand& op) { vcmpless(x, x, op); }
vcmplt_oqpd(const Xmm & x,const Operand & op)1344 void vcmplt_oqpd(const Xmm& x, const Operand& op) { vcmplt_oqpd(x, x, op); }
vcmplt_oqps(const Xmm & x,const Operand & op)1345 void vcmplt_oqps(const Xmm& x, const Operand& op) { vcmplt_oqps(x, x, op); }
vcmplt_oqsd(const Xmm & x,const Operand & op)1346 void vcmplt_oqsd(const Xmm& x, const Operand& op) { vcmplt_oqsd(x, x, op); }
vcmplt_oqss(const Xmm & x,const Operand & op)1347 void vcmplt_oqss(const Xmm& x, const Operand& op) { vcmplt_oqss(x, x, op); }
vcmpltpd(const Xmm & x,const Operand & op)1348 void vcmpltpd(const Xmm& x, const Operand& op) { vcmpltpd(x, x, op); }
vcmpltps(const Xmm & x,const Operand & op)1349 void vcmpltps(const Xmm& x, const Operand& op) { vcmpltps(x, x, op); }
vcmpltsd(const Xmm & x,const Operand & op)1350 void vcmpltsd(const Xmm& x, const Operand& op) { vcmpltsd(x, x, op); }
vcmpltss(const Xmm & x,const Operand & op)1351 void vcmpltss(const Xmm& x, const Operand& op) { vcmpltss(x, x, op); }
vcmpneq_oqpd(const Xmm & x,const Operand & op)1352 void vcmpneq_oqpd(const Xmm& x, const Operand& op) { vcmpneq_oqpd(x, x, op); }
vcmpneq_oqps(const Xmm & x,const Operand & op)1353 void vcmpneq_oqps(const Xmm& x, const Operand& op) { vcmpneq_oqps(x, x, op); }
vcmpneq_oqsd(const Xmm & x,const Operand & op)1354 void vcmpneq_oqsd(const Xmm& x, const Operand& op) { vcmpneq_oqsd(x, x, op); }
vcmpneq_oqss(const Xmm & x,const Operand & op)1355 void vcmpneq_oqss(const Xmm& x, const Operand& op) { vcmpneq_oqss(x, x, op); }
vcmpneq_ospd(const Xmm & x,const Operand & op)1356 void vcmpneq_ospd(const Xmm& x, const Operand& op) { vcmpneq_ospd(x, x, op); }
vcmpneq_osps(const Xmm & x,const Operand & op)1357 void vcmpneq_osps(const Xmm& x, const Operand& op) { vcmpneq_osps(x, x, op); }
vcmpneq_ossd(const Xmm & x,const Operand & op)1358 void vcmpneq_ossd(const Xmm& x, const Operand& op) { vcmpneq_ossd(x, x, op); }
vcmpneq_osss(const Xmm & x,const Operand & op)1359 void vcmpneq_osss(const Xmm& x, const Operand& op) { vcmpneq_osss(x, x, op); }
vcmpneq_uspd(const Xmm & x,const Operand & op)1360 void vcmpneq_uspd(const Xmm& x, const Operand& op) { vcmpneq_uspd(x, x, op); }
vcmpneq_usps(const Xmm & x,const Operand & op)1361 void vcmpneq_usps(const Xmm& x, const Operand& op) { vcmpneq_usps(x, x, op); }
vcmpneq_ussd(const Xmm & x,const Operand & op)1362 void vcmpneq_ussd(const Xmm& x, const Operand& op) { vcmpneq_ussd(x, x, op); }
vcmpneq_usss(const Xmm & x,const Operand & op)1363 void vcmpneq_usss(const Xmm& x, const Operand& op) { vcmpneq_usss(x, x, op); }
vcmpneqpd(const Xmm & x,const Operand & op)1364 void vcmpneqpd(const Xmm& x, const Operand& op) { vcmpneqpd(x, x, op); }
vcmpneqps(const Xmm & x,const Operand & op)1365 void vcmpneqps(const Xmm& x, const Operand& op) { vcmpneqps(x, x, op); }
vcmpneqsd(const Xmm & x,const Operand & op)1366 void vcmpneqsd(const Xmm& x, const Operand& op) { vcmpneqsd(x, x, op); }
vcmpneqss(const Xmm & x,const Operand & op)1367 void vcmpneqss(const Xmm& x, const Operand& op) { vcmpneqss(x, x, op); }
vcmpnge_uqpd(const Xmm & x,const Operand & op)1368 void vcmpnge_uqpd(const Xmm& x, const Operand& op) { vcmpnge_uqpd(x, x, op); }
vcmpnge_uqps(const Xmm & x,const Operand & op)1369 void vcmpnge_uqps(const Xmm& x, const Operand& op) { vcmpnge_uqps(x, x, op); }
vcmpnge_uqsd(const Xmm & x,const Operand & op)1370 void vcmpnge_uqsd(const Xmm& x, const Operand& op) { vcmpnge_uqsd(x, x, op); }
vcmpnge_uqss(const Xmm & x,const Operand & op)1371 void vcmpnge_uqss(const Xmm& x, const Operand& op) { vcmpnge_uqss(x, x, op); }
vcmpngepd(const Xmm & x,const Operand & op)1372 void vcmpngepd(const Xmm& x, const Operand& op) { vcmpngepd(x, x, op); }
vcmpngeps(const Xmm & x,const Operand & op)1373 void vcmpngeps(const Xmm& x, const Operand& op) { vcmpngeps(x, x, op); }
vcmpngesd(const Xmm & x,const Operand & op)1374 void vcmpngesd(const Xmm& x, const Operand& op) { vcmpngesd(x, x, op); }
vcmpngess(const Xmm & x,const Operand & op)1375 void vcmpngess(const Xmm& x, const Operand& op) { vcmpngess(x, x, op); }
vcmpngt_uqpd(const Xmm & x,const Operand & op)1376 void vcmpngt_uqpd(const Xmm& x, const Operand& op) { vcmpngt_uqpd(x, x, op); }
vcmpngt_uqps(const Xmm & x,const Operand & op)1377 void vcmpngt_uqps(const Xmm& x, const Operand& op) { vcmpngt_uqps(x, x, op); }
vcmpngt_uqsd(const Xmm & x,const Operand & op)1378 void vcmpngt_uqsd(const Xmm& x, const Operand& op) { vcmpngt_uqsd(x, x, op); }
vcmpngt_uqss(const Xmm & x,const Operand & op)1379 void vcmpngt_uqss(const Xmm& x, const Operand& op) { vcmpngt_uqss(x, x, op); }
vcmpngtpd(const Xmm & x,const Operand & op)1380 void vcmpngtpd(const Xmm& x, const Operand& op) { vcmpngtpd(x, x, op); }
vcmpngtps(const Xmm & x,const Operand & op)1381 void vcmpngtps(const Xmm& x, const Operand& op) { vcmpngtps(x, x, op); }
vcmpngtsd(const Xmm & x,const Operand & op)1382 void vcmpngtsd(const Xmm& x, const Operand& op) { vcmpngtsd(x, x, op); }
vcmpngtss(const Xmm & x,const Operand & op)1383 void vcmpngtss(const Xmm& x, const Operand& op) { vcmpngtss(x, x, op); }
vcmpnle_uqpd(const Xmm & x,const Operand & op)1384 void vcmpnle_uqpd(const Xmm& x, const Operand& op) { vcmpnle_uqpd(x, x, op); }
vcmpnle_uqps(const Xmm & x,const Operand & op)1385 void vcmpnle_uqps(const Xmm& x, const Operand& op) { vcmpnle_uqps(x, x, op); }
vcmpnle_uqsd(const Xmm & x,const Operand & op)1386 void vcmpnle_uqsd(const Xmm& x, const Operand& op) { vcmpnle_uqsd(x, x, op); }
vcmpnle_uqss(const Xmm & x,const Operand & op)1387 void vcmpnle_uqss(const Xmm& x, const Operand& op) { vcmpnle_uqss(x, x, op); }
vcmpnlepd(const Xmm & x,const Operand & op)1388 void vcmpnlepd(const Xmm& x, const Operand& op) { vcmpnlepd(x, x, op); }
vcmpnleps(const Xmm & x,const Operand & op)1389 void vcmpnleps(const Xmm& x, const Operand& op) { vcmpnleps(x, x, op); }
vcmpnlesd(const Xmm & x,const Operand & op)1390 void vcmpnlesd(const Xmm& x, const Operand& op) { vcmpnlesd(x, x, op); }
vcmpnless(const Xmm & x,const Operand & op)1391 void vcmpnless(const Xmm& x, const Operand& op) { vcmpnless(x, x, op); }
vcmpnlt_uqpd(const Xmm & x,const Operand & op)1392 void vcmpnlt_uqpd(const Xmm& x, const Operand& op) { vcmpnlt_uqpd(x, x, op); }
vcmpnlt_uqps(const Xmm & x,const Operand & op)1393 void vcmpnlt_uqps(const Xmm& x, const Operand& op) { vcmpnlt_uqps(x, x, op); }
vcmpnlt_uqsd(const Xmm & x,const Operand & op)1394 void vcmpnlt_uqsd(const Xmm& x, const Operand& op) { vcmpnlt_uqsd(x, x, op); }
vcmpnlt_uqss(const Xmm & x,const Operand & op)1395 void vcmpnlt_uqss(const Xmm& x, const Operand& op) { vcmpnlt_uqss(x, x, op); }
vcmpnltpd(const Xmm & x,const Operand & op)1396 void vcmpnltpd(const Xmm& x, const Operand& op) { vcmpnltpd(x, x, op); }
vcmpnltps(const Xmm & x,const Operand & op)1397 void vcmpnltps(const Xmm& x, const Operand& op) { vcmpnltps(x, x, op); }
vcmpnltsd(const Xmm & x,const Operand & op)1398 void vcmpnltsd(const Xmm& x, const Operand& op) { vcmpnltsd(x, x, op); }
vcmpnltss(const Xmm & x,const Operand & op)1399 void vcmpnltss(const Xmm& x, const Operand& op) { vcmpnltss(x, x, op); }
vcmpord_spd(const Xmm & x,const Operand & op)1400 void vcmpord_spd(const Xmm& x, const Operand& op) { vcmpord_spd(x, x, op); }
vcmpord_sps(const Xmm & x,const Operand & op)1401 void vcmpord_sps(const Xmm& x, const Operand& op) { vcmpord_sps(x, x, op); }
vcmpord_ssd(const Xmm & x,const Operand & op)1402 void vcmpord_ssd(const Xmm& x, const Operand& op) { vcmpord_ssd(x, x, op); }
vcmpord_sss(const Xmm & x,const Operand & op)1403 void vcmpord_sss(const Xmm& x, const Operand& op) { vcmpord_sss(x, x, op); }
vcmpordpd(const Xmm & x,const Operand & op)1404 void vcmpordpd(const Xmm& x, const Operand& op) { vcmpordpd(x, x, op); }
vcmpordps(const Xmm & x,const Operand & op)1405 void vcmpordps(const Xmm& x, const Operand& op) { vcmpordps(x, x, op); }
vcmpordsd(const Xmm & x,const Operand & op)1406 void vcmpordsd(const Xmm& x, const Operand& op) { vcmpordsd(x, x, op); }
vcmpordss(const Xmm & x,const Operand & op)1407 void vcmpordss(const Xmm& x, const Operand& op) { vcmpordss(x, x, op); }
vcmppd(const Xmm & x,const Operand & op,uint8 imm)1408 void vcmppd(const Xmm& x, const Operand& op, uint8 imm) { vcmppd(x, x, op, imm); }
vcmpps(const Xmm & x,const Operand & op,uint8 imm)1409 void vcmpps(const Xmm& x, const Operand& op, uint8 imm) { vcmpps(x, x, op, imm); }
vcmpsd(const Xmm & x,const Operand & op,uint8 imm)1410 void vcmpsd(const Xmm& x, const Operand& op, uint8 imm) { vcmpsd(x, x, op, imm); }
vcmpss(const Xmm & x,const Operand & op,uint8 imm)1411 void vcmpss(const Xmm& x, const Operand& op, uint8 imm) { vcmpss(x, x, op, imm); }
vcmptrue_uspd(const Xmm & x,const Operand & op)1412 void vcmptrue_uspd(const Xmm& x, const Operand& op) { vcmptrue_uspd(x, x, op); }
vcmptrue_usps(const Xmm & x,const Operand & op)1413 void vcmptrue_usps(const Xmm& x, const Operand& op) { vcmptrue_usps(x, x, op); }
vcmptrue_ussd(const Xmm & x,const Operand & op)1414 void vcmptrue_ussd(const Xmm& x, const Operand& op) { vcmptrue_ussd(x, x, op); }
vcmptrue_usss(const Xmm & x,const Operand & op)1415 void vcmptrue_usss(const Xmm& x, const Operand& op) { vcmptrue_usss(x, x, op); }
vcmptruepd(const Xmm & x,const Operand & op)1416 void vcmptruepd(const Xmm& x, const Operand& op) { vcmptruepd(x, x, op); }
vcmptrueps(const Xmm & x,const Operand & op)1417 void vcmptrueps(const Xmm& x, const Operand& op) { vcmptrueps(x, x, op); }
vcmptruesd(const Xmm & x,const Operand & op)1418 void vcmptruesd(const Xmm& x, const Operand& op) { vcmptruesd(x, x, op); }
vcmptruess(const Xmm & x,const Operand & op)1419 void vcmptruess(const Xmm& x, const Operand& op) { vcmptruess(x, x, op); }
vcmpunord_spd(const Xmm & x,const Operand & op)1420 void vcmpunord_spd(const Xmm& x, const Operand& op) { vcmpunord_spd(x, x, op); }
vcmpunord_sps(const Xmm & x,const Operand & op)1421 void vcmpunord_sps(const Xmm& x, const Operand& op) { vcmpunord_sps(x, x, op); }
vcmpunord_ssd(const Xmm & x,const Operand & op)1422 void vcmpunord_ssd(const Xmm& x, const Operand& op) { vcmpunord_ssd(x, x, op); }
vcmpunord_sss(const Xmm & x,const Operand & op)1423 void vcmpunord_sss(const Xmm& x, const Operand& op) { vcmpunord_sss(x, x, op); }
vcmpunordpd(const Xmm & x,const Operand & op)1424 void vcmpunordpd(const Xmm& x, const Operand& op) { vcmpunordpd(x, x, op); }
vcmpunordps(const Xmm & x,const Operand & op)1425 void vcmpunordps(const Xmm& x, const Operand& op) { vcmpunordps(x, x, op); }
vcmpunordsd(const Xmm & x,const Operand & op)1426 void vcmpunordsd(const Xmm& x, const Operand& op) { vcmpunordsd(x, x, op); }
vcmpunordss(const Xmm & x,const Operand & op)1427 void vcmpunordss(const Xmm& x, const Operand& op) { vcmpunordss(x, x, op); }
vcvtsd2ss(const Xmm & x,const Operand & op)1428 void vcvtsd2ss(const Xmm& x, const Operand& op) { vcvtsd2ss(x, x, op); }
vcvtsi2sd(const Xmm & x,const Operand & op)1429 void vcvtsi2sd(const Xmm& x, const Operand& op) { vcvtsi2sd(x, x, op); }
vcvtsi2ss(const Xmm & x,const Operand & op)1430 void vcvtsi2ss(const Xmm& x, const Operand& op) { vcvtsi2ss(x, x, op); }
vcvtss2sd(const Xmm & x,const Operand & op)1431 void vcvtss2sd(const Xmm& x, const Operand& op) { vcvtss2sd(x, x, op); }
vdppd(const Xmm & x,const Operand & op,uint8 imm)1432 void vdppd(const Xmm& x, const Operand& op, uint8 imm) { vdppd(x, x, op, imm); }
vdpps(const Xmm & x,const Operand & op,uint8 imm)1433 void vdpps(const Xmm& x, const Operand& op, uint8 imm) { vdpps(x, x, op, imm); }
vinsertps(const Xmm & x,const Operand & op,uint8 imm)1434 void vinsertps(const Xmm& x, const Operand& op, uint8 imm) { vinsertps(x, x, op, imm); }
vmpsadbw(const Xmm & x,const Operand & op,uint8 imm)1435 void vmpsadbw(const Xmm& x, const Operand& op, uint8 imm) { vmpsadbw(x, x, op, imm); }
vpackssdw(const Xmm & x,const Operand & op)1436 void vpackssdw(const Xmm& x, const Operand& op) { vpackssdw(x, x, op); }
vpacksswb(const Xmm & x,const Operand & op)1437 void vpacksswb(const Xmm& x, const Operand& op) { vpacksswb(x, x, op); }
vpackusdw(const Xmm & x,const Operand & op)1438 void vpackusdw(const Xmm& x, const Operand& op) { vpackusdw(x, x, op); }
vpackuswb(const Xmm & x,const Operand & op)1439 void vpackuswb(const Xmm& x, const Operand& op) { vpackuswb(x, x, op); }
vpaddb(const Xmm & x,const Operand & op)1440 void vpaddb(const Xmm& x, const Operand& op) { vpaddb(x, x, op); }
vpaddd(const Xmm & x,const Operand & op)1441 void vpaddd(const Xmm& x, const Operand& op) { vpaddd(x, x, op); }
vpaddq(const Xmm & x,const Operand & op)1442 void vpaddq(const Xmm& x, const Operand& op) { vpaddq(x, x, op); }
vpaddsb(const Xmm & x,const Operand & op)1443 void vpaddsb(const Xmm& x, const Operand& op) { vpaddsb(x, x, op); }
vpaddsw(const Xmm & x,const Operand & op)1444 void vpaddsw(const Xmm& x, const Operand& op) { vpaddsw(x, x, op); }
vpaddusb(const Xmm & x,const Operand & op)1445 void vpaddusb(const Xmm& x, const Operand& op) { vpaddusb(x, x, op); }
vpaddusw(const Xmm & x,const Operand & op)1446 void vpaddusw(const Xmm& x, const Operand& op) { vpaddusw(x, x, op); }
vpaddw(const Xmm & x,const Operand & op)1447 void vpaddw(const Xmm& x, const Operand& op) { vpaddw(x, x, op); }
vpalignr(const Xmm & x,const Operand & op,uint8 imm)1448 void vpalignr(const Xmm& x, const Operand& op, uint8 imm) { vpalignr(x, x, op, imm); }
vpand(const Xmm & x,const Operand & op)1449 void vpand(const Xmm& x, const Operand& op) { vpand(x, x, op); }
vpandn(const Xmm & x,const Operand & op)1450 void vpandn(const Xmm& x, const Operand& op) { vpandn(x, x, op); }
vpavgb(const Xmm & x,const Operand & op)1451 void vpavgb(const Xmm& x, const Operand& op) { vpavgb(x, x, op); }
vpavgw(const Xmm & x,const Operand & op)1452 void vpavgw(const Xmm& x, const Operand& op) { vpavgw(x, x, op); }
vpblendd(const Xmm & x,const Operand & op,uint8 imm)1453 void vpblendd(const Xmm& x, const Operand& op, uint8 imm) { vpblendd(x, x, op, imm); }
vpblendvb(const Xmm & x1,const Operand & op,const Xmm & x4)1454 void vpblendvb(const Xmm& x1, const Operand& op, const Xmm& x4) { vpblendvb(x1, x1, op, x4); }
vpblendw(const Xmm & x,const Operand & op,uint8 imm)1455 void vpblendw(const Xmm& x, const Operand& op, uint8 imm) { vpblendw(x, x, op, imm); }
vpclmulqdq(const Xmm & x,const Operand & op,uint8 imm)1456 void vpclmulqdq(const Xmm& x, const Operand& op, uint8 imm) { vpclmulqdq(x, x, op, imm); }
vpcmpeqb(const Xmm & x,const Operand & op)1457 void vpcmpeqb(const Xmm& x, const Operand& op) { vpcmpeqb(x, x, op); }
vpcmpeqd(const Xmm & x,const Operand & op)1458 void vpcmpeqd(const Xmm& x, const Operand& op) { vpcmpeqd(x, x, op); }
vpcmpeqq(const Xmm & x,const Operand & op)1459 void vpcmpeqq(const Xmm& x, const Operand& op) { vpcmpeqq(x, x, op); }
vpcmpeqw(const Xmm & x,const Operand & op)1460 void vpcmpeqw(const Xmm& x, const Operand& op) { vpcmpeqw(x, x, op); }
vpcmpgtb(const Xmm & x,const Operand & op)1461 void vpcmpgtb(const Xmm& x, const Operand& op) { vpcmpgtb(x, x, op); }
vpcmpgtd(const Xmm & x,const Operand & op)1462 void vpcmpgtd(const Xmm& x, const Operand& op) { vpcmpgtd(x, x, op); }
vpcmpgtq(const Xmm & x,const Operand & op)1463 void vpcmpgtq(const Xmm& x, const Operand& op) { vpcmpgtq(x, x, op); }
vpcmpgtw(const Xmm & x,const Operand & op)1464 void vpcmpgtw(const Xmm& x, const Operand& op) { vpcmpgtw(x, x, op); }
vphaddd(const Xmm & x,const Operand & op)1465 void vphaddd(const Xmm& x, const Operand& op) { vphaddd(x, x, op); }
vphaddsw(const Xmm & x,const Operand & op)1466 void vphaddsw(const Xmm& x, const Operand& op) { vphaddsw(x, x, op); }
vphaddw(const Xmm & x,const Operand & op)1467 void vphaddw(const Xmm& x, const Operand& op) { vphaddw(x, x, op); }
vphsubd(const Xmm & x,const Operand & op)1468 void vphsubd(const Xmm& x, const Operand& op) { vphsubd(x, x, op); }
vphsubsw(const Xmm & x,const Operand & op)1469 void vphsubsw(const Xmm& x, const Operand& op) { vphsubsw(x, x, op); }
vphsubw(const Xmm & x,const Operand & op)1470 void vphsubw(const Xmm& x, const Operand& op) { vphsubw(x, x, op); }
vpinsrb(const Xmm & x,const Operand & op,uint8 imm)1471 void vpinsrb(const Xmm& x, const Operand& op, uint8 imm) { vpinsrb(x, x, op, imm); }
vpinsrd(const Xmm & x,const Operand & op,uint8 imm)1472 void vpinsrd(const Xmm& x, const Operand& op, uint8 imm) { vpinsrd(x, x, op, imm); }
vpinsrq(const Xmm & x,const Operand & op,uint8 imm)1473 void vpinsrq(const Xmm& x, const Operand& op, uint8 imm) { vpinsrq(x, x, op, imm); }
vpinsrw(const Xmm & x,const Operand & op,uint8 imm)1474 void vpinsrw(const Xmm& x, const Operand& op, uint8 imm) { vpinsrw(x, x, op, imm); }
vpmaddubsw(const Xmm & x,const Operand & op)1475 void vpmaddubsw(const Xmm& x, const Operand& op) { vpmaddubsw(x, x, op); }
vpmaddwd(const Xmm & x,const Operand & op)1476 void vpmaddwd(const Xmm& x, const Operand& op) { vpmaddwd(x, x, op); }
vpmaxsb(const Xmm & x,const Operand & op)1477 void vpmaxsb(const Xmm& x, const Operand& op) { vpmaxsb(x, x, op); }
vpmaxsd(const Xmm & x,const Operand & op)1478 void vpmaxsd(const Xmm& x, const Operand& op) { vpmaxsd(x, x, op); }
vpmaxsw(const Xmm & x,const Operand & op)1479 void vpmaxsw(const Xmm& x, const Operand& op) { vpmaxsw(x, x, op); }
vpmaxub(const Xmm & x,const Operand & op)1480 void vpmaxub(const Xmm& x, const Operand& op) { vpmaxub(x, x, op); }
vpmaxud(const Xmm & x,const Operand & op)1481 void vpmaxud(const Xmm& x, const Operand& op) { vpmaxud(x, x, op); }
vpmaxuw(const Xmm & x,const Operand & op)1482 void vpmaxuw(const Xmm& x, const Operand& op) { vpmaxuw(x, x, op); }
vpminsb(const Xmm & x,const Operand & op)1483 void vpminsb(const Xmm& x, const Operand& op) { vpminsb(x, x, op); }
vpminsd(const Xmm & x,const Operand & op)1484 void vpminsd(const Xmm& x, const Operand& op) { vpminsd(x, x, op); }
vpminsw(const Xmm & x,const Operand & op)1485 void vpminsw(const Xmm& x, const Operand& op) { vpminsw(x, x, op); }
vpminub(const Xmm & x,const Operand & op)1486 void vpminub(const Xmm& x, const Operand& op) { vpminub(x, x, op); }
vpminud(const Xmm & x,const Operand & op)1487 void vpminud(const Xmm& x, const Operand& op) { vpminud(x, x, op); }
vpminuw(const Xmm & x,const Operand & op)1488 void vpminuw(const Xmm& x, const Operand& op) { vpminuw(x, x, op); }
vpmuldq(const Xmm & x,const Operand & op)1489 void vpmuldq(const Xmm& x, const Operand& op) { vpmuldq(x, x, op); }
vpmulhrsw(const Xmm & x,const Operand & op)1490 void vpmulhrsw(const Xmm& x, const Operand& op) { vpmulhrsw(x, x, op); }
vpmulhuw(const Xmm & x,const Operand & op)1491 void vpmulhuw(const Xmm& x, const Operand& op) { vpmulhuw(x, x, op); }
vpmulhw(const Xmm & x,const Operand & op)1492 void vpmulhw(const Xmm& x, const Operand& op) { vpmulhw(x, x, op); }
vpmulld(const Xmm & x,const Operand & op)1493 void vpmulld(const Xmm& x, const Operand& op) { vpmulld(x, x, op); }
vpmullw(const Xmm & x,const Operand & op)1494 void vpmullw(const Xmm& x, const Operand& op) { vpmullw(x, x, op); }
vpmuludq(const Xmm & x,const Operand & op)1495 void vpmuludq(const Xmm& x, const Operand& op) { vpmuludq(x, x, op); }
vpor(const Xmm & x,const Operand & op)1496 void vpor(const Xmm& x, const Operand& op) { vpor(x, x, op); }
vpsadbw(const Xmm & x,const Operand & op)1497 void vpsadbw(const Xmm& x, const Operand& op) { vpsadbw(x, x, op); }
vpsignb(const Xmm & x,const Operand & op)1498 void vpsignb(const Xmm& x, const Operand& op) { vpsignb(x, x, op); }
vpsignd(const Xmm & x,const Operand & op)1499 void vpsignd(const Xmm& x, const Operand& op) { vpsignd(x, x, op); }
vpsignw(const Xmm & x,const Operand & op)1500 void vpsignw(const Xmm& x, const Operand& op) { vpsignw(x, x, op); }
vpslld(const Xmm & x,const Operand & op)1501 void vpslld(const Xmm& x, const Operand& op) { vpslld(x, x, op); }
vpslld(const Xmm & x,uint8 imm)1502 void vpslld(const Xmm& x, uint8 imm) { vpslld(x, x, imm); }
vpslldq(const Xmm & x,uint8 imm)1503 void vpslldq(const Xmm& x, uint8 imm) { vpslldq(x, x, imm); }
vpsllq(const Xmm & x,const Operand & op)1504 void vpsllq(const Xmm& x, const Operand& op) { vpsllq(x, x, op); }
vpsllq(const Xmm & x,uint8 imm)1505 void vpsllq(const Xmm& x, uint8 imm) { vpsllq(x, x, imm); }
vpsllw(const Xmm & x,const Operand & op)1506 void vpsllw(const Xmm& x, const Operand& op) { vpsllw(x, x, op); }
vpsllw(const Xmm & x,uint8 imm)1507 void vpsllw(const Xmm& x, uint8 imm) { vpsllw(x, x, imm); }
vpsrad(const Xmm & x,const Operand & op)1508 void vpsrad(const Xmm& x, const Operand& op) { vpsrad(x, x, op); }
vpsrad(const Xmm & x,uint8 imm)1509 void vpsrad(const Xmm& x, uint8 imm) { vpsrad(x, x, imm); }
vpsraw(const Xmm & x,const Operand & op)1510 void vpsraw(const Xmm& x, const Operand& op) { vpsraw(x, x, op); }
vpsraw(const Xmm & x,uint8 imm)1511 void vpsraw(const Xmm& x, uint8 imm) { vpsraw(x, x, imm); }
vpsrld(const Xmm & x,const Operand & op)1512 void vpsrld(const Xmm& x, const Operand& op) { vpsrld(x, x, op); }
vpsrld(const Xmm & x,uint8 imm)1513 void vpsrld(const Xmm& x, uint8 imm) { vpsrld(x, x, imm); }
vpsrldq(const Xmm & x,uint8 imm)1514 void vpsrldq(const Xmm& x, uint8 imm) { vpsrldq(x, x, imm); }
vpsrlq(const Xmm & x,const Operand & op)1515 void vpsrlq(const Xmm& x, const Operand& op) { vpsrlq(x, x, op); }
vpsrlq(const Xmm & x,uint8 imm)1516 void vpsrlq(const Xmm& x, uint8 imm) { vpsrlq(x, x, imm); }
vpsrlw(const Xmm & x,const Operand & op)1517 void vpsrlw(const Xmm& x, const Operand& op) { vpsrlw(x, x, op); }
vpsrlw(const Xmm & x,uint8 imm)1518 void vpsrlw(const Xmm& x, uint8 imm) { vpsrlw(x, x, imm); }
vpsubb(const Xmm & x,const Operand & op)1519 void vpsubb(const Xmm& x, const Operand& op) { vpsubb(x, x, op); }
vpsubd(const Xmm & x,const Operand & op)1520 void vpsubd(const Xmm& x, const Operand& op) { vpsubd(x, x, op); }
vpsubq(const Xmm & x,const Operand & op)1521 void vpsubq(const Xmm& x, const Operand& op) { vpsubq(x, x, op); }
vpsubsb(const Xmm & x,const Operand & op)1522 void vpsubsb(const Xmm& x, const Operand& op) { vpsubsb(x, x, op); }
vpsubsw(const Xmm & x,const Operand & op)1523 void vpsubsw(const Xmm& x, const Operand& op) { vpsubsw(x, x, op); }
vpsubusb(const Xmm & x,const Operand & op)1524 void vpsubusb(const Xmm& x, const Operand& op) { vpsubusb(x, x, op); }
vpsubusw(const Xmm & x,const Operand & op)1525 void vpsubusw(const Xmm& x, const Operand& op) { vpsubusw(x, x, op); }
vpsubw(const Xmm & x,const Operand & op)1526 void vpsubw(const Xmm& x, const Operand& op) { vpsubw(x, x, op); }
vpunpckhbw(const Xmm & x,const Operand & op)1527 void vpunpckhbw(const Xmm& x, const Operand& op) { vpunpckhbw(x, x, op); }
vpunpckhdq(const Xmm & x,const Operand & op)1528 void vpunpckhdq(const Xmm& x, const Operand& op) { vpunpckhdq(x, x, op); }
vpunpckhqdq(const Xmm & x,const Operand & op)1529 void vpunpckhqdq(const Xmm& x, const Operand& op) { vpunpckhqdq(x, x, op); }
vpunpckhwd(const Xmm & x,const Operand & op)1530 void vpunpckhwd(const Xmm& x, const Operand& op) { vpunpckhwd(x, x, op); }
vpunpcklbw(const Xmm & x,const Operand & op)1531 void vpunpcklbw(const Xmm& x, const Operand& op) { vpunpcklbw(x, x, op); }
vpunpckldq(const Xmm & x,const Operand & op)1532 void vpunpckldq(const Xmm& x, const Operand& op) { vpunpckldq(x, x, op); }
vpunpcklqdq(const Xmm & x,const Operand & op)1533 void vpunpcklqdq(const Xmm& x, const Operand& op) { vpunpcklqdq(x, x, op); }
vpunpcklwd(const Xmm & x,const Operand & op)1534 void vpunpcklwd(const Xmm& x, const Operand& op) { vpunpcklwd(x, x, op); }
vpxor(const Xmm & x,const Operand & op)1535 void vpxor(const Xmm& x, const Operand& op) { vpxor(x, x, op); }
vrcpss(const Xmm & x,const Operand & op)1536 void vrcpss(const Xmm& x, const Operand& op) { vrcpss(x, x, op); }
vroundsd(const Xmm & x,const Operand & op,uint8 imm)1537 void vroundsd(const Xmm& x, const Operand& op, uint8 imm) { vroundsd(x, x, op, imm); }
vroundss(const Xmm & x,const Operand & op,uint8 imm)1538 void vroundss(const Xmm& x, const Operand& op, uint8 imm) { vroundss(x, x, op, imm); }
vrsqrtss(const Xmm & x,const Operand & op)1539 void vrsqrtss(const Xmm& x, const Operand& op) { vrsqrtss(x, x, op); }
vshufpd(const Xmm & x,const Operand & op,uint8 imm)1540 void vshufpd(const Xmm& x, const Operand& op, uint8 imm) { vshufpd(x, x, op, imm); }
vshufps(const Xmm & x,const Operand & op,uint8 imm)1541 void vshufps(const Xmm& x, const Operand& op, uint8 imm) { vshufps(x, x, op, imm); }
vsqrtsd(const Xmm & x,const Operand & op)1542 void vsqrtsd(const Xmm& x, const Operand& op) { vsqrtsd(x, x, op); }
vsqrtss(const Xmm & x,const Operand & op)1543 void vsqrtss(const Xmm& x, const Operand& op) { vsqrtss(x, x, op); }
vunpckhpd(const Xmm & x,const Operand & op)1544 void vunpckhpd(const Xmm& x, const Operand& op) { vunpckhpd(x, x, op); }
vunpckhps(const Xmm & x,const Operand & op)1545 void vunpckhps(const Xmm& x, const Operand& op) { vunpckhps(x, x, op); }
vunpcklpd(const Xmm & x,const Operand & op)1546 void vunpcklpd(const Xmm& x, const Operand& op) { vunpcklpd(x, x, op); }
vunpcklps(const Xmm & x,const Operand & op)1547 void vunpcklps(const Xmm& x, const Operand& op) { vunpcklps(x, x, op); }
1548 #endif
1549 #ifdef XBYAK64
jecxz(std::string label)1550 void jecxz(std::string label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jecxz(const Label & label)1551 void jecxz(const Label& label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jrcxz(std::string label)1552 void jrcxz(std::string label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
jrcxz(const Label & label)1553 void jrcxz(const Label& label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
cdqe()1554 void cdqe() { db(0x48); db(0x98); }
cqo()1555 void cqo() { db(0x48); db(0x99); }
cmpsq()1556 void cmpsq() { db(0x48); db(0xA7); }
movsq()1557 void movsq() { db(0x48); db(0xA5); }
scasq()1558 void scasq() { db(0x48); db(0xAF); }
stosq()1559 void stosq() { db(0x48); db(0xAB); }
cmpxchg16b(const Address & addr)1560 void cmpxchg16b(const Address& addr) { opModM(addr, Reg64(1), 0x0F, 0xC7); }
movq(const Reg64 & reg,const Mmx & mmx)1561 void movq(const Reg64& reg, const Mmx& mmx) { if (mmx.isXMM()) db(0x66); opModR(mmx, reg, 0x0F, 0x7E); }
movq(const Mmx & mmx,const Reg64 & reg)1562 void movq(const Mmx& mmx, const Reg64& reg) { if (mmx.isXMM()) db(0x66); opModR(mmx, reg, 0x0F, 0x6E); }
movsxd(const Reg64 & reg,const Operand & op)1563 void movsxd(const Reg64& reg, const Operand& op) { if (!op.isBit(32)) throw Error(ERR_BAD_COMBINATION); opModRM(reg, op, op.isREG(), op.isMEM(), 0x63); }
pextrq(const Operand & op,const Xmm & xmm,uint8 imm)1564 void pextrq(const Operand& op, const Xmm& xmm, uint8 imm) { if (!op.isREG(64) && !op.isMEM()) throw Error(ERR_BAD_COMBINATION); opGen(Reg64(xmm.getIdx()), op, 0x16, 0x66, 0, imm, 0x3A); }
pinsrq(const Xmm & xmm,const Operand & op,uint8 imm)1565 void pinsrq(const Xmm& xmm, const Operand& op, uint8 imm) { if (!op.isREG(64) && !op.isMEM()) throw Error(ERR_BAD_COMBINATION); opGen(Reg64(xmm.getIdx()), op, 0x22, 0x66, 0, imm, 0x3A); }
vcvtss2si(const Reg64 & r,const Operand & op)1566 void vcvtss2si(const Reg64& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F3 | T_W1 | T_EVEX | T_EW1 | T_ER_X | T_N8, 0x2D); }
vcvttss2si(const Reg64 & r,const Operand & op)1567 void vcvttss2si(const Reg64& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F3 | T_W1 | T_EVEX | T_EW1 | T_SAE_X | T_N8, 0x2C); }
vcvtsd2si(const Reg64 & r,const Operand & op)1568 void vcvtsd2si(const Reg64& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F2 | T_W1 | T_EVEX | T_EW1 | T_N4 | T_ER_X, 0x2D); }
vcvttsd2si(const Reg64 & r,const Operand & op)1569 void vcvttsd2si(const Reg64& r, const Operand& op) { opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, T_0F | T_F2 | T_W1 | T_EVEX | T_EW1 | T_N4 | T_SAE_X, 0x2C); }
vmovq(const Xmm & x,const Reg64 & r)1570 void vmovq(const Xmm& x, const Reg64& r) { opAVX_X_X_XM(x, xm0, Xmm(r.getIdx()), T_66 | T_0F | T_W1 | T_EVEX | T_EW1, 0x6E); }
vmovq(const Reg64 & r,const Xmm & x)1571 void vmovq(const Reg64& r, const Xmm& x) { opAVX_X_X_XM(x, xm0, Xmm(r.getIdx()), T_66 | T_0F | T_W1 | T_EVEX | T_EW1, 0x7E); }
1572 #else
jcxz(std::string label)1573 void jcxz(std::string label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jcxz(const Label & label)1574 void jcxz(const Label& label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jecxz(std::string label)1575 void jecxz(std::string label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
jecxz(const Label & label)1576 void jecxz(const Label& label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
aaa()1577 void aaa() { db(0x37); }
aad()1578 void aad() { db(0xD5); db(0x0A); }
aam()1579 void aam() { db(0xD4); db(0x0A); }
aas()1580 void aas() { db(0x3F); }
daa()1581 void daa() { db(0x27); }
das()1582 void das() { db(0x2F); }
popad()1583 void popad() { db(0x61); }
popfd()1584 void popfd() { db(0x9D); }
pusha()1585 void pusha() { db(0x60); }
pushad()1586 void pushad() { db(0x60); }
pushfd()1587 void pushfd() { db(0x9C); }
popa()1588 void popa() { db(0x61); }
1589 #endif
1590 #ifndef XBYAK_NO_OP_NAMES
and(const Operand & op1,const Operand & op2)1591 void and(const Operand& op1, const Operand& op2) { and_(op1, op2); }
and(const Operand & op,uint32 imm)1592 void and(const Operand& op, uint32 imm) { and_(op, imm); }
or(const Operand & op1,const Operand & op2)1593 void or(const Operand& op1, const Operand& op2) { or_(op1, op2); }
or(const Operand & op,uint32 imm)1594 void or(const Operand& op, uint32 imm) { or_(op, imm); }
xor(const Operand & op1,const Operand & op2)1595 void xor(const Operand& op1, const Operand& op2) { xor_(op1, op2); }
xor(const Operand & op,uint32 imm)1596 void xor(const Operand& op, uint32 imm) { xor_(op, imm); }
not(const Operand & op)1597 void not(const Operand& op) { not_(op); }
1598 #endif
1599 #ifndef XBYAK_DISABLE_AVX512
kaddb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1600 void kaddb(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x4A); }
kaddd(const Opmask & r1,const Opmask & r2,const Opmask & r3)1601 void kaddd(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W1, 0x4A); }
kaddq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1602 void kaddq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x4A); }
kaddw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1603 void kaddw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x4A); }
kandb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1604 void kandb(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x41); }
kandd(const Opmask & r1,const Opmask & r2,const Opmask & r3)1605 void kandd(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W1, 0x41); }
kandnb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1606 void kandnb(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x42); }
kandnd(const Opmask & r1,const Opmask & r2,const Opmask & r3)1607 void kandnd(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W1, 0x42); }
kandnq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1608 void kandnq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x42); }
kandnw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1609 void kandnw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x42); }
kandq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1610 void kandq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x41); }
kandw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1611 void kandw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x41); }
kmovb(const Address & addr,const Opmask & k)1612 void kmovb(const Address& addr, const Opmask& k) { opVex(k, 0, addr, T_L0 | T_0F | T_66 | T_W0, 0x91); }
kmovb(const Opmask & k,const Operand & op)1613 void kmovb(const Opmask& k, const Operand& op) { opVex(k, 0, op, T_L0 | T_0F | T_66 | T_W0, 0x90); }
kmovb(const Opmask & k,const Reg32 & r)1614 void kmovb(const Opmask& k, const Reg32& r) { opVex(k, 0, r, T_L0 | T_0F | T_66 | T_W0, 0x92); }
kmovb(const Reg32 & r,const Opmask & k)1615 void kmovb(const Reg32& r, const Opmask& k) { opVex(r, 0, k, T_L0 | T_0F | T_66 | T_W0, 0x93); }
kmovd(const Address & addr,const Opmask & k)1616 void kmovd(const Address& addr, const Opmask& k) { opVex(k, 0, addr, T_L0 | T_0F | T_66 | T_W1, 0x91); }
kmovd(const Opmask & k,const Operand & op)1617 void kmovd(const Opmask& k, const Operand& op) { opVex(k, 0, op, T_L0 | T_0F | T_66 | T_W1, 0x90); }
kmovd(const Opmask & k,const Reg32 & r)1618 void kmovd(const Opmask& k, const Reg32& r) { opVex(k, 0, r, T_L0 | T_0F | T_F2 | T_W0, 0x92); }
kmovd(const Reg32 & r,const Opmask & k)1619 void kmovd(const Reg32& r, const Opmask& k) { opVex(r, 0, k, T_L0 | T_0F | T_F2 | T_W0, 0x93); }
kmovq(const Address & addr,const Opmask & k)1620 void kmovq(const Address& addr, const Opmask& k) { opVex(k, 0, addr, T_L0 | T_0F | T_W1, 0x91); }
kmovq(const Opmask & k,const Operand & op)1621 void kmovq(const Opmask& k, const Operand& op) { opVex(k, 0, op, T_L0 | T_0F | T_W1, 0x90); }
kmovw(const Address & addr,const Opmask & k)1622 void kmovw(const Address& addr, const Opmask& k) { opVex(k, 0, addr, T_L0 | T_0F | T_W0, 0x91); }
kmovw(const Opmask & k,const Operand & op)1623 void kmovw(const Opmask& k, const Operand& op) { opVex(k, 0, op, T_L0 | T_0F | T_W0, 0x90); }
kmovw(const Opmask & k,const Reg32 & r)1624 void kmovw(const Opmask& k, const Reg32& r) { opVex(k, 0, r, T_L0 | T_0F | T_W0, 0x92); }
kmovw(const Reg32 & r,const Opmask & k)1625 void kmovw(const Reg32& r, const Opmask& k) { opVex(r, 0, k, T_L0 | T_0F | T_W0, 0x93); }
knotb(const Opmask & r1,const Opmask & r2)1626 void knotb(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_66 | T_W0, 0x44); }
knotd(const Opmask & r1,const Opmask & r2)1627 void knotd(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_66 | T_W1, 0x44); }
knotq(const Opmask & r1,const Opmask & r2)1628 void knotq(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W1, 0x44); }
knotw(const Opmask & r1,const Opmask & r2)1629 void knotw(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W0, 0x44); }
korb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1630 void korb(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x45); }
kord(const Opmask & r1,const Opmask & r2,const Opmask & r3)1631 void kord(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W1, 0x45); }
korq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1632 void korq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x45); }
kortestb(const Opmask & r1,const Opmask & r2)1633 void kortestb(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_66 | T_W0, 0x98); }
kortestd(const Opmask & r1,const Opmask & r2)1634 void kortestd(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_66 | T_W1, 0x98); }
kortestq(const Opmask & r1,const Opmask & r2)1635 void kortestq(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W1, 0x98); }
kortestw(const Opmask & r1,const Opmask & r2)1636 void kortestw(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W0, 0x98); }
korw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1637 void korw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x45); }
kshiftlb(const Opmask & r1,const Opmask & r2,uint8 imm)1638 void kshiftlb(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W0, 0x32, imm); }
kshiftld(const Opmask & r1,const Opmask & r2,uint8 imm)1639 void kshiftld(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W0, 0x33, imm); }
kshiftlq(const Opmask & r1,const Opmask & r2,uint8 imm)1640 void kshiftlq(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W1, 0x33, imm); }
kshiftlw(const Opmask & r1,const Opmask & r2,uint8 imm)1641 void kshiftlw(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W1, 0x32, imm); }
kshiftrb(const Opmask & r1,const Opmask & r2,uint8 imm)1642 void kshiftrb(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W0, 0x30, imm); }
kshiftrd(const Opmask & r1,const Opmask & r2,uint8 imm)1643 void kshiftrd(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W0, 0x31, imm); }
kshiftrq(const Opmask & r1,const Opmask & r2,uint8 imm)1644 void kshiftrq(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W1, 0x31, imm); }
kshiftrw(const Opmask & r1,const Opmask & r2,uint8 imm)1645 void kshiftrw(const Opmask& r1, const Opmask& r2, uint8 imm) { opVex(r1, 0, r2, T_66 | T_0F3A | T_W1, 0x30, imm); }
ktestb(const Opmask & r1,const Opmask & r2)1646 void ktestb(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_66 | T_W0, 0x99); }
ktestd(const Opmask & r1,const Opmask & r2)1647 void ktestd(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_66 | T_W1, 0x99); }
ktestq(const Opmask & r1,const Opmask & r2)1648 void ktestq(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W1, 0x99); }
ktestw(const Opmask & r1,const Opmask & r2)1649 void ktestw(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W0, 0x99); }
kunpckbw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1650 void kunpckbw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x4B); }
kunpckdq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1651 void kunpckdq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x4B); }
kunpckwd(const Opmask & r1,const Opmask & r2,const Opmask & r3)1652 void kunpckwd(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x4B); }
kxnorb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1653 void kxnorb(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x46); }
kxnord(const Opmask & r1,const Opmask & r2,const Opmask & r3)1654 void kxnord(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W1, 0x46); }
kxnorq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1655 void kxnorq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x46); }
kxnorw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1656 void kxnorw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x46); }
kxorb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1657 void kxorb(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W0, 0x47); }
kxord(const Opmask & r1,const Opmask & r2,const Opmask & r3)1658 void kxord(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_66 | T_W1, 0x47); }
kxorq(const Opmask & r1,const Opmask & r2,const Opmask & r3)1659 void kxorq(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W1, 0x47); }
kxorw(const Opmask & r1,const Opmask & r2,const Opmask & r3)1660 void kxorw(const Opmask& r1, const Opmask& r2, const Opmask& r3) { opVex(r1, &r2, r3, T_L1 | T_0F | T_W0, 0x47); }
v4fmaddps(const Zmm & z1,const Zmm & z2,const Address & addr)1661 void v4fmaddps(const Zmm& z1, const Zmm& z2, const Address& addr) { opAVX_X_X_XM(z1, z2, addr, T_0F38 | T_F2 | T_EW0 | T_YMM | T_MUST_EVEX | T_N16, 0x9A); }
v4fmaddss(const Xmm & x1,const Xmm & x2,const Address & addr)1662 void v4fmaddss(const Xmm& x1, const Xmm& x2, const Address& addr) { opAVX_X_X_XM(x1, x2, addr, T_0F38 | T_F2 | T_EW0 | T_MUST_EVEX | T_N16, 0x9B); }
v4fnmaddps(const Zmm & z1,const Zmm & z2,const Address & addr)1663 void v4fnmaddps(const Zmm& z1, const Zmm& z2, const Address& addr) { opAVX_X_X_XM(z1, z2, addr, T_0F38 | T_F2 | T_EW0 | T_YMM | T_MUST_EVEX | T_N16, 0xAA); }
v4fnmaddss(const Xmm & x1,const Xmm & x2,const Address & addr)1664 void v4fnmaddss(const Xmm& x1, const Xmm& x2, const Address& addr) { opAVX_X_X_XM(x1, x2, addr, T_0F38 | T_F2 | T_EW0 | T_MUST_EVEX | T_N16, 0xAB); }
valignd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1665 void valignd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x03, imm); }
valignq(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1666 void valignq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x03, imm); }
vblendmpd(const Xmm & x1,const Xmm & x2,const Operand & op)1667 void vblendmpd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x65); }
vblendmps(const Xmm & x1,const Xmm & x2,const Operand & op)1668 void vblendmps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x65); }
vbroadcastf32x2(const Ymm & y,const Operand & op)1669 void vbroadcastf32x2(const Ymm& y, const Operand& op) { opAVX_X_XM_IMM(y, op, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0 | T_N8, 0x19); }
vbroadcastf32x4(const Ymm & y,const Address & addr)1670 void vbroadcastf32x4(const Ymm& y, const Address& addr) { opAVX_X_XM_IMM(y, addr, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0 | T_N16, 0x1A); }
vbroadcastf32x8(const Zmm & y,const Address & addr)1671 void vbroadcastf32x8(const Zmm& y, const Address& addr) { opAVX_X_XM_IMM(y, addr, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0 | T_N32, 0x1B); }
vbroadcastf64x2(const Ymm & y,const Address & addr)1672 void vbroadcastf64x2(const Ymm& y, const Address& addr) { opAVX_X_XM_IMM(y, addr, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW1 | T_N16, 0x1A); }
vbroadcastf64x4(const Zmm & y,const Address & addr)1673 void vbroadcastf64x4(const Zmm& y, const Address& addr) { opAVX_X_XM_IMM(y, addr, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW1 | T_N32, 0x1B); }
vbroadcasti32x2(const Xmm & x,const Operand & op)1674 void vbroadcasti32x2(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0 | T_N8, 0x59); }
vbroadcasti32x4(const Ymm & y,const Operand & op)1675 void vbroadcasti32x4(const Ymm& y, const Operand& op) { opAVX_X_XM_IMM(y, op, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0 | T_N16, 0x5A); }
vbroadcasti32x8(const Zmm & z,const Operand & op)1676 void vbroadcasti32x8(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0 | T_N32, 0x5B); }
vbroadcasti64x2(const Ymm & y,const Operand & op)1677 void vbroadcasti64x2(const Ymm& y, const Operand& op) { opAVX_X_XM_IMM(y, op, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW1 | T_N16, 0x5A); }
vbroadcasti64x4(const Zmm & z,const Operand & op)1678 void vbroadcasti64x4(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW1 | T_N32, 0x5B); }
vcmppd(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1679 void vcmppd(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0xC2, imm); }
vcmpps(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1680 void vcmpps(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_0F | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0xC2, imm); }
vcmpsd(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1681 void vcmpsd(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_N8 | T_F2 | T_0F | T_EW1 | T_SAE_Z | T_MUST_EVEX, 0xC2, imm); }
vcmpss(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1682 void vcmpss(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_N4 | T_F3 | T_0F | T_EW0 | T_SAE_Z | T_MUST_EVEX, 0xC2, imm); }
vcompressb(const Operand & op,const Xmm & x)1683 void vcompressb(const Operand& op, const Xmm& x) { opAVX_X_XM_IMM(x, op, T_N1 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x63); }
vcompresspd(const Operand & op,const Xmm & x)1684 void vcompresspd(const Operand& op, const Xmm& x) { opAVX_X_XM_IMM(x, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x8A); }
vcompressps(const Operand & op,const Xmm & x)1685 void vcompressps(const Operand& op, const Xmm& x) { opAVX_X_XM_IMM(x, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x8A); }
vcompressw(const Operand & op,const Xmm & x)1686 void vcompressw(const Operand& op, const Xmm& x) { opAVX_X_XM_IMM(x, op, T_N2 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x63); }
vcvtpd2qq(const Xmm & x,const Operand & op)1687 void vcvtpd2qq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F | T_EW1 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B64, 0x7B); }
vcvtpd2udq(const Xmm & x,const Operand & op)1688 void vcvtpd2udq(const Xmm& x, const Operand& op) { opCvt2(x, op, T_0F | T_YMM | T_MUST_EVEX | T_EW1 | T_B64 | T_ER_Z, 0x79); }
vcvtpd2uqq(const Xmm & x,const Operand & op)1689 void vcvtpd2uqq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F | T_EW1 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B64, 0x79); }
vcvtps2qq(const Xmm & x,const Operand & op)1690 void vcvtps2qq(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_66 | T_0F | T_YMM | T_MUST_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL | T_ER_Y, 0x7B); }
vcvtps2udq(const Xmm & x,const Operand & op)1691 void vcvtps2udq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_0F | T_EW0 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B32, 0x79); }
vcvtps2uqq(const Xmm & x,const Operand & op)1692 void vcvtps2uqq(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_66 | T_0F | T_YMM | T_MUST_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL | T_ER_Y, 0x79); }
vcvtqq2pd(const Xmm & x,const Operand & op)1693 void vcvtqq2pd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F3 | T_0F | T_EW1 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B64, 0xE6); }
vcvtqq2ps(const Xmm & x,const Operand & op)1694 void vcvtqq2ps(const Xmm& x, const Operand& op) { opCvt2(x, op, T_0F | T_YMM | T_MUST_EVEX | T_EW1 | T_B64 | T_ER_Z, 0x5B); }
vcvtsd2usi(const Reg32e & r,const Operand & op)1695 void vcvtsd2usi(const Reg32e& r, const Operand& op) { int type = (T_F2 | T_0F | T_MUST_EVEX | T_N8 | T_ER_X) | (r.isREG(64) ? T_EW1 : T_EW0); opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, type, 0x79); }
vcvtss2usi(const Reg32e & r,const Operand & op)1696 void vcvtss2usi(const Reg32e& r, const Operand& op) { int type = (T_F3 | T_0F | T_MUST_EVEX | T_N4 | T_ER_X) | (r.isREG(64) ? T_EW1 : T_EW0); opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, type, 0x79); }
vcvttpd2qq(const Xmm & x,const Operand & op)1697 void vcvttpd2qq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x7A); }
vcvttpd2udq(const Xmm & x,const Operand & op)1698 void vcvttpd2udq(const Xmm& x, const Operand& op) { opCvt2(x, op, T_0F | T_YMM | T_MUST_EVEX | T_EW1 | T_B64 | T_SAE_Z, 0x78); }
vcvttpd2uqq(const Xmm & x,const Operand & op)1699 void vcvttpd2uqq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x78); }
vcvttps2qq(const Xmm & x,const Operand & op)1700 void vcvttps2qq(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_66 | T_0F | T_YMM | T_MUST_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL | T_SAE_Y, 0x7A); }
vcvttps2udq(const Xmm & x,const Operand & op)1701 void vcvttps2udq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_0F | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x78); }
vcvttps2uqq(const Xmm & x,const Operand & op)1702 void vcvttps2uqq(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_66 | T_0F | T_YMM | T_MUST_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL | T_SAE_Y, 0x78); }
vcvttsd2usi(const Reg32e & r,const Operand & op)1703 void vcvttsd2usi(const Reg32e& r, const Operand& op) { int type = (T_F2 | T_0F | T_MUST_EVEX | T_N8 | T_SAE_X) | (r.isREG(64) ? T_EW1 : T_EW0); opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, type, 0x78); }
vcvttss2usi(const Reg32e & r,const Operand & op)1704 void vcvttss2usi(const Reg32e& r, const Operand& op) { int type = (T_F3 | T_0F | T_MUST_EVEX | T_N4 | T_SAE_X) | (r.isREG(64) ? T_EW1 : T_EW0); opAVX_X_X_XM(Xmm(r.getIdx()), xm0, op, type, 0x78); }
vcvtudq2pd(const Xmm & x,const Operand & op)1705 void vcvtudq2pd(const Xmm& x, const Operand& op) { checkCvt1(x, op); opVex(x, 0, op, T_F3 | T_0F | T_YMM | T_MUST_EVEX | T_EW0 | T_B32 | T_N8 | T_N_VL, 0x7A); }
vcvtudq2ps(const Xmm & x,const Operand & op)1706 void vcvtudq2ps(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F2 | T_0F | T_EW0 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B32, 0x7A); }
vcvtuqq2pd(const Xmm & x,const Operand & op)1707 void vcvtuqq2pd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F3 | T_0F | T_EW1 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B64, 0x7A); }
vcvtuqq2ps(const Xmm & x,const Operand & op)1708 void vcvtuqq2ps(const Xmm& x, const Operand& op) { opCvt2(x, op, T_F2 | T_0F | T_YMM | T_MUST_EVEX | T_EW1 | T_B64 | T_ER_Z, 0x7A); }
vcvtusi2sd(const Xmm & x1,const Xmm & x2,const Operand & op)1709 void vcvtusi2sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opCvt3(x1, x2, op, T_F2 | T_0F | T_MUST_EVEX, T_W1 | T_EW1 | T_ER_X | T_N8, T_W0 | T_EW0 | T_N4, 0x7B); }
vcvtusi2ss(const Xmm & x1,const Xmm & x2,const Operand & op)1710 void vcvtusi2ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opCvt3(x1, x2, op, T_F3 | T_0F | T_MUST_EVEX | T_ER_X, T_W1 | T_EW1 | T_N8, T_W0 | T_EW0 | T_N4, 0x7B); }
vdbpsadbw(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1711 void vdbpsadbw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x42, imm); }
vexp2pd(const Zmm & z,const Operand & op)1712 void vexp2pd(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1 | T_B64 | T_SAE_Z, 0xC8); }
vexp2ps(const Zmm & z,const Operand & op)1713 void vexp2ps(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0 | T_B32 | T_SAE_Z, 0xC8); }
vexpandpd(const Xmm & x,const Operand & op)1714 void vexpandpd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x88); }
vexpandps(const Xmm & x,const Operand & op)1715 void vexpandps(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x88); }
vextractf32x4(const Operand & op,const Ymm & r,uint8 imm)1716 void vextractf32x4(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N16 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x19, imm); }
vextractf32x8(const Operand & op,const Zmm & r,uint8 imm)1717 void vextractf32x8(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N32 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x1B, imm); }
vextractf64x2(const Operand & op,const Ymm & r,uint8 imm)1718 void vextractf64x2(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N16 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x19, imm); }
vextractf64x4(const Operand & op,const Zmm & r,uint8 imm)1719 void vextractf64x4(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N32 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x1B, imm); }
vextracti32x4(const Operand & op,const Ymm & r,uint8 imm)1720 void vextracti32x4(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N16 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x39, imm); }
vextracti32x8(const Operand & op,const Zmm & r,uint8 imm)1721 void vextracti32x8(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N32 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x3B, imm); }
vextracti64x2(const Operand & op,const Ymm & r,uint8 imm)1722 void vextracti64x2(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N16 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x39, imm); }
vextracti64x4(const Operand & op,const Zmm & r,uint8 imm)1723 void vextracti64x4(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r, 0, op, T_N32 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x3B, imm); }
vfixupimmpd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1724 void vfixupimmpd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x54, imm); }
vfixupimmps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1725 void vfixupimmps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x54, imm); }
vfixupimmsd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1726 void vfixupimmsd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F3A | T_EW1 | T_SAE_Z | T_MUST_EVEX, 0x55, imm); }
vfixupimmss(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1727 void vfixupimmss(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F3A | T_EW0 | T_SAE_Z | T_MUST_EVEX, 0x55, imm); }
vfpclasspd(const Opmask & k,const Operand & op,uint8 imm)1728 void vfpclasspd(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isBit(128|256|512)) throw Error(ERR_BAD_MEM_SIZE); opVex(k.changeBit(op.getBit()), 0, op, T_66 | T_0F3A | T_MUST_EVEX | T_YMM | T_EW1 | T_B64, 0x66, imm); }
vfpclassps(const Opmask & k,const Operand & op,uint8 imm)1729 void vfpclassps(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isBit(128|256|512)) throw Error(ERR_BAD_MEM_SIZE); opVex(k.changeBit(op.getBit()), 0, op, T_66 | T_0F3A | T_MUST_EVEX | T_YMM | T_EW0 | T_B32, 0x66, imm); }
vfpclasssd(const Opmask & k,const Operand & op,uint8 imm)1730 void vfpclasssd(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isXMEM()) throw Error(ERR_BAD_MEM_SIZE); opVex(k, 0, op, T_66 | T_0F3A | T_MUST_EVEX | T_EW1 | T_N8, 0x67, imm); }
vfpclassss(const Opmask & k,const Operand & op,uint8 imm)1731 void vfpclassss(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isXMEM()) throw Error(ERR_BAD_MEM_SIZE); opVex(k, 0, op, T_66 | T_0F3A | T_MUST_EVEX | T_EW0 | T_N4, 0x67, imm); }
vgatherdpd(const Xmm & x,const Address & addr)1732 void vgatherdpd(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_VSIB, 0x92, 1); }
vgatherdps(const Xmm & x,const Address & addr)1733 void vgatherdps(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_VSIB, 0x92, 0); }
vgatherpf0dpd(const Address & addr)1734 void vgatherpf0dpd(const Address& addr) { opGatherFetch(addr, zm1, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::YMM); }
vgatherpf0dps(const Address & addr)1735 void vgatherpf0dps(const Address& addr) { opGatherFetch(addr, zm1, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::ZMM); }
vgatherpf0qpd(const Address & addr)1736 void vgatherpf0qpd(const Address& addr) { opGatherFetch(addr, zm1, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vgatherpf0qps(const Address & addr)1737 void vgatherpf0qps(const Address& addr) { opGatherFetch(addr, zm1, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vgatherpf1dpd(const Address & addr)1738 void vgatherpf1dpd(const Address& addr) { opGatherFetch(addr, zm2, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::YMM); }
vgatherpf1dps(const Address & addr)1739 void vgatherpf1dps(const Address& addr) { opGatherFetch(addr, zm2, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::ZMM); }
vgatherpf1qpd(const Address & addr)1740 void vgatherpf1qpd(const Address& addr) { opGatherFetch(addr, zm2, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vgatherpf1qps(const Address & addr)1741 void vgatherpf1qps(const Address& addr) { opGatherFetch(addr, zm2, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vgatherqpd(const Xmm & x,const Address & addr)1742 void vgatherqpd(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_VSIB, 0x93, 0); }
vgatherqps(const Xmm & x,const Address & addr)1743 void vgatherqps(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_VSIB, 0x93, 2); }
vgetexppd(const Xmm & x,const Operand & op)1744 void vgetexppd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x42); }
vgetexpps(const Xmm & x,const Operand & op)1745 void vgetexpps(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x42); }
vgetexpsd(const Xmm & x1,const Xmm & x2,const Operand & op)1746 void vgetexpsd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_SAE_X | T_MUST_EVEX, 0x43); }
vgetexpss(const Xmm & x1,const Xmm & x2,const Operand & op)1747 void vgetexpss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_SAE_X | T_MUST_EVEX, 0x43); }
vgetmantpd(const Xmm & x,const Operand & op,uint8 imm)1748 void vgetmantpd(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x26, imm); }
vgetmantps(const Xmm & x,const Operand & op,uint8 imm)1749 void vgetmantps(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x26, imm); }
vgetmantsd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1750 void vgetmantsd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F3A | T_EW1 | T_SAE_X | T_MUST_EVEX, 0x27, imm); }
vgetmantss(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1751 void vgetmantss(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F3A | T_EW0 | T_SAE_X | T_MUST_EVEX, 0x27, imm); }
vinsertf32x4(const Ymm & r1,const Ymm & r2,const Operand & op,uint8 imm)1752 void vinsertf32x4(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N16 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x18, imm); }
vinsertf32x8(const Zmm & r1,const Zmm & r2,const Operand & op,uint8 imm)1753 void vinsertf32x8(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N32 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x1A, imm); }
vinsertf64x2(const Ymm & r1,const Ymm & r2,const Operand & op,uint8 imm)1754 void vinsertf64x2(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N16 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x18, imm); }
vinsertf64x4(const Zmm & r1,const Zmm & r2,const Operand & op,uint8 imm)1755 void vinsertf64x4(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N32 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x1A, imm); }
vinserti32x4(const Ymm & r1,const Ymm & r2,const Operand & op,uint8 imm)1756 void vinserti32x4(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N16 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x38, imm); }
vinserti32x8(const Zmm & r1,const Zmm & r2,const Operand & op,uint8 imm)1757 void vinserti32x8(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N32 | T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x3A, imm); }
vinserti64x2(const Ymm & r1,const Ymm & r2,const Operand & op,uint8 imm)1758 void vinserti64x2(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N16 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x38, imm); }
vinserti64x4(const Zmm & r1,const Zmm & r2,const Operand & op,uint8 imm)1759 void vinserti64x4(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) throw Error(ERR_BAD_COMBINATION); opVex(r1, &r2, op, T_N32 | T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x3A, imm); }
vmovdqa32(const Address & addr,const Xmm & x)1760 void vmovdqa32(const Address& addr, const Xmm& x) { opAVX_X_XM_IMM(x, addr, T_66 | T_0F | T_EW0 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX | T_M_K, 0x7F); }
vmovdqa32(const Xmm & x,const Operand & op)1761 void vmovdqa32(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F | T_EW0 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX, 0x6F); }
vmovdqa64(const Address & addr,const Xmm & x)1762 void vmovdqa64(const Address& addr, const Xmm& x) { opAVX_X_XM_IMM(x, addr, T_66 | T_0F | T_EW1 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX | T_M_K, 0x7F); }
vmovdqa64(const Xmm & x,const Operand & op)1763 void vmovdqa64(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F | T_EW1 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX, 0x6F); }
vmovdqu16(const Address & addr,const Xmm & x)1764 void vmovdqu16(const Address& addr, const Xmm& x) { opAVX_X_XM_IMM(x, addr, T_F2 | T_0F | T_EW1 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX | T_M_K, 0x7F); }
vmovdqu16(const Xmm & x,const Operand & op)1765 void vmovdqu16(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F2 | T_0F | T_EW1 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX, 0x6F); }
vmovdqu32(const Address & addr,const Xmm & x)1766 void vmovdqu32(const Address& addr, const Xmm& x) { opAVX_X_XM_IMM(x, addr, T_F3 | T_0F | T_EW0 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX | T_M_K, 0x7F); }
vmovdqu32(const Xmm & x,const Operand & op)1767 void vmovdqu32(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F3 | T_0F | T_EW0 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX, 0x6F); }
vmovdqu64(const Address & addr,const Xmm & x)1768 void vmovdqu64(const Address& addr, const Xmm& x) { opAVX_X_XM_IMM(x, addr, T_F3 | T_0F | T_EW1 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX | T_M_K, 0x7F); }
vmovdqu64(const Xmm & x,const Operand & op)1769 void vmovdqu64(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F3 | T_0F | T_EW1 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX, 0x6F); }
vmovdqu8(const Address & addr,const Xmm & x)1770 void vmovdqu8(const Address& addr, const Xmm& x) { opAVX_X_XM_IMM(x, addr, T_F2 | T_0F | T_EW0 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX | T_M_K, 0x7F); }
vmovdqu8(const Xmm & x,const Operand & op)1771 void vmovdqu8(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_F2 | T_0F | T_EW0 | T_YMM | T_ER_X | T_ER_Y | T_ER_Z | T_MUST_EVEX, 0x6F); }
vp4dpwssd(const Zmm & z1,const Zmm & z2,const Address & addr)1772 void vp4dpwssd(const Zmm& z1, const Zmm& z2, const Address& addr) { opAVX_X_X_XM(z1, z2, addr, T_0F38 | T_F2 | T_EW0 | T_YMM | T_MUST_EVEX | T_N16, 0x52); }
vp4dpwssds(const Zmm & z1,const Zmm & z2,const Address & addr)1773 void vp4dpwssds(const Zmm& z1, const Zmm& z2, const Address& addr) { opAVX_X_X_XM(z1, z2, addr, T_0F38 | T_F2 | T_EW0 | T_YMM | T_MUST_EVEX | T_N16, 0x53); }
vpabsq(const Xmm & x,const Operand & op)1774 void vpabsq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_MUST_EVEX | T_EW1 | T_B64 | T_YMM, 0x1F); }
vpandd(const Xmm & x1,const Xmm & x2,const Operand & op)1775 void vpandd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0xDB); }
vpandnd(const Xmm & x1,const Xmm & x2,const Operand & op)1776 void vpandnd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0xDF); }
vpandnq(const Xmm & x1,const Xmm & x2,const Operand & op)1777 void vpandnq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xDF); }
vpandq(const Xmm & x1,const Xmm & x2,const Operand & op)1778 void vpandq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xDB); }
vpblendmb(const Xmm & x1,const Xmm & x2,const Operand & op)1779 void vpblendmb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x66); }
vpblendmd(const Xmm & x1,const Xmm & x2,const Operand & op)1780 void vpblendmd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x64); }
vpblendmq(const Xmm & x1,const Xmm & x2,const Operand & op)1781 void vpblendmq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x64); }
vpblendmw(const Xmm & x1,const Xmm & x2,const Operand & op)1782 void vpblendmw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x66); }
vpbroadcastb(const Xmm & x,const Reg8 & r)1783 void vpbroadcastb(const Xmm& x, const Reg8& r) { opVex(x, 0, r, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x7A); }
vpbroadcastd(const Xmm & x,const Reg32 & r)1784 void vpbroadcastd(const Xmm& x, const Reg32& r) { opVex(x, 0, r, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x7C); }
vpbroadcastmb2q(const Xmm & x,const Opmask & k)1785 void vpbroadcastmb2q(const Xmm& x, const Opmask& k) { opVex(x, 0, k, T_F3 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW1, 0x2A); }
vpbroadcastmw2d(const Xmm & x,const Opmask & k)1786 void vpbroadcastmw2d(const Xmm& x, const Opmask& k) { opVex(x, 0, k, T_F3 | T_0F38 | T_YMM | T_MUST_EVEX | T_EW0, 0x3A); }
vpbroadcastw(const Xmm & x,const Reg16 & r)1787 void vpbroadcastw(const Xmm& x, const Reg16& r) { opVex(x, 0, r, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x7B); }
vpcmpb(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1788 void vpcmpb(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x3F, imm); }
vpcmpd(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1789 void vpcmpd(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x1F, imm); }
vpcmpeqb(const Opmask & k,const Xmm & x,const Operand & op)1790 void vpcmpeqb(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_YMM | T_MUST_EVEX, 0x74); }
vpcmpeqd(const Opmask & k,const Xmm & x,const Operand & op)1791 void vpcmpeqd(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_YMM | T_MUST_EVEX | T_B32, 0x76); }
vpcmpeqq(const Opmask & k,const Xmm & x,const Operand & op)1792 void vpcmpeqq(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x29); }
vpcmpeqw(const Opmask & k,const Xmm & x,const Operand & op)1793 void vpcmpeqw(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_YMM | T_MUST_EVEX, 0x75); }
vpcmpgtb(const Opmask & k,const Xmm & x,const Operand & op)1794 void vpcmpgtb(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_YMM | T_MUST_EVEX, 0x64); }
vpcmpgtd(const Opmask & k,const Xmm & x,const Operand & op)1795 void vpcmpgtd(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x66); }
vpcmpgtq(const Opmask & k,const Xmm & x,const Operand & op)1796 void vpcmpgtq(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x37); }
vpcmpgtw(const Opmask & k,const Xmm & x,const Operand & op)1797 void vpcmpgtw(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F | T_YMM | T_MUST_EVEX, 0x65); }
vpcmpq(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1798 void vpcmpq(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x1F, imm); }
vpcmpub(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1799 void vpcmpub(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX, 0x3E, imm); }
vpcmpud(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1800 void vpcmpud(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x1E, imm); }
vpcmpuq(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1801 void vpcmpuq(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x1E, imm); }
vpcmpuw(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1802 void vpcmpuw(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x3E, imm); }
vpcmpw(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1803 void vpcmpw(const Opmask& k, const Xmm& x, const Operand& op, uint8 imm) { opAVX_K_X_XM(k, x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX, 0x3F, imm); }
vpcompressd(const Operand & op,const Xmm & x)1804 void vpcompressd(const Operand& op, const Xmm& x) { opAVX_X_XM_IMM(x, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x8B); }
vpcompressq(const Operand & op,const Xmm & x)1805 void vpcompressq(const Operand& op, const Xmm& x) { opAVX_X_XM_IMM(x, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x8B); }
vpconflictd(const Xmm & x,const Operand & op)1806 void vpconflictd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0xC4); }
vpconflictq(const Xmm & x,const Operand & op)1807 void vpconflictq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xC4); }
vpdpbusd(const Xmm & x1,const Xmm & x2,const Operand & op)1808 void vpdpbusd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x50); }
vpdpbusds(const Xmm & x1,const Xmm & x2,const Operand & op)1809 void vpdpbusds(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x51); }
vpdpwssd(const Xmm & x1,const Xmm & x2,const Operand & op)1810 void vpdpwssd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x52); }
vpdpwssds(const Xmm & x1,const Xmm & x2,const Operand & op)1811 void vpdpwssds(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x53); }
vpermb(const Xmm & x1,const Xmm & x2,const Operand & op)1812 void vpermb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x8D); }
vpermi2b(const Xmm & x1,const Xmm & x2,const Operand & op)1813 void vpermi2b(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x75); }
vpermi2d(const Xmm & x1,const Xmm & x2,const Operand & op)1814 void vpermi2d(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x76); }
vpermi2pd(const Xmm & x1,const Xmm & x2,const Operand & op)1815 void vpermi2pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x77); }
vpermi2ps(const Xmm & x1,const Xmm & x2,const Operand & op)1816 void vpermi2ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x77); }
vpermi2q(const Xmm & x1,const Xmm & x2,const Operand & op)1817 void vpermi2q(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x76); }
vpermi2w(const Xmm & x1,const Xmm & x2,const Operand & op)1818 void vpermi2w(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x75); }
vpermt2b(const Xmm & x1,const Xmm & x2,const Operand & op)1819 void vpermt2b(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x7D); }
vpermt2d(const Xmm & x1,const Xmm & x2,const Operand & op)1820 void vpermt2d(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x7E); }
vpermt2pd(const Xmm & x1,const Xmm & x2,const Operand & op)1821 void vpermt2pd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x7F); }
vpermt2ps(const Xmm & x1,const Xmm & x2,const Operand & op)1822 void vpermt2ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x7F); }
vpermt2q(const Xmm & x1,const Xmm & x2,const Operand & op)1823 void vpermt2q(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x7E); }
vpermt2w(const Xmm & x1,const Xmm & x2,const Operand & op)1824 void vpermt2w(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x7D); }
vpermw(const Xmm & x1,const Xmm & x2,const Operand & op)1825 void vpermw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x8D); }
vpexpandb(const Xmm & x,const Operand & op)1826 void vpexpandb(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_N1 | T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x62); }
vpexpandd(const Xmm & x,const Operand & op)1827 void vpexpandd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x89); }
vpexpandq(const Xmm & x,const Operand & op)1828 void vpexpandq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x89); }
vpexpandw(const Xmm & x,const Operand & op)1829 void vpexpandw(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_N2 | T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x62); }
vpgatherdd(const Xmm & x,const Address & addr)1830 void vpgatherdd(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_VSIB, 0x90, 0); }
vpgatherdq(const Xmm & x,const Address & addr)1831 void vpgatherdq(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_VSIB, 0x90, 1); }
vpgatherqd(const Xmm & x,const Address & addr)1832 void vpgatherqd(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_VSIB, 0x91, 2); }
vpgatherqq(const Xmm & x,const Address & addr)1833 void vpgatherqq(const Xmm& x, const Address& addr) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_VSIB, 0x91, 0); }
vplzcntd(const Xmm & x,const Operand & op)1834 void vplzcntd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x44); }
vplzcntq(const Xmm & x,const Operand & op)1835 void vplzcntq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x44); }
vpmadd52huq(const Xmm & x1,const Xmm & x2,const Operand & op)1836 void vpmadd52huq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xB5); }
vpmadd52luq(const Xmm & x1,const Xmm & x2,const Operand & op)1837 void vpmadd52luq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xB4); }
vpmaxsq(const Xmm & x1,const Xmm & x2,const Operand & op)1838 void vpmaxsq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x3D); }
vpmaxuq(const Xmm & x1,const Xmm & x2,const Operand & op)1839 void vpmaxuq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x3F); }
vpminsq(const Xmm & x1,const Xmm & x2,const Operand & op)1840 void vpminsq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x39); }
vpminuq(const Xmm & x1,const Xmm & x2,const Operand & op)1841 void vpminuq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x3B); }
vpmovb2m(const Opmask & k,const Xmm & x)1842 void vpmovb2m(const Opmask& k, const Xmm& x) { opVex(k, 0, x, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0, 0x29); }
vpmovd2m(const Opmask & k,const Xmm & x)1843 void vpmovd2m(const Opmask& k, const Xmm& x) { opVex(k, 0, x, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0, 0x39); }
vpmovdb(const Operand & op,const Xmm & x)1844 void vpmovdb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N4 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x31, false); }
vpmovdw(const Operand & op,const Xmm & x)1845 void vpmovdw(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x33, true); }
vpmovm2b(const Xmm & x,const Opmask & k)1846 void vpmovm2b(const Xmm& x, const Opmask& k) { opVex(x, 0, k, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0, 0x28); }
vpmovm2d(const Xmm & x,const Opmask & k)1847 void vpmovm2d(const Xmm& x, const Opmask& k) { opVex(x, 0, k, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0, 0x38); }
vpmovm2q(const Xmm & x,const Opmask & k)1848 void vpmovm2q(const Xmm& x, const Opmask& k) { opVex(x, 0, k, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1, 0x38); }
vpmovm2w(const Xmm & x,const Opmask & k)1849 void vpmovm2w(const Xmm& x, const Opmask& k) { opVex(x, 0, k, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1, 0x28); }
vpmovq2m(const Opmask & k,const Xmm & x)1850 void vpmovq2m(const Opmask& k, const Xmm& x) { opVex(k, 0, x, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1, 0x39); }
vpmovqb(const Operand & op,const Xmm & x)1851 void vpmovqb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N2 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x32, false); }
vpmovqd(const Operand & op,const Xmm & x)1852 void vpmovqd(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x35, true); }
vpmovqw(const Operand & op,const Xmm & x)1853 void vpmovqw(const Operand& op, const Xmm& x) { opVmov(op, x, T_N4 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x34, false); }
vpmovsdb(const Operand & op,const Xmm & x)1854 void vpmovsdb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N4 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x21, false); }
vpmovsdw(const Operand & op,const Xmm & x)1855 void vpmovsdw(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x23, true); }
vpmovsqb(const Operand & op,const Xmm & x)1856 void vpmovsqb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N2 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x22, false); }
vpmovsqd(const Operand & op,const Xmm & x)1857 void vpmovsqd(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x25, true); }
vpmovsqw(const Operand & op,const Xmm & x)1858 void vpmovsqw(const Operand& op, const Xmm& x) { opVmov(op, x, T_N4 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x24, false); }
vpmovswb(const Operand & op,const Xmm & x)1859 void vpmovswb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x20, true); }
vpmovusdb(const Operand & op,const Xmm & x)1860 void vpmovusdb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N4 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x11, false); }
vpmovusdw(const Operand & op,const Xmm & x)1861 void vpmovusdw(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x13, true); }
vpmovusqb(const Operand & op,const Xmm & x)1862 void vpmovusqb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N2 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x12, false); }
vpmovusqd(const Operand & op,const Xmm & x)1863 void vpmovusqd(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x15, true); }
vpmovusqw(const Operand & op,const Xmm & x)1864 void vpmovusqw(const Operand& op, const Xmm& x) { opVmov(op, x, T_N4 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x14, false); }
vpmovuswb(const Operand & op,const Xmm & x)1865 void vpmovuswb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x10, true); }
vpmovw2m(const Opmask & k,const Xmm & x)1866 void vpmovw2m(const Opmask& k, const Xmm& x) { opVex(k, 0, x, T_F3 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1, 0x29); }
vpmovwb(const Operand & op,const Xmm & x)1867 void vpmovwb(const Operand& op, const Xmm& x) { opVmov(op, x, T_N8 | T_N_VL | T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x30, true); }
vpmullq(const Xmm & x1,const Xmm & x2,const Operand & op)1868 void vpmullq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x40); }
vpmultishiftqb(const Xmm & x1,const Xmm & x2,const Operand & op)1869 void vpmultishiftqb(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x83); }
vpopcntb(const Xmm & x,const Operand & op)1870 void vpopcntb(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x54); }
vpopcntd(const Xmm & x,const Operand & op)1871 void vpopcntd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x55); }
vpopcntq(const Xmm & x,const Operand & op)1872 void vpopcntq(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x55); }
vpopcntw(const Xmm & x,const Operand & op)1873 void vpopcntw(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x54); }
vpord(const Xmm & x1,const Xmm & x2,const Operand & op)1874 void vpord(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0xEB); }
vporq(const Xmm & x1,const Xmm & x2,const Operand & op)1875 void vporq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xEB); }
vprold(const Xmm & x,const Operand & op,uint8 imm)1876 void vprold(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 1), x, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x72, imm); }
vprolq(const Xmm & x,const Operand & op,uint8 imm)1877 void vprolq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 1), x, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x72, imm); }
vprolvd(const Xmm & x1,const Xmm & x2,const Operand & op)1878 void vprolvd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x15); }
vprolvq(const Xmm & x1,const Xmm & x2,const Operand & op)1879 void vprolvq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x15); }
vprord(const Xmm & x,const Operand & op,uint8 imm)1880 void vprord(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 0), x, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x72, imm); }
vprorq(const Xmm & x,const Operand & op,uint8 imm)1881 void vprorq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 0), x, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x72, imm); }
vprorvd(const Xmm & x1,const Xmm & x2,const Operand & op)1882 void vprorvd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x14); }
vprorvq(const Xmm & x1,const Xmm & x2,const Operand & op)1883 void vprorvq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x14); }
vpscatterdd(const Address & addr,const Xmm & x)1884 void vpscatterdd(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA0, 0); }
vpscatterdq(const Address & addr,const Xmm & x)1885 void vpscatterdq(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA0, 1); }
vpscatterqd(const Address & addr,const Xmm & x)1886 void vpscatterqd(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA1, 2); }
vpscatterqq(const Address & addr,const Xmm & x)1887 void vpscatterqq(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA1, 0); }
vpshldd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1888 void vpshldd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x71, imm); }
vpshldq(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1889 void vpshldq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x71, imm); }
vpshldvd(const Xmm & x1,const Xmm & x2,const Operand & op)1890 void vpshldvd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x71); }
vpshldvq(const Xmm & x1,const Xmm & x2,const Operand & op)1891 void vpshldvq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x71); }
vpshldvw(const Xmm & x1,const Xmm & x2,const Operand & op)1892 void vpshldvw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x70); }
vpshldw(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1893 void vpshldw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x70, imm); }
vpshrdd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1894 void vpshrdd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x73, imm); }
vpshrdq(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1895 void vpshrdq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x73, imm); }
vpshrdvd(const Xmm & x1,const Xmm & x2,const Operand & op)1896 void vpshrdvd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x73); }
vpshrdvq(const Xmm & x1,const Xmm & x2,const Operand & op)1897 void vpshrdvq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x73); }
vpshrdvw(const Xmm & x1,const Xmm & x2,const Operand & op)1898 void vpshrdvw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x72); }
vpshrdw(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1899 void vpshrdw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX, 0x72, imm); }
vpshufbitqmb(const Opmask & k,const Xmm & x,const Operand & op)1900 void vpshufbitqmb(const Opmask& k, const Xmm& x, const Operand& op) { opVex(k, &x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x8F); }
vpsllvw(const Xmm & x1,const Xmm & x2,const Operand & op)1901 void vpsllvw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x12); }
vpsraq(const Xmm & x,const Operand & op,uint8 imm)1902 void vpsraq(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_X_XM(Xmm(x.getKind(), 4), x, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x72, imm); }
vpsraq(const Xmm & x1,const Xmm & x2,const Operand & op)1903 void vpsraq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N16 | T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX, 0xE2); }
vpsravq(const Xmm & x1,const Xmm & x2,const Operand & op)1904 void vpsravq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x46); }
vpsravw(const Xmm & x1,const Xmm & x2,const Operand & op)1905 void vpsravw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x11); }
vpsrlvw(const Xmm & x1,const Xmm & x2,const Operand & op)1906 void vpsrlvw(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x10); }
vpternlogd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1907 void vpternlogd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x25, imm); }
vpternlogq(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1908 void vpternlogq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x25, imm); }
vptestmb(const Opmask & k,const Xmm & x,const Operand & op)1909 void vptestmb(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x26); }
vptestmd(const Opmask & k,const Xmm & x,const Operand & op)1910 void vptestmd(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x27); }
vptestmq(const Opmask & k,const Xmm & x,const Operand & op)1911 void vptestmq(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x27); }
vptestmw(const Opmask & k,const Xmm & x,const Operand & op)1912 void vptestmw(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x26); }
vptestnmb(const Opmask & k,const Xmm & x,const Operand & op)1913 void vptestnmb(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x26); }
vptestnmd(const Opmask & k,const Xmm & x,const Operand & op)1914 void vptestnmd(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_F3 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x27); }
vptestnmq(const Opmask & k,const Xmm & x,const Operand & op)1915 void vptestnmq(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_F3 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x27); }
vptestnmw(const Opmask & k,const Xmm & x,const Operand & op)1916 void vptestnmw(const Opmask& k, const Xmm& x, const Operand& op) { opAVX_K_X_XM(k, x, op, T_F3 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x26); }
vpxord(const Xmm & x1,const Xmm & x2,const Operand & op)1917 void vpxord(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0xEF); }
vpxorq(const Xmm & x1,const Xmm & x2,const Operand & op)1918 void vpxorq(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0xEF); }
vrangepd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1919 void vrangepd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x50, imm); }
vrangeps(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1920 void vrangeps(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x50, imm); }
vrangesd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1921 void vrangesd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F3A | T_EW1 | T_SAE_X | T_MUST_EVEX, 0x51, imm); }
vrangess(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1922 void vrangess(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F3A | T_EW0 | T_SAE_X | T_MUST_EVEX, 0x51, imm); }
vrcp14pd(const Xmm & x,const Operand & op)1923 void vrcp14pd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x4C); }
vrcp14ps(const Xmm & x,const Operand & op)1924 void vrcp14ps(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x4C); }
vrcp14sd(const Xmm & x1,const Xmm & x2,const Operand & op)1925 void vrcp14sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX, 0x4D); }
vrcp14ss(const Xmm & x1,const Xmm & x2,const Operand & op)1926 void vrcp14ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX, 0x4D); }
vrcp28pd(const Zmm & z,const Operand & op)1927 void vrcp28pd(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1 | T_B64 | T_SAE_Z, 0xCA); }
vrcp28ps(const Zmm & z,const Operand & op)1928 void vrcp28ps(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0 | T_B32 | T_SAE_Z, 0xCA); }
vrcp28sd(const Xmm & x1,const Xmm & x2,const Operand & op)1929 void vrcp28sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_SAE_X | T_MUST_EVEX, 0xCB); }
vrcp28ss(const Xmm & x1,const Xmm & x2,const Operand & op)1930 void vrcp28ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_SAE_X | T_MUST_EVEX, 0xCB); }
vreducepd(const Xmm & x,const Operand & op,uint8 imm)1931 void vreducepd(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B64, 0x56, imm); }
vreduceps(const Xmm & x,const Operand & op,uint8 imm)1932 void vreduceps(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x56, imm); }
vreducesd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1933 void vreducesd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F3A | T_EW1 | T_SAE_X | T_MUST_EVEX, 0x57, imm); }
vreducess(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1934 void vreducess(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F3A | T_EW0 | T_SAE_X | T_MUST_EVEX, 0x57, imm); }
vrndscalepd(const Xmm & x,const Operand & op,uint8 imm)1935 void vrndscalepd(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(x, op, T_66 | T_0F3A | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x09, imm); }
vrndscaleps(const Xmm & x,const Operand & op,uint8 imm)1936 void vrndscaleps(const Xmm& x, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(x, op, T_66 | T_0F3A | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x08, imm); }
vrndscalesd(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1937 void vrndscalesd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F3A | T_EW1 | T_MUST_EVEX, 0x0B, imm); }
vrndscaless(const Xmm & x1,const Xmm & x2,const Operand & op,uint8 imm)1938 void vrndscaless(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F3A | T_EW0 | T_MUST_EVEX, 0x0A, imm); }
vrsqrt14pd(const Xmm & x,const Operand & op)1939 void vrsqrt14pd(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_B64, 0x4E); }
vrsqrt14ps(const Xmm & x,const Operand & op)1940 void vrsqrt14ps(const Xmm& x, const Operand& op) { opAVX_X_XM_IMM(x, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_B32, 0x4E); }
vrsqrt14sd(const Xmm & x1,const Xmm & x2,const Operand & op)1941 void vrsqrt14sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x4F); }
vrsqrt14ss(const Xmm & x1,const Xmm & x2,const Operand & op)1942 void vrsqrt14ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX, 0x4F); }
vrsqrt28pd(const Zmm & z,const Operand & op)1943 void vrsqrt28pd(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW1 | T_B64 | T_SAE_Z, 0xCC); }
vrsqrt28ps(const Zmm & z,const Operand & op)1944 void vrsqrt28ps(const Zmm& z, const Operand& op) { opAVX_X_XM_IMM(z, op, T_66 | T_0F38 | T_MUST_EVEX | T_YMM | T_EW0 | T_B32 | T_SAE_Z, 0xCC); }
vrsqrt28sd(const Xmm & x1,const Xmm & x2,const Operand & op)1945 void vrsqrt28sd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_SAE_X | T_MUST_EVEX, 0xCD); }
vrsqrt28ss(const Xmm & x1,const Xmm & x2,const Operand & op)1946 void vrsqrt28ss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_SAE_X | T_MUST_EVEX, 0xCD); }
vscalefpd(const Xmm & x1,const Xmm & x2,const Operand & op)1947 void vscalefpd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW1 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B64, 0x2C); }
vscalefps(const Xmm & x1,const Xmm & x2,const Operand & op)1948 void vscalefps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_66 | T_0F38 | T_EW0 | T_YMM | T_ER_Z | T_MUST_EVEX | T_B32, 0x2C); }
vscalefsd(const Xmm & x1,const Xmm & x2,const Operand & op)1949 void vscalefsd(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N8 | T_66 | T_0F38 | T_EW1 | T_ER_X | T_MUST_EVEX, 0x2D); }
vscalefss(const Xmm & x1,const Xmm & x2,const Operand & op)1950 void vscalefss(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_N4 | T_66 | T_0F38 | T_EW0 | T_ER_X | T_MUST_EVEX, 0x2D); }
vscatterdpd(const Address & addr,const Xmm & x)1951 void vscatterdpd(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA2, 1); }
vscatterdps(const Address & addr,const Xmm & x)1952 void vscatterdps(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA2, 0); }
vscatterpf0dpd(const Address & addr)1953 void vscatterpf0dpd(const Address& addr) { opGatherFetch(addr, zm5, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::YMM); }
vscatterpf0dps(const Address & addr)1954 void vscatterpf0dps(const Address& addr) { opGatherFetch(addr, zm5, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::ZMM); }
vscatterpf0qpd(const Address & addr)1955 void vscatterpf0qpd(const Address& addr) { opGatherFetch(addr, zm5, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vscatterpf0qps(const Address & addr)1956 void vscatterpf0qps(const Address& addr) { opGatherFetch(addr, zm5, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vscatterpf1dpd(const Address & addr)1957 void vscatterpf1dpd(const Address& addr) { opGatherFetch(addr, zm6, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::YMM); }
vscatterpf1dps(const Address & addr)1958 void vscatterpf1dps(const Address& addr) { opGatherFetch(addr, zm6, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC6, Operand::ZMM); }
vscatterpf1qpd(const Address & addr)1959 void vscatterpf1qpd(const Address& addr) { opGatherFetch(addr, zm6, T_N8 | T_66 | T_0F38 | T_EW1 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vscatterpf1qps(const Address & addr)1960 void vscatterpf1qps(const Address& addr) { opGatherFetch(addr, zm6, T_N4 | T_66 | T_0F38 | T_EW0 | T_MUST_EVEX | T_M_K | T_VSIB, 0xC7, Operand::ZMM); }
vscatterqpd(const Address & addr,const Xmm & x)1961 void vscatterqpd(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N8 | T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA3, 0); }
vscatterqps(const Address & addr,const Xmm & x)1962 void vscatterqps(const Address& addr, const Xmm& x) { opGather2(x, addr, T_N4 | T_66 | T_0F38 | T_EW0 | T_YMM | T_MUST_EVEX | T_M_K | T_VSIB, 0xA3, 2); }
vshuff32x4(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1963 void vshuff32x4(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F3A | T_YMM | T_MUST_EVEX | T_EW0 | T_B32, 0x23, imm); }
vshuff64x2(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1964 void vshuff64x2(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F3A | T_YMM | T_MUST_EVEX | T_EW1 | T_B64, 0x23, imm); }
vshufi32x4(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1965 void vshufi32x4(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F3A | T_YMM | T_MUST_EVEX | T_EW0 | T_B32, 0x43, imm); }
vshufi64x2(const Ymm & y1,const Ymm & y2,const Operand & op,uint8 imm)1966 void vshufi64x2(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { opAVX_X_X_XM(y1, y2, op, T_66 | T_0F3A | T_YMM | T_MUST_EVEX | T_EW1 | T_B64, 0x43, imm); }
1967 #ifdef XBYAK64
kmovq(const Opmask & k,const Reg64 & r)1968 void kmovq(const Opmask& k, const Reg64& r) { opVex(k, 0, r, T_L0 | T_0F | T_F2 | T_W1, 0x92); }
kmovq(const Reg64 & r,const Opmask & k)1969 void kmovq(const Reg64& r, const Opmask& k) { opVex(r, 0, k, T_L0 | T_0F | T_F2 | T_W1, 0x93); }
vpbroadcastq(const Xmm & x,const Reg64 & r)1970 void vpbroadcastq(const Xmm& x, const Reg64& r) { opVex(x, 0, r, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x7C); }
1971 #endif
1972 #endif
1973