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