getVersionString()1 const char *getVersionString() const { return "5.96"; }
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); }
clflushopt(const Address & addr)61 void clflushopt(const Address& addr) { db(0x66); opModM(addr, Reg32(7), 0x0F, 0xAE); }
cli()62 void cli() { db(0xFA); }
clzero()63 void clzero() { db(0x0F); db(0x01); db(0xFC); }
cmc()64 void cmc() { db(0xF5); }
cmova(const Reg & reg,const Operand & op)65 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)66 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)67 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)68 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)69 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)70 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)71 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)72 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)73 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)74 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)75 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)76 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)77 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)78 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)79 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)80 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)81 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)82 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)83 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)84 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)85 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)86 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)87 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)88 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)89 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)90 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)91 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)92 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)93 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)94 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)95 void cmp(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x38, 7); }
cmp(const Operand & op1,const Operand & op2)96 void cmp(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x38); }
cmpeqpd(const Xmm & x,const Operand & op)97 void cmpeqpd(const Xmm& x, const Operand& op) { cmppd(x, op, 0); }
cmpeqps(const Xmm & x,const Operand & op)98 void cmpeqps(const Xmm& x, const Operand& op) { cmpps(x, op, 0); }
cmpeqsd(const Xmm & x,const Operand & op)99 void cmpeqsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 0); }
cmpeqss(const Xmm & x,const Operand & op)100 void cmpeqss(const Xmm& x, const Operand& op) { cmpss(x, op, 0); }
cmplepd(const Xmm & x,const Operand & op)101 void cmplepd(const Xmm& x, const Operand& op) { cmppd(x, op, 2); }
cmpleps(const Xmm & x,const Operand & op)102 void cmpleps(const Xmm& x, const Operand& op) { cmpps(x, op, 2); }
cmplesd(const Xmm & x,const Operand & op)103 void cmplesd(const Xmm& x, const Operand& op) { cmpsd(x, op, 2); }
cmpless(const Xmm & x,const Operand & op)104 void cmpless(const Xmm& x, const Operand& op) { cmpss(x, op, 2); }
cmpltpd(const Xmm & x,const Operand & op)105 void cmpltpd(const Xmm& x, const Operand& op) { cmppd(x, op, 1); }
cmpltps(const Xmm & x,const Operand & op)106 void cmpltps(const Xmm& x, const Operand& op) { cmpps(x, op, 1); }
cmpltsd(const Xmm & x,const Operand & op)107 void cmpltsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 1); }
cmpltss(const Xmm & x,const Operand & op)108 void cmpltss(const Xmm& x, const Operand& op) { cmpss(x, op, 1); }
cmpneqpd(const Xmm & x,const Operand & op)109 void cmpneqpd(const Xmm& x, const Operand& op) { cmppd(x, op, 4); }
cmpneqps(const Xmm & x,const Operand & op)110 void cmpneqps(const Xmm& x, const Operand& op) { cmpps(x, op, 4); }
cmpneqsd(const Xmm & x,const Operand & op)111 void cmpneqsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 4); }
cmpneqss(const Xmm & x,const Operand & op)112 void cmpneqss(const Xmm& x, const Operand& op) { cmpss(x, op, 4); }
cmpnlepd(const Xmm & x,const Operand & op)113 void cmpnlepd(const Xmm& x, const Operand& op) { cmppd(x, op, 6); }
cmpnleps(const Xmm & x,const Operand & op)114 void cmpnleps(const Xmm& x, const Operand& op) { cmpps(x, op, 6); }
cmpnlesd(const Xmm & x,const Operand & op)115 void cmpnlesd(const Xmm& x, const Operand& op) { cmpsd(x, op, 6); }
cmpnless(const Xmm & x,const Operand & op)116 void cmpnless(const Xmm& x, const Operand& op) { cmpss(x, op, 6); }
cmpnltpd(const Xmm & x,const Operand & op)117 void cmpnltpd(const Xmm& x, const Operand& op) { cmppd(x, op, 5); }
cmpnltps(const Xmm & x,const Operand & op)118 void cmpnltps(const Xmm& x, const Operand& op) { cmpps(x, op, 5); }
cmpnltsd(const Xmm & x,const Operand & op)119 void cmpnltsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 5); }
cmpnltss(const Xmm & x,const Operand & op)120 void cmpnltss(const Xmm& x, const Operand& op) { cmpss(x, op, 5); }
cmpordpd(const Xmm & x,const Operand & op)121 void cmpordpd(const Xmm& x, const Operand& op) { cmppd(x, op, 7); }
cmpordps(const Xmm & x,const Operand & op)122 void cmpordps(const Xmm& x, const Operand& op) { cmpps(x, op, 7); }
cmpordsd(const Xmm & x,const Operand & op)123 void cmpordsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 7); }
cmpordss(const Xmm & x,const Operand & op)124 void cmpordss(const Xmm& x, const Operand& op) { cmpss(x, op, 7); }
cmppd(const Xmm & xmm,const Operand & op,uint8 imm8)125 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)126 void cmpps(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC2, 0x100, isXMM_XMMorMEM, imm8); }
cmpsb()127 void cmpsb() { db(0xA6); }
cmpsd()128 void cmpsd() { db(0xA7); }
cmpsd(const Xmm & xmm,const Operand & op,uint8 imm8)129 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)130 void cmpss(const Xmm& xmm, const Operand& op, uint8 imm8) { opGen(xmm, op, 0xC2, 0xF3, isXMM_XMMorMEM, imm8); }
cmpsw()131 void cmpsw() { db(0x66); db(0xA7); }
cmpunordpd(const Xmm & x,const Operand & op)132 void cmpunordpd(const Xmm& x, const Operand& op) { cmppd(x, op, 3); }
cmpunordps(const Xmm & x,const Operand & op)133 void cmpunordps(const Xmm& x, const Operand& op) { cmpps(x, op, 3); }
cmpunordsd(const Xmm & x,const Operand & op)134 void cmpunordsd(const Xmm& x, const Operand& op) { cmpsd(x, op, 3); }
cmpunordss(const Xmm & x,const Operand & op)135 void cmpunordss(const Xmm& x, const Operand& op) { cmpss(x, op, 3); }
cmpxchg(const Operand & op,const Reg & reg)136 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)137 void cmpxchg8b(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0xC7); }
comisd(const Xmm & xmm,const Operand & op)138 void comisd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2F, 0x66, isXMM_XMMorMEM); }
comiss(const Xmm & xmm,const Operand & op)139 void comiss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2F, 0x100, isXMM_XMMorMEM); }
cpuid()140 void cpuid() { db(0x0F); db(0xA2); }
crc32(const Reg32e & reg,const Operand & op)141 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)142 void cvtdq2pd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xE6, 0xF3, isXMM_XMMorMEM); }
cvtdq2ps(const Xmm & xmm,const Operand & op)143 void cvtdq2ps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5B, 0x100, isXMM_XMMorMEM); }
cvtpd2dq(const Xmm & xmm,const Operand & op)144 void cvtpd2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xE6, 0xF2, isXMM_XMMorMEM); }
cvtpd2pi(const Operand & reg,const Operand & op)145 void cvtpd2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0x66, isMMX_XMMorMEM); }
cvtpd2ps(const Xmm & xmm,const Operand & op)146 void cvtpd2ps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0x66, isXMM_XMMorMEM); }
cvtpi2pd(const Operand & reg,const Operand & op)147 void cvtpi2pd(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0x66, isXMM_MMXorMEM); }
cvtpi2ps(const Operand & reg,const Operand & op)148 void cvtpi2ps(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0x100, isXMM_MMXorMEM); }
cvtps2dq(const Xmm & xmm,const Operand & op)149 void cvtps2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5B, 0x66, isXMM_XMMorMEM); }
cvtps2pd(const Xmm & xmm,const Operand & op)150 void cvtps2pd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0x100, isXMM_XMMorMEM); }
cvtps2pi(const Operand & reg,const Operand & op)151 void cvtps2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0x100, isMMX_XMMorMEM); }
cvtsd2si(const Operand & reg,const Operand & op)152 void cvtsd2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0xF2, isREG32_XMMorMEM); }
cvtsd2ss(const Xmm & xmm,const Operand & op)153 void cvtsd2ss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0xF2, isXMM_XMMorMEM); }
cvtsi2sd(const Operand & reg,const Operand & op)154 void cvtsi2sd(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0xF2, isXMM_REG32orMEM); }
cvtsi2ss(const Operand & reg,const Operand & op)155 void cvtsi2ss(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2A, 0xF3, isXMM_REG32orMEM); }
cvtss2sd(const Xmm & xmm,const Operand & op)156 void cvtss2sd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5A, 0xF3, isXMM_XMMorMEM); }
cvtss2si(const Operand & reg,const Operand & op)157 void cvtss2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2D, 0xF3, isREG32_XMMorMEM); }
cvttpd2dq(const Xmm & xmm,const Operand & op)158 void cvttpd2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xE6, 0x66, isXMM_XMMorMEM); }
cvttpd2pi(const Operand & reg,const Operand & op)159 void cvttpd2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0x66, isMMX_XMMorMEM); }
cvttps2dq(const Xmm & xmm,const Operand & op)160 void cvttps2dq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5B, 0xF3, isXMM_XMMorMEM); }
cvttps2pi(const Operand & reg,const Operand & op)161 void cvttps2pi(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0x100, isMMX_XMMorMEM); }
cvttsd2si(const Operand & reg,const Operand & op)162 void cvttsd2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0xF2, isREG32_XMMorMEM); }
cvttss2si(const Operand & reg,const Operand & op)163 void cvttss2si(const Operand& reg, const Operand& op) { opGen(reg, op, 0x2C, 0xF3, isREG32_XMMorMEM); }
cwd()164 void cwd() { db(0x66); db(0x99); }
cwde()165 void cwde() { db(0x98); }
dec(const Operand & op)166 void dec(const Operand& op) { opIncDec(op, 0x48, 1); }
div(const Operand & op)167 void div(const Operand& op) { opR_ModM(op, 0, 6, 0xF6); }
divpd(const Xmm & xmm,const Operand & op)168 void divpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0x66, isXMM_XMMorMEM); }
divps(const Xmm & xmm,const Operand & op)169 void divps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0x100, isXMM_XMMorMEM); }
divsd(const Xmm & xmm,const Operand & op)170 void divsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0xF2, isXMM_XMMorMEM); }
divss(const Xmm & xmm,const Operand & op)171 void divss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5E, 0xF3, isXMM_XMMorMEM); }
dppd(const Xmm & xmm,const Operand & op,int imm)172 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)173 void dpps(const Xmm& xmm, const Operand& op, int imm) { opGen(xmm, op, 0x40, 0x66, isXMM_XMMorMEM, static_cast<uint8>(imm), 0x3A); }
emms()174 void emms() { db(0x0F); db(0x77); }
enter(uint16 x,uint8 y)175 void enter(uint16 x, uint8 y) { db(0xC8); dw(x); db(y); }
extractps(const Operand & op,const Xmm & xmm,uint8 imm)176 void extractps(const Operand& op, const Xmm& xmm, uint8 imm) { opExt(op, xmm, 0x17, imm); }
f2xm1()177 void f2xm1() { db(0xD9); db(0xF0); }
fabs()178 void fabs() { db(0xD9); db(0xE1); }
fadd(const Address & addr)179 void fadd(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 0, 0); }
fadd(const Fpu & reg1)180 void fadd(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8C0, 0xDCC0); }
fadd(const Fpu & reg1,const Fpu & reg2)181 void fadd(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8C0, 0xDCC0); }
faddp()182 void faddp() { db(0xDE); db(0xC1); }
faddp(const Fpu & reg1)183 void faddp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEC0); }
faddp(const Fpu & reg1,const Fpu & reg2)184 void faddp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEC0); }
fbld(const Address & addr)185 void fbld(const Address& addr) { opModM(addr, Reg32(4), 0xDF, 0x100); }
fbstp(const Address & addr)186 void fbstp(const Address& addr) { opModM(addr, Reg32(6), 0xDF, 0x100); }
fchs()187 void fchs() { db(0xD9); db(0xE0); }
fclex()188 void fclex() { db(0x9B); db(0xDB); db(0xE2); }
fcmovb(const Fpu & reg1)189 void fcmovb(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAC0, 0x00C0); }
fcmovb(const Fpu & reg1,const Fpu & reg2)190 void fcmovb(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAC0, 0x00C0); }
fcmovbe(const Fpu & reg1)191 void fcmovbe(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAD0, 0x00D0); }
fcmovbe(const Fpu & reg1,const Fpu & reg2)192 void fcmovbe(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAD0, 0x00D0); }
fcmove(const Fpu & reg1)193 void fcmove(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAC8, 0x00C8); }
fcmove(const Fpu & reg1,const Fpu & reg2)194 void fcmove(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAC8, 0x00C8); }
fcmovnb(const Fpu & reg1)195 void fcmovnb(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBC0, 0x00C0); }
fcmovnb(const Fpu & reg1,const Fpu & reg2)196 void fcmovnb(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBC0, 0x00C0); }
fcmovnbe(const Fpu & reg1)197 void fcmovnbe(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBD0, 0x00D0); }
fcmovnbe(const Fpu & reg1,const Fpu & reg2)198 void fcmovnbe(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBD0, 0x00D0); }
fcmovne(const Fpu & reg1)199 void fcmovne(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBC8, 0x00C8); }
fcmovne(const Fpu & reg1,const Fpu & reg2)200 void fcmovne(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBC8, 0x00C8); }
fcmovnu(const Fpu & reg1)201 void fcmovnu(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBD8, 0x00D8); }
fcmovnu(const Fpu & reg1,const Fpu & reg2)202 void fcmovnu(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBD8, 0x00D8); }
fcmovu(const Fpu & reg1)203 void fcmovu(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDAD8, 0x00D8); }
fcmovu(const Fpu & reg1,const Fpu & reg2)204 void fcmovu(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDAD8, 0x00D8); }
fcom()205 void fcom() { db(0xD8); db(0xD1); }
fcom(const Address & addr)206 void fcom(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 2, 0); }
fcom(const Fpu & reg)207 void fcom(const Fpu& reg) { opFpu(reg, 0xD8, 0xD0); }
fcomi(const Fpu & reg1)208 void fcomi(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBF0, 0x00F0); }
fcomi(const Fpu & reg1,const Fpu & reg2)209 void fcomi(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBF0, 0x00F0); }
fcomip(const Fpu & reg1)210 void fcomip(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDFF0, 0x00F0); }
fcomip(const Fpu & reg1,const Fpu & reg2)211 void fcomip(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDFF0, 0x00F0); }
fcomp()212 void fcomp() { db(0xD8); db(0xD9); }
fcomp(const Address & addr)213 void fcomp(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 3, 0); }
fcomp(const Fpu & reg)214 void fcomp(const Fpu& reg) { opFpu(reg, 0xD8, 0xD8); }
fcompp()215 void fcompp() { db(0xDE); db(0xD9); }
fcos()216 void fcos() { db(0xD9); db(0xFF); }
fdecstp()217 void fdecstp() { db(0xD9); db(0xF6); }
fdiv(const Address & addr)218 void fdiv(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 6, 0); }
fdiv(const Fpu & reg1)219 void fdiv(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8F0, 0xDCF8); }
fdiv(const Fpu & reg1,const Fpu & reg2)220 void fdiv(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8F0, 0xDCF8); }
fdivp()221 void fdivp() { db(0xDE); db(0xF9); }
fdivp(const Fpu & reg1)222 void fdivp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEF8); }
fdivp(const Fpu & reg1,const Fpu & reg2)223 void fdivp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEF8); }
fdivr(const Address & addr)224 void fdivr(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 7, 0); }
fdivr(const Fpu & reg1)225 void fdivr(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8F8, 0xDCF0); }
fdivr(const Fpu & reg1,const Fpu & reg2)226 void fdivr(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8F8, 0xDCF0); }
fdivrp()227 void fdivrp() { db(0xDE); db(0xF1); }
fdivrp(const Fpu & reg1)228 void fdivrp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEF0); }
fdivrp(const Fpu & reg1,const Fpu & reg2)229 void fdivrp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEF0); }
ffree(const Fpu & reg)230 void ffree(const Fpu& reg) { opFpu(reg, 0xDD, 0xC0); }
fiadd(const Address & addr)231 void fiadd(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 0, 0); }
ficom(const Address & addr)232 void ficom(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 2, 0); }
ficomp(const Address & addr)233 void ficomp(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 3, 0); }
fidiv(const Address & addr)234 void fidiv(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 6, 0); }
fidivr(const Address & addr)235 void fidivr(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 7, 0); }
fild(const Address & addr)236 void fild(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0xDF, 0, 5); }
fimul(const Address & addr)237 void fimul(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 1, 0); }
fincstp()238 void fincstp() { db(0xD9); db(0xF7); }
finit()239 void finit() { db(0x9B); db(0xDB); db(0xE3); }
fist(const Address & addr)240 void fist(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0x00, 2, 0); }
fistp(const Address & addr)241 void fistp(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0xDF, 3, 7); }
fisttp(const Address & addr)242 void fisttp(const Address& addr) { opFpuMem(addr, 0xDF, 0xDB, 0xDD, 1, 0); }
fisub(const Address & addr)243 void fisub(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 4, 0); }
fisubr(const Address & addr)244 void fisubr(const Address& addr) { opFpuMem(addr, 0xDE, 0xDA, 0x00, 5, 0); }
fld(const Address & addr)245 void fld(const Address& addr) { opFpuMem(addr, 0x00, 0xD9, 0xDD, 0, 0); }
fld(const Fpu & reg)246 void fld(const Fpu& reg) { opFpu(reg, 0xD9, 0xC0); }
fld1()247 void fld1() { db(0xD9); db(0xE8); }
fldcw(const Address & addr)248 void fldcw(const Address& addr) { opModM(addr, Reg32(5), 0xD9, 0x100); }
fldenv(const Address & addr)249 void fldenv(const Address& addr) { opModM(addr, Reg32(4), 0xD9, 0x100); }
fldl2e()250 void fldl2e() { db(0xD9); db(0xEA); }
fldl2t()251 void fldl2t() { db(0xD9); db(0xE9); }
fldlg2()252 void fldlg2() { db(0xD9); db(0xEC); }
fldln2()253 void fldln2() { db(0xD9); db(0xED); }
fldpi()254 void fldpi() { db(0xD9); db(0xEB); }
fldz()255 void fldz() { db(0xD9); db(0xEE); }
fmul(const Address & addr)256 void fmul(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 1, 0); }
fmul(const Fpu & reg1)257 void fmul(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8C8, 0xDCC8); }
fmul(const Fpu & reg1,const Fpu & reg2)258 void fmul(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8C8, 0xDCC8); }
fmulp()259 void fmulp() { db(0xDE); db(0xC9); }
fmulp(const Fpu & reg1)260 void fmulp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEC8); }
fmulp(const Fpu & reg1,const Fpu & reg2)261 void fmulp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEC8); }
fnclex()262 void fnclex() { db(0xDB); db(0xE2); }
fninit()263 void fninit() { db(0xDB); db(0xE3); }
fnop()264 void fnop() { db(0xD9); db(0xD0); }
fnsave(const Address & addr)265 void fnsave(const Address& addr) { opModM(addr, Reg32(6), 0xDD, 0x100); }
fnstcw(const Address & addr)266 void fnstcw(const Address& addr) { opModM(addr, Reg32(7), 0xD9, 0x100); }
fnstenv(const Address & addr)267 void fnstenv(const Address& addr) { opModM(addr, Reg32(6), 0xD9, 0x100); }
fnstsw(const Address & addr)268 void fnstsw(const Address& addr) { opModM(addr, Reg32(7), 0xDD, 0x100); }
fnstsw(const Reg16 & r)269 void fnstsw(const Reg16& r) { if (r.getIdx() != Operand::AX) XBYAK_THROW(ERR_BAD_PARAMETER) db(0xDF); db(0xE0); }
fpatan()270 void fpatan() { db(0xD9); db(0xF3); }
fprem()271 void fprem() { db(0xD9); db(0xF8); }
fprem1()272 void fprem1() { db(0xD9); db(0xF5); }
fptan()273 void fptan() { db(0xD9); db(0xF2); }
frndint()274 void frndint() { db(0xD9); db(0xFC); }
frstor(const Address & addr)275 void frstor(const Address& addr) { opModM(addr, Reg32(4), 0xDD, 0x100); }
fsave(const Address & addr)276 void fsave(const Address& addr) { db(0x9B); opModM(addr, Reg32(6), 0xDD, 0x100); }
fscale()277 void fscale() { db(0xD9); db(0xFD); }
fsin()278 void fsin() { db(0xD9); db(0xFE); }
fsincos()279 void fsincos() { db(0xD9); db(0xFB); }
fsqrt()280 void fsqrt() { db(0xD9); db(0xFA); }
fst(const Address & addr)281 void fst(const Address& addr) { opFpuMem(addr, 0x00, 0xD9, 0xDD, 2, 0); }
fst(const Fpu & reg)282 void fst(const Fpu& reg) { opFpu(reg, 0xDD, 0xD0); }
fstcw(const Address & addr)283 void fstcw(const Address& addr) { db(0x9B); opModM(addr, Reg32(7), 0xD9, 0x100); }
fstenv(const Address & addr)284 void fstenv(const Address& addr) { db(0x9B); opModM(addr, Reg32(6), 0xD9, 0x100); }
fstp(const Address & addr)285 void fstp(const Address& addr) { opFpuMem(addr, 0x00, 0xD9, 0xDD, 3, 0); }
fstp(const Fpu & reg)286 void fstp(const Fpu& reg) { opFpu(reg, 0xDD, 0xD8); }
fstsw(const Address & addr)287 void fstsw(const Address& addr) { db(0x9B); opModM(addr, Reg32(7), 0xDD, 0x100); }
fstsw(const Reg16 & r)288 void fstsw(const Reg16& r) { if (r.getIdx() != Operand::AX) XBYAK_THROW(ERR_BAD_PARAMETER) db(0x9B); db(0xDF); db(0xE0); }
fsub(const Address & addr)289 void fsub(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 4, 0); }
fsub(const Fpu & reg1)290 void fsub(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8E0, 0xDCE8); }
fsub(const Fpu & reg1,const Fpu & reg2)291 void fsub(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8E0, 0xDCE8); }
fsubp()292 void fsubp() { db(0xDE); db(0xE9); }
fsubp(const Fpu & reg1)293 void fsubp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEE8); }
fsubp(const Fpu & reg1,const Fpu & reg2)294 void fsubp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEE8); }
fsubr(const Address & addr)295 void fsubr(const Address& addr) { opFpuMem(addr, 0x00, 0xD8, 0xDC, 5, 0); }
fsubr(const Fpu & reg1)296 void fsubr(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xD8E8, 0xDCE0); }
fsubr(const Fpu & reg1,const Fpu & reg2)297 void fsubr(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xD8E8, 0xDCE0); }
fsubrp()298 void fsubrp() { db(0xDE); db(0xE1); }
fsubrp(const Fpu & reg1)299 void fsubrp(const Fpu& reg1) { opFpuFpu(reg1, st0, 0x0000, 0xDEE0); }
fsubrp(const Fpu & reg1,const Fpu & reg2)300 void fsubrp(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0x0000, 0xDEE0); }
ftst()301 void ftst() { db(0xD9); db(0xE4); }
fucom()302 void fucom() { db(0xDD); db(0xE1); }
fucom(const Fpu & reg)303 void fucom(const Fpu& reg) { opFpu(reg, 0xDD, 0xE0); }
fucomi(const Fpu & reg1)304 void fucomi(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDBE8, 0x00E8); }
fucomi(const Fpu & reg1,const Fpu & reg2)305 void fucomi(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDBE8, 0x00E8); }
fucomip(const Fpu & reg1)306 void fucomip(const Fpu& reg1) { opFpuFpu(st0, reg1, 0xDFE8, 0x00E8); }
fucomip(const Fpu & reg1,const Fpu & reg2)307 void fucomip(const Fpu& reg1, const Fpu& reg2) { opFpuFpu(reg1, reg2, 0xDFE8, 0x00E8); }
fucomp()308 void fucomp() { db(0xDD); db(0xE9); }
fucomp(const Fpu & reg)309 void fucomp(const Fpu& reg) { opFpu(reg, 0xDD, 0xE8); }
fucompp()310 void fucompp() { db(0xDA); db(0xE9); }
fwait()311 void fwait() { db(0x9B); }
fxam()312 void fxam() { db(0xD9); db(0xE5); }
fxch()313 void fxch() { db(0xD9); db(0xC9); }
fxch(const Fpu & reg)314 void fxch(const Fpu& reg) { opFpu(reg, 0xD9, 0xC8); }
fxrstor(const Address & addr)315 void fxrstor(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0xAE); }
fxtract()316 void fxtract() { db(0xD9); db(0xF4); }
fyl2x()317 void fyl2x() { db(0xD9); db(0xF1); }
fyl2xp1()318 void fyl2xp1() { db(0xD9); db(0xF9); }
gf2p8affineinvqb(const Xmm & xmm,const Operand & op,int imm)319 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)320 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)321 void gf2p8mulb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCF, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
haddpd(const Xmm & xmm,const Operand & op)322 void haddpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7C, 0x66, isXMM_XMMorMEM); }
haddps(const Xmm & xmm,const Operand & op)323 void haddps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7C, 0xF2, isXMM_XMMorMEM); }
hsubpd(const Xmm & xmm,const Operand & op)324 void hsubpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7D, 0x66, isXMM_XMMorMEM); }
hsubps(const Xmm & xmm,const Operand & op)325 void hsubps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x7D, 0xF2, isXMM_XMMorMEM); }
idiv(const Operand & op)326 void idiv(const Operand& op) { opR_ModM(op, 0, 7, 0xF6); }
imul(const Operand & op)327 void imul(const Operand& op) { opR_ModM(op, 0, 5, 0xF6); }
in_(const Reg & a,const Reg & d)328 void in_(const Reg& a, const Reg& d) { opInOut(a, d, 0xEC); }
in_(const Reg & a,uint8 v)329 void in_(const Reg& a, uint8 v) { opInOut(a, 0xE4, v); }
inc(const Operand & op)330 void inc(const Operand& op) { opIncDec(op, 0x40, 0); }
insertps(const Xmm & xmm,const Operand & op,uint8 imm)331 void insertps(const Xmm& xmm, const Operand& op, uint8 imm) { opGen(xmm, op, 0x21, 0x66, isXMM_XMMorMEM, imm, 0x3A); }
int3()332 void int3() { db(0xCC); }
int_(uint8 x)333 void int_(uint8 x) { db(0xCD); db(x); }
334 void ja(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
335 void ja(const char *label, LabelType type = T_AUTO) { ja(std::string(label), type); }//-V524
ja(const void * addr)336 void ja(const void *addr) { opJmpAbs(addr, T_NEAR, 0x77, 0x87, 0x0F); }//-V524
337 void ja(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
338 void jae(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
339 void jae(const char *label, LabelType type = T_AUTO) { jae(std::string(label), type); }//-V524
jae(const void * addr)340 void jae(const void *addr) { opJmpAbs(addr, T_NEAR, 0x73, 0x83, 0x0F); }//-V524
341 void jae(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
342 void jb(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
343 void jb(const char *label, LabelType type = T_AUTO) { jb(std::string(label), type); }//-V524
jb(const void * addr)344 void jb(const void *addr) { opJmpAbs(addr, T_NEAR, 0x72, 0x82, 0x0F); }//-V524
345 void jb(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
346 void jbe(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
347 void jbe(const char *label, LabelType type = T_AUTO) { jbe(std::string(label), type); }//-V524
jbe(const void * addr)348 void jbe(const void *addr) { opJmpAbs(addr, T_NEAR, 0x76, 0x86, 0x0F); }//-V524
349 void jbe(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
350 void jc(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
351 void jc(const char *label, LabelType type = T_AUTO) { jc(std::string(label), type); }//-V524
jc(const void * addr)352 void jc(const void *addr) { opJmpAbs(addr, T_NEAR, 0x72, 0x82, 0x0F); }//-V524
353 void jc(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
354 void je(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
355 void je(const char *label, LabelType type = T_AUTO) { je(std::string(label), type); }//-V524
je(const void * addr)356 void je(const void *addr) { opJmpAbs(addr, T_NEAR, 0x74, 0x84, 0x0F); }//-V524
357 void je(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
358 void jg(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
359 void jg(const char *label, LabelType type = T_AUTO) { jg(std::string(label), type); }//-V524
jg(const void * addr)360 void jg(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7F, 0x8F, 0x0F); }//-V524
361 void jg(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
362 void jge(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
363 void jge(const char *label, LabelType type = T_AUTO) { jge(std::string(label), type); }//-V524
jge(const void * addr)364 void jge(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7D, 0x8D, 0x0F); }//-V524
365 void jge(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
366 void jl(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
367 void jl(const char *label, LabelType type = T_AUTO) { jl(std::string(label), type); }//-V524
jl(const void * addr)368 void jl(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7C, 0x8C, 0x0F); }//-V524
369 void jl(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
370 void jle(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
371 void jle(const char *label, LabelType type = T_AUTO) { jle(std::string(label), type); }//-V524
jle(const void * addr)372 void jle(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7E, 0x8E, 0x0F); }//-V524
373 void jle(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
374 void jna(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
375 void jna(const char *label, LabelType type = T_AUTO) { jna(std::string(label), type); }//-V524
jna(const void * addr)376 void jna(const void *addr) { opJmpAbs(addr, T_NEAR, 0x76, 0x86, 0x0F); }//-V524
377 void jna(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x76, 0x86, 0x0F); }//-V524
378 void jnae(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
379 void jnae(const char *label, LabelType type = T_AUTO) { jnae(std::string(label), type); }//-V524
jnae(const void * addr)380 void jnae(const void *addr) { opJmpAbs(addr, T_NEAR, 0x72, 0x82, 0x0F); }//-V524
381 void jnae(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x72, 0x82, 0x0F); }//-V524
382 void jnb(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
383 void jnb(const char *label, LabelType type = T_AUTO) { jnb(std::string(label), type); }//-V524
jnb(const void * addr)384 void jnb(const void *addr) { opJmpAbs(addr, T_NEAR, 0x73, 0x83, 0x0F); }//-V524
385 void jnb(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
386 void jnbe(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
387 void jnbe(const char *label, LabelType type = T_AUTO) { jnbe(std::string(label), type); }//-V524
jnbe(const void * addr)388 void jnbe(const void *addr) { opJmpAbs(addr, T_NEAR, 0x77, 0x87, 0x0F); }//-V524
389 void jnbe(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x77, 0x87, 0x0F); }//-V524
390 void jnc(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
391 void jnc(const char *label, LabelType type = T_AUTO) { jnc(std::string(label), type); }//-V524
jnc(const void * addr)392 void jnc(const void *addr) { opJmpAbs(addr, T_NEAR, 0x73, 0x83, 0x0F); }//-V524
393 void jnc(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x73, 0x83, 0x0F); }//-V524
394 void jne(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
395 void jne(const char *label, LabelType type = T_AUTO) { jne(std::string(label), type); }//-V524
jne(const void * addr)396 void jne(const void *addr) { opJmpAbs(addr, T_NEAR, 0x75, 0x85, 0x0F); }//-V524
397 void jne(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
398 void jng(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
399 void jng(const char *label, LabelType type = T_AUTO) { jng(std::string(label), type); }//-V524
jng(const void * addr)400 void jng(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7E, 0x8E, 0x0F); }//-V524
401 void jng(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7E, 0x8E, 0x0F); }//-V524
402 void jnge(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
403 void jnge(const char *label, LabelType type = T_AUTO) { jnge(std::string(label), type); }//-V524
jnge(const void * addr)404 void jnge(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7C, 0x8C, 0x0F); }//-V524
405 void jnge(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7C, 0x8C, 0x0F); }//-V524
406 void jnl(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
407 void jnl(const char *label, LabelType type = T_AUTO) { jnl(std::string(label), type); }//-V524
jnl(const void * addr)408 void jnl(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7D, 0x8D, 0x0F); }//-V524
409 void jnl(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7D, 0x8D, 0x0F); }//-V524
410 void jnle(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
411 void jnle(const char *label, LabelType type = T_AUTO) { jnle(std::string(label), type); }//-V524
jnle(const void * addr)412 void jnle(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7F, 0x8F, 0x0F); }//-V524
413 void jnle(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7F, 0x8F, 0x0F); }//-V524
414 void jno(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x71, 0x81, 0x0F); }//-V524
415 void jno(const char *label, LabelType type = T_AUTO) { jno(std::string(label), type); }//-V524
jno(const void * addr)416 void jno(const void *addr) { opJmpAbs(addr, T_NEAR, 0x71, 0x81, 0x0F); }//-V524
417 void jno(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x71, 0x81, 0x0F); }//-V524
418 void jnp(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
419 void jnp(const char *label, LabelType type = T_AUTO) { jnp(std::string(label), type); }//-V524
jnp(const void * addr)420 void jnp(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7B, 0x8B, 0x0F); }//-V524
421 void jnp(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
422 void jns(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x79, 0x89, 0x0F); }//-V524
423 void jns(const char *label, LabelType type = T_AUTO) { jns(std::string(label), type); }//-V524
jns(const void * addr)424 void jns(const void *addr) { opJmpAbs(addr, T_NEAR, 0x79, 0x89, 0x0F); }//-V524
425 void jns(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x79, 0x89, 0x0F); }//-V524
426 void jnz(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
427 void jnz(const char *label, LabelType type = T_AUTO) { jnz(std::string(label), type); }//-V524
jnz(const void * addr)428 void jnz(const void *addr) { opJmpAbs(addr, T_NEAR, 0x75, 0x85, 0x0F); }//-V524
429 void jnz(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x75, 0x85, 0x0F); }//-V524
430 void jo(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x70, 0x80, 0x0F); }//-V524
431 void jo(const char *label, LabelType type = T_AUTO) { jo(std::string(label), type); }//-V524
jo(const void * addr)432 void jo(const void *addr) { opJmpAbs(addr, T_NEAR, 0x70, 0x80, 0x0F); }//-V524
433 void jo(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x70, 0x80, 0x0F); }//-V524
434 void jp(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
435 void jp(const char *label, LabelType type = T_AUTO) { jp(std::string(label), type); }//-V524
jp(const void * addr)436 void jp(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7A, 0x8A, 0x0F); }//-V524
437 void jp(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
438 void jpe(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
439 void jpe(const char *label, LabelType type = T_AUTO) { jpe(std::string(label), type); }//-V524
jpe(const void * addr)440 void jpe(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7A, 0x8A, 0x0F); }//-V524
441 void jpe(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7A, 0x8A, 0x0F); }//-V524
442 void jpo(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
443 void jpo(const char *label, LabelType type = T_AUTO) { jpo(std::string(label), type); }//-V524
jpo(const void * addr)444 void jpo(const void *addr) { opJmpAbs(addr, T_NEAR, 0x7B, 0x8B, 0x0F); }//-V524
445 void jpo(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x7B, 0x8B, 0x0F); }//-V524
446 void js(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x78, 0x88, 0x0F); }//-V524
447 void js(const char *label, LabelType type = T_AUTO) { js(std::string(label), type); }//-V524
js(const void * addr)448 void js(const void *addr) { opJmpAbs(addr, T_NEAR, 0x78, 0x88, 0x0F); }//-V524
449 void js(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x78, 0x88, 0x0F); }//-V524
450 void jz(const Label& label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
451 void jz(const char *label, LabelType type = T_AUTO) { jz(std::string(label), type); }//-V524
jz(const void * addr)452 void jz(const void *addr) { opJmpAbs(addr, T_NEAR, 0x74, 0x84, 0x0F); }//-V524
453 void jz(std::string label, LabelType type = T_AUTO) { opJmp(label, type, 0x74, 0x84, 0x0F); }//-V524
lahf()454 void lahf() { db(0x9F); }
lddqu(const Xmm & xmm,const Address & addr)455 void lddqu(const Xmm& xmm, const Address& addr) { db(0xF2); opModM(addr, xmm, 0x0F, 0xF0); }
ldmxcsr(const Address & addr)456 void ldmxcsr(const Address& addr) { opModM(addr, Reg32(2), 0x0F, 0xAE); }
lea(const Reg & reg,const Address & addr)457 void lea(const Reg& reg, const Address& addr) { if (!reg.isBit(16 | i32e)) XBYAK_THROW(ERR_BAD_SIZE_OF_REGISTER) opModM(addr, reg, 0x8D); }
leave()458 void leave() { db(0xC9); }
lfence()459 void lfence() { db(0x0F); db(0xAE); db(0xE8); }
lfs(const Reg & reg,const Address & addr)460 void lfs(const Reg& reg, const Address& addr) { opLoadSeg(addr, reg, 0x0F, 0xB4); }
lgs(const Reg & reg,const Address & addr)461 void lgs(const Reg& reg, const Address& addr) { opLoadSeg(addr, reg, 0x0F, 0xB5); }
lock()462 void lock() { db(0xF0); }
lodsb()463 void lodsb() { db(0xAC); }
lodsd()464 void lodsd() { db(0xAD); }
lodsw()465 void lodsw() { db(0x66); db(0xAD); }
loop(const Label & label)466 void loop(const Label& label) { opJmp(label, T_SHORT, 0xE2, 0, 0); }
loop(const char * label)467 void loop(const char *label) { loop(std::string(label)); }
loop(std::string label)468 void loop(std::string label) { opJmp(label, T_SHORT, 0xE2, 0, 0); }
loope(const Label & label)469 void loope(const Label& label) { opJmp(label, T_SHORT, 0xE1, 0, 0); }
loope(const char * label)470 void loope(const char *label) { loope(std::string(label)); }
loope(std::string label)471 void loope(std::string label) { opJmp(label, T_SHORT, 0xE1, 0, 0); }
loopne(const Label & label)472 void loopne(const Label& label) { opJmp(label, T_SHORT, 0xE0, 0, 0); }
loopne(const char * label)473 void loopne(const char *label) { loopne(std::string(label)); }
loopne(std::string label)474 void loopne(std::string label) { opJmp(label, T_SHORT, 0xE0, 0, 0); }
lss(const Reg & reg,const Address & addr)475 void lss(const Reg& reg, const Address& addr) { opLoadSeg(addr, reg, 0x0F, 0xB2); }
lzcnt(const Reg & reg,const Operand & op)476 void lzcnt(const Reg&reg, const Operand& op) { opSp1(reg, op, 0xF3, 0x0F, 0xBD); }
maskmovdqu(const Xmm & reg1,const Xmm & reg2)477 void maskmovdqu(const Xmm& reg1, const Xmm& reg2) { db(0x66);  opModR(reg1, reg2, 0x0F, 0xF7); }
maskmovq(const Mmx & reg1,const Mmx & reg2)478 void maskmovq(const Mmx& reg1, const Mmx& reg2) { if (!reg1.isMMX() || !reg2.isMMX()) XBYAK_THROW(ERR_BAD_COMBINATION) opModR(reg1, reg2, 0x0F, 0xF7); }
maxpd(const Xmm & xmm,const Operand & op)479 void maxpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0x66, isXMM_XMMorMEM); }
maxps(const Xmm & xmm,const Operand & op)480 void maxps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0x100, isXMM_XMMorMEM); }
maxsd(const Xmm & xmm,const Operand & op)481 void maxsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0xF2, isXMM_XMMorMEM); }
maxss(const Xmm & xmm,const Operand & op)482 void maxss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5F, 0xF3, isXMM_XMMorMEM); }
mfence()483 void mfence() { db(0x0F); db(0xAE); db(0xF0); }
minpd(const Xmm & xmm,const Operand & op)484 void minpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0x66, isXMM_XMMorMEM); }
minps(const Xmm & xmm,const Operand & op)485 void minps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0x100, isXMM_XMMorMEM); }
minsd(const Xmm & xmm,const Operand & op)486 void minsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0xF2, isXMM_XMMorMEM); }
minss(const Xmm & xmm,const Operand & op)487 void minss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5D, 0xF3, isXMM_XMMorMEM); }
monitor()488 void monitor() { db(0x0F); db(0x01); db(0xC8); }
monitorx()489 void monitorx() { db(0x0F); db(0x01); db(0xFA); }
movapd(const Address & addr,const Xmm & xmm)490 void movapd(const Address& addr, const Xmm& xmm) { db(0x66); opModM(addr, xmm, 0x0F, 0x29); }
movapd(const Xmm & xmm,const Operand & op)491 void movapd(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x28, 0x66); }
movaps(const Address & addr,const Xmm & xmm)492 void movaps(const Address& addr, const Xmm& xmm) { opModM(addr, xmm, 0x0F, 0x29); }
movaps(const Xmm & xmm,const Operand & op)493 void movaps(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x28, 0x100); }
movbe(const Address & addr,const Reg & reg)494 void movbe(const Address& addr, const Reg& reg) { opModM(addr, reg, 0x0F, 0x38, 0xF1); }
movbe(const Reg & reg,const Address & addr)495 void movbe(const Reg& reg, const Address& addr) { opModM(addr, reg, 0x0F, 0x38, 0xF0); }
movd(const Address & addr,const Mmx & mmx)496 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)497 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)498 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)499 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)500 void movddup(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x12, 0xF2, isXMM_XMMorMEM, NONE, NONE); }
movdq2q(const Mmx & mmx,const Xmm & xmm)501 void movdq2q(const Mmx& mmx, const Xmm& xmm) { db(0xF2); opModR(mmx, xmm, 0x0F, 0xD6); }
movdqa(const Address & addr,const Xmm & xmm)502 void movdqa(const Address& addr, const Xmm& xmm) { db(0x66); opModM(addr, xmm, 0x0F, 0x7F); }
movdqa(const Xmm & xmm,const Operand & op)503 void movdqa(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x6F, 0x66); }
movdqu(const Address & addr,const Xmm & xmm)504 void movdqu(const Address& addr, const Xmm& xmm) { db(0xF3); opModM(addr, xmm, 0x0F, 0x7F); }
movdqu(const Xmm & xmm,const Operand & op)505 void movdqu(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x6F, 0xF3); }
movhlps(const Xmm & reg1,const Xmm & reg2)506 void movhlps(const Xmm& reg1, const Xmm& reg2) {  opModR(reg1, reg2, 0x0F, 0x12); }
movhpd(const Operand & op1,const Operand & op2)507 void movhpd(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x16, 0x66); }
movhps(const Operand & op1,const Operand & op2)508 void movhps(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x16, 0x100); }
movlhps(const Xmm & reg1,const Xmm & reg2)509 void movlhps(const Xmm& reg1, const Xmm& reg2) {  opModR(reg1, reg2, 0x0F, 0x16); }
movlpd(const Operand & op1,const Operand & op2)510 void movlpd(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x12, 0x66); }
movlps(const Operand & op1,const Operand & op2)511 void movlps(const Operand& op1, const Operand& op2) { opMovXMM(op1, op2, 0x12, 0x100); }
movmskpd(const Reg32e & reg,const Xmm & xmm)512 void movmskpd(const Reg32e& reg, const Xmm& xmm) { db(0x66); movmskps(reg, xmm); }
movmskps(const Reg32e & reg,const Xmm & xmm)513 void movmskps(const Reg32e& reg, const Xmm& xmm) { opModR(reg, xmm, 0x0F, 0x50); }
movntdq(const Address & addr,const Xmm & reg)514 void movntdq(const Address& addr, const Xmm& reg) { opModM(addr, Reg16(reg.getIdx()), 0x0F, 0xE7); }
movntdqa(const Xmm & xmm,const Address & addr)515 void movntdqa(const Xmm& xmm, const Address& addr) { db(0x66); opModM(addr, xmm, 0x0F, 0x38, 0x2A); }
movnti(const Address & addr,const Reg32e & reg)516 void movnti(const Address& addr, const Reg32e& reg) { opModM(addr, reg, 0x0F, 0xC3); }
movntpd(const Address & addr,const Xmm & reg)517 void movntpd(const Address& addr, const Xmm& reg) { opModM(addr, Reg16(reg.getIdx()), 0x0F, 0x2B); }
movntps(const Address & addr,const Xmm & xmm)518 void movntps(const Address& addr, const Xmm& xmm) { opModM(addr, Mmx(xmm.getIdx()), 0x0F, 0x2B); }
movntq(const Address & addr,const Mmx & mmx)519 void movntq(const Address& addr, const Mmx& mmx) { if (!mmx.isMMX()) XBYAK_THROW(ERR_BAD_COMBINATION) opModM(addr, mmx, 0x0F, 0xE7); }
movq(const Address & addr,const Mmx & mmx)520 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)521 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)522 void movq2dq(const Xmm& xmm, const Mmx& mmx) { db(0xF3); opModR(xmm, mmx, 0x0F, 0xD6); }
movsb()523 void movsb() { db(0xA4); }
movsd()524 void movsd() { db(0xA5); }
movsd(const Address & addr,const Xmm & xmm)525 void movsd(const Address& addr, const Xmm& xmm) { db(0xF2); opModM(addr, xmm, 0x0F, 0x11); }
movsd(const Xmm & xmm,const Operand & op)526 void movsd(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0xF2); }
movshdup(const Xmm & xmm,const Operand & op)527 void movshdup(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x16, 0xF3, isXMM_XMMorMEM, NONE, NONE); }
movsldup(const Xmm & xmm,const Operand & op)528 void movsldup(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x12, 0xF3, isXMM_XMMorMEM, NONE, NONE); }
movss(const Address & addr,const Xmm & xmm)529 void movss(const Address& addr, const Xmm& xmm) { db(0xF3); opModM(addr, xmm, 0x0F, 0x11); }
movss(const Xmm & xmm,const Operand & op)530 void movss(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0xF3); }
movsw()531 void movsw() { db(0x66); db(0xA5); }
movsx(const Reg & reg,const Operand & op)532 void movsx(const Reg& reg, const Operand& op) { opMovxx(reg, op, 0xBE); }
movupd(const Address & addr,const Xmm & xmm)533 void movupd(const Address& addr, const Xmm& xmm) { db(0x66); opModM(addr, xmm, 0x0F, 0x11); }
movupd(const Xmm & xmm,const Operand & op)534 void movupd(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0x66); }
movups(const Address & addr,const Xmm & xmm)535 void movups(const Address& addr, const Xmm& xmm) { opModM(addr, xmm, 0x0F, 0x11); }
movups(const Xmm & xmm,const Operand & op)536 void movups(const Xmm& xmm, const Operand& op) { opMMX(xmm, op, 0x10, 0x100); }
movzx(const Reg & reg,const Operand & op)537 void movzx(const Reg& reg, const Operand& op) { opMovxx(reg, op, 0xB6); }
mpsadbw(const Xmm & xmm,const Operand & op,int imm)538 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)539 void mul(const Operand& op) { opR_ModM(op, 0, 4, 0xF6); }
mulpd(const Xmm & xmm,const Operand & op)540 void mulpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0x66, isXMM_XMMorMEM); }
mulps(const Xmm & xmm,const Operand & op)541 void mulps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0x100, isXMM_XMMorMEM); }
mulsd(const Xmm & xmm,const Operand & op)542 void mulsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x59, 0xF2, isXMM_XMMorMEM); }
mulss(const Xmm & xmm,const Operand & op)543 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)544 void mulx(const Reg32e& r1, const Reg32e& r2, const Operand& op) { opGpr(r1, r2, op, T_F2 | T_0F38, 0xf6, true); }
mwait()545 void mwait() { db(0x0F); db(0x01); db(0xC9); }
mwaitx()546 void mwaitx() { db(0x0F); db(0x01); db(0xFB); }
neg(const Operand & op)547 void neg(const Operand& op) { opR_ModM(op, 0, 3, 0xF6); }
not_(const Operand & op)548 void not_(const Operand& op) { opR_ModM(op, 0, 2, 0xF6); }
or_(const Operand & op,uint32 imm)549 void or_(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x08, 1); }
or_(const Operand & op1,const Operand & op2)550 void or_(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x08); }
orpd(const Xmm & xmm,const Operand & op)551 void orpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x56, 0x66, isXMM_XMMorMEM); }
orps(const Xmm & xmm,const Operand & op)552 void orps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x56, 0x100, isXMM_XMMorMEM); }
out_(const Reg & d,const Reg & a)553 void out_(const Reg& d, const Reg& a) { opInOut(a, d, 0xEE); }
out_(uint8 v,const Reg & a)554 void out_(uint8 v, const Reg& a) { opInOut(a, 0xE6, v); }
outsb()555 void outsb() { db(0x6E); }
outsd()556 void outsd() { db(0x6F); }
outsw()557 void outsw() { db(0x66); db(0x6F); }
pabsb(const Mmx & mmx,const Operand & op)558 void pabsb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x1C, 0x66, NONE, 0x38); }
pabsd(const Mmx & mmx,const Operand & op)559 void pabsd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x1E, 0x66, NONE, 0x38); }
pabsw(const Mmx & mmx,const Operand & op)560 void pabsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x1D, 0x66, NONE, 0x38); }
packssdw(const Mmx & mmx,const Operand & op)561 void packssdw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x6B); }
packsswb(const Mmx & mmx,const Operand & op)562 void packsswb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x63); }
packusdw(const Xmm & xmm,const Operand & op)563 void packusdw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2B, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
packuswb(const Mmx & mmx,const Operand & op)564 void packuswb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x67); }
paddb(const Mmx & mmx,const Operand & op)565 void paddb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFC); }
paddd(const Mmx & mmx,const Operand & op)566 void paddd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFE); }
paddq(const Mmx & mmx,const Operand & op)567 void paddq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD4); }
paddsb(const Mmx & mmx,const Operand & op)568 void paddsb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEC); }
paddsw(const Mmx & mmx,const Operand & op)569 void paddsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xED); }
paddusb(const Mmx & mmx,const Operand & op)570 void paddusb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDC); }
paddusw(const Mmx & mmx,const Operand & op)571 void paddusw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDD); }
paddw(const Mmx & mmx,const Operand & op)572 void paddw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFD); }
palignr(const Mmx & mmx,const Operand & op,int imm)573 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)574 void pand(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDB); }
pandn(const Mmx & mmx,const Operand & op)575 void pandn(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDF); }
pause()576 void pause() { db(0xF3); db(0x90); }
pavgb(const Mmx & mmx,const Operand & op)577 void pavgb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE0); }
pavgw(const Mmx & mmx,const Operand & op)578 void pavgw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE3); }
pblendvb(const Xmm & xmm,const Operand & op)579 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)580 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)581 void pclmulhqhdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x11); }
pclmulhqlqdq(const Xmm & xmm,const Operand & op)582 void pclmulhqlqdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x01); }
pclmullqhdq(const Xmm & xmm,const Operand & op)583 void pclmullqhdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x10); }
pclmullqlqdq(const Xmm & xmm,const Operand & op)584 void pclmullqlqdq(const Xmm& xmm, const Operand& op) { pclmulqdq(xmm, op, 0x00); }
pclmulqdq(const Xmm & xmm,const Operand & op,int imm)585 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)586 void pcmpeqb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x74); }
pcmpeqd(const Mmx & mmx,const Operand & op)587 void pcmpeqd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x76); }
pcmpeqq(const Xmm & xmm,const Operand & op)588 void pcmpeqq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x29, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pcmpeqw(const Mmx & mmx,const Operand & op)589 void pcmpeqw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x75); }
pcmpestri(const Xmm & xmm,const Operand & op,uint8 imm)590 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)591 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)592 void pcmpgtb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x64); }
pcmpgtd(const Mmx & mmx,const Operand & op)593 void pcmpgtd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x66); }
pcmpgtq(const Xmm & xmm,const Operand & op)594 void pcmpgtq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x37, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pcmpgtw(const Mmx & mmx,const Operand & op)595 void pcmpgtw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x65); }
pcmpistri(const Xmm & xmm,const Operand & op,uint8 imm)596 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)597 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)598 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)599 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)600 void pextrb(const Operand& op, const Xmm& xmm, uint8 imm) { opExt(op, xmm, 0x14, imm); }
pextrd(const Operand & op,const Xmm & xmm,uint8 imm)601 void pextrd(const Operand& op, const Xmm& xmm, uint8 imm) { opExt(op, xmm, 0x16, imm); }
pextrw(const Operand & op,const Mmx & xmm,uint8 imm)602 void pextrw(const Operand& op, const Mmx& xmm, uint8 imm) { opExt(op, xmm, 0x15, imm, true); }
phaddd(const Mmx & mmx,const Operand & op)603 void phaddd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x02, 0x66, NONE, 0x38); }
phaddsw(const Mmx & mmx,const Operand & op)604 void phaddsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x03, 0x66, NONE, 0x38); }
phaddw(const Mmx & mmx,const Operand & op)605 void phaddw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x01, 0x66, NONE, 0x38); }
phminposuw(const Xmm & xmm,const Operand & op)606 void phminposuw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x41, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
phsubd(const Mmx & mmx,const Operand & op)607 void phsubd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x06, 0x66, NONE, 0x38); }
phsubsw(const Mmx & mmx,const Operand & op)608 void phsubsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x07, 0x66, NONE, 0x38); }
phsubw(const Mmx & mmx,const Operand & op)609 void phsubw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x05, 0x66, NONE, 0x38); }
pinsrb(const Xmm & xmm,const Operand & op,uint8 imm)610 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)611 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)612 void pinsrw(const Mmx& mmx, const Operand& op, int imm) { if (!op.isREG(32) && !op.isMEM()) XBYAK_THROW(ERR_BAD_COMBINATION) opGen(mmx, op, 0xC4, mmx.isXMM() ? 0x66 : NONE, 0, imm); }
pmaddubsw(const Mmx & mmx,const Operand & op)613 void pmaddubsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x04, 0x66, NONE, 0x38); }
pmaddwd(const Mmx & mmx,const Operand & op)614 void pmaddwd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF5); }
pmaxsb(const Xmm & xmm,const Operand & op)615 void pmaxsb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3C, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmaxsd(const Xmm & xmm,const Operand & op)616 void pmaxsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3D, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmaxsw(const Mmx & mmx,const Operand & op)617 void pmaxsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEE); }
pmaxub(const Mmx & mmx,const Operand & op)618 void pmaxub(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDE); }
pmaxud(const Xmm & xmm,const Operand & op)619 void pmaxud(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3F, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmaxuw(const Xmm & xmm,const Operand & op)620 void pmaxuw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3E, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminsb(const Xmm & xmm,const Operand & op)621 void pminsb(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x38, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminsd(const Xmm & xmm,const Operand & op)622 void pminsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x39, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminsw(const Mmx & mmx,const Operand & op)623 void pminsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEA); }
pminub(const Mmx & mmx,const Operand & op)624 void pminub(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xDA); }
pminud(const Xmm & xmm,const Operand & op)625 void pminud(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3B, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pminuw(const Xmm & xmm,const Operand & op)626 void pminuw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x3A, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovmskb(const Reg32e & reg,const Mmx & mmx)627 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)628 void pmovsxbd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x21, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxbq(const Xmm & xmm,const Operand & op)629 void pmovsxbq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x22, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxbw(const Xmm & xmm,const Operand & op)630 void pmovsxbw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x20, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxdq(const Xmm & xmm,const Operand & op)631 void pmovsxdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x25, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxwd(const Xmm & xmm,const Operand & op)632 void pmovsxwd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x23, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovsxwq(const Xmm & xmm,const Operand & op)633 void pmovsxwq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x24, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxbd(const Xmm & xmm,const Operand & op)634 void pmovzxbd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x31, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxbq(const Xmm & xmm,const Operand & op)635 void pmovzxbq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x32, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxbw(const Xmm & xmm,const Operand & op)636 void pmovzxbw(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x30, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxdq(const Xmm & xmm,const Operand & op)637 void pmovzxdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x35, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxwd(const Xmm & xmm,const Operand & op)638 void pmovzxwd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x33, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmovzxwq(const Xmm & xmm,const Operand & op)639 void pmovzxwq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x34, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmuldq(const Xmm & xmm,const Operand & op)640 void pmuldq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x28, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmulhrsw(const Mmx & mmx,const Operand & op)641 void pmulhrsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x0B, 0x66, NONE, 0x38); }
pmulhuw(const Mmx & mmx,const Operand & op)642 void pmulhuw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE4); }
pmulhw(const Mmx & mmx,const Operand & op)643 void pmulhw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE5); }
pmulld(const Xmm & xmm,const Operand & op)644 void pmulld(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x40, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
pmullw(const Mmx & mmx,const Operand & op)645 void pmullw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD5); }
pmuludq(const Mmx & mmx,const Operand & op)646 void pmuludq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF4); }
popcnt(const Reg & reg,const Operand & op)647 void popcnt(const Reg&reg, const Operand& op) { opSp1(reg, op, 0xF3, 0x0F, 0xB8); }
popf()648 void popf() { db(0x9D); }
por(const Mmx & mmx,const Operand & op)649 void por(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEB); }
prefetchnta(const Address & addr)650 void prefetchnta(const Address& addr) { opModM(addr, Reg32(0), 0x0F, 0x18); }
prefetcht0(const Address & addr)651 void prefetcht0(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0x18); }
prefetcht1(const Address & addr)652 void prefetcht1(const Address& addr) { opModM(addr, Reg32(2), 0x0F, 0x18); }
prefetcht2(const Address & addr)653 void prefetcht2(const Address& addr) { opModM(addr, Reg32(3), 0x0F, 0x18); }
prefetchw(const Address & addr)654 void prefetchw(const Address& addr) { opModM(addr, Reg32(1), 0x0F, 0x0D); }
prefetchwt1(const Address & addr)655 void prefetchwt1(const Address& addr) { opModM(addr, Reg32(2), 0x0F, 0x0D); }
psadbw(const Mmx & mmx,const Operand & op)656 void psadbw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF6); }
pshufb(const Mmx & mmx,const Operand & op)657 void pshufb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x00, 0x66, NONE, 0x38); }
pshufd(const Mmx & mmx,const Operand & op,uint8 imm8)658 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)659 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)660 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)661 void pshufw(const Mmx& mmx, const Operand& op, uint8 imm8) { opMMX(mmx, op, 0x70, 0x00, imm8); }
psignb(const Mmx & mmx,const Operand & op)662 void psignb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x08, 0x66, NONE, 0x38); }
psignd(const Mmx & mmx,const Operand & op)663 void psignd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x0A, 0x66, NONE, 0x38); }
psignw(const Mmx & mmx,const Operand & op)664 void psignw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x09, 0x66, NONE, 0x38); }
pslld(const Mmx & mmx,const Operand & op)665 void pslld(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF2); }
pslld(const Mmx & mmx,int imm8)666 void pslld(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x72, 6); }
pslldq(const Xmm & xmm,int imm8)667 void pslldq(const Xmm& xmm, int imm8) { opMMX_IMM(xmm, imm8, 0x73, 7); }
psllq(const Mmx & mmx,const Operand & op)668 void psllq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF3); }
psllq(const Mmx & mmx,int imm8)669 void psllq(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x73, 6); }
psllw(const Mmx & mmx,const Operand & op)670 void psllw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF1); }
psllw(const Mmx & mmx,int imm8)671 void psllw(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x71, 6); }
psrad(const Mmx & mmx,const Operand & op)672 void psrad(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE2); }
psrad(const Mmx & mmx,int imm8)673 void psrad(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x72, 4); }
psraw(const Mmx & mmx,const Operand & op)674 void psraw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE1); }
psraw(const Mmx & mmx,int imm8)675 void psraw(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x71, 4); }
psrld(const Mmx & mmx,const Operand & op)676 void psrld(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD2); }
psrld(const Mmx & mmx,int imm8)677 void psrld(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x72, 2); }
psrldq(const Xmm & xmm,int imm8)678 void psrldq(const Xmm& xmm, int imm8) { opMMX_IMM(xmm, imm8, 0x73, 3); }
psrlq(const Mmx & mmx,const Operand & op)679 void psrlq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD3); }
psrlq(const Mmx & mmx,int imm8)680 void psrlq(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x73, 2); }
psrlw(const Mmx & mmx,const Operand & op)681 void psrlw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD1); }
psrlw(const Mmx & mmx,int imm8)682 void psrlw(const Mmx& mmx, int imm8) { opMMX_IMM(mmx, imm8, 0x71, 2); }
psubb(const Mmx & mmx,const Operand & op)683 void psubb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF8); }
psubd(const Mmx & mmx,const Operand & op)684 void psubd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFA); }
psubq(const Mmx & mmx,const Operand & op)685 void psubq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xFB); }
psubsb(const Mmx & mmx,const Operand & op)686 void psubsb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE8); }
psubsw(const Mmx & mmx,const Operand & op)687 void psubsw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xE9); }
psubusb(const Mmx & mmx,const Operand & op)688 void psubusb(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD8); }
psubusw(const Mmx & mmx,const Operand & op)689 void psubusw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xD9); }
psubw(const Mmx & mmx,const Operand & op)690 void psubw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xF9); }
ptest(const Xmm & xmm,const Operand & op)691 void ptest(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x17, 0x66, isXMM_XMMorMEM, NONE, 0x38); }
punpckhbw(const Mmx & mmx,const Operand & op)692 void punpckhbw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x68); }
punpckhdq(const Mmx & mmx,const Operand & op)693 void punpckhdq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x6A); }
punpckhqdq(const Xmm & xmm,const Operand & op)694 void punpckhqdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x6D, 0x66, isXMM_XMMorMEM); }
punpckhwd(const Mmx & mmx,const Operand & op)695 void punpckhwd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x69); }
punpcklbw(const Mmx & mmx,const Operand & op)696 void punpcklbw(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x60); }
punpckldq(const Mmx & mmx,const Operand & op)697 void punpckldq(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x62); }
punpcklqdq(const Xmm & xmm,const Operand & op)698 void punpcklqdq(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x6C, 0x66, isXMM_XMMorMEM); }
punpcklwd(const Mmx & mmx,const Operand & op)699 void punpcklwd(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0x61); }
pushf()700 void pushf() { db(0x9C); }
pxor(const Mmx & mmx,const Operand & op)701 void pxor(const Mmx& mmx, const Operand& op) { opMMX(mmx, op, 0xEF); }
rcl(const Operand & op,const Reg8 & _cl)702 void rcl(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 2); }
rcl(const Operand & op,int imm)703 void rcl(const Operand& op, int imm) { opShift(op, imm, 2); }
rcpps(const Xmm & xmm,const Operand & op)704 void rcpps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x53, 0x100, isXMM_XMMorMEM); }
rcpss(const Xmm & xmm,const Operand & op)705 void rcpss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x53, 0xF3, isXMM_XMMorMEM); }
rcr(const Operand & op,const Reg8 & _cl)706 void rcr(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 3); }
rcr(const Operand & op,int imm)707 void rcr(const Operand& op, int imm) { opShift(op, imm, 3); }
rdmsr()708 void rdmsr() { db(0x0F); db(0x32); }
rdpmc()709 void rdpmc() { db(0x0F); db(0x33); }
rdrand(const Reg & r)710 void rdrand(const Reg& r) { if (r.isBit(8)) XBYAK_THROW(ERR_BAD_SIZE_OF_REGISTER) opModR(Reg(6, Operand::REG, r.getBit()), r, 0x0F, 0xC7); }
rdseed(const Reg & r)711 void rdseed(const Reg& r) { if (r.isBit(8)) XBYAK_THROW(ERR_BAD_SIZE_OF_REGISTER) opModR(Reg(7, Operand::REG, r.getBit()), r, 0x0F, 0xC7); }
rdtsc()712 void rdtsc() { db(0x0F); db(0x31); }
rdtscp()713 void rdtscp() { db(0x0F); db(0x01); db(0xF9); }
rep()714 void rep() { db(0xF3); }
repe()715 void repe() { db(0xF3); }
repne()716 void repne() { db(0xF2); }
repnz()717 void repnz() { db(0xF2); }
repz()718 void repz() { db(0xF3); }
719 void ret(int imm = 0) { if (imm) { db(0xC2); dw(imm); } else { db(0xC3); } }
rol(const Operand & op,const Reg8 & _cl)720 void rol(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 0); }
rol(const Operand & op,int imm)721 void rol(const Operand& op, int imm) { opShift(op, imm, 0); }
ror(const Operand & op,const Reg8 & _cl)722 void ror(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 1); }
ror(const Operand & op,int imm)723 void ror(const Operand& op, int imm) { opShift(op, imm, 1); }
rorx(const Reg32e & r,const Operand & op,uint8 imm)724 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)725 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)726 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)727 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)728 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)729 void rsqrtps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x52, 0x100, isXMM_XMMorMEM); }
rsqrtss(const Xmm & xmm,const Operand & op)730 void rsqrtss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x52, 0xF3, isXMM_XMMorMEM); }
sahf()731 void sahf() { db(0x9E); }
sal(const Operand & op,const Reg8 & _cl)732 void sal(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 4); }
sal(const Operand & op,int imm)733 void sal(const Operand& op, int imm) { opShift(op, imm, 4); }
sar(const Operand & op,const Reg8 & _cl)734 void sar(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 7); }
sar(const Operand & op,int imm)735 void sar(const Operand& op, int imm) { opShift(op, imm, 7); }
sarx(const Reg32e & r1,const Operand & op,const Reg32e & r2)736 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)737 void sbb(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x18, 3); }
sbb(const Operand & op1,const Operand & op2)738 void sbb(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x18); }
scasb()739 void scasb() { db(0xAE); }
scasd()740 void scasd() { db(0xAF); }
scasw()741 void scasw() { db(0x66); db(0xAF); }
seta(const Operand & op)742 void seta(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 7); }//-V524
setae(const Operand & op)743 void setae(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 3); }//-V524
setb(const Operand & op)744 void setb(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 2); }//-V524
setbe(const Operand & op)745 void setbe(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 6); }//-V524
setc(const Operand & op)746 void setc(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 2); }//-V524
sete(const Operand & op)747 void sete(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 4); }//-V524
setg(const Operand & op)748 void setg(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 15); }//-V524
setge(const Operand & op)749 void setge(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 13); }//-V524
setl(const Operand & op)750 void setl(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 12); }//-V524
setle(const Operand & op)751 void setle(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 14); }//-V524
setna(const Operand & op)752 void setna(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 6); }//-V524
setnae(const Operand & op)753 void setnae(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 2); }//-V524
setnb(const Operand & op)754 void setnb(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 3); }//-V524
setnbe(const Operand & op)755 void setnbe(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 7); }//-V524
setnc(const Operand & op)756 void setnc(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 3); }//-V524
setne(const Operand & op)757 void setne(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 5); }//-V524
setng(const Operand & op)758 void setng(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 14); }//-V524
setnge(const Operand & op)759 void setnge(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 12); }//-V524
setnl(const Operand & op)760 void setnl(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 13); }//-V524
setnle(const Operand & op)761 void setnle(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 15); }//-V524
setno(const Operand & op)762 void setno(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 1); }//-V524
setnp(const Operand & op)763 void setnp(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 11); }//-V524
setns(const Operand & op)764 void setns(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 9); }//-V524
setnz(const Operand & op)765 void setnz(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 5); }//-V524
seto(const Operand & op)766 void seto(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 0); }//-V524
setp(const Operand & op)767 void setp(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 10); }//-V524
setpe(const Operand & op)768 void setpe(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 10); }//-V524
setpo(const Operand & op)769 void setpo(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 11); }//-V524
sets(const Operand & op)770 void sets(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 8); }//-V524
setz(const Operand & op)771 void setz(const Operand& op) { opR_ModM(op, 8, 0, 0x0F, 0x90 | 4); }//-V524
sfence()772 void sfence() { db(0x0F); db(0xAE); db(0xF8); }
sha1msg1(const Xmm & xmm,const Operand & op)773 void sha1msg1(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xC9, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha1msg2(const Xmm & xmm,const Operand & op)774 void sha1msg2(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCA, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha1nexte(const Xmm & xmm,const Operand & op)775 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)776 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)777 void sha256msg1(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCC, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha256msg2(const Xmm & xmm,const Operand & op)778 void sha256msg2(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCD, NONE, isXMM_XMMorMEM, NONE, 0x38); }
sha256rnds2(const Xmm & xmm,const Operand & op)779 void sha256rnds2(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0xCB, NONE, isXMM_XMMorMEM, NONE, 0x38); }
shl(const Operand & op,const Reg8 & _cl)780 void shl(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 4); }
shl(const Operand & op,int imm)781 void shl(const Operand& op, int imm) { opShift(op, imm, 4); }
shld(const Operand & op,const Reg & reg,const Reg8 & _cl)782 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)783 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)784 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)785 void shr(const Operand& op, const Reg8& _cl) { opShift(op, _cl, 5); }
shr(const Operand & op,int imm)786 void shr(const Operand& op, int imm) { opShift(op, imm, 5); }
shrd(const Operand & op,const Reg & reg,const Reg8 & _cl)787 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)788 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)789 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)790 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)791 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)792 void sqrtpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0x66, isXMM_XMMorMEM); }
sqrtps(const Xmm & xmm,const Operand & op)793 void sqrtps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0x100, isXMM_XMMorMEM); }
sqrtsd(const Xmm & xmm,const Operand & op)794 void sqrtsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0xF2, isXMM_XMMorMEM); }
sqrtss(const Xmm & xmm,const Operand & op)795 void sqrtss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x51, 0xF3, isXMM_XMMorMEM); }
stac()796 void stac() { db(0x0F); db(0x01); db(0xCB); }
stc()797 void stc() { db(0xF9); }
std()798 void std() { db(0xFD); }
sti()799 void sti() { db(0xFB); }
stmxcsr(const Address & addr)800 void stmxcsr(const Address& addr) { opModM(addr, Reg32(3), 0x0F, 0xAE); }
stosb()801 void stosb() { db(0xAA); }
stosd()802 void stosd() { db(0xAB); }
stosw()803 void stosw() { db(0x66); db(0xAB); }
sub(const Operand & op,uint32 imm)804 void sub(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x28, 5); }
sub(const Operand & op1,const Operand & op2)805 void sub(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x28); }
subpd(const Xmm & xmm,const Operand & op)806 void subpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0x66, isXMM_XMMorMEM); }
subps(const Xmm & xmm,const Operand & op)807 void subps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0x100, isXMM_XMMorMEM); }
subsd(const Xmm & xmm,const Operand & op)808 void subsd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0xF2, isXMM_XMMorMEM); }
subss(const Xmm & xmm,const Operand & op)809 void subss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x5C, 0xF3, isXMM_XMMorMEM); }
sysenter()810 void sysenter() { db(0x0F); db(0x34); }
sysexit()811 void sysexit() { db(0x0F); db(0x35); }
tzcnt(const Reg & reg,const Operand & op)812 void tzcnt(const Reg&reg, const Operand& op) { opSp1(reg, op, 0xF3, 0x0F, 0xBC); }
ucomisd(const Xmm & xmm,const Operand & op)813 void ucomisd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2E, 0x66, isXMM_XMMorMEM); }
ucomiss(const Xmm & xmm,const Operand & op)814 void ucomiss(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x2E, 0x100, isXMM_XMMorMEM); }
ud2()815 void ud2() { db(0x0F); db(0x0B); }
unpckhpd(const Xmm & xmm,const Operand & op)816 void unpckhpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x15, 0x66, isXMM_XMMorMEM); }
unpckhps(const Xmm & xmm,const Operand & op)817 void unpckhps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x15, 0x100, isXMM_XMMorMEM); }
unpcklpd(const Xmm & xmm,const Operand & op)818 void unpcklpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x14, 0x66, isXMM_XMMorMEM); }
unpcklps(const Xmm & xmm,const Operand & op)819 void unpcklps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x14, 0x100, isXMM_XMMorMEM); }
820 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); }
821 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); }
822 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); }
823 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); }
824 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); }
825 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); }
826 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); }
827 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); }
828 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); }
829 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)830 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)831 void vaeskeygenassist(const Xmm& xm, const Operand& op, uint8 imm) { opAVX_X_XM_IMM(xm, op, T_66 | T_0F3A, 0xDF, imm); }
832 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); }
833 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); }
834 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); }
835 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)836 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)837 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)838 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)839 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)840 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)841 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)842 void vbroadcastsd(const Ymm& y, const Operand& op) { if (!op.isMEM() && !(y.isYMM() && op.isXMM()) && !(y.isZMM() && op.isXMM())) XBYAK_THROW(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)843 void vbroadcastss(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) XBYAK_THROW(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)844 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)845 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)846 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)847 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)848 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)849 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)850 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)851 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)852 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)853 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)854 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)855 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)856 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)857 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)858 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)859 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)860 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)861 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)862 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)863 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)864 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)865 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)866 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)867 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)868 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)869 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)870 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)871 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)872 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)873 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)874 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)875 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)876 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)877 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)878 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)879 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)880 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)881 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)882 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)883 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)884 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)885 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)886 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)887 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)888 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)889 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)890 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)891 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)892 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)893 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)894 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)895 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)896 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)897 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)898 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)899 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)900 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)901 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)902 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)903 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)904 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)905 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)906 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)907 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)908 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)909 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)910 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)911 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)912 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)913 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)914 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)915 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)916 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)917 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)918 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)919 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)920 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)921 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)922 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)923 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)924 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)925 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)926 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)927 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)928 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)929 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)930 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)931 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)932 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)933 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)934 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)935 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)936 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)937 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)938 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)939 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)940 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)941 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)942 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)943 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)944 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)945 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)946 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)947 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)948 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)949 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)950 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)951 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)952 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)953 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)954 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)955 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)956 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)957 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)958 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)959 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)960 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)961 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)962 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)963 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)964 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)965 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)966 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)967 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)968 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)969 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)970 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)971 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)972 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)973 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)974 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)975 void vcmpunordss(const Xmm& x1, const Xmm& x2, const Operand& op) { vcmpss(x1, x2, op, 3); }
vcomisd(const Xmm & xm,const Operand & op)976 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)977 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)978 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)979 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)980 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)981 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)982 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)983 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)984 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)985 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)986 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)987 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)988 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)989 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)990 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)991 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)992 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)993 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)994 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)995 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); }
996 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); }
997 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); }
998 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); }
999 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)1000 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)1001 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)1002 void vextractf128(const Operand& op, const Ymm& y, uint8 imm) { if (!(op.isXMEM() && y.isYMM())) XBYAK_THROW(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)1003 void vextracti128(const Operand& op, const Ymm& y, uint8 imm) { if (!(op.isXMEM() && y.isYMM())) XBYAK_THROW(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)1004 void vextractps(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(32) || op.isMEM()) && x.isXMM())) XBYAK_THROW(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)1005 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)1006 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)1007 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)1008 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)1009 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)1010 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)1011 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)1012 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)1013 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)1014 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)1015 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)1016 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)1017 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)1018 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)1019 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)1020 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)1021 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)1022 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)1023 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)1024 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)1025 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)1026 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)1027 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)1028 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)1029 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)1030 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)1031 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)1032 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)1033 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)1034 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)1035 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)1036 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)1037 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)1038 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)1039 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)1040 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)1041 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)1042 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)1043 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)1044 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)1045 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)1046 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)1047 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)1048 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)1049 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)1050 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)1051 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)1052 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)1053 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)1054 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)1055 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)1056 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)1057 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)1058 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)1059 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)1060 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)1061 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)1062 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)1063 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)1064 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)1065 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)1066 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)1067 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)1068 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)1069 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)1070 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)1071 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); }
1072 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); }
1073 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); }
1074 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); }
1075 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)1076 void vinsertf128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isXMEM())) XBYAK_THROW(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)1077 void vinserti128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isXMEM())) XBYAK_THROW(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)1078 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)1079 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)1080 void vldmxcsr(const Address& addr) { opAVX_X_X_XM(xm2, xm0, addr, T_0F, 0xAE); }
vmaskmovdqu(const Xmm & x1,const Xmm & x2)1081 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)1082 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)1083 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)1084 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)1085 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); }
1086 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); }
1087 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); }
1088 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); }
1089 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); }
1090 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); }
1091 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); }
1092 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); }
1093 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)1094 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)1095 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)1096 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)1097 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)1098 void vmovd(const Operand& op, const Xmm& x) { if (!op.isREG(32) && !op.isMEM()) XBYAK_THROW(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)1099 void vmovd(const Xmm& x, const Operand& op) { if (!op.isREG(32) && !op.isMEM()) XBYAK_THROW(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)1100 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)1101 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)1102 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)1103 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)1104 void vmovdqu(const Xmm& xm, const Operand& op) { opAVX_X_XM_IMM(xm, op, T_F3 | T_0F | T_YMM, 0x6F); }
1105 void vmovhlps(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) XBYAK_THROW(ERR_BAD_COMBINATION) opAVX_X_X_XM(x1, x2, op, T_0F | T_EVEX | T_EW0, 0x12); }
vmovhpd(const Address & addr,const Xmm & x)1106 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); }
1107 void vmovhpd(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) XBYAK_THROW(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)1108 void vmovhps(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_EVEX | T_EW0 | T_N8, 0x17); }
1109 void vmovhps(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) XBYAK_THROW(ERR_BAD_COMBINATION) opAVX_X_X_XM(x, op1, op2, T_0F | T_EVEX | T_EW0 | T_N8, 0x16); }
1110 void vmovlhps(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) XBYAK_THROW(ERR_BAD_COMBINATION) opAVX_X_X_XM(x1, x2, op, T_0F | T_EVEX | T_EW0, 0x16); }
vmovlpd(const Address & addr,const Xmm & x)1111 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); }
1112 void vmovlpd(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) XBYAK_THROW(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)1113 void vmovlps(const Address& addr, const Xmm& x) { opAVX_X_X_XM(x, xm0, addr, T_0F | T_EVEX | T_EW0 | T_N8, 0x13); }
1114 void vmovlps(const Xmm& x, const Operand& op1, const Operand& op2 = Operand()) { if (!op2.isNone() && !op2.isMEM()) XBYAK_THROW(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)1115 void vmovmskpd(const Reg& r, const Xmm& x) { if (!r.isBit(i32e)) XBYAK_THROW(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)1116 void vmovmskps(const Reg& r, const Xmm& x) { if (!r.isBit(i32e)) XBYAK_THROW(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)1117 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)1118 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)1119 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)1120 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)1121 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)1122 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)1123 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)1124 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)1125 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); }
1126 void vmovsd(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) XBYAK_THROW(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)1127 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)1128 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)1129 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)1130 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); }
1131 void vmovss(const Xmm& x1, const Xmm& x2, const Operand& op = Operand()) { if (!op.isNone() && !op.isXMM()) XBYAK_THROW(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)1132 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)1133 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)1134 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)1135 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)1136 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); }
1137 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); }
1138 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); }
1139 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); }
1140 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); }
1141 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); }
1142 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)1143 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)1144 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)1145 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)1146 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)1147 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)1148 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)1149 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)1150 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)1151 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)1152 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)1153 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)1154 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)1155 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)1156 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)1157 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)1158 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)1159 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)1160 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)1161 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)1162 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)1163 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)1164 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)1165 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)1166 void vpbroadcastb(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) XBYAK_THROW(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)1167 void vpbroadcastd(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) XBYAK_THROW(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)1168 void vpbroadcastq(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) XBYAK_THROW(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)1169 void vpbroadcastw(const Xmm& x, const Operand& op) { if (!(op.isXMM() || op.isMEM())) XBYAK_THROW(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)1170 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)1171 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)1172 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)1173 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)1174 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)1175 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)1176 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)1177 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)1178 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)1179 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)1180 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)1181 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)1182 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)1183 void vperm2f128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isYMEM())) XBYAK_THROW(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)1184 void vperm2i128(const Ymm& y1, const Ymm& y2, const Operand& op, uint8 imm) { if (!(y1.isYMM() && y2.isYMM() && op.isYMEM())) XBYAK_THROW(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)1185 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)1186 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)1187 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)1188 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)1189 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)1190 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)1191 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)1192 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)1193 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)1194 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)1195 void vpextrb(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(8|16|i32e) || op.isMEM()) && x.isXMM())) XBYAK_THROW(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)1196 void vpextrd(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(32) || op.isMEM()) && x.isXMM())) XBYAK_THROW(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)1197 void vpextrq(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(64) || op.isMEM()) && x.isXMM())) XBYAK_THROW(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)1198 void vpextrw(const Operand& op, const Xmm& x, uint8 imm) { if (!((op.isREG(16|i32e) || op.isMEM()) && x.isXMM())) XBYAK_THROW(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)1199 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)1200 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)1201 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)1202 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)1203 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)1204 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)1205 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)1206 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)1207 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)1208 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)1209 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)1210 void vpinsrb(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(32) || op.isMEM()))) XBYAK_THROW(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)1211 void vpinsrd(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(32) || op.isMEM()))) XBYAK_THROW(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)1212 void vpinsrq(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(64) || op.isMEM()))) XBYAK_THROW(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)1213 void vpinsrw(const Xmm& x1, const Xmm& x2, const Operand& op, uint8 imm) { if (!(x1.isXMM() && x2.isXMM() && (op.isREG(32) || op.isMEM()))) XBYAK_THROW(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)1214 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)1215 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)1216 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)1217 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)1218 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)1219 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)1220 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)1221 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)1222 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)1223 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)1224 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)1225 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)1226 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)1227 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)1228 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)1229 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)1230 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)1231 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)1232 void vpmovmskb(const Reg32e& r, const Xmm& x) { if (!x.is(Operand::XMM | Operand::YMM)) XBYAK_THROW(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)1233 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)1234 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)1235 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)1236 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)1237 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)1238 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)1239 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)1240 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)1241 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)1242 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)1243 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)1244 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)1245 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)1246 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)1247 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)1248 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)1249 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)1250 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)1251 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)1252 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)1253 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)1254 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)1255 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)1256 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)1257 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)1258 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)1259 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)1260 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)1261 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)1262 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)1263 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)1264 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)1265 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)1266 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)1267 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)1268 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)1269 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)1270 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)1271 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)1272 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)1273 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)1274 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)1275 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)1276 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)1277 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)1278 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)1279 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)1280 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)1281 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)1282 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)1283 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)1284 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)1285 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)1286 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)1287 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)1288 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)1289 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)1290 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)1291 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)1292 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)1293 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)1294 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)1295 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)1296 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)1297 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)1298 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)1299 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)1300 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)1301 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)1302 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)1303 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)1304 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)1305 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)1306 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)1307 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)1308 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)1309 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)1310 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)1311 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)1312 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)1313 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)1314 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)1315 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)1316 void vstmxcsr(const Address& addr) { opAVX_X_X_XM(xm3, xm0, addr, T_0F, 0xAE); }
1317 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); }
1318 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); }
1319 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); }
1320 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)1321 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)1322 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)1323 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)1324 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)1325 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)1326 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)1327 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)1328 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); }
1329 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); }
1330 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()1331 void vzeroall() { db(0xC5); db(0xFC); db(0x77); }
vzeroupper()1332 void vzeroupper() { db(0xC5); db(0xF8); db(0x77); }
wait()1333 void wait() { db(0x9B); }
wbinvd()1334 void wbinvd() { db(0x0F); db(0x09); }
wrmsr()1335 void wrmsr() { db(0x0F); db(0x30); }
xadd(const Operand & op,const Reg & reg)1336 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()1337 void xgetbv() { db(0x0F); db(0x01); db(0xD0); }
xlatb()1338 void xlatb() { db(0xD7); }
xor_(const Operand & op,uint32 imm)1339 void xor_(const Operand& op, uint32 imm) { opRM_I(op, imm, 0x30, 6); }
xor_(const Operand & op1,const Operand & op2)1340 void xor_(const Operand& op1, const Operand& op2) { opRM_RM(op1, op2, 0x30); }
xorpd(const Xmm & xmm,const Operand & op)1341 void xorpd(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x57, 0x66, isXMM_XMMorMEM); }
xorps(const Xmm & xmm,const Operand & op)1342 void xorps(const Xmm& xmm, const Operand& op) { opGen(xmm, op, 0x57, 0x100, isXMM_XMMorMEM); }
1343 #ifdef XBYAK_ENABLE_OMITTED_OPERAND
vblendpd(const Xmm & x,const Operand & op,uint8 imm)1344 void vblendpd(const Xmm& x, const Operand& op, uint8 imm) { vblendpd(x, x, op, imm); }
vblendps(const Xmm & x,const Operand & op,uint8 imm)1345 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)1346 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)1347 void vblendvps(const Xmm& x1, const Operand& op, const Xmm& x4) { vblendvps(x1, x1, op, x4); }
vcmpeq_ospd(const Xmm & x,const Operand & op)1348 void vcmpeq_ospd(const Xmm& x, const Operand& op) { vcmpeq_ospd(x, x, op); }
vcmpeq_osps(const Xmm & x,const Operand & op)1349 void vcmpeq_osps(const Xmm& x, const Operand& op) { vcmpeq_osps(x, x, op); }
vcmpeq_ossd(const Xmm & x,const Operand & op)1350 void vcmpeq_ossd(const Xmm& x, const Operand& op) { vcmpeq_ossd(x, x, op); }
vcmpeq_osss(const Xmm & x,const Operand & op)1351 void vcmpeq_osss(const Xmm& x, const Operand& op) { vcmpeq_osss(x, x, op); }
vcmpeq_uqpd(const Xmm & x,const Operand & op)1352 void vcmpeq_uqpd(const Xmm& x, const Operand& op) { vcmpeq_uqpd(x, x, op); }
vcmpeq_uqps(const Xmm & x,const Operand & op)1353 void vcmpeq_uqps(const Xmm& x, const Operand& op) { vcmpeq_uqps(x, x, op); }
vcmpeq_uqsd(const Xmm & x,const Operand & op)1354 void vcmpeq_uqsd(const Xmm& x, const Operand& op) { vcmpeq_uqsd(x, x, op); }
vcmpeq_uqss(const Xmm & x,const Operand & op)1355 void vcmpeq_uqss(const Xmm& x, const Operand& op) { vcmpeq_uqss(x, x, op); }
vcmpeq_uspd(const Xmm & x,const Operand & op)1356 void vcmpeq_uspd(const Xmm& x, const Operand& op) { vcmpeq_uspd(x, x, op); }
vcmpeq_usps(const Xmm & x,const Operand & op)1357 void vcmpeq_usps(const Xmm& x, const Operand& op) { vcmpeq_usps(x, x, op); }
vcmpeq_ussd(const Xmm & x,const Operand & op)1358 void vcmpeq_ussd(const Xmm& x, const Operand& op) { vcmpeq_ussd(x, x, op); }
vcmpeq_usss(const Xmm & x,const Operand & op)1359 void vcmpeq_usss(const Xmm& x, const Operand& op) { vcmpeq_usss(x, x, op); }
vcmpeqpd(const Xmm & x,const Operand & op)1360 void vcmpeqpd(const Xmm& x, const Operand& op) { vcmpeqpd(x, x, op); }
vcmpeqps(const Xmm & x,const Operand & op)1361 void vcmpeqps(const Xmm& x, const Operand& op) { vcmpeqps(x, x, op); }
vcmpeqsd(const Xmm & x,const Operand & op)1362 void vcmpeqsd(const Xmm& x, const Operand& op) { vcmpeqsd(x, x, op); }
vcmpeqss(const Xmm & x,const Operand & op)1363 void vcmpeqss(const Xmm& x, const Operand& op) { vcmpeqss(x, x, op); }
vcmpfalse_ospd(const Xmm & x,const Operand & op)1364 void vcmpfalse_ospd(const Xmm& x, const Operand& op) { vcmpfalse_ospd(x, x, op); }
vcmpfalse_osps(const Xmm & x,const Operand & op)1365 void vcmpfalse_osps(const Xmm& x, const Operand& op) { vcmpfalse_osps(x, x, op); }
vcmpfalse_ossd(const Xmm & x,const Operand & op)1366 void vcmpfalse_ossd(const Xmm& x, const Operand& op) { vcmpfalse_ossd(x, x, op); }
vcmpfalse_osss(const Xmm & x,const Operand & op)1367 void vcmpfalse_osss(const Xmm& x, const Operand& op) { vcmpfalse_osss(x, x, op); }
vcmpfalsepd(const Xmm & x,const Operand & op)1368 void vcmpfalsepd(const Xmm& x, const Operand& op) { vcmpfalsepd(x, x, op); }
vcmpfalseps(const Xmm & x,const Operand & op)1369 void vcmpfalseps(const Xmm& x, const Operand& op) { vcmpfalseps(x, x, op); }
vcmpfalsesd(const Xmm & x,const Operand & op)1370 void vcmpfalsesd(const Xmm& x, const Operand& op) { vcmpfalsesd(x, x, op); }
vcmpfalsess(const Xmm & x,const Operand & op)1371 void vcmpfalsess(const Xmm& x, const Operand& op) { vcmpfalsess(x, x, op); }
vcmpge_oqpd(const Xmm & x,const Operand & op)1372 void vcmpge_oqpd(const Xmm& x, const Operand& op) { vcmpge_oqpd(x, x, op); }
vcmpge_oqps(const Xmm & x,const Operand & op)1373 void vcmpge_oqps(const Xmm& x, const Operand& op) { vcmpge_oqps(x, x, op); }
vcmpge_oqsd(const Xmm & x,const Operand & op)1374 void vcmpge_oqsd(const Xmm& x, const Operand& op) { vcmpge_oqsd(x, x, op); }
vcmpge_oqss(const Xmm & x,const Operand & op)1375 void vcmpge_oqss(const Xmm& x, const Operand& op) { vcmpge_oqss(x, x, op); }
vcmpgepd(const Xmm & x,const Operand & op)1376 void vcmpgepd(const Xmm& x, const Operand& op) { vcmpgepd(x, x, op); }
vcmpgeps(const Xmm & x,const Operand & op)1377 void vcmpgeps(const Xmm& x, const Operand& op) { vcmpgeps(x, x, op); }
vcmpgesd(const Xmm & x,const Operand & op)1378 void vcmpgesd(const Xmm& x, const Operand& op) { vcmpgesd(x, x, op); }
vcmpgess(const Xmm & x,const Operand & op)1379 void vcmpgess(const Xmm& x, const Operand& op) { vcmpgess(x, x, op); }
vcmpgt_oqpd(const Xmm & x,const Operand & op)1380 void vcmpgt_oqpd(const Xmm& x, const Operand& op) { vcmpgt_oqpd(x, x, op); }
vcmpgt_oqps(const Xmm & x,const Operand & op)1381 void vcmpgt_oqps(const Xmm& x, const Operand& op) { vcmpgt_oqps(x, x, op); }
vcmpgt_oqsd(const Xmm & x,const Operand & op)1382 void vcmpgt_oqsd(const Xmm& x, const Operand& op) { vcmpgt_oqsd(x, x, op); }
vcmpgt_oqss(const Xmm & x,const Operand & op)1383 void vcmpgt_oqss(const Xmm& x, const Operand& op) { vcmpgt_oqss(x, x, op); }
vcmpgtpd(const Xmm & x,const Operand & op)1384 void vcmpgtpd(const Xmm& x, const Operand& op) { vcmpgtpd(x, x, op); }
vcmpgtps(const Xmm & x,const Operand & op)1385 void vcmpgtps(const Xmm& x, const Operand& op) { vcmpgtps(x, x, op); }
vcmpgtsd(const Xmm & x,const Operand & op)1386 void vcmpgtsd(const Xmm& x, const Operand& op) { vcmpgtsd(x, x, op); }
vcmpgtss(const Xmm & x,const Operand & op)1387 void vcmpgtss(const Xmm& x, const Operand& op) { vcmpgtss(x, x, op); }
vcmple_oqpd(const Xmm & x,const Operand & op)1388 void vcmple_oqpd(const Xmm& x, const Operand& op) { vcmple_oqpd(x, x, op); }
vcmple_oqps(const Xmm & x,const Operand & op)1389 void vcmple_oqps(const Xmm& x, const Operand& op) { vcmple_oqps(x, x, op); }
vcmple_oqsd(const Xmm & x,const Operand & op)1390 void vcmple_oqsd(const Xmm& x, const Operand& op) { vcmple_oqsd(x, x, op); }
vcmple_oqss(const Xmm & x,const Operand & op)1391 void vcmple_oqss(const Xmm& x, const Operand& op) { vcmple_oqss(x, x, op); }
vcmplepd(const Xmm & x,const Operand & op)1392 void vcmplepd(const Xmm& x, const Operand& op) { vcmplepd(x, x, op); }
vcmpleps(const Xmm & x,const Operand & op)1393 void vcmpleps(const Xmm& x, const Operand& op) { vcmpleps(x, x, op); }
vcmplesd(const Xmm & x,const Operand & op)1394 void vcmplesd(const Xmm& x, const Operand& op) { vcmplesd(x, x, op); }
vcmpless(const Xmm & x,const Operand & op)1395 void vcmpless(const Xmm& x, const Operand& op) { vcmpless(x, x, op); }
vcmplt_oqpd(const Xmm & x,const Operand & op)1396 void vcmplt_oqpd(const Xmm& x, const Operand& op) { vcmplt_oqpd(x, x, op); }
vcmplt_oqps(const Xmm & x,const Operand & op)1397 void vcmplt_oqps(const Xmm& x, const Operand& op) { vcmplt_oqps(x, x, op); }
vcmplt_oqsd(const Xmm & x,const Operand & op)1398 void vcmplt_oqsd(const Xmm& x, const Operand& op) { vcmplt_oqsd(x, x, op); }
vcmplt_oqss(const Xmm & x,const Operand & op)1399 void vcmplt_oqss(const Xmm& x, const Operand& op) { vcmplt_oqss(x, x, op); }
vcmpltpd(const Xmm & x,const Operand & op)1400 void vcmpltpd(const Xmm& x, const Operand& op) { vcmpltpd(x, x, op); }
vcmpltps(const Xmm & x,const Operand & op)1401 void vcmpltps(const Xmm& x, const Operand& op) { vcmpltps(x, x, op); }
vcmpltsd(const Xmm & x,const Operand & op)1402 void vcmpltsd(const Xmm& x, const Operand& op) { vcmpltsd(x, x, op); }
vcmpltss(const Xmm & x,const Operand & op)1403 void vcmpltss(const Xmm& x, const Operand& op) { vcmpltss(x, x, op); }
vcmpneq_oqpd(const Xmm & x,const Operand & op)1404 void vcmpneq_oqpd(const Xmm& x, const Operand& op) { vcmpneq_oqpd(x, x, op); }
vcmpneq_oqps(const Xmm & x,const Operand & op)1405 void vcmpneq_oqps(const Xmm& x, const Operand& op) { vcmpneq_oqps(x, x, op); }
vcmpneq_oqsd(const Xmm & x,const Operand & op)1406 void vcmpneq_oqsd(const Xmm& x, const Operand& op) { vcmpneq_oqsd(x, x, op); }
vcmpneq_oqss(const Xmm & x,const Operand & op)1407 void vcmpneq_oqss(const Xmm& x, const Operand& op) { vcmpneq_oqss(x, x, op); }
vcmpneq_ospd(const Xmm & x,const Operand & op)1408 void vcmpneq_ospd(const Xmm& x, const Operand& op) { vcmpneq_ospd(x, x, op); }
vcmpneq_osps(const Xmm & x,const Operand & op)1409 void vcmpneq_osps(const Xmm& x, const Operand& op) { vcmpneq_osps(x, x, op); }
vcmpneq_ossd(const Xmm & x,const Operand & op)1410 void vcmpneq_ossd(const Xmm& x, const Operand& op) { vcmpneq_ossd(x, x, op); }
vcmpneq_osss(const Xmm & x,const Operand & op)1411 void vcmpneq_osss(const Xmm& x, const Operand& op) { vcmpneq_osss(x, x, op); }
vcmpneq_uspd(const Xmm & x,const Operand & op)1412 void vcmpneq_uspd(const Xmm& x, const Operand& op) { vcmpneq_uspd(x, x, op); }
vcmpneq_usps(const Xmm & x,const Operand & op)1413 void vcmpneq_usps(const Xmm& x, const Operand& op) { vcmpneq_usps(x, x, op); }
vcmpneq_ussd(const Xmm & x,const Operand & op)1414 void vcmpneq_ussd(const Xmm& x, const Operand& op) { vcmpneq_ussd(x, x, op); }
vcmpneq_usss(const Xmm & x,const Operand & op)1415 void vcmpneq_usss(const Xmm& x, const Operand& op) { vcmpneq_usss(x, x, op); }
vcmpneqpd(const Xmm & x,const Operand & op)1416 void vcmpneqpd(const Xmm& x, const Operand& op) { vcmpneqpd(x, x, op); }
vcmpneqps(const Xmm & x,const Operand & op)1417 void vcmpneqps(const Xmm& x, const Operand& op) { vcmpneqps(x, x, op); }
vcmpneqsd(const Xmm & x,const Operand & op)1418 void vcmpneqsd(const Xmm& x, const Operand& op) { vcmpneqsd(x, x, op); }
vcmpneqss(const Xmm & x,const Operand & op)1419 void vcmpneqss(const Xmm& x, const Operand& op) { vcmpneqss(x, x, op); }
vcmpnge_uqpd(const Xmm & x,const Operand & op)1420 void vcmpnge_uqpd(const Xmm& x, const Operand& op) { vcmpnge_uqpd(x, x, op); }
vcmpnge_uqps(const Xmm & x,const Operand & op)1421 void vcmpnge_uqps(const Xmm& x, const Operand& op) { vcmpnge_uqps(x, x, op); }
vcmpnge_uqsd(const Xmm & x,const Operand & op)1422 void vcmpnge_uqsd(const Xmm& x, const Operand& op) { vcmpnge_uqsd(x, x, op); }
vcmpnge_uqss(const Xmm & x,const Operand & op)1423 void vcmpnge_uqss(const Xmm& x, const Operand& op) { vcmpnge_uqss(x, x, op); }
vcmpngepd(const Xmm & x,const Operand & op)1424 void vcmpngepd(const Xmm& x, const Operand& op) { vcmpngepd(x, x, op); }
vcmpngeps(const Xmm & x,const Operand & op)1425 void vcmpngeps(const Xmm& x, const Operand& op) { vcmpngeps(x, x, op); }
vcmpngesd(const Xmm & x,const Operand & op)1426 void vcmpngesd(const Xmm& x, const Operand& op) { vcmpngesd(x, x, op); }
vcmpngess(const Xmm & x,const Operand & op)1427 void vcmpngess(const Xmm& x, const Operand& op) { vcmpngess(x, x, op); }
vcmpngt_uqpd(const Xmm & x,const Operand & op)1428 void vcmpngt_uqpd(const Xmm& x, const Operand& op) { vcmpngt_uqpd(x, x, op); }
vcmpngt_uqps(const Xmm & x,const Operand & op)1429 void vcmpngt_uqps(const Xmm& x, const Operand& op) { vcmpngt_uqps(x, x, op); }
vcmpngt_uqsd(const Xmm & x,const Operand & op)1430 void vcmpngt_uqsd(const Xmm& x, const Operand& op) { vcmpngt_uqsd(x, x, op); }
vcmpngt_uqss(const Xmm & x,const Operand & op)1431 void vcmpngt_uqss(const Xmm& x, const Operand& op) { vcmpngt_uqss(x, x, op); }
vcmpngtpd(const Xmm & x,const Operand & op)1432 void vcmpngtpd(const Xmm& x, const Operand& op) { vcmpngtpd(x, x, op); }
vcmpngtps(const Xmm & x,const Operand & op)1433 void vcmpngtps(const Xmm& x, const Operand& op) { vcmpngtps(x, x, op); }
vcmpngtsd(const Xmm & x,const Operand & op)1434 void vcmpngtsd(const Xmm& x, const Operand& op) { vcmpngtsd(x, x, op); }
vcmpngtss(const Xmm & x,const Operand & op)1435 void vcmpngtss(const Xmm& x, const Operand& op) { vcmpngtss(x, x, op); }
vcmpnle_uqpd(const Xmm & x,const Operand & op)1436 void vcmpnle_uqpd(const Xmm& x, const Operand& op) { vcmpnle_uqpd(x, x, op); }
vcmpnle_uqps(const Xmm & x,const Operand & op)1437 void vcmpnle_uqps(const Xmm& x, const Operand& op) { vcmpnle_uqps(x, x, op); }
vcmpnle_uqsd(const Xmm & x,const Operand & op)1438 void vcmpnle_uqsd(const Xmm& x, const Operand& op) { vcmpnle_uqsd(x, x, op); }
vcmpnle_uqss(const Xmm & x,const Operand & op)1439 void vcmpnle_uqss(const Xmm& x, const Operand& op) { vcmpnle_uqss(x, x, op); }
vcmpnlepd(const Xmm & x,const Operand & op)1440 void vcmpnlepd(const Xmm& x, const Operand& op) { vcmpnlepd(x, x, op); }
vcmpnleps(const Xmm & x,const Operand & op)1441 void vcmpnleps(const Xmm& x, const Operand& op) { vcmpnleps(x, x, op); }
vcmpnlesd(const Xmm & x,const Operand & op)1442 void vcmpnlesd(const Xmm& x, const Operand& op) { vcmpnlesd(x, x, op); }
vcmpnless(const Xmm & x,const Operand & op)1443 void vcmpnless(const Xmm& x, const Operand& op) { vcmpnless(x, x, op); }
vcmpnlt_uqpd(const Xmm & x,const Operand & op)1444 void vcmpnlt_uqpd(const Xmm& x, const Operand& op) { vcmpnlt_uqpd(x, x, op); }
vcmpnlt_uqps(const Xmm & x,const Operand & op)1445 void vcmpnlt_uqps(const Xmm& x, const Operand& op) { vcmpnlt_uqps(x, x, op); }
vcmpnlt_uqsd(const Xmm & x,const Operand & op)1446 void vcmpnlt_uqsd(const Xmm& x, const Operand& op) { vcmpnlt_uqsd(x, x, op); }
vcmpnlt_uqss(const Xmm & x,const Operand & op)1447 void vcmpnlt_uqss(const Xmm& x, const Operand& op) { vcmpnlt_uqss(x, x, op); }
vcmpnltpd(const Xmm & x,const Operand & op)1448 void vcmpnltpd(const Xmm& x, const Operand& op) { vcmpnltpd(x, x, op); }
vcmpnltps(const Xmm & x,const Operand & op)1449 void vcmpnltps(const Xmm& x, const Operand& op) { vcmpnltps(x, x, op); }
vcmpnltsd(const Xmm & x,const Operand & op)1450 void vcmpnltsd(const Xmm& x, const Operand& op) { vcmpnltsd(x, x, op); }
vcmpnltss(const Xmm & x,const Operand & op)1451 void vcmpnltss(const Xmm& x, const Operand& op) { vcmpnltss(x, x, op); }
vcmpord_spd(const Xmm & x,const Operand & op)1452 void vcmpord_spd(const Xmm& x, const Operand& op) { vcmpord_spd(x, x, op); }
vcmpord_sps(const Xmm & x,const Operand & op)1453 void vcmpord_sps(const Xmm& x, const Operand& op) { vcmpord_sps(x, x, op); }
vcmpord_ssd(const Xmm & x,const Operand & op)1454 void vcmpord_ssd(const Xmm& x, const Operand& op) { vcmpord_ssd(x, x, op); }
vcmpord_sss(const Xmm & x,const Operand & op)1455 void vcmpord_sss(const Xmm& x, const Operand& op) { vcmpord_sss(x, x, op); }
vcmpordpd(const Xmm & x,const Operand & op)1456 void vcmpordpd(const Xmm& x, const Operand& op) { vcmpordpd(x, x, op); }
vcmpordps(const Xmm & x,const Operand & op)1457 void vcmpordps(const Xmm& x, const Operand& op) { vcmpordps(x, x, op); }
vcmpordsd(const Xmm & x,const Operand & op)1458 void vcmpordsd(const Xmm& x, const Operand& op) { vcmpordsd(x, x, op); }
vcmpordss(const Xmm & x,const Operand & op)1459 void vcmpordss(const Xmm& x, const Operand& op) { vcmpordss(x, x, op); }
vcmppd(const Xmm & x,const Operand & op,uint8 imm)1460 void vcmppd(const Xmm& x, const Operand& op, uint8 imm) { vcmppd(x, x, op, imm); }
vcmpps(const Xmm & x,const Operand & op,uint8 imm)1461 void vcmpps(const Xmm& x, const Operand& op, uint8 imm) { vcmpps(x, x, op, imm); }
vcmpsd(const Xmm & x,const Operand & op,uint8 imm)1462 void vcmpsd(const Xmm& x, const Operand& op, uint8 imm) { vcmpsd(x, x, op, imm); }
vcmpss(const Xmm & x,const Operand & op,uint8 imm)1463 void vcmpss(const Xmm& x, const Operand& op, uint8 imm) { vcmpss(x, x, op, imm); }
vcmptrue_uspd(const Xmm & x,const Operand & op)1464 void vcmptrue_uspd(const Xmm& x, const Operand& op) { vcmptrue_uspd(x, x, op); }
vcmptrue_usps(const Xmm & x,const Operand & op)1465 void vcmptrue_usps(const Xmm& x, const Operand& op) { vcmptrue_usps(x, x, op); }
vcmptrue_ussd(const Xmm & x,const Operand & op)1466 void vcmptrue_ussd(const Xmm& x, const Operand& op) { vcmptrue_ussd(x, x, op); }
vcmptrue_usss(const Xmm & x,const Operand & op)1467 void vcmptrue_usss(const Xmm& x, const Operand& op) { vcmptrue_usss(x, x, op); }
vcmptruepd(const Xmm & x,const Operand & op)1468 void vcmptruepd(const Xmm& x, const Operand& op) { vcmptruepd(x, x, op); }
vcmptrueps(const Xmm & x,const Operand & op)1469 void vcmptrueps(const Xmm& x, const Operand& op) { vcmptrueps(x, x, op); }
vcmptruesd(const Xmm & x,const Operand & op)1470 void vcmptruesd(const Xmm& x, const Operand& op) { vcmptruesd(x, x, op); }
vcmptruess(const Xmm & x,const Operand & op)1471 void vcmptruess(const Xmm& x, const Operand& op) { vcmptruess(x, x, op); }
vcmpunord_spd(const Xmm & x,const Operand & op)1472 void vcmpunord_spd(const Xmm& x, const Operand& op) { vcmpunord_spd(x, x, op); }
vcmpunord_sps(const Xmm & x,const Operand & op)1473 void vcmpunord_sps(const Xmm& x, const Operand& op) { vcmpunord_sps(x, x, op); }
vcmpunord_ssd(const Xmm & x,const Operand & op)1474 void vcmpunord_ssd(const Xmm& x, const Operand& op) { vcmpunord_ssd(x, x, op); }
vcmpunord_sss(const Xmm & x,const Operand & op)1475 void vcmpunord_sss(const Xmm& x, const Operand& op) { vcmpunord_sss(x, x, op); }
vcmpunordpd(const Xmm & x,const Operand & op)1476 void vcmpunordpd(const Xmm& x, const Operand& op) { vcmpunordpd(x, x, op); }
vcmpunordps(const Xmm & x,const Operand & op)1477 void vcmpunordps(const Xmm& x, const Operand& op) { vcmpunordps(x, x, op); }
vcmpunordsd(const Xmm & x,const Operand & op)1478 void vcmpunordsd(const Xmm& x, const Operand& op) { vcmpunordsd(x, x, op); }
vcmpunordss(const Xmm & x,const Operand & op)1479 void vcmpunordss(const Xmm& x, const Operand& op) { vcmpunordss(x, x, op); }
vcvtsd2ss(const Xmm & x,const Operand & op)1480 void vcvtsd2ss(const Xmm& x, const Operand& op) { vcvtsd2ss(x, x, op); }
vcvtsi2sd(const Xmm & x,const Operand & op)1481 void vcvtsi2sd(const Xmm& x, const Operand& op) { vcvtsi2sd(x, x, op); }
vcvtsi2ss(const Xmm & x,const Operand & op)1482 void vcvtsi2ss(const Xmm& x, const Operand& op) { vcvtsi2ss(x, x, op); }
vcvtss2sd(const Xmm & x,const Operand & op)1483 void vcvtss2sd(const Xmm& x, const Operand& op) { vcvtss2sd(x, x, op); }
vdppd(const Xmm & x,const Operand & op,uint8 imm)1484 void vdppd(const Xmm& x, const Operand& op, uint8 imm) { vdppd(x, x, op, imm); }
vdpps(const Xmm & x,const Operand & op,uint8 imm)1485 void vdpps(const Xmm& x, const Operand& op, uint8 imm) { vdpps(x, x, op, imm); }
vinsertps(const Xmm & x,const Operand & op,uint8 imm)1486 void vinsertps(const Xmm& x, const Operand& op, uint8 imm) { vinsertps(x, x, op, imm); }
vmpsadbw(const Xmm & x,const Operand & op,uint8 imm)1487 void vmpsadbw(const Xmm& x, const Operand& op, uint8 imm) { vmpsadbw(x, x, op, imm); }
vpackssdw(const Xmm & x,const Operand & op)1488 void vpackssdw(const Xmm& x, const Operand& op) { vpackssdw(x, x, op); }
vpacksswb(const Xmm & x,const Operand & op)1489 void vpacksswb(const Xmm& x, const Operand& op) { vpacksswb(x, x, op); }
vpackusdw(const Xmm & x,const Operand & op)1490 void vpackusdw(const Xmm& x, const Operand& op) { vpackusdw(x, x, op); }
vpackuswb(const Xmm & x,const Operand & op)1491 void vpackuswb(const Xmm& x, const Operand& op) { vpackuswb(x, x, op); }
vpaddb(const Xmm & x,const Operand & op)1492 void vpaddb(const Xmm& x, const Operand& op) { vpaddb(x, x, op); }
vpaddd(const Xmm & x,const Operand & op)1493 void vpaddd(const Xmm& x, const Operand& op) { vpaddd(x, x, op); }
vpaddq(const Xmm & x,const Operand & op)1494 void vpaddq(const Xmm& x, const Operand& op) { vpaddq(x, x, op); }
vpaddsb(const Xmm & x,const Operand & op)1495 void vpaddsb(const Xmm& x, const Operand& op) { vpaddsb(x, x, op); }
vpaddsw(const Xmm & x,const Operand & op)1496 void vpaddsw(const Xmm& x, const Operand& op) { vpaddsw(x, x, op); }
vpaddusb(const Xmm & x,const Operand & op)1497 void vpaddusb(const Xmm& x, const Operand& op) { vpaddusb(x, x, op); }
vpaddusw(const Xmm & x,const Operand & op)1498 void vpaddusw(const Xmm& x, const Operand& op) { vpaddusw(x, x, op); }
vpaddw(const Xmm & x,const Operand & op)1499 void vpaddw(const Xmm& x, const Operand& op) { vpaddw(x, x, op); }
vpalignr(const Xmm & x,const Operand & op,uint8 imm)1500 void vpalignr(const Xmm& x, const Operand& op, uint8 imm) { vpalignr(x, x, op, imm); }
vpand(const Xmm & x,const Operand & op)1501 void vpand(const Xmm& x, const Operand& op) { vpand(x, x, op); }
vpandn(const Xmm & x,const Operand & op)1502 void vpandn(const Xmm& x, const Operand& op) { vpandn(x, x, op); }
vpavgb(const Xmm & x,const Operand & op)1503 void vpavgb(const Xmm& x, const Operand& op) { vpavgb(x, x, op); }
vpavgw(const Xmm & x,const Operand & op)1504 void vpavgw(const Xmm& x, const Operand& op) { vpavgw(x, x, op); }
vpblendd(const Xmm & x,const Operand & op,uint8 imm)1505 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)1506 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)1507 void vpblendw(const Xmm& x, const Operand& op, uint8 imm) { vpblendw(x, x, op, imm); }
vpclmulqdq(const Xmm & x,const Operand & op,uint8 imm)1508 void vpclmulqdq(const Xmm& x, const Operand& op, uint8 imm) { vpclmulqdq(x, x, op, imm); }
vpcmpeqb(const Xmm & x,const Operand & op)1509 void vpcmpeqb(const Xmm& x, const Operand& op) { vpcmpeqb(x, x, op); }
vpcmpeqd(const Xmm & x,const Operand & op)1510 void vpcmpeqd(const Xmm& x, const Operand& op) { vpcmpeqd(x, x, op); }
vpcmpeqq(const Xmm & x,const Operand & op)1511 void vpcmpeqq(const Xmm& x, const Operand& op) { vpcmpeqq(x, x, op); }
vpcmpeqw(const Xmm & x,const Operand & op)1512 void vpcmpeqw(const Xmm& x, const Operand& op) { vpcmpeqw(x, x, op); }
vpcmpgtb(const Xmm & x,const Operand & op)1513 void vpcmpgtb(const Xmm& x, const Operand& op) { vpcmpgtb(x, x, op); }
vpcmpgtd(const Xmm & x,const Operand & op)1514 void vpcmpgtd(const Xmm& x, const Operand& op) { vpcmpgtd(x, x, op); }
vpcmpgtq(const Xmm & x,const Operand & op)1515 void vpcmpgtq(const Xmm& x, const Operand& op) { vpcmpgtq(x, x, op); }
vpcmpgtw(const Xmm & x,const Operand & op)1516 void vpcmpgtw(const Xmm& x, const Operand& op) { vpcmpgtw(x, x, op); }
vphaddd(const Xmm & x,const Operand & op)1517 void vphaddd(const Xmm& x, const Operand& op) { vphaddd(x, x, op); }
vphaddsw(const Xmm & x,const Operand & op)1518 void vphaddsw(const Xmm& x, const Operand& op) { vphaddsw(x, x, op); }
vphaddw(const Xmm & x,const Operand & op)1519 void vphaddw(const Xmm& x, const Operand& op) { vphaddw(x, x, op); }
vphsubd(const Xmm & x,const Operand & op)1520 void vphsubd(const Xmm& x, const Operand& op) { vphsubd(x, x, op); }
vphsubsw(const Xmm & x,const Operand & op)1521 void vphsubsw(const Xmm& x, const Operand& op) { vphsubsw(x, x, op); }
vphsubw(const Xmm & x,const Operand & op)1522 void vphsubw(const Xmm& x, const Operand& op) { vphsubw(x, x, op); }
vpinsrb(const Xmm & x,const Operand & op,uint8 imm)1523 void vpinsrb(const Xmm& x, const Operand& op, uint8 imm) { vpinsrb(x, x, op, imm); }
vpinsrd(const Xmm & x,const Operand & op,uint8 imm)1524 void vpinsrd(const Xmm& x, const Operand& op, uint8 imm) { vpinsrd(x, x, op, imm); }
vpinsrq(const Xmm & x,const Operand & op,uint8 imm)1525 void vpinsrq(const Xmm& x, const Operand& op, uint8 imm) { vpinsrq(x, x, op, imm); }
vpinsrw(const Xmm & x,const Operand & op,uint8 imm)1526 void vpinsrw(const Xmm& x, const Operand& op, uint8 imm) { vpinsrw(x, x, op, imm); }
vpmaddubsw(const Xmm & x,const Operand & op)1527 void vpmaddubsw(const Xmm& x, const Operand& op) { vpmaddubsw(x, x, op); }
vpmaddwd(const Xmm & x,const Operand & op)1528 void vpmaddwd(const Xmm& x, const Operand& op) { vpmaddwd(x, x, op); }
vpmaxsb(const Xmm & x,const Operand & op)1529 void vpmaxsb(const Xmm& x, const Operand& op) { vpmaxsb(x, x, op); }
vpmaxsd(const Xmm & x,const Operand & op)1530 void vpmaxsd(const Xmm& x, const Operand& op) { vpmaxsd(x, x, op); }
vpmaxsw(const Xmm & x,const Operand & op)1531 void vpmaxsw(const Xmm& x, const Operand& op) { vpmaxsw(x, x, op); }
vpmaxub(const Xmm & x,const Operand & op)1532 void vpmaxub(const Xmm& x, const Operand& op) { vpmaxub(x, x, op); }
vpmaxud(const Xmm & x,const Operand & op)1533 void vpmaxud(const Xmm& x, const Operand& op) { vpmaxud(x, x, op); }
vpmaxuw(const Xmm & x,const Operand & op)1534 void vpmaxuw(const Xmm& x, const Operand& op) { vpmaxuw(x, x, op); }
vpminsb(const Xmm & x,const Operand & op)1535 void vpminsb(const Xmm& x, const Operand& op) { vpminsb(x, x, op); }
vpminsd(const Xmm & x,const Operand & op)1536 void vpminsd(const Xmm& x, const Operand& op) { vpminsd(x, x, op); }
vpminsw(const Xmm & x,const Operand & op)1537 void vpminsw(const Xmm& x, const Operand& op) { vpminsw(x, x, op); }
vpminub(const Xmm & x,const Operand & op)1538 void vpminub(const Xmm& x, const Operand& op) { vpminub(x, x, op); }
vpminud(const Xmm & x,const Operand & op)1539 void vpminud(const Xmm& x, const Operand& op) { vpminud(x, x, op); }
vpminuw(const Xmm & x,const Operand & op)1540 void vpminuw(const Xmm& x, const Operand& op) { vpminuw(x, x, op); }
vpmuldq(const Xmm & x,const Operand & op)1541 void vpmuldq(const Xmm& x, const Operand& op) { vpmuldq(x, x, op); }
vpmulhrsw(const Xmm & x,const Operand & op)1542 void vpmulhrsw(const Xmm& x, const Operand& op) { vpmulhrsw(x, x, op); }
vpmulhuw(const Xmm & x,const Operand & op)1543 void vpmulhuw(const Xmm& x, const Operand& op) { vpmulhuw(x, x, op); }
vpmulhw(const Xmm & x,const Operand & op)1544 void vpmulhw(const Xmm& x, const Operand& op) { vpmulhw(x, x, op); }
vpmulld(const Xmm & x,const Operand & op)1545 void vpmulld(const Xmm& x, const Operand& op) { vpmulld(x, x, op); }
vpmullw(const Xmm & x,const Operand & op)1546 void vpmullw(const Xmm& x, const Operand& op) { vpmullw(x, x, op); }
vpmuludq(const Xmm & x,const Operand & op)1547 void vpmuludq(const Xmm& x, const Operand& op) { vpmuludq(x, x, op); }
vpor(const Xmm & x,const Operand & op)1548 void vpor(const Xmm& x, const Operand& op) { vpor(x, x, op); }
vpsadbw(const Xmm & x,const Operand & op)1549 void vpsadbw(const Xmm& x, const Operand& op) { vpsadbw(x, x, op); }
vpsignb(const Xmm & x,const Operand & op)1550 void vpsignb(const Xmm& x, const Operand& op) { vpsignb(x, x, op); }
vpsignd(const Xmm & x,const Operand & op)1551 void vpsignd(const Xmm& x, const Operand& op) { vpsignd(x, x, op); }
vpsignw(const Xmm & x,const Operand & op)1552 void vpsignw(const Xmm& x, const Operand& op) { vpsignw(x, x, op); }
vpslld(const Xmm & x,const Operand & op)1553 void vpslld(const Xmm& x, const Operand& op) { vpslld(x, x, op); }
vpslld(const Xmm & x,uint8 imm)1554 void vpslld(const Xmm& x, uint8 imm) { vpslld(x, x, imm); }
vpslldq(const Xmm & x,uint8 imm)1555 void vpslldq(const Xmm& x, uint8 imm) { vpslldq(x, x, imm); }
vpsllq(const Xmm & x,const Operand & op)1556 void vpsllq(const Xmm& x, const Operand& op) { vpsllq(x, x, op); }
vpsllq(const Xmm & x,uint8 imm)1557 void vpsllq(const Xmm& x, uint8 imm) { vpsllq(x, x, imm); }
vpsllw(const Xmm & x,const Operand & op)1558 void vpsllw(const Xmm& x, const Operand& op) { vpsllw(x, x, op); }
vpsllw(const Xmm & x,uint8 imm)1559 void vpsllw(const Xmm& x, uint8 imm) { vpsllw(x, x, imm); }
vpsrad(const Xmm & x,const Operand & op)1560 void vpsrad(const Xmm& x, const Operand& op) { vpsrad(x, x, op); }
vpsrad(const Xmm & x,uint8 imm)1561 void vpsrad(const Xmm& x, uint8 imm) { vpsrad(x, x, imm); }
vpsraw(const Xmm & x,const Operand & op)1562 void vpsraw(const Xmm& x, const Operand& op) { vpsraw(x, x, op); }
vpsraw(const Xmm & x,uint8 imm)1563 void vpsraw(const Xmm& x, uint8 imm) { vpsraw(x, x, imm); }
vpsrld(const Xmm & x,const Operand & op)1564 void vpsrld(const Xmm& x, const Operand& op) { vpsrld(x, x, op); }
vpsrld(const Xmm & x,uint8 imm)1565 void vpsrld(const Xmm& x, uint8 imm) { vpsrld(x, x, imm); }
vpsrldq(const Xmm & x,uint8 imm)1566 void vpsrldq(const Xmm& x, uint8 imm) { vpsrldq(x, x, imm); }
vpsrlq(const Xmm & x,const Operand & op)1567 void vpsrlq(const Xmm& x, const Operand& op) { vpsrlq(x, x, op); }
vpsrlq(const Xmm & x,uint8 imm)1568 void vpsrlq(const Xmm& x, uint8 imm) { vpsrlq(x, x, imm); }
vpsrlw(const Xmm & x,const Operand & op)1569 void vpsrlw(const Xmm& x, const Operand& op) { vpsrlw(x, x, op); }
vpsrlw(const Xmm & x,uint8 imm)1570 void vpsrlw(const Xmm& x, uint8 imm) { vpsrlw(x, x, imm); }
vpsubb(const Xmm & x,const Operand & op)1571 void vpsubb(const Xmm& x, const Operand& op) { vpsubb(x, x, op); }
vpsubd(const Xmm & x,const Operand & op)1572 void vpsubd(const Xmm& x, const Operand& op) { vpsubd(x, x, op); }
vpsubq(const Xmm & x,const Operand & op)1573 void vpsubq(const Xmm& x, const Operand& op) { vpsubq(x, x, op); }
vpsubsb(const Xmm & x,const Operand & op)1574 void vpsubsb(const Xmm& x, const Operand& op) { vpsubsb(x, x, op); }
vpsubsw(const Xmm & x,const Operand & op)1575 void vpsubsw(const Xmm& x, const Operand& op) { vpsubsw(x, x, op); }
vpsubusb(const Xmm & x,const Operand & op)1576 void vpsubusb(const Xmm& x, const Operand& op) { vpsubusb(x, x, op); }
vpsubusw(const Xmm & x,const Operand & op)1577 void vpsubusw(const Xmm& x, const Operand& op) { vpsubusw(x, x, op); }
vpsubw(const Xmm & x,const Operand & op)1578 void vpsubw(const Xmm& x, const Operand& op) { vpsubw(x, x, op); }
vpunpckhbw(const Xmm & x,const Operand & op)1579 void vpunpckhbw(const Xmm& x, const Operand& op) { vpunpckhbw(x, x, op); }
vpunpckhdq(const Xmm & x,const Operand & op)1580 void vpunpckhdq(const Xmm& x, const Operand& op) { vpunpckhdq(x, x, op); }
vpunpckhqdq(const Xmm & x,const Operand & op)1581 void vpunpckhqdq(const Xmm& x, const Operand& op) { vpunpckhqdq(x, x, op); }
vpunpckhwd(const Xmm & x,const Operand & op)1582 void vpunpckhwd(const Xmm& x, const Operand& op) { vpunpckhwd(x, x, op); }
vpunpcklbw(const Xmm & x,const Operand & op)1583 void vpunpcklbw(const Xmm& x, const Operand& op) { vpunpcklbw(x, x, op); }
vpunpckldq(const Xmm & x,const Operand & op)1584 void vpunpckldq(const Xmm& x, const Operand& op) { vpunpckldq(x, x, op); }
vpunpcklqdq(const Xmm & x,const Operand & op)1585 void vpunpcklqdq(const Xmm& x, const Operand& op) { vpunpcklqdq(x, x, op); }
vpunpcklwd(const Xmm & x,const Operand & op)1586 void vpunpcklwd(const Xmm& x, const Operand& op) { vpunpcklwd(x, x, op); }
vpxor(const Xmm & x,const Operand & op)1587 void vpxor(const Xmm& x, const Operand& op) { vpxor(x, x, op); }
vrcpss(const Xmm & x,const Operand & op)1588 void vrcpss(const Xmm& x, const Operand& op) { vrcpss(x, x, op); }
vroundsd(const Xmm & x,const Operand & op,uint8 imm)1589 void vroundsd(const Xmm& x, const Operand& op, uint8 imm) { vroundsd(x, x, op, imm); }
vroundss(const Xmm & x,const Operand & op,uint8 imm)1590 void vroundss(const Xmm& x, const Operand& op, uint8 imm) { vroundss(x, x, op, imm); }
vrsqrtss(const Xmm & x,const Operand & op)1591 void vrsqrtss(const Xmm& x, const Operand& op) { vrsqrtss(x, x, op); }
vshufpd(const Xmm & x,const Operand & op,uint8 imm)1592 void vshufpd(const Xmm& x, const Operand& op, uint8 imm) { vshufpd(x, x, op, imm); }
vshufps(const Xmm & x,const Operand & op,uint8 imm)1593 void vshufps(const Xmm& x, const Operand& op, uint8 imm) { vshufps(x, x, op, imm); }
vsqrtsd(const Xmm & x,const Operand & op)1594 void vsqrtsd(const Xmm& x, const Operand& op) { vsqrtsd(x, x, op); }
vsqrtss(const Xmm & x,const Operand & op)1595 void vsqrtss(const Xmm& x, const Operand& op) { vsqrtss(x, x, op); }
vunpckhpd(const Xmm & x,const Operand & op)1596 void vunpckhpd(const Xmm& x, const Operand& op) { vunpckhpd(x, x, op); }
vunpckhps(const Xmm & x,const Operand & op)1597 void vunpckhps(const Xmm& x, const Operand& op) { vunpckhps(x, x, op); }
vunpcklpd(const Xmm & x,const Operand & op)1598 void vunpcklpd(const Xmm& x, const Operand& op) { vunpcklpd(x, x, op); }
vunpcklps(const Xmm & x,const Operand & op)1599 void vunpcklps(const Xmm& x, const Operand& op) { vunpcklps(x, x, op); }
1600 #endif
1601 #ifdef XBYAK64
jecxz(std::string label)1602 void jecxz(std::string label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jecxz(const Label & label)1603 void jecxz(const Label& label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jrcxz(std::string label)1604 void jrcxz(std::string label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
jrcxz(const Label & label)1605 void jrcxz(const Label& label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
cdqe()1606 void cdqe() { db(0x48); db(0x98); }
cqo()1607 void cqo() { db(0x48); db(0x99); }
cmpsq()1608 void cmpsq() { db(0x48); db(0xA7); }
popfq()1609 void popfq() { db(0x9D); }
pushfq()1610 void pushfq() { db(0x9C); }
lodsq()1611 void lodsq() { db(0x48); db(0xAD); }
movsq()1612 void movsq() { db(0x48); db(0xA5); }
scasq()1613 void scasq() { db(0x48); db(0xAF); }
stosq()1614 void stosq() { db(0x48); db(0xAB); }
syscall()1615 void syscall() { db(0x0F); db(0x05); }
sysret()1616 void sysret() { db(0x0F); db(0x07); }
cmpxchg16b(const Address & addr)1617 void cmpxchg16b(const Address& addr) { opModM(addr, Reg64(1), 0x0F, 0xC7); }
fxrstor64(const Address & addr)1618 void fxrstor64(const Address& addr) { opModM(addr, Reg64(1), 0x0F, 0xAE); }
movq(const Reg64 & reg,const Mmx & mmx)1619 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)1620 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)1621 void movsxd(const Reg64& reg, const Operand& op) { if (!op.isBit(32)) XBYAK_THROW(ERR_BAD_COMBINATION) opModRM(reg, op, op.isREG(), op.isMEM(), 0x63); }
pextrq(const Operand & op,const Xmm & xmm,uint8 imm)1622 void pextrq(const Operand& op, const Xmm& xmm, uint8 imm) { if (!op.isREG(64) && !op.isMEM()) XBYAK_THROW(ERR_BAD_COMBINATION) opGen(Reg64(xmm.getIdx()), op, 0x16, 0x66, 0, imm, 0x3A); }
pinsrq(const Xmm & xmm,const Operand & op,uint8 imm)1623 void pinsrq(const Xmm& xmm, const Operand& op, uint8 imm) { if (!op.isREG(64) && !op.isMEM()) XBYAK_THROW(ERR_BAD_COMBINATION) opGen(Reg64(xmm.getIdx()), op, 0x22, 0x66, 0, imm, 0x3A); }
vcvtss2si(const Reg64 & r,const Operand & op)1624 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)1625 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)1626 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)1627 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)1628 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)1629 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); }
ldtilecfg(const Address & addr)1630 void ldtilecfg(const Address& addr) { opVex(tmm0, &tmm0, addr, T_0F38 | T_W0, 0x49); }
sttilecfg(const Address & addr)1631 void sttilecfg(const Address& addr) { opVex(tmm0, &tmm0, addr, T_66 | T_0F38 | T_W0, 0x49); }
tileloadd(const Tmm & tm,const Address & addr)1632 void tileloadd(const Tmm& tm, const Address& addr) { opAMX(tm, addr, T_F2 | T_0F38 | T_W0, 0x4b); }
tileloaddt1(const Tmm & tm,const Address & addr)1633 void tileloaddt1(const Tmm& tm, const Address& addr) { opAMX(tm, addr, T_66 | T_0F38 | T_W0, 0x4b); }
tilerelease()1634 void tilerelease() { db(0xc4); db(0xe2); db(0x78); db(0x49); db(0xc0); }
tilestored(const Address & addr,const Tmm & tm)1635 void tilestored(const Address& addr, const Tmm& tm) { opVex(tm, &tmm0, addr, T_F3 | T_0F38 | T_W0, 0x4b); }
tilezero(const Tmm & Tmm)1636 void tilezero(const Tmm& Tmm) { opVex(Tmm, &tmm0, tmm0, T_F2 | T_0F38 | T_W0, 0x49); }
tdpbssd(const Tmm & x1,const Tmm & x2,const Tmm & x3)1637 void tdpbssd(const Tmm& x1, const Tmm& x2, const Tmm& x3) { opVex(x1, &x3, x2, T_F2 | T_0F38 | T_W0, 0x5e); }
tdpbsud(const Tmm & x1,const Tmm & x2,const Tmm & x3)1638 void tdpbsud(const Tmm& x1, const Tmm& x2, const Tmm& x3) { opVex(x1, &x3, x2, T_F3 | T_0F38 | T_W0, 0x5e); }
tdpbusd(const Tmm & x1,const Tmm & x2,const Tmm & x3)1639 void tdpbusd(const Tmm& x1, const Tmm& x2, const Tmm& x3) { opVex(x1, &x3, x2, T_66 | T_0F38 | T_W0, 0x5e); }
tdpbuud(const Tmm & x1,const Tmm & x2,const Tmm & x3)1640 void tdpbuud(const Tmm& x1, const Tmm& x2, const Tmm& x3) { opVex(x1, &x3, x2, T_0F38 | T_W0, 0x5e); }
tdpbf16ps(const Tmm & x1,const Tmm & x2,const Tmm & x3)1641 void tdpbf16ps(const Tmm& x1, const Tmm& x2, const Tmm& x3) { opVex(x1, &x3, x2, T_F3 | T_0F38 | T_W0, 0x5c); }
1642 #else
jcxz(std::string label)1643 void jcxz(std::string label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jcxz(const Label & label)1644 void jcxz(const Label& label) { db(0x67); opJmp(label, T_SHORT, 0xe3, 0, 0); }
jecxz(std::string label)1645 void jecxz(std::string label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
jecxz(const Label & label)1646 void jecxz(const Label& label) { opJmp(label, T_SHORT, 0xe3, 0, 0); }
aaa()1647 void aaa() { db(0x37); }
aad()1648 void aad() { db(0xD5); db(0x0A); }
aam()1649 void aam() { db(0xD4); db(0x0A); }
aas()1650 void aas() { db(0x3F); }
daa()1651 void daa() { db(0x27); }
das()1652 void das() { db(0x2F); }
into()1653 void into() { db(0xCE); }
popad()1654 void popad() { db(0x61); }
popfd()1655 void popfd() { db(0x9D); }
pusha()1656 void pusha() { db(0x60); }
pushad()1657 void pushad() { db(0x60); }
pushfd()1658 void pushfd() { db(0x9C); }
popa()1659 void popa() { db(0x61); }
lds(const Reg & reg,const Address & addr)1660 void lds(const Reg& reg, const Address& addr) { opLoadSeg(addr, reg, 0xC5, 0x100); }
les(const Reg & reg,const Address & addr)1661 void les(const Reg& reg, const Address& addr) { opLoadSeg(addr, reg, 0xC4, 0x100); }
1662 #endif
1663 #ifndef XBYAK_NO_OP_NAMES
and(const Operand & op1,const Operand & op2)1664 void and(const Operand& op1, const Operand& op2) { and_(op1, op2); }
and(const Operand & op,uint32 imm)1665 void and(const Operand& op, uint32 imm) { and_(op, imm); }
or(const Operand & op1,const Operand & op2)1666 void or(const Operand& op1, const Operand& op2) { or_(op1, op2); }
or(const Operand & op,uint32 imm)1667 void or(const Operand& op, uint32 imm) { or_(op, imm); }
xor(const Operand & op1,const Operand & op2)1668 void xor(const Operand& op1, const Operand& op2) { xor_(op1, op2); }
xor(const Operand & op,uint32 imm)1669 void xor(const Operand& op, uint32 imm) { xor_(op, imm); }
not(const Operand & op)1670 void not(const Operand& op) { not_(op); }
1671 #endif
1672 #ifndef XBYAK_DISABLE_AVX512
kaddb(const Opmask & r1,const Opmask & r2,const Opmask & r3)1673 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)1674 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)1675 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)1676 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)1677 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)1678 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)1679 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)1680 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)1681 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)1682 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)1683 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)1684 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)1685 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)1686 void kmovb(const Opmask& k, const Operand& op) { if (!op.isMEM() && !op.isOPMASK()) XBYAK_THROW(ERR_BAD_COMBINATION) opVex(k, 0, op, T_L0 | T_0F | T_66 | T_W0, 0x90); }
kmovb(const Opmask & k,const Reg32 & r)1687 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)1688 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)1689 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)1690 void kmovd(const Opmask& k, const Operand& op) { if (!op.isMEM() && !op.isOPMASK()) XBYAK_THROW(ERR_BAD_COMBINATION) opVex(k, 0, op, T_L0 | T_0F | T_66 | T_W1, 0x90); }
kmovd(const Opmask & k,const Reg32 & r)1691 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)1692 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)1693 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)1694 void kmovq(const Opmask& k, const Operand& op) { if (!op.isMEM() && !op.isOPMASK()) XBYAK_THROW(ERR_BAD_COMBINATION) opVex(k, 0, op, T_L0 | T_0F | T_W1, 0x90); }
kmovw(const Address & addr,const Opmask & k)1695 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)1696 void kmovw(const Opmask& k, const Operand& op) { if (!op.isMEM() && !op.isOPMASK()) XBYAK_THROW(ERR_BAD_COMBINATION) opVex(k, 0, op, T_L0 | T_0F | T_W0, 0x90); }
kmovw(const Opmask & k,const Reg32 & r)1697 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)1698 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)1699 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)1700 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)1701 void knotq(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W1, 0x44); }
knotw(const Opmask & r1,const Opmask & r2)1702 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)1703 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)1704 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)1705 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)1706 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)1707 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)1708 void kortestq(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W1, 0x98); }
kortestw(const Opmask & r1,const Opmask & r2)1709 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)1710 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)1711 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)1712 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)1713 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)1714 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)1715 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)1716 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)1717 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)1718 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)1719 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)1720 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)1721 void ktestq(const Opmask& r1, const Opmask& r2) { opVex(r1, 0, r2, T_0F | T_W1, 0x99); }
ktestw(const Opmask & r1,const Opmask & r2)1722 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)1723 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)1724 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)1725 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)1726 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)1727 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)1728 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)1729 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)1730 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)1731 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)1732 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)1733 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)1734 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)1735 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)1736 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)1737 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)1738 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)1739 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)1740 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)1741 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)1742 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)1743 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)1744 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)1745 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)1746 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)1747 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)1748 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)1749 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)1750 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)1751 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)1752 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 | T_B64, 0xC2, imm); }
vcmpps(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1753 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 | T_B32, 0xC2, imm); }
vcmpsd(const Opmask & k,const Xmm & x,const Operand & op,uint8 imm)1754 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)1755 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)1756 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)1757 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)1758 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)1759 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); }
vcvtne2ps2bf16(const Xmm & x1,const Xmm & x2,const Operand & op)1760 void vcvtne2ps2bf16(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_F2 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x72); }
vcvtneps2bf16(const Xmm & x,const Operand & op)1761 void vcvtneps2bf16(const Xmm& x, const Operand& op) { opCvt2(x, op, T_F3 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x72); }
vcvtpd2qq(const Xmm & x,const Operand & op)1762 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)1763 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)1764 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)1765 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)1766 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)1767 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)1768 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)1769 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)1770 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)1771 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)1772 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)1773 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)1774 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)1775 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)1776 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)1777 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)1778 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)1779 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)1780 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)1781 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)1782 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)1783 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)1784 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)1785 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)1786 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); }
vdpbf16ps(const Xmm & x1,const Xmm & x2,const Operand & op)1787 void vdpbf16ps(const Xmm& x1, const Xmm& x2, const Operand& op) { opAVX_X_X_XM(x1, x2, op, T_F3 | T_0F38 | T_EW0 | T_YMM | T_SAE_Z | T_MUST_EVEX | T_B32, 0x52); }
vexp2pd(const Zmm & z,const Operand & op)1788 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)1789 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)1790 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)1791 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)1792 void vextractf32x4(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) XBYAK_THROW(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)1793 void vextractf32x8(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1794 void vextractf64x2(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) XBYAK_THROW(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)1795 void vextractf64x4(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1796 void vextracti32x4(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) XBYAK_THROW(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)1797 void vextracti32x8(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1798 void vextracti64x2(const Operand& op, const Ymm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::XMM)) XBYAK_THROW(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)1799 void vextracti64x4(const Operand& op, const Zmm& r, uint8 imm) { if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1800 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)1801 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)1802 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)1803 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)1804 void vfpclasspd(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isBit(128|256|512)) XBYAK_THROW(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)1805 void vfpclassps(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isBit(128|256|512)) XBYAK_THROW(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)1806 void vfpclasssd(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isXMEM()) XBYAK_THROW(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)1807 void vfpclassss(const Opmask& k, const Operand& op, uint8 imm) { if (!op.isXMEM()) XBYAK_THROW(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)1808 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)1809 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)1810 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)1811 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)1812 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)1813 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)1814 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)1815 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)1816 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)1817 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)1818 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)1819 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)1820 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)1821 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)1822 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)1823 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)1824 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)1825 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)1826 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)1827 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)1828 void vinsertf32x4(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) XBYAK_THROW(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)1829 void vinsertf32x8(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1830 void vinsertf64x2(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) XBYAK_THROW(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)1831 void vinsertf64x4(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1832 void vinserti32x4(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) XBYAK_THROW(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)1833 void vinserti32x8(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1834 void vinserti64x2(const Ymm& r1, const Ymm& r2, const Operand& op, uint8 imm) {if (!(r1.getKind() == r2.getKind() && op.is(Operand::MEM | Operand::XMM))) XBYAK_THROW(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)1835 void vinserti64x4(const Zmm& r1, const Zmm& r2, const Operand& op, uint8 imm) {if (!op.is(Operand::MEM | Operand::YMM)) XBYAK_THROW(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)1836 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)1837 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)1838 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)1839 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)1840 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)1841 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)1842 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)1843 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)1844 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)1845 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)1846 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)1847 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); }
vp2intersectd(const Opmask & k,const Xmm & x,const Operand & op)1848 void vp2intersectd(const Opmask& k, const Xmm& x, const Operand& op) { if (k.getOpmaskIdx() != 0) XBYAK_THROW(ERR_OPMASK_IS_ALREADY_SET) opAVX_K_X_XM(k, x, op, T_F2 | T_0F38 | T_YMM | T_EVEX | T_EW0 | T_B32, 0x68); }
vp2intersectq(const Opmask & k,const Xmm & x,const Operand & op)1849 void vp2intersectq(const Opmask& k, const Xmm& x, const Operand& op) { if (k.getOpmaskIdx() != 0) XBYAK_THROW(ERR_OPMASK_IS_ALREADY_SET) opAVX_K_X_XM(k, x, op, T_F2 | T_0F38 | T_YMM | T_EVEX | T_EW1 | T_B64, 0x68); }
vp4dpwssd(const Zmm & z1,const Zmm & z2,const Address & addr)1850 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)1851 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)1852 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)1853 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)1854 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)1855 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)1856 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)1857 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)1858 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)1859 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)1860 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)1861 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)1862 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)1863 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)1864 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)1865 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)1866 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)1867 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)1868 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)1869 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)1870 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)1871 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)1872 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)1873 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)1874 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)1875 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)1876 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)1877 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)1878 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)1879 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)1880 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)1881 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)1882 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)1883 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)1884 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)1885 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)1886 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)1887 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)1888 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)1889 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)1890 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)1891 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)1892 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)1893 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)1894 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)1895 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)1896 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)1897 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)1898 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)1899 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)1900 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)1901 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)1902 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)1903 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)1904 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)1905 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)1906 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)1907 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)1908 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)1909 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)1910 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)1911 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)1912 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)1913 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)1914 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)1915 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)1916 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)1917 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)1918 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)1919 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)1920 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)1921 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)1922 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)1923 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)1924 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)1925 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)1926 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)1927 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)1928 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)1929 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)1930 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)1931 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)1932 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)1933 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)1934 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)1935 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)1936 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)1937 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)1938 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)1939 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)1940 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)1941 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)1942 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)1943 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)1944 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)1945 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)1946 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)1947 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)1948 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)1949 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)1950 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)1951 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)1952 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)1953 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)1954 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)1955 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)1956 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)1957 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)1958 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)1959 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)1960 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)1961 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)1962 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)1963 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)1964 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)1965 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)1966 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)1967 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)1968 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)1969 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)1970 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)1971 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)1972 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)1973 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)1974 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)1975 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)1976 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)1977 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)1978 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)1979 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)1980 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)1981 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)1982 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)1983 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)1984 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)1985 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)1986 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)1987 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)1988 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)1989 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)1990 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)1991 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)1992 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)1993 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)1994 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)1995 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)1996 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)1997 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)1998 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)1999 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)2000 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)2001 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)2002 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)2003 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)2004 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)2005 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)2006 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)2007 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)2008 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)2009 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)2010 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)2011 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)2012 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)2013 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)2014 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)2015 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)2016 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)2017 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)2018 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)2019 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)2020 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)2021 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)2022 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)2023 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)2024 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)2025 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)2026 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)2027 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)2028 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)2029 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)2030 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)2031 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)2032 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)2033 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)2034 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)2035 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)2036 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)2037 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)2038 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)2039 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)2040 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)2041 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)2042 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)2043 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)2044 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); }
2045 #ifdef XBYAK64
kmovq(const Opmask & k,const Reg64 & r)2046 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)2047 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)2048 void vpbroadcastq(const Xmm& x, const Reg64& r) { opVex(x, 0, r, T_66 | T_0F38 | T_EW1 | T_YMM | T_MUST_EVEX, 0x7C); }
2049 #endif
2050 #endif
2051