mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-01-15 01:29:11 +08:00
relax restriction of size to be an integral multiple of the alignment in 'alloc_aligned' as too many programs need this; see PR #584
This commit is contained in:
parent
3ad4639aea
commit
65eb5c65ec
@ -83,13 +83,16 @@ mi_decl_nodiscard mi_decl_restrict void* mi_pvalloc(size_t size) mi_attr_noexcep
|
|||||||
}
|
}
|
||||||
|
|
||||||
mi_decl_nodiscard mi_decl_restrict void* mi_aligned_alloc(size_t alignment, size_t size) mi_attr_noexcept {
|
mi_decl_nodiscard mi_decl_restrict void* mi_aligned_alloc(size_t alignment, size_t size) mi_attr_noexcept {
|
||||||
if mi_unlikely((size&(alignment-1)) != 0) { // C11 requires alignment>0 && integral multiple, see <https://en.cppreference.com/w/c/memory/aligned_alloc>
|
// C11 requires the size to be an integral multiple of the alignment, see <https://en.cppreference.com/w/c/memory/aligned_alloc>.
|
||||||
#if MI_DEBUG > 0
|
// unfortunately, it turns out quite some programs pass a size that is not an integral multiple so skip this check..
|
||||||
_mi_error_message(EOVERFLOW, "(mi_)aligned_alloc requires the size to be an integral multiple of the alignment (size %zu, alignment %zu)\n", size, alignment);
|
/* if mi_unlikely((size & (alignment - 1)) != 0) { // C11 requires alignment>0 && integral multiple, see <https://en.cppreference.com/w/c/memory/aligned_alloc>
|
||||||
#endif
|
#if MI_DEBUG > 0
|
||||||
return NULL;
|
_mi_error_message(EOVERFLOW, "(mi_)aligned_alloc requires the size to be an integral multiple of the alignment (size %zu, alignment %zu)\n", size, alignment);
|
||||||
}
|
#endif
|
||||||
// C11 also requires alignment to be a power-of-two which is checked in mi_malloc_aligned
|
return NULL;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
// C11 also requires alignment to be a power-of-two (and > 0) which is checked in mi_malloc_aligned
|
||||||
void* p = mi_malloc_aligned(size, alignment);
|
void* p = mi_malloc_aligned(size, alignment);
|
||||||
mi_assert_internal(((uintptr_t)p % alignment) == 0);
|
mi_assert_internal(((uintptr_t)p % alignment) == 0);
|
||||||
return p;
|
return p;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user