diff --git a/DevTools/UserspaceEmulator/SoftCPU.cpp b/DevTools/UserspaceEmulator/SoftCPU.cpp index 5a187d271c..1c6c89c578 100644 --- a/DevTools/UserspaceEmulator/SoftCPU.cpp +++ b/DevTools/UserspaceEmulator/SoftCPU.cpp @@ -587,9 +587,20 @@ void SoftCPU::JMP_imm16(const X86::Instruction&) { TODO(); } void SoftCPU::JMP_imm16_imm16(const X86::Instruction&) { TODO(); } void SoftCPU::JMP_imm16_imm32(const X86::Instruction&) { TODO(); } void SoftCPU::JMP_imm32(const X86::Instruction&) { TODO(); } -void SoftCPU::JMP_short_imm8(const X86::Instruction&) { TODO(); } + +void SoftCPU::JMP_short_imm8(const X86::Instruction& insn) +{ + set_eip(eip() + (i8)insn.imm8()); +} + void SoftCPU::Jcc_NEAR_imm(const X86::Instruction&) { TODO(); } -void SoftCPU::Jcc_imm8(const X86::Instruction&) { TODO(); } + +void SoftCPU::Jcc_imm8(const X86::Instruction& insn) +{ + if (evaluate_condition(insn.cc())) + set_eip(eip() + (i8)insn.imm8()); +} + void SoftCPU::LAHF(const X86::Instruction&) { TODO(); } void SoftCPU::LAR_reg16_RM16(const X86::Instruction&) { TODO(); } void SoftCPU::LAR_reg32_RM32(const X86::Instruction&) { TODO(); }