-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.c
71 lines (63 loc) · 3.01 KB
/
test.c
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#define BLOCK_ALLOCATOR_IMPL
#include "block_allocator.h"
#define ROUNDS_COUNT 1000
#define ALLOCS_COUNT 300
#define ALLOC_MAX_SIZE (1024 * 1024 * 100)
void assert_allocator_layout_good(block_allocator_t *allocator) {
block_allocator_block_t block;
block_allocator_head(allocator, &block);
while (block.mem_next != BLOCK_ALLOCATOR_UNUSED) {
assert(allocator->blocks[block.mem_next].offset == (block.offset + block.size));
assert(block_allocator_is_used(&block) || block_allocator_is_used(&allocator->blocks[block.mem_next]));
assert(block.offset < block.offset + block.size);
block_allocator_block_t next_block;
block_allocator_next(allocator, &block, &next_block);
block = next_block;
}
}
int main() {
printf("Beginning validation of allocator\n");
block_allocator_t allocator;
block_allocator_init(1024 * 1024 * 1024, &allocator);
// Stack allocate an array to put allocation info into
block_allocator_allocation_t allocs[1000];
// Initialise the array with allocations
for (int i=0; i < ALLOCS_COUNT; i++) {
block_allocator_allocation_t alloc;
uint32_t size = 256 * (1 + (rand() % (ALLOC_MAX_SIZE/256)));
int res = block_allocator_alloc(&allocator, size, &alloc);
assert_allocator_layout_good(&allocator);
if (res == BLOCK_ALLOCATOR_SUCCESS) {
allocs[i] = alloc;
} else {
allocs[i].metadata = BLOCK_ALLOCATOR_UNUSED;
}
}
assert_allocator_layout_good(&allocator);
// Repeatedly free and allocate half of the allocations
for (int r = 0; r < ROUNDS_COUNT; r++) {
for (int i = 0; i < ALLOCS_COUNT / 2; i++) {
block_allocator_allocation_t old_alloc = allocs[2 * i + (r % 2)];
if (old_alloc.metadata == BLOCK_ALLOCATOR_UNUSED) { continue; }
block_allocator_free(&allocator, &old_alloc);
allocs[2 * i + (r % 2)].metadata = BLOCK_ALLOCATOR_UNUSED;
}
for (int i = 0; i < ALLOCS_COUNT / 2; i++) {
block_allocator_allocation_t new_alloc;
uint32_t size = 256 * (1 + (rand() % (ALLOC_MAX_SIZE/256)));
int res = block_allocator_alloc(&allocator, size, &new_alloc);
assert_allocator_layout_good(&allocator);
if (res == BLOCK_ALLOCATOR_SUCCESS) {
allocs[2 * i + (r % 2)] = new_alloc;
} else {
allocs[2 * i + (r % 2)].metadata = BLOCK_ALLOCATOR_UNUSED;
}
}
}
assert_allocator_layout_good(&allocator);
block_allocator_destroy(&allocator);
printf("Allocator integrity validated at all points\n");
}