]> source.dussan.org Git - dcevm.git/commitdiff
Fixing Java 8 MethodHandle's
authorIvan Dubrov <idubrov@guidewire.com>
Wed, 30 Apr 2014 18:27:47 +0000 (11:27 -0700)
committerIvan Dubrov <idubrov@guidewire.com>
Wed, 30 Apr 2014 18:27:47 +0000 (11:27 -0700)
patches/light-jdk8u5-b13.patch

index e20f4cff29d202d12cd24e79c30243aad6c386fc..5491fd46df5797dbad558faf07a4de41fa577b0b 100644 (file)
@@ -1,6 +1,6 @@
 diff -r 8a6717910608 make/openjdk_distro
 --- a/make/openjdk_distro      Tue Mar 11 13:02:13 2014 -0700
-+++ b/make/openjdk_distro      Tue Apr 29 17:13:46 2014 -0700
++++ b/make/openjdk_distro      Wed Apr 30 11:27:18 2014 -0700
 @@ -27,6 +27,6 @@
  #
  
@@ -11,7 +11,7 @@ diff -r 8a6717910608 make/openjdk_distro
  PRODUCT_NAME=OpenJDK
 diff -r 8a6717910608 src/share/vm/ci/ciObjectFactory.cpp
 --- a/src/share/vm/ci/ciObjectFactory.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/ci/ciObjectFactory.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/ci/ciObjectFactory.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -750,3 +750,27 @@
               _unloaded_instances->length(),
               _unloaded_klasses->length());
@@ -42,7 +42,7 @@ diff -r 8a6717910608 src/share/vm/ci/ciObjectFactory.cpp
 +
 diff -r 8a6717910608 src/share/vm/ci/ciObjectFactory.hpp
 --- a/src/share/vm/ci/ciObjectFactory.hpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/ci/ciObjectFactory.hpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/ci/ciObjectFactory.hpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -90,6 +90,7 @@
  
    ciInstance* get_unloaded_instance(ciInstanceKlass* klass);
@@ -62,7 +62,7 @@ diff -r 8a6717910608 src/share/vm/ci/ciObjectFactory.hpp
  #endif // SHARE_VM_CI_CIOBJECTFACTORY_HPP
 diff -r 8a6717910608 src/share/vm/classfile/classFileParser.cpp
 --- a/src/share/vm/classfile/classFileParser.cpp       Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/classFileParser.cpp       Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/classFileParser.cpp       Wed Apr 30 11:27:18 2014 -0700
 @@ -759,6 +759,7 @@
  Array<Klass*>* ClassFileParser::parse_interfaces(int length,
                                                   Handle protection_domain,
@@ -236,7 +236,7 @@ diff -r 8a6717910608 src/share/vm/classfile/classFileParser.cpp
    }
 diff -r 8a6717910608 src/share/vm/classfile/classFileParser.hpp
 --- a/src/share/vm/classfile/classFileParser.hpp       Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/classFileParser.hpp       Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/classFileParser.hpp       Wed Apr 30 11:27:18 2014 -0700
 @@ -214,11 +214,12 @@
    Array<Klass*>* parse_interfaces(int length,
                                    Handle protection_domain,
@@ -284,7 +284,7 @@ diff -r 8a6717910608 src/share/vm/classfile/classFileParser.hpp
                                       TRAPS);
 diff -r 8a6717910608 src/share/vm/classfile/classLoader.cpp
 --- a/src/share/vm/classfile/classLoader.cpp   Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/classLoader.cpp   Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/classLoader.cpp   Wed Apr 30 11:27:18 2014 -0700
 @@ -926,6 +926,7 @@
      instanceKlassHandle result = parser.parseClassFile(h_name,
                                                         loader_data,
@@ -295,7 +295,7 @@ diff -r 8a6717910608 src/share/vm/classfile/classLoader.cpp
                                                         CHECK_(h));
 diff -r 8a6717910608 src/share/vm/classfile/dictionary.cpp
 --- a/src/share/vm/classfile/dictionary.cpp    Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/dictionary.cpp    Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/dictionary.cpp    Wed Apr 30 11:27:18 2014 -0700
 @@ -145,7 +145,7 @@
        InstanceKlass* ik = InstanceKlass::cast(e);
  
