/* TEST_HEADER id = $HopeName: MMQA_test_function!154.c(trunk.1) $ summary = EPVM allocate and epvm_collect, once only language = c link = testlib.o epvmfmt.o END_HEADER */ #include "testlib.h" #include "mpscepvm.h" #include "mpsavm.h" #include "epvmfmt.h" #define MAX_SAVE 1000 #define INIT_SAVE 12 void *stackpointer; static void test(void) { mps_arena_t arena; mps_thr_t thread; mps_fmt_t format; mps_pool_t pool1; mps_ap_t ap1s; int j; psobj *a; /* create an arena that can't grow beyond 64M */ cdie(mps_arena_create(&arena, mps_arena_class_vm(), (size_t) (1024*1024*64)), "create arena"); cdie(mps_thread_reg(&thread, arena), "register thread"); cdie(mps_fmt_create_A(&format, arena, &fmtepvm), "create format"); cdie(mps_pool_create(&pool1, arena, mps_class_epvm(), format, MAX_SAVE, INIT_SAVE), "create pool1"); cdie(mps_ap_create(&ap1s, pool1, 0), "create ap1s"); for (j=0; j<3000; j++) { a = allocepvm(ap1s, (size_t) (8+8*ranint(500))); } comment("collecting..."); mps_epvm_collect(pool1); mps_ap_destroy(ap1s); mps_pool_destroy(pool1); mps_fmt_destroy(format); mps_thread_dereg(thread); mps_arena_destroy(arena); comment("Destroyed arena"); } int main(void) { void *m; stackpointer=&m; easy_tramp(test); pass(); return 0; }