From 6d025e45529cc0398b26e38c9586c7f58061e554 Mon Sep 17 00:00:00 2001 From: Victor Ding Date: Tue, 25 Sep 2018 22:43:57 -0400 Subject: [PATCH] Fix for missing NULLCHK in Unsafe atomics NULLCHK on receiver is missing when transforming Unsafe.getAndAdd/Set. Fixing it. Signed-off-by: Victor Ding --- .../compiler/optimizer/J9RecognizedCallTransformer.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/runtime/compiler/optimizer/J9RecognizedCallTransformer.cpp b/runtime/compiler/optimizer/J9RecognizedCallTransformer.cpp index 4b05645ca03..c85f9176e55 100644 --- a/runtime/compiler/optimizer/J9RecognizedCallTransformer.cpp +++ b/runtime/compiler/optimizer/J9RecognizedCallTransformer.cpp @@ -105,7 +105,15 @@ void J9::RecognizedCallTransformer::process_java_lang_StringUTF16_toBytes(TR::Tr void J9::RecognizedCallTransformer::processUnsafeAtomicCall(TR::TreeTop* treetop, TR::Node* node, TR::SymbolReferenceTable::CommonNonhelperSymbol helper) { node->setSymbolReference(comp()->getSymRefTab()->findOrCreateCodeGenInlinedHelper(helper)); + if (treetop->getNode()->getOpCodeValue() == TR::NULLCHK) + { + auto nullchk = comp()->getSymRefTab()->findOrCreateNullCheckSymbolRef(comp()->getMethodSymbol()); + treetop->insertBefore(TR::TreeTop::create(comp(), TR::Node::createWithSymRef(TR::NULLCHK, 1, 1, TR::Node::create(node, TR::PassThrough, 1, node->getChild(0)), nullchk))); + treetop->getNode()->setSymbolReference(NULL); + TR::Node::recreate(treetop->getNode(), TR::treetop); + } node->removeChild(0); + bool safeToSkipDiamond = !strncmp(comp()->getCurrentMethod()->classNameChars(), "java/util/concurrent/atomic/", strlen("java/util/concurrent/atomic/")); TR_Array params(trMemory(), node->getNumChildren()-2);