diff options
| author | Craig Topper <craig.topper@intel.com> | 2017-11-15 05:23:02 +0000 |
|---|---|---|
| committer | Craig Topper <craig.topper@intel.com> | 2017-11-15 05:23:02 +0000 |
| commit | f7b86728fa1912fef2da37995a75c1023c838498 (patch) | |
| tree | f553bfea10beb16fe6fe5f02c7a7854be54e257e /llvm/test/Transforms | |
| parent | 72a1f98a6760940212677dc5706e3443c2a0f1e5 (diff) | |
| download | bcm5719-llvm-f7b86728fa1912fef2da37995a75c1023c838498.tar.gz bcm5719-llvm-f7b86728fa1912fef2da37995a75c1023c838498.zip | |
[InstCombine] Simplify binops that are only used by a select and are fed by a select with the same condition.
Summary:
This patch optimizes a binop sandwiched between 2 selects with the same condition. Since we know its only used by the select we can propagate the appropriate input value from the earlier select.
As I'm writing this I realize I may need to avoid doing this for division in case the select was protecting a divide by zero?
Reviewers: spatel, majnemer
Reviewed By: majnemer
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D39999
llvm-svn: 318267
Diffstat (limited to 'llvm/test/Transforms')
| -rw-r--r-- | llvm/test/Transforms/InstCombine/select.ll | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/select.ll b/llvm/test/Transforms/InstCombine/select.ll index e49639b3024..4a361cdc4ea 100644 --- a/llvm/test/Transforms/InstCombine/select.ll +++ b/llvm/test/Transforms/InstCombine/select.ll @@ -1490,3 +1490,55 @@ entry: %1 = select <4 x i1> %0, <4 x float> <float 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000>, <4 x float> zeroinitializer ret <4 x float> %1 } + +; select(C, binop(select(C, X, Y), W), Z) -> select(C, binop(X, W), Z) +define i8 @test87(i1 %cond, i8 %w, i8 %x, i8 %y, i8 %z) { +; CHECK-LABEL: @test87( +; CHECK-NEXT: [[B:%.*]] = add i8 [[X:%.*]], [[W:%.*]] +; CHECK-NEXT: [[C:%.*]] = select i1 [[COND:%.*]], i8 [[B]], i8 [[Z:%.*]] +; CHECK-NEXT: ret i8 [[C]] +; + %a = select i1 %cond, i8 %x, i8 %y + %b = add i8 %a, %w + %c = select i1 %cond, i8 %b, i8 %z + ret i8 %c +} + +; select(C, binop(select(C, X, Y), W), Z) -> select(C, Z, binop(Y, W)) +define i8 @test88(i1 %cond, i8 %w, i8 %x, i8 %y, i8 %z) { +; CHECK-LABEL: @test88( +; CHECK-NEXT: [[B:%.*]] = sub i8 [[Y:%.*]], [[W:%.*]] +; CHECK-NEXT: [[C:%.*]] = select i1 [[COND:%.*]], i8 [[Z:%.*]], i8 [[B]] +; CHECK-NEXT: ret i8 [[C]] +; + %a = select i1 %cond, i8 %x, i8 %y + %b = sub i8 %a, %w + %c = select i1 %cond, i8 %z, i8 %b + ret i8 %c +} + +; select(C, Z, binop(W, select(C, X, Y))) -> select(C, binop(X, W), Z) +define i8 @test89(i1 %cond, i8 %w, i8 %x, i8 %y, i8 %z) { +; CHECK-LABEL: @test89( +; CHECK-NEXT: [[B:%.*]] = and i8 [[X:%.*]], [[W:%.*]] +; CHECK-NEXT: [[C:%.*]] = select i1 [[COND:%.*]], i8 [[B]], i8 [[Z:%.*]] +; CHECK-NEXT: ret i8 [[C]] +; + %a = select i1 %cond, i8 %x, i8 %y + %b = and i8 %w, %a + %c = select i1 %cond, i8 %b, i8 %z + ret i8 %c +} + +; select(C, Z, binop(W, select(C, X, Y))) -> select(C, Z, binop(W, Y)) +define i8 @test90(i1 %cond, i8 %w, i8 %x, i8 %y, i8 %z) { +; CHECK-LABEL: @test90( +; CHECK-NEXT: [[B:%.*]] = or i8 [[Y:%.*]], [[W:%.*]] +; CHECK-NEXT: [[C:%.*]] = select i1 [[COND:%.*]], i8 [[Z:%.*]], i8 [[B]] +; CHECK-NEXT: ret i8 [[C]] +; + %a = select i1 %cond, i8 %x, i8 %y + %b = or i8 %w, %a + %c = select i1 %cond, i8 %z, i8 %b + ret i8 %c +} |

