From 0f2f8f179e884766c1ad6fae16a373ef6cf61bc6 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Wed, 8 Feb 2012 09:52:24 +0100 Subject: [PATCH] 7119286: JSR292: SIGSEGV in JNIHandleBlock::release_block(JNIHandleBlock*, Thread*)+0x3c Unaligned stack in throw_NullPointerException_at_call_entry(). Reviewed-by: twisti, never, kvn --- hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp b/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp index a6fcc782094..4baaf0e313f 100644 --- a/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp @@ -2978,7 +2978,9 @@ class StubGenerator: public StubCodeGenerator { int frame_complete = __ pc() - start; // Set up last_Java_sp and last_Java_fp - __ set_last_Java_frame(rsp, rbp, NULL); + address the_pc = __ pc(); + __ set_last_Java_frame(rsp, rbp, the_pc); + __ andptr(rsp, -(StackAlignmentInBytes)); // Align stack // Call runtime if (arg1 != noreg) { @@ -2997,7 +2999,7 @@ class StubGenerator: public StubCodeGenerator { oop_maps->add_gc_map(__ pc() - start, map); - __ reset_last_Java_frame(true, false); + __ reset_last_Java_frame(true, true); __ leave(); // required for proper stackwalking of RuntimeStub frame