52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
#include "master.hpp"
 | 
						|
 | 
						|
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) {}
 | 
						|
};
 | 
						|
 | 
						|
void factor_vm::collect_nursery() {
 | 
						|
 | 
						|
  /* Copy live objects from the nursery (as determined by the root set and
 | 
						|
     marked cards in aging and tenured) to aging space. */
 | 
						|
  nursery_policy policy(this->data->nursery);
 | 
						|
  collector<aging_space, nursery_policy>
 | 
						|
      collector(this, this->data->aging, policy);
 | 
						|
 | 
						|
  collector.visitor.visit_all_roots();
 | 
						|
  gc_event* event = current_gc->event;
 | 
						|
 | 
						|
  if (event)
 | 
						|
    event->started_card_scan();
 | 
						|
  collector.trace_cards(data->tenured, card_points_to_nursery,
 | 
						|
                        card_points_to_nursery);
 | 
						|
  collector.trace_cards(data->aging, card_points_to_nursery, 0xff);
 | 
						|
 | 
						|
  if (event)
 | 
						|
    event->ended_card_scan(collector.cards_scanned, collector.decks_scanned);
 | 
						|
 | 
						|
  if (event)
 | 
						|
    event->started_code_scan();
 | 
						|
  collector.trace_code_heap_roots(&code->points_to_nursery);
 | 
						|
  if (event)
 | 
						|
    event->ended_code_scan(collector.code_blocks_scanned);
 | 
						|
 | 
						|
  collector.cheneys_algorithm();
 | 
						|
 | 
						|
  data->reset_nursery();
 | 
						|
  code->points_to_nursery.clear();
 | 
						|
}
 | 
						|
 | 
						|
}
 |