From: Jay Freeman (saurik) Date: Wed, 23 Dec 2015 02:01:08 +0000 (+0000) Subject: Both tighten and correct alignment of pool malloc. X-Git-Tag: v0.9.590~154 X-Git-Url: https://git.saurik.com/cycript.git/commitdiff_plain/91fb60bf73ee8872552b4e80ca258e946f2550b0 Both tighten and correct alignment of pool malloc. --- diff --git a/Execute.cpp b/Execute.cpp index 6581ee1..af61f1a 100644 --- a/Execute.cpp +++ b/Execute.cpp @@ -890,11 +890,6 @@ static bool CString_setProperty(JSContextRef context, JSObjectRef object, JSStri return true; } CYCatch(false) } -template -static void Align(Type_ &data, size_t size) { - data = reinterpret_cast((reinterpret_cast(data) + (size - 1)) & ~(size - 1)); -} - static bool Index_(CYPool &pool, JSContextRef context, Struct_privateData *internal, JSStringRef property, ssize_t &index, uint8_t *&base) { Type_privateData *typical(internal->type_); sig::Type *type(typical->type_); @@ -931,13 +926,13 @@ static bool Index_(CYPool &pool, JSContextRef context, Struct_privateData *inter base: ffi_type **elements(typical->GetFFI()->elements); - base = reinterpret_cast(internal->value_); + size_t offset(0); for (ssize_t local(0); local != index; ++local) { - Align(base, elements[local]->alignment); - base += elements[local]->size; + offset += elements[local]->size; + CYAlign(offset, elements[local + 1]->alignment); } - Align(base, elements[index]->alignment); + base = reinterpret_cast(internal->value_) + offset; return true; } diff --git a/Pooling.hpp b/Pooling.hpp index 78aa1b2..3af05ac 100644 --- a/Pooling.hpp +++ b/Pooling.hpp @@ -35,6 +35,14 @@ #include "Local.hpp" #include "Standard.hpp" +// XXX: std::aligned_storage and alignof +static const size_t CYAlignment(sizeof(void *)); + +template +static void CYAlign(Type_ &data, size_t size) { + data = reinterpret_cast((reinterpret_cast(data) + (size - 1)) & ~static_cast(size - 1)); +} + class CYPool; _finline void *operator new(size_t size, CYPool &pool); _finline void *operator new [](size_t size, CYPool &pool); @@ -58,11 +66,6 @@ class CYPool { } } *cleaner_; - static _finline size_t align(size_t size) { - // XXX: alignment is more complex than this - return (size + 7) & ~0x3; - } - template static void delete_(void *data) { reinterpret_cast(data)->~Type_(); @@ -88,20 +91,27 @@ class CYPool { } template - Type_ *malloc(size_t size) { - size = align(size); - - if (size > size_) { - size_ = std::max(next_, size + align(sizeof(Cleaner))); + Type_ *malloc(size_t size, size_t alignment = CYAlignment) { + uint8_t *end(data_); + CYAlign(end, alignment); + end += size; + + if (size_t(end - data_) > size_) { + size_t need(sizeof(Cleaner)); + CYAlign(need, alignment); + need += size; + size_ = std::max(next_, need); next_ *= 2; data_ = reinterpret_cast(::malloc(size_)); atexit(free, data_); _assert(size <= size_); } - void *data(data_); - data_ += size; - size_ -= size; + uint8_t *data(data_); + CYAlign(data, alignment); + end = data + size; + size_ -= end - data_; + data_ = end; return reinterpret_cast(data); } @@ -112,8 +122,8 @@ class CYPool { } template - Type_ *memdup(const Type_ *data, size_t size) { - Type_ *copy(malloc(size)); + Type_ *memdup(const Type_ *data, size_t size, size_t alignment = CYAlignment) { + Type_ *copy(malloc(size, alignment)); memcpy(copy, data, size); return copy; } @@ -123,7 +133,7 @@ class CYPool { } char *strmemdup(const char *data, size_t size) { - char *copy(malloc(size + 1)); + char *copy(malloc(size + 1, 1)); memcpy(copy, data, size); copy[size] = '\0'; return copy; @@ -142,7 +152,7 @@ class CYPool { va_end(args); } - char *copy(malloc(size + 1)); { + char *copy(malloc(size + 1, 1)); { va_list args; va_start(args, data);