@@ -367,7 +367,7 @@ diff -r 8a6717910608 src/share/vm/classfile/dictionary.cpp
  
 diff -r 8a6717910608 src/share/vm/classfile/dictionary.hpp
 --- a/src/share/vm/classfile/dictionary.hpp    Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/dictionary.hpp    Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/dictionary.hpp    Wed Apr 30 11:27:18 2014 -0700
 @@ -78,6 +78,10 @@
  
    void add_klass(Symbol* class_name, ClassLoaderData* loader_data,KlassHandle obj);
@@ -393,7 +393,7 @@ diff -r 8a6717910608 src/share/vm/classfile/dictionary.hpp
    bool do_unloading();
 diff -r 8a6717910608 src/share/vm/classfile/javaClasses.cpp
 --- a/src/share/vm/classfile/javaClasses.cpp   Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/javaClasses.cpp   Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/javaClasses.cpp   Wed Apr 30 11:27:18 2014 -0700
 @@ -1629,6 +1629,8 @@
          skip_throwableInit_check = true;
        }
@@ -405,7 +405,7 @@ diff -r 8a6717910608 src/share/vm/classfile/javaClasses.cpp
      }
 diff -r 8a6717910608 src/share/vm/classfile/loaderConstraints.cpp
 --- a/src/share/vm/classfile/loaderConstraints.cpp     Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/loaderConstraints.cpp     Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/loaderConstraints.cpp     Wed Apr 30 11:27:18 2014 -0700
 @@ -446,7 +446,7 @@
          if (k != NULL) {
            // We found the class in the system dictionary, so we should
@@ -417,7 +417,7 @@ diff -r 8a6717910608 src/share/vm/classfile/loaderConstraints.cpp
            // has to be in the placeholders table.
 diff -r 8a6717910608 src/share/vm/classfile/systemDictionary.cpp
 --- a/src/share/vm/classfile/systemDictionary.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/systemDictionary.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/systemDictionary.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -174,6 +174,7 @@
      // can return a null klass
      klass = handle_resolution_exception(class_name, class_loader, protection_domain, throw_error, k_h, THREAD);
@@ -571,7 +571,7 @@ diff -r 8a6717910608 src/share/vm/classfile/systemDictionary.cpp
        } else {
 diff -r 8a6717910608 src/share/vm/classfile/systemDictionary.hpp
 --- a/src/share/vm/classfile/systemDictionary.hpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/systemDictionary.hpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/systemDictionary.hpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -269,7 +269,7 @@
    // Resolve from stream (called by jni_DefineClass and JVM_DefineClass)
    static Klass* resolve_from_stream(Symbol* class_name, Handle class_loader,
@@ -611,7 +611,7 @@ diff -r 8a6717910608 src/share/vm/classfile/systemDictionary.hpp
                                                  instanceKlassHandle k, TRAPS);
 diff -r 8a6717910608 src/share/vm/classfile/verifier.cpp
 --- a/src/share/vm/classfile/verifier.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/verifier.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/verifier.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -189,7 +189,7 @@
    Symbol* name = klass->name();
    Klass* refl_magic_klass = SystemDictionary::reflect_MagicAccessorImpl_klass();
@@ -641,7 +641,7 @@ diff -r 8a6717910608 src/share/vm/classfile/verifier.cpp
    for (int index = 0; index < num_methods; index++) {
 diff -r 8a6717910608 src/share/vm/classfile/verifier.hpp
 --- a/src/share/vm/classfile/verifier.hpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/classfile/verifier.hpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/classfile/verifier.hpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -331,6 +331,7 @@
  
    VerificationType object_type() const;
@@ -652,7 +652,7 @@ diff -r 8a6717910608 src/share/vm/classfile/verifier.hpp
    VerificationType    _this_type; // the verification type of the current class
 diff -r 8a6717910608 src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.cpp
 --- a/src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.cpp  Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.cpp  Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.cpp  Wed Apr 30 11:27:18 2014 -0700
 @@ -161,6 +161,12 @@
    }
  }
