forked from OSchip/llvm-project
[DAG] SimplifyVBinOp - add SDLoc() argument
Pass in SDLoc instead of (repeated) local creations in SimplifyVBinOp and scalarizeBinOpOfSplats
This commit is contained in:
parent
8658d20724
commit
7bac1985f4
|
@ -436,7 +436,7 @@ namespace {
|
|||
SDValue visitOR(SDNode *N);
|
||||
SDValue visitORLike(SDValue N0, SDValue N1, SDNode *N);
|
||||
SDValue visitXOR(SDNode *N);
|
||||
SDValue SimplifyVBinOp(SDNode *N);
|
||||
SDValue SimplifyVBinOp(SDNode *N, const SDLoc &DL);
|
||||
SDValue visitSHL(SDNode *N);
|
||||
SDValue visitSRA(SDNode *N);
|
||||
SDValue visitSRL(SDNode *N);
|
||||
|
@ -2262,7 +2262,7 @@ SDValue DAGCombiner::visitADDLike(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (add x, 0) -> x, vector edition
|
||||
|
@ -3262,7 +3262,7 @@ SDValue DAGCombiner::visitSUB(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (sub x, 0) -> x, vector edition
|
||||
|
@ -3787,7 +3787,7 @@ SDValue DAGCombiner::visitMUL(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
|
||||
return FoldedVOp;
|
||||
|
||||
N1IsConst = ISD::isConstantSplatVector(N1.getNode(), ConstValue1);
|
||||
|
@ -4138,14 +4138,13 @@ SDValue DAGCombiner::visitSDIV(SDNode *N) {
|
|||
SDValue N1 = N->getOperand(1);
|
||||
EVT VT = N->getValueType(0);
|
||||
EVT CCVT = getSetCCResultType(VT);
|
||||
SDLoc DL(N);
|
||||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
SDLoc DL(N);
|
||||
|
||||
// fold (sdiv c1, c2) -> c1/c2
|
||||
ConstantSDNode *N1C = isConstOrConstSplat(N1);
|
||||
if (SDValue C = DAG.FoldConstantArithmetic(ISD::SDIV, DL, VT, {N0, N1}))
|
||||
|
@ -4283,14 +4282,13 @@ SDValue DAGCombiner::visitUDIV(SDNode *N) {
|
|||
SDValue N1 = N->getOperand(1);
|
||||
EVT VT = N->getValueType(0);
|
||||
EVT CCVT = getSetCCResultType(VT);
|
||||
SDLoc DL(N);
|
||||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
SDLoc DL(N);
|
||||
|
||||
// fold (udiv c1, c2) -> c1/c2
|
||||
ConstantSDNode *N1C = isConstOrConstSplat(N1);
|
||||
if (SDValue C = DAG.FoldConstantArithmetic(ISD::UDIV, DL, VT, {N0, N1}))
|
||||
|
@ -4786,20 +4784,21 @@ SDValue DAGCombiner::visitIMINMAX(SDNode *N) {
|
|||
SDValue N1 = N->getOperand(1);
|
||||
EVT VT = N0.getValueType();
|
||||
unsigned Opcode = N->getOpcode();
|
||||
SDLoc DL(N);
|
||||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold operation with constant operands.
|
||||
if (SDValue C = DAG.FoldConstantArithmetic(Opcode, SDLoc(N), VT, {N0, N1}))
|
||||
if (SDValue C = DAG.FoldConstantArithmetic(Opcode, DL, VT, {N0, N1}))
|
||||
return C;
|
||||
|
||||
// canonicalize constant to RHS
|
||||
if (DAG.isConstantIntBuildVectorOrConstantInt(N0) &&
|
||||
!DAG.isConstantIntBuildVectorOrConstantInt(N1))
|
||||
return DAG.getNode(N->getOpcode(), SDLoc(N), VT, N1, N0);
|
||||
return DAG.getNode(N->getOpcode(), DL, VT, N1, N0);
|
||||
|
||||
// Is sign bits are zero, flip between UMIN/UMAX and SMIN/SMAX.
|
||||
// Only do this if the current op isn't legal and the flipped is.
|
||||
|
@ -4815,7 +4814,7 @@ SDValue DAGCombiner::visitIMINMAX(SDNode *N) {
|
|||
default: llvm_unreachable("Unknown MINMAX opcode");
|
||||
}
|
||||
if (TLI.isOperationLegal(AltOpcode, VT))
|
||||
return DAG.getNode(AltOpcode, SDLoc(N), VT, N0, N1);
|
||||
return DAG.getNode(AltOpcode, DL, VT, N0, N1);
|
||||
}
|
||||
|
||||
// Simplify the operands using demanded-bits information.
|
||||
|
@ -5669,7 +5668,7 @@ SDValue DAGCombiner::visitAND(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (and x, 0) -> 0, vector edition
|
||||
|
@ -6438,7 +6437,7 @@ SDValue DAGCombiner::visitOR(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (or x, 0) -> x, vector edition
|
||||
|
@ -7801,10 +7800,11 @@ SDValue DAGCombiner::visitXOR(SDNode *N) {
|
|||
SDValue N0 = N->getOperand(0);
|
||||
SDValue N1 = N->getOperand(1);
|
||||
EVT VT = N0.getValueType();
|
||||
SDLoc DL(N);
|
||||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (xor x, 0) -> x, vector edition
|
||||
|
@ -7815,7 +7815,6 @@ SDValue DAGCombiner::visitXOR(SDNode *N) {
|
|||
}
|
||||
|
||||
// fold (xor undef, undef) -> 0. This is a common idiom (misuse).
|
||||
SDLoc DL(N);
|
||||
if (N0.isUndef() && N1.isUndef())
|
||||
return DAG.getConstant(0, DL, VT);
|
||||
|
||||
|
@ -8273,7 +8272,7 @@ SDValue DAGCombiner::visitSHL(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
|
||||
return FoldedVOp;
|
||||
|
||||
BuildVectorSDNode *N1CV = dyn_cast<BuildVectorSDNode>(N1);
|
||||
|
@ -8628,7 +8627,7 @@ SDValue DAGCombiner::visitSRA(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
|
||||
return FoldedVOp;
|
||||
|
||||
ConstantSDNode *N1C = isConstOrConstSplat(N1);
|
||||
|
@ -8826,7 +8825,7 @@ SDValue DAGCombiner::visitSRL(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
|
||||
return FoldedVOp;
|
||||
|
||||
ConstantSDNode *N1C = isConstOrConstSplat(N1);
|
||||
|
@ -13739,7 +13738,7 @@ SDValue DAGCombiner::visitFADD(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (fadd c1, c2) -> c1 + c2
|
||||
|
@ -13947,7 +13946,7 @@ SDValue DAGCombiner::visitFSUB(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (fsub c1, c2) -> c1-c2
|
||||
|
@ -14032,7 +14031,7 @@ SDValue DAGCombiner::visitFMUL(SDNode *N) {
|
|||
// fold vector ops
|
||||
if (VT.isVector()) {
|
||||
// This just handles C1 * C2 for vectors. Other vector folds are below.
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
}
|
||||
|
||||
|
@ -14369,7 +14368,7 @@ SDValue DAGCombiner::visitFDIV(SDNode *N) {
|
|||
|
||||
// fold vector ops
|
||||
if (VT.isVector())
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N))
|
||||
if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
|
||||
return FoldedVOp;
|
||||
|
||||
// fold (fdiv c1, c2) -> c1/c2
|
||||
|
@ -22234,7 +22233,8 @@ SDValue DAGCombiner::XformToShuffleWithZero(SDNode *N) {
|
|||
|
||||
/// If a vector binop is performed on splat values, it may be profitable to
|
||||
/// extract, scalarize, and insert/splat.
|
||||
static SDValue scalarizeBinOpOfSplats(SDNode *N, SelectionDAG &DAG) {
|
||||
static SDValue scalarizeBinOpOfSplats(SDNode *N, SelectionDAG &DAG,
|
||||
const SDLoc &DL) {
|
||||
SDValue N0 = N->getOperand(0);
|
||||
SDValue N1 = N->getOperand(1);
|
||||
unsigned Opcode = N->getOpcode();
|
||||
|
@ -22255,7 +22255,6 @@ static SDValue scalarizeBinOpOfSplats(SDNode *N, SelectionDAG &DAG) {
|
|||
!TLI.isOperationLegalOrCustom(Opcode, EltVT))
|
||||
return SDValue();
|
||||
|
||||
SDLoc DL(N);
|
||||
SDValue IndexC = DAG.getVectorIdxConstant(Index0, DL);
|
||||
SDValue X = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Src0, IndexC);
|
||||
SDValue Y = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Src1, IndexC);
|
||||
|
@ -22279,7 +22278,7 @@ static SDValue scalarizeBinOpOfSplats(SDNode *N, SelectionDAG &DAG) {
|
|||
}
|
||||
|
||||
/// Visit a binary vector operation, like ADD.
|
||||
SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
||||
SDValue DAGCombiner::SimplifyVBinOp(SDNode *N, const SDLoc &DL) {
|
||||
EVT VT = N->getValueType(0);
|
||||
assert(VT.isVector() && "SimplifyVBinOp only works on vectors!");
|
||||
|
||||
|
@ -22309,7 +22308,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
|||
if (Shuf0 && Shuf1 && Shuf0->getMask().equals(Shuf1->getMask()) &&
|
||||
LHS.getOperand(1).isUndef() && RHS.getOperand(1).isUndef() &&
|
||||
(LHS.hasOneUse() || RHS.hasOneUse() || LHS == RHS)) {
|
||||
SDLoc DL(N);
|
||||
SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, LHS.getOperand(0),
|
||||
RHS.getOperand(0), Flags);
|
||||
SDValue UndefV = LHS.getOperand(1);
|
||||
|
@ -22326,7 +22324,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
|||
Shuf0->hasOneUse() && Shuf0->getOperand(1).isUndef() &&
|
||||
Shuf0->getOperand(0).getOpcode() != ISD::INSERT_VECTOR_ELT) {
|
||||
// binop (splat X), (splat C) --> splat (binop X, C)
|
||||
SDLoc DL(N);
|
||||
SDValue X = Shuf0->getOperand(0);
|
||||
SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, X, RHS, Flags);
|
||||
return DAG.getVectorShuffle(VT, DL, NewBinOp, DAG.getUNDEF(VT),
|
||||
|
@ -22336,7 +22333,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
|||
Shuf1->hasOneUse() && Shuf1->getOperand(1).isUndef() &&
|
||||
Shuf1->getOperand(0).getOpcode() != ISD::INSERT_VECTOR_ELT) {
|
||||
// binop (splat C), (splat X) --> splat (binop C, X)
|
||||
SDLoc DL(N);
|
||||
SDValue X = Shuf1->getOperand(0);
|
||||
SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, LHS, X, Flags);
|
||||
return DAG.getVectorShuffle(VT, DL, NewBinOp, DAG.getUNDEF(VT),
|
||||
|
@ -22360,7 +22356,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
|||
TLI.isOperationLegalOrCustomOrPromote(Opcode, NarrowVT,
|
||||
LegalOperations)) {
|
||||
// (binop undef, undef) may not return undef, so compute that result.
|
||||
SDLoc DL(N);
|
||||
SDValue VecC =
|
||||
DAG.getNode(Opcode, DL, VT, DAG.getUNDEF(VT), DAG.getUNDEF(VT));
|
||||
SDValue NarrowBO = DAG.getNode(Opcode, DL, NarrowVT, X, Y);
|
||||
|
@ -22387,7 +22382,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
|||
EVT NarrowVT = LHS.getOperand(0).getValueType();
|
||||
if (NarrowVT == RHS.getOperand(0).getValueType() &&
|
||||
TLI.isOperationLegalOrCustomOrPromote(Opcode, NarrowVT)) {
|
||||
SDLoc DL(N);
|
||||
unsigned NumOperands = LHS.getNumOperands();
|
||||
SmallVector<SDValue, 4> ConcatOps;
|
||||
for (unsigned i = 0; i != NumOperands; ++i) {
|
||||
|
@ -22400,7 +22394,7 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
|
|||
}
|
||||
}
|
||||
|
||||
if (SDValue V = scalarizeBinOpOfSplats(N, DAG))
|
||||
if (SDValue V = scalarizeBinOpOfSplats(N, DAG, DL))
|
||||
return V;
|
||||
|
||||
return SDValue();
|
||||
|
|
Loading…
Reference in New Issue