[llvm] r370548 - [MemorySSA] Rename all phi entries.
Alina Sbirlea via llvm-commits
llvm-commits at lists.llvm.org
Fri Aug 30 16:02:53 PDT 2019
Author: asbirlea
Date: Fri Aug 30 16:02:53 2019
New Revision: 370548
URL: http://llvm.org/viewvc/llvm-project?rev=370548&view=rev
Log:
[MemorySSA] Rename all phi entries.
When renaming Phis incoming values, there may be multiple edges incoming
from the same block (switch). Rename all.
Added:
llvm/trunk/test/Analysis/MemorySSA/renamephis.ll
Modified:
llvm/trunk/lib/Analysis/MemorySSA.cpp
Modified: llvm/trunk/lib/Analysis/MemorySSA.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/MemorySSA.cpp?rev=370548&r1=370547&r2=370548&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/MemorySSA.cpp (original)
+++ llvm/trunk/lib/Analysis/MemorySSA.cpp Fri Aug 30 16:02:53 2019
@@ -1088,9 +1088,14 @@ void MemorySSA::renameSuccessorPhis(Basi
AccessList *Accesses = It->second.get();
auto *Phi = cast<MemoryPhi>(&Accesses->front());
if (RenameAllUses) {
- int PhiIndex = Phi->getBasicBlockIndex(BB);
- assert(PhiIndex != -1 && "Incomplete phi during partial rename");
- Phi->setIncomingValue(PhiIndex, IncomingVal);
+ bool ReplacementDone = false;
+ for (unsigned I = 0, E = Phi->getNumIncomingValues(); I != E; ++I)
+ if (Phi->getIncomingBlock(I) == BB) {
+ Phi->setIncomingValue(I, IncomingVal);
+ ReplacementDone = true;
+ }
+ (void) ReplacementDone;
+ assert(ReplacementDone && "Incomplete phi during partial rename");
} else
Phi->addIncoming(IncomingVal, BB);
}
Added: llvm/trunk/test/Analysis/MemorySSA/renamephis.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Analysis/MemorySSA/renamephis.ll?rev=370548&view=auto
==============================================================================
--- llvm/trunk/test/Analysis/MemorySSA/renamephis.ll (added)
+++ llvm/trunk/test/Analysis/MemorySSA/renamephis.ll Fri Aug 30 16:02:53 2019
@@ -0,0 +1,51 @@
+; RUN: opt -licm -enable-mssa-loop-dependency -verify-memoryssa -S %s | FileCheck %s
+; REQUIRES: asserts
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+ at 0 = external global { { [86 x i8]*, i32, i32 }, { i16, i16, [20 x i8] }*, i8, i8 }
+
+declare void @g()
+
+; Function Attrs: argmemonly nounwind willreturn
+declare void @llvm.lifetime.end.p0i8(i64 immarg, i8* nocapture) #0
+
+; CHECK-LABEL: @f
+define void @f() align 2 {
+entry:
+ %P = alloca i32*, align 8
+ br label %cond.end.i.i.i.i
+
+cond.end.i.i.i.i: ; preds = %cont20, %entry
+ br i1 undef, label %cont20, label %if.end
+
+cont20: ; preds = %cond.end.i.i.i.i, %cond.end.i.i.i.i, %cond.end.i.i.i.i
+ store i32* undef, i32** %P, align 8
+ br label %cond.end.i.i.i.i
+
+if.end: ; preds = %cond.end.i.i.i.i
+ br i1 undef, label %cond.exit, label %handler.type_mismatch2.i
+
+handler.type_mismatch2.i: ; preds = %if.end
+ tail call void @g()
+ unreachable
+
+cond.exit: ; preds = %if.end
+ switch i8 undef, label %block.exit [
+ i8 81, label %sw.bb94
+ i8 12, label %cleanup
+ i8 74, label %cleanup
+ ]
+
+block.exit: ; preds = %cond.exit
+ unreachable
+
+sw.bb94: ; preds = %cond.exit
+ call void @llvm.lifetime.end.p0i8(i64 8, i8* nonnull undef)
+ br label %cleanup
+
+cleanup: ; preds = %sw.bb94, %cond.exit, %cond.exit
+ ret void
+}
+
+attributes #0 = { argmemonly nounwind willreturn }
More information about the llvm-commits
mailing list