[PATCH] D63992: [InstCombine] Y - ~X --> X + Y + 1 fold (PR42457)
Phabricator via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Jul 3 02:44:02 PDT 2019
This revision was not accepted when it landed; it landed in state "Changes Planned".
This revision was automatically updated to reflect the committed changes.
Closed by commit rL365011: [InstCombine] Y - ~X --> X + Y + 1 fold (PR42457) (authored by lebedevri, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D63992?vs=207391&id=207735#toc
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D63992/new/
https://reviews.llvm.org/D63992
Files:
llvm/trunk/lib/Transforms/InstCombine/InstCombineAddSub.cpp
llvm/trunk/test/Transforms/InstCombine/fold-sub-of-not-to-inc-of-add.ll
Index: llvm/trunk/test/Transforms/InstCombine/fold-sub-of-not-to-inc-of-add.ll
===================================================================
--- llvm/trunk/test/Transforms/InstCombine/fold-sub-of-not-to-inc-of-add.ll
+++ llvm/trunk/test/Transforms/InstCombine/fold-sub-of-not-to-inc-of-add.ll
@@ -4,7 +4,8 @@
; Given:
; sub %y, (xor %x, -1)
; Transform it to:
-; add (add %x, %y), 1
+; add (add %x, 1), %y
+; We prefer this form because that is what -reassociate would produce.
;------------------------------------------------------------------------------;
; Scalar tests
@@ -12,8 +13,8 @@
define i32 @p0_scalar(i32 %x, i32 %y) {
; CHECK-LABEL: @p0_scalar(
-; CHECK-NEXT: [[T0:%.*]] = xor i32 [[X:%.*]], -1
-; CHECK-NEXT: [[T1:%.*]] = sub i32 [[Y:%.*]], [[T0]]
+; CHECK-NEXT: [[TMP1:%.*]] = add i32 [[Y:%.*]], 1
+; CHECK-NEXT: [[T1:%.*]] = add i32 [[TMP1]], [[X:%.*]]
; CHECK-NEXT: ret i32 [[T1]]
;
%t0 = xor i32 %x, -1
@@ -27,8 +28,8 @@
define <4 x i32> @p1_vector_splat(<4 x i32> %x, <4 x i32> %y) {
; CHECK-LABEL: @p1_vector_splat(
-; CHECK-NEXT: [[T0:%.*]] = xor <4 x i32> [[X:%.*]], <i32 -1, i32 -1, i32 -1, i32 -1>
-; CHECK-NEXT: [[T1:%.*]] = sub <4 x i32> [[Y:%.*]], [[T0]]
+; CHECK-NEXT: [[TMP1:%.*]] = add <4 x i32> [[Y:%.*]], <i32 1, i32 1, i32 1, i32 1>
+; CHECK-NEXT: [[T1:%.*]] = add <4 x i32> [[TMP1]], [[X:%.*]]
; CHECK-NEXT: ret <4 x i32> [[T1]]
;
%t0 = xor <4 x i32> %x, <i32 -1, i32 -1, i32 -1, i32 -1>
@@ -38,8 +39,8 @@
define <4 x i32> @p2_vector_undef(<4 x i32> %x, <4 x i32> %y) {
; CHECK-LABEL: @p2_vector_undef(
-; CHECK-NEXT: [[T0:%.*]] = xor <4 x i32> [[X:%.*]], <i32 -1, i32 -1, i32 undef, i32 -1>
-; CHECK-NEXT: [[T1:%.*]] = sub <4 x i32> [[Y:%.*]], [[T0]]
+; CHECK-NEXT: [[TMP1:%.*]] = add <4 x i32> [[Y:%.*]], <i32 1, i32 1, i32 1, i32 1>
+; CHECK-NEXT: [[T1:%.*]] = add <4 x i32> [[TMP1]], [[X:%.*]]
; CHECK-NEXT: ret <4 x i32> [[T1]]
;
%t0 = xor <4 x i32> %x, <i32 -1, i32 -1, i32 undef, i32 -1>
Index: llvm/trunk/lib/Transforms/InstCombine/InstCombineAddSub.cpp
===================================================================
--- llvm/trunk/lib/Transforms/InstCombine/InstCombineAddSub.cpp
+++ llvm/trunk/lib/Transforms/InstCombine/InstCombineAddSub.cpp
@@ -1580,6 +1580,12 @@
if (match(Op1, m_OneUse(m_Add(m_Value(X), m_One()))))
return BinaryOperator::CreateAdd(Builder.CreateNot(X), Op0);
+ // Y - ~X --> (X + 1) + Y
+ if (match(Op1, m_OneUse(m_Not(m_Value(X))))) {
+ return BinaryOperator::CreateAdd(
+ Builder.CreateAdd(Op0, ConstantInt::get(I.getType(), 1)), X);
+ }
+
if (Constant *C = dyn_cast<Constant>(Op0)) {
bool IsNegate = match(C, m_ZeroInt());
Value *X;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D63992.207735.patch
Type: text/x-patch
Size: 2735 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190703/737fb3ef/attachment.bin>
More information about the llvm-commits
mailing list