diff options
| author | 2014-08-17 14:23:54 -0400 | |
|---|---|---|
| committer | 2014-08-17 14:23:54 -0400 | |
| commit | da18671166e096dc375da5c547c3be38de0493fb (patch) | |
| tree | 2963df3c0857fe35238fdafc99290abf9733e959 /src/core/mem_map_funcs.cpp | |
| parent | Merge pull request #47 from archshift/stdstring (diff) | |
| download | yuzu-da18671166e096dc375da5c547c3be38de0493fb.tar.gz yuzu-da18671166e096dc375da5c547c3be38de0493fb.tar.xz yuzu-da18671166e096dc375da5c547c3be38de0493fb.zip | |
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.cpp | 12 |
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 | ||
| 290 | void WriteBlock(const u32 addr, const u8* data, const int size) { | 290 | void 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]); |