24
25 #include "precompiled.hpp"
26 #include "aot/aotLoader.hpp"
27 #include "classfile/classLoaderDataGraph.hpp"
28 #include "classfile/stringTable.hpp"
29 #include "classfile/systemDictionary.hpp"
30 #include "code/codeCache.hpp"
31 #include "gc/g1/g1BarrierSet.hpp"
32 #include "gc/g1/g1CodeBlobClosure.hpp"
33 #include "gc/g1/g1CollectedHeap.inline.hpp"
34 #include "gc/g1/g1CollectorState.hpp"
35 #include "gc/g1/g1GCPhaseTimes.hpp"
36 #include "gc/g1/g1ParScanThreadState.inline.hpp"
37 #include "gc/g1/g1Policy.hpp"
38 #include "gc/g1/g1RootClosures.hpp"
39 #include "gc/g1/g1RootProcessor.hpp"
40 #include "gc/g1/heapRegion.inline.hpp"
41 #include "gc/shared/referenceProcessor.hpp"
42 #include "memory/allocation.inline.hpp"
43 #include "memory/universe.hpp"
44 #include "runtime/mutex.hpp"
45 #include "services/management.hpp"
46 #include "utilities/macros.hpp"
47
48 void G1RootProcessor::worker_has_discovered_all_strong_nmethods() {
49 assert(ClassUnloadingWithConcurrentMark, "Currently only needed when doing G1 Class Unloading");
50
51 uint new_value = (uint)Atomic::add(1, &_n_workers_discovered_strong_classes);
52 if (new_value == n_workers()) {
53 // This thread is last. Notify the others.
54 MonitorLocker ml(&_lock, Mutex::_no_safepoint_check_flag);
55 _lock.notify_all();
56 }
57 }
58
59 void G1RootProcessor::wait_until_all_strong_nmethods_discovered() {
60 assert(ClassUnloadingWithConcurrentMark, "Currently only needed when doing G1 Class Unloading");
61
62 if ((uint)_n_workers_discovered_strong_classes != n_workers()) {
63 MonitorLocker ml(&_lock, Mutex::_no_safepoint_check_flag);
64 while ((uint)_n_workers_discovered_strong_classes != n_workers()) {
|
24
25 #include "precompiled.hpp"
26 #include "aot/aotLoader.hpp"
27 #include "classfile/classLoaderDataGraph.hpp"
28 #include "classfile/stringTable.hpp"
29 #include "classfile/systemDictionary.hpp"
30 #include "code/codeCache.hpp"
31 #include "gc/g1/g1BarrierSet.hpp"
32 #include "gc/g1/g1CodeBlobClosure.hpp"
33 #include "gc/g1/g1CollectedHeap.inline.hpp"
34 #include "gc/g1/g1CollectorState.hpp"
35 #include "gc/g1/g1GCPhaseTimes.hpp"
36 #include "gc/g1/g1ParScanThreadState.inline.hpp"
37 #include "gc/g1/g1Policy.hpp"
38 #include "gc/g1/g1RootClosures.hpp"
39 #include "gc/g1/g1RootProcessor.hpp"
40 #include "gc/g1/heapRegion.inline.hpp"
41 #include "gc/shared/referenceProcessor.hpp"
42 #include "memory/allocation.inline.hpp"
43 #include "memory/universe.hpp"
44 #include "runtime/mutexLocker.inline.hpp"
45 #include "services/management.hpp"
46 #include "utilities/macros.hpp"
47
48 void G1RootProcessor::worker_has_discovered_all_strong_nmethods() {
49 assert(ClassUnloadingWithConcurrentMark, "Currently only needed when doing G1 Class Unloading");
50
51 uint new_value = (uint)Atomic::add(1, &_n_workers_discovered_strong_classes);
52 if (new_value == n_workers()) {
53 // This thread is last. Notify the others.
54 MonitorLocker ml(&_lock, Mutex::_no_safepoint_check_flag);
55 _lock.notify_all();
56 }
57 }
58
59 void G1RootProcessor::wait_until_all_strong_nmethods_discovered() {
60 assert(ClassUnloadingWithConcurrentMark, "Currently only needed when doing G1 Class Unloading");
61
62 if ((uint)_n_workers_discovered_strong_classes != n_workers()) {
63 MonitorLocker ml(&_lock, Mutex::_no_safepoint_check_flag);
64 while ((uint)_n_workers_discovered_strong_classes != n_workers()) {
|