Lines Matching defs:ModRM

127 #define RMExt       (4<<15)     /* Opcode extension in ModRM r/m if mod == 3 */
132 /* Generic ModRM decode. */
133 #define ModRM (1<<19)
177 #define IncSP ((u64)1 << 54) /* SP is incremented before ModRM calc */
1005 * Given the 'reg' portion of a ModRM byte, and a register block, return a
1278 if (!(ctxt->d & ModRM))
4417 #define G(_f, _g) { .flags = ((_f) | Group | ModRM), .u.group = (_g) }
4418 #define GD(_f, _g) { .flags = ((_f) | GroupDual | ModRM), .u.gdual = (_g) }
4419 #define ID(_f, _i) { .flags = ((_f) | InstrDual | ModRM), .u.idual = (_i) }
4421 #define E(_f, _e) { .flags = ((_f) | Escape | ModRM), .u.esc = (_e) }
4438 #define F6ALU(_f, _e) F2bv((_f) | DstMem | SrcReg | ModRM, _e), \
4439 F2bv(((_f) | DstReg | SrcMem | ModRM) & ~Lock, _e), \
4493 F(DstMem | ModRM, em_rol),
4494 F(DstMem | ModRM, em_ror),
4495 F(DstMem | ModRM, em_rcl),
4496 F(DstMem | ModRM, em_rcr),
4497 F(DstMem | ModRM, em_shl),
4498 F(DstMem | ModRM, em_shr),
4499 F(DstMem | ModRM, em_shl),
4500 F(DstMem | ModRM, em_sar),
4569 N, N, N, II(DstMem | ModRM | Op3264 | EmulateOnUD, em_rdpid, rdpid),
4590 I(ModRM | Aligned16, em_fxsave),
4591 I(ModRM | Aligned16, em_fxrstor),
4685 I(DstMem | SrcReg | ModRM | No16 | Mov, em_mov), N
4689 N, I(DstReg | SrcMem32 | ModRM | Mov, em_movsxd)
4726 N, MD(ModRM, &mode_dual_63),
4730 I(DstReg | SrcMem | ModRM | Src2Imm, em_imul_3op),
4732 I(DstReg | SrcMem | ModRM | Src2ImmByte, em_imul_3op),
4742 F2bv(DstMem | SrcReg | ModRM | NoWrite, em_test),
4743 I2bv(DstMem | SrcReg | ModRM | Lock | PageTable, em_xchg),
4745 I2bv(DstMem | SrcReg | ModRM | Mov | PageTable, em_mov),
4746 I2bv(DstReg | SrcMem | ModRM | Mov, em_mov),
4747 I(DstMem | SrcNone | ModRM | Mov | PageTable, em_mov_rm_sreg),
4748 D(ModRM | SrcMem | NoAccess | DstReg),
4749 I(ImplicitOps | SrcMem16 | ModRM, em_mov_sreg_rm),
4777 I(DstReg | SrcMemFAddr | ModRM | No64 | Src2ES, em_lseg),
4778 I(DstReg | SrcMemFAddr | ModRM | No64 | Src2DS, em_lseg),
4822 N, D(ImplicitOps | ModRM | SrcMem | NoAccess), N, N,
4824 GP(ModRM | DstReg | SrcMem | Mov | Sse, &pfx_0f_10_0f_11),
4825 GP(ModRM | DstMem | SrcReg | Mov | Sse, &pfx_0f_10_0f_11),
4827 D(ImplicitOps | ModRM | SrcMem | NoAccess), /* 4 * prefetch + 4 * reserved NOP */
4828 D(ImplicitOps | ModRM | SrcMem | NoAccess), N, N,
4829 D(ImplicitOps | ModRM | SrcMem | NoAccess), /* 8 * reserved NOP */
4830 D(ImplicitOps | ModRM | SrcMem | NoAccess), /* 8 * reserved NOP */
4831 D(ImplicitOps | ModRM | SrcMem | NoAccess), /* 8 * reserved NOP */
4832 D(ImplicitOps | ModRM | SrcMem | NoAccess), /* NOP + 7 * reserved NOP */
4834 DIP(ModRM | DstMem | Priv | Op3264 | NoMod, cr_read, check_cr_access),
4835 DIP(ModRM | DstMem | Priv | Op3264 | NoMod, dr_read, check_dr_read),
4836 IIP(ModRM | SrcMem | Priv | Op3264 | NoMod, em_cr_write, cr_write,
4838 IIP(ModRM | SrcMem | Priv | Op3264 | NoMod, em_dr_write, dr_write,
4841 GP(ModRM | DstReg | SrcMem | Mov | Sse, &pfx_0f_28_0f_29),
4842 GP(ModRM | DstMem | SrcReg | Mov | Sse, &pfx_0f_28_0f_29),
4843 N, GP(ModRM | DstMem | SrcReg | Mov | Sse, &pfx_0f_2b),
4855 X16(D(DstReg | SrcMem | ModRM)),
4862 N, N, N, GP(SrcMem | DstReg | ModRM | Mov, &pfx_0f_6f_0f_7f),
4867 N, N, N, GP(SrcReg | DstMem | ModRM | Mov, &pfx_0f_6f_0f_7f),
4871 X16(D(ByteOp | DstMem | SrcNone | ModRM| Mov)),
4875 F(DstMem | SrcReg | ModRM | BitOp | NoWrite, em_bt),
4876 F(DstMem | SrcReg | Src2ImmByte | ModRM, em_shld),
4877 F(DstMem | SrcReg | Src2CL | ModRM, em_shld), N, N,
4881 F(DstMem | SrcReg | ModRM | BitOp | Lock | PageTable, em_bts),
4882 F(DstMem | SrcReg | Src2ImmByte | ModRM, em_shrd),
4883 F(DstMem | SrcReg | Src2CL | ModRM, em_shrd),
4884 GD(0, &group15), F(DstReg | SrcMem | ModRM, em_imul),
4886 I2bv(DstMem | SrcReg | ModRM | Lock | PageTable | SrcWrite, em_cmpxchg),
4887 I(DstReg | SrcMemFAddr | ModRM | Src2SS, em_lseg),
4888 F(DstMem | SrcReg | ModRM | BitOp | Lock, em_btr),
4889 I(DstReg | SrcMemFAddr | ModRM | Src2FS, em_lseg),
4890 I(DstReg | SrcMemFAddr | ModRM | Src2GS, em_lseg),
4891 D(DstReg | SrcMem8 | ModRM | Mov), D(DstReg | SrcMem16 | ModRM | Mov),
4895 F(DstMem | SrcReg | ModRM | BitOp | Lock | PageTable, em_btc),
4896 I(DstReg | SrcMem | ModRM, em_bsf_c),
4897 I(DstReg | SrcMem | ModRM, em_bsr_c),
4898 D(DstReg | SrcMem8 | ModRM | Mov), D(DstReg | SrcMem16 | ModRM | Mov),
4900 F2bv(DstMem | SrcReg | ModRM | SrcWrite | Lock, em_xadd),
4908 N, N, N, N, N, N, N, GP(SrcReg | DstMem | ModRM | Mov, &pfx_0f_e7),
4940 GP(EmulateOnUD | ModRM, &three_byte_0f_38_f0),
4941 GP(EmulateOnUD | ModRM, &three_byte_0f_38_f1),
5315 if (ctxt->d & ModRM)
5428 /* ModRM and SIB bytes. */
5429 if (ctxt->d & ModRM) {