diff options
| author | 2014-08-05 20:09:04 -0400 | |
|---|---|---|
| committer | 2014-08-05 20:09:04 -0400 | |
| commit | 90aaab1df0fe0a0518200c71df6ebe1bcf8eb783 (patch) | |
| tree | 437b0b82227c54f45212dd200885698311089064 /src/core/mem_map_funcs.cpp | |
| parent | Merge pull request #35 from bunnei/skyeye-3dmoo (diff) | |
| parent | MemMap: Added an error for unaligned 16-bit memory reads. (diff) | |
| download | yuzu-90aaab1df0fe0a0518200c71df6ebe1bcf8eb783.tar.gz yuzu-90aaab1df0fe0a0518200c71df6ebe1bcf8eb783.tar.xz yuzu-90aaab1df0fe0a0518200c71df6ebe1bcf8eb783.zip | |
Merge pull request #36 from bunnei/fix-memory-unaligned-reads
Fix memory unaligned reads
Diffstat (limited to 'src/core/mem_map_funcs.cpp')
| -rw-r--r-- | src/core/mem_map_funcs.cpp | 42 |
1 files changed, 27 insertions, 15 deletions
diff --git a/src/core/mem_map_funcs.cpp b/src/core/mem_map_funcs.cpp index 0342122df..038d3bffa 100644 --- a/src/core/mem_map_funcs.cpp +++ b/src/core/mem_map_funcs.cpp | |||
| @@ -224,27 +224,39 @@ u32 MapBlock_HeapGSP(u32 size, u32 operation, u32 permissions) { | |||
| 224 | } | 224 | } |
| 225 | 225 | ||
| 226 | u8 Read8(const u32 addr) { | 226 | u8 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 | ||
| 232 | u16 Read16(const u32 addr) { | 232 | u16 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; | ||
| 236 | } | ||
| 237 | 235 | ||
| 238 | u32 Read32(const u32 addr) { | 236 | // Check for 16-bit unaligned memory reads... |
| 239 | u32_le _var = 0; | 237 | if (addr & 1) { |
| 240 | Read<u32_le>(_var, addr); | 238 | // TODO(bunnei): Implement 16-bit unaligned memory reads |
| 241 | return _var; | 239 | ERROR_LOG(MEMMAP, "16-bit unaligned memory reads are not implemented!"); |
| 240 | } | ||
| 241 | |||
| 242 | return (u16)data; | ||
| 242 | } | 243 | } |
| 243 | 244 | ||
| 244 | u64 Read64(const u32 addr) { | 245 | u32 Read32(const u32 addr) { |
| 245 | u64_le _var = 0; | 246 | u32_le data = 0; |
| 246 | Read<u64_le>(_var, addr); | 247 | Read<u32_le>(data, addr); |
| 247 | return _var; | 248 | |
| 249 | // Check for 32-bit unaligned memory reads... | ||
| 250 | if (addr & 3) { | ||
| 251 | // ARM allows for unaligned memory reads, however older ARM architectures read out memory | ||
| 252 | // from unaligned addresses in a shifted way. Our ARM CPU core (SkyEye) corrects for this, | ||
| 253 | // so therefore expects the memory to be read out in this manner. | ||
| 254 | // TODO(bunnei): Determine if this is necessary - perhaps it is OK to remove this from both | ||
| 255 | // SkyEye and here? | ||
| 256 | int shift = (addr & 3) * 8; | ||
| 257 | data = (data << shift) | (data >> (32 - shift)); | ||
| 258 | } | ||
| 259 | return (u32)data; | ||
| 248 | } | 260 | } |
| 249 | 261 | ||
| 250 | u32 Read8_ZX(const u32 addr) { | 262 | u32 Read8_ZX(const u32 addr) { |