summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/InstCombine/minmax-fold.ll
diff options
context:
space:
mode:
authorHans Wennborg <hans@hanshq.net>2015-05-19 23:06:30 +0000
committerHans Wennborg <hans@hanshq.net>2015-05-19 23:06:30 +0000
commit2f21b8760e895242e6827a03e4641e0886dbd385 (patch)
treed549dba43863f39366d7fccc0e9b47029a52d046 /llvm/test/Transforms/InstCombine/minmax-fold.ll
parent3de417f40836c6302449ca0eaafbf05a5c863e33 (diff)
downloadbcm5719-llvm-2f21b8760e895242e6827a03e4641e0886dbd385.tar.gz
bcm5719-llvm-2f21b8760e895242e6827a03e4641e0886dbd385.zip
Revert r237539: "Reapply r237520 with another fix for infinite looping"
This caused PR23583. llvm-svn: 237739
Diffstat (limited to 'llvm/test/Transforms/InstCombine/minmax-fold.ll')
-rw-r--r--llvm/test/Transforms/InstCombine/minmax-fold.ll99
1 files changed, 0 insertions, 99 deletions
diff --git a/llvm/test/Transforms/InstCombine/minmax-fold.ll b/llvm/test/Transforms/InstCombine/minmax-fold.ll
deleted file mode 100644
index 537251109d9..00000000000
--- a/llvm/test/Transforms/InstCombine/minmax-fold.ll
+++ /dev/null
@@ -1,99 +0,0 @@
-; RUN: opt -S -instcombine < %s | FileCheck %s
-
-; CHECK-LABEL: @t1
-; CHECK-NEXT: icmp
-; CHECK-NEXT: select
-; CHECK-NEXT: sext
-define i64 @t1(i32 %a) {
- ; This is the canonical form for a type-changing min/max.
- %1 = icmp slt i32 %a, 5
- %2 = select i1 %1, i32 %a, i32 5
- %3 = sext i32 %2 to i64
- ret i64 %3
-}
-
-; CHECK-LABEL: @t2
-; CHECK-NEXT: icmp
-; CHECK-NEXT: select
-; CHECK-NEXT: sext
-define i64 @t2(i32 %a) {
- ; Check this is converted into canonical form, as above.
- %1 = icmp slt i32 %a, 5
- %2 = sext i32 %a to i64
- %3 = select i1 %1, i64 %2, i64 5
- ret i64 %3
-}
-
-; CHECK-LABEL: @t3
-; CHECK-NEXT: icmp
-; CHECK-NEXT: select
-; CHECK-NEXT: zext
-define i64 @t3(i32 %a) {
- ; Same as @t2, with flipped operands and zext instead of sext.
- %1 = icmp ult i32 %a, 5
- %2 = zext i32 %a to i64
- %3 = select i1 %1, i64 5, i64 %2
- ret i64 %3
-}
-
-; CHECK-LABEL: @t4
-; CHECK-NEXT: icmp
-; CHECK-NEXT: select
-; CHECK-NEXT: trunc
-define i32 @t4(i64 %a) {
- ; Same again, with trunc.
- %1 = icmp slt i64 %a, 5
- %2 = trunc i64 %a to i32
- %3 = select i1 %1, i32 %2, i32 5
- ret i32 %3
-}
-
-; CHECK-LABEL: @t5
-; CHECK-NEXT: icmp
-; CHECK-NEXT: zext
-; CHECK-NEXT: select
-define i64 @t5(i32 %a) {
- ; Same as @t3, but with mismatched signedness between icmp and zext.
- ; InstCombine should leave this alone.
- %1 = icmp slt i32 %a, 5
- %2 = zext i32 %a to i64
- %3 = select i1 %1, i64 5, i64 %2
- ret i64 %3
-}
-
-; CHECK-LABEL: @t6
-; CHECK-NEXT: icmp
-; CHECK-NEXT: select
-; CHECK-NEXT: sitofp
-define float @t6(i32 %a) {
- %1 = icmp slt i32 %a, 0
- %2 = select i1 %1, i32 %a, i32 0
- %3 = sitofp i32 %2 to float
- ret float %3
-}
-
-; CHECK-LABEL: @t7
-; CHECK-NEXT: icmp
-; CHECK-NEXT: select
-; CHECK-NEXT: trunc
-define i16 @t7(i32 %a) {
- %1 = icmp slt i32 %a, -32768
- %2 = trunc i32 %a to i16
- %3 = select i1 %1, i16 %2, i16 -32768
- ret i16 %3
-}
-
-; Just check for no infinite loop. InstSimplify liked to
-; "simplify" -32767 by removing all the sign bits,
-; which led to a canonicalization fight between different
-; parts of instcombine.
-define i32 @t8(i64 %a, i32 %b) {
- %1 = icmp slt i64 %a, -32767
- %2 = select i1 %1, i64 %a, i64 -32767
- %3 = trunc i64 %2 to i32
- %4 = icmp slt i32 %b, 42
- %5 = select i1 %4, i32 42, i32 %3
- %6 = icmp ne i32 %5, %b
- %7 = zext i1 %6 to i32
- ret i32 %7
-}
OpenPOWER on IntegriCloud