From 3013015a0c7b830c9985e4d3a6b2bd66f15546e2 Mon Sep 17 00:00:00 2001 From: bunnei Date: Fri, 4 Jul 2014 23:46:16 -0400 Subject: mem_map: Updated interface to expose template functions to other modules. --- src/core/mem_map.h | 6 ++++++ src/core/mem_map_funcs.cpp | 20 ++++++++++---------- 2 files changed, 16 insertions(+), 10 deletions(-) (limited to 'src/core') diff --git a/src/core/mem_map.h b/src/core/mem_map.h index d5899e4b..70a8dedc 100644 --- a/src/core/mem_map.h +++ b/src/core/mem_map.h @@ -128,6 +128,12 @@ extern u8* g_exefs_code; ///< ExeFS:/.code is loaded here void Init(); void Shutdown(); +template +inline void Read(T &var, const u32 addr); + +template +inline void Write(u32 addr, const T data); + u8 Read8(const u32 addr); u16 Read16(const u32 addr); u32 Read32(const u32 addr); diff --git a/src/core/mem_map_funcs.cpp b/src/core/mem_map_funcs.cpp index 37913119..d0ca85cc 100644 --- a/src/core/mem_map_funcs.cpp +++ b/src/core/mem_map_funcs.cpp @@ -41,7 +41,7 @@ u32 _VirtualAddress(const u32 addr) { } template -inline void _Read(T &var, const u32 addr) { +inline void Read(T &var, const u32 addr) { // TODO: Figure out the fastest order of tests for both read and write (they are probably different). // TODO: Make sure this represents the mirrors in a correct way. // Could just do a base-relative read, too.... TODO @@ -91,7 +91,7 @@ inline void _Read(T &var, const u32 addr) { } template -inline void _Write(u32 addr, const T data) { +inline void Write(u32 addr, const T data) { u32 vaddr = _VirtualAddress(addr); // Kernel memory command buffer @@ -247,25 +247,25 @@ u32 MapBlock_HeapGSP(u32 size, u32 operation, u32 permissions) { u8 Read8(const u32 addr) { u8 _var = 0; - _Read(_var, addr); + Read(_var, addr); return (u8)_var; } u16 Read16(const u32 addr) { u16_le _var = 0; - _Read(_var, addr); + Read(_var, addr); return (u16)_var; } u32 Read32(const u32 addr) { u32_le _var = 0; - _Read(_var, addr); + Read(_var, addr); return _var; } u64 Read64(const u32 addr) { u64_le _var = 0; - _Read(_var, addr); + Read(_var, addr); return _var; } @@ -278,19 +278,19 @@ u32 Read16_ZX(const u32 addr) { } void Write8(const u32 addr, const u8 data) { - _Write(addr, data); + Write(addr, data); } void Write16(const u32 addr, const u16 data) { - _Write(addr, data); + Write(addr, data); } void Write32(const u32 addr, const u32 data) { - _Write(addr, data); + Write(addr, data); } void Write64(const u32 addr, const u64 data) { - _Write(addr, data); + Write(addr, data); } void WriteBlock(const u32 addr, const u8* data, const int size) { -- cgit v1.2.3