@@ -686,7 +686,7 @@ diff -r 8a6717910608 src/share/vm/gc_implementation/concurrentMarkSweep/compacti
  // fragmentation_metric = 1 - [sum of (fbs**2) / (sum of fbs)**2]
 diff -r 8a6717910608 src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.hpp
 --- a/src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.hpp  Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.hpp  Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/gc_implementation/concurrentMarkSweep/compactibleFreeListSpace.hpp  Wed Apr 30 11:27:18 2014 -0700
 @@ -150,6 +150,7 @@
  
    // Support for compacting cms
@@ -697,7 +697,7 @@ diff -r 8a6717910608 src/share/vm/gc_implementation/concurrentMarkSweep/compacti
    // Initialization helpers.
 diff -r 8a6717910608 src/share/vm/gc_implementation/shared/markSweep.cpp
 --- a/src/share/vm/gc_implementation/shared/markSweep.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/gc_implementation/shared/markSweep.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/gc_implementation/shared/markSweep.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -32,6 +32,8 @@
  #include "oops/objArrayKlass.inline.hpp"
  #include "oops/oop.inline.hpp"
@@ -810,7 +810,7 @@ diff -r 8a6717910608 src/share/vm/gc_implementation/shared/markSweep.cpp
 +}
 diff -r 8a6717910608 src/share/vm/gc_implementation/shared/markSweep.hpp
 --- a/src/share/vm/gc_implementation/shared/markSweep.hpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/gc_implementation/shared/markSweep.hpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/gc_implementation/shared/markSweep.hpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -107,8 +107,12 @@
    friend class AdjustPointerClosure;
    friend class KeepAliveClosure;
@@ -836,7 +836,7 @@ diff -r 8a6717910608 src/share/vm/gc_implementation/shared/markSweep.hpp
    static void follow_klass(Klass* klass);
 diff -r 8a6717910608 src/share/vm/interpreter/linkResolver.cpp
 --- a/src/share/vm/interpreter/linkResolver.cpp        Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/interpreter/linkResolver.cpp        Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/interpreter/linkResolver.cpp        Wed Apr 30 11:27:18 2014 -0700
 @@ -215,8 +215,8 @@
  // Klass resolution
  
@@ -866,19 +866,26 @@ diff -r 8a6717910608 src/share/vm/interpreter/linkResolver.cpp
      THROW(vmSymbols::java_lang_IllegalAccessError());
    }
  
-@@ -1199,6 +1199,9 @@
+@@ -1199,6 +1199,16 @@
        // recv_klass might be an arrayKlassOop but all vtables start at
        // the same place. The cast is to avoid virtual call and assertion.
        InstanceKlass* inst = (InstanceKlass*)recv_klass();
 +
 +      // (DCEVM) Check that the receiver is a subtype of the holder of the resolved method.
++      if (!inst->is_subtype_of(resolved_method->method_holder())) {
++        inst->print();
++        tty->print_cr("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
++        resolved_method->method_holder()->print();
++        tty->print_cr("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
++        resolved_method->print();
++      }
 +      assert(inst->is_subtype_of(resolved_method->method_holder()), "receiver and resolved method holder are inconsistent");
        selected_method = methodHandle(THREAD, inst->method_at_vtable(vtable_index));
      }
    }
 diff -r 8a6717910608 src/share/vm/memory/genMarkSweep.cpp
 --- a/src/share/vm/memory/genMarkSweep.cpp     Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/memory/genMarkSweep.cpp     Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/memory/genMarkSweep.cpp     Wed Apr 30 11:27:18 2014 -0700
 @@ -334,11 +334,16 @@
    // in the same order in phase2, phase3 and phase4. We don't quite do that
    // here (perm_gen first rather than last), so we tell the validate code
