1 /*
2 * Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 *
23 */
24
25 #ifndef SHARE_VM_GC_G1_G1ROOTPROCESSOR_HPP
26 #define SHARE_VM_GC_G1_G1ROOTPROCESSOR_HPP
27
28 #include "gc/shared/strongRootsScope.hpp"
29 #include "memory/allocation.hpp"
30 #include "runtime/mutex.hpp"
31
32 class CLDClosure;
33 class CodeBlobClosure;
34 class G1CollectedHeap;
35 class G1EvacuationRootClosures;
36 class G1GCPhaseTimes;
37 class G1RootClosures;
38 class Monitor;
39 class OopClosure;
40 class SubTasksDone;
41
42 // Scoped object to assist in applying oop, CLD and code blob closures to
43 // root locations. Handles claiming of different root scanning tasks
44 // and takes care of global state for root scanning via a StrongRootsScope.
45 // In the parallel case there is a shared G1RootProcessor object where all
46 // worker thread call the process_roots methods.
47 class G1RootProcessor : public StackObj {
48 G1CollectedHeap* _g1h;
49 SubTasksDone _process_strong_tasks;
50 StrongRootsScope _srs;
51
52 // Used to implement the Thread work barrier.
53 Monitor _lock;
54 volatile jint _n_workers_discovered_strong_classes;
55
56 enum G1H_process_roots_tasks {
80
81 void process_java_roots(G1RootClosures* closures,
82 G1GCPhaseTimes* phase_times,
83 uint worker_i);
84
85 void process_vm_roots(G1RootClosures* closures,
86 G1GCPhaseTimes* phase_times,
87 uint worker_i);
88
89 void process_string_table_roots(G1RootClosures* closures,
90 G1GCPhaseTimes* phase_times,
91 uint worker_i);
92
93 void process_code_cache_roots(CodeBlobClosure* code_closure,
94 G1GCPhaseTimes* phase_times,
95 uint worker_i);
96
97 public:
98 G1RootProcessor(G1CollectedHeap* g1h, uint n_workers);
99
100 // Apply closures to the strongly and weakly reachable roots in the system
101 // in a single pass.
102 // Record and report timing measurements for sub phases using the worker_i
103 void evacuate_roots(G1EvacuationRootClosures* closures, uint worker_i);
104
105 // Apply oops, clds and blobs to all strongly reachable roots in the system
106 void process_strong_roots(OopClosure* oops,
107 CLDClosure* clds,
108 CodeBlobClosure* blobs);
109
110 // Apply oops, clds and blobs to strongly and weakly reachable roots in the system
111 void process_all_roots(OopClosure* oops,
112 CLDClosure* clds,
113 CodeBlobClosure* blobs);
114
115 // Apply oops, clds and blobs to strongly and weakly reachable roots in the system,
116 // the only thing different from process_all_roots is that we skip the string table
117 // to avoid keeping every string live when doing class unloading.
118 void process_all_roots_no_string_table(OopClosure* oops,
119 CLDClosure* clds,
120 CodeBlobClosure* blobs);
121
122 // Apply closure to weak roots in the system. Used during the adjust phase
123 // for the Full GC.
|
1 /*
2 * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 *
23 */
24
25 #ifndef SHARE_VM_GC_G1_G1ROOTPROCESSOR_HPP
26 #define SHARE_VM_GC_G1_G1ROOTPROCESSOR_HPP
27
28 #include "gc/shared/strongRootsScope.hpp"
29 #include "memory/allocation.hpp"
30 #include "runtime/mutex.hpp"
31
32 class CLDClosure;
33 class CodeBlobClosure;
34 class G1CollectedHeap;
35 class G1EvacuationRootClosures;
36 class G1GCPhaseTimes;
37 class G1ParScanThreadState;
38 class G1RootClosures;
39 class Monitor;
40 class OopClosure;
41 class SubTasksDone;
42
43 // Scoped object to assist in applying oop, CLD and code blob closures to
44 // root locations. Handles claiming of different root scanning tasks
45 // and takes care of global state for root scanning via a StrongRootsScope.
46 // In the parallel case there is a shared G1RootProcessor object where all
47 // worker thread call the process_roots methods.
48 class G1RootProcessor : public StackObj {
49 G1CollectedHeap* _g1h;
50 SubTasksDone _process_strong_tasks;
51 StrongRootsScope _srs;
52
53 // Used to implement the Thread work barrier.
54 Monitor _lock;
55 volatile jint _n_workers_discovered_strong_classes;
56
57 enum G1H_process_roots_tasks {
81
82 void process_java_roots(G1RootClosures* closures,
83 G1GCPhaseTimes* phase_times,
84 uint worker_i);
85
86 void process_vm_roots(G1RootClosures* closures,
87 G1GCPhaseTimes* phase_times,
88 uint worker_i);
89
90 void process_string_table_roots(G1RootClosures* closures,
91 G1GCPhaseTimes* phase_times,
92 uint worker_i);
93
94 void process_code_cache_roots(CodeBlobClosure* code_closure,
95 G1GCPhaseTimes* phase_times,
96 uint worker_i);
97
98 public:
99 G1RootProcessor(G1CollectedHeap* g1h, uint n_workers);
100
101 // Apply correct closures from pss to the strongly and weakly reachable roots in the system
102 // in a single pass.
103 // Record and report timing measurements for sub phases using the worker_i
104 void evacuate_roots(G1ParScanThreadState* pss, uint worker_id);
105
106 // Apply oops, clds and blobs to all strongly reachable roots in the system
107 void process_strong_roots(OopClosure* oops,
108 CLDClosure* clds,
109 CodeBlobClosure* blobs);
110
111 // Apply oops, clds and blobs to strongly and weakly reachable roots in the system
112 void process_all_roots(OopClosure* oops,
113 CLDClosure* clds,
114 CodeBlobClosure* blobs);
115
116 // Apply oops, clds and blobs to strongly and weakly reachable roots in the system,
117 // the only thing different from process_all_roots is that we skip the string table
118 // to avoid keeping every string live when doing class unloading.
119 void process_all_roots_no_string_table(OopClosure* oops,
120 CLDClosure* clds,
121 CodeBlobClosure* blobs);
122
123 // Apply closure to weak roots in the system. Used during the adjust phase
124 // for the Full GC.
|