8173196: [REDO] C2 does not optimize redundant memory operations with G1
Reviewed-by: thartmann, kvn
This commit is contained in:
parent
d222b01dee
commit
98b1d8c798
@ -472,7 +472,7 @@ void G1BarrierSetC2::post_barrier(GraphKit* kit,
|
|||||||
|
|
||||||
__ if_then(card_val, BoolTest::ne, young_card); {
|
__ if_then(card_val, BoolTest::ne, young_card); {
|
||||||
kit->sync_kit(ideal);
|
kit->sync_kit(ideal);
|
||||||
kit->insert_mem_bar(Op_MemBarVolatile, oop_store);
|
kit->insert_store_load_for_barrier();
|
||||||
__ sync_kit(kit);
|
__ sync_kit(kit);
|
||||||
|
|
||||||
Node* card_val_reload = __ load(__ ctrl(), card_adr, TypeInt::INT, T_BYTE, Compile::AliasIdxRaw);
|
Node* card_val_reload = __ load(__ ctrl(), card_adr, TypeInt::INT, T_BYTE, Compile::AliasIdxRaw);
|
||||||
|
@ -105,7 +105,7 @@ void CardTableBarrierSetC2::post_barrier(GraphKit* kit,
|
|||||||
|
|
||||||
if (UseCondCardMark) {
|
if (UseCondCardMark) {
|
||||||
if (ct->scanned_concurrently()) {
|
if (ct->scanned_concurrently()) {
|
||||||
kit->insert_mem_bar(Op_MemBarVolatile, oop_store);
|
kit->insert_store_load_for_barrier();
|
||||||
__ sync_kit(kit);
|
__ sync_kit(kit);
|
||||||
}
|
}
|
||||||
// The classic GC reference write barrier is typically implemented
|
// The classic GC reference write barrier is typically implemented
|
||||||
|
@ -3306,6 +3306,18 @@ Node* GraphKit::insert_mem_bar_volatile(int opcode, int alias_idx, Node* precede
|
|||||||
return membar;
|
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------------------------------------
|
//------------------------------shared_lock------------------------------------
|
||||||
// Emit locking code.
|
// Emit locking code.
|
||||||
FastLockNode* GraphKit::shared_lock(Node* obj) {
|
FastLockNode* GraphKit::shared_lock(Node* obj) {
|
||||||
|
@ -811,6 +811,7 @@ class GraphKit : public Phase {
|
|||||||
int next_monitor();
|
int next_monitor();
|
||||||
Node* insert_mem_bar(int opcode, Node* precedent = NULL);
|
Node* insert_mem_bar(int opcode, Node* precedent = NULL);
|
||||||
Node* insert_mem_bar_volatile(int opcode, int alias_idx, 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.
|
// Optional 'precedent' is appended as an extra edge, to force ordering.
|
||||||
FastLockNode* shared_lock(Node* obj);
|
FastLockNode* shared_lock(Node* obj);
|
||||||
void shared_unlock(Node* box, Node* obj);
|
void shared_unlock(Node* box, Node* obj);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user