8246622: Remove CollectedHeap::print_gc_threads_on()

Reviewed-by: stefank, tschatzl, sjohanss
This commit is contained in:
Per Lidén 2020-06-05 15:22:53 +02:00
parent c66bef0289
commit 06e47d05b6
27 changed files with 31 additions and 127 deletions

View File

@ -117,7 +117,6 @@ public:
bool block_is_obj(const HeapWord* addr) const { return false; } bool block_is_obj(const HeapWord* addr) const { return false; }
// No GC threads // No GC threads
virtual void print_gc_threads_on(outputStream* st) const {}
virtual void gc_threads_do(ThreadClosure* tc) const {} virtual void gc_threads_do(ThreadClosure* tc) const {}
// No nmethod handling // No nmethod handling

View File

@ -2567,18 +2567,6 @@ void G1CollectedHeap::print_on_error(outputStream* st) const {
} }
} }
void G1CollectedHeap::print_gc_threads_on(outputStream* st) const {
workers()->print_worker_threads_on(st);
_cm_thread->print_on(st);
st->cr();
_cm->print_worker_threads_on(st);
_cr->print_threads_on(st);
_young_gen_sampling_thread->print_on(st);
if (G1StringDedup::is_enabled()) {
G1StringDedup::print_worker_threads_on(st);
}
}
void G1CollectedHeap::gc_threads_do(ThreadClosure* tc) const { void G1CollectedHeap::gc_threads_do(ThreadClosure* tc) const {
workers()->threads_do(tc); workers()->threads_do(tc);
tc->do_thread(_cm_thread); tc->do_thread(_cm_thread);

View File

@ -1454,7 +1454,6 @@ public:
virtual void print_extended_on(outputStream* st) const; virtual void print_extended_on(outputStream* st) const;
virtual void print_on_error(outputStream* st) const; virtual void print_on_error(outputStream* st) const;
virtual void print_gc_threads_on(outputStream* st) const;
virtual void gc_threads_do(ThreadClosure* tc) const; virtual void gc_threads_do(ThreadClosure* tc) const;
// Override // Override

View File

@ -2026,10 +2026,6 @@ void G1ConcurrentMark::print_summary_info() {
cm_thread()->vtime_accum(), cm_thread()->vtime_mark_accum()); cm_thread()->vtime_accum(), cm_thread()->vtime_mark_accum());
} }
void G1ConcurrentMark::print_worker_threads_on(outputStream* st) const {
_concurrent_workers->print_worker_threads_on(st);
}
void G1ConcurrentMark::threads_do(ThreadClosure* tc) const { void G1ConcurrentMark::threads_do(ThreadClosure* tc) const {
_concurrent_workers->threads_do(tc); _concurrent_workers->threads_do(tc);
} }

View File

@ -583,7 +583,6 @@ public:
void print_summary_info(); void print_summary_info();
void print_worker_threads_on(outputStream* st) const;
void threads_do(ThreadClosure* tc) const; void threads_do(ThreadClosure* tc) const;
void print_on_error(outputStream* st) const; void print_on_error(outputStream* st) const;

View File

