summaryrefslogtreecommitdiff
path: root/src/core/mem_map_funcs.cpp
diff options
context:
space:
mode:
authorGravatar bunnei2014-08-17 20:30:30 -0400
committerGravatar bunnei2014-08-17 20:30:30 -0400
commit7ed73af78fb1b8e736b7807633875b3fe05474e6 (patch)
tree6ab8ab1f459d87da940fb9551ed152402a7c1976 /src/core/mem_map_funcs.cpp
parentMerge pull request #54 from lioncash/fmt (diff)
parentCore: Fix undefined behavior in mem_map_funcs' WriteBlock function (diff)
downloadyuzu-7ed73af78fb1b8e736b7807633875b3fe05474e6.tar.gz
yuzu-7ed73af78fb1b8e736b7807633875b3fe05474e6.tar.xz
yuzu-7ed73af78fb1b8e736b7807633875b3fe05474e6.zip
Merge pull request #53 from lioncash/memmap
Core: Fix undefined behavior in mem_map_funcs' WriteBlock function
Diffstat (limited to 'src/core/mem_map_funcs.cpp')
-rw-r--r--src/core/mem_map_funcs.cpp12
1 files changed, 8 insertions, 4 deletions
diff --git a/src/core/mem_map_funcs.cpp b/src/core/mem_map_funcs.cpp
index 5772cca52..ecdaa06d7 100644
--- a/src/core/mem_map_funcs.cpp
+++ b/src/core/mem_map_funcs.cpp
@@ -289,11 +289,15 @@ void Write64(const u32 addr, const u64 data) {
289 289
290void WriteBlock(const u32 addr, const u8* data, const int size) { 290void WriteBlock(const u32 addr, const u8* data, const int size) {
291 int offset = 0; 291 int offset = 0;
292 while (offset < (size & ~3)) 292 while (offset < (size & ~3)) {
293 Write32(addr + offset, *(u32*)&data[offset += 4]); 293 Write32(addr + offset, *(u32*)&data[offset]);
294 offset += 4;
295 }
294 296
295 if (size & 2) 297 if (size & 2) {
296 Write16(addr + offset, *(u16*)&data[offset += 2]); 298 Write16(addr + offset, *(u16*)&data[offset]);
299 offset += 2;
300 }
297 301
298 if (size & 1) 302 if (size & 1)
299 Write8(addr + offset, data[offset]); 303 Write8(addr + offset, data[offset]);