@@ -898,7 +905,7 @@ diff -r 8a6717910608 src/share/vm/memory/genMarkSweep.cpp
  }
 diff -r 8a6717910608 src/share/vm/memory/space.cpp
 --- a/src/share/vm/memory/space.cpp    Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/memory/space.cpp    Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/memory/space.cpp    Wed Apr 30 11:27:18 2014 -0700
 @@ -379,9 +379,8 @@
    _compaction_top = bottom();
  }
@@ -1135,7 +1142,7 @@ diff -r 8a6717910608 src/share/vm/memory/space.cpp
  void Space::print_short() const { print_short_on(tty); }
 diff -r 8a6717910608 src/share/vm/memory/space.hpp
 --- a/src/share/vm/memory/space.hpp    Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/memory/space.hpp    Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/memory/space.hpp    Wed Apr 30 11:27:18 2014 -0700
 @@ -450,6 +450,9 @@
    // indicates when the next such action should be taken.
    virtual void prepare_for_compaction(CompactPoint* cp);
@@ -1277,7 +1284,7 @@ diff -r 8a6717910608 src/share/vm/memory/space.hpp
        assert(oop(compaction_top)->klass() != NULL, "should have a class");      \
 diff -r 8a6717910608 src/share/vm/memory/universe.cpp
 --- a/src/share/vm/memory/universe.cpp Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/memory/universe.cpp Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/memory/universe.cpp Wed Apr 30 11:27:18 2014 -0700
 @@ -78,6 +78,8 @@
  #include "gc_implementation/parallelScavenge/parallelScavengeHeap.hpp"
  #endif // INCLUDE_ALL_GCS
@@ -1332,7 +1339,7 @@ diff -r 8a6717910608 src/share/vm/memory/universe.cpp
    f->do_oop((oop*) &_int_mirror);
 diff -r 8a6717910608 src/share/vm/memory/universe.hpp
 --- a/src/share/vm/memory/universe.hpp Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/memory/universe.hpp Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/memory/universe.hpp Wed Apr 30 11:27:18 2014 -0700
 @@ -248,7 +248,13 @@
  
    static void compute_verify_oop_data();
@@ -1357,7 +1364,7 @@ diff -r 8a6717910608 src/share/vm/memory/universe.hpp
    // as static fields of "Universe".
 diff -r 8a6717910608 src/share/vm/oops/cpCache.cpp
 --- a/src/share/vm/oops/cpCache.cpp    Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/cpCache.cpp    Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/cpCache.cpp    Wed Apr 30 11:27:18 2014 -0700
 @@ -336,7 +336,8 @@
    if (has_appendix) {
      const int appendix_index = f2_as_index() + _indy_resolved_references_appendix_offset;
@@ -1378,7 +1385,7 @@ diff -r 8a6717910608 src/share/vm/oops/cpCache.cpp
      resolved_references->obj_at_put(method_type_index, method_type());
    }
  
-@@ -532,6 +534,20 @@
+@@ -532,6 +534,26 @@
    // the method is in the interesting class so the entry is interesting
    return true;
  }
@@ -1387,6 +1394,12 @@ diff -r 8a6717910608 src/share/vm/oops/cpCache.cpp
 +// Clear cached entry, let it be re-resolved
 +void ConstantPoolCacheEntry::clear_entry() {
 +  // Clear entry during class redefinition. Note that we still keep flags.
++  if (has_appendix()) {
++    // (DCEVM): Now this gets really ugly. If this entry is used by invokehandle, we cannot
++    // clear it just like that (data is used by _invokehandle bytecode which wouldn't re-resolve anything).
++    // FIXME: (DCEVM) need to figure out if we need to rewrite it somehow or it should be fine...
++    return;
++  }
 +  _indices = constant_pool_index();
 +  _f1 = NULL;
 +  _f2 = 0;
@@ -1399,7 +1412,7 @@ diff -r 8a6717910608 src/share/vm/oops/cpCache.cpp
  #endif // INCLUDE_JVMTI
  
  void ConstantPoolCacheEntry::print(outputStream* st, int index) const {
-@@ -660,6 +676,14 @@
+@@ -660,6 +682,14 @@
      }
    }
  }
