summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-02-16 06:35:19 +0000
committerChris Lattner <sabre@nondot.org>2004-02-16 06:35:19 +0000
commit58d4db3f275e61f658ec55a708a97a45de53e908 (patch)
tree5f5ba2cc6f899db47bb62472db507fa549b22bd0
parent4db2d22beabbbee03eb561987da05ae4308914ed (diff)
downloadbcm5719-llvm-58d4db3f275e61f658ec55a708a97a45de53e908.tar.gz
bcm5719-llvm-58d4db3f275e61f658ec55a708a97a45de53e908.zip
New testcase, details in the comments
llvm-svn: 11495
-rw-r--r--llvm/test/Regression/Transforms/SimplifyCFG/UncondBranchToReturn.ll32
1 files changed, 32 insertions, 0 deletions
diff --git a/llvm/test/Regression/Transforms/SimplifyCFG/UncondBranchToReturn.ll b/llvm/test/Regression/Transforms/SimplifyCFG/UncondBranchToReturn.ll
new file mode 100644
index 00000000000..6e943f35fb1
--- /dev/null
+++ b/llvm/test/Regression/Transforms/SimplifyCFG/UncondBranchToReturn.ll
@@ -0,0 +1,32 @@
+; The unify-function-exit-nodes pass often makes basic blocks that just contain
+; a PHI node and a return. Make sure the simplify cfg can straighten out this
+; important case. This is basically the most trivial form of tail-duplication.
+
+; RUN: llvm-as < %s | opt -simplifycfg | llvm-dis | not grep 'br label'
+
+int %test(bool %B, int %A, int %B) {
+ br bool %B, label %T, label %F
+T:
+ br label %ret
+F:
+ br label %ret
+ret:
+ %X = phi int [%A, %F], [%B, %T]
+ ret int %X
+}
+
+; Make sure it's willing to move unconditional branches to return instructions
+; as well, even if the return block is shared and the source blocks are
+; non-empty.
+int %test2(bool %B, int %A, int %B) {
+ br bool %B, label %T, label %F
+T:
+ call int %test(bool true, int 5, int 8)
+ br label %ret
+F:
+ call int %test(bool true, int 5, int 8)
+ br label %ret
+ret:
+ ret int %A
+}
+
OpenPOWER on IntegriCloud