summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar bunnei2014-07-24 19:46:10 -0400
committerGravatar bunnei2014-08-05 19:58:28 -0400
commit2b52ec4829dce2801e4a507b81e9d302aae08735 (patch)
treed527b6f343f8d15ebb2f1387248c0e26b93e3921 /src
parentMerge pull request #27 from neobrain/disassembly_view_rewrite (diff)
downloadyuzu-2b52ec4829dce2801e4a507b81e9d302aae08735.tar.gz
yuzu-2b52ec4829dce2801e4a507b81e9d302aae08735.tar.xz
yuzu-2b52ec4829dce2801e4a507b81e9d302aae08735.zip
MemMap: Fix Read32 for unaligned memory reads.
MemMap: Cleaned up Read32 unaligned memory access.
Diffstat (limited to 'src')
-rw-r--r--src/core/mem_map_funcs.cpp35
1 files changed, 23 insertions, 12 deletions
diff --git a/src/core/mem_map_funcs.cpp b/src/core/mem_map_funcs.cpp
index 0342122df..e9533a0c5 100644
--- a/src/core/mem_map_funcs.cpp
+++ b/src/core/mem_map_funcs.cpp
@@ -224,27 +224,38 @@ u32 MapBlock_HeapGSP(u32 size, u32 operation, u32 permissions) {
224} 224}
225 225
226u8 Read8(const u32 addr) { 226u8 Read8(const u32 addr) {
227 u8 _var = 0; 227 u8 data = 0;
228 Read<u8>(_var, addr); 228 Read<u8>(data, addr);
229 return (u8)_var; 229 return (u8)data;
230} 230}
231 231
232u16 Read16(const u32 addr) { 232u16 Read16(const u32 addr) {
233 u16_le _var = 0; 233 u16_le data = 0;
234 Read<u16_le>(_var, addr); 234 Read<u16_le>(data, addr);
235 return (u16)_var; 235 return (u16)data;
236} 236}
237 237
238u32 Read32(const u32 addr) { 238u32 Read32(const u32 addr) {
239 u32_le _var = 0; 239 u32_le data = 0;
240 Read<u32_le>(_var, addr); 240 Read<u32_le>(data, addr);
241 return _var; 241
242 // Check for 32-bit unaligned memory reads...
243 if (addr & 3) {
244 // ARM allows for unaligned memory reads, however older ARM architectures read out memory
245 // from unaligned addresses in a shifted way. Our ARM CPU core (SkyEye) corrects for this,
246 // so therefore expects the memory to be read out in this manner.
247 // TODO(bunnei): Determine if this is necessary - perhaps it is OK to remove this from both
248 // SkyEye and here?
249 int shift = (addr & 3) * 8;
250 data = (data << shift) | (data >> (32 - shift));
251 }
252 return (u32)data;
242} 253}
243 254
244u64 Read64(const u32 addr) { 255u64 Read64(const u32 addr) {
245 u64_le _var = 0; 256 u64_le data = 0;
246 Read<u64_le>(_var, addr); 257 Read<u64_le>(data, addr);
247 return _var; 258 return data;
248} 259}
249 260
250u32 Read8_ZX(const u32 addr) { 261u32 Read8_ZX(const u32 addr) {