* Added ikrt_register_guardian_pair to replace ikrt_register_guardian.

This commit is contained in:
Abdulaziz Ghuloum 2007-09-01 01:00:35 -04:00
parent 5667428e70
commit 4daea5e4e0
4 changed files with 105 additions and 110 deletions

Binary file not shown.

View File

@ -79,7 +79,7 @@ typedef struct gc_t{
ikp tconc_ep; ikp tconc_ep;
ikp tconc_base; ikp tconc_base;
ikpages* tconc_queue; ikpages* tconc_queue;
ik_guardian_table* final_guardians; //ik_guardian_table* final_guardians;
} gc_t; } gc_t;
static unsigned int static unsigned int
@ -581,76 +581,94 @@ is_live(ikp x, gc_t* gc){
return 0; return 0;
} }
static ik_guardian_table*
move_guardian(ikp tc, ikp obj, ik_guardian_table* t){
if(t && (t->count < ik_guardian_table_size)){
ik_guardian_pair* p = &t->p[t->count];
p->tc = tc;
p->obj = obj;
t->count++;
return t;
} else {
ik_guardian_table* nt =
(ik_guardian_table*)ik_mmap(sizeof(ik_guardian_table));
nt->next = t;
nt->count = 1;
nt->p[0].tc = tc;
nt->p[0].obj = obj;
return nt;
}
}
static inline int static inline int
next_gen(int i){ next_gen(int i){
return ((i == generation_count) ? generation_count : (i+1)); return ((i == generation_count) ? generation_count : (i+1));
} }
static ik_ptr_page*
move_guarded(ikp x, ik_ptr_page* dst){
if((dst == 0) || (dst->count == ik_ptr_page_size)){
ik_ptr_page* y = ik_mmap(sizeof(ik_ptr_page));
y->count = 0;
y->next = dst;
dst = y;
}
dst->ptr[dst->count++] = x;
return dst;
}
static void static void
forward_guardians(gc_t* gc){ forward_guardians(gc_t* gc){
ikpcb* pcb = gc->pcb; ikpcb* pcb = gc->pcb;
int gen; int gen;
ik_ptr_page* forward_list[generation_count];
for(gen = gc->collect_gen; gen>=0; gen--){ for(gen = gc->collect_gen; gen>=0; gen--){
/* must move backwards from older to younger generations */ /* must move backwards from older to younger generations */
ikp todo = pcb->guardians[gen]; ik_ptr_page* todo = pcb->guardians[gen];
pcb->guardians[gen] = null_object; pcb->guardians[gen] = 0;
ikp forward = pcb->guardians[next_gen(gen)]; ik_ptr_page* forward = 0;
ikp dropped = null_object; ik_ptr_page* dropped = 0;
while(todo != null_object){ while(todo){
ikp next = ref(todo, off_cdr); int i;
ikp a = ref(todo, off_car); int n = todo->count;
/* ikp tc = ref(a, off_car); */ for(i=0; i<n; i++){
ikp a = todo->ptr[i];
ikp obj = ref(a, off_cdr); ikp obj = ref(a, off_cdr);
if(is_live(obj, gc)){ if(is_live(obj, gc)){
ref(todo, off_cdr) = forward; forward = move_guarded(a, forward);
forward = todo;
} else { } else {
ref(todo, off_cdr) = dropped; dropped = move_guarded(a, dropped);
dropped = todo;
} }
}
ik_ptr_page* next = todo->next;
ik_munmap(todo, sizeof(ik_ptr_page));
todo = next; todo = next;
} }
pcb->guardians[next_gen(gen)] = forward; forward_list[gen] = forward;
pcb->guardians_dropped[gen] = dropped; pcb->guardians_dropped[gen] = dropped;
} }
for(gen = next_gen(gc->collect_gen); gen>=0; gen--){ for(gen=0; gen<=gc->collect_gen; gen++){
pcb->guardians[gen] = add_object(gc, pcb->guardians[gen], "guardians"); ik_ptr_page* src = forward_list[gen];
ik_ptr_page* dst = pcb->guardians[next_gen(gen)];
while(src){
int i;
int n = src->count;
for(i=0; i<n; i++){
ikp a = add_object(gc, src->ptr[i], "prot");
dst = move_guarded(a, dst);
}
ik_ptr_page* next = src->next;
ik_munmap(src, sizeof(ik_ptr_page));
src = next;
}
pcb->guardians[next_gen(gen)] = dst;
}
for(gen = 0; gen<=gc->collect_gen; gen++){
ik_ptr_page* src = pcb->guardians_dropped[gen];
while(src){
int i;
int n = src->count;
for(i=0; i<n; i++){
src->ptr[i] = add_object(gc, src->ptr[i], "prot");
}
src = src->next;
} }
for(gen = gc->collect_gen; gen>=0; gen--){
pcb->guardians_dropped[gen] =
add_object(gc, pcb->guardians_dropped[gen], "guardians dropped");
} }
} }
static void static void
empty_dropped_guardians(gc_t* gc){ empty_dropped_guardians(gc_t* gc){
ikpcb* pcb = gc->pcb; ikpcb* pcb = gc->pcb;
int gen; int gen;
for(gen = gc->collect_gen; gen>=0; gen--){ for(gen = 0; gen<=gc->collect_gen; gen++){
ikp ls = pcb->guardians_dropped[gen]; ik_ptr_page* src = pcb->guardians_dropped[gen];
while(ls != null_object){ while(src){
ikp next = ref(ls, off_cdr); int i;
ikp a = ref(ls, off_car); int n = src->count;
for(i=0; i<n; i++){
ikp a = src->ptr[i];
ikp tc = ref(a, off_car); ikp tc = ref(a, off_car);
ikp obj = ref(a, off_cdr); ikp obj = ref(a, off_cdr);
assert(tagof(tc) == pair_tag); assert(tagof(tc) == pair_tag);
@ -663,9 +681,12 @@ empty_dropped_guardians(gc_t* gc){
ref(tc, off_cdr) = a; ref(tc, off_cdr) = a;
pcb->dirty_vector[page_index(tc)] = -1; pcb->dirty_vector[page_index(tc)] = -1;
pcb->dirty_vector[page_index(d)] = -1; pcb->dirty_vector[page_index(d)] = -1;
ls = next;
} }
pcb->guardians_dropped[gen] = null_object; ik_ptr_page* next = src->next;
ik_munmap(src, sizeof(ik_ptr_page));
src = next;
}
pcb->guardians_dropped[gen] = 0;
} }
} }

View File

@ -264,14 +264,6 @@ ikpcb* ik_make_pcb(){
ikpcb* pcb = ik_malloc(sizeof(ikpcb)); ikpcb* pcb = ik_malloc(sizeof(ikpcb));
bzero(pcb, sizeof(ikpcb)); bzero(pcb, sizeof(ikpcb));
pcb->collect_key = false_object; pcb->collect_key = false_object;
{
int i;
for(i=0; i<generation_count; i++){
pcb->guardians[i] = null_object;
pcb->guardians_forward[i] = null_object;
pcb->guardians_dropped[i] = null_object;
}
}
#define HEAPSIZE (1024 * 4096) #define HEAPSIZE (1024 * 4096)
#define STAKSIZE (1024 * 4096) #define STAKSIZE (1024 * 4096)
//#define STAKSIZE (256 * 4096) //#define STAKSIZE (256 * 4096)
@ -893,40 +885,27 @@ ikrt_write_char(){
#if 0
ikp ikp
ikrt_register_guardian(ikp tc, ikp obj, ikpcb* pcb){ ikrt_register_guardian_pair(ikp p0, ikpcb* pcb){
ik_guardian_table* g = pcb->guardians[0]; ik_ptr_page* x = pcb->guardians[0];
if((!g) || (g->count == ik_guardian_table_size)){ if((x == NULL) || (x->count == ik_ptr_page_size)){
if(sizeof(ik_guardian_table) != pagesize){ assert(sizeof(ik_ptr_page) == pagesize);
fprintf(stderr, "ERR: invalid guardian table size\n"); ik_ptr_page* y = ik_mmap(pagesize);
exit(-1); y->count = 0;
y->next = x;
pcb->guardians[0] = y;
x = y;
} }
ik_guardian_table* p = x->ptr[x->count++] = p0;
(ik_guardian_table*)ik_mmap(sizeof(ik_guardian_table)); return void_object;
p->next = g;
p->count = 0;
pcb->guardians[0] = p;
g=p;
}
ik_guardian_pair* p = &(g->p[g->count]);
p->tc = tc;
p->obj = obj;
g->count++;
return 0;
} }
#endif
ikp ikp
ikrt_register_guardian(ikp tc, ikp obj, ikpcb* pcb){ ikrt_register_guardian(ikp tc, ikp obj, ikpcb* pcb){
ikp p0 = ik_alloc(pcb, pair_size) + pair_tag; ikp p0 = ik_alloc(pcb, pair_size) + pair_tag;
ikp p1 = ik_alloc(pcb, pair_size) + pair_tag;
ref(p0, off_car) = tc; ref(p0, off_car) = tc;
ref(p0, off_cdr) = obj; ref(p0, off_cdr) = obj;
ref(p1, off_car) = p0; return ikrt_register_guardian_pair(p0, pcb);
ref(p1, off_cdr) = pcb->guardians[0];
pcb->guardians[0] = p1;
return void_object;
} }

View File

@ -90,19 +90,15 @@ typedef struct ikdl{ /* double-link */
struct ikdl* next; struct ikdl* next;
} ikdl; } ikdl;
typedef struct ik_guardian_pair{
ikp tc;
ikp obj;
} ik_guardian_pair;
#define ik_guardian_table_size \ #define ik_ptr_page_size \
((pagesize - sizeof(int) - sizeof(struct ik_guardian_table*))/sizeof(ik_guardian_pair)) ((pagesize - sizeof(int) - sizeof(struct ik_ptr_page*))/sizeof(ikp))
typedef struct ik_guardian_table{ typedef struct ik_ptr_page{
int count; int count;
struct ik_guardian_table* next; struct ik_ptr_page* next;
ik_guardian_pair p[ik_guardian_table_size]; ikp ptr[ik_ptr_page_size];
} ik_guardian_table; } ik_ptr_page;
typedef struct ikpcb{ typedef struct ikpcb{
@ -135,9 +131,8 @@ typedef struct ikpcb{
int stack_size; int stack_size;
ikp symbol_table; ikp symbol_table;
ikp gensym_table; ikp gensym_table;
ikp guardians[generation_count]; ik_ptr_page* guardians[generation_count];
ikp guardians_forward[generation_count]; ik_ptr_page* guardians_dropped[generation_count];
ikp guardians_dropped[generation_count];
unsigned int* dirty_vector_base; unsigned int* dirty_vector_base;
unsigned int* segment_vector_base; unsigned int* segment_vector_base;
unsigned char* memory_base; unsigned char* memory_base;