factor/vm/nursery_collector.cpp

54 lines
1.4 KiB
C++
Raw Normal View History

#include "master.hpp"
2013-05-11 22:16:22 -04:00
namespace factor {
struct nursery_policy {
bump_allocator* nursery;
explicit nursery_policy(bump_allocator* nursery) : nursery(nursery) {}
bool should_copy_p(object* obj) {
return nursery->contains_p(obj);
}
void promoted_object(object* obj) {}
void visited_object(object* obj) {}
};
2013-05-11 22:16:22 -04:00
void factor_vm::collect_nursery() {
2013-05-11 22:16:22 -04:00
/* Copy live objects from the nursery (as determined by the root set and
marked cards in aging and tenured) to aging space. */
gc_workhorse<aging_space, nursery_policy>
workhorse(this, data->aging, nursery_policy(data->nursery));
slot_visitor<gc_workhorse<aging_space, nursery_policy>>
visitor(this, workhorse);
2013-05-11 22:16:22 -04:00
cell scan = data->aging->start + data->aging->occupied_space();
visitor.visit_all_roots();
2013-05-11 22:16:22 -04:00
gc_event* event = current_gc->event;
if (event)
event->reset_timer();
visitor.visit_cards(data->tenured, card_points_to_nursery,
card_points_to_nursery);
visitor.visit_cards(data->aging, card_points_to_nursery, 0xff);
if (event)
event->ended_card_scan(visitor.cards_scanned, visitor.decks_scanned);
2013-05-11 22:16:22 -04:00
if (event)
event->reset_timer();
visitor.visit_code_heap_roots(&code->points_to_nursery);
2013-05-11 22:16:22 -04:00
if (event)
event->ended_code_scan(code->points_to_nursery.size());
2013-05-11 22:16:22 -04:00
visitor.cheneys_algorithm(data->aging, scan);
2013-05-11 22:16:22 -04:00
data->reset_nursery();
2013-05-11 22:16:22 -04:00
code->points_to_nursery.clear();
}
}