提交 e6f75963 编写于 作者: J johnc

7127708: G1: change task num types from int to uint in concurrent mark

Summary: Change the type of various task num fields, parameters etc to unsigned and rename them to be more consistent with the other collectors. Code changes were also reviewed by Vitaly Davidovich.
Reviewed-by: johnc
Contributed-by: NKaushik Srenevasan <kaushik@twitter.com>
上级 7a9dad8d
...@@ -426,11 +426,11 @@ ConcurrentMark::ConcurrentMark(ReservedSpace rs, uint max_regions) : ...@@ -426,11 +426,11 @@ ConcurrentMark::ConcurrentMark(ReservedSpace rs, uint max_regions) :
_markStack(this), _markStack(this),
// _finger set in set_non_marking_state // _finger set in set_non_marking_state
_max_task_num(MAX2((uint)ParallelGCThreads, 1U)), _max_worker_id(MAX2((uint)ParallelGCThreads, 1U)),
// _active_tasks set in set_non_marking_state // _active_tasks set in set_non_marking_state
// _tasks set inside the constructor // _tasks set inside the constructor
_task_queues(new CMTaskQueueSet((int) _max_task_num)), _task_queues(new CMTaskQueueSet((int) _max_worker_id)),
_terminator(ParallelTaskTerminator((int) _max_task_num, _task_queues)), _terminator(ParallelTaskTerminator((int) _max_worker_id, _task_queues)),
_has_overflown(false), _has_overflown(false),
_concurrent(false), _concurrent(false),
...@@ -481,17 +481,17 @@ ConcurrentMark::ConcurrentMark(ReservedSpace rs, uint max_regions) : ...@@ -481,17 +481,17 @@ ConcurrentMark::ConcurrentMark(ReservedSpace rs, uint max_regions) :
_root_regions.init(_g1h, this); _root_regions.init(_g1h, this);
_tasks = NEW_C_HEAP_ARRAY(CMTask*, _max_task_num, mtGC); _tasks = NEW_C_HEAP_ARRAY(CMTask*, _max_worker_id, mtGC);
_accum_task_vtime = NEW_C_HEAP_ARRAY(double, _max_task_num, mtGC); _accum_task_vtime = NEW_C_HEAP_ARRAY(double, _max_worker_id, mtGC);
_count_card_bitmaps = NEW_C_HEAP_ARRAY(BitMap, _max_task_num, mtGC); _count_card_bitmaps = NEW_C_HEAP_ARRAY(BitMap, _max_worker_id, mtGC);
_count_marked_bytes = NEW_C_HEAP_ARRAY(size_t*, _max_task_num, mtGC); _count_marked_bytes = NEW_C_HEAP_ARRAY(size_t*, _max_worker_id, mtGC);
BitMap::idx_t card_bm_size = _card_bm.size(); BitMap::idx_t card_bm_size = _card_bm.size();
// so that the assertion in MarkingTaskQueue::task_queue doesn't fail // so that the assertion in MarkingTaskQueue::task_queue doesn't fail
_active_tasks = _max_task_num; _active_tasks = _max_worker_id;
for (int i = 0; i < (int) _max_task_num; ++i) { for (uint i = 0; i < _max_worker_id; ++i) {
CMTaskQueue* task_queue = new CMTaskQueue(); CMTaskQueue* task_queue = new CMTaskQueue();
task_queue->initialize(); task_queue->initialize();
_task_queues->register_queue(i, task_queue); _task_queues->register_queue(i, task_queue);
...@@ -638,7 +638,7 @@ void ConcurrentMark::reset() { ...@@ -638,7 +638,7 @@ void ConcurrentMark::reset() {
// We do reset all of them, since different phases will use // We do reset all of them, since different phases will use
// different number of active threads. So, it's easiest to have all // different number of active threads. So, it's easiest to have all
// of them ready. // of them ready.
for (int i = 0; i < (int) _max_task_num; ++i) { for (uint i = 0; i < _max_worker_id; ++i) {
_tasks[i]->reset(_nextMarkBitMap); _tasks[i]->reset(_nextMarkBitMap);
} }
...@@ -648,7 +648,7 @@ void ConcurrentMark::reset() { ...@@ -648,7 +648,7 @@ void ConcurrentMark::reset() {
} }
void ConcurrentMark::set_phase(uint active_tasks, bool concurrent) { void ConcurrentMark::set_phase(uint active_tasks, bool concurrent) {
assert(active_tasks <= _max_task_num, "we should not have more"); assert(active_tasks <= _max_worker_id, "we should not have more");
_active_tasks = active_tasks; _active_tasks = active_tasks;
// Need to update the three data structures below according to the // Need to update the three data structures below according to the
...@@ -659,7 +659,7 @@ void ConcurrentMark::set_phase(uint active_tasks, bool concurrent) { ...@@ -659,7 +659,7 @@ void ConcurrentMark::set_phase(uint active_tasks, bool concurrent) {
_concurrent = concurrent; _concurrent = concurrent;
// We propagate this to all tasks, not just the active ones. // We propagate this to all tasks, not just the active ones.
for (int i = 0; i < (int) _max_task_num; ++i) for (uint i = 0; i < _max_worker_id; ++i)
_tasks[i]->set_concurrent(concurrent); _tasks[i]->set_concurrent(concurrent);
if (concurrent) { if (concurrent) {
...@@ -818,9 +818,9 @@ void ConcurrentMark::checkpointRootsInitialPost() { ...@@ -818,9 +818,9 @@ void ConcurrentMark::checkpointRootsInitialPost() {
* doesn't manipulate any data structures afterwards. * doesn't manipulate any data structures afterwards.
*/ */
void ConcurrentMark::enter_first_sync_barrier(int task_num) { void ConcurrentMark::enter_first_sync_barrier(uint worker_id) {
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] entering first barrier", task_num); gclog_or_tty->print_cr("[%u] entering first barrier", worker_id);
} }
if (concurrent()) { if (concurrent()) {
...@@ -834,11 +834,11 @@ void ConcurrentMark::enter_first_sync_barrier(int task_num) { ...@@ -834,11 +834,11 @@ void ConcurrentMark::enter_first_sync_barrier(int task_num) {
// more work // more work
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] leaving first barrier", task_num); gclog_or_tty->print_cr("[%u] leaving first barrier", worker_id);
} }
// let task 0 do this // let the task associated with with worker 0 do this
if (task_num == 0) { if (worker_id == 0) {
// task 0 is responsible for clearing the global data structures // task 0 is responsible for clearing the global data structures
// We should be here because of an overflow. During STW we should // We should be here because of an overflow. During STW we should
// not clear the overflow flag since we rely on it being true when // not clear the overflow flag since we rely on it being true when
...@@ -858,9 +858,9 @@ void ConcurrentMark::enter_first_sync_barrier(int task_num) { ...@@ -858,9 +858,9 @@ void ConcurrentMark::enter_first_sync_barrier(int task_num) {
// then go into the second barrier // then go into the second barrier
} }
void ConcurrentMark::enter_second_sync_barrier(int task_num) { void ConcurrentMark::enter_second_sync_barrier(uint worker_id) {
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] entering second barrier", task_num); gclog_or_tty->print_cr("[%u] entering second barrier", worker_id);
} }
if (concurrent()) { if (concurrent()) {
...@@ -873,7 +873,7 @@ void ConcurrentMark::enter_second_sync_barrier(int task_num) { ...@@ -873,7 +873,7 @@ void ConcurrentMark::enter_second_sync_barrier(int task_num) {
// at this point everything should be re-initialised and ready to go // at this point everything should be re-initialised and ready to go
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] leaving second barrier", task_num); gclog_or_tty->print_cr("[%u] leaving second barrier", worker_id);
} }
} }
...@@ -2113,9 +2113,9 @@ class G1CMParKeepAliveAndDrainClosure: public OopClosure { ...@@ -2113,9 +2113,9 @@ class G1CMParKeepAliveAndDrainClosure: public OopClosure {
if (!_cm->has_overflown()) { if (!_cm->has_overflown()) {
oop obj = oopDesc::load_decode_heap_oop(p); oop obj = oopDesc::load_decode_heap_oop(p);
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("\t[%d] we're looking at location " gclog_or_tty->print_cr("\t[%u] we're looking at location "
"*"PTR_FORMAT" = "PTR_FORMAT, "*"PTR_FORMAT" = "PTR_FORMAT,
_task->task_id(), p, (void*) obj); _task->worker_id(), p, (void*) obj);
} }
_task->deal_with_reference(obj); _task->deal_with_reference(obj);
...@@ -2144,7 +2144,7 @@ class G1CMParKeepAliveAndDrainClosure: public OopClosure { ...@@ -2144,7 +2144,7 @@ class G1CMParKeepAliveAndDrainClosure: public OopClosure {
} }
} else { } else {
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("\t[%d] CM Overflow", _task->task_id()); gclog_or_tty->print_cr("\t[%u] CM Overflow", _task->worker_id());
} }
} }
} }
...@@ -2160,8 +2160,8 @@ class G1CMParDrainMarkingStackClosure: public VoidClosure { ...@@ -2160,8 +2160,8 @@ class G1CMParDrainMarkingStackClosure: public VoidClosure {
void do_void() { void do_void() {
do { do {
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("\t[%d] Drain: Calling do marking_step", gclog_or_tty->print_cr("\t[%u] Drain: Calling do marking_step",
_task->task_id()); _task->worker_id());
} }
// We call CMTask::do_marking_step() to completely drain the local and // We call CMTask::do_marking_step() to completely drain the local and
...@@ -2300,7 +2300,7 @@ void ConcurrentMark::weakRefsWork(bool clear_all_soft_refs) { ...@@ -2300,7 +2300,7 @@ void ConcurrentMark::weakRefsWork(bool clear_all_soft_refs) {
// We use the work gang from the G1CollectedHeap and we utilize all // We use the work gang from the G1CollectedHeap and we utilize all
// the worker threads. // the worker threads.
uint active_workers = g1h->workers() ? g1h->workers()->active_workers() : 1U; uint active_workers = g1h->workers() ? g1h->workers()->active_workers() : 1U;
active_workers = MAX2(MIN2(active_workers, _max_task_num), 1U); active_workers = MAX2(MIN2(active_workers, _max_worker_id), 1U);
G1CMRefProcTaskExecutor par_task_executor(g1h, this, G1CMRefProcTaskExecutor par_task_executor(g1h, this,
g1h->workers(), active_workers); g1h->workers(), active_workers);
...@@ -2619,7 +2619,7 @@ void ConcurrentMark::clearRangeBothBitmaps(MemRegion mr) { ...@@ -2619,7 +2619,7 @@ void ConcurrentMark::clearRangeBothBitmaps(MemRegion mr) {
} }
HeapRegion* HeapRegion*
ConcurrentMark::claim_region(int task_num) { ConcurrentMark::claim_region(uint worker_id) {
// "checkpoint" the finger // "checkpoint" the finger
HeapWord* finger = _finger; HeapWord* finger = _finger;
...@@ -2657,10 +2657,10 @@ ConcurrentMark::claim_region(int task_num) { ...@@ -2657,10 +2657,10 @@ ConcurrentMark::claim_region(int task_num) {
HeapWord* limit = curr_region->next_top_at_mark_start(); HeapWord* limit = curr_region->next_top_at_mark_start();
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] curr_region = "PTR_FORMAT" " gclog_or_tty->print_cr("[%u] curr_region = "PTR_FORMAT" "
"["PTR_FORMAT", "PTR_FORMAT"), " "["PTR_FORMAT", "PTR_FORMAT"), "
"limit = "PTR_FORMAT, "limit = "PTR_FORMAT,
task_num, curr_region, bottom, end, limit); worker_id, curr_region, bottom, end, limit);
} }
// Is the gap between reading the finger and doing the CAS too long? // Is the gap between reading the finger and doing the CAS too long?
...@@ -2673,22 +2673,22 @@ ConcurrentMark::claim_region(int task_num) { ...@@ -2673,22 +2673,22 @@ ConcurrentMark::claim_region(int task_num) {
assert(_finger >= end, "the finger should have moved forward"); assert(_finger >= end, "the finger should have moved forward");
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] we were successful with region = " gclog_or_tty->print_cr("[%u] we were successful with region = "
PTR_FORMAT, task_num, curr_region); PTR_FORMAT, worker_id, curr_region);
} }
if (limit > bottom) { if (limit > bottom) {
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] region "PTR_FORMAT" is not empty, " gclog_or_tty->print_cr("[%u] region "PTR_FORMAT" is not empty, "
"returning it ", task_num, curr_region); "returning it ", worker_id, curr_region);
} }
return curr_region; return curr_region;
} else { } else {
assert(limit == bottom, assert(limit == bottom,
"the region limit should be at bottom"); "the region limit should be at bottom");
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] region "PTR_FORMAT" is empty, " gclog_or_tty->print_cr("[%u] region "PTR_FORMAT" is empty, "
"returning NULL", task_num, curr_region); "returning NULL", worker_id, curr_region);
} }
// we return NULL and the caller should try calling // we return NULL and the caller should try calling
// claim_region() again. // claim_region() again.
...@@ -2697,10 +2697,10 @@ ConcurrentMark::claim_region(int task_num) { ...@@ -2697,10 +2697,10 @@ ConcurrentMark::claim_region(int task_num) {
} else { } else {
assert(_finger > finger, "the finger should have moved forward"); assert(_finger > finger, "the finger should have moved forward");
if (verbose_low()) { if (verbose_low()) {
gclog_or_tty->print_cr("[%d] somebody else moved the finger, " gclog_or_tty->print_cr("[%u] somebody else moved the finger, "
"global finger = "PTR_FORMAT", " "global finger = "PTR_FORMAT", "
"our finger = "PTR_FORMAT, "our finger = "PTR_FORMAT,
task_num, _finger, finger); worker_id, _finger, finger);
} }
// read it again // read it again
...@@ -2783,7 +2783,7 @@ void ConcurrentMark::verify_no_cset_oops(bool verify_stacks, ...@@ -2783,7 +2783,7 @@ void ConcurrentMark::verify_no_cset_oops(bool verify_stacks,
_markStack.oops_do(&cl); _markStack.oops_do(&cl);
// Verify entries on the task queues // Verify entries on the task queues
for (int i = 0; i < (int) _max_task_num; i += 1) { for (uint i = 0; i < _max_worker_id; i += 1) {
cl.set_phase(VerifyNoCSetOopsQueues, i); cl.set_phase(VerifyNoCSetOopsQueues, i);
OopTaskQueue* queue = _task_queues->queue(i); OopTaskQueue* queue = _task_queues->queue(i);
queue->oops_do(&cl); queue->oops_do(&cl);
...@@ -2822,7 +2822,7 @@ void ConcurrentMark::verify_no_cset_oops(bool verify_stacks, ...@@ -2822,7 +2822,7 @@ void ConcurrentMark::verify_no_cset_oops(bool verify_stacks,
} }
// Verify the task fingers // Verify the task fingers
assert(parallel_marking_threads() <= _max_task_num, "sanity"); assert(parallel_marking_threads() <= _max_worker_id, "sanity");
for (int i = 0; i < (int) parallel_marking_threads(); i += 1) { for (int i = 0; i < (int) parallel_marking_threads(); i += 1) {
CMTask* task = _tasks[i]; CMTask* task = _tasks[i];
HeapWord* task_finger = task->finger(); HeapWord* task_finger = task->finger();
...@@ -2849,7 +2849,7 @@ void ConcurrentMark::clear_marking_state(bool clear_overflow) { ...@@ -2849,7 +2849,7 @@ void ConcurrentMark::clear_marking_state(bool clear_overflow) {
} }
_finger = _heap_start; _finger = _heap_start;
for (int i = 0; i < (int)_max_task_num; ++i) { for (uint i = 0; i < _max_worker_id; ++i) {
OopTaskQueue* queue = _task_queues->queue(i); OopTaskQueue* queue = _task_queues->queue(i);
queue->set_empty(); queue->set_empty();
} }
...@@ -2862,15 +2862,15 @@ class AggregateCountDataHRClosure: public HeapRegionClosure { ...@@ -2862,15 +2862,15 @@ class AggregateCountDataHRClosure: public HeapRegionClosure {
ConcurrentMark* _cm; ConcurrentMark* _cm;
CardTableModRefBS* _ct_bs; CardTableModRefBS* _ct_bs;
BitMap* _cm_card_bm; BitMap* _cm_card_bm;
size_t _max_task_num; uint _max_worker_id;
public: public:
AggregateCountDataHRClosure(G1CollectedHeap* g1h, AggregateCountDataHRClosure(G1CollectedHeap* g1h,
BitMap* cm_card_bm, BitMap* cm_card_bm,
size_t max_task_num) : uint max_worker_id) :
_g1h(g1h), _cm(g1h->concurrent_mark()), _g1h(g1h), _cm(g1h->concurrent_mark()),
_ct_bs((CardTableModRefBS*) (g1h->barrier_set())), _ct_bs((CardTableModRefBS*) (g1h->barrier_set())),
_cm_card_bm(cm_card_bm), _max_task_num(max_task_num) { } _cm_card_bm(cm_card_bm), _max_worker_id(max_worker_id) { }
bool doHeapRegion(HeapRegion* hr) { bool doHeapRegion(HeapRegion* hr) {
if (hr->continuesHumongous()) { if (hr->continuesHumongous()) {
...@@ -2927,7 +2927,7 @@ class AggregateCountDataHRClosure: public HeapRegionClosure { ...@@ -2927,7 +2927,7 @@ class AggregateCountDataHRClosure: public HeapRegionClosure {
uint hrs_index = hr->hrs_index(); uint hrs_index = hr->hrs_index();
size_t marked_bytes = 0; size_t marked_bytes = 0;
for (int i = 0; (size_t)i < _max_task_num; i += 1) { for (uint i = 0; i < _max_worker_id; i += 1) {
size_t* marked_bytes_array = _cm->count_marked_bytes_array_for(i); size_t* marked_bytes_array = _cm->count_marked_bytes_array_for(i);
BitMap* task_card_bm = _cm->count_card_bitmap_for(i); BitMap* task_card_bm = _cm->count_card_bitmap_for(i);
...@@ -2935,7 +2935,7 @@ class AggregateCountDataHRClosure: public HeapRegionClosure { ...@@ -2935,7 +2935,7 @@ class AggregateCountDataHRClosure: public HeapRegionClosure {
// add it to the running total for this region. // add it to the running total for this region.
marked_bytes += marked_bytes_array[hrs_index]; marked_bytes += marked_bytes_array[hrs_index];
// Now union the bitmaps[0,max_task_num)[start_idx..limit_idx) // Now union the bitmaps[0,max_worker_id)[start_idx..limit_idx)
// into the global card bitmap. // into the global card bitmap.
BitMap::idx_t scan_idx = task_card_bm->get_next_one_offset(start_idx, limit_idx); BitMap::idx_t scan_idx = task_card_bm->get_next_one_offset(start_idx, limit_idx);
...@@ -2967,22 +2967,22 @@ protected: ...@@ -2967,22 +2967,22 @@ protected:
G1CollectedHeap* _g1h; G1CollectedHeap* _g1h;
ConcurrentMark* _cm; ConcurrentMark* _cm;
BitMap* _cm_card_bm; BitMap* _cm_card_bm;
size_t _max_task_num; uint _max_worker_id;
int _active_workers; int _active_workers;
public: public:
G1AggregateCountDataTask(G1CollectedHeap* g1h, G1AggregateCountDataTask(G1CollectedHeap* g1h,
ConcurrentMark* cm, ConcurrentMark* cm,
BitMap* cm_card_bm, BitMap* cm_card_bm,
size_t max_task_num, uint max_worker_id,
int n_workers) : int n_workers) :
AbstractGangTask("Count Aggregation"), AbstractGangTask("Count Aggregation"),
_g1h(g1h), _cm(cm), _cm_card_bm(cm_card_bm), _g1h(g1h), _cm(cm), _cm_card_bm(cm_card_bm),
_max_task_num(max_task_num), _max_worker_id(max_worker_id),
_active_workers(n_workers) { } _active_workers(n_workers) { }
void work(uint worker_id) { void work(uint worker_id) {
AggregateCountDataHRClosure cl(_g1h, _cm_card_bm, _max_task_num); AggregateCountDataHRClosure cl(_g1h, _cm_card_bm, _max_worker_id);
if (G1CollectedHeap::use_parallel_gc_threads()) { if (G1CollectedHeap::use_parallel_gc_threads()) {
_g1h->heap_region_par_iterate_chunked(&cl, worker_id, _g1h->heap_region_par_iterate_chunked(&cl, worker_id,
...@@ -3001,7 +3001,7 @@ void ConcurrentMark::aggregate_count_data() { ...@@ -3001,7 +3001,7 @@ void ConcurrentMark::aggregate_count_data() {
1); 1);
G1AggregateCountDataTask g1_par_agg_task(_g1h, this, &_card_bm, G1AggregateCountDataTask g1_par_agg_task(_g1h, this, &_card_bm,
_max_task_num, n_workers); _max_worker_id, n_workers);
if (G1CollectedHeap::use_parallel_gc_threads()) { if (G1CollectedHeap::use_parallel_gc_threads()) {
assert(_g1h->check_heap_region_claim_values(HeapRegion::InitialClaimValue), assert(_g1h->check_heap_region_claim_values(HeapRegion::InitialClaimValue),
...@@ -3030,9 +3030,9 @@ void ConcurrentMark::clear_all_count_data() { ...@@ -3030,9 +3030,9 @@ void ConcurrentMark::clear_all_count_data() {
_region_bm.clear(); _region_bm.clear();
uint max_regions = _g1h->max_regions(); uint max_regions = _g1h->max_regions();
assert(_max_task_num != 0, "unitialized"); assert(_max_worker_id > 0, "uninitialized");
for (int i = 0; (size_t) i < _max_task_num; i += 1) { for (uint i = 0; i < _max_worker_id; i += 1) {
BitMap* task_card_bm = count_card_bitmap_for(i); BitMap* task_card_bm = count_card_bitmap_for(i);
size_t* marked_bytes_array = count_marked_bytes_array_for(i); size_t* marked_bytes_array = count_marked_bytes_array_for(i);
...@@ -3062,7 +3062,7 @@ void ConcurrentMark::abort() { ...@@ -3062,7 +3062,7 @@ void ConcurrentMark::abort() {
clear_all_count_data(); clear_all_count_data();
// Empty mark stack // Empty mark stack
clear_marking_state(); clear_marking_state();
for (int i = 0; i < (int)_max_task_num; ++i) { for (uint i = 0; i < _max_worker_id; ++i) {
_tasks[i]->clear_region_fields(); _tasks[i]->clear_region_fields();
} }
_has_aborted = true; _has_aborted = true;
...@@ -3154,8 +3154,8 @@ bool ConcurrentMark::containing_cards_are_marked(void* start, ...@@ -3154,8 +3154,8 @@ bool ConcurrentMark::containing_cards_are_marked(void* start,
void ConcurrentMark::print_finger() { void ConcurrentMark::print_finger() {
gclog_or_tty->print_cr("heap ["PTR_FORMAT", "PTR_FORMAT"), global finger = "PTR_FORMAT, gclog_or_tty->print_cr("heap ["PTR_FORMAT", "PTR_FORMAT"), global finger = "PTR_FORMAT,
_heap_start, _heap_end, _finger); _heap_start, _heap_end, _finger);
for (int i = 0; i < (int) _max_task_num; ++i) { for (uint i = 0; i < _max_worker_id; ++i) {
gclog_or_tty->print(" %d: "PTR_FORMAT, i, _tasks[i]->finger()); gclog_or_tty->print(" %u: "PTR_FORMAT, i, _tasks[i]->finger());
} }
gclog_or_tty->print_cr(""); gclog_or_tty->print_cr("");
} }
...@@ -3165,8 +3165,8 @@ void CMTask::scan_object(oop obj) { ...@@ -3165,8 +3165,8 @@ void CMTask::scan_object(oop obj) {
assert(_nextMarkBitMap->isMarked((HeapWord*) obj), "invariant"); assert(_nextMarkBitMap->isMarked((HeapWord*) obj), "invariant");
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] we're scanning object "PTR_FORMAT, gclog_or_tty->print_cr("[%u] we're scanning object "PTR_FORMAT,
_task_id, (void*) obj); _worker_id, (void*) obj);
} }
size_t obj_size = obj->size(); size_t obj_size = obj->size();
...@@ -3245,8 +3245,8 @@ void CMTask::setup_for_region(HeapRegion* hr) { ...@@ -3245,8 +3245,8 @@ void CMTask::setup_for_region(HeapRegion* hr) {
"claim_region() should have filtered out continues humongous regions"); "claim_region() should have filtered out continues humongous regions");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] setting up for region "PTR_FORMAT, gclog_or_tty->print_cr("[%u] setting up for region "PTR_FORMAT,
_task_id, hr); _worker_id, hr);
} }
_curr_region = hr; _curr_region = hr;
...@@ -3261,9 +3261,9 @@ void CMTask::update_region_limit() { ...@@ -3261,9 +3261,9 @@ void CMTask::update_region_limit() {
if (limit == bottom) { if (limit == bottom) {
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] found an empty region " gclog_or_tty->print_cr("[%u] found an empty region "
"["PTR_FORMAT", "PTR_FORMAT")", "["PTR_FORMAT", "PTR_FORMAT")",
_task_id, bottom, limit); _worker_id, bottom, limit);
} }
// The region was collected underneath our feet. // The region was collected underneath our feet.
// We set the finger to bottom to ensure that the bitmap // We set the finger to bottom to ensure that the bitmap
...@@ -3294,8 +3294,8 @@ void CMTask::update_region_limit() { ...@@ -3294,8 +3294,8 @@ void CMTask::update_region_limit() {
void CMTask::giveup_current_region() { void CMTask::giveup_current_region() {
assert(_curr_region != NULL, "invariant"); assert(_curr_region != NULL, "invariant");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] giving up region "PTR_FORMAT, gclog_or_tty->print_cr("[%u] giving up region "PTR_FORMAT,
_task_id, _curr_region); _worker_id, _curr_region);
} }
clear_region_fields(); clear_region_fields();
} }
...@@ -3321,7 +3321,7 @@ void CMTask::reset(CMBitMap* nextMarkBitMap) { ...@@ -3321,7 +3321,7 @@ void CMTask::reset(CMBitMap* nextMarkBitMap) {
guarantee(nextMarkBitMap != NULL, "invariant"); guarantee(nextMarkBitMap != NULL, "invariant");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] resetting", _task_id); gclog_or_tty->print_cr("[%u] resetting", _worker_id);
} }
_nextMarkBitMap = nextMarkBitMap; _nextMarkBitMap = nextMarkBitMap;
...@@ -3415,9 +3415,9 @@ void CMTask::regular_clock_call() { ...@@ -3415,9 +3415,9 @@ void CMTask::regular_clock_call() {
_all_clock_intervals_ms.add(last_interval_ms); _all_clock_intervals_ms.add(last_interval_ms);
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] regular clock, interval = %1.2lfms, " gclog_or_tty->print_cr("[%u] regular clock, interval = %1.2lfms, "
"scanned = %d%s, refs reached = %d%s", "scanned = %d%s, refs reached = %d%s",
_task_id, last_interval_ms, _worker_id, last_interval_ms,
_words_scanned, _words_scanned,
(_words_scanned >= _words_scanned_limit) ? " (*)" : "", (_words_scanned >= _words_scanned_limit) ? " (*)" : "",
_refs_reached, _refs_reached,
...@@ -3449,8 +3449,8 @@ void CMTask::regular_clock_call() { ...@@ -3449,8 +3449,8 @@ void CMTask::regular_clock_call() {
SATBMarkQueueSet& satb_mq_set = JavaThread::satb_mark_queue_set(); SATBMarkQueueSet& satb_mq_set = JavaThread::satb_mark_queue_set();
if (!_draining_satb_buffers && satb_mq_set.process_completed_buffers()) { if (!_draining_satb_buffers && satb_mq_set.process_completed_buffers()) {
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] aborting to deal with pending SATB buffers", gclog_or_tty->print_cr("[%u] aborting to deal with pending SATB buffers",
_task_id); _worker_id);
} }
// we do need to process SATB buffers, we'll abort and restart // we do need to process SATB buffers, we'll abort and restart
// the marking task to do so // the marking task to do so
...@@ -3475,7 +3475,7 @@ void CMTask::decrease_limits() { ...@@ -3475,7 +3475,7 @@ void CMTask::decrease_limits() {
// scanning limit so that the clock is called earlier. // scanning limit so that the clock is called earlier.
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] decreasing limits", _task_id); gclog_or_tty->print_cr("[%u] decreasing limits", _worker_id);
} }
_words_scanned_limit = _real_words_scanned_limit - _words_scanned_limit = _real_words_scanned_limit -
...@@ -3503,16 +3503,16 @@ void CMTask::move_entries_to_global_stack() { ...@@ -3503,16 +3503,16 @@ void CMTask::move_entries_to_global_stack() {
if (!_cm->mark_stack_push(buffer, n)) { if (!_cm->mark_stack_push(buffer, n)) {
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] aborting due to global stack overflow", gclog_or_tty->print_cr("[%u] aborting due to global stack overflow",
_task_id); _worker_id);
} }
set_has_aborted(); set_has_aborted();
} else { } else {
// the transfer was successful // the transfer was successful
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] pushed %d entries to the global stack", gclog_or_tty->print_cr("[%u] pushed %d entries to the global stack",
_task_id, n); _worker_id, n);
} }
statsOnly( int tmp_size = _cm->mark_stack_size(); statsOnly( int tmp_size = _cm->mark_stack_size();
if (tmp_size > _global_max_size) { if (tmp_size > _global_max_size) {
...@@ -3539,8 +3539,8 @@ void CMTask::get_entries_from_global_stack() { ...@@ -3539,8 +3539,8 @@ void CMTask::get_entries_from_global_stack() {
statsOnly( ++_global_transfers_from; _global_pops += n ); statsOnly( ++_global_transfers_from; _global_pops += n );
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] popped %d entries from the global stack", gclog_or_tty->print_cr("[%u] popped %d entries from the global stack",
_task_id, n); _worker_id, n);
} }
for (int i = 0; i < n; ++i) { for (int i = 0; i < n; ++i) {
bool success = _task_queue->push(buffer[i]); bool success = _task_queue->push(buffer[i]);
...@@ -3575,8 +3575,8 @@ void CMTask::drain_local_queue(bool partially) { ...@@ -3575,8 +3575,8 @@ void CMTask::drain_local_queue(bool partially) {
if (_task_queue->size() > target_size) { if (_task_queue->size() > target_size) {
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] draining local queue, target size = %d", gclog_or_tty->print_cr("[%u] draining local queue, target size = %d",
_task_id, target_size); _worker_id, target_size);
} }
oop obj; oop obj;
...@@ -3585,7 +3585,7 @@ void CMTask::drain_local_queue(bool partially) { ...@@ -3585,7 +3585,7 @@ void CMTask::drain_local_queue(bool partially) {
statsOnly( ++_local_pops ); statsOnly( ++_local_pops );
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] popped "PTR_FORMAT, _task_id, gclog_or_tty->print_cr("[%u] popped "PTR_FORMAT, _worker_id,
(void*) obj); (void*) obj);
} }
...@@ -3603,8 +3603,8 @@ void CMTask::drain_local_queue(bool partially) { ...@@ -3603,8 +3603,8 @@ void CMTask::drain_local_queue(bool partially) {
} }
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] drained local queue, size = %d", gclog_or_tty->print_cr("[%u] drained local queue, size = %d",
_task_id, _task_queue->size()); _worker_id, _task_queue->size());
} }
} }
} }
...@@ -3631,8 +3631,8 @@ void CMTask::drain_global_stack(bool partially) { ...@@ -3631,8 +3631,8 @@ void CMTask::drain_global_stack(bool partially) {
if (_cm->mark_stack_size() > target_size) { if (_cm->mark_stack_size() > target_size) {
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] draining global_stack, target size %d", gclog_or_tty->print_cr("[%u] draining global_stack, target size %d",
_task_id, target_size); _worker_id, target_size);
} }
while (!has_aborted() && _cm->mark_stack_size() > target_size) { while (!has_aborted() && _cm->mark_stack_size() > target_size) {
...@@ -3641,8 +3641,8 @@ void CMTask::drain_global_stack(bool partially) { ...@@ -3641,8 +3641,8 @@ void CMTask::drain_global_stack(bool partially) {
} }
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] drained global stack, size = %d", gclog_or_tty->print_cr("[%u] drained global stack, size = %d",
_task_id, _cm->mark_stack_size()); _worker_id, _cm->mark_stack_size());
} }
} }
} }
...@@ -3663,7 +3663,7 @@ void CMTask::drain_satb_buffers() { ...@@ -3663,7 +3663,7 @@ void CMTask::drain_satb_buffers() {
CMObjectClosure oc(this); CMObjectClosure oc(this);
SATBMarkQueueSet& satb_mq_set = JavaThread::satb_mark_queue_set(); SATBMarkQueueSet& satb_mq_set = JavaThread::satb_mark_queue_set();
if (G1CollectedHeap::use_parallel_gc_threads()) { if (G1CollectedHeap::use_parallel_gc_threads()) {
satb_mq_set.set_par_closure(_task_id, &oc); satb_mq_set.set_par_closure(_worker_id, &oc);
} else { } else {
satb_mq_set.set_closure(&oc); satb_mq_set.set_closure(&oc);
} }
...@@ -3672,9 +3672,9 @@ void CMTask::drain_satb_buffers() { ...@@ -3672,9 +3672,9 @@ void CMTask::drain_satb_buffers() {
// until we run out of buffers or we need to abort. // until we run out of buffers or we need to abort.
if (G1CollectedHeap::use_parallel_gc_threads()) { if (G1CollectedHeap::use_parallel_gc_threads()) {
while (!has_aborted() && while (!has_aborted() &&
satb_mq_set.par_apply_closure_to_completed_buffer(_task_id)) { satb_mq_set.par_apply_closure_to_completed_buffer(_worker_id)) {
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] processed an SATB buffer", _task_id); gclog_or_tty->print_cr("[%u] processed an SATB buffer", _worker_id);
} }
statsOnly( ++_satb_buffers_processed ); statsOnly( ++_satb_buffers_processed );
regular_clock_call(); regular_clock_call();
...@@ -3683,7 +3683,7 @@ void CMTask::drain_satb_buffers() { ...@@ -3683,7 +3683,7 @@ void CMTask::drain_satb_buffers() {
while (!has_aborted() && while (!has_aborted() &&
satb_mq_set.apply_closure_to_completed_buffer()) { satb_mq_set.apply_closure_to_completed_buffer()) {
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] processed an SATB buffer", _task_id); gclog_or_tty->print_cr("[%u] processed an SATB buffer", _worker_id);
} }
statsOnly( ++_satb_buffers_processed ); statsOnly( ++_satb_buffers_processed );
regular_clock_call(); regular_clock_call();
...@@ -3693,7 +3693,7 @@ void CMTask::drain_satb_buffers() { ...@@ -3693,7 +3693,7 @@ void CMTask::drain_satb_buffers() {
if (!concurrent() && !has_aborted()) { if (!concurrent() && !has_aborted()) {
// We should only do this during remark. // We should only do this during remark.
if (G1CollectedHeap::use_parallel_gc_threads()) { if (G1CollectedHeap::use_parallel_gc_threads()) {
satb_mq_set.par_iterate_closure_all_threads(_task_id); satb_mq_set.par_iterate_closure_all_threads(_worker_id);
} else { } else {
satb_mq_set.iterate_closure_all_threads(); satb_mq_set.iterate_closure_all_threads();
} }
...@@ -3706,7 +3706,7 @@ void CMTask::drain_satb_buffers() { ...@@ -3706,7 +3706,7 @@ void CMTask::drain_satb_buffers() {
satb_mq_set.completed_buffers_num() == 0, "invariant"); satb_mq_set.completed_buffers_num() == 0, "invariant");
if (G1CollectedHeap::use_parallel_gc_threads()) { if (G1CollectedHeap::use_parallel_gc_threads()) {
satb_mq_set.set_par_closure(_task_id, NULL); satb_mq_set.set_par_closure(_worker_id, NULL);
} else { } else {
satb_mq_set.set_closure(NULL); satb_mq_set.set_closure(NULL);
} }
...@@ -3717,8 +3717,8 @@ void CMTask::drain_satb_buffers() { ...@@ -3717,8 +3717,8 @@ void CMTask::drain_satb_buffers() {
} }
void CMTask::print_stats() { void CMTask::print_stats() {
gclog_or_tty->print_cr("Marking Stats, task = %d, calls = %d", gclog_or_tty->print_cr("Marking Stats, task = %u, calls = %d",
_task_id, _calls); _worker_id, _calls);
gclog_or_tty->print_cr(" Elapsed time = %1.2lfms, Termination time = %1.2lfms", gclog_or_tty->print_cr(" Elapsed time = %1.2lfms, Termination time = %1.2lfms",
_elapsed_time_ms, _termination_time_ms); _elapsed_time_ms, _termination_time_ms);
gclog_or_tty->print_cr(" Step Times (cum): num = %d, avg = %1.2lfms, sd = %1.2lfms", gclog_or_tty->print_cr(" Step Times (cum): num = %d, avg = %1.2lfms, sd = %1.2lfms",
...@@ -3866,7 +3866,7 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -3866,7 +3866,7 @@ void CMTask::do_marking_step(double time_target_ms,
G1CollectorPolicy* g1_policy = _g1h->g1_policy(); G1CollectorPolicy* g1_policy = _g1h->g1_policy();
assert(_task_queues != NULL, "invariant"); assert(_task_queues != NULL, "invariant");
assert(_task_queue != NULL, "invariant"); assert(_task_queue != NULL, "invariant");
assert(_task_queues->queue(_task_id) == _task_queue, "invariant"); assert(_task_queues->queue(_worker_id) == _task_queue, "invariant");
assert(!_claimed, assert(!_claimed,
"only one thread should claim this task at any one time"); "only one thread should claim this task at any one time");
...@@ -3898,9 +3898,9 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -3898,9 +3898,9 @@ void CMTask::do_marking_step(double time_target_ms,
++_calls; ++_calls;
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] >>>>>>>>>> START, call = %d, " gclog_or_tty->print_cr("[%u] >>>>>>>>>> START, call = %d, "
"target = %1.2lfms >>>>>>>>>>", "target = %1.2lfms >>>>>>>>>>",
_task_id, _calls, _time_target_ms); _worker_id, _calls, _time_target_ms);
} }
// Set up the bitmap and oop closures. Anything that uses them is // Set up the bitmap and oop closures. Anything that uses them is
...@@ -3948,10 +3948,10 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -3948,10 +3948,10 @@ void CMTask::do_marking_step(double time_target_ms,
MemRegion mr = MemRegion(_finger, _region_limit); MemRegion mr = MemRegion(_finger, _region_limit);
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] we're scanning part " gclog_or_tty->print_cr("[%u] we're scanning part "
"["PTR_FORMAT", "PTR_FORMAT") " "["PTR_FORMAT", "PTR_FORMAT") "
"of region "PTR_FORMAT, "of region "PTR_FORMAT,
_task_id, _finger, _region_limit, _curr_region); _worker_id, _finger, _region_limit, _curr_region);
} }
// Let's iterate over the bitmap of the part of the // Let's iterate over the bitmap of the part of the
...@@ -4007,17 +4007,17 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4007,17 +4007,17 @@ void CMTask::do_marking_step(double time_target_ms,
assert(_finger == NULL, "invariant"); assert(_finger == NULL, "invariant");
assert(_region_limit == NULL, "invariant"); assert(_region_limit == NULL, "invariant");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] trying to claim a new region", _task_id); gclog_or_tty->print_cr("[%u] trying to claim a new region", _worker_id);
} }
HeapRegion* claimed_region = _cm->claim_region(_task_id); HeapRegion* claimed_region = _cm->claim_region(_worker_id);
if (claimed_region != NULL) { if (claimed_region != NULL) {
// Yes, we managed to claim one // Yes, we managed to claim one
statsOnly( ++_regions_claimed ); statsOnly( ++_regions_claimed );
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] we successfully claimed " gclog_or_tty->print_cr("[%u] we successfully claimed "
"region "PTR_FORMAT, "region "PTR_FORMAT,
_task_id, claimed_region); _worker_id, claimed_region);
} }
setup_for_region(claimed_region); setup_for_region(claimed_region);
...@@ -4044,7 +4044,7 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4044,7 +4044,7 @@ void CMTask::do_marking_step(double time_target_ms,
"at this point we should be out of regions"); "at this point we should be out of regions");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] all regions claimed", _task_id); gclog_or_tty->print_cr("[%u] all regions claimed", _worker_id);
} }
// Try to reduce the number of available SATB buffers so that // Try to reduce the number of available SATB buffers so that
...@@ -4068,17 +4068,17 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4068,17 +4068,17 @@ void CMTask::do_marking_step(double time_target_ms,
"only way to reach here"); "only way to reach here");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] starting to steal", _task_id); gclog_or_tty->print_cr("[%u] starting to steal", _worker_id);
} }
while (!has_aborted()) { while (!has_aborted()) {
oop obj; oop obj;
statsOnly( ++_steal_attempts ); statsOnly( ++_steal_attempts );
if (_cm->try_stealing(_task_id, &_hash_seed, obj)) { if (_cm->try_stealing(_worker_id, &_hash_seed, obj)) {
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] stolen "PTR_FORMAT" successfully", gclog_or_tty->print_cr("[%u] stolen "PTR_FORMAT" successfully",
_task_id, (void*) obj); _worker_id, (void*) obj);
} }
statsOnly( ++_steals ); statsOnly( ++_steals );
...@@ -4116,7 +4116,7 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4116,7 +4116,7 @@ void CMTask::do_marking_step(double time_target_ms,
assert(_task_queue->size() == 0, "only way to reach here"); assert(_task_queue->size() == 0, "only way to reach here");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] starting termination protocol", _task_id); gclog_or_tty->print_cr("[%u] starting termination protocol", _worker_id);
} }
_termination_start_time_ms = os::elapsedVTime() * 1000.0; _termination_start_time_ms = os::elapsedVTime() * 1000.0;
...@@ -4131,7 +4131,7 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4131,7 +4131,7 @@ void CMTask::do_marking_step(double time_target_ms,
if (finished) { if (finished) {
// We're all done. // We're all done.
if (_task_id == 0) { if (_worker_id == 0) {
// let's allow task 0 to do this // let's allow task 0 to do this
if (concurrent()) { if (concurrent()) {
assert(_cm->concurrent_marking_in_progress(), "invariant"); assert(_cm->concurrent_marking_in_progress(), "invariant");
...@@ -4153,15 +4153,15 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4153,15 +4153,15 @@ void CMTask::do_marking_step(double time_target_ms,
guarantee(!_cm->mark_stack_overflow(), "only way to reach here"); guarantee(!_cm->mark_stack_overflow(), "only way to reach here");
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] all tasks terminated", _task_id); gclog_or_tty->print_cr("[%u] all tasks terminated", _worker_id);
} }
} else { } else {
// Apparently there's more work to do. Let's abort this task. It // Apparently there's more work to do. Let's abort this task. It
// will restart it and we can hopefully find more things to do. // will restart it and we can hopefully find more things to do.
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] apparently there is more work to do", gclog_or_tty->print_cr("[%u] apparently there is more work to do",
_task_id); _worker_id);
} }
set_has_aborted(); set_has_aborted();
...@@ -4200,10 +4200,10 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4200,10 +4200,10 @@ void CMTask::do_marking_step(double time_target_ms,
// will achieve this with the use of two barrier sync points. // will achieve this with the use of two barrier sync points.
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] detected overflow", _task_id); gclog_or_tty->print_cr("[%u] detected overflow", _worker_id);
} }
_cm->enter_first_sync_barrier(_task_id); _cm->enter_first_sync_barrier(_worker_id);
// When we exit this sync barrier we know that all tasks have // When we exit this sync barrier we know that all tasks have
// stopped doing marking work. So, it's now safe to // stopped doing marking work. So, it's now safe to
// re-initialise our data structures. At the end of this method, // re-initialise our data structures. At the end of this method,
...@@ -4215,39 +4215,39 @@ void CMTask::do_marking_step(double time_target_ms, ...@@ -4215,39 +4215,39 @@ void CMTask::do_marking_step(double time_target_ms,
clear_region_fields(); clear_region_fields();
// ...and enter the second barrier. // ...and enter the second barrier.
_cm->enter_second_sync_barrier(_task_id); _cm->enter_second_sync_barrier(_worker_id);
// At this point everything has bee re-initialised and we're // At this point everything has bee re-initialised and we're
// ready to restart. // ready to restart.
} }
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] <<<<<<<<<< ABORTING, target = %1.2lfms, " gclog_or_tty->print_cr("[%u] <<<<<<<<<< ABORTING, target = %1.2lfms, "
"elapsed = %1.2lfms <<<<<<<<<<", "elapsed = %1.2lfms <<<<<<<<<<",
_task_id, _time_target_ms, elapsed_time_ms); _worker_id, _time_target_ms, elapsed_time_ms);
if (_cm->has_aborted()) { if (_cm->has_aborted()) {
gclog_or_tty->print_cr("[%d] ========== MARKING ABORTED ==========", gclog_or_tty->print_cr("[%u] ========== MARKING ABORTED ==========",
_task_id); _worker_id);
} }
} }
} else { } else {
if (_cm->verbose_low()) { if (_cm->verbose_low()) {
gclog_or_tty->print_cr("[%d] <<<<<<<<<< FINISHED, target = %1.2lfms, " gclog_or_tty->print_cr("[%u] <<<<<<<<<< FINISHED, target = %1.2lfms, "
"elapsed = %1.2lfms <<<<<<<<<<", "elapsed = %1.2lfms <<<<<<<<<<",
_task_id, _time_target_ms, elapsed_time_ms); _worker_id, _time_target_ms, elapsed_time_ms);
} }
} }
_claimed = false; _claimed = false;
} }
CMTask::CMTask(int task_id, CMTask::CMTask(uint worker_id,
ConcurrentMark* cm, ConcurrentMark* cm,
size_t* marked_bytes, size_t* marked_bytes,
BitMap* card_bm, BitMap* card_bm,
CMTaskQueue* task_queue, CMTaskQueue* task_queue,
CMTaskQueueSet* task_queues) CMTaskQueueSet* task_queues)
: _g1h(G1CollectedHeap::heap()), : _g1h(G1CollectedHeap::heap()),
_task_id(task_id), _cm(cm), _worker_id(worker_id), _cm(cm),
_claimed(false), _claimed(false),
_nextMarkBitMap(NULL), _hash_seed(17), _nextMarkBitMap(NULL), _hash_seed(17),
_task_queue(task_queue), _task_queue(task_queue),
......
...@@ -399,9 +399,9 @@ protected: ...@@ -399,9 +399,9 @@ protected:
// last claimed region // last claimed region
// marking tasks // marking tasks
uint _max_task_num; // maximum task number uint _max_worker_id;// maximum worker id
uint _active_tasks; // task num currently active uint _active_tasks; // task num currently active
CMTask** _tasks; // task queue array (max_task_num len) CMTask** _tasks; // task queue array (max_worker_id len)
CMTaskQueueSet* _task_queues; // task queue set CMTaskQueueSet* _task_queues; // task queue set
ParallelTaskTerminator _terminator; // for termination ParallelTaskTerminator _terminator; // for termination
...@@ -492,10 +492,10 @@ protected: ...@@ -492,10 +492,10 @@ protected:
ParallelTaskTerminator* terminator() { return &_terminator; } ParallelTaskTerminator* terminator() { return &_terminator; }
// It claims the next available region to be scanned by a marking // It claims the next available region to be scanned by a marking
// task. It might return NULL if the next region is empty or we have // task/thread. It might return NULL if the next region is empty or
// run out of regions. In the latter case, out_of_regions() // we have run out of regions. In the latter case, out_of_regions()
// determines whether we've really run out of regions or the task // determines whether we've really run out of regions or the task
// should call claim_region() again. This might seem a bit // should call claim_region() again. This might seem a bit
// awkward. Originally, the code was written so that claim_region() // awkward. Originally, the code was written so that claim_region()
// either successfully returned with a non-empty region or there // either successfully returned with a non-empty region or there
// were no more regions to be claimed. The problem with this was // were no more regions to be claimed. The problem with this was
...@@ -505,7 +505,7 @@ protected: ...@@ -505,7 +505,7 @@ protected:
// method. So, this way, each task will spend very little time in // method. So, this way, each task will spend very little time in
// claim_region() and is allowed to call the regular clock method // claim_region() and is allowed to call the regular clock method
// frequently. // frequently.
HeapRegion* claim_region(int task); HeapRegion* claim_region(uint worker_id);
// It determines whether we've run out of regions to scan. // It determines whether we've run out of regions to scan.
bool out_of_regions() { return _finger == _heap_end; } bool out_of_regions() { return _finger == _heap_end; }
...@@ -537,8 +537,8 @@ protected: ...@@ -537,8 +537,8 @@ protected:
bool has_aborted() { return _has_aborted; } bool has_aborted() { return _has_aborted; }
// Methods to enter the two overflow sync barriers // Methods to enter the two overflow sync barriers
void enter_first_sync_barrier(int task_num); void enter_first_sync_barrier(uint worker_id);
void enter_second_sync_barrier(int task_num); void enter_second_sync_barrier(uint worker_id);
ForceOverflowSettings* force_overflow_conc() { ForceOverflowSettings* force_overflow_conc() {
return &_force_overflow_conc; return &_force_overflow_conc;
...@@ -626,14 +626,14 @@ public: ...@@ -626,14 +626,14 @@ public:
double all_task_accum_vtime() { double all_task_accum_vtime() {
double ret = 0.0; double ret = 0.0;
for (int i = 0; i < (int)_max_task_num; ++i) for (uint i = 0; i < _max_worker_id; ++i)
ret += _accum_task_vtime[i]; ret += _accum_task_vtime[i];
return ret; return ret;
} }
// Attempts to steal an object from the task queues of other tasks // Attempts to steal an object from the task queues of other tasks
bool try_stealing(int task_num, int* hash_seed, oop& obj) { bool try_stealing(uint worker_id, int* hash_seed, oop& obj) {
return _task_queues->steal(task_num, hash_seed, obj); return _task_queues->steal(worker_id, hash_seed, obj);
} }
ConcurrentMark(ReservedSpace rs, uint max_regions); ConcurrentMark(ReservedSpace rs, uint max_regions);
...@@ -823,7 +823,7 @@ public: ...@@ -823,7 +823,7 @@ public:
// Returns the card bitmap for a given task or worker id. // Returns the card bitmap for a given task or worker id.
BitMap* count_card_bitmap_for(uint worker_id) { BitMap* count_card_bitmap_for(uint worker_id) {
assert(0 <= worker_id && worker_id < _max_task_num, "oob"); assert(0 <= worker_id && worker_id < _max_worker_id, "oob");
assert(_count_card_bitmaps != NULL, "uninitialized"); assert(_count_card_bitmaps != NULL, "uninitialized");
BitMap* task_card_bm = &_count_card_bitmaps[worker_id]; BitMap* task_card_bm = &_count_card_bitmaps[worker_id];
assert(task_card_bm->size() == _card_bm.size(), "size mismatch"); assert(task_card_bm->size() == _card_bm.size(), "size mismatch");
...@@ -833,7 +833,7 @@ public: ...@@ -833,7 +833,7 @@ public:
// Returns the array containing the marked bytes for each region, // Returns the array containing the marked bytes for each region,
// for the given worker or task id. // for the given worker or task id.
size_t* count_marked_bytes_array_for(uint worker_id) { size_t* count_marked_bytes_array_for(uint worker_id) {
assert(0 <= worker_id && worker_id < _max_task_num, "oob"); assert(0 <= worker_id && worker_id < _max_worker_id, "oob");
assert(_count_marked_bytes != NULL, "uninitialized"); assert(_count_marked_bytes != NULL, "uninitialized");
size_t* marked_bytes_array = _count_marked_bytes[worker_id]; size_t* marked_bytes_array = _count_marked_bytes[worker_id];
assert(marked_bytes_array != NULL, "uninitialized"); assert(marked_bytes_array != NULL, "uninitialized");
...@@ -939,7 +939,7 @@ private: ...@@ -939,7 +939,7 @@ private:
global_stack_transfer_size = 16 global_stack_transfer_size = 16
}; };
int _task_id; uint _worker_id;
G1CollectedHeap* _g1h; G1CollectedHeap* _g1h;
ConcurrentMark* _cm; ConcurrentMark* _cm;
CMBitMap* _nextMarkBitMap; CMBitMap* _nextMarkBitMap;
...@@ -1115,8 +1115,8 @@ public: ...@@ -1115,8 +1115,8 @@ public:
_elapsed_time_ms = os::elapsedTime() * 1000.0 - _elapsed_time_ms; _elapsed_time_ms = os::elapsedTime() * 1000.0 - _elapsed_time_ms;
} }
// returns the task ID // returns the worker ID associated with this task.
int task_id() { return _task_id; } uint worker_id() { return _worker_id; }
// From TerminatorTerminator. It determines whether this task should // From TerminatorTerminator. It determines whether this task should
// exit the termination protocol after it's entered it. // exit the termination protocol after it's entered it.
...@@ -1170,7 +1170,7 @@ public: ...@@ -1170,7 +1170,7 @@ public:
_finger = new_finger; _finger = new_finger;
} }
CMTask(int task_num, ConcurrentMark *cm, CMTask(uint worker_id, ConcurrentMark *cm,
size_t* marked_bytes, BitMap* card_bm, size_t* marked_bytes, BitMap* card_bm,
CMTaskQueue* task_queue, CMTaskQueueSet* task_queues); CMTaskQueue* task_queue, CMTaskQueueSet* task_queues);
......
...@@ -279,7 +279,7 @@ inline void CMTask::push(oop obj) { ...@@ -279,7 +279,7 @@ inline void CMTask::push(oop obj) {
assert(_nextMarkBitMap->isMarked(objAddr), "invariant"); assert(_nextMarkBitMap->isMarked(objAddr), "invariant");
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] pushing "PTR_FORMAT, _task_id, (void*) obj); gclog_or_tty->print_cr("[%u] pushing "PTR_FORMAT, _worker_id, (void*) obj);
} }
if (!_task_queue->push(obj)) { if (!_task_queue->push(obj)) {
...@@ -287,9 +287,9 @@ inline void CMTask::push(oop obj) { ...@@ -287,9 +287,9 @@ inline void CMTask::push(oop obj) {
// to the global stack. // to the global stack.
if (_cm->verbose_medium()) { if (_cm->verbose_medium()) {
gclog_or_tty->print_cr("[%d] task queue overflow, " gclog_or_tty->print_cr("[%u] task queue overflow, "
"moving entries to the global stack", "moving entries to the global stack",
_task_id); _worker_id);
} }
move_entries_to_global_stack(); move_entries_to_global_stack();
...@@ -318,8 +318,8 @@ inline void CMTask::push(oop obj) { ...@@ -318,8 +318,8 @@ inline void CMTask::push(oop obj) {
inline void CMTask::deal_with_reference(oop obj) { inline void CMTask::deal_with_reference(oop obj) {
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] we're dealing with reference = "PTR_FORMAT, gclog_or_tty->print_cr("[%u] we're dealing with reference = "PTR_FORMAT,
_task_id, (void*) obj); _worker_id, (void*) obj);
} }
++_refs_reached; ++_refs_reached;
...@@ -335,8 +335,8 @@ inline void CMTask::deal_with_reference(oop obj) { ...@@ -335,8 +335,8 @@ inline void CMTask::deal_with_reference(oop obj) {
HeapRegion* hr = _g1h->heap_region_containing_raw(obj); HeapRegion* hr = _g1h->heap_region_containing_raw(obj);
if (!hr->obj_allocated_since_next_marking(obj)) { if (!hr->obj_allocated_since_next_marking(obj)) {
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] "PTR_FORMAT" is not considered marked", gclog_or_tty->print_cr("[%u] "PTR_FORMAT" is not considered marked",
_task_id, (void*) obj); _worker_id, (void*) obj);
} }
// we need to mark it first // we need to mark it first
...@@ -350,8 +350,8 @@ inline void CMTask::deal_with_reference(oop obj) { ...@@ -350,8 +350,8 @@ inline void CMTask::deal_with_reference(oop obj) {
if (_finger != NULL && objAddr < _finger) { if (_finger != NULL && objAddr < _finger) {
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] below the local finger ("PTR_FORMAT"), " gclog_or_tty->print_cr("[%u] below the local finger ("PTR_FORMAT"), "
"pushing it", _task_id, _finger); "pushing it", _worker_id, _finger);
} }
push(obj); push(obj);
} else if (_curr_region != NULL && objAddr < _region_limit) { } else if (_curr_region != NULL && objAddr < _region_limit) {
...@@ -367,9 +367,9 @@ inline void CMTask::deal_with_reference(oop obj) { ...@@ -367,9 +367,9 @@ inline void CMTask::deal_with_reference(oop obj) {
// correctness problems. // correctness problems.
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] below the global finger " gclog_or_tty->print_cr("[%u] below the global finger "
"("PTR_FORMAT"), pushing it", "("PTR_FORMAT"), pushing it",
_task_id, global_finger); _worker_id, global_finger);
} }
push(obj); push(obj);
} else { } else {
...@@ -382,9 +382,9 @@ inline void CMTask::deal_with_reference(oop obj) { ...@@ -382,9 +382,9 @@ inline void CMTask::deal_with_reference(oop obj) {
// see long comment above // see long comment above
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] below the global finger " gclog_or_tty->print_cr("[%u] below the global finger "
"("PTR_FORMAT"), pushing it", "("PTR_FORMAT"), pushing it",
_task_id, global_finger); _worker_id, global_finger);
} }
push(obj); push(obj);
} }
......
...@@ -111,9 +111,9 @@ inline void G1CMOopClosure::do_oop_nv(T* p) { ...@@ -111,9 +111,9 @@ inline void G1CMOopClosure::do_oop_nv(T* p) {
oop obj = oopDesc::load_decode_heap_oop(p); oop obj = oopDesc::load_decode_heap_oop(p);
if (_cm->verbose_high()) { if (_cm->verbose_high()) {
gclog_or_tty->print_cr("[%d] we're looking at location " gclog_or_tty->print_cr("[%u] we're looking at location "
"*"PTR_FORMAT" = "PTR_FORMAT, "*"PTR_FORMAT" = "PTR_FORMAT,
_task->task_id(), p, (void*) obj); _task->worker_id(), p, (void*) obj);
} }
_task->deal_with_reference(obj); _task->deal_with_reference(obj);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册