blob: 2cfb25076e19a1c9ff8f87c9c872833be6e67e2c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
#include <stdio.h>
#include "gc/leak_detector.h"
#define N_TESTS 100
int main(void) {
char *p[N_TESTS];
int i;
GC_set_find_leak(1); /* for new collect versions not compiled */
/* with -DFIND_LEAK. */
GC_INIT(); /* Needed if thread-local allocation is enabled. */
/* FIXME: This is not ideal. */
p[0] = (char *)_aligned_malloc(70 /* size */, 16);
if (!p[0]) {
fprintf(stderr, "Aligned allocation failed\n");
return 1;
}
_aligned_free(p[0]);
for (i = 0; i < N_TESTS; ++i) {
p[i] = i > 0 ? (char*)malloc(sizeof(int)+i)
: strdup("abc");
}
CHECK_LEAKS();
for (i = 3; i < N_TESTS / 2; ++i) {
p[i] = (char*)((i & 1) != 0 ? reallocarray(p[i], i, 43)
: realloc(p[i], i * 16 + 1));
}
CHECK_LEAKS();
for (i = 2; i < N_TESTS; ++i) {
free(p[i]);
}
for (i = 0; i < N_TESTS / 8; ++i) {
p[i] = i < 3 || i > 6 ? (char*)malloc(sizeof(int)+i)
: strndup("abcd", (unsigned)i);
}
CHECK_LEAKS();
CHECK_LEAKS();
CHECK_LEAKS();
printf("SUCCEEDED\n");
return 0;
}
|