aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar bunnei <bunneidev@gmail.com>2014-07-04 23:46:16 -0400
committerGravatar bunnei <bunneidev@gmail.com>2014-07-04 23:46:16 -0400
commit3013015a0c7b830c9985e4d3a6b2bd66f15546e2 (patch)
tree1b514233226d458efa501d9367cccc11bbe8e700
parentad1adb2f9270cc48bfbfd8b12ad1dac162c48e39 (diff)
mem_map: Updated interface to expose template functions to other modules.
-rw-r--r--src/core/mem_map.h6
-rw-r--r--src/core/mem_map_funcs.cpp20
2 files changed, 16 insertions, 10 deletions
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 <typename T>
+inline void Read(T &var, const u32 addr);
+
+template <typename T>
+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 <typename T>
-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 <typename T>
-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<u8>(_var, addr);
+ Read<u8>(_var, addr);
return (u8)_var;
}
u16 Read16(const u32 addr) {
u16_le _var = 0;
- _Read<u16_le>(_var, addr);
+ Read<u16_le>(_var, addr);
return (u16)_var;
}
u32 Read32(const u32 addr) {
u32_le _var = 0;
- _Read<u32_le>(_var, addr);
+ Read<u32_le>(_var, addr);
return _var;
}
u64 Read64(const u32 addr) {
u64_le _var = 0;
- _Read<u64_le>(_var, addr);
+ Read<u64_le>(_var, addr);
return _var;
}
@@ -278,19 +278,19 @@ u32 Read16_ZX(const u32 addr) {
}
void Write8(const u32 addr, const u8 data) {
- _Write<u8>(addr, data);
+ Write<u8>(addr, data);
}
void Write16(const u32 addr, const u16 data) {
- _Write<u16_le>(addr, data);
+ Write<u16_le>(addr, data);
}
void Write32(const u32 addr, const u32 data) {
- _Write<u32_le>(addr, data);
+ Write<u32_le>(addr, data);
}
void Write64(const u32 addr, const u64 data) {
- _Write<u64_le>(addr, data);
+ Write<u64_le>(addr, data);
}
void WriteBlock(const u32 addr, const u8* data, const int size) {