[9] RFR(S): Crash with assert: symbol conversion failure in java_lang_String::create_from_symbol()
Coleen Phillimore
coleen.phillimore at oracle.com
Fri Sep 9 20:55:08 UTC 2016
This change is fine because it matches the commented out assert in
create_from_str(). We should probably figure out what it would take to
check the characters coming in from JNI and decide whether we should do
this. If not, it doesn't make sense to have commented out asserts.
But this is okay for jdk9.
Thanks,
Coleen
On 9/9/16 8:42 AM, Tobias Hartmann wrote:
> Hi,
>
> please review the following patch:
> https://bugs.openjdk.java.net/browse/JDK-8164561
> http://cr.openjdk.java.net/~thartmann/8164561/webrev.00/
>
> The verification code in java_lang_String::create_from_symbol() that was added by Compact Strings fails because the input symbol does not contain valid UTF8. The problem is that a JCK JNI test passes an invalid UTF8 string as class name to the JNI method "FindClass". In fact, the string contains garbage from reading past array boundaries because of a bug in the test [1]. The JNI spec [2] states that 'name' should be "a fully-qualified class name (that is, a package name, delimited by “/”, followed by the class name). If the name begins with “[“ (the array signature character), it returns an array class. The string is encoded in modified UTF-8".
>
> I nevertheless think that we should not crash in the case of an invalid UTF8 string and therefore disabled the verification code with a comment. We did the same for java_lang_String::create_from_str() [3].
>
> Tested with failing JCK test and JPRT (running).
>
> Thanks,
> Tobias
>
> [1] https://bugs.openjdk.java.net/browse/JCK-7307244
> [2] https://docs.oracle.com/javase/8/docs/technotes/guides/jni/spec/functions.html#FindClass
> [3] http://hg.openjdk.java.net/jdk9/hs/hotspot/file/d060826d0911/src/share/vm/classfile/javaClasses.cpp#l274
More information about the hotspot-dev
mailing list