summaryrefslogtreecommitdiff
path: root/src/core/memory.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/memory.cpp')
-rw-r--r--src/core/memory.cpp37
1 files changed, 36 insertions, 1 deletions
diff --git a/src/core/memory.cpp b/src/core/memory.cpp
index 1f66bb27d..935dac90f 100644
--- a/src/core/memory.cpp
+++ b/src/core/memory.cpp
@@ -9,7 +9,6 @@
9#include "common/logging/log.h" 9#include "common/logging/log.h"
10#include "common/swap.h" 10#include "common/swap.h"
11 11
12#include "core/mem_map.h"
13#include "core/memory.h" 12#include "core/memory.h"
14#include "core/memory_setup.h" 13#include "core/memory_setup.h"
15 14
@@ -198,4 +197,40 @@ void WriteBlock(const VAddr addr, const u8* data, const size_t size) {
198 Write8(addr + offset, data[offset]); 197 Write8(addr + offset, data[offset]);
199} 198}
200 199
200PAddr VirtualToPhysicalAddress(const VAddr addr) {
201 if (addr == 0) {
202 return 0;
203 } else if (addr >= VRAM_VADDR && addr < VRAM_VADDR_END) {
204 return addr - VRAM_VADDR + VRAM_PADDR;
205 } else if (addr >= LINEAR_HEAP_VADDR && addr < LINEAR_HEAP_VADDR_END) {
206 return addr - LINEAR_HEAP_VADDR + FCRAM_PADDR;
207 } else if (addr >= DSP_RAM_VADDR && addr < DSP_RAM_VADDR_END) {
208 return addr - DSP_RAM_VADDR + DSP_RAM_PADDR;
209 } else if (addr >= IO_AREA_VADDR && addr < IO_AREA_VADDR_END) {
210 return addr - IO_AREA_VADDR + IO_AREA_PADDR;
211 }
212
213 LOG_ERROR(HW_Memory, "Unknown virtual address @ 0x%08X", addr);
214 // To help with debugging, set bit on address so that it's obviously invalid.
215 return addr | 0x80000000;
216}
217
218VAddr PhysicalToVirtualAddress(const PAddr addr) {
219 if (addr == 0) {
220 return 0;
221 } else if (addr >= VRAM_PADDR && addr < VRAM_PADDR_END) {
222 return addr - VRAM_PADDR + VRAM_VADDR;
223 } else if (addr >= FCRAM_PADDR && addr < FCRAM_PADDR_END) {
224 return addr - FCRAM_PADDR + LINEAR_HEAP_VADDR;
225 } else if (addr >= DSP_RAM_PADDR && addr < DSP_RAM_PADDR_END) {
226 return addr - DSP_RAM_PADDR + DSP_RAM_VADDR;
227 } else if (addr >= IO_AREA_PADDR && addr < IO_AREA_PADDR_END) {
228 return addr - IO_AREA_PADDR + IO_AREA_VADDR;
229 }
230
231 LOG_ERROR(HW_Memory, "Unknown physical address @ 0x%08X", addr);
232 // To help with debugging, set bit on address so that it's obviously invalid.
233 return addr | 0x80000000;
234}
235
201} // namespace 236} // namespace