diff options
| author | Chad Rosier <mcrosier@codeaurora.org> | 2016-05-10 20:22:09 +0000 |
|---|---|---|
| committer | Chad Rosier <mcrosier@codeaurora.org> | 2016-05-10 20:22:09 +0000 |
| commit | 4e6cda2db5d464d814a440b3e44c9d76ba12a00a (patch) | |
| tree | 6f5b3cd7876f940e5cd6641b77185c4928b8ea49 /llvm/test | |
| parent | 7347fce4c3cf2254ac22058059af4f2260260b15 (diff) | |
| download | bcm5719-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.ll | 91 |
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 +} |

