Don't crash on critical edge. Patch by Andre Tavares.
authorNick Lewycky <nicholas@mxc.ca>
Mon, 17 Aug 2009 17:00:57 +0000 (17:00 +0000)
committerNick Lewycky <nicholas@mxc.ca>
Mon, 17 Aug 2009 17:00:57 +0000 (17:00 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79252 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Utils/SSI.cpp
test/Transforms/SSI/2009-08-17-CritEdge.ll [new file with mode: 0644]

index 7736f087684e8cb35314268bb04aa97117177470..7bb9495f3cf9e1032aeaec39b325ee1e97d8c7ec 100644 (file)
@@ -95,7 +95,7 @@ void SSI::insertSigmaFunctions(SmallVectorImpl<Instruction *> &value) {
           // Next Basic Block
           BasicBlock *BB_next = TI->getSuccessor(j);
           if (BB_next != BB &&
-              BB_next->getUniquePredecessor() != NULL &&
+              BB_next->getSinglePredecessor() != NULL &&
               dominateAny(BB_next, value[i])) {
             PHINode *PN = PHINode::Create(
                 value[i]->getType(), SSI_SIG, BB_next->begin());
diff --git a/test/Transforms/SSI/2009-08-17-CritEdge.ll b/test/Transforms/SSI/2009-08-17-CritEdge.ll
new file mode 100644 (file)
index 0000000..e5d1183
--- /dev/null
@@ -0,0 +1,15 @@
+; RUN: llvm-as < %s | opt -abcd -disable-output
+
+define void @test(i32 %x) {
+entry:
+  br label %label1
+label1:
+  %A = phi i32 [ 0, %entry ], [ %A.1, %label2 ]
+  %B = icmp slt i32 %A, %x
+  br i1 %B, label %label2, label %label2
+label2:
+  %A.1 = add i32 %A, 1
+  br label %label1
+label3:  ; No predecessors!
+  ret void
+}