aboutsummaryrefslogtreecommitdiffstats
path: root/test/Transforms/JumpThreading/basic.ll
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-10-11 18:39:58 +0000
committerChris Lattner <sabre@nondot.org>2009-10-11 18:39:58 +0000
commit5a06cf644f35b873686c8694968192ad3385e36a (patch)
tree9b50fc5a73451b253060db85f5e36bbe593a8cf1 /test/Transforms/JumpThreading/basic.ll
parentf9f3cb18457d493b55bda504c9ab2a6dff239795 (diff)
downloadexternal_llvm-5a06cf644f35b873686c8694968192ad3385e36a.zip
external_llvm-5a06cf644f35b873686c8694968192ad3385e36a.tar.gz
external_llvm-5a06cf644f35b873686c8694968192ad3385e36a.tar.bz2
when folding duplicate conditions, delete the
now-probably-dead instruction tree feeding it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@83778 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/JumpThreading/basic.ll')
-rw-r--r--test/Transforms/JumpThreading/basic.ll33
1 files changed, 33 insertions, 0 deletions
diff --git a/test/Transforms/JumpThreading/basic.ll b/test/Transforms/JumpThreading/basic.ll
index 50433db..3d936b8 100644
--- a/test/Transforms/JumpThreading/basic.ll
+++ b/test/Transforms/JumpThreading/basic.ll
@@ -139,3 +139,36 @@ F2:
ret i32 %B
}
+
+;; Lexically duplicated conditionals should be threaded.
+
+
+define i32 @test6(i32 %A) {
+; CHECK: @test6
+ %tmp455 = icmp eq i32 %A, 42
+ br i1 %tmp455, label %BB1, label %BB2
+
+BB2:
+; CHECK: call i32 @f1()
+; CHECK-NEXT: call void @f3()
+; CHECK-NEXT: ret i32 4
+ call i32 @f1()
+ br label %BB1
+
+
+BB1:
+ %tmp459 = icmp eq i32 %A, 42
+ br i1 %tmp459, label %BB3, label %BB4
+
+BB3:
+ call i32 @f2()
+ ret i32 3
+
+BB4:
+ call void @f3()
+ ret i32 4
+}
+
+
+
+