forked from OSchip/llvm-project
[MemorySSA] Fix insertUse.
Actually call the renamePass on inserted Phis. Fixes PR42940. Subscribers: llvm-commits llvm-svn: 369997
This commit is contained in:
parent
e19f3ff4c8
commit
228ffac678
|
@ -255,6 +255,7 @@ void MemorySSAUpdater::insertUse(MemoryUse *MU, bool RenameUses) {
|
||||||
FirstDef = MD->getDefiningAccess();
|
FirstDef = MD->getDefiningAccess();
|
||||||
|
|
||||||
MSSA->renamePass(MU->getBlock(), FirstDef, Visited);
|
MSSA->renamePass(MU->getBlock(), FirstDef, Visited);
|
||||||
|
}
|
||||||
// We just inserted a phi into this block, so the incoming value will
|
// We just inserted a phi into this block, so the incoming value will
|
||||||
// become the phi anyway, so it does not matter what we pass.
|
// become the phi anyway, so it does not matter what we pass.
|
||||||
for (auto &MP : InsertedPHIs)
|
for (auto &MP : InsertedPHIs)
|
||||||
|
@ -262,7 +263,6 @@ void MemorySSAUpdater::insertUse(MemoryUse *MU, bool RenameUses) {
|
||||||
MSSA->renamePass(Phi->getBlock(), nullptr, Visited);
|
MSSA->renamePass(Phi->getBlock(), nullptr, Visited);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Set every incoming edge {BB, MP->getBlock()} of MemoryPhi MP to NewDef.
|
// Set every incoming edge {BB, MP->getBlock()} of MemoryPhi MP to NewDef.
|
||||||
static void setMemoryPhiValueForBlock(MemoryPhi *MP, const BasicBlock *BB,
|
static void setMemoryPhiValueForBlock(MemoryPhi *MP, const BasicBlock *BB,
|
||||||
|
|
|
@ -125,3 +125,65 @@ cleanup1270:
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@g_1504 = external dso_local local_unnamed_addr global i16****, align 8
|
||||||
|
|
||||||
|
define void @f5() {
|
||||||
|
bb:
|
||||||
|
tail call fastcc void @f21()
|
||||||
|
br label %bb12.outer
|
||||||
|
|
||||||
|
bb12.outer.loopexit: ; No predecessors!
|
||||||
|
br label %bb12.outer
|
||||||
|
|
||||||
|
bb12.outer: ; preds = %bb12.outer.loopexit, %bb
|
||||||
|
br i1 undef, label %bb12.outer.split.us, label %bb12.preheader
|
||||||
|
|
||||||
|
bb12.preheader: ; preds = %bb12.outer
|
||||||
|
br label %bb12
|
||||||
|
|
||||||
|
bb12.outer.split.us: ; preds = %bb12.outer
|
||||||
|
br label %bb16.us.us
|
||||||
|
|
||||||
|
bb16.us.us: ; preds = %bb16.us.us, %bb12.outer.split.us
|
||||||
|
br label %bb16.us.us
|
||||||
|
|
||||||
|
bb12: ; preds = %bb77.1, %bb12.preheader
|
||||||
|
br i1 undef, label %bb25.preheader, label %bb77
|
||||||
|
|
||||||
|
bb25.preheader: ; preds = %bb12.1, %bb12
|
||||||
|
br label %bb25
|
||||||
|
|
||||||
|
bb25: ; preds = %l0, %bb25.preheader
|
||||||
|
br i1 undef, label %bb62, label %bb71.thread
|
||||||
|
|
||||||
|
bb62: ; preds = %bb25
|
||||||
|
br i1 undef, label %bb92.loopexit, label %l0
|
||||||
|
|
||||||
|
l0: ; preds = %bb62
|
||||||
|
br label %bb25
|
||||||
|
|
||||||
|
bb71.thread: ; preds = %bb25
|
||||||
|
br label %bb92
|
||||||
|
|
||||||
|
bb77: ; preds = %bb12
|
||||||
|
%tmp78 = load i16****, i16***** @g_1504, align 8
|
||||||
|
%tmp79 = load volatile i16***, i16**** %tmp78, align 8
|
||||||
|
br i1 undef, label %bb91, label %bb12.1
|
||||||
|
|
||||||
|
bb91: ; preds = %bb77.1, %bb77
|
||||||
|
unreachable
|
||||||
|
|
||||||
|
bb92.loopexit: ; preds = %bb62
|
||||||
|
br label %bb92
|
||||||
|
|
||||||
|
bb92: ; preds = %bb92.loopexit, %bb71.thread
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb12.1: ; preds = %bb77
|
||||||
|
br i1 undef, label %bb25.preheader, label %bb77.1
|
||||||
|
|
||||||
|
bb77.1: ; preds = %bb12.1
|
||||||
|
br i1 undef, label %bb91, label %bb12
|
||||||
|
}
|
||||||
|
|
||||||
|
declare void @f21()
|
||||||
|
|
Loading…
Reference in New Issue