author | gziemski |
Fri, 26 Oct 2018 10:47:05 -0500 | |
changeset 52304 | 72f2fc52ef85 |
parent 50416 | ef980b9ac191 |
child 52385 | 5c679ec60888 |
permissions | -rw-r--r-- |
1 | 1 |
/* |
49611 | 2 |
* Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. |
1 | 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 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5533
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5533
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5533
diff
changeset
|
21 |
* questions. |
1 | 22 |
* |
23 |
*/ |
|
24 |
||
7397 | 25 |
#ifndef SHARE_VM_CODE_CODECACHE_HPP |
26 |
#define SHARE_VM_CODE_CODECACHE_HPP |
|
27 |
||
28 |
#include "code/codeBlob.hpp" |
|
26796 | 29 |
#include "code/nmethod.hpp" |
7397 | 30 |
#include "memory/allocation.hpp" |
31 |
#include "memory/heap.hpp" |
|
32 |
#include "oops/instanceKlass.hpp" |
|
33 |
#include "oops/oopsHierarchy.hpp" |
|
26796 | 34 |
#include "runtime/mutexLocker.hpp" |
7397 | 35 |
|
1 | 36 |
// The CodeCache implements the code cache for various pieces of generated |
37 |
// code, e.g., compiled java methods, runtime stubs, transition frames, etc. |
|
38 |
// The entries in the CodeCache are all CodeBlob's. |
|
39 |
||
26796 | 40 |
// -- Implementation -- |
41 |
// The CodeCache consists of one or more CodeHeaps, each of which contains |
|
42 |
// CodeBlobs of a specific CodeBlobType. Currently heaps for the following |
|
43 |
// types are available: |
|
26919
361b4b4c92c0
8059468: Fix PrintCodeCache output changed by JDK-8059137
thartmann
parents:
26796
diff
changeset
|
44 |
// - Non-nmethods: Non-nmethods like Buffers, Adapters and Runtime Stubs |
26796 | 45 |
// - Profiled nmethods: nmethods that are profiled, i.e., those |
46 |
// executed at level 2 or 3 |
|
47 |
// - Non-Profiled nmethods: nmethods that are not profiled, i.e., those |
|
48 |
// executed at level 1 or 4 and native methods |
|
49 |
// - All: Used for code of all types if code cache segmentation is disabled. |
|
50 |
// |
|
26919
361b4b4c92c0
8059468: Fix PrintCodeCache output changed by JDK-8059137
thartmann
parents:
26796
diff
changeset
|
51 |
// In the rare case of the non-nmethod code heap getting full, non-nmethod code |
26796 | 52 |
// will be stored in the non-profiled code heap as a fallback solution. |
53 |
// |
|
54 |
// Depending on the availability of compilers and TieredCompilation there |
|
55 |
// may be fewer heaps. The size of the code heaps depends on the values of |
|
56 |
// ReservedCodeCacheSize, NonProfiledCodeHeapSize and ProfiledCodeHeapSize |
|
57 |
// (see CodeCache::heap_available(..) and CodeCache::initialize_heaps(..) |
|
58 |
// for details). |
|
59 |
// |
|
60 |
// Code cache segmentation is controlled by the flag SegmentedCodeCache. |
|
61 |
// If turned off, all code types are stored in a single code heap. By default |
|
62 |
// code cache segmentation is turned on if TieredCompilation is enabled and |
|
63 |
// ReservedCodeCacheSize >= 240 MB. |
|
64 |
// |
|
65 |
// All methods of the CodeCache accepting a CodeBlobType only apply to |
|
66 |
// CodeBlobs of the given type. For example, iteration over the |
|
67 |
// CodeBlobs of a specific type can be done by using CodeCache::first_blob(..) |
|
68 |
// and CodeCache::next_blob(..) and providing the corresponding CodeBlobType. |
|
69 |
// |
|
70 |
// IMPORTANT: If you add new CodeHeaps to the code cache or change the |
|
71 |
// existing ones, make sure to adapt the dtrace scripts (jhelper.d) for |
|
72 |
// Solaris and BSD. |
|
1 | 73 |
|
74 |
class OopClosure; |
|
36300
5b47f168b948
7177745: JSR292: Many Callsite relinkages cause target method to always run in interpreter mode
vlivanov
parents:
35123
diff
changeset
|
75 |
class KlassDepChange; |
1 | 76 |
|
77 |
class CodeCache : AllStatic { |
|
78 |
friend class VMStructs; |
|
35123
b0b89d83bcf5
8134994: use separate VMStructs databases for SA and JVMCI
twisti
parents:
34182
diff
changeset
|
79 |
friend class JVMCIVMStructs; |
42650 | 80 |
template <class T, class Filter> friend class CodeBlobIterator; |
27642
8c9eff693145
8059624: Test task: WhiteBox API for testing segmented codecache feature
iignatyev
parents:
27420
diff
changeset
|
81 |
friend class WhiteBox; |
31620
53be635ad49c
8087333: Optionally Pre-Generate the HotSpot Template Interpreter
bdelsart
parents:
31348
diff
changeset
|
82 |
friend class CodeCacheLoader; |
1 | 83 |
private: |
26796 | 84 |
// CodeHeaps of the cache |
85 |
static GrowableArray<CodeHeap*>* _heaps; |
|
42650 | 86 |
static GrowableArray<CodeHeap*>* _compiled_heaps; |
87 |
static GrowableArray<CodeHeap*>* _nmethod_heaps; |
|
45622
3e4f81c922de
8181757: NonNMethod heap in segmented CodeCache is not scanned in some cases
dlong
parents:
43945
diff
changeset
|
88 |
static GrowableArray<CodeHeap*>* _allocable_heaps; |
26796 | 89 |
|
90 |
static address _low_bound; // Lower bound of CodeHeap addresses |
|
91 |
static address _high_bound; // Upper bound of CodeHeap addresses |
|
92 |
static int _number_of_nmethods_with_dependencies; // Total number of nmethods with dependencies |
|
93 |
static bool _needs_cache_clean; // True if inline caches of the nmethods needs to be flushed |
|
94 |
static nmethod* _scavenge_root_nmethods; // linked via nm->scavenge_root_link() |
|
1 | 95 |
|
3908
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
96 |
static void mark_scavenge_root_nmethods() PRODUCT_RETURN; |
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
97 |
static void verify_perm_nmethods(CodeBlobClosure* f_or_null) PRODUCT_RETURN; |
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
98 |
|
26796 | 99 |
// CodeHeap management |
100 |
static void initialize_heaps(); // Initializes the CodeHeaps |
|
34182
82d1b1696016
8061436: Processing of options related to segmented code cache should be enhanced
thartmann
parents:
34158
diff
changeset
|
101 |
// Check the code heap sizes set by the user via command line |
82d1b1696016
8061436: Processing of options related to segmented code cache should be enhanced
thartmann
parents:
34158
diff
changeset
|
102 |
static void check_heap_sizes(size_t non_nmethod_size, size_t profiled_size, size_t non_profiled_size, size_t cache_size, bool all_set); |
26796 | 103 |
// Creates a new heap with the given name and size, containing CodeBlobs of the given type |
28730
106944a21769
8064940: JMH javac performance regressions on solaris-sparcv9 in 9-b34
thartmann
parents:
28374
diff
changeset
|
104 |
static void add_heap(ReservedSpace rs, const char* name, int code_blob_type); |
46647
634dc786bf96
8183573: Refactor CodeHeap and AOTCodeHeap to devirtualize hot methods
redestad
parents:
46632
diff
changeset
|
105 |
static CodeHeap* get_code_heap_containing(void* p); // Returns the CodeHeap containing the given pointer, or NULL |
27642
8c9eff693145
8059624: Test task: WhiteBox API for testing segmented codecache feature
iignatyev
parents:
27420
diff
changeset
|
106 |
static CodeHeap* get_code_heap(const CodeBlob* cb); // Returns the CodeHeap for the given CodeBlob |
26796 | 107 |
static CodeHeap* get_code_heap(int code_blob_type); // Returns the CodeHeap for the given CodeBlobType |
27410
dd80df7cfa2b
8060196: 'CodeHeap is full' warning suggests to increase wrong code heap size
thartmann
parents:
26942
diff
changeset
|
108 |
// Returns the name of the VM option to set the size of the corresponding CodeHeap |
dd80df7cfa2b
8060196: 'CodeHeap is full' warning suggests to increase wrong code heap size
thartmann
parents:
26942
diff
changeset
|
109 |
static const char* get_code_heap_flag_name(int code_blob_type); |
48119
c1b46afab3ba
8087339: The code heap might use different alignment for committed size and reserved size
thartmann
parents:
47688
diff
changeset
|
110 |
static size_t page_size(bool aligned = true); // Returns the page size used by the CodeCache |
26796 | 111 |
static ReservedCodeSpace reserve_heap_memory(size_t size); // Reserves one continuous chunk of memory for the CodeHeaps |
112 |
||
113 |
// Iteration |
|
114 |
static CodeBlob* first_blob(CodeHeap* heap); // Returns the first CodeBlob on the given CodeHeap |
|
115 |
static CodeBlob* first_blob(int code_blob_type); // Returns the first CodeBlob of the given type |
|
42650 | 116 |
static CodeBlob* next_blob(CodeHeap* heap, CodeBlob* cb); // Returns the next CodeBlob on the given CodeHeap |
26796 | 117 |
|
118 |
static size_t bytes_allocated_in_freelists(); |
|
119 |
static int allocated_segments(); |
|
120 |
static size_t freelists_length(); |
|
18025 | 121 |
|
36591
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
122 |
static void set_scavenge_root_nmethods(nmethod* nm) { _scavenge_root_nmethods = nm; } |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
123 |
static void prune_scavenge_root_nmethods(); |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
124 |
static void unlink_scavenge_root_nmethod(nmethod* nm, nmethod* prev); |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
125 |
|
42650 | 126 |
// Make private to prevent unsafe calls. Not all CodeBlob*'s are embedded in a CodeHeap. |
127 |
static bool contains(CodeBlob *p) { fatal("don't call me!"); return false; } |
|
128 |
||
1 | 129 |
public: |
130 |
// Initialization |
|
131 |
static void initialize(); |
|
132 |
||
42650 | 133 |
static int code_heap_compare(CodeHeap* const &lhs, CodeHeap* const &rhs); |
134 |
||
135 |
static void add_heap(CodeHeap* heap); |
|
136 |
static const GrowableArray<CodeHeap*>* heaps() { return _heaps; } |
|
137 |
static const GrowableArray<CodeHeap*>* compiled_heaps() { return _compiled_heaps; } |
|
138 |
static const GrowableArray<CodeHeap*>* nmethod_heaps() { return _nmethod_heaps; } |
|
139 |
||
1 | 140 |
// Allocation/administration |
40863
f5fec6a2dc9e
8064892: Non-methods code cache overflow is not handled correctly
thartmann
parents:
38133
diff
changeset
|
141 |
static CodeBlob* allocate(int size, int code_blob_type, int orig_code_blob_type = CodeBlobType::All); // allocates a new CodeBlob |
27420
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
142 |
static void commit(CodeBlob* cb); // called when the allocated CodeBlob has been filled |
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
143 |
static int alignment_unit(); // guaranteed alignment of all CodeBlobs |
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
144 |
static int alignment_offset(); // guaranteed offset of first CodeBlob byte within alignment unit (i.e., allocation header) |
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
145 |
static void free(CodeBlob* cb); // frees a CodeBlob |
47688 | 146 |
static void free_unused_tail(CodeBlob* cb, size_t used); // frees the unused tail of a CodeBlob (only used by TemplateInterpreter::initialize()) |
27420
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
147 |
static bool contains(void *p); // returns whether p is included |
42650 | 148 |
static bool contains(nmethod* nm); // returns whether nm is included |
27420
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
149 |
static void blobs_do(void f(CodeBlob* cb)); // iterates over all CodeBlobs |
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
150 |
static void blobs_do(CodeBlobClosure* f); // iterates over all CodeBlobs |
04e6f914cce1
8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents:
27410
diff
changeset
|
151 |
static void nmethods_do(void f(nmethod* nm)); // iterates over all nmethods |
38133
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
152 |
static void metadata_do(void f(Metadata* m)); // iterates over metadata in alive nmethods |
1 | 153 |
|
154 |
// Lookup |
|
26796 | 155 |
static CodeBlob* find_blob(void* start); // Returns the CodeBlob containing the given address |
156 |
static CodeBlob* find_blob_unsafe(void* start); // Same as find_blob but does not fail if looking up a zombie method |
|
157 |
static nmethod* find_nmethod(void* start); // Returns the nmethod containing the given address |
|
38133
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
158 |
static CompiledMethod* find_compiled(void* start); |
13195 | 159 |
|
34158
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
160 |
static int blob_count(); // Returns the total number of CodeBlobs in the cache |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
161 |
static int blob_count(int code_blob_type); |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
162 |
static int adapter_count(); // Returns the total number of Adapters in the cache |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
163 |
static int adapter_count(int code_blob_type); |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
164 |
static int nmethod_count(); // Returns the total number of nmethods in the cache |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
165 |
static int nmethod_count(int code_blob_type); |
1 | 166 |
|
167 |
// GC support |
|
168 |
static void gc_epilogue(); |
|
169 |
static void gc_prologue(); |
|
8724
693c6b883b54
7028374: race in fix_oop_relocations for scavengeable nmethods
never
parents:
8672
diff
changeset
|
170 |
static void verify_oops(); |
50416
ef980b9ac191
8203837: Split nmethod unloading from inline cache cleaning
coleenp
parents:
49611
diff
changeset
|
171 |
// If any oops are not marked this method unloads (i.e., breaks root links |
1 | 172 |
// to) any unmarked codeBlobs in the cache. Sets "marked_for_unloading" |
173 |
// to "true" iff some code got unloaded. |
|
50416
ef980b9ac191
8203837: Split nmethod unloading from inline cache cleaning
coleenp
parents:
49611
diff
changeset
|
174 |
// "unloading_occurred" controls whether metadata should be cleaned because of class unloading. |
13878
6e6a462a6cff
7200470: KeepAliveClosure not needed in CodeCache::do_unloading
brutisso
parents:
13728
diff
changeset
|
175 |
static void do_unloading(BoolObjectClosure* is_alive, bool unloading_occurred); |
3908
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
176 |
static void asserted_non_scavengable_nmethods_do(CodeBlobClosure* f = NULL) PRODUCT_RETURN; |
36591
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
177 |
|
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
178 |
// Apply f to every live code blob in scavengable nmethods. Prune nmethods |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
179 |
// from the list of scavengable nmethods if f->fix_relocations() and a nmethod |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
180 |
// no longer has scavengable oops. If f->fix_relocations(), then f must copy |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
181 |
// objects to their new location immediately to avoid fixing nmethods on the |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
182 |
// basis of the old object locations. |
d0622cab5983
8150013: ParNew: Prune nmethods scavengable list.
cvarming
parents:
35123
diff
changeset
|
183 |
static void scavenge_root_nmethods_do(CodeBlobToOopClosure* f); |
3908
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
184 |
|
26796 | 185 |
static nmethod* scavenge_root_nmethods() { return _scavenge_root_nmethods; } |
47624
b055cb5170f5
8185141: Generalize scavengeable nmethod root handling
eosterlund
parents:
47216
diff
changeset
|
186 |
// register_scavenge_root_nmethod() conditionally adds the nmethod to the list |
b055cb5170f5
8185141: Generalize scavengeable nmethod root handling
eosterlund
parents:
47216
diff
changeset
|
187 |
// if it is not already on the list and has a scavengeable root |
b055cb5170f5
8185141: Generalize scavengeable nmethod root handling
eosterlund
parents:
47216
diff
changeset
|
188 |
static void register_scavenge_root_nmethod(nmethod* nm); |
b055cb5170f5
8185141: Generalize scavengeable nmethod root handling
eosterlund
parents:
47216
diff
changeset
|
189 |
static void verify_scavenge_root_nmethod(nmethod* nm); |
3908
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
190 |
static void add_scavenge_root_nmethod(nmethod* nm); |
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
191 |
static void drop_scavenge_root_nmethod(nmethod* nm); |
1 | 192 |
|
193 |
// Printing/debugging |
|
15201
f3d755b11424
8005204: Code Cache Reduction: command line options implementation
vladidan
parents:
13878
diff
changeset
|
194 |
static void print(); // prints summary |
1 | 195 |
static void print_internals(); |
23214
b6426873cb37
8029799: vm/mlvm/anonloader/stress/oome prints warning: CodeHeap: # of free blocks > 10000
anoll
parents:
20290
diff
changeset
|
196 |
static void print_memory_overhead(); |
1 | 197 |
static void verify(); // verifies the code cache |
3908
24b55ad4c228
6863023: need non-perm oops in code cache for JSR 292
jrose
parents:
670
diff
changeset
|
198 |
static void print_trace(const char* event, CodeBlob* cb, int size = 0) PRODUCT_RETURN; |
15201
f3d755b11424
8005204: Code Cache Reduction: command line options implementation
vladidan
parents:
13878
diff
changeset
|
199 |
static void print_summary(outputStream* st, bool detailed = true); // Prints a summary of the code cache usage |
8672
26a427ab6f32
7025742: Can not use CodeCache::unallocated_capacity() with fragmented CodeCache
kvn
parents:
7715
diff
changeset
|
200 |
static void log_state(outputStream* st); |
26796 | 201 |
static const char* get_code_heap_name(int code_blob_type) { return (heap_available(code_blob_type) ? get_code_heap(code_blob_type)->name() : "Unused"); } |
202 |
static void report_codemem_full(int code_blob_type, bool print); |
|
1 | 203 |
|
26587 | 204 |
// Dcmd (Diagnostic commands) |
205 |
static void print_codelist(outputStream* st); |
|
206 |
static void print_layout(outputStream* st); |
|
207 |
||
1 | 208 |
// The full limits of the codeCache |
26796 | 209 |
static address low_bound() { return _low_bound; } |
34158
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
210 |
static address low_bound(int code_blob_type); |
26796 | 211 |
static address high_bound() { return _high_bound; } |
34158
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
212 |
static address high_bound(int code_blob_type); |
1 | 213 |
|
42650 | 214 |
// Have to use far call instructions to call this pc. |
215 |
static bool is_far_target(address pc); |
|
216 |
||
1 | 217 |
// Profiling |
26796 | 218 |
static size_t capacity(); |
26942
fa5ea7ff078d
8059390: code cache fills up for bigapps/Weblogic+medrec/nowarnings
zmajo
parents:
26919
diff
changeset
|
219 |
static size_t unallocated_capacity(int code_blob_type); |
26796 | 220 |
static size_t unallocated_capacity(); |
221 |
static size_t max_capacity(); |
|
222 |
||
223 |
static double reverse_free_ratio(int code_blob_type); |
|
224 |
||
225 |
static bool needs_cache_clean() { return _needs_cache_clean; } |
|
226 |
static void set_needs_cache_clean(bool v) { _needs_cache_clean = v; } |
|
50416
ef980b9ac191
8203837: Split nmethod unloading from inline cache cleaning
coleenp
parents:
49611
diff
changeset
|
227 |
|
26796 | 228 |
static void clear_inline_caches(); // clear all inline caches |
50416
ef980b9ac191
8203837: Split nmethod unloading from inline cache cleaning
coleenp
parents:
49611
diff
changeset
|
229 |
static void cleanup_inline_caches(); // clean unloaded/zombie nmethods from inline caches |
ef980b9ac191
8203837: Split nmethod unloading from inline cache cleaning
coleenp
parents:
49611
diff
changeset
|
230 |
static void do_unloading_nmethod_caches(bool class_unloading_occurred); // clean all nmethod caches for unloading, including inline caches |
1 | 231 |
|
34158
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
232 |
// Returns true if an own CodeHeap for the given CodeBlobType is available |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
233 |
static bool heap_available(int code_blob_type); |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
234 |
|
42650 | 235 |
// Returns the CodeBlobType for the given CompiledMethod |
38133
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
236 |
static int get_code_blob_type(CompiledMethod* cm) { |
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
237 |
return get_code_heap(cm)->code_blob_type(); |
31348
c28f02c7abb5
8077279: assert(ic->is_clean()) failed: IC should be clean
sjohanss
parents:
31037
diff
changeset
|
238 |
} |
c28f02c7abb5
8077279: assert(ic->is_clean()) failed: IC should be clean
sjohanss
parents:
31037
diff
changeset
|
239 |
|
42650 | 240 |
static bool code_blob_type_accepts_compiled(int type) { |
241 |
bool result = type == CodeBlobType::All || type <= CodeBlobType::MethodProfiled; |
|
242 |
AOT_ONLY( result = result || type == CodeBlobType::AOT; ) |
|
243 |
return result; |
|
244 |
} |
|
245 |
||
246 |
static bool code_blob_type_accepts_nmethod(int type) { |
|
247 |
return type == CodeBlobType::All || type <= CodeBlobType::MethodProfiled; |
|
248 |
} |
|
249 |
||
45622
3e4f81c922de
8181757: NonNMethod heap in segmented CodeCache is not scanned in some cases
dlong
parents:
43945
diff
changeset
|
250 |
static bool code_blob_type_accepts_allocable(int type) { |
3e4f81c922de
8181757: NonNMethod heap in segmented CodeCache is not scanned in some cases
dlong
parents:
43945
diff
changeset
|
251 |
return type <= CodeBlobType::All; |
3e4f81c922de
8181757: NonNMethod heap in segmented CodeCache is not scanned in some cases
dlong
parents:
43945
diff
changeset
|
252 |
} |
3e4f81c922de
8181757: NonNMethod heap in segmented CodeCache is not scanned in some cases
dlong
parents:
43945
diff
changeset
|
253 |
|
3e4f81c922de
8181757: NonNMethod heap in segmented CodeCache is not scanned in some cases
dlong
parents:
43945
diff
changeset
|
254 |
|
31348
c28f02c7abb5
8077279: assert(ic->is_clean()) failed: IC should be clean
sjohanss
parents:
31037
diff
changeset
|
255 |
// Returns the CodeBlobType for the given compilation level |
26796 | 256 |
static int get_code_blob_type(int comp_level) { |
257 |
if (comp_level == CompLevel_none || |
|
258 |
comp_level == CompLevel_simple || |
|
259 |
comp_level == CompLevel_full_optimization) { |
|
260 |
// Non profiled methods |
|
261 |
return CodeBlobType::MethodNonProfiled; |
|
262 |
} else if (comp_level == CompLevel_limited_profile || |
|
263 |
comp_level == CompLevel_full_profile) { |
|
264 |
// Profiled methods |
|
265 |
return CodeBlobType::MethodProfiled; |
|
266 |
} |
|
267 |
ShouldNotReachHere(); |
|
268 |
return 0; |
|
269 |
} |
|
1 | 270 |
|
25492
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
271 |
static void verify_clean_inline_caches(); |
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
272 |
static void verify_icholder_relocations(); |
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
273 |
|
1 | 274 |
// Deoptimization |
28374
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
275 |
private: |
36300
5b47f168b948
7177745: JSR292: Many Callsite relinkages cause target method to always run in interpreter mode
vlivanov
parents:
35123
diff
changeset
|
276 |
static int mark_for_deoptimization(KlassDepChange& changes); |
1 | 277 |
#ifdef HOTSWAP |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43945
diff
changeset
|
278 |
static int mark_for_evol_deoptimization(InstanceKlass* dependee); |
1 | 279 |
#endif // HOTSWAP |
280 |
||
28374
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
281 |
public: |
1 | 282 |
static void mark_all_nmethods_for_deoptimization(); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13195
diff
changeset
|
283 |
static int mark_for_deoptimization(Method* dependee); |
1 | 284 |
static void make_marked_nmethods_not_entrant(); |
285 |
||
28374
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
286 |
// Flushing and deoptimization |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43945
diff
changeset
|
287 |
static void flush_dependents_on(InstanceKlass* dependee); |
28374
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
288 |
#ifdef HOTSWAP |
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
289 |
// Flushing and deoptimization in case of evolution |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43945
diff
changeset
|
290 |
static void flush_evol_dependents_on(InstanceKlass* dependee); |
28374
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
291 |
#endif // HOTSWAP |
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
292 |
// Support for fullspeed debugging |
46727
6e4a84748e2c
8183039: Re-examine methodHandle methods uninlined by 8144256
coleenp
parents:
46647
diff
changeset
|
293 |
static void flush_dependents_on_method(const methodHandle& dependee); |
28374
0558e321c027
8067836: The Universe::flush_foo methods belong in CodeCache.
coleenp
parents:
27642
diff
changeset
|
294 |
|
26796 | 295 |
// tells how many nmethods have dependencies |
1 | 296 |
static int number_of_nmethods_with_dependencies(); |
18025 | 297 |
|
34158
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
298 |
static int get_codemem_full_count(int code_blob_type) { |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
299 |
CodeHeap* heap = get_code_heap(code_blob_type); |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
300 |
return (heap != NULL) ? heap->full_count() : 0; |
1f8d643b02d5
8067378: Add segmented code heaps info into jfr events: vm/code_cache/stats and vm/code_cache/config
thartmann
parents:
32401
diff
changeset
|
301 |
} |
49611 | 302 |
|
303 |
// CodeHeap State Analytics. |
|
304 |
// interface methods for CodeHeap printing, called by CompileBroker |
|
305 |
static void aggregate(outputStream *out, const char* granularity); |
|
306 |
static void discard(outputStream *out); |
|
307 |
static void print_usedSpace(outputStream *out); |
|
308 |
static void print_freeSpace(outputStream *out); |
|
309 |
static void print_count(outputStream *out); |
|
310 |
static void print_space(outputStream *out); |
|
311 |
static void print_age(outputStream *out); |
|
312 |
static void print_names(outputStream *out); |
|
1 | 313 |
}; |
7397 | 314 |
|
26796 | 315 |
|
316 |
// Iterator to iterate over nmethods in the CodeCache. |
|
42650 | 317 |
template <class T, class Filter> class CodeBlobIterator : public StackObj { |
26796 | 318 |
private: |
319 |
CodeBlob* _code_blob; // Current CodeBlob |
|
42650 | 320 |
GrowableArrayIterator<CodeHeap*> _heap; |
321 |
GrowableArrayIterator<CodeHeap*> _end; |
|
26796 | 322 |
|
323 |
public: |
|
42650 | 324 |
CodeBlobIterator(T* nm = NULL) { |
325 |
if (Filter::heaps() == NULL) { |
|
326 |
return; |
|
327 |
} |
|
328 |
_heap = Filter::heaps()->begin(); |
|
329 |
_end = Filter::heaps()->end(); |
|
330 |
// If set to NULL, initialized by first call to next() |
|
331 |
_code_blob = (CodeBlob*)nm; |
|
332 |
if (nm != NULL) { |
|
43945
e7f2e49d2274
8173151: Code heap corruption due to incorrect inclusion test
zmajo
parents:
42664
diff
changeset
|
333 |
while(!(*_heap)->contains_blob(_code_blob)) { |
42650 | 334 |
++_heap; |
335 |
} |
|
43945
e7f2e49d2274
8173151: Code heap corruption due to incorrect inclusion test
zmajo
parents:
42664
diff
changeset
|
336 |
assert((*_heap)->contains_blob(_code_blob), "match not found"); |
42650 | 337 |
} |
26796 | 338 |
} |
339 |
||
42650 | 340 |
// Advance iterator to next blob |
26796 | 341 |
bool next() { |
342 |
assert_locked_or_safepoint(CodeCache_lock); |
|
343 |
||
42650 | 344 |
bool result = next_blob(); |
345 |
while (!result && _heap != _end) { |
|
346 |
// Advance to next code heap of segmented code cache |
|
347 |
if (++_heap == _end) { |
|
348 |
break; |
|
349 |
} |
|
350 |
result = next_blob(); |
|
26796 | 351 |
} |
42650 | 352 |
|
26796 | 353 |
return result; |
354 |
} |
|
355 |
||
42650 | 356 |
// Advance iterator to next alive blob |
26796 | 357 |
bool next_alive() { |
358 |
bool result = next(); |
|
359 |
while(result && !_code_blob->is_alive()) { |
|
360 |
result = next(); |
|
361 |
} |
|
362 |
return result; |
|
363 |
} |
|
364 |
||
365 |
bool end() const { return _code_blob == NULL; } |
|
42650 | 366 |
T* method() const { return (T*)_code_blob; } |
26796 | 367 |
|
368 |
private: |
|
42650 | 369 |
|
370 |
// Advance iterator to the next blob in the current code heap |
|
371 |
bool next_blob() { |
|
372 |
if (_heap == _end) { |
|
373 |
return false; |
|
26796 | 374 |
} |
42650 | 375 |
CodeHeap *heap = *_heap; |
26796 | 376 |
// Get first method CodeBlob |
377 |
if (_code_blob == NULL) { |
|
42650 | 378 |
_code_blob = CodeCache::first_blob(heap); |
26796 | 379 |
if (_code_blob == NULL) { |
380 |
return false; |
|
42650 | 381 |
} else if (Filter::apply(_code_blob)) { |
26796 | 382 |
return true; |
383 |
} |
|
384 |
} |
|
385 |
// Search for next method CodeBlob |
|
42650 | 386 |
_code_blob = CodeCache::next_blob(heap, _code_blob); |
387 |
while (_code_blob != NULL && !Filter::apply(_code_blob)) { |
|
388 |
_code_blob = CodeCache::next_blob(heap, _code_blob); |
|
26796 | 389 |
} |
390 |
return _code_blob != NULL; |
|
391 |
} |
|
392 |
}; |
|
393 |
||
38133
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
394 |
|
42650 | 395 |
struct CompiledMethodFilter { |
396 |
static bool apply(CodeBlob* cb) { return cb->is_compiled(); } |
|
397 |
static const GrowableArray<CodeHeap*>* heaps() { return CodeCache::compiled_heaps(); } |
|
38133
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
398 |
}; |
78b95467b9f1
8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents:
37289
diff
changeset
|
399 |
|
42650 | 400 |
|
401 |
struct NMethodFilter { |
|
402 |
static bool apply(CodeBlob* cb) { return cb->is_nmethod(); } |
|
403 |
static const GrowableArray<CodeHeap*>* heaps() { return CodeCache::nmethod_heaps(); } |
|
404 |
}; |
|
405 |
||
406 |
||
407 |
typedef CodeBlobIterator<CompiledMethod, CompiledMethodFilter> CompiledMethodIterator; |
|
408 |
typedef CodeBlobIterator<nmethod, NMethodFilter> NMethodIterator; |
|
409 |
||
7397 | 410 |
#endif // SHARE_VM_CODE_CODECACHE_HPP |