aboutsummaryrefslogtreecommitdiffstats
path: root/allocn.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2024-08-18 09:58:23 +0200
committerMattias Andrée <maandree@kth.se>2024-08-18 09:58:23 +0200
commita69f0f613687edf6c1f1ee83b462f77e8ea3c9a9 (patch)
treed976683461a0f427d2f1ef79a8732a048dd0c67b /allocn.c
parentMerge tag '1.3' into since (diff)
parentUpdate VERSION_MINOR (diff)
downloadlibsimple-a69f0f613687edf6c1f1ee83b462f77e8ea3c9a9.tar.gz
libsimple-a69f0f613687edf6c1f1ee83b462f77e8ea3c9a9.tar.bz2
libsimple-a69f0f613687edf6c1f1ee83b462f77e8ea3c9a9.tar.xz
Merge tag '1.4' into since
Version 1.4
Diffstat (limited to '')
-rw-r--r--allocn.c65
1 files changed, 2 insertions, 63 deletions
diff --git a/allocn.c b/allocn.c
index ce4fbad..fabedfa 100644
--- a/allocn.c
+++ b/allocn.c
@@ -1,5 +1,5 @@
/* See LICENSE file for copyright and license details. */
-#include "libsimple.h"
+#include "common.h"
#ifndef TEST
@@ -78,7 +78,7 @@ int
main(void)
{
struct allocinfo *info;
- void *ptr, *old;
+ void *ptr;
assert(!libsimple_malloczn(0, 0) && errno == EINVAL);
errno = 0;
@@ -88,17 +88,12 @@ main(void)
errno = 0;
assert(!libsimple_callocn(0) && errno == EINVAL);
errno = 0;
- assert(!libsimple_reallocn(NULL, 0) && errno == EINVAL);
- errno = 0;
assert(!libsimple_aligned_alloczn(0, 128, 0) && errno == EINVAL);
errno = 0;
assert(!libsimple_aligned_alloczn(1, 128, 0) && errno == EINVAL);
errno = 0;
assert(!libsimple_aligned_allocn(128, 0) && errno == EINVAL);
errno = 0;
- assert(libsimple_posix_memalignzn(&ptr, 0, 128, 0) == EINVAL && !errno);
- assert(libsimple_posix_memalignzn(&ptr, 1, 128, 0) == EINVAL && !errno);
- assert(libsimple_posix_memalignn(&ptr, 128, 0) == EINVAL && !errno);
assert(!libsimple_malloczn(0, SIZE_MAX, 2, 0) && errno == ENOMEM);
errno = 0;
@@ -108,17 +103,12 @@ main(void)
errno = 0;
assert(!libsimple_callocn(SIZE_MAX, 2, 0) && errno == ENOMEM);
errno = 0;
- assert(!libsimple_reallocn(NULL, SIZE_MAX, 2, 0) && errno == ENOMEM);
- errno = 0;
assert(!libsimple_aligned_alloczn(0, 1024, SIZE_MAX, 2, 0) && errno == ENOMEM);
errno = 0;
assert(!libsimple_aligned_alloczn(1, 1024, SIZE_MAX, 2, 0) && errno == ENOMEM);
errno = 0;
assert(!libsimple_aligned_allocn(1024, SIZE_MAX, 2, 0) && errno == ENOMEM);
errno = 0;
- assert(libsimple_posix_memalignzn(&ptr, 0, 1024, SIZE_MAX, 2, 0) == ENOMEM && !errno);
- assert(libsimple_posix_memalignzn(&ptr, 1, 1024, SIZE_MAX, 2, 0) == ENOMEM && !errno);
- assert(libsimple_posix_memalignn(&ptr, 1024, SIZE_MAX, 2, 0) == ENOMEM && !errno);
assert((ptr = libsimple_malloczn(0, 10, 10, 0)));
if (have_custom_malloc()) {
@@ -156,27 +146,6 @@ main(void)
}
free(ptr);
- assert((ptr = libsimple_reallocn(NULL, 5, 0)));
- if (have_custom_malloc()) {
- assert((info = get_allocinfo(ptr)));
- assert(info->size == 5);
- assert(!info->zeroed);
- info->refcount += 1;
- assert(!((uintptr_t)ptr % (uintptr_t)(info->alignment)));
- }
- stpcpy(ptr, "test");
- assert((ptr = libsimple_reallocn(old = ptr, 10, 0)));
- assert(!strcmp(ptr, "test"));
- if (have_custom_malloc()) {
- assert((info = get_allocinfo(ptr)));
- assert(info->size == 10);
- assert(!info->zeroed);
- assert(!((uintptr_t)ptr % (uintptr_t)(info->alignment)));
- assert(ptr != old);
- free(old);
- }
- free(ptr);
-
assert((ptr = libsimple_aligned_alloczn(0, 8, 12, 12, 0)));
if (have_custom_malloc()) {
assert((info = get_allocinfo(ptr)));
@@ -207,36 +176,6 @@ main(void)
}
free(ptr);
- assert(!libsimple_posix_memalignzn(&ptr, 0, sizeof(void *), 12, 12, 0));
- if (have_custom_malloc()) {
- assert((info = get_allocinfo(ptr)));
- assert(info->size == 144);
- assert(info->alignment == sizeof(void *));
- assert(!info->zeroed);
- assert(!((uintptr_t)ptr % (uintptr_t)(info->alignment)));
- }
- free(ptr);
-
- assert(!libsimple_posix_memalignzn(&ptr, 1, 2 * sizeof(void *), 12, 12, 2, 0));
- if (have_custom_malloc()) {
- assert((info = get_allocinfo(ptr)));
- assert(info->size == 288);
- assert(info->alignment == 2 * sizeof(void *));
- assert(info->zeroed == 288);
- assert(!((uintptr_t)ptr % (uintptr_t)(info->alignment)));
- }
- free(ptr);
-
- assert(!libsimple_posix_memalignn(&ptr, 2 * sizeof(void *), 12, 12, 3, 0));
- if (have_custom_malloc()) {
- assert((info = get_allocinfo(ptr)));
- assert(info->size == 432);
- assert(info->alignment == 2 * sizeof(void *));
- assert(!info->zeroed);
- assert(!((uintptr_t)ptr % (uintptr_t)(info->alignment)));
- }
- free(ptr);
-
assert(!errno);
return 0;