[llvm] r274891 - [InstCombine] check for one-use before turning simple logic op into a select
Sanjay Patel via llvm-commits
llvm-commits at lists.llvm.org
Fri Jul 8 10:26:47 PDT 2016
Author: spatel
Date: Fri Jul 8 12:26:47 2016
New Revision: 274891
URL: http://llvm.org/viewvc/llvm-project?rev=274891&view=rev
Log:
[InstCombine] check for one-use before turning simple logic op into a select
Modified:
llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
llvm/trunk/test/Transforms/InstCombine/or.ll
Modified: llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp?rev=274891&r1=274890&r2=274891&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp (original)
+++ llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp Fri Jul 8 12:26:47 2016
@@ -2394,10 +2394,10 @@ Instruction *InstCombiner::visitOr(Binar
return CastedOr;
// or(sext(A), B) / or(B, sext(A)) --> A ? -1 : B, where A is i1 or <N x i1>.
- if (match(Op0, m_SExt(m_Value(A))) &&
+ if (match(Op0, m_OneUse(m_SExt(m_Value(A)))) &&
A->getType()->getScalarType()->isIntegerTy(1))
return SelectInst::Create(A, ConstantInt::getSigned(I.getType(), -1), Op1);
- if (match(Op1, m_SExt(m_Value(A))) &&
+ if (match(Op1, m_OneUse(m_SExt(m_Value(A)))) &&
A->getType()->getScalarType()->isIntegerTy(1))
return SelectInst::Create(A, ConstantInt::getSigned(I.getType(), -1), Op0);
Modified: llvm/trunk/test/Transforms/InstCombine/or.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/or.ll?rev=274891&r1=274890&r2=274891&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/or.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/or.ll Fri Jul 8 12:26:47 2016
@@ -445,12 +445,10 @@ define i32 @orsext_to_sel_swap(i32 %x, i
ret i32 %or
}
-; FIXME: Don't replace an 'or' with a select unless it allows further simplification.
-
define i32 @orsext_to_sel_multi_use(i32 %x, i1 %y) {
; CHECK-LABEL: @orsext_to_sel_multi_use(
; CHECK-NEXT: [[SEXT:%.*]] = sext i1 %y to i32
-; CHECK-NEXT: [[OR:%.*]] = select i1 %y, i32 -1, i32 %x
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[SEXT]], %x
; CHECK-NEXT: [[ADD:%.*]] = add i32 [[SEXT]], [[OR]]
; CHECK-NEXT: ret i32 [[ADD]]
;
More information about the llvm-commits
mailing list