< prev index next >

src/hotspot/share/gc/g1/g1ConcurrentMark.cpp

Print this page
rev 55281 : [mq]: 8225478-cmrootregions-cleanup

*** 255,297 **** _hwm = 0; _chunk_list = NULL; _free_list = NULL; } ! G1CMRootRegions::G1CMRootRegions(uint const max_regions) : ! _root_regions(NEW_C_HEAP_ARRAY(HeapRegion*, max_regions, mtGC)), _max_regions(max_regions), _num_root_regions(0), _claimed_root_regions(0), _scan_in_progress(false), ! _should_abort(false) { } ! G1CMRootRegions::~G1CMRootRegions() { ! FREE_C_HEAP_ARRAY(HeapRegion*, _max_regions); } ! void G1CMRootRegions::reset() { _num_root_regions = 0; } ! void G1CMRootRegions::add(HeapRegion* hr) { assert_at_safepoint(); size_t idx = Atomic::add((size_t)1, &_num_root_regions) - 1; ! assert(idx < _max_regions, "Trying to add more root regions than there is space " SIZE_FORMAT, _max_regions); ! _root_regions[idx] = hr; } ! void G1CMRootRegions::prepare_for_scan() { assert(!scan_in_progress(), "pre-condition"); _scan_in_progress = _num_root_regions > 0; _claimed_root_regions = 0; _should_abort = false; } ! HeapRegion* G1CMRootRegions::claim_next() { if (_should_abort) { // If someone has set the should_abort flag, we return NULL to // force the caller to bail out of their loop. return NULL; } --- 255,306 ---- _hwm = 0; _chunk_list = NULL; _free_list = NULL; } ! G1CMRootMemRegions::G1CMRootMemRegions(uint const max_regions) : ! _root_regions(NULL), _max_regions(max_regions), _num_root_regions(0), _claimed_root_regions(0), _scan_in_progress(false), ! _should_abort(false) { ! _root_regions = new MemRegion[_max_regions]; ! if (_root_regions == NULL) { ! vm_exit_during_initialization("Could not allocate root MemRegion set."); ! } ! } ! G1CMRootMemRegions::~G1CMRootMemRegions() { ! delete[] _root_regions; ! _root_regions = NULL; } ! void G1CMRootMemRegions::reset() { _num_root_regions = 0; } ! void G1CMRootMemRegions::add(HeapWord* start, HeapWord* end) { assert_at_safepoint(); size_t idx = Atomic::add((size_t)1, &_num_root_regions) - 1; ! assert(idx < _max_regions, "Trying to add more root MemRegions than there is space " SIZE_FORMAT, _max_regions); ! assert(start != NULL && end != NULL && start <= end, "Start (" PTR_FORMAT ") should be equal to or greater " ! "than end (" PTR_FORMAT ")", p2i(start), p2i(end)); ! _root_regions[idx].set_start(start); ! _root_regions[idx].set_end(end); } ! void G1CMRootMemRegions::prepare_for_scan() { assert(!scan_in_progress(), "pre-condition"); _scan_in_progress = _num_root_regions > 0; _claimed_root_regions = 0; _should_abort = false; } ! MemRegion* G1CMRootMemRegions::claim_next() { if (_should_abort) { // If someone has set the should_abort flag, we return NULL to // force the caller to bail out of their loop. return NULL; }
*** 300,329 **** return NULL; } size_t claimed_index = Atomic::add((size_t)1, &_claimed_root_regions) - 1; if (claimed_index < _num_root_regions) { ! return _root_regions[claimed_index]; } return NULL; } ! uint G1CMRootRegions::num_root_regions() const { return (uint)_num_root_regions; } ! void G1CMRootRegions::notify_scan_done() { MutexLocker x(RootRegionScan_lock, Mutex::_no_safepoint_check_flag); _scan_in_progress = false; RootRegionScan_lock->notify_all(); } ! void G1CMRootRegions::cancel_scan() { notify_scan_done(); } ! void G1CMRootRegions::scan_finished() { assert(scan_in_progress(), "pre-condition"); if (!_should_abort) { assert(_claimed_root_regions >= num_root_regions(), "we should have claimed all root regions, claimed " SIZE_FORMAT ", length = %u", --- 309,338 ---- return NULL; } size_t claimed_index = Atomic::add((size_t)1, &_claimed_root_regions) - 1; if (claimed_index < _num_root_regions) { ! return &_root_regions[claimed_index]; } return NULL; } ! uint G1CMRootMemRegions::num_root_regions() const { return (uint)_num_root_regions; } ! void G1CMRootMemRegions::notify_scan_done() { MutexLocker x(RootRegionScan_lock, Mutex::_no_safepoint_check_flag); _scan_in_progress = false; RootRegionScan_lock->notify_all(); } ! void G1CMRootMemRegions::cancel_scan() { notify_scan_done(); } ! void G1CMRootMemRegions::scan_finished() { assert(scan_in_progress(), "pre-condition"); if (!_should_abort) { assert(_claimed_root_regions >= num_root_regions(), "we should have claimed all root regions, claimed " SIZE_FORMAT ", length = %u",
*** 331,341 **** } notify_scan_done(); } ! bool G1CMRootRegions::wait_until_scan_finished() { if (!scan_in_progress()) { return false; } { --- 340,350 ---- } notify_scan_done(); } ! bool G1CMRootMemRegions::wait_until_scan_finished() { if (!scan_in_progress()) { return false; } {
*** 873,890 **** "Calculated number of marking workers must be larger than zero and at most the maximum %u, but is %u", _max_concurrent_workers, result); return result; } ! void G1ConcurrentMark::scan_root_region(HeapRegion* hr, uint worker_id) { ! assert(hr->is_old() || (hr->is_survivor() && hr->next_top_at_mark_start() == hr->bottom()), ! "Root regions must be old or survivor but region %u is %s", hr->hrm_index(), hr->get_type_str()); G1RootRegionScanClosure cl(_g1h, this, worker_id); const uintx interval = PrefetchScanIntervalInBytes; ! HeapWord* curr = hr->next_top_at_mark_start(); ! const HeapWord* end = hr->top(); while (curr < end) { Prefetch::read(curr, interval); oop obj = oop(curr); int size = obj->oop_iterate_size(&cl); assert(size == obj->size(), "sanity"); --- 882,906 ---- "Calculated number of marking workers must be larger than zero and at most the maximum %u, but is %u", _max_concurrent_workers, result); return result; } ! void G1ConcurrentMark::scan_root_region(MemRegion* region, uint worker_id) { ! #ifdef ASSERT ! HeapWord* last = region->last(); ! HeapRegion* hr = _g1h->heap_region_containing(last); ! assert(hr->is_old() || hr->next_top_at_mark_start() == hr->bottom(), ! "Root regions must be old or survivor/eden but region %u is %s", hr->hrm_index(), hr->get_type_str()); ! assert(hr->next_top_at_mark_start() == region->start(), ! "MemRegion start should be equal to nTAMS"); ! #endif ! G1RootRegionScanClosure cl(_g1h, this, worker_id); const uintx interval = PrefetchScanIntervalInBytes; ! HeapWord* curr = region->start(); ! const HeapWord* end = region->end(); while (curr < end) { Prefetch::read(curr, interval); oop obj = oop(curr); int size = obj->oop_iterate_size(&cl); assert(size == obj->size(), "sanity");
*** 900,914 **** void work(uint worker_id) { assert(Thread::current()->is_ConcurrentGC_thread(), "this should only be done by a conc GC thread"); ! G1CMRootRegions* root_regions = _cm->root_regions(); ! HeapRegion* hr = root_regions->claim_next(); ! while (hr != NULL) { ! _cm->scan_root_region(hr, worker_id); ! hr = root_regions->claim_next(); } } }; void G1ConcurrentMark::scan_root_regions() { --- 916,930 ---- void work(uint worker_id) { assert(Thread::current()->is_ConcurrentGC_thread(), "this should only be done by a conc GC thread"); ! G1CMRootMemRegions* root_regions = _cm->root_regions(); ! MemRegion* region = root_regions->claim_next(); ! while (region != NULL) { ! _cm->scan_root_region(region, worker_id); ! region = root_regions->claim_next(); } } }; void G1ConcurrentMark::scan_root_regions() {
< prev index next >