@@ -1416,7 +1429,7 @@ diff -r 8a6717910608 src/share/vm/oops/cpCache.cpp
  
 diff -r 8a6717910608 src/share/vm/oops/cpCache.hpp
 --- a/src/share/vm/oops/cpCache.hpp    Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/cpCache.hpp    Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/cpCache.hpp    Wed Apr 30 11:27:18 2014 -0700
 @@ -373,6 +373,10 @@
           bool * trace_name_printed);
    bool check_no_old_or_obsolete_entries();
@@ -1441,7 +1454,7 @@ diff -r 8a6717910608 src/share/vm/oops/cpCache.hpp
    // Deallocate - no fields to deallocate
 diff -r 8a6717910608 src/share/vm/oops/instanceKlass.cpp
 --- a/src/share/vm/oops/instanceKlass.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/instanceKlass.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/instanceKlass.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -718,7 +718,8 @@
        }
  #endif
@@ -1587,7 +1600,7 @@ diff -r 8a6717910608 src/share/vm/oops/instanceKlass.cpp
  
 diff -r 8a6717910608 src/share/vm/oops/instanceKlass.hpp
 --- a/src/share/vm/oops/instanceKlass.hpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/instanceKlass.hpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/instanceKlass.hpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -139,6 +139,7 @@
    friend class VMStructs;
    friend class ClassFileParser;
@@ -1634,7 +1647,7 @@ diff -r 8a6717910608 src/share/vm/oops/instanceKlass.hpp
    void array_klasses_do(void f(Klass* k, TRAPS), TRAPS);
 diff -r 8a6717910608 src/share/vm/oops/klass.cpp
 --- a/src/share/vm/oops/klass.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/klass.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/klass.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -170,6 +170,13 @@
    set_next_link(NULL);
    TRACE_INIT_ID(this);
@@ -1676,7 +1689,7 @@ diff -r 8a6717910608 src/share/vm/oops/klass.cpp
  
 diff -r 8a6717910608 src/share/vm/oops/klass.hpp
 --- a/src/share/vm/oops/klass.hpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/klass.hpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/klass.hpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -149,6 +149,10 @@
    oop       _java_mirror;
    // Superclass
