mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 11:56:42 +08: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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user