From 98b1d8c798595c58ff2c8da97820178800cee1f0 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Tue, 21 May 2019 15:46:09 +0200 Subject: [PATCH] 8173196: [REDO] C2 does not optimize redundant memory operations with G1 Reviewed-by: thartmann, kvn --- src/hotspot/share/gc/g1/c2/g1BarrierSetC2.cpp | 2 +- .../share/gc/shared/c2/cardTableBarrierSetC2.cpp | 2 +- src/hotspot/share/opto/graphKit.cpp | 12 ++++++++++++ src/hotspot/share/opto/graphKit.hpp | 1 + 4 files changed, 15 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/gc/g1/c2/g1BarrierSetC2.cpp b/src/hotspot/share/gc/g1/c2/g1BarrierSetC2.cpp index 096fb9771c8..162f04aa63f 100644 --- a/src/hotspot/share/gc/g1/c2/g1BarrierSetC2.cpp +++ b/src/hotspot/share/gc/g1/c2/g1BarrierSetC2.cpp @@ -472,7 +472,7 @@ void G1BarrierSetC2::post_barrier(GraphKit* kit, __ if_then(card_val, BoolTest::ne, young_card); { kit->sync_kit(ideal); - kit->insert_mem_bar(Op_MemBarVolatile, oop_store); + kit->insert_store_load_for_barrier(); __ sync_kit(kit); Node* card_val_reload = __ load(__ ctrl(), card_adr, TypeInt::INT, T_BYTE, Compile::AliasIdxRaw); diff --git a/src/hotspot/share/gc/shared/c2/cardTableBarrierSetC2.cpp b/src/hotspot/share/gc/shared/c2/cardTableBarrierSetC2.cpp index 90ba73ca054..fbf9f253cb6 100644 --- a/src/hotspot/share/gc/shared/c2/cardTableBarrierSetC2.cpp +++ b/src/hotspot/share/gc/shared/c2/cardTableBarrierSetC2.cpp @@ -105,7 +105,7 @@ void CardTableBarrierSetC2::post_barrier(GraphKit* kit, if (UseCondCardMark) { if (ct->scanned_concurrently()) { - kit->insert_mem_bar(Op_MemBarVolatile, oop_store); + kit->insert_store_load_for_barrier(); __ sync_kit(kit); } // The classic GC reference write barrier is typically implemented diff --git a/src/hotspot/share/opto/graphKit.cpp b/src/hotspot/share/opto/graphKit.cpp index 587f2477780..9d602a9b260 100644 --- a/src/hotspot/share/opto/graphKit.cpp +++ b/src/hotspot/share/opto/graphKit.cpp @@ -3306,6 +3306,18 @@ Node* GraphKit::insert_mem_bar_volatile(int opcode, int alias_idx, Node* precede return membar; } +void GraphKit::insert_store_load_for_barrier() { + Node* mem = reset_memory(); + MemBarNode* mb = MemBarNode::make(C, Op_MemBarVolatile, Compile::AliasIdxRaw); + mb->init_req(TypeFunc::Control, control()); + mb->init_req(TypeFunc::Memory, mem); + Node* membar = _gvn.transform(mb); + set_control(_gvn.transform(new ProjNode(membar, TypeFunc::Control))); + Node* newmem = _gvn.transform(new ProjNode(membar, TypeFunc::Memory)); + set_all_memory(mem); + set_memory(newmem, Compile::AliasIdxRaw); +} + //------------------------------shared_lock------------------------------------ // Emit locking code. FastLockNode* GraphKit::shared_lock(Node* obj) { diff --git a/src/hotspot/share/opto/graphKit.hpp b/src/hotspot/share/opto/graphKit.hpp index 2c6d3464eb1..660227d45d0 100644 --- a/src/hotspot/share/opto/graphKit.hpp +++ b/src/hotspot/share/opto/graphKit.hpp @@ -811,6 +811,7 @@ class GraphKit : public Phase { int next_monitor(); Node* insert_mem_bar(int opcode, Node* precedent = NULL); Node* insert_mem_bar_volatile(int opcode, int alias_idx, Node* precedent = NULL); + void insert_store_load_for_barrier(); // Optional 'precedent' is appended as an extra edge, to force ordering. FastLockNode* shared_lock(Node* obj); void shared_unlock(Node* box, Node* obj);