VM: Refactor nursery_* to Factor style

db4
Erik Charlebois 2013-05-11 22:16:22 -04:00
parent d57c1cc579
commit bac6919705
3 changed files with 41 additions and 49 deletions

View File

@ -1,45 +1,42 @@
#include "master.hpp" #include "master.hpp"
namespace factor namespace factor {
{
nursery_collector::nursery_collector(factor_vm *parent_) : nursery_collector::nursery_collector(factor_vm* parent_)
copying_collector<aging_space,nursery_policy>( : copying_collector<aging_space, nursery_policy>(parent_,
parent_, parent_->data->aging,
parent_->data->aging, nursery_policy(parent_)) {}
nursery_policy(parent_)) {}
void factor_vm::collect_nursery() void factor_vm::collect_nursery() {
{ /* Copy live objects from the nursery (as determined by the root set and
/* Copy live objects from the nursery (as determined by the root set and marked cards in aging and tenured) to aging space. */
marked cards in aging and tenured) to aging space. */ nursery_collector collector(this);
nursery_collector collector(this);
collector.trace_roots(); collector.trace_roots();
collector.trace_contexts(); collector.trace_contexts();
gc_event *event = current_gc->event; gc_event* event = current_gc->event;
if(event) event->started_card_scan(); if (event)
collector.trace_cards(data->tenured, event->started_card_scan();
card_points_to_nursery, collector.trace_cards(data->tenured, card_points_to_nursery,
simple_unmarker(card_points_to_nursery)); simple_unmarker(card_points_to_nursery));
if(data->aging->here != data->aging->start) if (data->aging->here != data->aging->start) {
{ collector.trace_cards(data->aging, card_points_to_nursery, full_unmarker());
collector.trace_cards(data->aging, }
card_points_to_nursery, if (event)
full_unmarker()); event->ended_card_scan(collector.cards_scanned, collector.decks_scanned);
}
if(event) event->ended_card_scan(collector.cards_scanned,collector.decks_scanned);
if(event) event->started_code_scan(); if (event)
collector.trace_code_heap_roots(&code->points_to_nursery); event->started_code_scan();
if(event) event->ended_code_scan(collector.code_blocks_scanned); collector.trace_code_heap_roots(&code->points_to_nursery);
if (event)
event->ended_code_scan(collector.code_blocks_scanned);
collector.cheneys_algorithm(); collector.cheneys_algorithm();
data->reset_generation(&nursery); data->reset_generation(&nursery);
code->points_to_nursery.clear(); code->points_to_nursery.clear();
} }
} }

View File

@ -1,23 +1,19 @@
namespace factor namespace factor {
{
struct nursery_policy { struct nursery_policy {
factor_vm *parent; factor_vm* parent;
explicit nursery_policy(factor_vm *parent_) : parent(parent_) {} explicit nursery_policy(factor_vm* parent_) : parent(parent_) {}
bool should_copy_p(object *obj) bool should_copy_p(object* obj) { return parent->nursery.contains_p(obj); }
{
return parent->nursery.contains_p(obj);
}
void promoted_object(object *obj) {} void promoted_object(object* obj) {}
void visited_object(object *obj) {} void visited_object(object* obj) {}
}; };
struct nursery_collector : copying_collector<aging_space,nursery_policy> { struct nursery_collector : copying_collector<aging_space, nursery_policy> {
explicit nursery_collector(factor_vm *parent_); explicit nursery_collector(factor_vm* parent_);
}; };
} }

View File

@ -1,9 +1,8 @@
namespace factor namespace factor {
{
struct nursery_space : bump_allocator<object> struct nursery_space : bump_allocator<object> {
{ explicit nursery_space(cell size, cell start)
explicit nursery_space(cell size, cell start) : bump_allocator<object>(size,start) {} : bump_allocator<object>(size, start) {}
}; };
} }