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
|
|
|
|
2008-09-18 03:15:49 +00:00
|
|
|
class CDebugTlb;
|
2023-10-05 02:40:45 +00:00
|
|
|
class CRecompiler;
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2015-11-09 06:21:32 +00:00
|
|
|
#pragma warning(push)
|
|
|
|
#pragma warning(disable : 4201) // warning C4201: nonstandard extension used : nameless struct/union
|
|
|
|
|
2023-10-05 03:58:32 +00:00
|
|
|
enum MemorySegment
|
|
|
|
{
|
|
|
|
MemorySegment_Mapped,
|
|
|
|
MemorySegment_Cached,
|
|
|
|
MemorySegment_Cached32,
|
|
|
|
MemorySegment_Direct,
|
|
|
|
MemorySegment_Direct32,
|
|
|
|
MemorySegment_Unused,
|
|
|
|
};
|
|
|
|
|
2023-10-05 02:40:45 +00:00
|
|
|
struct TLB_ENTRY
|
2008-09-18 03:15:49 +00:00
|
|
|
{
|
2023-10-05 02:40:45 +00:00
|
|
|
bool EntryDefined;
|
|
|
|
COP0PageMask PageMask;
|
|
|
|
COP0EntryHi EntryHi;
|
|
|
|
COP0EntryLo EntryLo0;
|
|
|
|
COP0EntryLo EntryLo1;
|
|
|
|
};
|
2015-11-09 06:21:32 +00:00
|
|
|
|
2023-10-05 02:40:45 +00:00
|
|
|
class CTLB :
|
|
|
|
private CGameSettings
|
|
|
|
{
|
|
|
|
friend class CDebugTlb;
|
2012-09-28 20:17:44 +00:00
|
|
|
|
2015-11-09 06:21:32 +00:00
|
|
|
struct FASTTLB
|
|
|
|
{
|
2023-11-16 06:41:05 +00:00
|
|
|
uint32_t VSTART;
|
|
|
|
uint32_t VEND;
|
2015-11-09 06:21:32 +00:00
|
|
|
uint32_t PHYSSTART;
|
|
|
|
uint32_t PHYSEND;
|
|
|
|
uint32_t Length;
|
2023-11-16 06:41:05 +00:00
|
|
|
uint8_t Region;
|
2022-10-10 00:22:17 +00:00
|
|
|
bool VALID;
|
|
|
|
bool DIRTY;
|
|
|
|
bool GLOBAL;
|
|
|
|
bool ValidEntry;
|
|
|
|
bool Random;
|
|
|
|
bool Probed;
|
2015-11-09 06:21:32 +00:00
|
|
|
};
|
|
|
|
|
2023-10-05 02:40:45 +00:00
|
|
|
public:
|
|
|
|
CTLB(CMipsMemoryVM & MMU, CRegisters & Reg, CRecompiler *& Recomp);
|
|
|
|
~CTLB();
|
2015-11-09 06:21:32 +00:00
|
|
|
|
2023-10-05 02:40:45 +00:00
|
|
|
void Reset(bool InvalidateTLB);
|
|
|
|
void Probe();
|
|
|
|
void ReadEntry();
|
2023-10-05 03:12:31 +00:00
|
|
|
void WriteEntry(uint32_t Index, bool Random);
|
2023-10-05 03:58:32 +00:00
|
|
|
void COP0StatusChanged(void);
|
2023-10-05 04:31:09 +00:00
|
|
|
bool AddressDefined(uint64_t VAddr, bool & Dirty);
|
2023-10-05 02:40:45 +00:00
|
|
|
TLB_ENTRY & TlbEntry(int32_t Entry);
|
2023-10-05 03:12:31 +00:00
|
|
|
|
2023-10-05 03:58:32 +00:00
|
|
|
bool VAddrToPAddr(uint64_t VAddr, uint32_t & PAddr, bool & MemoryUnused);
|
2023-10-05 02:40:45 +00:00
|
|
|
bool PAddrToVAddr(uint32_t PAddr, uint32_t & VAddr, uint32_t & Index);
|
|
|
|
void RecordDifference(CLog & LogFile, const CTLB & rTLB);
|
2015-11-09 06:21:32 +00:00
|
|
|
|
2023-10-05 02:40:45 +00:00
|
|
|
bool operator==(const CTLB & rTLB) const;
|
|
|
|
bool operator!=(const CTLB & rTLB) const;
|
2015-11-09 06:21:32 +00:00
|
|
|
|
|
|
|
private:
|
2021-04-13 00:07:11 +00:00
|
|
|
CTLB();
|
2022-10-10 00:22:17 +00:00
|
|
|
CTLB(const CTLB &);
|
|
|
|
CTLB & operator=(const CTLB &);
|
2023-10-05 02:40:45 +00:00
|
|
|
|
2023-10-05 03:12:31 +00:00
|
|
|
void SetupTLB_Entry(uint32_t Index, bool Random);
|
2023-11-16 06:41:05 +00:00
|
|
|
void TLB_Unmaped(uint32_t VAddr, uint32_t Len);
|
2023-10-05 03:58:32 +00:00
|
|
|
MemorySegment VAddrMemorySegment(uint64_t VAddr);
|
2023-10-05 02:40:45 +00:00
|
|
|
|
2023-10-05 03:58:32 +00:00
|
|
|
PRIVILEGE_MODE m_PrivilegeMode;
|
|
|
|
bool m_AddressSize32bit;
|
2023-10-05 02:40:45 +00:00
|
|
|
CMipsMemoryVM & m_MMU;
|
|
|
|
CRegisters & m_Reg;
|
|
|
|
CRecompiler *& m_Recomp;
|
|
|
|
TLB_ENTRY m_tlb[32];
|
|
|
|
FASTTLB m_FastTlb[64];
|
2008-09-18 03:15:49 +00:00
|
|
|
};
|
2015-11-09 06:21:32 +00:00
|
|
|
|
|
|
|
#pragma warning(pop)
|