From 1890d7a430e77540598dbaf024fce066179c0080 Mon Sep 17 00:00:00 2001 From: Harold Seigel Date: Tue, 22 Sep 2015 09:48:19 -0400 Subject: [PATCH] 8135208: VM permits illegal access_flags, versions 51-52 Check access flags for methods that are not class init methods. Reviewed-by: kamg, gtriantafill --- hotspot/src/share/vm/classfile/classFileParser.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/hotspot/src/share/vm/classfile/classFileParser.cpp b/hotspot/src/share/vm/classfile/classFileParser.cpp index 3b2f8999c8f..5f17e00415f 100644 --- a/hotspot/src/share/vm/classfile/classFileParser.cpp +++ b/hotspot/src/share/vm/classfile/classFileParser.cpp @@ -1989,6 +1989,10 @@ methodHandle ClassFileParser::parse_method(bool is_interface, flags = JVM_ACC_STATIC; } else if ((flags & JVM_ACC_STATIC) == JVM_ACC_STATIC) { flags &= JVM_ACC_STATIC | JVM_ACC_STRICT; + } else { + // As of major_version 51, a method named without ACC_STATIC is + // just another method. So, do a normal method modifer check. + verify_legal_method_modifiers(flags, is_interface, name, CHECK_(nullHandle)); } } else { verify_legal_method_modifiers(flags, is_interface, name, CHECK_(nullHandle));