[DAG] SimplifyVBinOp - add SDLoc() argument

Pass in SDLoc instead of (repeated) local creations in SimplifyVBinOp and scalarizeBinOpOfSplats
This commit is contained in:
Simon Pilgrim 2021-11-12 18:52:00 +00:00
parent 8658d20724
commit 7bac1985f4
1 changed files with 28 additions and 34 deletions

View File

@ -436,7 +436,7 @@ namespace {
SDValue visitOR(SDNode *N); SDValue visitOR(SDNode *N);
SDValue visitORLike(SDValue N0, SDValue N1, SDNode *N); SDValue visitORLike(SDValue N0, SDValue N1, SDNode *N);
SDValue visitXOR(SDNode *N); SDValue visitXOR(SDNode *N);
SDValue SimplifyVBinOp(SDNode *N); SDValue SimplifyVBinOp(SDNode *N, const SDLoc &DL);
SDValue visitSHL(SDNode *N); SDValue visitSHL(SDNode *N);
SDValue visitSRA(SDNode *N); SDValue visitSRA(SDNode *N);
SDValue visitSRL(SDNode *N); SDValue visitSRL(SDNode *N);
@ -2262,7 +2262,7 @@ SDValue DAGCombiner::visitADDLike(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold (add x, 0) -> x, vector edition // fold (add x, 0) -> x, vector edition
@ -3262,7 +3262,7 @@ SDValue DAGCombiner::visitSUB(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold (sub x, 0) -> x, vector edition // fold (sub x, 0) -> x, vector edition
@ -3787,7 +3787,7 @@ SDValue DAGCombiner::visitMUL(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
return FoldedVOp; return FoldedVOp;
N1IsConst = ISD::isConstantSplatVector(N1.getNode(), ConstValue1); N1IsConst = ISD::isConstantSplatVector(N1.getNode(), ConstValue1);
@ -4138,14 +4138,13 @@ SDValue DAGCombiner::visitSDIV(SDNode *N) {
SDValue N1 = N->getOperand(1); SDValue N1 = N->getOperand(1);
EVT VT = N->getValueType(0); EVT VT = N->getValueType(0);
EVT CCVT = getSetCCResultType(VT); EVT CCVT = getSetCCResultType(VT);
SDLoc DL(N);
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
SDLoc DL(N);
// fold (sdiv c1, c2) -> c1/c2 // fold (sdiv c1, c2) -> c1/c2
ConstantSDNode *N1C = isConstOrConstSplat(N1); ConstantSDNode *N1C = isConstOrConstSplat(N1);
if (SDValue C = DAG.FoldConstantArithmetic(ISD::SDIV, DL, VT, {N0, 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); SDValue N1 = N->getOperand(1);
EVT VT = N->getValueType(0); EVT VT = N->getValueType(0);
EVT CCVT = getSetCCResultType(VT); EVT CCVT = getSetCCResultType(VT);
SDLoc DL(N);
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
SDLoc DL(N);
// fold (udiv c1, c2) -> c1/c2 // fold (udiv c1, c2) -> c1/c2
ConstantSDNode *N1C = isConstOrConstSplat(N1); ConstantSDNode *N1C = isConstOrConstSplat(N1);
if (SDValue C = DAG.FoldConstantArithmetic(ISD::UDIV, DL, VT, {N0, 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); SDValue N1 = N->getOperand(1);
EVT VT = N0.getValueType(); EVT VT = N0.getValueType();
unsigned Opcode = N->getOpcode(); unsigned Opcode = N->getOpcode();
SDLoc DL(N);
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold operation with constant operands. // 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; return C;
// canonicalize constant to RHS // canonicalize constant to RHS
if (DAG.isConstantIntBuildVectorOrConstantInt(N0) && if (DAG.isConstantIntBuildVectorOrConstantInt(N0) &&
!DAG.isConstantIntBuildVectorOrConstantInt(N1)) !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. // 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. // 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"); default: llvm_unreachable("Unknown MINMAX opcode");
} }
if (TLI.isOperationLegal(AltOpcode, VT)) 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. // Simplify the operands using demanded-bits information.
@ -5669,7 +5668,7 @@ SDValue DAGCombiner::visitAND(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
return FoldedVOp; return FoldedVOp;
// fold (and x, 0) -> 0, vector edition // fold (and x, 0) -> 0, vector edition
@ -6438,7 +6437,7 @@ SDValue DAGCombiner::visitOR(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
return FoldedVOp; return FoldedVOp;
// fold (or x, 0) -> x, vector edition // fold (or x, 0) -> x, vector edition
@ -7801,10 +7800,11 @@ SDValue DAGCombiner::visitXOR(SDNode *N) {
SDValue N0 = N->getOperand(0); SDValue N0 = N->getOperand(0);
SDValue N1 = N->getOperand(1); SDValue N1 = N->getOperand(1);
EVT VT = N0.getValueType(); EVT VT = N0.getValueType();
SDLoc DL(N);
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold (xor x, 0) -> x, vector edition // 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). // fold (xor undef, undef) -> 0. This is a common idiom (misuse).
SDLoc DL(N);
if (N0.isUndef() && N1.isUndef()) if (N0.isUndef() && N1.isUndef())
return DAG.getConstant(0, DL, VT); return DAG.getConstant(0, DL, VT);
@ -8273,7 +8272,7 @@ SDValue DAGCombiner::visitSHL(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
return FoldedVOp; return FoldedVOp;
BuildVectorSDNode *N1CV = dyn_cast<BuildVectorSDNode>(N1); BuildVectorSDNode *N1CV = dyn_cast<BuildVectorSDNode>(N1);
@ -8628,7 +8627,7 @@ SDValue DAGCombiner::visitSRA(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
return FoldedVOp; return FoldedVOp;
ConstantSDNode *N1C = isConstOrConstSplat(N1); ConstantSDNode *N1C = isConstOrConstSplat(N1);
@ -8826,7 +8825,7 @@ SDValue DAGCombiner::visitSRL(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, SDLoc(N)))
return FoldedVOp; return FoldedVOp;
ConstantSDNode *N1C = isConstOrConstSplat(N1); ConstantSDNode *N1C = isConstOrConstSplat(N1);
@ -13739,7 +13738,7 @@ SDValue DAGCombiner::visitFADD(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold (fadd c1, c2) -> c1 + c2 // fold (fadd c1, c2) -> c1 + c2
@ -13947,7 +13946,7 @@ SDValue DAGCombiner::visitFSUB(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold (fsub c1, c2) -> c1-c2 // fold (fsub c1, c2) -> c1-c2
@ -14032,7 +14031,7 @@ SDValue DAGCombiner::visitFMUL(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) { if (VT.isVector()) {
// This just handles C1 * C2 for vectors. Other vector folds are below. // 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; return FoldedVOp;
} }
@ -14369,7 +14368,7 @@ SDValue DAGCombiner::visitFDIV(SDNode *N) {
// fold vector ops // fold vector ops
if (VT.isVector()) if (VT.isVector())
if (SDValue FoldedVOp = SimplifyVBinOp(N)) if (SDValue FoldedVOp = SimplifyVBinOp(N, DL))
return FoldedVOp; return FoldedVOp;
// fold (fdiv c1, c2) -> c1/c2 // 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 /// If a vector binop is performed on splat values, it may be profitable to
/// extract, scalarize, and insert/splat. /// 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 N0 = N->getOperand(0);
SDValue N1 = N->getOperand(1); SDValue N1 = N->getOperand(1);
unsigned Opcode = N->getOpcode(); unsigned Opcode = N->getOpcode();
@ -22255,7 +22255,6 @@ static SDValue scalarizeBinOpOfSplats(SDNode *N, SelectionDAG &DAG) {
!TLI.isOperationLegalOrCustom(Opcode, EltVT)) !TLI.isOperationLegalOrCustom(Opcode, EltVT))
return SDValue(); return SDValue();
SDLoc DL(N);
SDValue IndexC = DAG.getVectorIdxConstant(Index0, DL); SDValue IndexC = DAG.getVectorIdxConstant(Index0, DL);
SDValue X = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Src0, IndexC); SDValue X = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Src0, IndexC);
SDValue Y = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Src1, 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. /// 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); EVT VT = N->getValueType(0);
assert(VT.isVector() && "SimplifyVBinOp only works on vectors!"); 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()) && if (Shuf0 && Shuf1 && Shuf0->getMask().equals(Shuf1->getMask()) &&
LHS.getOperand(1).isUndef() && RHS.getOperand(1).isUndef() && LHS.getOperand(1).isUndef() && RHS.getOperand(1).isUndef() &&
(LHS.hasOneUse() || RHS.hasOneUse() || LHS == RHS)) { (LHS.hasOneUse() || RHS.hasOneUse() || LHS == RHS)) {
SDLoc DL(N);
SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, LHS.getOperand(0), SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, LHS.getOperand(0),
RHS.getOperand(0), Flags); RHS.getOperand(0), Flags);
SDValue UndefV = LHS.getOperand(1); SDValue UndefV = LHS.getOperand(1);
@ -22326,7 +22324,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
Shuf0->hasOneUse() && Shuf0->getOperand(1).isUndef() && Shuf0->hasOneUse() && Shuf0->getOperand(1).isUndef() &&
Shuf0->getOperand(0).getOpcode() != ISD::INSERT_VECTOR_ELT) { Shuf0->getOperand(0).getOpcode() != ISD::INSERT_VECTOR_ELT) {
// binop (splat X), (splat C) --> splat (binop X, C) // binop (splat X), (splat C) --> splat (binop X, C)
SDLoc DL(N);
SDValue X = Shuf0->getOperand(0); SDValue X = Shuf0->getOperand(0);
SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, X, RHS, Flags); SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, X, RHS, Flags);
return DAG.getVectorShuffle(VT, DL, NewBinOp, DAG.getUNDEF(VT), 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->hasOneUse() && Shuf1->getOperand(1).isUndef() &&
Shuf1->getOperand(0).getOpcode() != ISD::INSERT_VECTOR_ELT) { Shuf1->getOperand(0).getOpcode() != ISD::INSERT_VECTOR_ELT) {
// binop (splat C), (splat X) --> splat (binop C, X) // binop (splat C), (splat X) --> splat (binop C, X)
SDLoc DL(N);
SDValue X = Shuf1->getOperand(0); SDValue X = Shuf1->getOperand(0);
SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, LHS, X, Flags); SDValue NewBinOp = DAG.getNode(Opcode, DL, VT, LHS, X, Flags);
return DAG.getVectorShuffle(VT, DL, NewBinOp, DAG.getUNDEF(VT), return DAG.getVectorShuffle(VT, DL, NewBinOp, DAG.getUNDEF(VT),
@ -22360,7 +22356,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
TLI.isOperationLegalOrCustomOrPromote(Opcode, NarrowVT, TLI.isOperationLegalOrCustomOrPromote(Opcode, NarrowVT,
LegalOperations)) { LegalOperations)) {
// (binop undef, undef) may not return undef, so compute that result. // (binop undef, undef) may not return undef, so compute that result.
SDLoc DL(N);
SDValue VecC = SDValue VecC =
DAG.getNode(Opcode, DL, VT, DAG.getUNDEF(VT), DAG.getUNDEF(VT)); DAG.getNode(Opcode, DL, VT, DAG.getUNDEF(VT), DAG.getUNDEF(VT));
SDValue NarrowBO = DAG.getNode(Opcode, DL, NarrowVT, X, Y); SDValue NarrowBO = DAG.getNode(Opcode, DL, NarrowVT, X, Y);
@ -22387,7 +22382,6 @@ SDValue DAGCombiner::SimplifyVBinOp(SDNode *N) {
EVT NarrowVT = LHS.getOperand(0).getValueType(); EVT NarrowVT = LHS.getOperand(0).getValueType();
if (NarrowVT == RHS.getOperand(0).getValueType() && if (NarrowVT == RHS.getOperand(0).getValueType() &&
TLI.isOperationLegalOrCustomOrPromote(Opcode, NarrowVT)) { TLI.isOperationLegalOrCustomOrPromote(Opcode, NarrowVT)) {
SDLoc DL(N);
unsigned NumOperands = LHS.getNumOperands(); unsigned NumOperands = LHS.getNumOperands();
SmallVector<SDValue, 4> ConcatOps; SmallVector<SDValue, 4> ConcatOps;
for (unsigned i = 0; i != NumOperands; ++i) { 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 V;
return SDValue(); return SDValue();