diff options
Diffstat (limited to 'src/core/memory.cpp')
| -rw-r--r-- | src/core/memory.cpp | 37 |
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 | ||
| 200 | PAddr 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 | |||
| 218 | VAddr 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 |