diff --git a/Source/Core/Core/DSP/Jit/DSPJitRegCache.cpp b/Source/Core/Core/DSP/Jit/DSPJitRegCache.cpp index 162352a063..527f2e1c64 100644 --- a/Source/Core/Core/DSP/Jit/DSPJitRegCache.cpp +++ b/Source/Core/Core/DSP/Jit/DSPJitRegCache.cpp @@ -94,134 +94,135 @@ static void* GetRegisterPointer(size_t reg) #define STATIC_REG_ACCS //#undef STATIC_REG_ACCS -DSPJitRegCache::DSPJitRegCache(DSPEmitter& _emitter) - : emitter(_emitter), temporary(false), merged(false) +DSPJitRegCache::DSPJitRegCache(DSPEmitter& emitter) + : m_emitter(emitter), m_is_temporary(false), m_is_merged(false) { - for (X64CachedReg& xreg : xregs) + for (X64CachedReg& xreg : m_xregs) { xreg.guest_reg = DSP_REG_STATIC; xreg.pushed = false; } - xregs[RAX].guest_reg = DSP_REG_STATIC; // reserved for MUL/DIV - xregs[RDX].guest_reg = DSP_REG_STATIC; // reserved for MUL/DIV - xregs[RCX].guest_reg = DSP_REG_STATIC; // reserved for shifts + m_xregs[RAX].guest_reg = DSP_REG_STATIC; // reserved for MUL/DIV + m_xregs[RDX].guest_reg = DSP_REG_STATIC; // reserved for MUL/DIV + m_xregs[RCX].guest_reg = DSP_REG_STATIC; // reserved for shifts - xregs[RBX].guest_reg = DSP_REG_STATIC; // extended op backing store + m_xregs[RBX].guest_reg = DSP_REG_STATIC; // extended op backing store - xregs[RSP].guest_reg = DSP_REG_STATIC; // stack pointer + m_xregs[RSP].guest_reg = DSP_REG_STATIC; // stack pointer - xregs[RBP].guest_reg = DSP_REG_NONE; // definitely usable in dsplle because - // all external calls are protected + m_xregs[RBP].guest_reg = DSP_REG_NONE; // definitely usable in dsplle because + // all external calls are protected - xregs[RSI].guest_reg = DSP_REG_NONE; - xregs[RDI].guest_reg = DSP_REG_NONE; + m_xregs[RSI].guest_reg = DSP_REG_NONE; + m_xregs[RDI].guest_reg = DSP_REG_NONE; #ifdef STATIC_REG_ACCS - xregs[R8].guest_reg = DSP_REG_STATIC; // acc0 - xregs[R9].guest_reg = DSP_REG_STATIC; // acc1 + m_xregs[R8].guest_reg = DSP_REG_STATIC; // acc0 + m_xregs[R9].guest_reg = DSP_REG_STATIC; // acc1 #else - xregs[R8].guest_reg = DSP_REG_NONE; - xregs[R9].guest_reg = DSP_REG_NONE; + m_xregs[R8].guest_reg = DSP_REG_NONE; + m_xregs[R9].guest_reg = DSP_REG_NONE; #endif - xregs[R10].guest_reg = DSP_REG_NONE; - xregs[R11].guest_reg = DSP_REG_NONE; - xregs[R12].guest_reg = DSP_REG_NONE; - xregs[R13].guest_reg = DSP_REG_NONE; - xregs[R14].guest_reg = DSP_REG_NONE; - xregs[R15].guest_reg = DSP_REG_NONE; + m_xregs[R10].guest_reg = DSP_REG_NONE; + m_xregs[R11].guest_reg = DSP_REG_NONE; + m_xregs[R12].guest_reg = DSP_REG_NONE; + m_xregs[R13].guest_reg = DSP_REG_NONE; + m_xregs[R14].guest_reg = DSP_REG_NONE; + m_xregs[R15].guest_reg = DSP_REG_NONE; - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - regs[i].mem = GetRegisterPointer(i); - regs[i].size = 0; - regs[i].dirty = false; - regs[i].used = false; - regs[i].last_use_ctr = -1; - regs[i].parentReg = DSP_REG_NONE; - regs[i].shift = 0; - regs[i].host_reg = INVALID_REG; - regs[i].loc = M(regs[i].mem); + m_regs[i].mem = GetRegisterPointer(i); + m_regs[i].size = 0; + m_regs[i].dirty = false; + m_regs[i].used = false; + m_regs[i].last_use_ctr = -1; + m_regs[i].parentReg = DSP_REG_NONE; + m_regs[i].shift = 0; + m_regs[i].host_reg = INVALID_REG; + m_regs[i].loc = M(m_regs[i].mem); } for (unsigned int i = 0; i < 32; i++) { - regs[i].size = 2; + m_regs[i].size = 2; } // special composite registers #ifdef STATIC_REG_ACCS - regs[DSP_REG_ACC0_64].host_reg = R8; - regs[DSP_REG_ACC1_64].host_reg = R9; + m_regs[DSP_REG_ACC0_64].host_reg = R8; + m_regs[DSP_REG_ACC1_64].host_reg = R9; #endif for (unsigned int i = 0; i < 2; i++) { - regs[i + DSP_REG_ACC0_64].size = 8; - regs[i + DSP_REG_ACL0].parentReg = i + DSP_REG_ACC0_64; - regs[i + DSP_REG_ACM0].parentReg = i + DSP_REG_ACC0_64; - regs[i + DSP_REG_ACH0].parentReg = i + DSP_REG_ACC0_64; - regs[i + DSP_REG_ACL0].shift = 0; - regs[i + DSP_REG_ACM0].shift = 16; - regs[i + DSP_REG_ACH0].shift = 32; + m_regs[i + DSP_REG_ACC0_64].size = 8; + m_regs[i + DSP_REG_ACL0].parentReg = i + DSP_REG_ACC0_64; + m_regs[i + DSP_REG_ACM0].parentReg = i + DSP_REG_ACC0_64; + m_regs[i + DSP_REG_ACH0].parentReg = i + DSP_REG_ACC0_64; + m_regs[i + DSP_REG_ACL0].shift = 0; + m_regs[i + DSP_REG_ACM0].shift = 16; + m_regs[i + DSP_REG_ACH0].shift = 32; } - regs[DSP_REG_PROD_64].size = 8; - regs[DSP_REG_PRODL].parentReg = DSP_REG_PROD_64; - regs[DSP_REG_PRODM].parentReg = DSP_REG_PROD_64; - regs[DSP_REG_PRODH].parentReg = DSP_REG_PROD_64; - regs[DSP_REG_PRODM2].parentReg = DSP_REG_PROD_64; - regs[DSP_REG_PRODL].shift = 0; - regs[DSP_REG_PRODM].shift = 16; - regs[DSP_REG_PRODH].shift = 32; - regs[DSP_REG_PRODM2].shift = 48; + m_regs[DSP_REG_PROD_64].size = 8; + m_regs[DSP_REG_PRODL].parentReg = DSP_REG_PROD_64; + m_regs[DSP_REG_PRODM].parentReg = DSP_REG_PROD_64; + m_regs[DSP_REG_PRODH].parentReg = DSP_REG_PROD_64; + m_regs[DSP_REG_PRODM2].parentReg = DSP_REG_PROD_64; + m_regs[DSP_REG_PRODL].shift = 0; + m_regs[DSP_REG_PRODM].shift = 16; + m_regs[DSP_REG_PRODH].shift = 32; + m_regs[DSP_REG_PRODM2].shift = 48; for (unsigned int i = 0; i < 2; i++) { - regs[i + DSP_REG_AX0_32].size = 4; - regs[i + DSP_REG_AXL0].parentReg = i + DSP_REG_AX0_32; - regs[i + DSP_REG_AXH0].parentReg = i + DSP_REG_AX0_32; - regs[i + DSP_REG_AXL0].shift = 0; - regs[i + DSP_REG_AXH0].shift = 16; + m_regs[i + DSP_REG_AX0_32].size = 4; + m_regs[i + DSP_REG_AXL0].parentReg = i + DSP_REG_AX0_32; + m_regs[i + DSP_REG_AXH0].parentReg = i + DSP_REG_AX0_32; + m_regs[i + DSP_REG_AXL0].shift = 0; + m_regs[i + DSP_REG_AXH0].shift = 16; } - use_ctr = 0; + m_use_ctr = 0; } DSPJitRegCache::DSPJitRegCache(const DSPJitRegCache& cache) - : regs(cache.regs), xregs(cache.xregs), emitter(cache.emitter), temporary(true), merged(false) + : m_regs(cache.m_regs), m_xregs(cache.m_xregs), m_emitter(cache.m_emitter), + m_is_temporary(true), m_is_merged(false) { } DSPJitRegCache& DSPJitRegCache::operator=(const DSPJitRegCache& cache) { - _assert_msg_(DSPLLE, &emitter == &cache.emitter, "emitter does not match"); - _assert_msg_(DSPLLE, temporary, "register cache not temporary??"); - merged = false; + _assert_msg_(DSPLLE, &m_emitter == &cache.m_emitter, "emitter does not match"); + _assert_msg_(DSPLLE, m_is_temporary, "register cache not temporary??"); + m_is_merged = false; - xregs = cache.xregs; - regs = cache.regs; + m_xregs = cache.m_xregs; + m_regs = cache.m_regs; return *this; } DSPJitRegCache::~DSPJitRegCache() { - _assert_msg_(DSPLLE, !temporary || merged, "temporary cache not merged"); + _assert_msg_(DSPLLE, !m_is_temporary || m_is_merged, "temporary cache not merged"); } void DSPJitRegCache::Drop() { - merged = true; + m_is_merged = true; } void DSPJitRegCache::FlushRegs(DSPJitRegCache& cache, bool emit) { - cache.merged = true; + cache.m_is_merged = true; // drop all guest register not used by cache - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - regs[i].used = false; // used is restored later - if (regs[i].loc.IsSimpleReg() && !cache.regs[i].loc.IsSimpleReg()) + m_regs[i].used = false; // used is restored later + if (m_regs[i].loc.IsSimpleReg() && !cache.m_regs[i].loc.IsSimpleReg()) { MovToMemory(i); } @@ -232,12 +233,12 @@ void DSPJitRegCache::FlushRegs(DSPJitRegCache& cache, bool emit) do { movcnt = 0; - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - X64Reg simple = regs[i].loc.GetSimpleReg(); - X64Reg simple_cache = cache.regs[i].loc.GetSimpleReg(); + X64Reg simple = m_regs[i].loc.GetSimpleReg(); + X64Reg simple_cache = cache.m_regs[i].loc.GetSimpleReg(); - if (simple_cache != simple && xregs[simple_cache].guest_reg == DSP_REG_NONE) + if (simple_cache != simple && m_xregs[simple_cache].guest_reg == DSP_REG_NONE) { MovToHostReg(i, simple_cache, true); movcnt++; @@ -246,70 +247,73 @@ void DSPJitRegCache::FlushRegs(DSPJitRegCache& cache, bool emit) } while (movcnt != 0); // free all host regs that are not used for the same guest reg - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (cache.regs[i].loc.GetSimpleReg() != regs[i].loc.GetSimpleReg() && regs[i].loc.IsSimpleReg()) + const auto reg = m_regs[i]; + const auto cached_reg = cache.m_regs[i]; + + if (cached_reg.loc.GetSimpleReg() != reg.loc.GetSimpleReg() && reg.loc.IsSimpleReg()) { MovToMemory(i); } } // load all guest regs that are in memory and should be in host reg - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (cache.regs[i].loc.IsSimpleReg()) + if (cache.m_regs[i].loc.IsSimpleReg()) { - MovToHostReg(i, cache.regs[i].loc.GetSimpleReg(), true); - RotateHostReg(i, cache.regs[i].shift, true); + MovToHostReg(i, cache.m_regs[i].loc.GetSimpleReg(), true); + RotateHostReg(i, cache.m_regs[i].shift, true); } - else if (cache.regs[i].loc.IsImm()) + else if (cache.m_regs[i].loc.IsImm()) { // TODO: Immediates? } - regs[i].used = cache.regs[i].used; - regs[i].dirty |= cache.regs[i].dirty; - regs[i].last_use_ctr = cache.regs[i].last_use_ctr; + m_regs[i].used = cache.m_regs[i].used; + m_regs[i].dirty |= cache.m_regs[i].dirty; + m_regs[i].last_use_ctr = cache.m_regs[i].last_use_ctr; } // sync the freely used xregs if (!emit) { - for (size_t i = 0; i < xregs.size(); i++) + for (size_t i = 0; i < m_xregs.size(); i++) { - if (cache.xregs[i].guest_reg == DSP_REG_USED && xregs[i].guest_reg == DSP_REG_NONE) + if (cache.m_xregs[i].guest_reg == DSP_REG_USED && m_xregs[i].guest_reg == DSP_REG_NONE) { - xregs[i].guest_reg = DSP_REG_USED; + m_xregs[i].guest_reg = DSP_REG_USED; } - if (cache.xregs[i].guest_reg == DSP_REG_NONE && xregs[i].guest_reg == DSP_REG_USED) + if (cache.m_xregs[i].guest_reg == DSP_REG_NONE && m_xregs[i].guest_reg == DSP_REG_USED) { - xregs[i].guest_reg = DSP_REG_NONE; + m_xregs[i].guest_reg = DSP_REG_NONE; } } } // consistency checks - for (size_t i = 0; i < xregs.size(); i++) + for (size_t i = 0; i < m_xregs.size(); i++) { - _assert_msg_(DSPLLE, xregs[i].guest_reg == cache.xregs[i].guest_reg, + _assert_msg_(DSPLLE, m_xregs[i].guest_reg == cache.m_xregs[i].guest_reg, "cache and current xreg guest_reg mismatch for %u", static_cast(i)); } - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - _assert_msg_(DSPLLE, regs[i].loc.IsImm() == cache.regs[i].loc.IsImm(), + _assert_msg_(DSPLLE, m_regs[i].loc.IsImm() == cache.m_regs[i].loc.IsImm(), "cache and current reg loc mismatch for %i", static_cast(i)); - _assert_msg_(DSPLLE, regs[i].loc.GetSimpleReg() == cache.regs[i].loc.GetSimpleReg(), + _assert_msg_(DSPLLE, m_regs[i].loc.GetSimpleReg() == cache.m_regs[i].loc.GetSimpleReg(), "cache and current reg loc mismatch for %i", static_cast(i)); - _assert_msg_(DSPLLE, regs[i].dirty || !cache.regs[i].dirty, + _assert_msg_(DSPLLE, m_regs[i].dirty || !cache.m_regs[i].dirty, "cache and current reg dirty mismatch for %i", static_cast(i)); - _assert_msg_(DSPLLE, regs[i].used == cache.regs[i].used, + _assert_msg_(DSPLLE, m_regs[i].used == cache.m_regs[i].used, "cache and current reg used mismatch for %i", static_cast(i)); - _assert_msg_(DSPLLE, regs[i].shift == cache.regs[i].shift, + _assert_msg_(DSPLLE, m_regs[i].shift == cache.m_regs[i].shift, "cache and current reg shift mismatch for %i", static_cast(i)); } - use_ctr = cache.use_ctr; + m_use_ctr = cache.m_use_ctr; } void DSPJitRegCache::FlushMemBackedRegs() @@ -318,21 +322,21 @@ void DSPJitRegCache::FlushMemBackedRegs() // this should have the same effect as // merge(DSPJitRegCache(emitter)); - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - _assert_msg_(DSPLLE, !regs[i].used, "register %u still in use", static_cast(i)); + _assert_msg_(DSPLLE, !m_regs[i].used, "register %u still in use", static_cast(i)); - if (regs[i].used) + if (m_regs[i].used) { - emitter.INT3(); + m_emitter.INT3(); } - if (regs[i].host_reg != INVALID_REG) + if (m_regs[i].host_reg != INVALID_REG) { - MovToHostReg(i, regs[i].host_reg, true); + MovToHostReg(i, m_regs[i].host_reg, true); RotateHostReg(i, 0, true); } - else if (regs[i].parentReg == DSP_REG_NONE) + else if (m_regs[i].parentReg == DSP_REG_NONE) { MovToMemory(i); } @@ -343,53 +347,53 @@ void DSPJitRegCache::FlushRegs() { FlushMemBackedRegs(); - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (regs[i].host_reg != INVALID_REG) + if (m_regs[i].host_reg != INVALID_REG) { MovToMemory(i); } - _assert_msg_(DSPLLE, !regs[i].loc.IsSimpleReg(), "register %zu is still a simple reg", i); + _assert_msg_(DSPLLE, !m_regs[i].loc.IsSimpleReg(), "register %zu is still a simple reg", i); } - _assert_msg_(DSPLLE, xregs[RSP].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", RSP); - _assert_msg_(DSPLLE, xregs[RBX].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", RBX); - _assert_msg_(DSPLLE, xregs[RBP].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", RBP); - _assert_msg_(DSPLLE, xregs[RSI].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", RSI); - _assert_msg_(DSPLLE, xregs[RDI].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", RDI); + _assert_msg_(DSPLLE, m_xregs[RSP].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", RSP); + _assert_msg_(DSPLLE, m_xregs[RBX].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", RBX); + _assert_msg_(DSPLLE, m_xregs[RBP].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", RBP); + _assert_msg_(DSPLLE, m_xregs[RSI].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", RSI); + _assert_msg_(DSPLLE, m_xregs[RDI].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", RDI); #ifdef STATIC_REG_ACCS - _assert_msg_(DSPLLE, xregs[R8].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", R8); - _assert_msg_(DSPLLE, xregs[R9].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", R9); + _assert_msg_(DSPLLE, m_xregs[R8].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", R8); + _assert_msg_(DSPLLE, m_xregs[R9].guest_reg == DSP_REG_STATIC, "wrong xreg state for %d", R9); #else - _assert_msg_(DSPLLE, xregs[R8].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R8); - _assert_msg_(DSPLLE, xregs[R9].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R9); + _assert_msg_(DSPLLE, m_xregs[R8].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R8); + _assert_msg_(DSPLLE, m_xregs[R9].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R9); #endif - _assert_msg_(DSPLLE, xregs[R10].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R10); - _assert_msg_(DSPLLE, xregs[R11].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R11); - _assert_msg_(DSPLLE, xregs[R12].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R12); - _assert_msg_(DSPLLE, xregs[R13].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R13); - _assert_msg_(DSPLLE, xregs[R14].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R14); - _assert_msg_(DSPLLE, xregs[R15].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R15); + _assert_msg_(DSPLLE, m_xregs[R10].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R10); + _assert_msg_(DSPLLE, m_xregs[R11].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R11); + _assert_msg_(DSPLLE, m_xregs[R12].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R12); + _assert_msg_(DSPLLE, m_xregs[R13].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R13); + _assert_msg_(DSPLLE, m_xregs[R14].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R14); + _assert_msg_(DSPLLE, m_xregs[R15].guest_reg == DSP_REG_NONE, "wrong xreg state for %d", R15); - use_ctr = 0; + m_use_ctr = 0; } static u64 ebp_store; void DSPJitRegCache::LoadRegs(bool emit) { - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (regs[i].host_reg != INVALID_REG) + if (m_regs[i].host_reg != INVALID_REG) { - MovToHostReg(i, regs[i].host_reg, emit); + MovToHostReg(i, m_regs[i].host_reg, emit); } } if (emit) { - emitter.MOV(64, M(&ebp_store), R(RBP)); + m_emitter.MOV(64, M(&ebp_store), R(RBP)); } } @@ -397,35 +401,35 @@ void DSPJitRegCache::SaveRegs() { FlushRegs(); - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (regs[i].host_reg != INVALID_REG) + if (m_regs[i].host_reg != INVALID_REG) { MovToMemory(i); } - _assert_msg_(DSPLLE, !regs[i].loc.IsSimpleReg(), "register %zu is still a simple reg", i); + _assert_msg_(DSPLLE, !m_regs[i].loc.IsSimpleReg(), "register %zu is still a simple reg", i); } - emitter.MOV(64, R(RBP), M(&ebp_store)); + m_emitter.MOV(64, R(RBP), M(&ebp_store)); } void DSPJitRegCache::PushRegs() { FlushMemBackedRegs(); - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (regs[i].host_reg != INVALID_REG) + if (m_regs[i].host_reg != INVALID_REG) { MovToMemory(i); } - _assert_msg_(DSPLLE, !regs[i].loc.IsSimpleReg(), "register %zu is still a simple reg", i); + _assert_msg_(DSPLLE, !m_regs[i].loc.IsSimpleReg(), "register %zu is still a simple reg", i); } int push_count = 0; - for (X64CachedReg& xreg : xregs) + for (X64CachedReg& xreg : m_xregs) { if (xreg.guest_reg == DSP_REG_USED) push_count++; @@ -434,53 +438,54 @@ void DSPJitRegCache::PushRegs() // hardcoding alignment to 16 bytes if (push_count & 1) { - emitter.SUB(64, R(RSP), Imm32(8)); + m_emitter.SUB(64, R(RSP), Imm32(8)); } - for (size_t i = 0; i < xregs.size(); i++) + for (size_t i = 0; i < m_xregs.size(); i++) { - if (xregs[i].guest_reg == DSP_REG_USED) + if (m_xregs[i].guest_reg == DSP_REG_USED) { - emitter.PUSH(static_cast(i)); - xregs[i].pushed = true; - xregs[i].guest_reg = DSP_REG_NONE; + m_emitter.PUSH(static_cast(i)); + m_xregs[i].pushed = true; + m_xregs[i].guest_reg = DSP_REG_NONE; } - _assert_msg_(DSPLLE, xregs[i].guest_reg == DSP_REG_NONE || xregs[i].guest_reg == DSP_REG_STATIC, + _assert_msg_(DSPLLE, + m_xregs[i].guest_reg == DSP_REG_NONE || m_xregs[i].guest_reg == DSP_REG_STATIC, "register %zu is still used", i); } - emitter.MOV(64, R(RBP), M(&ebp_store)); + m_emitter.MOV(64, R(RBP), M(&ebp_store)); } void DSPJitRegCache::PopRegs() { - emitter.MOV(64, M(&ebp_store), R(RBP)); + m_emitter.MOV(64, M(&ebp_store), R(RBP)); int push_count = 0; - for (int i = static_cast(xregs.size() - 1); i >= 0; i--) + for (int i = static_cast(m_xregs.size() - 1); i >= 0; i--) { - if (xregs[i].pushed) + if (m_xregs[i].pushed) { push_count++; - emitter.POP(static_cast(i)); - xregs[i].pushed = false; - xregs[i].guest_reg = DSP_REG_USED; + m_emitter.POP(static_cast(i)); + m_xregs[i].pushed = false; + m_xregs[i].guest_reg = DSP_REG_USED; } } // hardcoding alignment to 16 bytes if (push_count & 1) { - emitter.ADD(64, R(RSP), Imm32(8)); + m_emitter.ADD(64, R(RSP), Imm32(8)); } - for (size_t i = 0; i < regs.size(); i++) + for (size_t i = 0; i < m_regs.size(); i++) { - if (regs[i].host_reg != INVALID_REG) + if (m_regs[i].host_reg != INVALID_REG) { - MovToHostReg(i, regs[i].host_reg, true); + MovToHostReg(i, m_regs[i].host_reg, true); } } } @@ -492,48 +497,48 @@ X64Reg DSPJitRegCache::MakeABICallSafe(X64Reg reg) return reg; } - size_t rbp_guest = xregs[RBP].guest_reg; - xregs[RBP].guest_reg = DSP_REG_USED; + size_t rbp_guest = m_xregs[RBP].guest_reg; + m_xregs[RBP].guest_reg = DSP_REG_USED; X64Reg safe = FindSpillFreeXReg(); _assert_msg_(DSPLLE, safe != INVALID_REG, "could not find register"); if (safe == INVALID_REG) { - emitter.INT3(); + m_emitter.INT3(); } - xregs[RBP].guest_reg = rbp_guest; - emitter.MOV(64, R(safe), R(reg)); + m_xregs[RBP].guest_reg = rbp_guest; + m_emitter.MOV(64, R(safe), R(reg)); return safe; } void DSPJitRegCache::MovToHostReg(size_t reg, X64Reg host_reg, bool load) { - _assert_msg_(DSPLLE, reg < regs.size(), "bad register name %zu", reg); - _assert_msg_(DSPLLE, regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, - regs[reg].parentReg); - _assert_msg_(DSPLLE, !regs[reg].used, "moving to host reg in use guest reg %zu", reg); - X64Reg old_reg = regs[reg].loc.GetSimpleReg(); + _assert_msg_(DSPLLE, reg < m_regs.size(), "bad register name %zu", reg); + _assert_msg_(DSPLLE, m_regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, + m_regs[reg].parentReg); + _assert_msg_(DSPLLE, !m_regs[reg].used, "moving to host reg in use guest reg %zu", reg); + X64Reg old_reg = m_regs[reg].loc.GetSimpleReg(); if (old_reg == host_reg) { return; } - if (xregs[host_reg].guest_reg != DSP_REG_STATIC) + if (m_xregs[host_reg].guest_reg != DSP_REG_STATIC) { - xregs[host_reg].guest_reg = reg; + m_xregs[host_reg].guest_reg = reg; } if (load) { - switch (regs[reg].size) + switch (m_regs[reg].size) { case 2: - emitter.MOV(16, R(host_reg), regs[reg].loc); + m_emitter.MOV(16, R(host_reg), m_regs[reg].loc); break; case 4: - emitter.MOV(32, R(host_reg), regs[reg].loc); + m_emitter.MOV(32, R(host_reg), m_regs[reg].loc); break; case 8: - emitter.MOV(64, R(host_reg), regs[reg].loc); + m_emitter.MOV(64, R(host_reg), m_regs[reg].loc); break; default: _assert_msg_(DSPLLE, 0, "unsupported memory size"); @@ -541,29 +546,29 @@ void DSPJitRegCache::MovToHostReg(size_t reg, X64Reg host_reg, bool load) } } - regs[reg].loc = R(host_reg); - if (old_reg != INVALID_REG && xregs[old_reg].guest_reg != DSP_REG_STATIC) + m_regs[reg].loc = R(host_reg); + if (old_reg != INVALID_REG && m_xregs[old_reg].guest_reg != DSP_REG_STATIC) { - xregs[old_reg].guest_reg = DSP_REG_NONE; + m_xregs[old_reg].guest_reg = DSP_REG_NONE; } } void DSPJitRegCache::MovToHostReg(size_t reg, bool load) { - _assert_msg_(DSPLLE, reg < regs.size(), "bad register name %zu", reg); - _assert_msg_(DSPLLE, regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, - regs[reg].parentReg); - _assert_msg_(DSPLLE, !regs[reg].used, "moving to host reg in use guest reg %zu", reg); + _assert_msg_(DSPLLE, reg < m_regs.size(), "bad register name %zu", reg); + _assert_msg_(DSPLLE, m_regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, + m_regs[reg].parentReg); + _assert_msg_(DSPLLE, !m_regs[reg].used, "moving to host reg in use guest reg %zu", reg); - if (regs[reg].loc.IsSimpleReg()) + if (m_regs[reg].loc.IsSimpleReg()) { return; } X64Reg tmp; - if (regs[reg].host_reg != INVALID_REG) + if (m_regs[reg].host_reg != INVALID_REG) { - tmp = regs[reg].host_reg; + tmp = m_regs[reg].host_reg; } else { @@ -580,64 +585,64 @@ void DSPJitRegCache::MovToHostReg(size_t reg, bool load) void DSPJitRegCache::RotateHostReg(size_t reg, int shift, bool emit) { - _assert_msg_(DSPLLE, reg < regs.size(), "bad register name %zu", reg); - _assert_msg_(DSPLLE, regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, - regs[reg].parentReg); - _assert_msg_(DSPLLE, regs[reg].loc.IsSimpleReg(), "register %zu is not a simple reg", reg); - _assert_msg_(DSPLLE, !regs[reg].used, "rotating in use guest reg %zu", reg); + _assert_msg_(DSPLLE, reg < m_regs.size(), "bad register name %zu", reg); + _assert_msg_(DSPLLE, m_regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, + m_regs[reg].parentReg); + _assert_msg_(DSPLLE, m_regs[reg].loc.IsSimpleReg(), "register %zu is not a simple reg", reg); + _assert_msg_(DSPLLE, !m_regs[reg].used, "rotating in use guest reg %zu", reg); - if (shift > regs[reg].shift && emit) + if (shift > m_regs[reg].shift && emit) { - switch (regs[reg].size) + switch (m_regs[reg].size) { case 2: - emitter.ROR(16, regs[reg].loc, Imm8(shift - regs[reg].shift)); + m_emitter.ROR(16, m_regs[reg].loc, Imm8(shift - m_regs[reg].shift)); break; case 4: - emitter.ROR(32, regs[reg].loc, Imm8(shift - regs[reg].shift)); + m_emitter.ROR(32, m_regs[reg].loc, Imm8(shift - m_regs[reg].shift)); break; case 8: - emitter.ROR(64, regs[reg].loc, Imm8(shift - regs[reg].shift)); + m_emitter.ROR(64, m_regs[reg].loc, Imm8(shift - m_regs[reg].shift)); break; } } - else if (shift < regs[reg].shift && emit) + else if (shift < m_regs[reg].shift && emit) { - switch (regs[reg].size) + switch (m_regs[reg].size) { case 2: - emitter.ROL(16, regs[reg].loc, Imm8(regs[reg].shift - shift)); + m_emitter.ROL(16, m_regs[reg].loc, Imm8(m_regs[reg].shift - shift)); break; case 4: - emitter.ROL(32, regs[reg].loc, Imm8(regs[reg].shift - shift)); + m_emitter.ROL(32, m_regs[reg].loc, Imm8(m_regs[reg].shift - shift)); break; case 8: - emitter.ROL(64, regs[reg].loc, Imm8(regs[reg].shift - shift)); + m_emitter.ROL(64, m_regs[reg].loc, Imm8(m_regs[reg].shift - shift)); break; } } - regs[reg].shift = shift; + m_regs[reg].shift = shift; } void DSPJitRegCache::MovToMemory(size_t reg) { - _assert_msg_(DSPLLE, reg < regs.size(), "bad register name %zu", reg); - _assert_msg_(DSPLLE, regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, - regs[reg].parentReg); - _assert_msg_(DSPLLE, !regs[reg].used, "moving to memory in use guest reg %zu", reg); + _assert_msg_(DSPLLE, reg < m_regs.size(), "bad register name %zu", reg); + _assert_msg_(DSPLLE, m_regs[reg].parentReg == DSP_REG_NONE, "register %zu is proxy for %d", reg, + m_regs[reg].parentReg); + _assert_msg_(DSPLLE, !m_regs[reg].used, "moving to memory in use guest reg %zu", reg); - if (regs[reg].used) + if (m_regs[reg].used) { - emitter.INT3(); + m_emitter.INT3(); } - if (!regs[reg].loc.IsSimpleReg() && !regs[reg].loc.IsImm()) + if (!m_regs[reg].loc.IsSimpleReg() && !m_regs[reg].loc.IsImm()) { return; } // but first, check for any needed rotations - if (regs[reg].loc.IsSimpleReg()) + if (m_regs[reg].loc.IsSimpleReg()) { RotateHostReg(reg, 0, true); } @@ -646,57 +651,57 @@ void DSPJitRegCache::MovToMemory(size_t reg) // TODO: Immediates? } - _assert_msg_(DSPLLE, regs[reg].shift == 0, "still shifted??"); + _assert_msg_(DSPLLE, m_regs[reg].shift == 0, "still shifted??"); // move to mem - OpArg tmp = M(regs[reg].mem); + OpArg tmp = M(m_regs[reg].mem); - if (regs[reg].dirty) + if (m_regs[reg].dirty) { - switch (regs[reg].size) + switch (m_regs[reg].size) { case 2: - emitter.MOV(16, tmp, regs[reg].loc); + m_emitter.MOV(16, tmp, m_regs[reg].loc); break; case 4: - emitter.MOV(32, tmp, regs[reg].loc); + m_emitter.MOV(32, tmp, m_regs[reg].loc); break; case 8: - emitter.MOV(64, tmp, regs[reg].loc); + m_emitter.MOV(64, tmp, m_regs[reg].loc); break; default: _assert_msg_(DSPLLE, 0, "unsupported memory size"); break; } - regs[reg].dirty = false; + m_regs[reg].dirty = false; } - if (regs[reg].loc.IsSimpleReg()) + if (m_regs[reg].loc.IsSimpleReg()) { - X64Reg hostreg = regs[reg].loc.GetSimpleReg(); - if (xregs[hostreg].guest_reg != DSP_REG_STATIC) + X64Reg hostreg = m_regs[reg].loc.GetSimpleReg(); + if (m_xregs[hostreg].guest_reg != DSP_REG_STATIC) { - xregs[hostreg].guest_reg = DSP_REG_NONE; + m_xregs[hostreg].guest_reg = DSP_REG_NONE; } } - regs[reg].last_use_ctr = -1; - regs[reg].loc = tmp; + m_regs[reg].last_use_ctr = -1; + m_regs[reg].loc = tmp; } void DSPJitRegCache::GetReg(int reg, OpArg& oparg, bool load) { int real_reg; int shift; - if (regs[reg].parentReg != DSP_REG_NONE) + if (m_regs[reg].parentReg != DSP_REG_NONE) { - real_reg = regs[reg].parentReg; + real_reg = m_regs[reg].parentReg; // always load and rotate since we need the other // parts of the register load = true; - shift = regs[reg].shift; + shift = m_regs[reg].shift; } else { @@ -704,22 +709,22 @@ void DSPJitRegCache::GetReg(int reg, OpArg& oparg, bool load) shift = 0; } - _assert_msg_(DSPLLE, !regs[real_reg].used, "register %d already in use", real_reg); + _assert_msg_(DSPLLE, !m_regs[real_reg].used, "register %d already in use", real_reg); - if (regs[real_reg].used) + if (m_regs[real_reg].used) { - emitter.INT3(); + m_emitter.INT3(); } // no need to actually emit code for load or rotate if caller doesn't // use the contents, but see above for a reason to force the load MovToHostReg(real_reg, load); // TODO: actually handle INVALID_REG - _assert_msg_(DSPLLE, regs[real_reg].loc.IsSimpleReg(), "did not get host reg for %d", reg); + _assert_msg_(DSPLLE, m_regs[real_reg].loc.IsSimpleReg(), "did not get host reg for %d", reg); RotateHostReg(real_reg, shift, load); - oparg = regs[real_reg].loc; - regs[real_reg].used = true; + oparg = m_regs[real_reg].loc; + m_regs[real_reg].used = true; // do some register specific fixup switch (reg) @@ -730,8 +735,8 @@ void DSPJitRegCache::GetReg(int reg, OpArg& oparg, bool load) { // need to do this because interpreter only does 48 bits // (and PutReg does the same) - emitter.SHL(64, oparg, Imm8(64 - 40)); // sign extend - emitter.SAR(64, oparg, Imm8(64 - 40)); + m_emitter.SHL(64, oparg, Imm8(64 - 40)); // sign extend + m_emitter.SAR(64, oparg, Imm8(64 - 40)); } break; default: @@ -742,10 +747,10 @@ void DSPJitRegCache::GetReg(int reg, OpArg& oparg, bool load) void DSPJitRegCache::PutReg(int reg, bool dirty) { int real_reg = reg; - if (regs[reg].parentReg != DSP_REG_NONE) - real_reg = regs[reg].parentReg; + if (m_regs[reg].parentReg != DSP_REG_NONE) + real_reg = m_regs[reg].parentReg; - OpArg oparg = regs[real_reg].loc; + OpArg oparg = m_regs[real_reg].loc; switch (reg) { @@ -761,7 +766,7 @@ void DSPJitRegCache::PutReg(int reg, bool dirty) // (if at all) // sign extend from the bottom 8 bits. - emitter.MOVSX(16, 8, oparg.GetSimpleReg(), oparg); + m_emitter.MOVSX(16, 8, oparg.GetSimpleReg(), oparg); } else if (oparg.IsImm()) { @@ -773,8 +778,8 @@ void DSPJitRegCache::PutReg(int reg, bool dirty) // of real_reg, since it has the right loc X64Reg tmp = GetFreeXReg(); // Sign extend from the bottom 8 bits. - emitter.MOVSX(16, 8, tmp, regs[reg].loc); - emitter.MOV(16, regs[reg].loc, R(tmp)); + m_emitter.MOVSX(16, 8, tmp, m_regs[reg].loc); + m_emitter.MOV(16, m_regs[reg].loc, R(tmp)); PutXReg(tmp); } } @@ -783,21 +788,21 @@ void DSPJitRegCache::PutReg(int reg, bool dirty) case DSP_REG_ACC1_64: if (dirty) { - emitter.SHL(64, oparg, Imm8(64 - 40)); // sign extend - emitter.SAR(64, oparg, Imm8(64 - 40)); + m_emitter.SHL(64, oparg, Imm8(64 - 40)); // sign extend + m_emitter.SAR(64, oparg, Imm8(64 - 40)); } break; default: break; } - regs[real_reg].used = false; + m_regs[real_reg].used = false; - if (regs[real_reg].loc.IsSimpleReg()) + if (m_regs[real_reg].loc.IsSimpleReg()) { - regs[real_reg].dirty |= dirty; - regs[real_reg].last_use_ctr = use_ctr; - use_ctr++; + m_regs[real_reg].dirty |= dirty; + m_regs[real_reg].last_use_ctr = m_use_ctr; + m_use_ctr++; } } @@ -806,19 +811,19 @@ void DSPJitRegCache::ReadReg(int sreg, X64Reg host_dreg, DSPJitSignExtend extend OpArg reg; GetReg(sreg, reg); - switch (regs[sreg].size) + switch (m_regs[sreg].size) { case 2: switch (extend) { case SIGN: - emitter.MOVSX(64, 16, host_dreg, reg); + m_emitter.MOVSX(64, 16, host_dreg, reg); break; case ZERO: - emitter.MOVZX(64, 16, host_dreg, reg); + m_emitter.MOVZX(64, 16, host_dreg, reg); break; case NONE: - emitter.MOV(16, R(host_dreg), reg); + m_emitter.MOV(16, R(host_dreg), reg); break; } break; @@ -826,18 +831,18 @@ void DSPJitRegCache::ReadReg(int sreg, X64Reg host_dreg, DSPJitSignExtend extend switch (extend) { case SIGN: - emitter.MOVSX(64, 32, host_dreg, reg); + m_emitter.MOVSX(64, 32, host_dreg, reg); break; case ZERO: - emitter.MOVZX(64, 32, host_dreg, reg); + m_emitter.MOVZX(64, 32, host_dreg, reg); break; case NONE: - emitter.MOV(32, R(host_dreg), reg); + m_emitter.MOV(32, R(host_dreg), reg); break; } break; case 8: - emitter.MOV(64, R(host_dreg), reg); + m_emitter.MOV(64, R(host_dreg), reg); break; default: _assert_msg_(DSPLLE, 0, "unsupported memory size"); @@ -852,22 +857,22 @@ void DSPJitRegCache::WriteReg(int dreg, OpArg arg) GetReg(dreg, reg, false); if (arg.IsImm()) { - switch (regs[dreg].size) + switch (m_regs[dreg].size) { case 2: - emitter.MOV(16, reg, Imm16(arg.Imm16())); + m_emitter.MOV(16, reg, Imm16(arg.Imm16())); break; case 4: - emitter.MOV(32, reg, Imm32(arg.Imm32())); + m_emitter.MOV(32, reg, Imm32(arg.Imm32())); break; case 8: if ((u32)arg.Imm64() == arg.Imm64()) { - emitter.MOV(64, reg, Imm32((u32)arg.Imm64())); + m_emitter.MOV(64, reg, Imm32((u32)arg.Imm64())); } else { - emitter.MOV(64, reg, Imm64(arg.Imm64())); + m_emitter.MOV(64, reg, Imm64(arg.Imm64())); } break; default: @@ -877,16 +882,16 @@ void DSPJitRegCache::WriteReg(int dreg, OpArg arg) } else { - switch (regs[dreg].size) + switch (m_regs[dreg].size) { case 2: - emitter.MOV(16, reg, arg); + m_emitter.MOV(16, reg, arg); break; case 4: - emitter.MOV(32, reg, arg); + m_emitter.MOV(32, reg, arg); break; case 8: - emitter.MOV(64, reg, arg); + m_emitter.MOV(64, reg, arg); break; default: _assert_msg_(DSPLLE, 0, "unsupported memory size"); @@ -902,9 +907,9 @@ X64Reg DSPJitRegCache::SpillXReg() X64Reg least_recent_use_reg = INVALID_REG; for (X64Reg reg : m_allocation_order) { - if (xregs[reg].guest_reg <= DSP_REG_MAX_MEM_BACKED && !regs[xregs[reg].guest_reg].used) + if (m_xregs[reg].guest_reg <= DSP_REG_MAX_MEM_BACKED && !m_regs[m_xregs[reg].guest_reg].used) { - int use_ctr_diff = use_ctr - regs[xregs[reg].guest_reg].last_use_ctr; + int use_ctr_diff = m_use_ctr - m_regs[m_xregs[reg].guest_reg].last_use_ctr; if (use_ctr_diff >= max_use_ctr_diff) { max_use_ctr_diff = use_ctr_diff; @@ -915,16 +920,16 @@ X64Reg DSPJitRegCache::SpillXReg() if (least_recent_use_reg != INVALID_REG) { - MovToMemory(xregs[least_recent_use_reg].guest_reg); + MovToMemory(m_xregs[least_recent_use_reg].guest_reg); return least_recent_use_reg; } // just choose one. for (X64Reg reg : m_allocation_order) { - if (xregs[reg].guest_reg <= DSP_REG_MAX_MEM_BACKED && !regs[xregs[reg].guest_reg].used) + if (m_xregs[reg].guest_reg <= DSP_REG_MAX_MEM_BACKED && !m_regs[m_xregs[reg].guest_reg].used) { - MovToMemory(xregs[reg].guest_reg); + MovToMemory(m_xregs[reg].guest_reg); return reg; } } @@ -934,17 +939,17 @@ X64Reg DSPJitRegCache::SpillXReg() void DSPJitRegCache::SpillXReg(X64Reg reg) { - if (xregs[reg].guest_reg <= DSP_REG_MAX_MEM_BACKED) + if (m_xregs[reg].guest_reg <= DSP_REG_MAX_MEM_BACKED) { - _assert_msg_(DSPLLE, !regs[xregs[reg].guest_reg].used, + _assert_msg_(DSPLLE, !m_regs[m_xregs[reg].guest_reg].used, "to be spilled host reg %x(guest reg %zx) still in use!", reg, - xregs[reg].guest_reg); + m_xregs[reg].guest_reg); - MovToMemory(xregs[reg].guest_reg); + MovToMemory(m_xregs[reg].guest_reg); } else { - _assert_msg_(DSPLLE, xregs[reg].guest_reg == DSP_REG_NONE, + _assert_msg_(DSPLLE, m_xregs[reg].guest_reg == DSP_REG_NONE, "to be spilled host reg %x still in use!", reg); } } @@ -953,7 +958,7 @@ X64Reg DSPJitRegCache::FindFreeXReg() { for (X64Reg x : m_allocation_order) { - if (xregs[x].guest_reg == DSP_REG_NONE) + if (m_xregs[x].guest_reg == DSP_REG_NONE) { return x; } @@ -979,40 +984,40 @@ X64Reg DSPJitRegCache::GetFreeXReg() _assert_msg_(DSPLLE, reg != INVALID_REG, "could not find register"); if (reg == INVALID_REG) { - emitter.INT3(); + m_emitter.INT3(); } - xregs[reg].guest_reg = DSP_REG_USED; + m_xregs[reg].guest_reg = DSP_REG_USED; return reg; } void DSPJitRegCache::GetXReg(X64Reg reg) { - if (xregs[reg].guest_reg == DSP_REG_STATIC) + if (m_xregs[reg].guest_reg == DSP_REG_STATIC) { ERROR_LOG(DSPLLE, "Trying to get statically used XReg %d", reg); return; } - if (xregs[reg].guest_reg != DSP_REG_NONE) + if (m_xregs[reg].guest_reg != DSP_REG_NONE) { SpillXReg(reg); } - _assert_msg_(DSPLLE, xregs[reg].guest_reg == DSP_REG_NONE, "register already in use"); - xregs[reg].guest_reg = DSP_REG_USED; + _assert_msg_(DSPLLE, m_xregs[reg].guest_reg == DSP_REG_NONE, "register already in use"); + m_xregs[reg].guest_reg = DSP_REG_USED; } void DSPJitRegCache::PutXReg(X64Reg reg) { - if (xregs[reg].guest_reg == DSP_REG_STATIC) + if (m_xregs[reg].guest_reg == DSP_REG_STATIC) { ERROR_LOG(DSPLLE, "Trying to put statically used XReg %d", reg); return; } - _assert_msg_(DSPLLE, xregs[reg].guest_reg == DSP_REG_USED, "PutXReg without get(Free)XReg"); + _assert_msg_(DSPLLE, m_xregs[reg].guest_reg == DSP_REG_USED, "PutXReg without get(Free)XReg"); - xregs[reg].guest_reg = DSP_REG_NONE; + m_xregs[reg].guest_reg = DSP_REG_NONE; } } // namespace x86 diff --git a/Source/Core/Core/DSP/Jit/DSPJitRegCache.h b/Source/Core/Core/DSP/Jit/DSPJitRegCache.h index 2c1e3c50b8..bcb93b154c 100644 --- a/Source/Core/Core/DSP/Jit/DSPJitRegCache.h +++ b/Source/Core/Core/DSP/Jit/DSPJitRegCache.h @@ -39,7 +39,7 @@ enum DSPJitSignExtend class DSPJitRegCache { public: - DSPJitRegCache(DSPEmitter& _emitter); + DSPJitRegCache(DSPEmitter& emitter); // For branching into multiple control flows DSPJitRegCache(const DSPJitRegCache& cache); @@ -176,14 +176,14 @@ private: static const std::array m_allocation_order; - std::array regs; - std::array xregs; + std::array m_regs; + std::array m_xregs; - DSPEmitter& emitter; - bool temporary; - bool merged; + DSPEmitter& m_emitter; + bool m_is_temporary; + bool m_is_merged; - int use_ctr; + int m_use_ctr; }; } // namespace x86