aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-04-15 01:00:37 +0000
committerChris Lattner <sabre@nondot.org>2007-04-15 01:00:37 +0000
commit9838939b3a5118bd6f8cd74654126c28c61adec7 (patch)
treed5edb378017d6f84c1ef9afd7d51b3225d19ba0c
parent1c44c4db2170f9cea4a06d317e0684bfc4097b84 (diff)
new testcase
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36039 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--test/Transforms/InstCombine/store-merge.ll36
1 files changed, 36 insertions, 0 deletions
diff --git a/test/Transforms/InstCombine/store-merge.ll b/test/Transforms/InstCombine/store-merge.ll
new file mode 100644
index 0000000000..c457a2f9c9
--- /dev/null
+++ b/test/Transforms/InstCombine/store-merge.ll
@@ -0,0 +1,36 @@
+; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {ret i32 %storemerge} | wc -l | grep 2
+;; Simple sinking tests
+
+; "if then else"
+define i32 @test1(i1 %C) {
+ %A = alloca i32
+ br i1 %C, label %Cond, label %Cond2
+
+Cond:
+ store i32 -987654321, i32* %A
+ br label %Cont
+
+Cond2:
+ store i32 47, i32* %A
+ br label %Cont
+
+Cont:
+ %V = load i32* %A
+ ret i32 %V
+}
+
+; "if then"
+define i32 @test2(i1 %C) {
+ %A = alloca i32
+ store i32 47, i32* %A
+ br i1 %C, label %Cond, label %Cont
+
+Cond:
+ store i32 -987654321, i32* %A
+ br label %Cont
+
+Cont:
+ %V = load i32* %A
+ ret i32 %V
+}
+