diff --git a/src/alloc-override.c b/src/alloc-override.c index e06a3e6e..b8172d50 100644 --- a/src/alloc-override.c +++ b/src/alloc-override.c @@ -135,7 +135,7 @@ int posix_memalign(void** p, size_t alignment, size_t size) { // TODO: the spec says we should return EINVAL also if alignment is not a power of 2. // The spec also dictates we should not modify `*p` on an error. (issue#27) // - if (alignment % sizeof(void*) != 0) return EINVAL; // no `p==NULL` check as it is declared as non-null + if ((alignment % sizeof(void*))||(alignment % 2 != 0) return EINVAL; // no `p==NULL` check as it is declared as non-null void* q = mi_malloc_aligned(size, alignment); if (q==NULL && size != 0) return ENOMEM; *p = q;