JitArm64_RegCache: Mark several member functions as const

Many of these don't modify member state, so they can be marked as const.
This commit is contained in:
Lioncash 2020-12-30 09:52:27 -05:00
parent e9aaa46c2f
commit 4ff597cf21
2 changed files with 26 additions and 20 deletions

View File

@ -27,7 +27,7 @@ void Arm64RegCache::Init(ARM64XEmitter* emitter)
ARM64Reg Arm64RegCache::GetReg() ARM64Reg Arm64RegCache::GetReg()
{ {
// If we have no registers left, dump the most stale register first // If we have no registers left, dump the most stale register first
if (!GetUnlockedRegisterCount()) if (GetUnlockedRegisterCount() == 0)
FlushMostStaleRegister(); FlushMostStaleRegister();
for (auto& it : m_host_registers) for (auto& it : m_host_registers)
@ -45,12 +45,14 @@ ARM64Reg Arm64RegCache::GetReg()
return INVALID_REG; return INVALID_REG;
} }
u32 Arm64RegCache::GetUnlockedRegisterCount() u32 Arm64RegCache::GetUnlockedRegisterCount() const
{ {
u32 unlocked_registers = 0; u32 unlocked_registers = 0;
for (auto& it : m_host_registers) for (const auto& it : m_host_registers)
{
if (!it.IsLocked()) if (!it.IsLocked())
++unlocked_registers; ++unlocked_registers;
}
return unlocked_registers; return unlocked_registers;
} }
@ -105,7 +107,7 @@ void Arm64GPRCache::Start(PPCAnalyst::BlockRegStats& stats)
{ {
} }
bool Arm64GPRCache::IsCalleeSaved(ARM64Reg reg) bool Arm64GPRCache::IsCalleeSaved(ARM64Reg reg) const
{ {
static constexpr std::array<ARM64Reg, 11> callee_regs{{ static constexpr std::array<ARM64Reg, 11> callee_regs{{
X28, X28,
@ -351,12 +353,14 @@ void Arm64GPRCache::GetAllocationOrder()
m_host_registers.push_back(HostReg(reg)); m_host_registers.push_back(HostReg(reg));
} }
BitSet32 Arm64GPRCache::GetCallerSavedUsed() BitSet32 Arm64GPRCache::GetCallerSavedUsed() const
{ {
BitSet32 registers(0); BitSet32 registers(0);
for (auto& it : m_host_registers) for (const auto& it : m_host_registers)
{
if (it.IsLocked() && !IsCalleeSaved(it.GetReg())) if (it.IsLocked() && !IsCalleeSaved(it.GetReg()))
registers[DecodeReg(it.GetReg())] = 1; registers[DecodeReg(it.GetReg())] = true;
}
return registers; return registers;
} }
@ -622,7 +626,7 @@ void Arm64FPRCache::FlushByHost(ARM64Reg host_reg)
} }
} }
bool Arm64FPRCache::IsCalleeSaved(ARM64Reg reg) bool Arm64FPRCache::IsCalleeSaved(ARM64Reg reg) const
{ {
static constexpr std::array<ARM64Reg, 9> callee_regs{{ static constexpr std::array<ARM64Reg, 9> callee_regs{{
Q8, Q8,
@ -710,18 +714,20 @@ void Arm64FPRCache::FlushRegisters(BitSet32 regs, bool maintain_state)
FlushRegister(j, maintain_state); FlushRegister(j, maintain_state);
} }
BitSet32 Arm64FPRCache::GetCallerSavedUsed() BitSet32 Arm64FPRCache::GetCallerSavedUsed() const
{ {
BitSet32 registers(0); BitSet32 registers(0);
for (auto& it : m_host_registers) for (const auto& it : m_host_registers)
{
if (it.IsLocked()) if (it.IsLocked())
registers[it.GetReg() - Q0] = 1; registers[it.GetReg() - Q0] = true;
}
return registers; return registers;
} }
bool Arm64FPRCache::IsSingle(size_t preg, bool lower_only) bool Arm64FPRCache::IsSingle(size_t preg, bool lower_only) const
{ {
RegType type = m_guest_registers[preg].GetType(); const RegType type = m_guest_registers[preg].GetType();
return type == REG_REG_SINGLE || type == REG_DUP_SINGLE || return type == REG_REG_SINGLE || type == REG_DUP_SINGLE ||
(lower_only && type == REG_LOWER_PAIR_SINGLE); (lower_only && type == REG_LOWER_PAIR_SINGLE);
} }

View File

@ -134,7 +134,7 @@ public:
// Flushes the register cache in different ways depending on the mode // Flushes the register cache in different ways depending on the mode
virtual void Flush(FlushMode mode, PPCAnalyst::CodeOp* op) = 0; virtual void Flush(FlushMode mode, PPCAnalyst::CodeOp* op) = 0;
virtual BitSet32 GetCallerSavedUsed() = 0; virtual BitSet32 GetCallerSavedUsed() const = 0;
// Returns a temporary register for use // Returns a temporary register for use
// Requires unlocking after done // Requires unlocking after done
@ -183,7 +183,7 @@ protected:
virtual void FlushRegister(size_t preg, bool maintain_state) = 0; virtual void FlushRegister(size_t preg, bool maintain_state) = 0;
// Get available host registers // Get available host registers
u32 GetUnlockedRegisterCount(); u32 GetUnlockedRegisterCount() const;
void IncrementAllUsed() void IncrementAllUsed()
{ {
@ -234,7 +234,7 @@ public:
void BindToRegister(size_t preg, bool do_load) { BindToRegister(GetGuestGPR(preg), do_load); } void BindToRegister(size_t preg, bool do_load) { BindToRegister(GetGuestGPR(preg), do_load); }
// Binds a guest CR to a host register, optionally loading its value // Binds a guest CR to a host register, optionally loading its value
void BindCRToRegister(size_t preg, bool do_load) { BindToRegister(GetGuestCR(preg), do_load); } void BindCRToRegister(size_t preg, bool do_load) { BindToRegister(GetGuestCR(preg), do_load); }
BitSet32 GetCallerSavedUsed() override; BitSet32 GetCallerSavedUsed() const override;
void StoreRegisters(BitSet32 regs) { FlushRegisters(regs, false); } void StoreRegisters(BitSet32 regs) { FlushRegisters(regs, false); }
void StoreCRRegisters(BitSet32 regs) { FlushCRRegisters(regs, false); } void StoreCRRegisters(BitSet32 regs) { FlushCRRegisters(regs, false); }
@ -249,7 +249,7 @@ protected:
void FlushRegister(size_t index, bool maintain_state) override; void FlushRegister(size_t index, bool maintain_state) override;
private: private:
bool IsCalleeSaved(Arm64Gen::ARM64Reg reg); bool IsCalleeSaved(Arm64Gen::ARM64Reg reg) const;
struct GuestRegInfo struct GuestRegInfo
{ {
@ -285,9 +285,9 @@ public:
Arm64Gen::ARM64Reg RW(size_t preg, RegType type = REG_LOWER_PAIR); Arm64Gen::ARM64Reg RW(size_t preg, RegType type = REG_LOWER_PAIR);
BitSet32 GetCallerSavedUsed() override; BitSet32 GetCallerSavedUsed() const override;
bool IsSingle(size_t preg, bool lower_only = false); bool IsSingle(size_t preg, bool lower_only = false) const;
void FixSinglePrecision(size_t preg); void FixSinglePrecision(size_t preg);
@ -303,7 +303,7 @@ protected:
void FlushRegister(size_t preg, bool maintain_state) override; void FlushRegister(size_t preg, bool maintain_state) override;
private: private:
bool IsCalleeSaved(Arm64Gen::ARM64Reg reg); bool IsCalleeSaved(Arm64Gen::ARM64Reg reg) const;
void FlushRegisters(BitSet32 regs, bool maintain_state); void FlushRegisters(BitSet32 regs, bool maintain_state);
}; };