summaryrefslogtreecommitdiff
path: root/tests/test-alignalloc.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test-alignalloc.c')
-rw-r--r--tests/test-alignalloc.c40
1 files changed, 23 insertions, 17 deletions
diff --git a/tests/test-alignalloc.c b/tests/test-alignalloc.c
index 161ab384db..eccaea0e68 100644
--- a/tests/test-alignalloc.c
+++ b/tests/test-alignalloc.c
@@ -29,26 +29,32 @@ SIGNATURE_CHECK (alignfree, void, (void *));
#include "macros.h"
-int
-main ()
+static void
+test_alignalloc (idx_t alignment, idx_t size)
{
- /* Check that alignalloc returns properly aligned storage,
- when it succeeds. */
- for (idx_t alignment = 1; ; )
+ void *p = alignalloc (alignment, size);
+ if (p)
{
- for (idx_t size = 0; size <= 1024; size = size ? 2 * size : 1)
- {
- void *p = alignalloc (alignment, size);
- if (p)
- {
- memset (p, 0, size);
- ASSERT ((uintptr_t) p % alignment == 0);
- }
- alignfree (p);
- }
- if (INT_MULTIPLY_WRAPV (alignment, 2, &alignment))
- break;
+ memset (p, 0, size);
+ ASSERT ((uintptr_t) p % alignment == 0);
}
+ alignfree (p);
+}
+
+int
+main ()
+{
+ /* Check that alignalloc returns properly aligned storage when it succeeds.
+ Stop at 16 MiB alignments because circa-2022 AddressSanitizer goes
+ catatonic with large alignments in posix_memalign,
+ and there seems to be little point to testing them. */
+ for (idx_t alignment = 1; alignment <= 16 * 1024 * 1024; alignment *= 2)
+ for (idx_t size = 1; size <= 1024; size *= 2)
+ {
+ test_alignalloc (alignment, size - 1);
+ test_alignalloc (alignment, size);
+ test_alignalloc (alignment, size + 1);
+ }
/* Check that alignfree is a no-op on null pointers. */
alignfree (NULL);