本文整理汇总了C++中X64Assembler::emitM方法的典型用法代码示例。如果您正苦于以下问题:C++ X64Assembler::emitM方法的具体用法?C++ X64Assembler::emitM怎么用?C++ X64Assembler::emitM使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类X64Assembler
的用法示例。
在下文中一共展示了X64Assembler::emitM方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: testEmitMethods
//.........这里部分代码省略.........
}
}
if (supported_AM[i] & MASK_IRR) {
printf(" Address mode: IRR\n");
e.emitIRR(op, rsi, rax, -128);
e.emitIRR(op, rax, rdi, -128);
e.emitIRR(op, rbp, rsp, 127);
e.emitIRR(op, rsp, rbp, 0xF1);
e.emitIRR(op, rsp, rbp, 1);
e.emitIRR(op, r14, rax, -128);
e.emitIRR(op, r8, rdi, -128);
e.emitIRR(op, r13, rsp, 127);
e.emitIRR(op, r12, rbp, 0xF1);
e.emitIRR(op, r12, rbp, 1);
e.emitIRR(op, rsi, r8, -128);
e.emitIRR(op, rax, r15, -128);
e.emitIRR(op, rbp, r12, 127);
e.emitIRR(op, rsp, r13, 0xF1);
e.emitIRR(op, rsp, r13, 1);
e.emitIRR(op, r14, r8, -128);
e.emitIRR(op, r8, r15, -128);
e.emitIRR(op, r13, r12, 127);
e.emitIRR(op, r12, r13, 0xF1);
e.emitIRR(op, r12, r13, 1);
e.emitIRR(op, rax, rax, 1);
e.emitIRR(op, rax, r8, 1);
e.emitIRR(op, r8, rax, 1);
e.emitIRR(op, r8, r8, 1);
}
if (supported_AM[i] & MASK_M) {
printf(" Address mode: M\n");
e.emitM(op, rsi, rdi, sz::word, -128);
e.emitM(op, rbp, noreg, sz::dword, 127);
e.emitM(op, noreg, rbp, sz::byte, 127);
e.emitM(op, rsp, rbp, sz::qword, 0xF1);
e.emitM(op, rsi, r15, sz::word, -128);
e.emitM(op, rbp, noreg, sz::dword, 127);
e.emitM(op, noreg, r13, sz::byte, 127);
e.emitM(op, rsp, r13, sz::qword, 0xF1);
e.emitM(op, r14, rdi, sz::word, -128);
e.emitM(op, r13, noreg, sz::dword, 127);
e.emitM(op, noreg, rbp, sz::byte, 127);
e.emitM(op, r12, rbp, sz::qword, 0xF1);
e.emitM(op, r14, r15, sz::word, -128);
e.emitM(op, r13, noreg, sz::dword, 127);
e.emitM(op, noreg, r13, sz::byte, 127);
e.emitM(op, r12, r13, sz::qword, 0xF1);
// Providing only an immediate with no base register and no index
// register produces the RIP relative form
e.emitM(op, noreg, noreg, sz::byte, 0xF1F1);
}
if (supported_AM[i] & MASK_RM) {
printf(" Address mode: RM\n");
e.emitRM(op, rsi, rdi, sz::word, -128, rax);
e.emitRM(op, rbp, noreg, sz::dword, 127, rcx);
e.emitRM(op, noreg, rbp, sz::byte, 127, rcx);
e.emitRM(op, rsp, rbp, sz::qword, 0xF1, rbp);
e.emitRM(op, noreg, noreg, sz::byte, 0xF1F1, rsp);
e.emitRM(op, rsi, rdi, sz::word, -128, r8);
e.emitRM(op, rbp, noreg, sz::dword, 127, r9);
e.emitRM(op, noreg, rbp, sz::byte, 127, r9);
e.emitRM(op, rsp, rbp, sz::qword, 0xF1, r13);
e.emitRM(op, noreg, noreg, sz::byte, 0xF1F1, r12);