summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-06-18 04:00:49 +0000
committerChris Lattner <sabre@nondot.org>2008-06-18 04:00:49 +0000
commitb5ee8b3e899f4de7e2493f416b9d9b15dd39e8a8 (patch)
treedbef9c4dc968ce3d063288f05f94417d5fcd0b7f /llvm/test
parentf6a1466829f5122e452096c576c0b2199d713427 (diff)
downloadbcm5719-llvm-b5ee8b3e899f4de7e2493f416b9d9b15dd39e8a8.tar.gz
bcm5719-llvm-b5ee8b3e899f4de7e2493f416b9d9b15dd39e8a8.zip
make truncate/sext elimination capable of changing phi's. This
implements rdar://6013816 and the testcase in Transforms/InstCombine/sext-misc.ll. llvm-svn: 52440
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/Transforms/InstCombine/sext-misc.ll17
1 files changed, 15 insertions, 2 deletions
diff --git a/llvm/test/Transforms/InstCombine/sext-misc.ll b/llvm/test/Transforms/InstCombine/sext-misc.ll
index 076f59568b7..69850025aca 100644
--- a/llvm/test/Transforms/InstCombine/sext-misc.ll
+++ b/llvm/test/Transforms/InstCombine/sext-misc.ll
@@ -1,6 +1,4 @@
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep sext
-; RUN: llvm-as < %s | llc -march=x86-64 | not grep movslq
-; RUN: llvm-as < %s | llc -march=x86 | not grep sar
declare i32 @llvm.ctpop.i32(i32)
declare i32 @llvm.ctlz.i32(i32)
@@ -50,3 +48,18 @@ define i32 @woo(i8 %a, i32 %f, i1 %p, i32* %z) {
%n = sext i16 %s to i32
ret i32 %n
}
+
+; rdar://6013816
+define i16 @test(i16 %t, i1 %cond) nounwind {
+entry:
+ br i1 %cond, label %T, label %F
+T:
+ %t2 = sext i16 %t to i32
+ br label %F
+
+F:
+ %V = phi i32 [%t2, %T], [42, %entry]
+ %W = trunc i32 %V to i16
+ ret i16 %W
+}
+
OpenPOWER on IntegriCloud