@ -114,15 +114,6 @@ void G1ConcurrentRefineThreadControl::maybe_activate_next(uint cur_worker_id) {
} }
} }
void G1ConcurrentRefineThreadControl::print_on(outputStream* st) const {
for (uint i = 0; i < _num_max_threads; ++i) {
if (_threads[i] != NULL) {
_threads[i]->print_on(st);
st->cr();
}
}
}
void G1ConcurrentRefineThreadControl::worker_threads_do(ThreadClosure* tc) { void G1ConcurrentRefineThreadControl::worker_threads_do(ThreadClosure* tc) {
for (uint i = 0; i < _num_max_threads; i++) { for (uint i = 0; i < _num_max_threads; i++) {
if (_threads[i] != NULL) { if (_threads[i] != NULL) {
@ -318,10 +309,6 @@ uint G1ConcurrentRefine::max_num_threads() {
return G1ConcRefinementThreads; return G1ConcRefinementThreads;
} }
void G1ConcurrentRefine::print_threads_on(outputStream* st) const {
_thread_control.print_on(st);
}
static size_t calc_new_green_zone(size_t green, static size_t calc_new_green_zone(size_t green,
double logged_cards_scan_time, double logged_cards_scan_time,
size_t processed_logged_cards, size_t processed_logged_cards,

View File

@ -57,7 +57,6 @@ public:
// activate it. // activate it.
void maybe_activate_next(uint cur_worker_id); void maybe_activate_next(uint cur_worker_id);
void print_on(outputStream* st) const;
void worker_threads_do(ThreadClosure* tc); void worker_threads_do(ThreadClosure* tc);
void stop(); void stop();
}; };
@ -139,8 +138,6 @@ public:
// Maximum number of refinement threads. // Maximum number of refinement threads.
static uint max_num_threads(); static uint max_num_threads();
void print_threads_on(outputStream* st) const;
// Cards in the dirty card queue set. // Cards in the dirty card queue set.
size_t green_zone() const { return _green_zone; } size_t green_zone() const { return _green_zone; }
size_t yellow_zone() const { return _yellow_zone; } size_t yellow_zone() const { return _yellow_zone; }

View File

@ -615,10 +615,6 @@ void ParallelScavengeHeap::gc_threads_do(ThreadClosure* tc) const {
ParallelScavengeHeap::heap()->workers().threads_do(tc); ParallelScavengeHeap::heap()->workers().threads_do(tc);
} }
void ParallelScavengeHeap::print_gc_threads_on(outputStream* st) const {
ParallelScavengeHeap::heap()->workers().print_worker_threads_on(st);
}
void ParallelScavengeHeap::print_tracing_info() const { void ParallelScavengeHeap::print_tracing_info() const {
AdaptiveSizePolicyOutput::print(); AdaptiveSizePolicyOutput::print();
log_debug(gc, heap, exit)("Accumulated young generation GC time %3.7f secs", PSScavenge::accumulated_time()->seconds()); log_debug(gc, heap, exit)("Accumulated young generation GC time %3.7f secs", PSScavenge::accumulated_time()->seconds());

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -217,7 +217,6 @@ class ParallelScavengeHeap : public CollectedHeap {
PSHeapSummary create_ps_heap_summary(); PSHeapSummary create_ps_heap_summary();
virtual void print_on(outputStream* st) const; virtual void print_on(outputStream* st) const;
virtual void print_on_error(outputStream* st) const; virtual void print_on_error(outputStream* st) const;
virtual void print_gc_threads_on(outputStream* st) const;
virtual void gc_threads_do(ThreadClosure* tc) const; virtual void gc_threads_do(ThreadClosure* tc) const;
virtual void print_tracing_info() const; virtual void print_tracing_info() const;

View File

@ -429,13 +429,6 @@ class CollectedHeap : public CHeapObj<mtInternal> {
// Used to print information about locations in the hs_err file. // Used to print information about locations in the hs_err file.
virtual bool print_location(outputStream* st, void* addr) const = 0; virtual bool print_location(outputStream* st, void* addr) const = 0;
// Print all GC threads (other than the VM thread)
// used by this heap.
virtual void print_gc_threads_on(outputStream* st) const = 0;
// The default behavior is to call print_gc_threads_on() on tty.
void print_gc_threads() {
print_gc_threads_on(tty);
}
// Iterator for all GC threads (other than VM thread) // Iterator for all GC threads (other than VM thread)
virtual void gc_threads_do(ThreadClosure* tc) const = 0; virtual void gc_threads_do(ThreadClosure* tc) const = 0;

View File

@ -1237,9 +1237,6 @@ void GenCollectedHeap::print_on(outputStream* st) const {
void GenCollectedHeap::gc_threads_do(ThreadClosure* tc) const { void GenCollectedHeap::gc_threads_do(ThreadClosure* tc) const {
} }
void GenCollectedHeap::print_gc_threads_on(outputStream* st) const {
}
bool GenCollectedHeap::print_location(outputStream* st, void* addr) const { bool GenCollectedHeap::print_location(outputStream* st, void* addr) const {
return BlockLocationPrinter<GenCollectedHeap>::print_location(st, addr); return BlockLocationPrinter<GenCollectedHeap>::print_location(st, addr);
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -331,7 +331,6 @@ public:
// Override. // Override.
virtual void print_on(outputStream* st) const; virtual void print_on(outputStream* st) const;
virtual void print_gc_threads_on(outputStream* st) const;
virtual void gc_threads_do(ThreadClosure* tc) const; virtual void gc_threads_do(ThreadClosure* tc) const;
virtual void print_tracing_info() const; virtual void print_tracing_info() const;

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -65,12 +65,6 @@ void StringDedup::threads_do(ThreadClosure* tc) {
tc->do_thread(StringDedupThread::thread()); tc->do_thread(StringDedupThread::thread());
} }
void StringDedup::print_worker_threads_on(outputStream* st) {
assert(is_enabled(), "String deduplication not enabled");
StringDedupThread::thread()->print_on(st);
st->cr();
}
void StringDedup::verify() { void StringDedup::verify() {
assert(is_enabled(), "String deduplication not enabled"); assert(is_enabled(), "String deduplication not enabled");
StringDedupQueue::verify(); StringDedupQueue::verify();

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -95,7 +95,7 @@ public:
static void parallel_unlink(StringDedupUnlinkOrOopsDoClosure* unlink, uint worker_id); static void parallel_unlink(StringDedupUnlinkOrOopsDoClosure* unlink, uint worker_id);
static void threads_do(ThreadClosure* tc); static void threads_do(ThreadClosure* tc);
static void print_worker_threads_on(outputStream* st);
static void verify(); static void verify();
// GC support // GC support

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -86,14 +86,6 @@ AbstractGangWorker* AbstractWorkGang::worker(uint i) const {
return result; return result;
} }
void AbstractWorkGang::print_worker_threads_on(outputStream* st) const {
uint workers = created_workers();
for (uint i = 0; i < workers; i++) {
worker(i)->print_on(st);
st->cr();
}
}
void AbstractWorkGang::threads_do(ThreadClosure* tc) const { void AbstractWorkGang::threads_do(ThreadClosure* tc) const {
assert(tc != NULL, "Null ThreadClosure"); assert(tc != NULL, "Null ThreadClosure");
uint workers = created_workers(); uint workers = created_workers();

View File

@ -188,12 +188,6 @@ class AbstractWorkGang : public CHeapObj<mtInternal> {
// Debugging. // Debugging.
const char* name() const { return _name; } const char* name() const { return _name; }
// Printing
void print_worker_threads_on(outputStream *st) const;
void print_worker_threads() const {
print_worker_threads_on(tty);
}
protected: protected:
virtual AbstractGangWorker* allocate_worker(uint which) = 0; virtual AbstractGangWorker* allocate_worker(uint which) = 0;
}; };

View File

@ -1178,13 +1178,6 @@ void ShenandoahHeap::prepare_for_verify() {
} }
} }
void ShenandoahHeap::print_gc_threads_on(outputStream* st) const {
workers()->print_worker_threads_on(st);
if (ShenandoahStringDedup::is_enabled()) {
ShenandoahStringDedup::print_worker_threads_on(st);
}
}
void ShenandoahHeap::gc_threads_do(ThreadClosure* tcl) const { void ShenandoahHeap::gc_threads_do(ThreadClosure* tcl) const {
workers()->threads_do(tcl); workers()->threads_do(tcl);
if (_safepoint_workers != NULL) { if (_safepoint_workers != NULL) {

View File

@ -160,7 +160,6 @@ public:
void print_on(outputStream* st) const; void print_on(outputStream* st) const;
void print_extended_on(outputStream *st) const; void print_extended_on(outputStream *st) const;
void print_tracing_info() const; void print_tracing_info() const;
void print_gc_threads_on(outputStream* st) const;
void print_heap_regions_on(outputStream* st) const; void print_heap_regions_on(outputStream* st) const;
void stop(); void stop();

View File

@ -329,19 +329,6 @@ void ZCollectedHeap::print_extended_on(outputStream* st) const {
_heap.print_extended_on(st); _heap.print_extended_on(st);
} }
void ZCollectedHeap::print_gc_threads_on(outputStream* st) const {
_director->print_on(st);
st->cr();
_driver->print_on(st);
st->cr();
_uncommitter->print_on(st);
st->cr();
_stat->print_on(st);
st->cr();
_heap.print_worker_threads_on(st);
_runtime_workers.print_threads_on(st);
}
void ZCollectedHeap::print_tracing_info() const { void ZCollectedHeap::print_tracing_info() const {
// Does nothing // Does nothing
} }

View File

@ -120,7 +120,6 @@ public:
virtual void print_on(outputStream* st) const; virtual void print_on(outputStream* st) const;
virtual void print_on_error(outputStream* st) const; virtual void print_on_error(outputStream* st) const;
virtual void print_extended_on(outputStream* st) const; virtual void print_extended_on(outputStream* st) const;
virtual void print_gc_threads_on(outputStream* st) const;
virtual void print_tracing_info() const; virtual void print_tracing_info() const;
virtual bool print_location(outputStream* st, void* addr) const; virtual bool print_location(outputStream* st, void* addr) const;

View File

@ -202,10 +202,6 @@ void ZHeap::worker_threads_do(ThreadClosure* tc) const {
_workers.threads_do(tc); _workers.threads_do(tc);
} }
void ZHeap::print_worker_threads_on(outputStream* st) const {
_workers.print_threads_on(st);
}
void ZHeap::out_of_memory() { void ZHeap::out_of_memory() {
ResourceMark rm; ResourceMark rm;

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -104,7 +104,6 @@ public:
uint nconcurrent_no_boost_worker_threads() const; uint nconcurrent_no_boost_worker_threads() const;
void set_boost_worker_threads(bool boost); void set_boost_worker_threads(bool boost);
void worker_threads_do(ThreadClosure* tc) const; void worker_threads_do(ThreadClosure* tc) const;
void print_worker_threads_on(outputStream* st) const;
// Reference processing // Reference processing
ReferenceDiscoverer* reference_discoverer(); ReferenceDiscoverer* reference_discoverer();

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -94,7 +94,3 @@ WorkGang* ZRuntimeWorkers::workers() {
void ZRuntimeWorkers::threads_do(ThreadClosure* tc) const { void ZRuntimeWorkers::threads_do(ThreadClosure* tc) const {
_workers.threads_do(tc); _workers.threads_do(tc);
} }
void ZRuntimeWorkers::print_threads_on(outputStream* st) const {
_workers.print_worker_threads_on(st);
}

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -40,7 +40,6 @@ public:
WorkGang* workers(); WorkGang* workers();
void threads_do(ThreadClosure* tc) const; void threads_do(ThreadClosure* tc) const;
void print_threads_on(outputStream* st) const;
}; };
#endif // SHARE_GC_Z_ZRUNTIMEWORKERS_HPP #endif // SHARE_GC_Z_ZRUNTIMEWORKERS_HPP

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -111,7 +111,3 @@ void ZWorkers::run_concurrent(ZTask* task) {
void ZWorkers::threads_do(ThreadClosure* tc) const { void ZWorkers::threads_do(ThreadClosure* tc) const {
_workers.threads_do(tc); _workers.threads_do(tc);
} }
void ZWorkers::print_threads_on(outputStream* st) const {
_workers.print_worker_threads_on(st);
}

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -52,7 +52,6 @@ public:
void run_concurrent(ZTask* task); void run_concurrent(ZTask* task);
void threads_do(ThreadClosure* tc) const; void threads_do(ThreadClosure* tc) const;
void print_threads_on(outputStream* st) const;
}; };
#endif // SHARE_GC_Z_ZWORKERS_HPP #endif // SHARE_GC_Z_ZWORKERS_HPP

View File

@ -4736,6 +4736,22 @@ JavaThread *Threads::owning_thread_from_monitor_owner(ThreadsList * t_list,
return the_owner; return the_owner;
} }
class PrintOnClosure : public ThreadClosure {
private:
outputStream* _st;
public:
PrintOnClosure(outputStream* st) :
_st(st) {}
virtual void do_thread(Thread* thread) {
if (thread != NULL) {
thread->print_on(_st);
_st->cr();
}
}
};
// Threads::print_on() is called at safepoint by VM_PrintThreads operation. // Threads::print_on() is called at safepoint by VM_PrintThreads operation.
void Threads::print_on(outputStream* st, bool print_stacks, void Threads::print_on(outputStream* st, bool print_stacks,
bool internal_format, bool print_concurrent_locks, bool internal_format, bool print_concurrent_locks,
@ -4778,14 +4794,10 @@ void Threads::print_on(outputStream* st, bool print_stacks,
#endif // INCLUDE_SERVICES #endif // INCLUDE_SERVICES
} }
VMThread::vm_thread()->print_on(st); PrintOnClosure cl(st);
st->cr(); cl.do_thread(VMThread::vm_thread());
Universe::heap()->print_gc_threads_on(st); Universe::heap()->gc_threads_do(&cl);
WatcherThread* wt = WatcherThread::watcher_thread(); cl.do_thread(WatcherThread::watcher_thread());
if (wt != NULL) {
wt->print_on(st);
st->cr();
}
st->flush(); st->flush();
} }