summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-03-11 22:09:43 +0000
committerChris Lattner <sabre@nondot.org>2002-03-11 22:09:43 +0000
commit7d1c5b31b6ea46c985dd422870f0fea3811a259b (patch)
treeb64ed042d78b5b231bd3e438d083a31d406e1929
parent26ec8810625ccecbd1ae8574341dc3a0a5122859 (diff)
downloadbcm5719-llvm-7d1c5b31b6ea46c985dd422870f0fea3811a259b.tar.gz
bcm5719-llvm-7d1c5b31b6ea46c985dd422870f0fea3811a259b.zip
New testcase for failure
llvm-svn: 1857
-rw-r--r--llvm/test/Regression/Other/2002-03-11-ConstPropCrash.ll25
1 files changed, 25 insertions, 0 deletions
diff --git a/llvm/test/Regression/Other/2002-03-11-ConstPropCrash.ll b/llvm/test/Regression/Other/2002-03-11-ConstPropCrash.ll
new file mode 100644
index 00000000000..6eca6393787
--- /dev/null
+++ b/llvm/test/Regression/Other/2002-03-11-ConstPropCrash.ll
@@ -0,0 +1,25 @@
+; When constant propogating terminator instructions, the basic block iterator
+; was not updated to refer to the final position of the new terminator. This
+; can be bad, f.e. because constproping a terminator can lead to the
+; destruction of PHI nodes, which invalidates the iterator!
+;
+; Fixed by adding new arguments to ConstantFoldTerminator
+;
+; RUN: as < %s | opt -constprop
+
+implementation
+
+void "build_tree"(int %ml)
+begin
+ br label %bb2
+
+bb2:
+ %reg137 = phi int [ %reg140, %bb2 ], [ 12, %0 ] ; <int> [#uses=2]
+ %reg138 = phi uint [ %reg139, %bb2 ], [ 0, %0 ] ; <uint> [#uses=3]
+ %reg139 = add uint %reg138, 1 ; <uint> [#uses=1]
+ %reg140 = add int %reg137, -1 ; <int> [#uses=1]
+ br bool false, label %bb2, label %bb3
+
+bb3:
+ ret void
+end
OpenPOWER on IntegriCloud