Merge pull request #9533 from sepalani/mmu-is-ram
MMU: Fix IsRAMAddress not working
This commit is contained in:
commit
5f7d935b0a
|
@ -207,7 +207,7 @@ static T ReadFromHardware(u32 em_address)
|
||||||
|
|
||||||
// TODO: Make sure these are safe for unaligned addresses.
|
// TODO: Make sure these are safe for unaligned addresses.
|
||||||
|
|
||||||
if ((em_address & 0xF8000000) == 0x00000000)
|
if (Memory::m_pRAM && (em_address & 0xF8000000) == 0x00000000)
|
||||||
{
|
{
|
||||||
// Handle RAM; the masking intentionally discards bits (essentially creating
|
// Handle RAM; the masking intentionally discards bits (essentially creating
|
||||||
// mirrors of memory).
|
// mirrors of memory).
|
||||||
|
@ -226,7 +226,8 @@ static T ReadFromHardware(u32 em_address)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Locked L1 technically doesn't have a fixed address, but games all use 0xE0000000.
|
// Locked L1 technically doesn't have a fixed address, but games all use 0xE0000000.
|
||||||
if ((em_address >> 28) == 0xE && (em_address < (0xE0000000 + Memory::GetL1CacheSize())))
|
if (Memory::m_pL1Cache && (em_address >> 28) == 0xE &&
|
||||||
|
(em_address < (0xE0000000 + Memory::GetL1CacheSize())))
|
||||||
{
|
{
|
||||||
T value;
|
T value;
|
||||||
std::memcpy(&value, &Memory::m_pL1Cache[em_address & 0x0FFFFFFF], sizeof(T));
|
std::memcpy(&value, &Memory::m_pL1Cache[em_address & 0x0FFFFFFF], sizeof(T));
|
||||||
|
@ -296,7 +297,7 @@ static void WriteToHardware(u32 em_address, const T data)
|
||||||
|
|
||||||
// TODO: Make sure these are safe for unaligned addresses.
|
// TODO: Make sure these are safe for unaligned addresses.
|
||||||
|
|
||||||
if ((em_address & 0xF8000000) == 0x00000000)
|
if (Memory::m_pRAM && (em_address & 0xF8000000) == 0x00000000)
|
||||||
{
|
{
|
||||||
// Handle RAM; the masking intentionally discards bits (essentially creating
|
// Handle RAM; the masking intentionally discards bits (essentially creating
|
||||||
// mirrors of memory).
|
// mirrors of memory).
|
||||||
|
@ -315,7 +316,8 @@ static void WriteToHardware(u32 em_address, const T data)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Locked L1 technically doesn't have a fixed address, but games all use 0xE0000000.
|
// Locked L1 technically doesn't have a fixed address, but games all use 0xE0000000.
|
||||||
if ((em_address >> 28 == 0xE) && (em_address < (0xE0000000 + Memory::GetL1CacheSize())))
|
if (Memory::m_pL1Cache && (em_address >> 28 == 0xE) &&
|
||||||
|
(em_address < (0xE0000000 + Memory::GetL1CacheSize())))
|
||||||
{
|
{
|
||||||
const T swapped_data = bswap(data);
|
const T swapped_data = bswap(data);
|
||||||
std::memcpy(&Memory::m_pL1Cache[em_address & 0x0FFFFFFF], &swapped_data, sizeof(T));
|
std::memcpy(&Memory::m_pL1Cache[em_address & 0x0FFFFFFF], &swapped_data, sizeof(T));
|
||||||
|
@ -665,15 +667,24 @@ static bool IsRAMAddress(u32 address, bool translate)
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 segment = address >> 28;
|
u32 segment = address >> 28;
|
||||||
if (segment == 0x0 && (address & 0x0FFFFFFF) < Memory::GetRamSizeReal())
|
if (Memory::m_pRAM && segment == 0x0 && (address & 0x0FFFFFFF) < Memory::GetRamSizeReal())
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
else if (Memory::m_pEXRAM && segment == 0x1 &&
|
else if (Memory::m_pEXRAM && segment == 0x1 &&
|
||||||
(address & 0x0FFFFFFF) < Memory::GetExRamSizeReal())
|
(address & 0x0FFFFFFF) < Memory::GetExRamSizeReal())
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
else if (Memory::m_pFakeVMEM && ((address & 0xFE000000) == 0x7E000000))
|
else if (Memory::m_pFakeVMEM && ((address & 0xFE000000) == 0x7E000000))
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
else if (segment == 0xE && (address < (0xE0000000 + Memory::GetL1CacheSize())))
|
}
|
||||||
|
else if (Memory::m_pL1Cache && segment == 0xE &&
|
||||||
|
(address < (0xE0000000 + Memory::GetL1CacheSize())))
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue