summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorChad Rosier <mcrosier@codeaurora.org>2016-05-10 20:22:09 +0000
committerChad Rosier <mcrosier@codeaurora.org>2016-05-10 20:22:09 +0000
commit4e6cda2db5d464d814a440b3e44c9d76ba12a00a (patch)
tree6f5b3cd7876f940e5cd6641b77185c4928b8ea49 /llvm/test
parent7347fce4c3cf2254ac22058059af4f2260260b15 (diff)
downloadbcm5719-llvm-4e6cda2db5d464d814a440b3e44c9d76ba12a00a.tar.gz
bcm5719-llvm-4e6cda2db5d464d814a440b3e44c9d76ba12a00a.zip
[InstCombine] Fold icmp ugt/ult (udiv i32 C2, X), C1.
This patch adds support for two optimizations: icmp ugt (udiv C2, X), C1 -> icmp ule X, C2/(C1+1) icmp ult (udiv C2, X), C1 -> icmp ugt X, C2/C1 Differential Revision: http://reviews.llvm.org/D20123 llvm-svn: 269109
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/Transforms/InstCombine/compare-udiv.ll91
1 files changed, 91 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/compare-udiv.ll b/llvm/test/Transforms/InstCombine/compare-udiv.ll
index d919d77a5b2..140f9b52130 100644
--- a/llvm/test/Transforms/InstCombine/compare-udiv.ll
+++ b/llvm/test/Transforms/InstCombine/compare-udiv.ll
@@ -39,3 +39,94 @@ define i1 @test5(i32 %d) {
%cmp1 = icmp ne i32 %div, 0
ret i1 %cmp1
}
+
+; CHECK-LABEL: @test6
+; CHECK: %cmp1 = icmp ult i32 %d, 6
+define i1 @test6(i32 %d) {
+ %div = udiv i32 5, %d
+ %cmp1 = icmp ugt i32 %div, 0
+ ret i1 %cmp1
+}
+
+; (icmp ugt (udiv C1, X), C1) -> false.
+; CHECK-LABEL: @test7
+; CHECK: ret i1 false
+define i1 @test7(i32 %d) {
+ %div = udiv i32 8, %d
+ %cmp1 = icmp ugt i32 %div, 8
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test8
+; CHECK: %cmp1 = icmp ult i32 %d, 2
+define i1 @test8(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ugt i32 %div, 3
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test9
+; CHECK: %cmp1 = icmp ult i32 %d, 2
+define i1 @test9(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ugt i32 %div, 2
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test10
+; CHECK: %cmp1 = icmp ult i32 %d, 3
+define i1 @test10(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ugt i32 %div, 1
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test11
+; CHECK: %cmp1 = icmp ugt i32 %d, 4
+define i1 @test11(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ult i32 %div, 1
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test12
+; CHECK: %cmp1 = icmp ugt i32 %d, 2
+define i1 @test12(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ult i32 %div, 2
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test13
+; CHECK: %cmp1 = icmp ugt i32 %d, 1
+define i1 @test13(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ult i32 %div, 3
+ ret i1 %cmp1
+}
+
+; CHECK-LABEL: @test14
+; CHECK: %cmp1 = icmp ugt i32 %d, 1
+define i1 @test14(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ult i32 %div, 4
+ ret i1 %cmp1
+}
+
+; icmp ugt X, UINT_MAX -> false.
+; CHECK-LABEL: @test15
+; CHECK: ret i1 false
+define i1 @test15(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ugt i32 %div, -1
+ ret i1 %cmp1
+}
+
+; icmp ult X, UINT_MAX -> true.
+; CHECK-LABEL: @test16
+; CHECK: ret i1 true
+define i1 @test16(i32 %d) {
+ %div = udiv i32 4, %d
+ %cmp1 = icmp ult i32 %div, -1
+ ret i1 %cmp1
+}
OpenPOWER on IntegriCloud