Mercurial > hg > truffle
diff src/share/vm/ci/ciMemberName.cpp @ 6725:da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
Summary: Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
Contributed-by: jmasa <jon.masamitsu@oracle.com>, stefank <stefan.karlsson@oracle.com>, mgerdin <mikael.gerdin@oracle.com>, never <tom.rodriguez@oracle.com>
author | coleenp |
---|---|
date | Sat, 01 Sep 2012 13:25:18 -0400 |
parents | 1d7922586cf6 |
children |
line wrap: on
line diff
--- a/src/share/vm/ci/ciMemberName.cpp Fri Aug 31 16:39:35 2012 -0700 +++ b/src/share/vm/ci/ciMemberName.cpp Sat Sep 01 13:25:18 2012 -0400 @@ -34,6 +34,11 @@ // Return: MN.vmtarget ciMethod* ciMemberName::get_vmtarget() const { VM_ENTRY_MARK; - oop vmtarget_oop = java_lang_invoke_MemberName::vmtarget(get_oop()); - return CURRENT_ENV->get_object(vmtarget_oop)->as_method(); + // FIXME: Share code with ciMethodHandle::get_vmtarget + Metadata* vmtarget = java_lang_invoke_MemberName::vmtarget(get_oop()); + if (vmtarget->is_method()) + return CURRENT_ENV->get_method((Method*) vmtarget); + // FIXME: What if the vmtarget is a Klass? + assert(false, ""); + return NULL; }