From bbaa01af79cda0f08e723873500805a16b8c6fa5 Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Thu, 22 Feb 2024 11:15:02 +0100 Subject: [INTERPRETER] Added CB opcode --- src/emu/x64run.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'src') diff --git a/src/emu/x64run.c b/src/emu/x64run.c index c51d3566..068dc007 100644 --- a/src/emu/x64run.c +++ b/src/emu/x64run.c @@ -1401,6 +1401,18 @@ x64emurun: R_RBP = rex.is32bits?Pop32(emu):Pop64(emu); break; + case 0xCB: /* FAR RET */ + if(rex.is32bits) { + addr = Pop32(emu); + emu->segs[_CS] = Pop32(emu); // no check, no use.... + } else { + addr = Pop64(emu); + emu->segs[_CS] = Pop64(emu); // no check, no use.... + } + emu->segs_serial[_CS] = 0; + // need to check status of CS register! + STEP2; + break; case 0xCC: /* INT 3 */ #ifndef TEST_INTERPRETER x64Int3(emu, &addr); -- cgit 1.4.1