1
1
mirror of https://github.com/anoma/juvix.git synced 2025-01-08 16:51:53 +03:00
juvix/tests/runtime/positive/test006.c
2022-11-03 09:38:09 +01:00

84 lines
2.1 KiB
C

/* Stack */
#include <juvix/mem/pages.h>
#include <juvix/mem/stack.h>
static unsigned long seed = 123456789UL;
static uint myrandom() {
return ((seed = seed * 214013L + 2531011L) >> 16) & 0x7fff;
}
#define N 1024
#define M (PAGE_SIZE / sizeof(word_t) + 16)
int main() {
DECL_STACK_POINTER;
juvix_stack_pointer = stack_init();
word_t *ptr = juvix_stack_pointer;
STACK_ENTER(1);
STACK_PUSH(3);
ASSERT(STACK_TOP == 3);
STACK_POPT;
STACK_LEAVE;
ASSERT(juvix_stack_pointer == ptr);
ASSERT(juvix_allocated_pages_num == 1);
for (uint i = 0; i < M; ++i) {
STACK_ENTER(3);
STACK_PUSH(1);
STACK_PUSH(2);
STACK_PUSH(3);
}
ASSERT(juvix_allocated_pages_num == juvix_max_allocated_pages_num);
ASSERT(juvix_allocated_pages_num == 4);
for (uint i = 0; i < M; ++i) {
ASSERT(STACK_TOP == 3);
STACK_POPT;
ASSERT(STACK_TOP == 2);
STACK_POPT;
ASSERT(STACK_TOP == 1);
STACK_POPT;
STACK_LEAVE;
}
ASSERT(juvix_stack_pointer == ptr);
ASSERT(juvix_allocated_pages_num == 1);
for (uint i = 0; i < M; ++i) {
STACK_ENTER(2);
STACK_PUSH(1);
STACK_PUSH(2);
}
ASSERT(juvix_max_allocated_pages_num == 4);
ASSERT(juvix_allocated_pages_num == 3);
for (uint i = 0; i < M; ++i) {
ASSERT(STACK_TOP == 2);
STACK_POPT;
ASSERT(STACK_TOP == 1);
STACK_POPT;
STACK_LEAVE;
}
ASSERT(juvix_stack_pointer == ptr);
ASSERT(juvix_allocated_pages_num == 1);
for (uint i = 0; i < N; ++i) {
uint n = myrandom() % MAX_STACK_DELTA + 1;
STACK_ENTER(n);
for (uint j = 0; j < n; ++j) {
STACK_PUSH(j);
}
STACK_PUSH(n);
}
ASSERT(juvix_allocated_pages_num == juvix_max_allocated_pages_num);
for (uint i = 0; i < N; ++i) {
uint n;
STACK_POP(n);
for (uint j = 0; j < n; ++j) {
uint k;
STACK_POP(k);
ASSERT(k == n - j - 1);
}
STACK_LEAVE;
}
ASSERT(juvix_stack_pointer == ptr);
ASSERT(juvix_allocated_pages_num == 1);
return 0;
}