mirror of
https://github.com/citra-emu/citra.git
synced 2024-11-22 18:10:07 +00:00
Memory: Properly cleanup & shutdown.
This commit is contained in:
parent
28df8dbfeb
commit
bbabed8e98
@ -11,29 +11,29 @@
|
|||||||
|
|
||||||
namespace Memory {
|
namespace Memory {
|
||||||
|
|
||||||
u8* g_base = nullptr; ///< The base pointer to the auto-mirrored arena.
|
u8* g_base; ///< The base pointer to the auto-mirrored arena.
|
||||||
|
|
||||||
static MemArena arena; ///< The MemArena class
|
static MemArena arena; ///< The MemArena class
|
||||||
|
|
||||||
u8* g_exefs_code = nullptr; ///< ExeFS:/.code is loaded here
|
u8* g_exefs_code; ///< ExeFS:/.code is loaded here
|
||||||
u8* g_system_mem = nullptr; ///< System memory
|
u8* g_system_mem; ///< System memory
|
||||||
u8* g_heap = nullptr; ///< Application heap (main memory)
|
u8* g_heap; ///< Application heap (main memory)
|
||||||
u8* g_heap_linear = nullptr; ///< Linear heap
|
u8* g_heap_linear; ///< Linear heap
|
||||||
u8* g_vram = nullptr; ///< Video memory (VRAM) pointer
|
u8* g_vram; ///< Video memory (VRAM) pointer
|
||||||
u8* g_shared_mem = nullptr; ///< Shared memory
|
u8* g_shared_mem; ///< Shared memory
|
||||||
u8* g_dsp_mem = nullptr; ///< DSP memory
|
u8* g_dsp_mem; ///< DSP memory
|
||||||
u8* g_kernel_mem; ///< Kernel memory
|
u8* g_kernel_mem; ///< Kernel memory
|
||||||
|
|
||||||
static u8* physical_bootrom = nullptr; ///< Bootrom physical memory
|
static u8* physical_bootrom; ///< Bootrom physical memory
|
||||||
static u8* uncached_bootrom = nullptr;
|
static u8* uncached_bootrom;
|
||||||
|
|
||||||
static u8* physical_exefs_code = nullptr; ///< Phsical ExeFS:/.code is loaded here
|
static u8* physical_exefs_code; ///< Phsical ExeFS:/.code is loaded here
|
||||||
static u8* physical_system_mem = nullptr; ///< System physical memory
|
static u8* physical_system_mem; ///< System physical memory
|
||||||
static u8* physical_fcram = nullptr; ///< Main physical memory (FCRAM)
|
static u8* physical_fcram; ///< Main physical memory (FCRAM)
|
||||||
static u8* physical_heap_gsp = nullptr; ///< GSP heap physical memory
|
static u8* physical_heap_gsp; ///< GSP heap physical memory
|
||||||
static u8* physical_vram = nullptr; ///< Video physical memory (VRAM)
|
static u8* physical_vram; ///< Video physical memory (VRAM)
|
||||||
static u8* physical_shared_mem = nullptr; ///< Physical shared memory
|
static u8* physical_shared_mem; ///< Physical shared memory
|
||||||
static u8* physical_dsp_mem = nullptr; ///< Physical DSP memory
|
static u8* physical_dsp_mem; ///< Physical DSP memory
|
||||||
static u8* physical_kernel_mem; ///< Kernel memory
|
static u8* physical_kernel_mem; ///< Kernel memory
|
||||||
|
|
||||||
// We don't declare the IO region in here since its handled by other means.
|
// We don't declare the IO region in here since its handled by other means.
|
||||||
@ -73,6 +73,7 @@ void Init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
g_base = MemoryMap_Setup(g_views, kNumMemViews, flags, &arena);
|
g_base = MemoryMap_Setup(g_views, kNumMemViews, flags, &arena);
|
||||||
|
MemBlock_Init();
|
||||||
|
|
||||||
LOG_DEBUG(HW_Memory, "initialized OK, RAM at %p (mirror at 0 @ %p)", g_heap,
|
LOG_DEBUG(HW_Memory, "initialized OK, RAM at %p (mirror at 0 @ %p)", g_heap,
|
||||||
physical_fcram);
|
physical_fcram);
|
||||||
@ -81,9 +82,29 @@ void Init() {
|
|||||||
void Shutdown() {
|
void Shutdown() {
|
||||||
u32 flags = 0;
|
u32 flags = 0;
|
||||||
MemoryMap_Shutdown(g_views, kNumMemViews, flags, &arena);
|
MemoryMap_Shutdown(g_views, kNumMemViews, flags, &arena);
|
||||||
|
|
||||||
arena.ReleaseSpace();
|
arena.ReleaseSpace();
|
||||||
|
MemBlock_Shutdown();
|
||||||
|
|
||||||
g_base = nullptr;
|
g_base = nullptr;
|
||||||
|
g_exefs_code = nullptr;
|
||||||
|
g_system_mem = nullptr;
|
||||||
|
g_heap = nullptr;
|
||||||
|
g_heap_linear = nullptr;
|
||||||
|
g_vram = nullptr;
|
||||||
|
g_shared_mem = nullptr;
|
||||||
|
g_dsp_mem = nullptr;
|
||||||
|
g_kernel_mem = nullptr;
|
||||||
|
|
||||||
|
physical_bootrom = nullptr;
|
||||||
|
uncached_bootrom = nullptr;
|
||||||
|
physical_exefs_code = nullptr;
|
||||||
|
physical_system_mem = nullptr;
|
||||||
|
physical_fcram = nullptr;
|
||||||
|
physical_heap_gsp = nullptr;
|
||||||
|
physical_vram = nullptr;
|
||||||
|
physical_shared_mem = nullptr;
|
||||||
|
physical_dsp_mem = nullptr;
|
||||||
|
physical_kernel_mem = nullptr;
|
||||||
|
|
||||||
LOG_DEBUG(HW_Memory, "shutdown OK");
|
LOG_DEBUG(HW_Memory, "shutdown OK");
|
||||||
}
|
}
|
||||||
|
@ -171,6 +171,12 @@ u32 MapBlock_Heap(u32 size, u32 operation, u32 permissions);
|
|||||||
*/
|
*/
|
||||||
u32 MapBlock_HeapLinear(u32 size, u32 operation, u32 permissions);
|
u32 MapBlock_HeapLinear(u32 size, u32 operation, u32 permissions);
|
||||||
|
|
||||||
|
/// Initialize mapped memory blocks
|
||||||
|
void MemBlock_Init();
|
||||||
|
|
||||||
|
/// Shutdown mapped memory blocks
|
||||||
|
void MemBlock_Shutdown();
|
||||||
|
|
||||||
inline const char* GetCharPointer(const VAddr address) {
|
inline const char* GetCharPointer(const VAddr address) {
|
||||||
return (const char *)GetPointer(address);
|
return (const char *)GetPointer(address);
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,6 @@ namespace Memory {
|
|||||||
|
|
||||||
static std::map<u32, MemoryBlock> heap_map;
|
static std::map<u32, MemoryBlock> heap_map;
|
||||||
static std::map<u32, MemoryBlock> heap_linear_map;
|
static std::map<u32, MemoryBlock> heap_linear_map;
|
||||||
static std::map<u32, MemoryBlock> shared_map;
|
|
||||||
|
|
||||||
/// Convert a physical address to virtual address
|
/// Convert a physical address to virtual address
|
||||||
VAddr PhysicalToVirtualAddress(const PAddr addr) {
|
VAddr PhysicalToVirtualAddress(const PAddr addr) {
|
||||||
@ -185,12 +184,6 @@ u8 *GetPointer(const VAddr vaddr) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Maps a block of memory on the heap
|
|
||||||
* @param size Size of block in bytes
|
|
||||||
* @param operation Memory map operation type
|
|
||||||
* @param flags Memory allocation flags
|
|
||||||
*/
|
|
||||||
u32 MapBlock_Heap(u32 size, u32 operation, u32 permissions) {
|
u32 MapBlock_Heap(u32 size, u32 operation, u32 permissions) {
|
||||||
MemoryBlock block;
|
MemoryBlock block;
|
||||||
|
|
||||||
@ -208,12 +201,6 @@ u32 MapBlock_Heap(u32 size, u32 operation, u32 permissions) {
|
|||||||
return block.GetVirtualAddress();
|
return block.GetVirtualAddress();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Maps a block of memory on the linear heap
|
|
||||||
* @param size Size of block in bytes
|
|
||||||
* @param operation Memory map operation type
|
|
||||||
* @param flags Memory allocation flags
|
|
||||||
*/
|
|
||||||
u32 MapBlock_HeapLinear(u32 size, u32 operation, u32 permissions) {
|
u32 MapBlock_HeapLinear(u32 size, u32 operation, u32 permissions) {
|
||||||
MemoryBlock block;
|
MemoryBlock block;
|
||||||
|
|
||||||
@ -231,6 +218,14 @@ u32 MapBlock_HeapLinear(u32 size, u32 operation, u32 permissions) {
|
|||||||
return block.GetVirtualAddress();
|
return block.GetVirtualAddress();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MemBlock_Init() {
|
||||||
|
}
|
||||||
|
|
||||||
|
void MemBlock_Shutdown() {
|
||||||
|
heap_map.clear();
|
||||||
|
heap_linear_map.clear();
|
||||||
|
}
|
||||||
|
|
||||||
u8 Read8(const VAddr addr) {
|
u8 Read8(const VAddr addr) {
|
||||||
u8 data = 0;
|
u8 data = 0;
|
||||||
Read<u8>(data, addr);
|
Read<u8>(data, addr);
|
||||||
|
Loading…
Reference in New Issue
Block a user