factor/vm/gc.hpp

56 lines
1.0 KiB
C++
Raw Normal View History

2013-05-11 22:04:08 -04:00
namespace factor {
2009-05-04 02:46:13 -04:00
struct must_start_gc_again {
};
enum gc_op {
2016-10-19 03:05:15 -04:00
COLLECT_NURSERY_OP,
COLLECT_AGING_OP,
COLLECT_TO_TENURED_OP,
COLLECT_FULL_OP,
COLLECT_COMPACT_OP,
COLLECT_GROWING_DATA_HEAP_OP
};
// These are the phases of the gc cycles we record the times of.
enum gc_phase {
PHASE_CARD_SCAN,
PHASE_CODE_SCAN,
PHASE_DATA_SWEEP,
PHASE_CODE_SWEEP,
PHASE_DATA_COMPACTION,
PHASE_MARKING
};
2009-10-26 23:12:44 -04:00
struct gc_event {
2013-05-11 22:04:08 -04:00
gc_op op;
data_heap_room data_heap_before;
allocator_room code_heap_before;
2013-05-11 22:04:08 -04:00
data_heap_room data_heap_after;
allocator_room code_heap_after;
2013-05-11 22:04:08 -04:00
cell cards_scanned;
cell decks_scanned;
cell code_blocks_scanned;
uint64_t start_time;
2013-05-11 22:04:08 -04:00
cell total_time;
cell times[6];
uint64_t temp_time;
2009-10-26 23:12:44 -04:00
gc_event(gc_op op, factor_vm* parent);
void reset_timer();
void ended_phase(gc_phase phase);
2013-05-11 22:04:08 -04:00
void ended_gc(factor_vm* parent);
2009-10-26 23:12:44 -04:00
};
struct gc_state {
2013-05-11 22:04:08 -04:00
gc_op op;
uint64_t start_time;
2013-05-11 22:04:08 -04:00
gc_event* event;
gc_state(gc_op op, factor_vm* parent);
2013-05-11 22:04:08 -04:00
~gc_state();
void start_again(gc_op op_, factor_vm* parent);
};
2009-05-04 02:46:13 -04:00
}