VM: Refactor to_tenured_collector.cpp/hpp to Factor style
parent
bd66094e1b
commit
93b586da31
|
@ -1,27 +1,22 @@
|
||||||
#include "master.hpp"
|
#include "master.hpp"
|
||||||
|
|
||||||
namespace factor
|
namespace factor {
|
||||||
{
|
|
||||||
|
|
||||||
to_tenured_collector::to_tenured_collector(factor_vm *parent_) :
|
to_tenured_collector::to_tenured_collector(factor_vm* parent_)
|
||||||
collector<tenured_space,to_tenured_policy>(
|
: collector<tenured_space, to_tenured_policy>(parent_,
|
||||||
parent_,
|
|
||||||
parent_->data->tenured,
|
parent_->data->tenured,
|
||||||
to_tenured_policy(parent_)) {}
|
to_tenured_policy(parent_)) {}
|
||||||
|
|
||||||
void to_tenured_collector::tenure_reachable_objects()
|
void to_tenured_collector::tenure_reachable_objects() {
|
||||||
{
|
|
||||||
std::vector<cell>* mark_stack = &parent->mark_stack;
|
std::vector<cell>* mark_stack = &parent->mark_stack;
|
||||||
while(!mark_stack->empty())
|
while (!mark_stack->empty()) {
|
||||||
{
|
|
||||||
cell ptr = mark_stack->back();
|
cell ptr = mark_stack->back();
|
||||||
mark_stack->pop_back();
|
mark_stack->pop_back();
|
||||||
this->trace_object((object*)ptr);
|
this->trace_object((object*)ptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void factor_vm::collect_to_tenured()
|
void factor_vm::collect_to_tenured() {
|
||||||
{
|
|
||||||
/* Copy live objects from aging space to tenured space. */
|
/* Copy live objects from aging space to tenured space. */
|
||||||
to_tenured_collector collector(this);
|
to_tenured_collector collector(this);
|
||||||
|
|
||||||
|
@ -32,15 +27,17 @@ void factor_vm::collect_to_tenured()
|
||||||
|
|
||||||
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_aging,
|
collector.trace_cards(data->tenured, card_points_to_aging, full_unmarker());
|
||||||
full_unmarker());
|
if (event)
|
||||||
if(event) event->ended_card_scan(collector.cards_scanned,collector.decks_scanned);
|
event->ended_card_scan(collector.cards_scanned, collector.decks_scanned);
|
||||||
|
|
||||||
if(event) event->started_code_scan();
|
if (event)
|
||||||
|
event->started_code_scan();
|
||||||
collector.trace_code_heap_roots(&code->points_to_aging);
|
collector.trace_code_heap_roots(&code->points_to_aging);
|
||||||
if(event) event->ended_code_scan(collector.code_blocks_scanned);
|
if (event)
|
||||||
|
event->ended_code_scan(collector.code_blocks_scanned);
|
||||||
|
|
||||||
collector.tenure_reachable_objects();
|
collector.tenure_reachable_objects();
|
||||||
|
|
||||||
|
|
|
@ -1,19 +1,17 @@
|
||||||
namespace factor
|
namespace factor {
|
||||||
{
|
|
||||||
|
|
||||||
struct to_tenured_policy {
|
struct to_tenured_policy {
|
||||||
factor_vm* parent;
|
factor_vm* parent;
|
||||||
tenured_space* tenured;
|
tenured_space* tenured;
|
||||||
|
|
||||||
explicit to_tenured_policy(factor_vm *parent_) : parent(parent_), tenured(parent->data->tenured) {}
|
explicit to_tenured_policy(factor_vm* parent_)
|
||||||
|
: parent(parent_), tenured(parent->data->tenured) {}
|
||||||
|
|
||||||
bool should_copy_p(object *untagged)
|
bool should_copy_p(object* untagged) {
|
||||||
{
|
|
||||||
return !tenured->contains_p(untagged);
|
return !tenured->contains_p(untagged);
|
||||||
}
|
}
|
||||||
|
|
||||||
void promoted_object(object *obj)
|
void promoted_object(object* obj) {
|
||||||
{
|
|
||||||
parent->mark_stack.push_back((cell) obj);
|
parent->mark_stack.push_back((cell) obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue