|
@@ -1083,31 +1083,6 @@ push:
|
|
|
case 0xd2 ... 0xd3: /* Grp2 */
|
|
|
src.val = _regs[VCPU_REGS_RCX];
|
|
|
goto grp2;
|
|
|
- case 0xe8: /* call (near) */ {
|
|
|
- long int rel;
|
|
|
- switch (op_bytes) {
|
|
|
- case 2:
|
|
|
- rel = insn_fetch(s16, 2, _eip);
|
|
|
- break;
|
|
|
- case 4:
|
|
|
- rel = insn_fetch(s32, 4, _eip);
|
|
|
- break;
|
|
|
- case 8:
|
|
|
- rel = insn_fetch(s64, 8, _eip);
|
|
|
- break;
|
|
|
- default:
|
|
|
- DPRINTF("Call: Invalid op_bytes\n");
|
|
|
- goto cannot_emulate;
|
|
|
- }
|
|
|
- src.val = (unsigned long) _eip;
|
|
|
- JMP_REL(rel);
|
|
|
- goto push;
|
|
|
- }
|
|
|
- case 0xe9: /* jmp rel */
|
|
|
- case 0xeb: /* jmp rel short */
|
|
|
- JMP_REL(src.val);
|
|
|
- no_wb = 1; /* Disable writeback. */
|
|
|
- break;
|
|
|
case 0xf6 ... 0xf7: /* Grp3 */
|
|
|
switch (modrm_reg) {
|
|
|
case 0 ... 1: /* test */
|
|
@@ -1350,6 +1325,32 @@ special_insn:
|
|
|
case 0xae ... 0xaf: /* scas */
|
|
|
DPRINTF("Urk! I don't handle SCAS.\n");
|
|
|
goto cannot_emulate;
|
|
|
+ case 0xe8: /* call (near) */ {
|
|
|
+ long int rel;
|
|
|
+ switch (op_bytes) {
|
|
|
+ case 2:
|
|
|
+ rel = insn_fetch(s16, 2, _eip);
|
|
|
+ break;
|
|
|
+ case 4:
|
|
|
+ rel = insn_fetch(s32, 4, _eip);
|
|
|
+ break;
|
|
|
+ case 8:
|
|
|
+ rel = insn_fetch(s64, 8, _eip);
|
|
|
+ break;
|
|
|
+ default:
|
|
|
+ DPRINTF("Call: Invalid op_bytes\n");
|
|
|
+ goto cannot_emulate;
|
|
|
+ }
|
|
|
+ src.val = (unsigned long) _eip;
|
|
|
+ JMP_REL(rel);
|
|
|
+ goto push;
|
|
|
+ }
|
|
|
+ case 0xe9: /* jmp rel */
|
|
|
+ case 0xeb: /* jmp rel short */
|
|
|
+ JMP_REL(src.val);
|
|
|
+ no_wb = 1; /* Disable writeback. */
|
|
|
+ break;
|
|
|
+
|
|
|
|
|
|
}
|
|
|
goto writeback;
|