[lworld] RFR: 8276538: [lworld] [AArch64] LIR_Assembler::emit_profile_inline_type temporary register conflict
Frederic Parain
fparain at openjdk.java.net
Thu Nov 4 16:07:27 UTC 2021
On Thu, 4 Nov 2021 08:35:55 GMT, Nick Gasson <ngasson at openjdk.org> wrote:
> LIR_Assembler::as_Address() may use rscratch1 as a temporary register
> for the address offset if it's too large to fit in an immediate, but
> rscratch1 is also used at the same time to hold the updated MDO value.
> See the discussion on JDK-8276108.
I've tested this patch with the current patch proposed for JDK-8276108 and got several crashes due to SIGSEGV in ciObjectFactory::create_new_metadata(Metadata*), from both C1 and C2 code.
For instance, with compiler/valhalla/inlinetypes/TestArrays.java:
Current CompileTask:
C1: 8816 1128 b 3 compiler.valhalla.inlinetypes.TestArrays::verify (36 bytes)
Stack: [0x0000fffbf8380000,0x0000fffbf8580000], sp=0x0000fffbf857cb20, free space=2034k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V [libjvm.so+0x921f14] ciObjectFactory::create_new_metadata(Metadata*)+0x70
V [libjvm.so+0x922d08] ciObjectFactory::get_metadata(Metadata*)+0x1f8
V [libjvm.so+0x8f3d10] ciMethod::ensure_method_data(methodHandle const&)+0x180
V [libjvm.so+0x8fb8e0] ciMethod::ensure_method_data()+0x110
V [libjvm.so+0x73ff5c] GraphBuilder::try_inline_full(ciMethod*, bool, bool, Bytecodes::Code, Instruction*)+0x28c
V [libjvm.so+0x7410a8] GraphBuilder::try_inline(ciMethod*, bool, bool, Bytecodes::Code, Instruction*)+0x194
V [libjvm.so+0x741bfc] GraphBuilder::invoke(Bytecodes::Code)+0xa8c
V [libjvm.so+0x742850] GraphBuilder::iterate_bytecodes_for_block(int)+0x640
V [libjvm.so+0x744518] GraphBuilder::iterate_all_blocks(bool)+0xa8
V [libjvm.so+0x740518] GraphBuilder::try_inline_full(ciMethod*, bool, bool, Bytecodes::Code, Instruction*)+0x848
V [libjvm.so+0x7410a8] GraphBuilder::try_inline(ciMethod*, bool, bool, Bytecodes::Code, Instruction*)+0x194
V [libjvm.so+0x741bfc] GraphBuilder::invoke(Bytecodes::Code)+0xa8c
V [libjvm.so+0x742850] GraphBuilder::iterate_bytecodes_for_block(int)+0x640
V [libjvm.so+0x744518] GraphBuilder::iterate_all_blocks(bool)+0xa8
V [libjvm.so+0x740518] GraphBuilder::try_inline_full(ciMethod*, bool, bool, Bytecodes::Code, Instruction*)+0x848
V [libjvm.so+0x7410a8] GraphBuilder::try_inline(ciMethod*, bool, bool, Bytecodes::Code, Instruction*)+0x194
V [libjvm.so+0x741bfc] GraphBuilder::invoke(Bytecodes::Code)+0xa8c
V [libjvm.so+0x742850] GraphBuilder::iterate_bytecodes_for_block(int)+0x640
V [libjvm.so+0x744504] GraphBuilder::iterate_all_blocks(bool)+0x94
V [libjvm.so+0x7456b4] GraphBuilder::GraphBuilder(Compilation*, IRScope*)+0x504
V [libjvm.so+0x7550c0] IRScope::IRScope(Compilation*, IRScope*, int, ciMethod*, int, bool)+0x3c0
V [libjvm.so+0x7552d4] IR::IR(Compilation*, ciMethod*, int)+0xd0
V [libjvm.so+0x71adfc] Compilation::build_hir() [clone .part.0]+0x22c
V [libjvm.so+0x71f574] Compilation::compile_java_method()+0x1b0
V [libjvm.so+0x7203c8] Compilation::compile_method()+0x1d8
V [libjvm.so+0x720da4] Compilation::Compilation(AbstractCompiler*, ciEnv*, ciMethod*, int, BufferBlob*, bool, DirectiveSet*)+0x324
V [libjvm.so+0x722348] Compiler::compile_method(ciEnv*, ciMethod*, int, bool, DirectiveSet*)+0x158
V [libjvm.so+0xa2b798] CompileBroker::invoke_compiler_on_method(CompileTask*)+0x8b8
V [libjvm.so+0xa2c1fc] CompileBroker::compiler_thread_loop()+0x2dc
V [libjvm.so+0x1826384] JavaThread::thread_main_inner()+0x284
V [libjvm.so+0x182c928] Thread::call_run()+0xf8
V [libjvm.so+0x1533394] thread_native_entry(Thread*)+0x104
C [libpthread.so.0+0x7738] start_thread+0x198
or with compiler/valhalla/inlinetypes/TestLWorld.java:
Current CompileTask:
C2: 9975 1071 b 4 compiler.valhalla.inlinetypes.TestLWorld::test136 (30 bytes)
Stack: [0x0000fffd15000000,0x0000fffd15200000], sp=0x0000fffd151fc440, free space=2033k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
C 0x00400f61f940f260
V [libjvm.so+0x922d08] ciObjectFactory::get_metadata(Metadata*)+0x1f8
V [libjvm.so+0x8f3d10] ciMethod::ensure_method_data(methodHandle const&)+0x180
V [libjvm.so+0x8fb8e0] ciMethod::ensure_method_data()+0x110
V [libjvm.so+0xa1c1f4] Compile::Compile(ciEnv*, ciMethod*, int, bool, bool, bool, bool, bool, DirectiveSet*)+0x10d4
V [libjvm.so+0x83509c] C2Compiler::compile_method(ciEnv*, ciMethod*, int, bool, DirectiveSet*)+0x1a8
V [libjvm.so+0xa2b798] CompileBroker::invoke_compiler_on_method(CompileTask*)+0x8b8
V [libjvm.so+0xa2c1fc] CompileBroker::compiler_thread_loop()+0x2dc
V [libjvm.so+0x1826384] JavaThread::thread_main_inner()+0x284
V [libjvm.so+0x182c928] Thread::call_run()+0xf8
V [libjvm.so+0x1533394] thread_native_entry(Thread*)+0x104
C [libpthread.so.0+0x7738] start_thread+0x198
-------------
PR: https://git.openjdk.java.net/valhalla/pull/577
More information about the valhalla-dev
mailing list