Merge
authorlana
Tue, 12 Mar 2013 18:22:40 -0700
changeset 15922 86a368d3ac8c
parent 15896 e41d716405b2 (current diff)
parent 15921 92ae6d9a60bd (diff)
child 15923 f81715dd3f0b
Merge
hotspot/src/share/vm/interpreter/linkResolver.cpp
hotspot/src/share/vm/runtime/arguments.cpp
hotspot/src/share/vm/runtime/globals.hpp
--- a/hotspot/src/share/vm/interpreter/linkResolver.cpp	Wed Jul 05 18:43:54 2017 +0200
+++ b/hotspot/src/share/vm/interpreter/linkResolver.cpp	Tue Mar 12 18:22:40 2013 -0700
@@ -803,7 +803,7 @@
     if (!direct_calling_default_method &&
         check_access &&
         // a) check if ACC_SUPER flag is set for the current class
-        current_klass->is_super() &&
+        (current_klass->is_super() || !AllowNonVirtualCalls) &&
         // b) check if the method class is a superclass of the current class (superclass relation is not reflexive!)
         current_klass->is_subtype_of(method_klass()) &&
         current_klass() != method_klass() &&
--- a/hotspot/src/share/vm/runtime/globals.hpp	Wed Jul 05 18:43:54 2017 +0200
+++ b/hotspot/src/share/vm/runtime/globals.hpp	Tue Mar 12 18:22:40 2013 -0700
@@ -3644,7 +3644,10 @@
           "Enable internal testing APIs")                                   \
                                                                             \
   product(bool, PrintGCCause, true,                                         \
-          "Include GC cause in GC logging")
+          "Include GC cause in GC logging")                                 \
+                                                                            \
+  product(bool, AllowNonVirtualCalls, false,                                \
+          "Obey the ACC_SUPER flag and allow invokenonvirtual calls")
 
 /*
  *  Macros for factoring of globals