project64/Source/Project64-core/N64System/Mips/TLB.h

74 lines
1.7 KiB
C
Raw Normal View History

2012-12-19 09:30:18 +00:00
#pragma once
2021-04-14 05:34:15 +00:00
#include <Common/Log.h>
#include <Project64-core/N64System/Mips/Register.h>
2015-12-06 09:59:58 +00:00
class CDebugTlb;
class CRecompiler;
#pragma warning(push)
#pragma warning(disable : 4201) // warning C4201: nonstandard extension used : nameless struct/union
struct TLB_ENTRY
{
bool EntryDefined;
COP0PageMask PageMask;
COP0EntryHi EntryHi;
COP0EntryLo EntryLo0;
COP0EntryLo EntryLo1;
};
class CTLB :
protected CSystemRegisters,
private CGameSettings
{
friend class CDebugTlb;
struct FASTTLB
{
uint32_t VSTART;
uint32_t VEND;
uint32_t PHYSSTART;
uint32_t PHYSEND;
uint32_t Length;
2022-10-10 00:22:17 +00:00
bool VALID;
bool DIRTY;
bool GLOBAL;
bool ValidEntry;
bool Random;
bool Probed;
};
public:
CTLB(CMipsMemoryVM & MMU, CRegisters & Reg, CRecompiler *& Recomp);
~CTLB();
void Reset(bool InvalidateTLB);
void Probe();
void ReadEntry();
void WriteEntry(uint32_t index, bool Random);
bool AddressDefined(uint64_t VAddr);
TLB_ENTRY & TlbEntry(int32_t Entry);
bool PAddrToVAddr(uint32_t PAddr, uint32_t & VAddr, uint32_t & Index);
void RecordDifference(CLog & LogFile, const CTLB & rTLB);
bool operator==(const CTLB & rTLB) const;
bool operator!=(const CTLB & rTLB) const;
private:
CTLB();
2022-10-10 00:22:17 +00:00
CTLB(const CTLB &);
CTLB & operator=(const CTLB &);
void SetupTLB_Entry(uint32_t index, bool Random);
void TLB_Unmaped(uint32_t VAddr, uint32_t Len);
CMipsMemoryVM & m_MMU;
CRegisters & m_Reg;
CRecompiler *& m_Recomp;
TLB_ENTRY m_tlb[32];
FASTTLB m_FastTlb[64];
};
#pragma warning(pop)