diff options
author | Nikolay Korolev <nickvnuk@gmail.com> | 2020-05-16 22:09:34 +0200 |
---|---|---|
committer | Nikolay Korolev <nickvnuk@gmail.com> | 2020-05-16 22:09:34 +0200 |
commit | 5c8888d2edb4f77a30ca52c5a48669d937ae9ef2 (patch) | |
tree | 62c1274fc38820d2f2037ae6dab48576439b1ed2 /src/rw/RwHelper.cpp | |
parent | more script stuff (diff) | |
parent | Merge branch 'master' into miami (diff) | |
download | re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.tar re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.tar.gz re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.tar.bz2 re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.tar.lz re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.tar.xz re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.tar.zst re3-5c8888d2edb4f77a30ca52c5a48669d937ae9ef2.zip |
Diffstat (limited to '')
-rw-r--r-- | src/rw/RwHelper.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/rw/RwHelper.cpp b/src/rw/RwHelper.cpp index 91916df3..a87874d7 100644 --- a/src/rw/RwHelper.cpp +++ b/src/rw/RwHelper.cpp @@ -60,6 +60,16 @@ void FlushObrsPrintfs() void * RwMallocAlign(RwUInt32 size, RwUInt32 align) { +#ifdef FIX_BUGS + uintptr ptralign = align-1; + void *mem = (void *)malloc(size + sizeof(uintptr) + ptralign); + + ASSERT(mem != nil); + + void *addr = (void *)((((uintptr)mem) + sizeof(uintptr) + ptralign) & ~ptralign); + + ASSERT(addr != nil); +#else void *mem = (void *)malloc(size + align); ASSERT(mem != nil); @@ -67,6 +77,7 @@ RwMallocAlign(RwUInt32 size, RwUInt32 align) void *addr = (void *)((((uintptr)mem) + align) & ~(align - 1)); ASSERT(addr != nil); +#endif *(((void **)addr) - 1) = mem; |