From 593dd559fc9c91e7cd143d3fd5831eadd0ce7453 Mon Sep 17 00:00:00 2001 From: mtabachenko Date: Fri, 19 Apr 2013 09:49:15 +0000 Subject: [PATCH] JIT: - fix set CPU mode in MSR instruction; (fix FeOS - http://feos.mtheall.com/ maybe others); --- desmume/src/arm_jit.cpp | 25 +++++++++++++++++++------ desmume/src/commandline.cpp | 2 +- 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/desmume/src/arm_jit.cpp b/desmume/src/arm_jit.cpp index e7bc73a8d..2d66c57a8 100644 --- a/desmume/src/arm_jit.cpp +++ b/desmume/src/arm_jit.cpp @@ -51,9 +51,27 @@ using namespace AsmJit; #if (LOG_JIT_LEVEL > 0) #define LOG_JIT 1 #define JIT_COMMENT(...) c.comment(__VA_ARGS__) +#define printJIT(buf, val) { \ + JIT_COMMENT("printJIT(\""##buf"\", val);"); \ + GpVar txt = c.newGpVar(kX86VarTypeGpz); \ + GpVar data = c.newGpVar(kX86VarTypeGpz); \ + GpVar io = c.newGpVar(kX86VarTypeGpd); \ + c.lea(io, dword_ptr_abs(stdout)); \ + c.lea(txt, dword_ptr_abs(&buf)); \ + c.mov(data, *(GpVar*)&val); \ + X86CompilerFuncCall* prn = c.call((uintptr_t)fprintf); \ + prn->setPrototype(ASMJIT_CALL_CONV, FuncBuilder3()); \ + prn->setArgument(0, io); \ + prn->setArgument(1, txt); \ + prn->setArgument(2, data); \ + X86CompilerFuncCall* prn_flush = c.call((uintptr_t)fflush); \ + prn_flush->setPrototype(ASMJIT_CALL_CONV, FuncBuilder1()); \ + prn_flush->setArgument(0, io); \ +} #else #define LOG_JIT 0 #define JIT_COMMENT(...) +#define printJIT(buf, val) #endif #ifdef MAPPED_JIT_FUNCS @@ -1351,6 +1369,7 @@ static int OP_MRS_SPSR(const u32 i) #define OP_MSR_(reg, args, sw) \ GpVar operand = c.newGpVar(kX86VarTypeGpd); \ args; \ + c.mov(operand, rhs); \ switch (((i>>16) & 0xF)) \ { \ case 0x1: /* bit 16 */ \ @@ -1370,7 +1389,6 @@ static int OP_MRS_SPSR(const u32 i) ctx->setArgument(0, bb_cpu); \ ctx->setArgument(1, mode); \ } \ - c.mov(operand, rhs); \ Mem xPSR_memB = cpu_ptr_byte(reg, 0); \ c.mov(xPSR_memB, operand.r8Lo()); \ changeCPSR; \ @@ -1385,7 +1403,6 @@ static int OP_MRS_SPSR(const u32 i) c.and_(mode, 0x1F); \ c.cmp(mode, USR); \ c.je(__skip); \ - c.mov(operand, rhs); \ Mem xPSR_memB = cpu_ptr_byte(reg, 1); \ c.shr(operand, 8); \ c.mov(xPSR_memB, operand.r8Lo()); \ @@ -1401,7 +1418,6 @@ static int OP_MRS_SPSR(const u32 i) c.and_(mode, 0x1F); \ c.cmp(mode, USR); \ c.je(__skip); \ - c.mov(operand, rhs); \ Mem xPSR_memB = cpu_ptr_byte(reg, 2); \ c.shr(operand, 16); \ c.mov(xPSR_memB, operand.r8Lo()); \ @@ -1411,7 +1427,6 @@ static int OP_MRS_SPSR(const u32 i) return 1; \ case 0x8: /* bit 19 */ \ { \ - c.mov(operand, rhs); \ Mem xPSR_memB = cpu_ptr_byte(reg, 3); \ c.shr(operand, 24); \ c.mov(xPSR_memB, operand.r8Lo()); \ @@ -1449,7 +1464,6 @@ static int OP_MRS_SPSR(const u32 i) ctx->setArgument(1, mode); \ } \ /* cpu->CPSR.val = (cpu->CPSR.val & ~byte_mask) | (operand & byte_mask); */ \ - c.mov(operand, rhs); \ c.mov(xPSR, xPSR_mem); \ c.and_(operand, byte_mask); \ c.and_(xPSR, ~byte_mask); \ @@ -1458,7 +1472,6 @@ static int OP_MRS_SPSR(const u32 i) c.jmp(__done); \ /* mode == USR */ \ c.bind(__USR); \ - c.mov(operand, rhs); \ c.mov(xPSR, xPSR_mem); \ c.and_(operand, byte_mask_USR); \ c.and_(xPSR, ~byte_mask_USR); \ diff --git a/desmume/src/commandline.cpp b/desmume/src/commandline.cpp index fcdb88fe7..426dd7817 100644 --- a/desmume/src/commandline.cpp +++ b/desmume/src/commandline.cpp @@ -251,7 +251,7 @@ bool CommandLine::validate() if (_cpu_mode < -1 || _cpu_mode > 1) { g_printerr("Invalid cpu mode emulation (0 - interpreter, 1 - dynarec)\n"); } - if (_jit_size < 1 || _jit_size > 100) { + if (_cpu_mode != -1 && (_jit_size < 1 || _jit_size > 100)) { g_printerr("Invalid jit block size [1..100]. set to 100\n"); } #endif