annotate src/share/vm/prims/whitebox.cpp @ 20667:887a7cedb892

8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI Summary: Added API to track bootclasspath modification Reviewed-by: jiangli, dholmes, minqi
author iklam
date Tue, 18 Nov 2014 03:38:50 -0800
parents 787c9c28311f
children c80ddae00f51
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1 /*
17817
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
2 * Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved.
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
4 *
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
7 * published by the Free Software Foundation.
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
8 *
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
13 * accompanied this code).
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
14 *
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
18 *
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
21 * questions.
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
22 *
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
23 */
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
24
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
25 #include "precompiled.hpp"
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
26
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
27 #include "memory/metadataFactory.hpp"
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
28 #include "memory/universe.hpp"
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
29 #include "oops/oop.inline.hpp"
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
30
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
31 #include "classfile/symbolTable.hpp"
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
32 #include "classfile/classLoaderData.hpp"
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
33
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
34 #include "prims/whitebox.hpp"
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
35 #include "prims/wbtestmethods/parserTests.hpp"
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
36
12233
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
37 #include "runtime/arguments.hpp"
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
38 #include "runtime/interfaceSupport.hpp"
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
39 #include "runtime/os.hpp"
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
40 #include "utilities/array.hpp"
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
41 #include "utilities/debug.hpp"
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
42 #include "utilities/macros.hpp"
10341
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
43 #include "utilities/exceptions.hpp"
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
44
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
45 #if INCLUDE_ALL_GCS
20357
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
46 #include "gc_implementation/parallelScavenge/parallelScavengeHeap.inline.hpp"
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
47 #include "gc_implementation/g1/concurrentMark.hpp"
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
48 #include "gc_implementation/g1/g1CollectedHeap.inline.hpp"
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
49 #include "gc_implementation/g1/heapRegionRemSet.hpp"
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
50 #endif // INCLUDE_ALL_GCS
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
51
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
52 #if INCLUDE_NMT
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
53 #include "services/mallocSiteTable.hpp"
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
54 #include "services/memTracker.hpp"
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
55 #include "utilities/nativeCallStack.hpp"
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
56 #endif // INCLUDE_NMT
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
57
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
58 #include "compiler/compileBroker.hpp"
20667
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
59 #include "jvmtifiles/jvmtiEnv.hpp"
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
60 #include "runtime/compilationPolicy.hpp"
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
61
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17867
diff changeset
62 PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 17867
diff changeset
63
13053
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
64 #define SIZE_T_MAX_VALUE ((size_t) -1)
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
65
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
66 bool WhiteBox::_used = false;
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
67
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
68 WB_ENTRY(jlong, WB_GetObjectAddress(JNIEnv* env, jobject o, jobject obj))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
69 return (jlong)(void*)JNIHandles::resolve(obj);
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
70 WB_END
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
71
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
72 WB_ENTRY(jint, WB_GetHeapOopSize(JNIEnv* env, jobject o))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
73 return heapOopSize;
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
74 WB_END
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
75
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
76
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
77 class WBIsKlassAliveClosure : public KlassClosure {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
78 Symbol* _name;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
79 bool _found;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
80 public:
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
81 WBIsKlassAliveClosure(Symbol* name) : _name(name), _found(false) {}
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
82
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
83 void do_klass(Klass* k) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
84 if (_found) return;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
85 Symbol* ksym = k->name();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
86 if (ksym->fast_compare(_name) == 0) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
87 _found = true;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
88 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
89 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
90
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
91 bool found() const {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
92 return _found;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
93 }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
94 };
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
95
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
96 WB_ENTRY(jboolean, WB_IsClassAlive(JNIEnv* env, jobject target, jstring name))
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
97 Handle h_name = JNIHandles::resolve(name);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
98 if (h_name.is_null()) return false;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
99 Symbol* sym = java_lang_String::as_symbol(h_name, CHECK_false);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
100 TempNewSymbol tsym(sym); // Make sure to decrement reference count on sym on return
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
101
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
102 WBIsKlassAliveClosure closure(sym);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
103 ClassLoaderDataGraph::classes_do(&closure);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
104
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
105 return closure.found();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
106 WB_END
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
107
20608
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
108 WB_ENTRY(jboolean, WB_ClassKnownToNotExist(JNIEnv* env, jobject o, jobject loader, jstring name))
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
109 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
110 const char* class_name = env->GetStringUTFChars(name, NULL);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
111 jboolean result = JVM_KnownToNotExist(env, loader, class_name);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
112 env->ReleaseStringUTFChars(name, class_name);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
113 return result;
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
114 WB_END
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
115
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
116 WB_ENTRY(jobjectArray, WB_GetLookupCacheURLs(JNIEnv* env, jobject o, jobject loader))
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
117 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
118 return JVM_GetResourceLookupCacheURLs(env, loader);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
119 WB_END
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
120
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
121 WB_ENTRY(jintArray, WB_GetLookupCacheMatches(JNIEnv* env, jobject o, jobject loader, jstring name))
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
122 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
123 const char* resource_name = env->GetStringUTFChars(name, NULL);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
124 jintArray result = JVM_GetResourceLookupCache(env, loader, resource_name);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
125
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
126 env->ReleaseStringUTFChars(name, resource_name);
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
127 return result;
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
128 WB_END
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
129
20667
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
130 WB_ENTRY(void, WB_AddToBootstrapClassLoaderSearch(JNIEnv* env, jobject o, jstring segment)) {
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
131 #if INCLUDE_JVMTI
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
132 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
133 const char* seg = env->GetStringUTFChars(segment, NULL);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
134 JvmtiEnv* jvmti_env = JvmtiEnv::create_a_jvmti(JVMTI_VERSION);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
135 jvmtiError err = jvmti_env->AddToBootstrapClassLoaderSearch(seg);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
136 assert(err == JVMTI_ERROR_NONE, "must not fail");
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
137 env->ReleaseStringUTFChars(segment, seg);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
138 #endif
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
139 }
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
140 WB_END
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
141
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
142 WB_ENTRY(void, WB_AddToSystemClassLoaderSearch(JNIEnv* env, jobject o, jstring segment)) {
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
143 #if INCLUDE_JVMTI
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
144 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
145 const char* seg = env->GetStringUTFChars(segment, NULL);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
146 JvmtiEnv* jvmti_env = JvmtiEnv::create_a_jvmti(JVMTI_VERSION);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
147 jvmtiError err = jvmti_env->AddToSystemClassLoaderSearch(seg);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
148 assert(err == JVMTI_ERROR_NONE, "must not fail");
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
149 env->ReleaseStringUTFChars(segment, seg);
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
150 #endif
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
151 }
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
152 WB_END
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
153
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
154
12233
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
155 WB_ENTRY(jlong, WB_GetCompressedOopsMaxHeapSize(JNIEnv* env, jobject o)) {
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
156 return (jlong)Arguments::max_heap_for_compressed_oops();
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
157 }
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
158 WB_END
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
159
10241
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
160 WB_ENTRY(void, WB_PrintHeapSizes(JNIEnv* env, jobject o)) {
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
161 CollectorPolicy * p = Universe::heap()->collector_policy();
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
162 gclog_or_tty->print_cr("Minimum heap "SIZE_FORMAT" Initial heap "
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
163 SIZE_FORMAT" Maximum heap "SIZE_FORMAT" Min alignment "SIZE_FORMAT" Max alignment "SIZE_FORMAT,
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
164 p->min_heap_byte_size(), p->initial_heap_byte_size(), p->max_heap_byte_size(),
13060
8f07aa079343 8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents: 12233
diff changeset
165 p->space_alignment(), p->heap_alignment());
10241
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
166 }
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
167 WB_END
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
168
13053
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
169 #ifndef PRODUCT
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
170 // Forward declaration
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
171 void TestReservedSpace_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
172 void TestReserveMemorySpecial_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
173 void TestVirtualSpace_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
174 void TestMetaspaceAux_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
175 #endif
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
176
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
177 WB_ENTRY(void, WB_RunMemoryUnitTests(JNIEnv* env, jobject o))
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
178 #ifndef PRODUCT
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
179 TestReservedSpace_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
180 TestReserveMemorySpecial_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
181 TestVirtualSpace_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
182 TestMetaspaceAux_test();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
183 #endif
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
184 WB_END
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
185
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
186 WB_ENTRY(void, WB_ReadFromNoaccessArea(JNIEnv* env, jobject o))
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
187 size_t granularity = os::vm_allocation_granularity();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
188 ReservedHeapSpace rhs(100 * granularity, granularity, false, NULL);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
189 VirtualSpace vs;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
190 vs.initialize(rhs, 50 * granularity);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
191
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
192 //Check if constraints are complied
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
193 if (!( UseCompressedOops && rhs.base() != NULL &&
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
194 Universe::narrow_oop_base() != NULL &&
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
195 Universe::narrow_oop_use_implicit_null_checks() )) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
196 tty->print_cr("WB_ReadFromNoaccessArea method is useless:\n "
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
197 "\tUseCompressedOops is %d\n"
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
198 "\trhs.base() is "PTR_FORMAT"\n"
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
199 "\tUniverse::narrow_oop_base() is "PTR_FORMAT"\n"
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
200 "\tUniverse::narrow_oop_use_implicit_null_checks() is %d",
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
201 UseCompressedOops,
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
202 rhs.base(),
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
203 Universe::narrow_oop_base(),
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
204 Universe::narrow_oop_use_implicit_null_checks());
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
205 return;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
206 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
207 tty->print_cr("Reading from no access area... ");
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
208 tty->print_cr("*(vs.low_boundary() - rhs.noaccess_prefix() / 2 ) = %c",
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
209 *(vs.low_boundary() - rhs.noaccess_prefix() / 2 ));
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
210 WB_END
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
211
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
212 static jint wb_stress_virtual_space_resize(size_t reserved_space_size,
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
213 size_t magnitude, size_t iterations) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
214 size_t granularity = os::vm_allocation_granularity();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
215 ReservedHeapSpace rhs(reserved_space_size * granularity, granularity, false, NULL);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
216 VirtualSpace vs;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
217 if (!vs.initialize(rhs, 0)) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
218 tty->print_cr("Failed to initialize VirtualSpace. Can't proceed.");
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
219 return 3;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
220 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
221
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
222 long seed = os::random();
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
223 tty->print_cr("Random seed is %ld", seed);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
224 os::init_random(seed);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
225
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
226 for (size_t i = 0; i < iterations; i++) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
227
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
228 // Whether we will shrink or grow
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
229 bool shrink = os::random() % 2L == 0;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
230
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
231 // Get random delta to resize virtual space
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
232 size_t delta = (size_t)os::random() % magnitude;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
233
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
234 // If we are about to shrink virtual space below zero, then expand instead
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
235 if (shrink && vs.committed_size() < delta) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
236 shrink = false;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
237 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
238
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
239 // Resizing by delta
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
240 if (shrink) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
241 vs.shrink_by(delta);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
242 } else {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
243 // If expanding fails expand_by will silently return false
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
244 vs.expand_by(delta, true);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
245 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
246 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
247 return 0;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
248 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
249
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
250 WB_ENTRY(jint, WB_StressVirtualSpaceResize(JNIEnv* env, jobject o,
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
251 jlong reserved_space_size, jlong magnitude, jlong iterations))
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
252 tty->print_cr("reservedSpaceSize="JLONG_FORMAT", magnitude="JLONG_FORMAT", "
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
253 "iterations="JLONG_FORMAT"\n", reserved_space_size, magnitude,
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
254 iterations);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
255 if (reserved_space_size < 0 || magnitude < 0 || iterations < 0) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
256 tty->print_cr("One of variables printed above is negative. Can't proceed.\n");
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
257 return 1;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
258 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
259
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
260 // sizeof(size_t) depends on whether OS is 32bit or 64bit. sizeof(jlong) is
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
261 // always 8 byte. That's why we should avoid overflow in case of 32bit platform.
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
262 if (sizeof(size_t) < sizeof(jlong)) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
263 jlong size_t_max_value = (jlong) SIZE_T_MAX_VALUE;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
264 if (reserved_space_size > size_t_max_value || magnitude > size_t_max_value
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
265 || iterations > size_t_max_value) {
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
266 tty->print_cr("One of variables printed above overflows size_t. Can't proceed.\n");
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
267 return 2;
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
268 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
269 }
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
270
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
271 return wb_stress_virtual_space_resize((size_t) reserved_space_size,
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
272 (size_t) magnitude, (size_t) iterations);
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
273 WB_END
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
274
20357
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
275 WB_ENTRY(jboolean, WB_isObjectInOldGen(JNIEnv* env, jobject o, jobject obj))
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
276 oop p = JNIHandles::resolve(obj);
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
277 #if INCLUDE_ALL_GCS
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
278 if (UseG1GC) {
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
279 G1CollectedHeap* g1 = G1CollectedHeap::heap();
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
280 const HeapRegion* hr = g1->heap_region_containing(p);
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
281 if (hr == NULL) {
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
282 return false;
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
283 }
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
284 return !(hr->is_young());
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
285 } else if (UseParallelGC) {
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
286 ParallelScavengeHeap* psh = ParallelScavengeHeap::heap();
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
287 return !psh->is_in_young(p);
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
288 }
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
289 #endif // INCLUDE_ALL_GCS
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
290 GenCollectedHeap* gch = GenCollectedHeap::heap();
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
291 return !gch->is_in_young(p);
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
292 WB_END
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
293
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
294 WB_ENTRY(jlong, WB_GetObjectSize(JNIEnv* env, jobject o, jobject obj))
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
295 oop p = JNIHandles::resolve(obj);
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
296 return p->size() * HeapWordSize;
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
297 WB_END
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
298
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
299 #if INCLUDE_ALL_GCS
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
300 WB_ENTRY(jboolean, WB_G1IsHumongous(JNIEnv* env, jobject o, jobject obj))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
301 G1CollectedHeap* g1 = G1CollectedHeap::heap();
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
302 oop result = JNIHandles::resolve(obj);
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
303 const HeapRegion* hr = g1->heap_region_containing(result);
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
304 return hr->isHumongous();
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
305 WB_END
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
306
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
307 WB_ENTRY(jlong, WB_G1NumFreeRegions(JNIEnv* env, jobject o))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
308 G1CollectedHeap* g1 = G1CollectedHeap::heap();
20336
6701abbc4441 8054818: Refactor HeapRegionSeq to manage heap region and auxiliary data
tschatzl
parents: 20278
diff changeset
309 size_t nr = g1->num_free_regions();
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
310 return (jlong)nr;
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
311 WB_END
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
312
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
313 WB_ENTRY(jboolean, WB_G1InConcurrentMark(JNIEnv* env, jobject o))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
314 G1CollectedHeap* g1 = G1CollectedHeap::heap();
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
315 ConcurrentMark* cm = g1->concurrent_mark();
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
316 return cm->concurrent_marking_in_progress();
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
317 WB_END
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
318
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
319 WB_ENTRY(jint, WB_G1RegionSize(JNIEnv* env, jobject o))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
320 return (jint)HeapRegion::GrainBytes;
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
321 WB_END
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
322 #endif // INCLUDE_ALL_GCS
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
323
12118
5fd8e2fbafd4 8020829: JT_HS: 2 runtime NMT tests fail on platforms if NMT detail is not supported
cjplummer
parents: 12073
diff changeset
324 #if INCLUDE_NMT
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
325 // Alloc memory using the test memory type so that we can use that to see if
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
326 // NMT picks it up correctly
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
327 WB_ENTRY(jlong, WB_NMTMalloc(JNIEnv* env, jobject o, jlong size))
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
328 jlong addr = 0;
20630
787c9c28311f 8058251: assert(_count > 0) failed: Negative counter when running runtime/NMT/MallocTrackingVerify.java
ctornqvi
parents: 20628
diff changeset
329 addr = (jlong)(uintptr_t)os::malloc(size, mtTest);
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
330 return addr;
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
331 WB_END
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
332
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
333 // Alloc memory with pseudo call stack. The test can create psudo malloc
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
334 // allocation site to stress the malloc tracking.
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
335 WB_ENTRY(jlong, WB_NMTMallocWithPseudoStack(JNIEnv* env, jobject o, jlong size, jint pseudo_stack))
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
336 address pc = (address)(size_t)pseudo_stack;
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
337 NativeCallStack stack(&pc, 1);
20630
787c9c28311f 8058251: assert(_count > 0) failed: Negative counter when running runtime/NMT/MallocTrackingVerify.java
ctornqvi
parents: 20628
diff changeset
338 return (jlong)(uintptr_t)os::malloc(size, mtTest, stack);
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
339 WB_END
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
340
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
341 // Free the memory allocated by NMTAllocTest
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
342 WB_ENTRY(void, WB_NMTFree(JNIEnv* env, jobject o, jlong mem))
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
343 os::free((void*)(uintptr_t)mem, mtTest);
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
344 WB_END
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
345
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
346 WB_ENTRY(jlong, WB_NMTReserveMemory(JNIEnv* env, jobject o, jlong size))
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
347 jlong addr = 0;
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
348
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
349 addr = (jlong)(uintptr_t)os::reserve_memory(size);
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
350 MemTracker::record_virtual_memory_type((address)addr, mtTest);
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
351
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
352 return addr;
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
353 WB_END
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
354
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
355
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
356 WB_ENTRY(void, WB_NMTCommitMemory(JNIEnv* env, jobject o, jlong addr, jlong size))
10969
a837fa3d3f86 8013057: assert(_needs_gc || SafepointSynchronize::is_at_safepoint()) failed: only read at safepoint
dcubed
parents: 10341
diff changeset
357 os::commit_memory((char *)(uintptr_t)addr, size, !ExecMem);
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
358 MemTracker::record_virtual_memory_type((address)(uintptr_t)addr, mtTest);
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
359 WB_END
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
360
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
361 WB_ENTRY(void, WB_NMTUncommitMemory(JNIEnv* env, jobject o, jlong addr, jlong size))
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
362 os::uncommit_memory((char *)(uintptr_t)addr, size);
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
363 WB_END
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
364
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
365 WB_ENTRY(void, WB_NMTReleaseMemory(JNIEnv* env, jobject o, jlong addr, jlong size))
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
366 os::release_memory((char *)(uintptr_t)addr, size);
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
367 WB_END
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
368
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
369 WB_ENTRY(jboolean, WB_NMTIsDetailSupported(JNIEnv* env))
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
370 return MemTracker::tracking_level() == NMT_detail;
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
371 WB_END
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
372
20553
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
373 WB_ENTRY(jboolean, WB_NMTChangeTrackingLevel(JNIEnv* env))
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
374 // Test that we can downgrade NMT levels but not upgrade them.
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
375 if (MemTracker::tracking_level() == NMT_off) {
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
376 MemTracker::transition_to(NMT_off);
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
377 return MemTracker::tracking_level() == NMT_off;
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
378 } else {
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
379 assert(MemTracker::tracking_level() == NMT_detail, "Should start out as detail tracking");
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
380 MemTracker::transition_to(NMT_summary);
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
381 assert(MemTracker::tracking_level() == NMT_summary, "Should be summary now");
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
382
20553
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
383 // Can't go to detail once NMT is set to summary.
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
384 MemTracker::transition_to(NMT_detail);
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
385 assert(MemTracker::tracking_level() == NMT_summary, "Should still be summary now");
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
386
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
387 // Shutdown sets tracking level to minimal.
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
388 MemTracker::shutdown();
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
389 assert(MemTracker::tracking_level() == NMT_minimal, "Should be minimal now");
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
390
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
391 // Once the tracking level is minimal, we cannot increase to summary.
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
392 // The code ignores this request instead of asserting because if the malloc site
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
393 // table overflows in another thread, it tries to change the code to summary.
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
394 MemTracker::transition_to(NMT_summary);
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
395 assert(MemTracker::tracking_level() == NMT_minimal, "Should still be minimal now");
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
396
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
397 // Really can never go up to detail, verify that the code would never do this.
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
398 MemTracker::transition_to(NMT_detail);
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
399 assert(MemTracker::tracking_level() == NMT_minimal, "Should still be minimal now");
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
400 return MemTracker::tracking_level() == NMT_minimal;
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
401 }
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
402 WB_END
20628
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
403
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
404 WB_ENTRY(jint, WB_NMTGetHashSize(JNIEnv* env, jobject o))
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
405 int hash_size = MallocSiteTable::hash_buckets();
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
406 assert(hash_size > 0, "NMT hash_size should be > 0");
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
407 return (jint)hash_size;
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
408 WB_END
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
409 #endif // INCLUDE_NMT
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
410
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
411 static jmethodID reflected_method_to_jmid(JavaThread* thread, JNIEnv* env, jobject method) {
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
412 assert(method != NULL, "method should not be null");
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
413 ThreadToNativeFromVM ttn(thread);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
414 return env->FromReflectedMethod(method);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
415 }
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
416
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
417 WB_ENTRY(void, WB_DeoptimizeAll(JNIEnv* env, jobject o))
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
418 MutexLockerEx mu(Compile_lock);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
419 CodeCache::mark_all_nmethods_for_deoptimization();
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
420 VM_Deoptimize op;
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
421 VMThread::execute(&op);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
422 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
423
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
424 WB_ENTRY(jint, WB_DeoptimizeMethod(JNIEnv* env, jobject o, jobject method, jboolean is_osr))
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
425 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
426 int result = 0;
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
427 CHECK_JNI_EXCEPTION_(env, result);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
428 MutexLockerEx mu(Compile_lock);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
429 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
430 if (is_osr) {
20611
3c87c13918fb 8061817: Whitebox.deoptimizeMethod() does not deoptimize all OSR versions of method
thartmann
parents: 20608
diff changeset
431 result += mh->mark_osr_nmethods();
3c87c13918fb 8061817: Whitebox.deoptimizeMethod() does not deoptimize all OSR versions of method
thartmann
parents: 20608
diff changeset
432 } else if (mh->code() != NULL) {
3c87c13918fb 8061817: Whitebox.deoptimizeMethod() does not deoptimize all OSR versions of method
thartmann
parents: 20608
diff changeset
433 mh->code()->mark_for_deoptimization();
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
434 ++result;
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
435 }
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
436 result += CodeCache::mark_for_deoptimization(mh());
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
437 if (result > 0) {
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
438 VM_Deoptimize op;
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
439 VMThread::execute(&op);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
440 }
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
441 return result;
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
442 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
443
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
444 WB_ENTRY(jboolean, WB_IsMethodCompiled(JNIEnv* env, jobject o, jobject method, jboolean is_osr))
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
445 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
446 CHECK_JNI_EXCEPTION_(env, JNI_FALSE);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
447 MutexLockerEx mu(Compile_lock);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
448 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
449 nmethod* code = is_osr ? mh->lookup_osr_nmethod_for(InvocationEntryBci, CompLevel_none, false) : mh->code();
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
450 if (code == NULL) {
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
451 return JNI_FALSE;
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
452 }
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
453 return (code->is_alive() && !code->is_marked_for_deoptimization());
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
454 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
455
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
456 WB_ENTRY(jboolean, WB_IsMethodCompilable(JNIEnv* env, jobject o, jobject method, jint comp_level, jboolean is_osr))
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
457 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
458 CHECK_JNI_EXCEPTION_(env, JNI_FALSE);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
459 MutexLockerEx mu(Compile_lock);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
460 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
461 if (is_osr) {
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
462 return CompilationPolicy::can_be_osr_compiled(mh, comp_level);
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
463 } else {
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
464 return CompilationPolicy::can_be_compiled(mh, comp_level);
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
465 }
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
466 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
467
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
468 WB_ENTRY(jboolean, WB_IsMethodQueuedForCompilation(JNIEnv* env, jobject o, jobject method))
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
469 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
470 CHECK_JNI_EXCEPTION_(env, JNI_FALSE);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
471 MutexLockerEx mu(Compile_lock);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
472 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
473 return mh->queued_for_compilation();
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
474 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
475
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
476 WB_ENTRY(jint, WB_GetMethodCompilationLevel(JNIEnv* env, jobject o, jobject method, jboolean is_osr))
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
477 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
478 CHECK_JNI_EXCEPTION_(env, CompLevel_none);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
479 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
480 nmethod* code = is_osr ? mh->lookup_osr_nmethod_for(InvocationEntryBci, CompLevel_none, false) : mh->code();
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
481 return (code != NULL ? code->comp_level() : CompLevel_none);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
482 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
483
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
484 WB_ENTRY(void, WB_MakeMethodNotCompilable(JNIEnv* env, jobject o, jobject method, jint comp_level, jboolean is_osr))
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
485 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
486 CHECK_JNI_EXCEPTION(env);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
487 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
488 if (is_osr) {
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
489 mh->set_not_osr_compilable(comp_level, true /* report */, "WhiteBox");
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
490 } else {
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
491 mh->set_not_compilable(comp_level, true /* report */, "WhiteBox");
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
492 }
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
493 WB_END
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
494
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
495 WB_ENTRY(jint, WB_GetMethodEntryBci(JNIEnv* env, jobject o, jobject method))
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
496 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
497 CHECK_JNI_EXCEPTION_(env, InvocationEntryBci);
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
498 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
499 nmethod* code = mh->lookup_osr_nmethod_for(InvocationEntryBci, CompLevel_none, false);
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
500 return (code != NULL && code->is_osr_method() ? code->osr_entry_bci() : InvocationEntryBci);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
501 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
502
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
503 WB_ENTRY(jboolean, WB_TestSetDontInlineMethod(JNIEnv* env, jobject o, jobject method, jboolean value))
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
504 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
505 CHECK_JNI_EXCEPTION_(env, JNI_FALSE);
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
506 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
507 bool result = mh->dont_inline();
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
508 mh->set_dont_inline(value == JNI_TRUE);
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
509 return result;
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
510 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
511
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
512 WB_ENTRY(jint, WB_GetCompileQueueSize(JNIEnv* env, jobject o, jint comp_level))
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
513 if (comp_level == CompLevel_any) {
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
514 return CompileBroker::queue_size(CompLevel_full_optimization) /* C2 */ +
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
515 CompileBroker::queue_size(CompLevel_full_profile) /* C1 */;
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
516 } else {
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
517 return CompileBroker::queue_size(comp_level);
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
518 }
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
519 WB_END
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
520
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
521 WB_ENTRY(jboolean, WB_TestSetForceInlineMethod(JNIEnv* env, jobject o, jobject method, jboolean value))
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
522 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
523 CHECK_JNI_EXCEPTION_(env, JNI_FALSE);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
524 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
525 bool result = mh->force_inline();
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
526 mh->set_force_inline(value == JNI_TRUE);
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
527 return result;
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
528 WB_END
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
529
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
530 WB_ENTRY(jboolean, WB_EnqueueMethodForCompilation(JNIEnv* env, jobject o, jobject method, jint comp_level, jint bci))
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
531 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
532 CHECK_JNI_EXCEPTION_(env, JNI_FALSE);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
533 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
534 nmethod* nm = CompileBroker::compile_method(mh, bci, comp_level, mh, mh->invocation_count(), "WhiteBox", THREAD);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
535 MutexLockerEx mu(Compile_lock);
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
536 return (mh->queued_for_compilation() || nm != NULL);
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
537 WB_END
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
538
17867
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
539 class VM_WhiteBoxOperation : public VM_Operation {
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
540 public:
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
541 VM_WhiteBoxOperation() { }
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
542 VMOp_Type type() const { return VMOp_WhiteBoxOperation; }
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
543 bool allow_nested_vm_operations() const { return true; }
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
544 };
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
545
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
546 class AlwaysFalseClosure : public BoolObjectClosure {
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
547 public:
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
548 bool do_object_b(oop p) { return false; }
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
549 };
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
550
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
551 static AlwaysFalseClosure always_false;
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
552
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
553 class VM_WhiteBoxCleanMethodData : public VM_WhiteBoxOperation {
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
554 public:
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
555 VM_WhiteBoxCleanMethodData(MethodData* mdo) : _mdo(mdo) { }
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
556 void doit() {
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
557 _mdo->clean_method_data(&always_false);
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
558 }
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
559 private:
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
560 MethodData* _mdo;
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
561 };
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
562
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
563 WB_ENTRY(void, WB_ClearMethodState(JNIEnv* env, jobject o, jobject method))
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
564 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
17704
56cd09c4a5c9 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 13070
diff changeset
565 CHECK_JNI_EXCEPTION(env);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
566 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
567 MutexLockerEx mu(Compile_lock);
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
568 MethodData* mdo = mh->method_data();
10107
jiangli
parents: 9085
diff changeset
569 MethodCounters* mcs = mh->method_counters();
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
570
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
571 if (mdo != NULL) {
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
572 mdo->init();
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
573 ResourceMark rm;
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
574 int arg_count = mdo->method()->size_of_parameters();
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
575 for (int i = 0; i < arg_count; i++) {
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
576 mdo->set_arg_modified(i, 0);
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
577 }
17867
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
578 VM_WhiteBoxCleanMethodData op(mdo);
b127b0d6de7f 8039597: WhiteBox :: clean type profiling data
iignatyev
parents: 17817
diff changeset
579 VMThread::execute(&op);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
580 }
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
581
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
582 mh->clear_not_c1_compilable();
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
583 mh->clear_not_c2_compilable();
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
584 mh->clear_not_c2_osr_compilable();
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
585 NOT_PRODUCT(mh->set_compiled_invocation_count(0));
10107
jiangli
parents: 9085
diff changeset
586 if (mcs != NULL) {
jiangli
parents: 9085
diff changeset
587 mcs->backedge_counter()->init();
jiangli
parents: 9085
diff changeset
588 mcs->invocation_counter()->init();
jiangli
parents: 9085
diff changeset
589 mcs->set_interpreter_invocation_count(0);
jiangli
parents: 9085
diff changeset
590 mcs->set_interpreter_throwout_count(0);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
591
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
592 #ifdef TIERED
10107
jiangli
parents: 9085
diff changeset
593 mcs->set_rate(0.0F);
20465
7301840ea20e 8023461: Thread holding lock at safepoint that vm can block on: MethodCompileQueue_lock
vlivanov
parents: 20451
diff changeset
594 mh->set_prev_event_count(0);
7301840ea20e 8023461: Thread holding lock at safepoint that vm can block on: MethodCompileQueue_lock
vlivanov
parents: 20451
diff changeset
595 mh->set_prev_time(0);
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
596 #endif
10107
jiangli
parents: 9085
diff changeset
597 }
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
598 WB_END
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
599
20249
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
600 template <typename T>
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
601 static bool GetVMFlag(JavaThread* thread, JNIEnv* env, jstring name, T* value, bool (*TAt)(const char*, T*)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
602 if (name == NULL) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
603 return false;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
604 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
605 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
606 const char* flag_name = env->GetStringUTFChars(name, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
607 bool result = (*TAt)(flag_name, value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
608 env->ReleaseStringUTFChars(name, flag_name);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
609 return result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
610 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
611
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
612 template <typename T>
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
613 static bool SetVMFlag(JavaThread* thread, JNIEnv* env, jstring name, T* value, bool (*TAtPut)(const char*, T*, Flag::Flags)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
614 if (name == NULL) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
615 return false;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
616 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
617 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
618 const char* flag_name = env->GetStringUTFChars(name, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
619 bool result = (*TAtPut)(flag_name, value, Flag::INTERNAL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
620 env->ReleaseStringUTFChars(name, flag_name);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
621 return result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
622 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
623
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
624 template <typename T>
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
625 static jobject box(JavaThread* thread, JNIEnv* env, Symbol* name, Symbol* sig, T value) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
626 ResourceMark rm(thread);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
627 jclass clazz = env->FindClass(name->as_C_string());
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
628 CHECK_JNI_EXCEPTION_(env, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
629 jmethodID methodID = env->GetStaticMethodID(clazz,
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
630 vmSymbols::valueOf_name()->as_C_string(),
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
631 sig->as_C_string());
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
632 CHECK_JNI_EXCEPTION_(env, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
633 jobject result = env->CallStaticObjectMethod(clazz, methodID, value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
634 CHECK_JNI_EXCEPTION_(env, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
635 return result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
636 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
637
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
638 static jobject booleanBox(JavaThread* thread, JNIEnv* env, jboolean value) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
639 return box(thread, env, vmSymbols::java_lang_Boolean(), vmSymbols::Boolean_valueOf_signature(), value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
640 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
641 static jobject integerBox(JavaThread* thread, JNIEnv* env, jint value) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
642 return box(thread, env, vmSymbols::java_lang_Integer(), vmSymbols::Integer_valueOf_signature(), value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
643 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
644 static jobject longBox(JavaThread* thread, JNIEnv* env, jlong value) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
645 return box(thread, env, vmSymbols::java_lang_Long(), vmSymbols::Long_valueOf_signature(), value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
646 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
647 /* static jobject floatBox(JavaThread* thread, JNIEnv* env, jfloat value) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
648 return box(thread, env, vmSymbols::java_lang_Float(), vmSymbols::Float_valueOf_signature(), value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
649 }*/
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
650 static jobject doubleBox(JavaThread* thread, JNIEnv* env, jdouble value) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
651 return box(thread, env, vmSymbols::java_lang_Double(), vmSymbols::Double_valueOf_signature(), value);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
652 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
653
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
654 WB_ENTRY(jobject, WB_GetBooleanVMFlag(JNIEnv* env, jobject o, jstring name))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
655 bool result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
656 if (GetVMFlag <bool> (thread, env, name, &result, &CommandLineFlags::boolAt)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
657 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
658 return booleanBox(thread, env, result);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
659 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
660 return NULL;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
661 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
662
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
663 WB_ENTRY(jobject, WB_GetIntxVMFlag(JNIEnv* env, jobject o, jstring name))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
664 intx result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
665 if (GetVMFlag <intx> (thread, env, name, &result, &CommandLineFlags::intxAt)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
666 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
667 return longBox(thread, env, result);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
668 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
669 return NULL;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
670 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
671
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
672 WB_ENTRY(jobject, WB_GetUintxVMFlag(JNIEnv* env, jobject o, jstring name))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
673 uintx result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
674 if (GetVMFlag <uintx> (thread, env, name, &result, &CommandLineFlags::uintxAt)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
675 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
676 return longBox(thread, env, result);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
677 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
678 return NULL;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
679 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
680
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
681 WB_ENTRY(jobject, WB_GetUint64VMFlag(JNIEnv* env, jobject o, jstring name))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
682 uint64_t result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
683 if (GetVMFlag <uint64_t> (thread, env, name, &result, &CommandLineFlags::uint64_tAt)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
684 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
685 return longBox(thread, env, result);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
686 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
687 return NULL;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
688 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
689
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
690 WB_ENTRY(jobject, WB_GetDoubleVMFlag(JNIEnv* env, jobject o, jstring name))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
691 double result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
692 if (GetVMFlag <double> (thread, env, name, &result, &CommandLineFlags::doubleAt)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
693 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
694 return doubleBox(thread, env, result);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
695 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
696 return NULL;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
697 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
698
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
699 WB_ENTRY(jstring, WB_GetStringVMFlag(JNIEnv* env, jobject o, jstring name))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
700 ccstr ccstrResult;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
701 if (GetVMFlag <ccstr> (thread, env, name, &ccstrResult, &CommandLineFlags::ccstrAt)) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
702 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
703 jstring result = env->NewStringUTF(ccstrResult);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
704 CHECK_JNI_EXCEPTION_(env, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
705 return result;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
706 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
707 return NULL;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
708 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
709
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
710 WB_ENTRY(void, WB_SetBooleanVMFlag(JNIEnv* env, jobject o, jstring name, jboolean value))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
711 bool result = value == JNI_TRUE ? true : false;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
712 SetVMFlag <bool> (thread, env, name, &result, &CommandLineFlags::boolAtPut);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
713 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
714
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
715 WB_ENTRY(void, WB_SetIntxVMFlag(JNIEnv* env, jobject o, jstring name, jlong value))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
716 intx result = value;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
717 SetVMFlag <intx> (thread, env, name, &result, &CommandLineFlags::intxAtPut);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
718 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
719
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
720 WB_ENTRY(void, WB_SetUintxVMFlag(JNIEnv* env, jobject o, jstring name, jlong value))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
721 uintx result = value;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
722 SetVMFlag <uintx> (thread, env, name, &result, &CommandLineFlags::uintxAtPut);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
723 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
724
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
725 WB_ENTRY(void, WB_SetUint64VMFlag(JNIEnv* env, jobject o, jstring name, jlong value))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
726 uint64_t result = value;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
727 SetVMFlag <uint64_t> (thread, env, name, &result, &CommandLineFlags::uint64_tAtPut);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
728 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
729
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
730 WB_ENTRY(void, WB_SetDoubleVMFlag(JNIEnv* env, jobject o, jstring name, jdouble value))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
731 double result = value;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
732 SetVMFlag <double> (thread, env, name, &result, &CommandLineFlags::doubleAtPut);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
733 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
734
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
735 WB_ENTRY(void, WB_SetStringVMFlag(JNIEnv* env, jobject o, jstring name, jstring value))
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
736 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
737 const char* ccstrValue = (value == NULL) ? NULL : env->GetStringUTFChars(value, NULL);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
738 ccstr ccstrResult = ccstrValue;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
739 bool needFree;
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
740 {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
741 ThreadInVMfromNative ttvfn(thread); // back to VM
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
742 needFree = SetVMFlag <ccstr> (thread, env, name, &ccstrResult, &CommandLineFlags::ccstrAtPut);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
743 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
744 if (value != NULL) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
745 env->ReleaseStringUTFChars(value, ccstrValue);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
746 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
747 if (needFree) {
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
748 FREE_C_HEAP_ARRAY(char, ccstrResult, mtInternal);
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
749 }
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
750 WB_END
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
751
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
752
8850
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
753 WB_ENTRY(jboolean, WB_IsInStringTable(JNIEnv* env, jobject o, jstring javaString))
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
754 ResourceMark rm(THREAD);
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
755 int len;
10155
f258c5828eb8 8011773: Some tests on Interned String crashed JVM with OOM
hseigel
parents: 10116
diff changeset
756 jchar* name = java_lang_String::as_unicode_string(JNIHandles::resolve(javaString), len, CHECK_false);
f258c5828eb8 8011773: Some tests on Interned String crashed JVM with OOM
hseigel
parents: 10116
diff changeset
757 return (StringTable::lookup(name, len) != NULL);
8850
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
758 WB_END
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
759
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
760 WB_ENTRY(void, WB_FullGC(JNIEnv* env, jobject o))
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
761 Universe::heap()->collector_policy()->set_should_clear_all_soft_refs(true);
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
762 Universe::heap()->collect(GCCause::_last_ditch_collection);
20451
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
763 #if INCLUDE_ALL_GCS
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
764 if (UseG1GC) {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
765 // Needs to be cleared explicitly for G1
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
766 Universe::heap()->collector_policy()->set_should_clear_all_soft_refs(false);
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
767 }
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
768 #endif // INCLUDE_ALL_GCS
8850
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
769 WB_END
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
770
20357
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
771 WB_ENTRY(void, WB_YoungGC(JNIEnv* env, jobject o))
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
772 Universe::heap()->collect(GCCause::_wb_young_gc);
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
773 WB_END
10157
f32b6c267d2e 8012015: Use PROT_NONE when reserving memory
mikael
parents: 10155
diff changeset
774
10341
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
775 WB_ENTRY(void, WB_ReadReservedMemory(JNIEnv* env, jobject o))
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
776 // static+volatile in order to force the read to happen
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
777 // (not be eliminated by the compiler)
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
778 static char c;
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
779 static volatile char* p;
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
780
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
781 p = os::reserve_memory(os::vm_allocation_granularity(), NULL, 0);
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
782 if (p == NULL) {
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
783 THROW_MSG(vmSymbols::java_lang_OutOfMemoryError(), "Failed to reserve memory");
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
784 }
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
785
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
786 c = *p;
10157
f32b6c267d2e 8012015: Use PROT_NONE when reserving memory
mikael
parents: 10155
diff changeset
787 WB_END
f32b6c267d2e 8012015: Use PROT_NONE when reserving memory
mikael
parents: 10155
diff changeset
788
17778
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
789 WB_ENTRY(jstring, WB_GetCPUFeatures(JNIEnv* env, jobject o))
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
790 const char* cpu_features = VM_Version::cpu_features();
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
791 ThreadToNativeFromVM ttn(thread);
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
792 jstring features_string = env->NewStringUTF(cpu_features);
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
793
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
794 CHECK_JNI_EXCEPTION_(env, NULL);
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
795
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
796 return features_string;
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
797 WB_END
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
798
17817
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
799
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
800 WB_ENTRY(jobjectArray, WB_GetNMethod(JNIEnv* env, jobject o, jobject method, jboolean is_osr))
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
801 ResourceMark rm(THREAD);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
802 jmethodID jmid = reflected_method_to_jmid(thread, env, method);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
803 CHECK_JNI_EXCEPTION_(env, NULL);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
804 methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid));
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
805 nmethod* code = is_osr ? mh->lookup_osr_nmethod_for(InvocationEntryBci, CompLevel_none, false) : mh->code();
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
806 jobjectArray result = NULL;
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
807 if (code == NULL) {
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
808 return result;
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
809 }
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
810 int insts_size = code->insts_size();
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
811
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
812 ThreadToNativeFromVM ttn(thread);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
813 jclass clazz = env->FindClass(vmSymbols::java_lang_Object()->as_C_string());
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
814 CHECK_JNI_EXCEPTION_(env, NULL);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
815 result = env->NewObjectArray(2, clazz, NULL);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
816 if (result == NULL) {
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
817 return result;
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
818 }
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
819
20249
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
820 jobject obj = integerBox(thread, env, code->comp_level());
17817
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
821 CHECK_JNI_EXCEPTION_(env, NULL);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
822 env->SetObjectArrayElement(result, 0, obj);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
823
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
824 jbyteArray insts = env->NewByteArray(insts_size);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
825 CHECK_JNI_EXCEPTION_(env, NULL);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
826 env->SetByteArrayRegion(insts, 0, insts_size, (jbyte*) code->insts_begin());
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
827 env->SetObjectArrayElement(result, 1, insts);
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
828
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
829 return result;
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
830 WB_END
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
831
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
832
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
833 int WhiteBox::array_bytes_to_length(size_t bytes) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
834 return Array<u1>::bytes_to_length(bytes);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
835 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
836
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
837 WB_ENTRY(jlong, WB_AllocateMetaspace(JNIEnv* env, jobject wb, jobject class_loader, jlong size))
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
838 if (size < 0) {
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
839 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(),
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
840 err_msg("WB_AllocateMetaspace: size is negative: " JLONG_FORMAT, size));
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
841 }
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
842
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
843 oop class_loader_oop = JNIHandles::resolve(class_loader);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
844 ClassLoaderData* cld = class_loader_oop != NULL
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
845 ? java_lang_ClassLoader::loader_data(class_loader_oop)
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
846 : ClassLoaderData::the_null_class_loader_data();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
847
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
848 void* metadata = MetadataFactory::new_writeable_array<u1>(cld, WhiteBox::array_bytes_to_length((size_t)size), thread);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
849
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
850 return (jlong)(uintptr_t)metadata;
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
851 WB_END
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
852
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
853 WB_ENTRY(void, WB_FreeMetaspace(JNIEnv* env, jobject wb, jobject class_loader, jlong addr, jlong size))
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
854 oop class_loader_oop = JNIHandles::resolve(class_loader);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
855 ClassLoaderData* cld = class_loader_oop != NULL
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
856 ? java_lang_ClassLoader::loader_data(class_loader_oop)
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
857 : ClassLoaderData::the_null_class_loader_data();
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
858
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
859 MetadataFactory::free_array(cld, (Array<u1>*)(uintptr_t)addr);
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
860 WB_END
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
861
20540
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
862 WB_ENTRY(jlong, WB_IncMetaspaceCapacityUntilGC(JNIEnv* env, jobject wb, jlong inc))
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
863 if (inc < 0) {
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
864 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(),
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
865 err_msg("WB_IncMetaspaceCapacityUntilGC: inc is negative: " JLONG_FORMAT, inc));
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
866 }
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
867
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
868 jlong max_size_t = (jlong) ((size_t) -1);
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
869 if (inc > max_size_t) {
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
870 THROW_MSG_0(vmSymbols::java_lang_IllegalArgumentException(),
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
871 err_msg("WB_IncMetaspaceCapacityUntilGC: inc does not fit in size_t: " JLONG_FORMAT, inc));
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
872 }
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
873
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
874 size_t new_cap_until_GC = 0;
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
875 size_t aligned_inc = align_size_down((size_t) inc, Metaspace::commit_alignment());
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
876 bool success = MetaspaceGC::inc_capacity_until_GC(aligned_inc, &new_cap_until_GC);
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
877 if (!success) {
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
878 THROW_MSG_0(vmSymbols::java_lang_IllegalStateException(),
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
879 "WB_IncMetaspaceCapacityUntilGC: could not increase capacity until GC "
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
880 "due to contention with another thread");
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
881 }
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
882 return (jlong) new_cap_until_GC;
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
883 WB_END
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
884
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
885 WB_ENTRY(jlong, WB_MetaspaceCapacityUntilGC(JNIEnv* env, jobject wb))
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
886 return (jlong) MetaspaceGC::capacity_until_GC();
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
887 WB_END
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
888
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
889 //Some convenience methods to deal with objects from java
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
890 int WhiteBox::offset_for_field(const char* field_name, oop object,
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
891 Symbol* signature_symbol) {
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
892 assert(field_name != NULL && strlen(field_name) > 0, "Field name not valid");
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
893 Thread* THREAD = Thread::current();
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
894
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
895 //Get the class of our object
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
896 Klass* arg_klass = object->klass();
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
897 //Turn it into an instance-klass
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
898 InstanceKlass* ik = InstanceKlass::cast(arg_klass);
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
899
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
900 //Create symbols to look for in the class
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
901 TempNewSymbol name_symbol = SymbolTable::lookup(field_name, (int) strlen(field_name),
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
902 THREAD);
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
903
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
904 //To be filled in with an offset of the field we're looking for
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
905 fieldDescriptor fd;
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
906
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6202
diff changeset
907 Klass* res = ik->find_field(name_symbol, signature_symbol, &fd);
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
908 if (res == NULL) {
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
909 tty->print_cr("Invalid layout of %s at %s", ik->external_name(),
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
910 name_symbol->as_C_string());
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
911 fatal("Invalid layout of preloaded class");
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
912 }
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
913
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
914 //fetch the field at the offset we've found
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
915 int dest_offset = fd.offset();
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
916
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
917 return dest_offset;
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
918 }
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
919
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
920
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
921 const char* WhiteBox::lookup_jstring(const char* field_name, oop object) {
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
922 int offset = offset_for_field(field_name, object,
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
923 vmSymbols::string_signature());
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
924 oop string = object->obj_field(offset);
6202
5a1f452f8f90 7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents: 5978
diff changeset
925 if (string == NULL) {
5a1f452f8f90 7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents: 5978
diff changeset
926 return NULL;
5a1f452f8f90 7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents: 5978
diff changeset
927 }
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
928 const char* ret = java_lang_String::as_utf8_string(string);
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
929 return ret;
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
930 }
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
931
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
932 bool WhiteBox::lookup_bool(const char* field_name, oop object) {
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
933 int offset =
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
934 offset_for_field(field_name, object, vmSymbols::bool_signature());
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
935 bool ret = (object->bool_field(offset) == JNI_TRUE);
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
936 return ret;
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
937 }
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
938
20451
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
939 void WhiteBox::register_methods(JNIEnv* env, jclass wbclass, JavaThread* thread, JNINativeMethod* method_array, int method_count) {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
940 ResourceMark rm;
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
941 ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
942
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
943 // one by one registration natives for exception catching
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
944 jclass no_such_method_error_klass = env->FindClass(vmSymbols::java_lang_NoSuchMethodError()->as_C_string());
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
945 CHECK_JNI_EXCEPTION(env);
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
946 for (int i = 0, n = method_count; i < n; ++i) {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
947 // Skip dummy entries
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
948 if (method_array[i].fnPtr == NULL) continue;
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
949 if (env->RegisterNatives(wbclass, &method_array[i], 1) != 0) {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
950 jthrowable throwable_obj = env->ExceptionOccurred();
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
951 if (throwable_obj != NULL) {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
952 env->ExceptionClear();
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
953 if (env->IsInstanceOf(throwable_obj, no_such_method_error_klass)) {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
954 // NoSuchMethodError is thrown when a method can't be found or a method is not native.
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
955 // Ignoring the exception since it is not preventing use of other WhiteBox methods.
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
956 tty->print_cr("Warning: 'NoSuchMethodError' on register of sun.hotspot.WhiteBox::%s%s",
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
957 method_array[i].name, method_array[i].signature);
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
958 }
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
959 } else {
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
960 // Registration failed unexpectedly.
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
961 tty->print_cr("Warning: unexpected error on register of sun.hotspot.WhiteBox::%s%s. All methods will be unregistered",
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
962 method_array[i].name, method_array[i].signature);
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
963 env->UnregisterNatives(wbclass);
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
964 break;
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
965 }
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
966 }
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
967 }
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
968 }
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
969
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
970 #define CC (char*)
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
971
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
972 static JNINativeMethod methods[] = {
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
973 {CC"getObjectAddress", CC"(Ljava/lang/Object;)J", (void*)&WB_GetObjectAddress },
20357
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
974 {CC"getObjectSize", CC"(Ljava/lang/Object;)J", (void*)&WB_GetObjectSize },
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
975 {CC"isObjectInOldGen", CC"(Ljava/lang/Object;)Z", (void*)&WB_isObjectInOldGen },
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
976 {CC"getHeapOopSize", CC"()I", (void*)&WB_GetHeapOopSize },
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
977 {CC"isClassAlive0", CC"(Ljava/lang/String;)Z", (void*)&WB_IsClassAlive },
20608
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
978 {CC"classKnownToNotExist",
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
979 CC"(Ljava/lang/ClassLoader;Ljava/lang/String;)Z",(void*)&WB_ClassKnownToNotExist},
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
980 {CC"getLookupCacheURLs", CC"(Ljava/lang/ClassLoader;)[Ljava/net/URL;", (void*)&WB_GetLookupCacheURLs},
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
981 {CC"getLookupCacheMatches", CC"(Ljava/lang/ClassLoader;Ljava/lang/String;)[I",
4cb90023bf2b 8061651: Interface to the Lookup Index Cache to improve URLClassPath search time
iklam
parents: 20553
diff changeset
982 (void*)&WB_GetLookupCacheMatches},
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
983 {CC"parseCommandLine",
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
984 CC"(Ljava/lang/String;[Lsun/hotspot/parser/DiagnosticCommand;)[Ljava/lang/Object;",
5978
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
985 (void*) &WB_ParseCommandLine
51612f0c0a79 7148488: Whitebox tests for the Diagnostic Framework Parser
nloodin
parents: 5915
diff changeset
986 },
20667
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
987 {CC"addToBootstrapClassLoaderSearch", CC"(Ljava/lang/String;)V",
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
988 (void*)&WB_AddToBootstrapClassLoaderSearch},
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
989 {CC"addToSystemClassLoaderSearch", CC"(Ljava/lang/String;)V",
887a7cedb892 8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
iklam
parents: 20630
diff changeset
990 (void*)&WB_AddToSystemClassLoaderSearch},
12233
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
991 {CC"getCompressedOopsMaxHeapSize", CC"()J",
40136aa2cdb1 8010722: assert: failed: heap size is too big for compressed oops
tschatzl
parents: 12118
diff changeset
992 (void*)&WB_GetCompressedOopsMaxHeapSize},
10241
d17700c82d7d 8006088: Incompatible heap size flags accepted by VM
tschatzl
parents: 10208
diff changeset
993 {CC"printHeapSizes", CC"()V", (void*)&WB_PrintHeapSizes },
13053
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
994 {CC"runMemoryUnitTests", CC"()V", (void*)&WB_RunMemoryUnitTests},
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
995 {CC"readFromNoaccessArea",CC"()V", (void*)&WB_ReadFromNoaccessArea},
9d8b29a0548c 8027237: New tests on ReservedSpace/VirtualSpace classes
mgerdin
parents: 12233
diff changeset
996 {CC"stressVirtualSpaceResize",CC"(JJJ)I", (void*)&WB_StressVirtualSpaceResize},
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
997 #if INCLUDE_ALL_GCS
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
998 {CC"g1InConcurrentMark", CC"()Z", (void*)&WB_G1InConcurrentMark},
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
999 {CC"g1IsHumongous", CC"(Ljava/lang/Object;)Z", (void*)&WB_G1IsHumongous },
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1000 {CC"g1NumFreeRegions", CC"()J", (void*)&WB_G1NumFreeRegions },
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1001 {CC"g1RegionSize", CC"()I", (void*)&WB_G1RegionSize },
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
1002 #endif // INCLUDE_ALL_GCS
12118
5fd8e2fbafd4 8020829: JT_HS: 2 runtime NMT tests fail on platforms if NMT detail is not supported
cjplummer
parents: 12073
diff changeset
1003 #if INCLUDE_NMT
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
1004 {CC"NMTMalloc", CC"(J)J", (void*)&WB_NMTMalloc },
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 20357
diff changeset
1005 {CC"NMTMallocWithPseudoStack", CC"(JI)J", (void*)&WB_NMTMallocWithPseudoStack},
9056
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
1006 {CC"NMTFree", CC"(J)V", (void*)&WB_NMTFree },
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
1007 {CC"NMTReserveMemory", CC"(J)J", (void*)&WB_NMTReserveMemory },
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
1008 {CC"NMTCommitMemory", CC"(JJ)V", (void*)&WB_NMTCommitMemory },
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
1009 {CC"NMTUncommitMemory", CC"(JJ)V", (void*)&WB_NMTUncommitMemory },
3b890cd4da64 8009125: Add NMT tests for Virtual Memory operations
ctornqvi
parents: 8850
diff changeset
1010 {CC"NMTReleaseMemory", CC"(JJ)V", (void*)&WB_NMTReleaseMemory },
12118
5fd8e2fbafd4 8020829: JT_HS: 2 runtime NMT tests fail on platforms if NMT detail is not supported
cjplummer
parents: 12073
diff changeset
1011 {CC"NMTIsDetailSupported",CC"()Z", (void*)&WB_NMTIsDetailSupported},
20553
417e3b8d04c5 8059100: SIGSEGV VirtualMemoryTracker::remove_released_region
coleenp
parents: 20540
diff changeset
1012 {CC"NMTChangeTrackingLevel", CC"()Z", (void*)&WB_NMTChangeTrackingLevel},
20628
80260967f994 8061969: [TESTBUG] MallocSiteHashOverflow.java should be enabled for 32-bit platforms
gtriantafill
parents: 20611
diff changeset
1013 {CC"NMTGetHashSize", CC"()I", (void*)&WB_NMTGetHashSize },
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 6725
diff changeset
1014 #endif // INCLUDE_NMT
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1015 {CC"deoptimizeAll", CC"()V", (void*)&WB_DeoptimizeAll },
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1016 {CC"deoptimizeMethod", CC"(Ljava/lang/reflect/Executable;Z)I",
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1017 (void*)&WB_DeoptimizeMethod },
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1018 {CC"isMethodCompiled", CC"(Ljava/lang/reflect/Executable;Z)Z",
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1019 (void*)&WB_IsMethodCompiled },
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1020 {CC"isMethodCompilable", CC"(Ljava/lang/reflect/Executable;IZ)Z",
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1021 (void*)&WB_IsMethodCompilable},
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1022 {CC"isMethodQueuedForCompilation",
10113
4b2eebe03f93 8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents: 9085
diff changeset
1023 CC"(Ljava/lang/reflect/Executable;)Z", (void*)&WB_IsMethodQueuedForCompilation},
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1024 {CC"makeMethodNotCompilable",
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1025 CC"(Ljava/lang/reflect/Executable;IZ)V", (void*)&WB_MakeMethodNotCompilable},
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
1026 {CC"testSetDontInlineMethod",
10113
4b2eebe03f93 8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents: 9085
diff changeset
1027 CC"(Ljava/lang/reflect/Executable;Z)Z", (void*)&WB_TestSetDontInlineMethod},
8051
12e01444ca2d 8006683: Add WhiteBox API to testing of compiler
iignatyev
parents: 8003
diff changeset
1028 {CC"getMethodCompilationLevel",
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1029 CC"(Ljava/lang/reflect/Executable;Z)I", (void*)&WB_GetMethodCompilationLevel},
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1030 {CC"getMethodEntryBci",
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1031 CC"(Ljava/lang/reflect/Executable;)I", (void*)&WB_GetMethodEntryBci},
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1032 {CC"getCompileQueueSize",
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1033 CC"(I)I", (void*)&WB_GetCompileQueueSize},
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
1034 {CC"testSetForceInlineMethod",
10113
4b2eebe03f93 8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents: 9085
diff changeset
1035 CC"(Ljava/lang/reflect/Executable;Z)Z", (void*)&WB_TestSetForceInlineMethod},
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
1036 {CC"enqueueMethodForCompilation",
12073
f99558245e5c 8022832: Add WB APIs for OSR compilation
iignatyev
parents: 10969
diff changeset
1037 CC"(Ljava/lang/reflect/Executable;II)Z", (void*)&WB_EnqueueMethodForCompilation},
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8850
diff changeset
1038 {CC"clearMethodState",
10113
4b2eebe03f93 8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents: 9085
diff changeset
1039 CC"(Ljava/lang/reflect/Executable;)V", (void*)&WB_ClearMethodState},
20249
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1040 {CC"setBooleanVMFlag", CC"(Ljava/lang/String;Z)V",(void*)&WB_SetBooleanVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1041 {CC"setIntxVMFlag", CC"(Ljava/lang/String;J)V",(void*)&WB_SetIntxVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1042 {CC"setUintxVMFlag", CC"(Ljava/lang/String;J)V",(void*)&WB_SetUintxVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1043 {CC"setUint64VMFlag", CC"(Ljava/lang/String;J)V",(void*)&WB_SetUint64VMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1044 {CC"setDoubleVMFlag", CC"(Ljava/lang/String;D)V",(void*)&WB_SetDoubleVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1045 {CC"setStringVMFlag", CC"(Ljava/lang/String;Ljava/lang/String;)V",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1046 (void*)&WB_SetStringVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1047 {CC"getBooleanVMFlag", CC"(Ljava/lang/String;)Ljava/lang/Boolean;",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1048 (void*)&WB_GetBooleanVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1049 {CC"getIntxVMFlag", CC"(Ljava/lang/String;)Ljava/lang/Long;",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1050 (void*)&WB_GetIntxVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1051 {CC"getUintxVMFlag", CC"(Ljava/lang/String;)Ljava/lang/Long;",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1052 (void*)&WB_GetUintxVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1053 {CC"getUint64VMFlag", CC"(Ljava/lang/String;)Ljava/lang/Long;",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1054 (void*)&WB_GetUint64VMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1055 {CC"getDoubleVMFlag", CC"(Ljava/lang/String;)Ljava/lang/Double;",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1056 (void*)&WB_GetDoubleVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1057 {CC"getStringVMFlag", CC"(Ljava/lang/String;)Ljava/lang/String;",
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1058 (void*)&WB_GetStringVMFlag},
0c48231c5c84 8038756: new WB API :: get/setVMFlag
iignatyev
parents: 17937
diff changeset
1059 {CC"isInStringTable", CC"(Ljava/lang/String;)Z", (void*)&WB_IsInStringTable },
8850
ede380e13960 8009763: Add WB test for String.intern()
mgerdin
parents: 8051
diff changeset
1060 {CC"fullGC", CC"()V", (void*)&WB_FullGC },
20357
4bfc44ba0d19 8055098: WB API should be extended to provide information about size and age of object.
tschatzl
parents: 20336
diff changeset
1061 {CC"youngGC", CC"()V", (void*)&WB_YoungGC },
10341
f54c85acc043 8013726: runtime/memory/ReserveMemory.java fails due to 'assert(bytes % os::vm_allocation_granularity() == 0) failed: reserve block size'
mikael
parents: 10241
diff changeset
1062 {CC"readReservedMemory", CC"()V", (void*)&WB_ReadReservedMemory },
20278
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
1063 {CC"allocateMetaspace",
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
1064 CC"(Ljava/lang/ClassLoader;J)J", (void*)&WB_AllocateMetaspace },
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
1065 {CC"freeMetaspace",
2c6ef90f030a 8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents: 20249
diff changeset
1066 CC"(Ljava/lang/ClassLoader;JJ)V", (void*)&WB_FreeMetaspace },
20540
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
1067 {CC"incMetaspaceCapacityUntilGC", CC"(J)J", (void*)&WB_IncMetaspaceCapacityUntilGC },
b509b7ff561c 8049599: MetaspaceGC::_capacity_until_GC can overflow
ehelin
parents: 20465
diff changeset
1068 {CC"metaspaceCapacityUntilGC", CC"()J", (void*)&WB_MetaspaceCapacityUntilGC },
17778
a48e16541e6b 8035857: Add tests to verify correctness of operations with BMI1 and LZCNT instructions
iignatyev
parents: 17704
diff changeset
1069 {CC"getCPUFeatures", CC"()Ljava/lang/String;", (void*)&WB_GetCPUFeatures },
17817
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
1070 {CC"getNMethod", CC"(Ljava/lang/reflect/Executable;Z)[Ljava/lang/Object;",
4abb719c5620 8038240: new WB API to get nmethod
iignatyev
parents: 17778
diff changeset
1071 (void*)&WB_GetNMethod },
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1072 };
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1073
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1074 #undef CC
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1075
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1076 JVM_ENTRY(void, JVM_RegisterWhiteBoxMethods(JNIEnv* env, jclass wbclass))
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1077 {
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1078 if (WhiteBoxAPI) {
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1079 // Make sure that wbclass is loaded by the null classloader
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1080 instanceKlassHandle ikh = instanceKlassHandle(JNIHandles::resolve(wbclass)->klass());
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1081 Handle loader(ikh->class_loader());
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1082 if (loader.is_null()) {
20451
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
1083 WhiteBox::register_methods(env, wbclass, thread, methods, sizeof(methods) / sizeof(methods[0]));
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
1084 WhiteBox::register_extended(env, wbclass, thread);
e2452c3ff7fb 8057752: WhiteBox extension support for testing
sjohanss
parents: 20360
diff changeset
1085 WhiteBox::set_used();
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1086 }
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1087 }
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1088 }
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents:
diff changeset
1089 JVM_END