@@ -1786,7 +1799,7 @@ diff -r 8a6717910608 src/share/vm/oops/klass.hpp
    static ByteSize super_offset()                 { return in_ByteSize(offset_of(Klass, _super)); }
 diff -r 8a6717910608 src/share/vm/oops/klassVtable.cpp
 --- a/src/share/vm/oops/klassVtable.cpp        Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/klassVtable.cpp        Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/klassVtable.cpp        Wed Apr 30 11:27:18 2014 -0700
 @@ -1409,6 +1409,8 @@
  
  void klassVtable::verify_against(outputStream* st, klassVtable* vt, int index) {
@@ -1818,7 +1831,7 @@ diff -r 8a6717910608 src/share/vm/oops/klassVtable.cpp
  
 diff -r 8a6717910608 src/share/vm/oops/method.cpp
 --- a/src/share/vm/oops/method.cpp     Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/method.cpp     Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/method.cpp     Wed Apr 30 11:27:18 2014 -0700
 @@ -1185,6 +1185,8 @@
  
    // Reset correct method/const method, method size, and parameter info
@@ -1841,7 +1854,7 @@ diff -r 8a6717910608 src/share/vm/oops/method.cpp
    if (!SafepointSynchronize::is_at_safepoint()) {
 diff -r 8a6717910608 src/share/vm/oops/method.hpp
 --- a/src/share/vm/oops/method.hpp     Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/oops/method.hpp     Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/oops/method.hpp     Wed Apr 30 11:27:18 2014 -0700
 @@ -105,6 +105,10 @@
    AccessFlags       _access_flags;               // Access flags
    int               _vtable_index;               // vtable index of this method (see VtableIndexFlag)
@@ -1879,7 +1892,7 @@ diff -r 8a6717910608 src/share/vm/oops/method.hpp
    int signature_index() const                    { return constMethod()->signature_index();         }
 diff -r 8a6717910608 src/share/vm/prims/jni.cpp
 --- a/src/share/vm/prims/jni.cpp       Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/prims/jni.cpp       Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/prims/jni.cpp       Wed Apr 30 11:27:18 2014 -0700
 @@ -406,6 +406,7 @@
    }
    Klass* k = SystemDictionary::resolve_from_stream(class_name, class_loader,
@@ -1890,7 +1903,7 @@ diff -r 8a6717910608 src/share/vm/prims/jni.cpp
    if (TraceClassResolution && k != NULL) {
 diff -r 8a6717910608 src/share/vm/prims/jvm.cpp
 --- a/src/share/vm/prims/jvm.cpp       Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/prims/jvm.cpp       Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/prims/jvm.cpp       Wed Apr 30 11:27:18 2014 -0700
 @@ -904,6 +904,7 @@
    Klass* k = SystemDictionary::resolve_from_stream(class_name, class_loader,
                                                       protection_domain, &st,
@@ -1901,7 +1914,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvm.cpp
    if (TraceClassResolution && k != NULL) {
 diff -r 8a6717910608 src/share/vm/prims/jvmtiEnv.cpp
 --- a/src/share/vm/prims/jvmtiEnv.cpp  Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/prims/jvmtiEnv.cpp  Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/prims/jvmtiEnv.cpp  Wed Apr 30 11:27:18 2014 -0700
 @@ -42,6 +42,7 @@
  #include "prims/jvmtiManageCapabilities.hpp"
  #include "prims/jvmtiRawMonitor.hpp"
@@ -1949,7 +1962,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiEnv.cpp
    return (op.check_error());
 diff -r 8a6717910608 src/share/vm/prims/jvmtiExport.hpp
 --- a/src/share/vm/prims/jvmtiExport.hpp       Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/prims/jvmtiExport.hpp       Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/prims/jvmtiExport.hpp       Wed Apr 30 11:27:18 2014 -0700
 @@ -188,6 +188,7 @@
    // systems as needed to relax invariant checks.
    static bool _has_redefined_a_class;
@@ -1960,7 +1973,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiExport.hpp
    }
 diff -r 8a6717910608 src/share/vm/prims/jvmtiImpl.cpp
 --- a/src/share/vm/prims/jvmtiImpl.cpp Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/prims/jvmtiImpl.cpp Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/prims/jvmtiImpl.cpp Wed Apr 30 11:27:18 2014 -0700
 @@ -289,6 +289,11 @@
    Symbol* m_name = _method->name();
    Symbol* m_signature = _method->signature();
@@ -1975,8 +1988,8 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiImpl.cpp
    for (PreviousVersionNode * pv_node = pvw.next_previous_version();
 diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.cpp
 --- /dev/null  Thu Jan 01 00:00:00 1970 +0000
-+++ b/src/share/vm/prims/jvmtiRedefineClasses2.cpp     Tue Apr 29 17:13:46 2014 -0700
-@@ -0,0 +1,2015 @@
++++ b/src/share/vm/prims/jvmtiRedefineClasses2.cpp     Wed Apr 30 11:27:18 2014 -0700
+@@ -0,0 +1,2034 @@
 +/*
 + * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
 + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@@ -3604,6 +3617,25 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.cpp
 +  transfer_old_native_function_registrations(the_old_class);
 +
 +
++  // JSR-292 support
++
++  // Transfer method handles
++  MemberNameTable* mnt = the_old_class->member_names();
++  the_new_class->set_member_names(mnt);
++  the_old_class->set_member_names(NULL);
++  if (mnt != NULL) {
++    for (int i = 0; i < mnt->length(); i++) {
++      oop mem_name = mnt->get_member_name(i);
++      if (mem_name != NULL) {
++        Method* method = (Method*) java_lang_invoke_MemberName::vmtarget(mem_name);
++
++        // Replace the method with matching one from the new class
++        Method* new_method = the_new_class->find_method(method->name(), method->signature());
++        java_lang_invoke_MemberName::set_vmtarget(mem_name, new_method);
++      }
++    }
++  }
++
 +
 +#ifdef ASSERT
 +
@@ -3620,7 +3652,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.cpp
 +
 +  for (int i=0; i<the_new_class->methods()->length(); i++) {
 +    assert((the_new_class->methods()->at(i))->method_holder() == the_new_class(), "method holder must match!");
-+    }
++  }
 +
 +  // FIXME:
 +  //_old_methods->verify();
@@ -3635,7 +3667,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.cpp
 +  // direct and indirect subclasses of the_class
 +  increment_class_counter((InstanceKlass *)the_old_class(), THREAD);
 +
-+  }
++}
 +
 +
 +void VM_EnhancedRedefineClasses::check_methods_and_mark_as_obsolete(BitMap *emcp_methods, int * emcp_method_count_p) {
@@ -3994,7 +4026,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.cpp
 +}
 diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.hpp
 --- /dev/null  Thu Jan 01 00:00:00 1970 +0000
-+++ b/src/share/vm/prims/jvmtiRedefineClasses2.hpp     Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/prims/jvmtiRedefineClasses2.hpp     Wed Apr 30 11:27:18 2014 -0700
 @@ -0,0 +1,156 @@
 +/*
 + * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
@@ -4154,7 +4186,7 @@ diff -r 8a6717910608 src/share/vm/prims/jvmtiRedefineClasses2.hpp
 +#endif // SHARE_VM_PRIMS_JVMTIENHANCEDREDEFINECLASSES_HPP
 diff -r 8a6717910608 src/share/vm/runtime/arguments.cpp
 --- a/src/share/vm/runtime/arguments.cpp       Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/runtime/arguments.cpp       Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/runtime/arguments.cpp       Wed Apr 30 11:27:18 2014 -0700
 @@ -59,8 +59,8 @@
  #include "gc_implementation/parallelScavenge/parallelScavengeHeap.hpp"
  #endif // INCLUDE_ALL_GCS
@@ -4197,7 +4229,7 @@ diff -r 8a6717910608 src/share/vm/runtime/arguments.cpp
                  "Conflicting collector combinations in option list; "
 diff -r 8a6717910608 src/share/vm/runtime/globals.hpp
 --- a/src/share/vm/runtime/globals.hpp Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/runtime/globals.hpp Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/runtime/globals.hpp Wed Apr 30 11:27:18 2014 -0700
 @@ -1273,6 +1273,9 @@
    product(intx, TraceRedefineClasses, 0,                                    \
            "Trace level for JVMTI RedefineClasses")                          \
@@ -4210,7 +4242,7 @@ diff -r 8a6717910608 src/share/vm/runtime/globals.hpp
                                                                              \
 diff -r 8a6717910608 src/share/vm/runtime/reflection.cpp
 --- a/src/share/vm/runtime/reflection.cpp      Tue Mar 11 13:02:13 2014 -0700
-+++ b/src/share/vm/runtime/reflection.cpp      Tue Apr 29 17:13:46 2014 -0700
++++ b/src/share/vm/runtime/reflection.cpp      Wed Apr 30 11:27:18 2014 -0700
 @@ -519,6 +519,12 @@
                                       AccessFlags access,
                                       bool classloader_only,