diff options
author | Sanjay Patel <spatel@rotateright.com> | 2018-07-11 16:52:18 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2018-07-11 16:52:18 +0000 |
commit | 14eeb5a5c0fd8c79a71aed6ce240a32cd8f18e85 (patch) | |
tree | 2311d17bd7e625bc2fbbdb3a4bfee5c51b3e5c70 | |
parent | 569200aab8cf72ef60074f87243d74f34b86b73a (diff) | |
download | bcm5719-llvm-14eeb5a5c0fd8c79a71aed6ce240a32cd8f18e85.tar.gz bcm5719-llvm-14eeb5a5c0fd8c79a71aed6ce240a32cd8f18e85.zip |
[InstSimplify] add/move tests for add folds; NFC
isKnownNegation() is currently proposed as part of D48754,
but it could be used to make InstSimplify stronger independently
of any abs() improvements.
llvm-svn: 336822
-rw-r--r-- | llvm/test/Transforms/InstCombine/sub.ll | 9 | ||||
-rw-r--r-- | llvm/test/Transforms/InstSimplify/add.ll | 57 |
2 files changed, 57 insertions, 9 deletions
diff --git a/llvm/test/Transforms/InstCombine/sub.ll b/llvm/test/Transforms/InstCombine/sub.ll index 997ee6e16b5..c48ab6db7f7 100644 --- a/llvm/test/Transforms/InstCombine/sub.ll +++ b/llvm/test/Transforms/InstCombine/sub.ll @@ -250,15 +250,6 @@ define i64 @test18(i64 %Y) { ret i64 %tmp.8 } -define i32 @test19(i32 %X, i32 %Y) { -; CHECK-LABEL: @test19( -; CHECK-NEXT: ret i32 [[X:%.*]] -; - %Z = sub i32 %X, %Y - %Q = add i32 %Z, %Y - ret i32 %Q -} - define i1 @test20(i32 %g, i32 %h) { ; CHECK-LABEL: @test20( ; CHECK-NEXT: [[TMP_4:%.*]] = icmp ne i32 [[H:%.*]], 0 diff --git a/llvm/test/Transforms/InstSimplify/add.ll b/llvm/test/Transforms/InstSimplify/add.ll new file mode 100644 index 00000000000..d32b2551ab1 --- /dev/null +++ b/llvm/test/Transforms/InstSimplify/add.ll @@ -0,0 +1,57 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt < %s -instsimplify -S | FileCheck %s + +define i32 @common_sub_operand(i32 %X, i32 %Y) { +; CHECK-LABEL: @common_sub_operand( +; CHECK-NEXT: ret i32 [[X:%.*]] +; + %Z = sub i32 %X, %Y + %Q = add i32 %Z, %Y + ret i32 %Q +} + +define i32 @negated_operand(i32 %x) { +; CHECK-LABEL: @negated_operand( +; CHECK-NEXT: ret i32 0 +; + %negx = sub i32 0, %x + %r = add i32 %negx, %x + ret i32 %r +} + +define <2 x i32> @negated_operand_commute_vec(<2 x i32> %x) { +; CHECK-LABEL: @negated_operand_commute_vec( +; CHECK-NEXT: ret <2 x i32> zeroinitializer +; + %negx = sub <2 x i32> zeroinitializer, %x + %r = add <2 x i32> %x, %negx + ret <2 x i32> %r +} + +define i8 @knownnegation(i8 %x, i8 %y) { +; CHECK-LABEL: @knownnegation( +; CHECK-NEXT: [[XY:%.*]] = sub i8 [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[YX:%.*]] = sub i8 [[Y]], [[X]] +; CHECK-NEXT: [[R:%.*]] = add i8 [[XY]], [[YX]] +; CHECK-NEXT: ret i8 [[R]] +; + %xy = sub i8 %x, %y + %yx = sub i8 %y, %x + %r = add i8 %xy, %yx + ret i8 %r +} + +define <2 x i8> @knownnegation_commute_vec(<2 x i8> %x, <2 x i8> %y) { +; CHECK-LABEL: @knownnegation_commute_vec( +; CHECK-NEXT: [[XY:%.*]] = sub <2 x i8> [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[YX:%.*]] = sub <2 x i8> [[Y]], [[X]] +; CHECK-NEXT: [[R:%.*]] = add <2 x i8> [[YX]], [[XY]] +; CHECK-NEXT: ret <2 x i8> [[R]] +; + %xy = sub <2 x i8> %x, %y + %yx = sub <2 x i8> %y, %x + %r = add <2 x i8> %yx, %xy + ret <2 x i8> %r +} + + |