From 20a3437a74ef88922766488e55773b86b52efd15 Mon Sep 17 00:00:00 2001 From: John Cuthbertson Date: Wed, 13 Apr 2011 17:56:43 -0700 Subject: [PATCH] 7035117: G1: nsk/stress/jni/jnistress002 fails with assertion failure Allow long type for offset in G1 code in compiler implementations of Unsafe.getObject Reviewed-by: never, iveresov --- .../src/cpu/sparc/vm/c1_CodeStubs_sparc.cpp | 2 +- hotspot/src/cpu/x86/vm/c1_CodeStubs_x86.cpp | 2 +- hotspot/src/share/vm/c1/c1_LIRGenerator.cpp | 27 +++++++++++++++---- hotspot/src/share/vm/opto/library_call.cpp | 2 +- 4 files changed, 25 insertions(+), 8 deletions(-) diff --git a/hotspot/src/cpu/sparc/vm/c1_CodeStubs_sparc.cpp b/hotspot/src/cpu/sparc/vm/c1_CodeStubs_sparc.cpp index 39186972dd3..8ea114f7c23 100644 --- a/hotspot/src/cpu/sparc/vm/c1_CodeStubs_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/c1_CodeStubs_sparc.cpp @@ -489,7 +489,7 @@ void G1UnsafeGetObjSATBBarrierStub::emit_code(LIR_Assembler* ce) { // Is marking active? assert(thread()->is_register(), "precondition"); - Register thread_reg = thread()->as_register(); + Register thread_reg = NOT_LP64(thread()->as_register()) LP64_ONLY(thread()->as_register_lo()); Address in_progress(thread_reg, in_bytes(JavaThread::satb_mark_queue_offset() + PtrQueue::byte_offset_of_active())); diff --git a/hotspot/src/cpu/x86/vm/c1_CodeStubs_x86.cpp b/hotspot/src/cpu/x86/vm/c1_CodeStubs_x86.cpp index 92482427692..a83f9311429 100644 --- a/hotspot/src/cpu/x86/vm/c1_CodeStubs_x86.cpp +++ b/hotspot/src/cpu/x86/vm/c1_CodeStubs_x86.cpp @@ -523,7 +523,7 @@ void G1UnsafeGetObjSATBBarrierStub::emit_code(LIR_Assembler* ce) { // Is marking active? assert(thread()->is_register(), "precondition"); - Register thread_reg = thread()->as_register(); + Register thread_reg = NOT_LP64(thread()->as_register()) LP64_ONLY(thread()->as_register_lo()); Address in_progress(thread_reg, in_bytes(JavaThread::satb_mark_queue_offset() + PtrQueue::byte_offset_of_active())); diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp index ee9f1abf78e..5e7dd27bdf0 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp @@ -2062,9 +2062,12 @@ void LIRGenerator::do_UnsafeGetObject(UnsafeGetObject* x) { bool gen_source_check = true; // Assume the code stub has to check the src object for null. if (off.is_constant()) { - jint off_con = off.get_jint_constant(); + jlong off_con = (off.type()->is_int() ? + (jlong) off.get_jint_constant() : + off.get_jlong_constant()); - if (off_con != java_lang_ref_Reference::referent_offset) { + + if (off_con != (jlong) java_lang_ref_Reference::referent_offset) { // The constant offset is something other than referent_offset. // We can skip generating/checking the remaining guards and // skip generation of the code stub. @@ -2112,15 +2115,29 @@ void LIRGenerator::do_UnsafeGetObject(UnsafeGetObject* x) { // the offset check. if (gen_offset_check) { // if (offset == referent_offset) -> slow code stub - __ cmp(lir_cond_equal, off.result(), - LIR_OprFact::intConst(java_lang_ref_Reference::referent_offset)); + // If offset is an int then we can do the comparison with the + // referent_offset constant; otherwise we need to move + // referent_offset into a temporary register and generate + // a reg-reg compare. + + LIR_Opr referent_off; + + if (off.type()->is_int()) { + referent_off = LIR_OprFact::intConst(java_lang_ref_Reference::referent_offset); + } else { + assert(off.type()->is_long(), "what else?"); + referent_off = new_register(T_LONG); + __ move(LIR_OprFact::longConst(java_lang_ref_Reference::referent_offset), referent_off); + } + + __ cmp(lir_cond_equal, off.result(), referent_off); // Optionally generate "src == null" check. stub = new G1UnsafeGetObjSATBBarrierStub(reg, src.result(), src_klass, thread, gen_source_check); - __ branch(lir_cond_equal, T_INT, stub); + __ branch(lir_cond_equal, as_BasicType(off.type()), stub); } else { if (gen_source_check) { // offset is a const and equals referent offset diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 6dd7fa02a1d..e7a8dffeda5 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -2169,7 +2169,7 @@ void LibraryCallKit::insert_g1_pre_barrier(Node* base_oop, Node* offset, Node* p const int reference_type_offset = instanceKlass::reference_type_offset_in_bytes() + sizeof(oopDesc); - Node* referent_off = __ ConI(java_lang_ref_Reference::referent_offset); + Node* referent_off = __ ConX(java_lang_ref_Reference::referent_offset); __ if_then(offset, BoolTest::eq, referent_off, unlikely); { __ if_then(base_oop, BoolTest::ne, null(), likely); {