# HG changeset patch # User asaha # Date 1481936226 28800 # Node ID 351bf1d4ff9a41137f91e2ec97ec59ed29a38d8b # Parent e4f6e58f397435674f5ec6b223e2ee35fc2a7da6# Parent 660d3da877c048093b235c0b605af8023cf14b8a Merge diff -r e4f6e58f3974 -r 351bf1d4ff9a .hgtags --- a/.hgtags Mon Dec 12 12:52:22 2016 -0800 +++ b/.hgtags Fri Dec 16 16:57:06 2016 -0800 @@ -931,6 +931,8 @@ b28d012a24cab8f4ceeee0c9d3252969757423ed jdk8u112-b15 e134dc1879b72124e478be01680b0646a2fbf585 jdk8u112-b16 87440ed4e1de7753a436f957d35555d8b4e26f1d jdk8u112-b31 +ba25f5833a128b8062e597f794efda26b30f095d jdk8u112-b32 +919ffdca10c2721ee0f6f233e704709174556510 jdk8u112-b33 3b0e5f01891f5ebbf67797b1aae786196f1bb4f6 jdk8u121-b00 251a2493b1857f2ff4f11eab2dfd8b2fe8ed441b jdk8u121-b01 70c4a50f576a01ec975d0a02b3642ee33db39ed8 jdk8u121-b02 diff -r e4f6e58f3974 -r 351bf1d4ff9a src/share/vm/classfile/systemDictionary.cpp --- a/src/share/vm/classfile/systemDictionary.cpp Mon Dec 12 12:52:22 2016 -0800 +++ b/src/share/vm/classfile/systemDictionary.cpp Fri Dec 16 16:57:06 2016 -0800 @@ -1084,15 +1084,18 @@ THREAD); const char* pkg = "java/"; + size_t pkglen = strlen(pkg); if (!HAS_PENDING_EXCEPTION && !class_loader.is_null() && parsed_name != NULL && - !strncmp((const char*)parsed_name->bytes(), pkg, strlen(pkg))) { + parsed_name->utf8_length() >= (int)pkglen && + !strncmp((const char*)parsed_name->bytes(), pkg, pkglen)) { // It is illegal to define classes in the "java." package from // JVM_DefineClass or jni_DefineClass unless you're the bootclassloader ResourceMark rm(THREAD); char* name = parsed_name->as_C_string(); char* index = strrchr(name, '/'); + assert(index != NULL, "must be"); *index = '\0'; // chop to just the package name while ((index = strchr(name, '/')) != NULL) { *index = '.'; // replace '/' with '.' in package name