aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar bunnei <bunneidev@gmail.com>2014-08-05 20:09:04 -0400
committerGravatar bunnei <bunneidev@gmail.com>2014-08-05 20:09:04 -0400
commit90aaab1df0fe0a0518200c71df6ebe1bcf8eb783 (patch)
tree437b0b82227c54f45212dd200885698311089064
parent8a9f155f29a1e49cf461370c23a69c297ee60778 (diff)
parent967e5629de4ffb49a193e73df388efae7b3eaa43 (diff)
Merge pull request #36 from bunnei/fix-memory-unaligned-reads
Fix memory unaligned reads
-rw-r--r--src/core/hle/service/fs.h2
-rw-r--r--src/core/mem_map_funcs.cpp42
2 files changed, 28 insertions, 16 deletions
diff --git a/src/core/hle/service/fs.h b/src/core/hle/service/fs.h
index 34b0610a..fabf5ac7 100644
--- a/src/core/hle/service/fs.h
+++ b/src/core/hle/service/fs.h
@@ -24,7 +24,7 @@ public:
* @return Port name of service
*/
const char *GetPortName() const {
- return "Ufs:";
+ return "fs:USER";
}
};
diff --git a/src/core/mem_map_funcs.cpp b/src/core/mem_map_funcs.cpp
index 0342122d..038d3bff 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) {
}
u8 Read8(const u32 addr) {
- u8 _var = 0;
- Read<u8>(_var, addr);
- return (u8)_var;
+ u8 data = 0;
+ Read<u8>(data, addr);
+ return (u8)data;
}
u16 Read16(const u32 addr) {
- u16_le _var = 0;
- Read<u16_le>(_var, addr);
- return (u16)_var;
-}
+ u16_le data = 0;
+ Read<u16_le>(data, addr);
-u32 Read32(const u32 addr) {
- u32_le _var = 0;
- Read<u32_le>(_var, addr);
- return _var;
+ // Check for 16-bit unaligned memory reads...
+ if (addr & 1) {
+ // TODO(bunnei): Implement 16-bit unaligned memory reads
+ ERROR_LOG(MEMMAP, "16-bit unaligned memory reads are not implemented!");
+ }
+
+ return (u16)data;
}
-u64 Read64(const u32 addr) {
- u64_le _var = 0;
- Read<u64_le>(_var, addr);
- return _var;
+u32 Read32(const u32 addr) {
+ u32_le data = 0;
+ Read<u32_le>(data, addr);
+
+ // Check for 32-bit unaligned memory reads...
+ if (addr & 3) {
+ // ARM allows for unaligned memory reads, however older ARM architectures read out memory
+ // from unaligned addresses in a shifted way. Our ARM CPU core (SkyEye) corrects for this,
+ // so therefore expects the memory to be read out in this manner.
+ // TODO(bunnei): Determine if this is necessary - perhaps it is OK to remove this from both
+ // SkyEye and here?
+ int shift = (addr & 3) * 8;
+ data = (data << shift) | (data >> (32 - shift));
+ }
+ return (u32)data;
}
u32 Read8_ZX(const u32 addr) {