--- old/src/share/vm/opto/compile.cpp Tue Oct 16 18:46:43 2012 +++ new/src/share/vm/opto/compile.cpp Tue Oct 16 18:46:43 2012 @@ -3047,9 +3047,9 @@ case T_LONG: case T_DOUBLE: return (_v._value.j == other._v._value.j); case T_OBJECT: - case T_METADATA: return (_v._metadata == other._v._metadata); case T_ADDRESS: return (_v._value.l == other._v._value.l); case T_VOID: return (_v._value.l == other._v._value.l); // jump-table entries + case T_METADATA: return (_v._metadata == other._v._metadata); default: ShouldNotReachHere(); } return false; --- old/src/share/vm/opto/compile.hpp Tue Oct 16 18:46:44 2012 +++ new/src/share/vm/opto/compile.hpp Tue Oct 16 18:46:44 2012 @@ -149,7 +149,7 @@ private: BasicType _type; union { - jvalue _value; + jvalue _value; Metadata* _metadata; } _v; int _offset; // offset of this constant (in bytes) relative to the constant table base. --- old/src/share/vm/opto/library_call.cpp Tue Oct 16 18:46:45 2012 +++ new/src/share/vm/opto/library_call.cpp Tue Oct 16 18:46:44 2012 @@ -3830,7 +3830,7 @@ vtable_index*vtableEntry::size()) * wordSize + vtableEntry::method_offset_in_bytes(); Node* entry_addr = basic_plus_adr(obj_klass, entry_offset); - Node* target_call = make_load(NULL, entry_addr, TypeInstPtr::NOTNULL, T_OBJECT); + Node* target_call = make_load(NULL, entry_addr, TypePtr::NOTNULL, T_ADDRESS); // Compare the target method with the expected method (e.g., Object.hashCode). const TypePtr* native_call_addr = TypeMetadataPtr::make(method);