factor/vm/tenured_space.hpp

42 lines
1014 B
C++

namespace factor {
struct tenured_space : free_list_allocator<object> {
object_start_map starts;
tenured_space(cell size, cell start)
: free_list_allocator<object>(size, start), starts(size, start) {}
object* allot(cell size) {
object* obj = free_list_allocator<object>::allot(size);
if (obj) {
starts.record_object_start_offset(obj);
return obj;
}
return NULL;
}
cell next_allocated_object_after(cell scan) {
while (scan != this->end && ((object*)scan)->free_p()) {
free_heap_block* free_block = (free_heap_block*)scan;
scan = (cell)free_block + free_block->size();
}
return scan == this->end ? 0 : scan;
}
cell first_object() {
return next_allocated_object_after(this->start);
}
cell next_object_after(cell scan) {
cell size = ((object*)scan)->size();
return next_allocated_object_after(scan + size);
}
void sweep() {
free_list_allocator<object>::sweep();
starts.update_for_sweep(&this->state);
}
};
}