8064701: Some CDS optimizations should be disabled if bootclasspath is modified by JVMTI
Added API to track bootclasspath modification Reviewed-by: jiangli, dholmes, minqi
This commit is contained in:
parent
ae592ef688
commit
ef64d5393d
@ -63,6 +63,9 @@ public:
|
|||||||
ClassPathEntry* new_entry) {
|
ClassPathEntry* new_entry) {
|
||||||
ClassLoader::add_to_list(new_entry);
|
ClassLoader::add_to_list(new_entry);
|
||||||
}
|
}
|
||||||
|
static void append_boot_classpath(ClassPathEntry* new_entry) {
|
||||||
|
ClassLoader::add_to_list(new_entry);
|
||||||
|
}
|
||||||
static void setup_search_paths() {}
|
static void setup_search_paths() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "precompiled.hpp"
|
#include "precompiled.hpp"
|
||||||
|
#include "classfile/classLoaderExt.hpp"
|
||||||
#include "classfile/systemDictionary.hpp"
|
#include "classfile/systemDictionary.hpp"
|
||||||
#include "classfile/vmSymbols.hpp"
|
#include "classfile/vmSymbols.hpp"
|
||||||
#include "interpreter/bytecodeStream.hpp"
|
#include "interpreter/bytecodeStream.hpp"
|
||||||
@ -472,7 +473,7 @@ JvmtiEnv::AddToBootstrapClassLoaderSearch(const char* segment) {
|
|||||||
if (TraceClassLoading) {
|
if (TraceClassLoading) {
|
||||||
tty->print_cr("[Opened %s]", zip_entry->name());
|
tty->print_cr("[Opened %s]", zip_entry->name());
|
||||||
}
|
}
|
||||||
ClassLoader::add_to_list(zip_entry);
|
ClassLoaderExt::append_boot_classpath(zip_entry);
|
||||||
return JVMTI_ERROR_NONE;
|
return JVMTI_ERROR_NONE;
|
||||||
} else {
|
} else {
|
||||||
return JVMTI_ERROR_WRONG_PHASE;
|
return JVMTI_ERROR_WRONG_PHASE;
|
||||||
|
@ -64,6 +64,7 @@
|
|||||||
#endif // INCLUDE_NMT
|
#endif // INCLUDE_NMT
|
||||||
|
|
||||||
#include "compiler/compileBroker.hpp"
|
#include "compiler/compileBroker.hpp"
|
||||||
|
#include "jvmtifiles/jvmtiEnv.hpp"
|
||||||
#include "runtime/compilationPolicy.hpp"
|
#include "runtime/compilationPolicy.hpp"
|
||||||
|
|
||||||
PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC
|
PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC
|
||||||
@ -113,6 +114,31 @@ WB_ENTRY(jboolean, WB_IsClassAlive(JNIEnv* env, jobject target, jstring name))
|
|||||||
return closure.found();
|
return closure.found();
|
||||||
WB_END
|
WB_END
|
||||||
|
|
||||||
|
WB_ENTRY(void, WB_AddToBootstrapClassLoaderSearch(JNIEnv* env, jobject o, jstring segment)) {
|
||||||
|
#if INCLUDE_JVMTI
|
||||||
|
ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
|
||||||
|
const char* seg = env->GetStringUTFChars(segment, NULL);
|
||||||
|
JvmtiEnv* jvmti_env = JvmtiEnv::create_a_jvmti(JVMTI_VERSION);
|
||||||
|
jvmtiError err = jvmti_env->AddToBootstrapClassLoaderSearch(seg);
|
||||||
|
assert(err == JVMTI_ERROR_NONE, "must not fail");
|
||||||
|
env->ReleaseStringUTFChars(segment, seg);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
WB_END
|
||||||
|
|
||||||
|
WB_ENTRY(void, WB_AddToSystemClassLoaderSearch(JNIEnv* env, jobject o, jstring segment)) {
|
||||||
|
#if INCLUDE_JVMTI
|
||||||
|
ThreadToNativeFromVM ttnfv(thread); // can't be in VM when we call JNI
|
||||||
|
const char* seg = env->GetStringUTFChars(segment, NULL);
|
||||||
|
JvmtiEnv* jvmti_env = JvmtiEnv::create_a_jvmti(JVMTI_VERSION);
|
||||||
|
jvmtiError err = jvmti_env->AddToSystemClassLoaderSearch(seg);
|
||||||
|
assert(err == JVMTI_ERROR_NONE, "must not fail");
|
||||||
|
env->ReleaseStringUTFChars(segment, seg);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
WB_END
|
||||||
|
|
||||||
|
|
||||||
WB_ENTRY(jlong, WB_GetCompressedOopsMaxHeapSize(JNIEnv* env, jobject o)) {
|
WB_ENTRY(jlong, WB_GetCompressedOopsMaxHeapSize(JNIEnv* env, jobject o)) {
|
||||||
return (jlong)Arguments::max_heap_for_compressed_oops();
|
return (jlong)Arguments::max_heap_for_compressed_oops();
|
||||||
}
|
}
|
||||||
@ -1102,6 +1128,10 @@ static JNINativeMethod methods[] = {
|
|||||||
CC"(Ljava/lang/String;[Lsun/hotspot/parser/DiagnosticCommand;)[Ljava/lang/Object;",
|
CC"(Ljava/lang/String;[Lsun/hotspot/parser/DiagnosticCommand;)[Ljava/lang/Object;",
|
||||||
(void*) &WB_ParseCommandLine
|
(void*) &WB_ParseCommandLine
|
||||||
},
|
},
|
||||||
|
{CC"addToBootstrapClassLoaderSearch", CC"(Ljava/lang/String;)V",
|
||||||
|
(void*)&WB_AddToBootstrapClassLoaderSearch},
|
||||||
|
{CC"addToSystemClassLoaderSearch", CC"(Ljava/lang/String;)V",
|
||||||
|
(void*)&WB_AddToSystemClassLoaderSearch},
|
||||||
{CC"getCompressedOopsMaxHeapSize", CC"()J",
|
{CC"getCompressedOopsMaxHeapSize", CC"()J",
|
||||||
(void*)&WB_GetCompressedOopsMaxHeapSize},
|
(void*)&WB_GetCompressedOopsMaxHeapSize},
|
||||||
{CC"printHeapSizes", CC"()V", (void*)&WB_PrintHeapSizes },
|
{CC"printHeapSizes", CC"()V", (void*)&WB_PrintHeapSizes },
|
||||||
|
@ -84,6 +84,10 @@ public class WhiteBox {
|
|||||||
}
|
}
|
||||||
private native boolean isClassAlive0(String name);
|
private native boolean isClassAlive0(String name);
|
||||||
|
|
||||||
|
// JVMTI
|
||||||
|
public native void addToBootstrapClassLoaderSearch(String segment);
|
||||||
|
public native void addToSystemClassLoaderSearch(String segment);
|
||||||
|
|
||||||
// G1
|
// G1
|
||||||
public native boolean g1InConcurrentMark();
|
public native boolean g1InConcurrentMark();
|
||||||
public native boolean g1IsHumongous(Object o);
|
public native boolean g1IsHumongous(Object o);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user