forked from OSchip/llvm-project
[DebugInfo] Add debug locations to constant SD nodes
This adds debug location to constant nodes of Selection DAG and updates all places that create constants to pass debug locations (see PR13269). Can't guarantee that all locations are correct, but in a lot of cases choice is obvious, so most of them should be. At least all tests pass. Tests for these changes do not cover everything, instead just check it for SDNodes, ARM and AArch64 where it's easy to get incorrect locations on constants. This is not complete fix as FastISel contains workaround for wrong debug locations, which drops locations from instructions on processing constants, but there isn't currently a way to use debug locations from constants there as llvm::Constant doesn't cache it (yet). Although this is a bit different issue, not directly related to these changes. Differential Revision: http://reviews.llvm.org/D9084 llvm-svn: 235977
This commit is contained in:
parent
ba945626b0
commit
adb4c69d5c
|
@ -413,36 +413,40 @@ public:
|
|||
//===--------------------------------------------------------------------===//
|
||||
// Node creation methods.
|
||||
//
|
||||
SDValue getConstant(uint64_t Val, EVT VT, bool isTarget = false,
|
||||
SDValue getConstant(uint64_t Val, SDLoc DL, EVT VT, bool isTarget = false,
|
||||
bool isOpaque = false);
|
||||
SDValue getConstant(const APInt &Val, EVT VT, bool isTarget = false,
|
||||
SDValue getConstant(const APInt &Val, SDLoc DL, EVT VT, bool isTarget = false,
|
||||
bool isOpaque = false);
|
||||
SDValue getConstant(const ConstantInt &Val, EVT VT, bool isTarget = false,
|
||||
bool isOpaque = false);
|
||||
SDValue getIntPtrConstant(uint64_t Val, bool isTarget = false);
|
||||
SDValue getTargetConstant(uint64_t Val, EVT VT, bool isOpaque = false) {
|
||||
return getConstant(Val, VT, true, isOpaque);
|
||||
}
|
||||
SDValue getTargetConstant(const APInt &Val, EVT VT, bool isOpaque = false) {
|
||||
return getConstant(Val, VT, true, isOpaque);
|
||||
}
|
||||
SDValue getTargetConstant(const ConstantInt &Val, EVT VT,
|
||||
SDValue getConstant(const ConstantInt &Val, SDLoc DL, EVT VT,
|
||||
bool isTarget = false, bool isOpaque = false);
|
||||
SDValue getIntPtrConstant(uint64_t Val, SDLoc DL, bool isTarget = false);
|
||||
SDValue getTargetConstant(uint64_t Val, SDLoc DL, EVT VT,
|
||||
bool isOpaque = false) {
|
||||
return getConstant(Val, VT, true, isOpaque);
|
||||
return getConstant(Val, DL, VT, true, isOpaque);
|
||||
}
|
||||
SDValue getTargetConstant(const APInt &Val, SDLoc DL, EVT VT,
|
||||
bool isOpaque = false) {
|
||||
return getConstant(Val, DL, VT, true, isOpaque);
|
||||
}
|
||||
SDValue getTargetConstant(const ConstantInt &Val, SDLoc DL, EVT VT,
|
||||
bool isOpaque = false) {
|
||||
return getConstant(Val, DL, VT, true, isOpaque);
|
||||
}
|
||||
// The forms below that take a double should only be used for simple
|
||||
// constants that can be exactly represented in VT. No checks are made.
|
||||
SDValue getConstantFP(double Val, EVT VT, bool isTarget = false);
|
||||
SDValue getConstantFP(const APFloat& Val, EVT VT, bool isTarget = false);
|
||||
SDValue getConstantFP(const ConstantFP &CF, EVT VT, bool isTarget = false);
|
||||
SDValue getTargetConstantFP(double Val, EVT VT) {
|
||||
return getConstantFP(Val, VT, true);
|
||||
SDValue getConstantFP(double Val, SDLoc DL, EVT VT, bool isTarget = false);
|
||||
SDValue getConstantFP(const APFloat& Val, SDLoc DL, EVT VT,
|
||||
bool isTarget = false);
|
||||
SDValue getConstantFP(const ConstantFP &CF, SDLoc DL, EVT VT,
|
||||
bool isTarget = false);
|
||||
SDValue getTargetConstantFP(double Val, SDLoc DL, EVT VT) {
|
||||
return getConstantFP(Val, DL, VT, true);
|
||||
}
|
||||
SDValue getTargetConstantFP(const APFloat& Val, EVT VT) {
|
||||
return getConstantFP(Val, VT, true);
|
||||
SDValue getTargetConstantFP(const APFloat& Val, SDLoc DL, EVT VT) {
|
||||
return getConstantFP(Val, DL, VT, true);
|
||||
}
|
||||
SDValue getTargetConstantFP(const ConstantFP &Val, EVT VT) {
|
||||
return getConstantFP(Val, VT, true);
|
||||
SDValue getTargetConstantFP(const ConstantFP &Val, SDLoc DL, EVT VT) {
|
||||
return getConstantFP(Val, DL, VT, true);
|
||||
}
|
||||
SDValue getGlobalAddress(const GlobalValue *GV, SDLoc DL, EVT VT,
|
||||
int64_t offset = 0, bool isTargetGA = false,
|
||||
|
@ -1117,7 +1121,7 @@ public:
|
|||
/// either of the specified value types.
|
||||
SDValue CreateStackTemporary(EVT VT1, EVT VT2);
|
||||
|
||||
SDValue FoldConstantArithmetic(unsigned Opcode, EVT VT,
|
||||
SDValue FoldConstantArithmetic(unsigned Opcode, SDLoc DL, EVT VT,
|
||||
SDNode *Cst1, SDNode *Cst2);
|
||||
|
||||
/// Constant fold a setcc to true or false.
|
||||
|
|
|
@ -199,7 +199,7 @@ protected:
|
|||
|
||||
/// SelectInlineAsmMemoryOperands - Calls to this are automatically generated
|
||||
/// by tblgen. Others should not call it.
|
||||
void SelectInlineAsmMemoryOperands(std::vector<SDValue> &Ops);
|
||||
void SelectInlineAsmMemoryOperands(std::vector<SDValue> &Ops, SDLoc DL);
|
||||
|
||||
|
||||
public:
|
||||
|
|
|
@ -1361,9 +1361,10 @@ public:
|
|||
class ConstantSDNode : public SDNode {
|
||||
const ConstantInt *Value;
|
||||
friend class SelectionDAG;
|
||||
ConstantSDNode(bool isTarget, bool isOpaque, const ConstantInt *val, EVT VT)
|
||||
ConstantSDNode(bool isTarget, bool isOpaque, const ConstantInt *val,
|
||||
DebugLoc DL, EVT VT)
|
||||
: SDNode(isTarget ? ISD::TargetConstant : ISD::Constant,
|
||||
0, DebugLoc(), getSDVTList(VT)), Value(val) {
|
||||
0, DL, getSDVTList(VT)), Value(val) {
|
||||
SubclassData |= (uint16_t)isOpaque;
|
||||
}
|
||||
public:
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -249,7 +249,7 @@ SelectionDAGLegalize::ExpandConstantFP(ConstantFPSDNode *CFP, bool UseCP) {
|
|||
ConstantFP *LLVMC = const_cast<ConstantFP*>(CFP->getConstantFPValue());
|
||||
if (!UseCP) {
|
||||
assert((VT == MVT::f64 || VT == MVT::f32) && "Invalid type expansion");
|
||||
return DAG.getConstant(LLVMC->getValueAPF().bitcastToAPInt(),
|
||||
return DAG.getConstant(LLVMC->getValueAPF().bitcastToAPInt(), dl,
|
||||
(VT == MVT::f64) ? MVT::i64 : MVT::i32);
|
||||
}
|
||||
|
||||
|
@ -331,7 +331,7 @@ static void ExpandUnalignedStore(StoreSDNode *ST, SelectionDAG &DAG,
|
|||
SDValue Store = DAG.getTruncStore(Chain, dl,
|
||||
Val, StackPtr, MachinePointerInfo(),
|
||||
StoredVT, false, false, 0);
|
||||
SDValue Increment = DAG.getConstant(RegBytes, TLI.getPointerTy(AS));
|
||||
SDValue Increment = DAG.getConstant(RegBytes, dl, TLI.getPointerTy(AS));
|
||||
SmallVector<SDValue, 8> Stores;
|
||||
unsigned Offset = 0;
|
||||
|
||||
|
@ -385,7 +385,7 @@ static void ExpandUnalignedStore(StoreSDNode *ST, SelectionDAG &DAG,
|
|||
int IncrementSize = NumBits / 8;
|
||||
|
||||
// Divide the stored value in two parts.
|
||||
SDValue ShiftAmount = DAG.getConstant(NumBits,
|
||||
SDValue ShiftAmount = DAG.getConstant(NumBits, dl,
|
||||
TLI.getShiftAmountTy(Val.getValueType()));
|
||||
SDValue Lo = Val;
|
||||
SDValue Hi = DAG.getNode(ISD::SRL, dl, VT, Val, ShiftAmount);
|
||||
|
@ -397,7 +397,7 @@ static void ExpandUnalignedStore(StoreSDNode *ST, SelectionDAG &DAG,
|
|||
ST->isVolatile(), ST->isNonTemporal(), Alignment);
|
||||
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, TLI.getPointerTy(AS)));
|
||||
DAG.getConstant(IncrementSize, dl, TLI.getPointerTy(AS)));
|
||||
Alignment = MinAlign(Alignment, IncrementSize);
|
||||
Store2 = DAG.getTruncStore(Chain, dl, TLI.isLittleEndian()?Hi:Lo, Ptr,
|
||||
ST->getPointerInfo().getWithOffset(IncrementSize),
|
||||
|
@ -448,7 +448,7 @@ ExpandUnalignedLoad(LoadSDNode *LD, SelectionDAG &DAG,
|
|||
// Make sure the stack slot is also aligned for the register type.
|
||||
SDValue StackBase = DAG.CreateStackTemporary(LoadedVT, RegVT);
|
||||
|
||||
SDValue Increment = DAG.getConstant(RegBytes, TLI.getPointerTy());
|
||||
SDValue Increment = DAG.getConstant(RegBytes, dl, TLI.getPointerTy());
|
||||
SmallVector<SDValue, 8> Stores;
|
||||
SDValue StackPtr = StackBase;
|
||||
unsigned Offset = 0;
|
||||
|
@ -528,7 +528,7 @@ ExpandUnalignedLoad(LoadSDNode *LD, SelectionDAG &DAG,
|
|||
LD->isNonTemporal(), LD->isInvariant(), Alignment,
|
||||
LD->getAAInfo());
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getExtLoad(HiExtType, dl, VT, Chain, Ptr,
|
||||
LD->getPointerInfo().getWithOffset(IncrementSize),
|
||||
NewLoadedVT, LD->isVolatile(),
|
||||
|
@ -540,7 +540,7 @@ ExpandUnalignedLoad(LoadSDNode *LD, SelectionDAG &DAG,
|
|||
LD->isNonTemporal(), LD->isInvariant(), Alignment,
|
||||
LD->getAAInfo());
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Lo = DAG.getExtLoad(ISD::ZEXTLOAD, dl, VT, Chain, Ptr,
|
||||
LD->getPointerInfo().getWithOffset(IncrementSize),
|
||||
NewLoadedVT, LD->isVolatile(),
|
||||
|
@ -549,7 +549,7 @@ ExpandUnalignedLoad(LoadSDNode *LD, SelectionDAG &DAG,
|
|||
}
|
||||
|
||||
// aggregate the two parts
|
||||
SDValue ShiftAmount = DAG.getConstant(NumBits,
|
||||
SDValue ShiftAmount = DAG.getConstant(NumBits, dl,
|
||||
TLI.getShiftAmountTy(Hi.getValueType()));
|
||||
SDValue Result = DAG.getNode(ISD::SHL, dl, VT, Hi, ShiftAmount);
|
||||
Result = DAG.getNode(ISD::OR, dl, VT, Result, Lo);
|
||||
|
@ -596,7 +596,8 @@ PerformInsertVectorEltInMemory(SDValue Vec, SDValue Val, SDValue Idx,
|
|||
Tmp3 = DAG.getNode(CastOpc, dl, PtrVT, Tmp3);
|
||||
// Add the offset to the index.
|
||||
unsigned EltSize = EltVT.getSizeInBits()/8;
|
||||
Tmp3 = DAG.getNode(ISD::MUL, dl, IdxVT, Tmp3,DAG.getConstant(EltSize, IdxVT));
|
||||
Tmp3 = DAG.getNode(ISD::MUL, dl, IdxVT, Tmp3,
|
||||
DAG.getConstant(EltSize, dl, IdxVT));
|
||||
SDValue StackPtr2 = DAG.getNode(ISD::ADD, dl, IdxVT, Tmp3, StackPtr);
|
||||
// Store the scalar value.
|
||||
Ch = DAG.getTruncStore(Ch, dl, Tmp2, StackPtr2, MachinePointerInfo(), EltVT,
|
||||
|
@ -655,7 +656,7 @@ SDValue SelectionDAGLegalize::OptimizeFloatStore(StoreSDNode* ST) {
|
|||
TLI.isTypeLegal(MVT::i32)) {
|
||||
SDValue Con = DAG.getConstant(CFP->getValueAPF().
|
||||
bitcastToAPInt().zextOrTrunc(32),
|
||||
MVT::i32);
|
||||
SDLoc(CFP), MVT::i32);
|
||||
return DAG.getStore(Chain, dl, Con, Ptr, ST->getPointerInfo(),
|
||||
isVolatile, isNonTemporal, Alignment, AAInfo);
|
||||
}
|
||||
|
@ -664,7 +665,7 @@ SDValue SelectionDAGLegalize::OptimizeFloatStore(StoreSDNode* ST) {
|
|||
// If this target supports 64-bit registers, do a single 64-bit store.
|
||||
if (TLI.isTypeLegal(MVT::i64)) {
|
||||
SDValue Con = DAG.getConstant(CFP->getValueAPF().bitcastToAPInt().
|
||||
zextOrTrunc(64), MVT::i64);
|
||||
zextOrTrunc(64), SDLoc(CFP), MVT::i64);
|
||||
return DAG.getStore(Chain, dl, Con, Ptr, ST->getPointerInfo(),
|
||||
isVolatile, isNonTemporal, Alignment, AAInfo);
|
||||
}
|
||||
|
@ -673,15 +674,15 @@ SDValue SelectionDAGLegalize::OptimizeFloatStore(StoreSDNode* ST) {
|
|||
// Otherwise, if the target supports 32-bit registers, use 2 32-bit
|
||||
// stores. If the target supports neither 32- nor 64-bits, this
|
||||
// xform is certainly not worth it.
|
||||
const APInt &IntVal =CFP->getValueAPF().bitcastToAPInt();
|
||||
SDValue Lo = DAG.getConstant(IntVal.trunc(32), MVT::i32);
|
||||
SDValue Hi = DAG.getConstant(IntVal.lshr(32).trunc(32), MVT::i32);
|
||||
const APInt &IntVal = CFP->getValueAPF().bitcastToAPInt();
|
||||
SDValue Lo = DAG.getConstant(IntVal.trunc(32), dl, MVT::i32);
|
||||
SDValue Hi = DAG.getConstant(IntVal.lshr(32).trunc(32), dl, MVT::i32);
|
||||
if (TLI.isBigEndian()) std::swap(Lo, Hi);
|
||||
|
||||
Lo = DAG.getStore(Chain, dl, Lo, Ptr, ST->getPointerInfo(), isVolatile,
|
||||
isNonTemporal, Alignment, AAInfo);
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(4, Ptr.getValueType()));
|
||||
DAG.getConstant(4, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getStore(Chain, dl, Hi, Ptr,
|
||||
ST->getPointerInfo().getWithOffset(4),
|
||||
isVolatile, isNonTemporal, MinAlign(Alignment, 4U),
|
||||
|
@ -792,9 +793,10 @@ void SelectionDAGLegalize::LegalizeStoreOps(SDNode *Node) {
|
|||
// Store the remaining ExtraWidth bits.
|
||||
IncrementSize = RoundWidth / 8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl,
|
||||
Ptr.getValueType()));
|
||||
Hi = DAG.getNode(ISD::SRL, dl, Value.getValueType(), Value,
|
||||
DAG.getConstant(RoundWidth,
|
||||
DAG.getConstant(RoundWidth, dl,
|
||||
TLI.getShiftAmountTy(Value.getValueType())));
|
||||
Hi = DAG.getTruncStore(Chain, dl, Hi, Ptr,
|
||||
ST->getPointerInfo().getWithOffset(IncrementSize),
|
||||
|
@ -805,7 +807,7 @@ void SelectionDAGLegalize::LegalizeStoreOps(SDNode *Node) {
|
|||
// TRUNCSTORE:i24 X -> TRUNCSTORE:i16 (srl X, 8), TRUNCSTORE@+2:i8 X
|
||||
// Store the top RoundWidth bits.
|
||||
Hi = DAG.getNode(ISD::SRL, dl, Value.getValueType(), Value,
|
||||
DAG.getConstant(ExtraWidth,
|
||||
DAG.getConstant(ExtraWidth, dl,
|
||||
TLI.getShiftAmountTy(Value.getValueType())));
|
||||
Hi = DAG.getTruncStore(Chain, dl, Hi, Ptr, ST->getPointerInfo(),
|
||||
RoundVT, isVolatile, isNonTemporal, Alignment,
|
||||
|
@ -814,7 +816,8 @@ void SelectionDAGLegalize::LegalizeStoreOps(SDNode *Node) {
|
|||
// Store the remaining ExtraWidth bits.
|
||||
IncrementSize = RoundWidth / 8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl,
|
||||
Ptr.getValueType()));
|
||||
Lo = DAG.getTruncStore(Chain, dl, Value, Ptr,
|
||||
ST->getPointerInfo().getWithOffset(IncrementSize),
|
||||
ExtraVT, isVolatile, isNonTemporal,
|
||||
|
@ -1004,7 +1007,8 @@ void SelectionDAGLegalize::LegalizeLoadOps(SDNode *Node) {
|
|||
// Load the remaining ExtraWidth bits.
|
||||
IncrementSize = RoundWidth / 8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl,
|
||||
Ptr.getValueType()));
|
||||
Hi = DAG.getExtLoad(ExtType, dl, Node->getValueType(0), Chain, Ptr,
|
||||
LD->getPointerInfo().getWithOffset(IncrementSize),
|
||||
ExtraVT, isVolatile, isNonTemporal, isInvariant,
|
||||
|
@ -1017,7 +1021,7 @@ void SelectionDAGLegalize::LegalizeLoadOps(SDNode *Node) {
|
|||
|
||||
// Move the top bits to the right place.
|
||||
Hi = DAG.getNode(ISD::SHL, dl, Hi.getValueType(), Hi,
|
||||
DAG.getConstant(RoundWidth,
|
||||
DAG.getConstant(RoundWidth, dl,
|
||||
TLI.getShiftAmountTy(Hi.getValueType())));
|
||||
|
||||
// Join the hi and lo parts.
|
||||
|
@ -1033,7 +1037,8 @@ void SelectionDAGLegalize::LegalizeLoadOps(SDNode *Node) {
|
|||
// Load the remaining ExtraWidth bits.
|
||||
IncrementSize = RoundWidth / 8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl,
|
||||
Ptr.getValueType()));
|
||||
Lo = DAG.getExtLoad(ISD::ZEXTLOAD,
|
||||
dl, Node->getValueType(0), Chain, Ptr,
|
||||
LD->getPointerInfo().getWithOffset(IncrementSize),
|
||||
|
@ -1047,7 +1052,7 @@ void SelectionDAGLegalize::LegalizeLoadOps(SDNode *Node) {
|
|||
|
||||
// Move the top bits to the right place.
|
||||
Hi = DAG.getNode(ISD::SHL, dl, Hi.getValueType(), Hi,
|
||||
DAG.getConstant(ExtraWidth,
|
||||
DAG.getConstant(ExtraWidth, dl,
|
||||
TLI.getShiftAmountTy(Hi.getValueType())));
|
||||
|
||||
// Join the hi and lo parts.
|
||||
|
@ -1437,7 +1442,7 @@ SDValue SelectionDAGLegalize::ExpandExtractFromVectorThroughStack(SDValue Op) {
|
|||
unsigned EltSize =
|
||||
Vec.getValueType().getVectorElementType().getSizeInBits()/8;
|
||||
Idx = DAG.getNode(ISD::MUL, dl, Idx.getValueType(), Idx,
|
||||
DAG.getConstant(EltSize, Idx.getValueType()));
|
||||
DAG.getConstant(EltSize, SDLoc(Vec), Idx.getValueType()));
|
||||
|
||||
Idx = DAG.getZExtOrTrunc(Idx, dl, TLI.getPointerTy());
|
||||
StackPtr = DAG.getNode(ISD::ADD, dl, Idx.getValueType(), Idx, StackPtr);
|
||||
|
@ -1490,7 +1495,7 @@ SDValue SelectionDAGLegalize::ExpandInsertToVectorThroughStack(SDValue Op) {
|
|||
Vec.getValueType().getVectorElementType().getSizeInBits()/8;
|
||||
|
||||
Idx = DAG.getNode(ISD::MUL, dl, Idx.getValueType(), Idx,
|
||||
DAG.getConstant(EltSize, Idx.getValueType()));
|
||||
DAG.getConstant(EltSize, SDLoc(Vec), Idx.getValueType()));
|
||||
Idx = DAG.getZExtOrTrunc(Idx, dl, TLI.getPointerTy());
|
||||
|
||||
SDValue SubStackPtr = DAG.getNode(ISD::ADD, dl, Idx.getValueType(), Idx,
|
||||
|
@ -1527,7 +1532,7 @@ SDValue SelectionDAGLegalize::ExpandVectorBuildThroughStack(SDNode* Node) {
|
|||
|
||||
unsigned Offset = TypeByteSize*i;
|
||||
|
||||
SDValue Idx = DAG.getConstant(Offset, FIPtr.getValueType());
|
||||
SDValue Idx = DAG.getConstant(Offset, dl, FIPtr.getValueType());
|
||||
Idx = DAG.getNode(ISD::ADD, dl, FIPtr.getValueType(), FIPtr, Idx);
|
||||
|
||||
// If the destination vector element type is narrower than the source
|
||||
|
@ -1589,7 +1594,8 @@ SDValue SelectionDAGLegalize::ExpandFCOPYSIGN(SDNode* Node) {
|
|||
unsigned Strides = (FloatVT.getSizeInBits()-1)/LoadTy.getSizeInBits();
|
||||
unsigned ByteOffset = (Strides * LoadTy.getSizeInBits()) / 8;
|
||||
LoadPtr = DAG.getNode(ISD::ADD, dl, LoadPtr.getValueType(), LoadPtr,
|
||||
DAG.getConstant(ByteOffset, LoadPtr.getValueType()));
|
||||
DAG.getConstant(ByteOffset, dl,
|
||||
LoadPtr.getValueType()));
|
||||
// Load a legal integer containing the sign bit.
|
||||
SignBit = DAG.getLoad(LoadTy, dl, Ch, LoadPtr, MachinePointerInfo(),
|
||||
false, false, false, 0);
|
||||
|
@ -1599,13 +1605,14 @@ SDValue SelectionDAGLegalize::ExpandFCOPYSIGN(SDNode* Node) {
|
|||
assert(BitShift < LoadTy.getSizeInBits() && "Pointer advanced wrong?");
|
||||
if (BitShift)
|
||||
SignBit = DAG.getNode(ISD::SHL, dl, LoadTy, SignBit,
|
||||
DAG.getConstant(BitShift,
|
||||
DAG.getConstant(BitShift, dl,
|
||||
TLI.getShiftAmountTy(SignBit.getValueType())));
|
||||
}
|
||||
}
|
||||
// Now get the sign bit proper, by seeing whether the value is negative.
|
||||
SignBit = DAG.getSetCC(dl, getSetCCResultType(SignBit.getValueType()),
|
||||
SignBit, DAG.getConstant(0, SignBit.getValueType()),
|
||||
SignBit,
|
||||
DAG.getConstant(0, dl, SignBit.getValueType()),
|
||||
ISD::SETLT);
|
||||
// Get the absolute value of the result.
|
||||
SDValue AbsVal = DAG.getNode(ISD::FABS, dl, Tmp1.getValueType(), Tmp1);
|
||||
|
@ -1630,8 +1637,7 @@ void SelectionDAGLegalize::ExpandDYNAMIC_STACKALLOC(SDNode* Node,
|
|||
|
||||
// Chain the dynamic stack allocation so that it doesn't modify the stack
|
||||
// pointer when other instructions are using the stack.
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(0, true),
|
||||
SDLoc(Node));
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(0, dl, true), dl);
|
||||
|
||||
SDValue Size = Tmp2.getOperand(1);
|
||||
SDValue SP = DAG.getCopyFromReg(Chain, dl, SPReg, VT);
|
||||
|
@ -1642,12 +1648,11 @@ void SelectionDAGLegalize::ExpandDYNAMIC_STACKALLOC(SDNode* Node,
|
|||
Tmp1 = DAG.getNode(ISD::SUB, dl, VT, SP, Size); // Value
|
||||
if (Align > StackAlign)
|
||||
Tmp1 = DAG.getNode(ISD::AND, dl, VT, Tmp1,
|
||||
DAG.getConstant(-(uint64_t)Align, VT));
|
||||
DAG.getConstant(-(uint64_t)Align, dl, VT));
|
||||
Chain = DAG.getCopyToReg(Chain, dl, SPReg, Tmp1); // Output chain
|
||||
|
||||
Tmp2 = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(0, true),
|
||||
DAG.getIntPtrConstant(0, true), SDValue(),
|
||||
SDLoc(Node));
|
||||
Tmp2 = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(0, dl, true),
|
||||
DAG.getIntPtrConstant(0, dl, true), SDValue(), dl);
|
||||
|
||||
Results.push_back(Tmp1);
|
||||
Results.push_back(Tmp2);
|
||||
|
@ -2418,7 +2423,8 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
SDValue StackSlot = DAG.CreateStackTemporary(MVT::f64);
|
||||
|
||||
// word offset constant for Hi/Lo address computation
|
||||
SDValue WordOff = DAG.getConstant(sizeof(int), StackSlot.getValueType());
|
||||
SDValue WordOff = DAG.getConstant(sizeof(int), dl,
|
||||
StackSlot.getValueType());
|
||||
// set up Hi and Lo (into buffer) address based on endian
|
||||
SDValue Hi = StackSlot;
|
||||
SDValue Lo = DAG.getNode(ISD::ADD, dl, StackSlot.getValueType(),
|
||||
|
@ -2430,7 +2436,7 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
SDValue Op0Mapped;
|
||||
if (isSigned) {
|
||||
// constant used to invert sign bit (signed to unsigned mapping)
|
||||
SDValue SignBit = DAG.getConstant(0x80000000u, MVT::i32);
|
||||
SDValue SignBit = DAG.getConstant(0x80000000u, dl, MVT::i32);
|
||||
Op0Mapped = DAG.getNode(ISD::XOR, dl, MVT::i32, Op0, SignBit);
|
||||
} else {
|
||||
Op0Mapped = Op0;
|
||||
|
@ -2440,7 +2446,7 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
Op0Mapped, Lo, MachinePointerInfo(),
|
||||
false, false, 0);
|
||||
// initial hi portion of constructed double
|
||||
SDValue InitialHi = DAG.getConstant(0x43300000u, MVT::i32);
|
||||
SDValue InitialHi = DAG.getConstant(0x43300000u, dl, MVT::i32);
|
||||
// store the hi of the constructed double - biased exponent
|
||||
SDValue Store2 = DAG.getStore(Store1, dl, InitialHi, Hi,
|
||||
MachinePointerInfo(),
|
||||
|
@ -2452,7 +2458,7 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
SDValue Bias = DAG.getConstantFP(isSigned ?
|
||||
BitsToDouble(0x4330000080000000ULL) :
|
||||
BitsToDouble(0x4330000000000000ULL),
|
||||
MVT::f64);
|
||||
dl, MVT::f64);
|
||||
// subtract the bias
|
||||
SDValue Sub = DAG.getNode(ISD::FSUB, dl, MVT::f64, Load, Bias);
|
||||
// final result
|
||||
|
@ -2463,7 +2469,7 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
Result = Sub;
|
||||
} else if (DestVT.bitsLT(MVT::f64)) {
|
||||
Result = DAG.getNode(ISD::FP_ROUND, dl, DestVT, Sub,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
} else if (DestVT.bitsGT(MVT::f64)) {
|
||||
Result = DAG.getNode(ISD::FP_EXTEND, dl, DestVT, Sub);
|
||||
}
|
||||
|
@ -2479,15 +2485,16 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
// TODO: Generalize this for use with other types.
|
||||
if (Op0.getValueType() == MVT::i64 && DestVT == MVT::f64) {
|
||||
SDValue TwoP52 =
|
||||
DAG.getConstant(UINT64_C(0x4330000000000000), MVT::i64);
|
||||
DAG.getConstant(UINT64_C(0x4330000000000000), dl, MVT::i64);
|
||||
SDValue TwoP84PlusTwoP52 =
|
||||
DAG.getConstantFP(BitsToDouble(UINT64_C(0x4530000000100000)), MVT::f64);
|
||||
DAG.getConstantFP(BitsToDouble(UINT64_C(0x4530000000100000)), dl,
|
||||
MVT::f64);
|
||||
SDValue TwoP84 =
|
||||
DAG.getConstant(UINT64_C(0x4530000000000000), MVT::i64);
|
||||
DAG.getConstant(UINT64_C(0x4530000000000000), dl, MVT::i64);
|
||||
|
||||
SDValue Lo = DAG.getZeroExtendInReg(Op0, dl, MVT::i32);
|
||||
SDValue Hi = DAG.getNode(ISD::SRL, dl, MVT::i64, Op0,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
SDValue LoOr = DAG.getNode(ISD::OR, dl, MVT::i64, Lo, TwoP52);
|
||||
SDValue HiOr = DAG.getNode(ISD::OR, dl, MVT::i64, Hi, TwoP84);
|
||||
SDValue LoFlt = DAG.getNode(ISD::BITCAST, dl, MVT::f64, LoOr);
|
||||
|
@ -2506,9 +2513,9 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
SDValue Fast = DAG.getNode(ISD::SINT_TO_FP, dl, MVT::f32, Op0);
|
||||
|
||||
SDValue ShiftConst =
|
||||
DAG.getConstant(1, TLI.getShiftAmountTy(Op0.getValueType()));
|
||||
DAG.getConstant(1, dl, TLI.getShiftAmountTy(Op0.getValueType()));
|
||||
SDValue Shr = DAG.getNode(ISD::SRL, dl, MVT::i64, Op0, ShiftConst);
|
||||
SDValue AndConst = DAG.getConstant(1, MVT::i64);
|
||||
SDValue AndConst = DAG.getConstant(1, dl, MVT::i64);
|
||||
SDValue And = DAG.getNode(ISD::AND, dl, MVT::i64, Op0, AndConst);
|
||||
SDValue Or = DAG.getNode(ISD::OR, dl, MVT::i64, And, Shr);
|
||||
|
||||
|
@ -2520,47 +2527,52 @@ SDValue SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
|||
// thing most of the time. This would be a good candidate for a
|
||||
//pseudo-op, or, even better, for whole-function isel.
|
||||
SDValue SignBitTest = DAG.getSetCC(dl, getSetCCResultType(MVT::i64),
|
||||
Op0, DAG.getConstant(0, MVT::i64), ISD::SETLT);
|
||||
Op0, DAG.getConstant(0, dl, MVT::i64), ISD::SETLT);
|
||||
return DAG.getSelect(dl, MVT::f32, SignBitTest, Slow, Fast);
|
||||
}
|
||||
|
||||
// Otherwise, implement the fully general conversion.
|
||||
|
||||
SDValue And = DAG.getNode(ISD::AND, dl, MVT::i64, Op0,
|
||||
DAG.getConstant(UINT64_C(0xfffffffffffff800), MVT::i64));
|
||||
DAG.getConstant(UINT64_C(0xfffffffffffff800), dl, MVT::i64));
|
||||
SDValue Or = DAG.getNode(ISD::OR, dl, MVT::i64, And,
|
||||
DAG.getConstant(UINT64_C(0x800), MVT::i64));
|
||||
DAG.getConstant(UINT64_C(0x800), dl, MVT::i64));
|
||||
SDValue And2 = DAG.getNode(ISD::AND, dl, MVT::i64, Op0,
|
||||
DAG.getConstant(UINT64_C(0x7ff), MVT::i64));
|
||||
SDValue Ne = DAG.getSetCC(dl, getSetCCResultType(MVT::i64),
|
||||
And2, DAG.getConstant(UINT64_C(0), MVT::i64), ISD::SETNE);
|
||||
DAG.getConstant(UINT64_C(0x7ff), dl, MVT::i64));
|
||||
SDValue Ne = DAG.getSetCC(dl, getSetCCResultType(MVT::i64), And2,
|
||||
DAG.getConstant(UINT64_C(0), dl, MVT::i64),
|
||||
ISD::SETNE);
|
||||
SDValue Sel = DAG.getSelect(dl, MVT::i64, Ne, Or, Op0);
|
||||
SDValue Ge = DAG.getSetCC(dl, getSetCCResultType(MVT::i64),
|
||||
Op0, DAG.getConstant(UINT64_C(0x0020000000000000), MVT::i64),
|
||||
ISD::SETUGE);
|
||||
SDValue Ge = DAG.getSetCC(dl, getSetCCResultType(MVT::i64), Op0,
|
||||
DAG.getConstant(UINT64_C(0x0020000000000000), dl,
|
||||
MVT::i64),
|
||||
ISD::SETUGE);
|
||||
SDValue Sel2 = DAG.getSelect(dl, MVT::i64, Ge, Sel, Op0);
|
||||
EVT SHVT = TLI.getShiftAmountTy(Sel2.getValueType());
|
||||
|
||||
SDValue Sh = DAG.getNode(ISD::SRL, dl, MVT::i64, Sel2,
|
||||
DAG.getConstant(32, SHVT));
|
||||
DAG.getConstant(32, dl, SHVT));
|
||||
SDValue Trunc = DAG.getNode(ISD::TRUNCATE, dl, MVT::i32, Sh);
|
||||
SDValue Fcvt = DAG.getNode(ISD::UINT_TO_FP, dl, MVT::f64, Trunc);
|
||||
SDValue TwoP32 =
|
||||
DAG.getConstantFP(BitsToDouble(UINT64_C(0x41f0000000000000)), MVT::f64);
|
||||
DAG.getConstantFP(BitsToDouble(UINT64_C(0x41f0000000000000)), dl,
|
||||
MVT::f64);
|
||||
SDValue Fmul = DAG.getNode(ISD::FMUL, dl, MVT::f64, TwoP32, Fcvt);
|
||||
SDValue Lo = DAG.getNode(ISD::TRUNCATE, dl, MVT::i32, Sel2);
|
||||
SDValue Fcvt2 = DAG.getNode(ISD::UINT_TO_FP, dl, MVT::f64, Lo);
|
||||
SDValue Fadd = DAG.getNode(ISD::FADD, dl, MVT::f64, Fmul, Fcvt2);
|
||||
return DAG.getNode(ISD::FP_ROUND, dl, MVT::f32, Fadd,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
}
|
||||
|
||||
SDValue Tmp1 = DAG.getNode(ISD::SINT_TO_FP, dl, DestVT, Op0);
|
||||
|
||||
SDValue SignSet = DAG.getSetCC(dl, getSetCCResultType(Op0.getValueType()),
|
||||
Op0, DAG.getConstant(0, Op0.getValueType()),
|
||||
Op0,
|
||||
DAG.getConstant(0, dl, Op0.getValueType()),
|
||||
ISD::SETLT);
|
||||
SDValue Zero = DAG.getIntPtrConstant(0), Four = DAG.getIntPtrConstant(4);
|
||||
SDValue Zero = DAG.getIntPtrConstant(0, dl),
|
||||
Four = DAG.getIntPtrConstant(4, dl);
|
||||
SDValue CstOffset = DAG.getSelect(dl, Zero.getValueType(),
|
||||
SignSet, Four, Zero);
|
||||
|
||||
|
@ -2695,34 +2707,41 @@ SDValue SelectionDAGLegalize::ExpandBSWAP(SDValue Op, SDLoc dl) {
|
|||
switch (VT.getSimpleVT().SimpleTy) {
|
||||
default: llvm_unreachable("Unhandled Expand type in BSWAP!");
|
||||
case MVT::i16:
|
||||
Tmp2 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(8, SHVT));
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(8, SHVT));
|
||||
Tmp2 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(8, dl, SHVT));
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(8, dl, SHVT));
|
||||
return DAG.getNode(ISD::OR, dl, VT, Tmp1, Tmp2);
|
||||
case MVT::i32:
|
||||
Tmp4 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(24, SHVT));
|
||||
Tmp3 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(8, SHVT));
|
||||
Tmp2 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(8, SHVT));
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(24, SHVT));
|
||||
Tmp3 = DAG.getNode(ISD::AND, dl, VT, Tmp3, DAG.getConstant(0xFF0000, VT));
|
||||
Tmp2 = DAG.getNode(ISD::AND, dl, VT, Tmp2, DAG.getConstant(0xFF00, VT));
|
||||
Tmp4 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(24, dl, SHVT));
|
||||
Tmp3 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(8, dl, SHVT));
|
||||
Tmp2 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(8, dl, SHVT));
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(24, dl, SHVT));
|
||||
Tmp3 = DAG.getNode(ISD::AND, dl, VT, Tmp3,
|
||||
DAG.getConstant(0xFF0000, dl, VT));
|
||||
Tmp2 = DAG.getNode(ISD::AND, dl, VT, Tmp2, DAG.getConstant(0xFF00, dl, VT));
|
||||
Tmp4 = DAG.getNode(ISD::OR, dl, VT, Tmp4, Tmp3);
|
||||
Tmp2 = DAG.getNode(ISD::OR, dl, VT, Tmp2, Tmp1);
|
||||
return DAG.getNode(ISD::OR, dl, VT, Tmp4, Tmp2);
|
||||
case MVT::i64:
|
||||
Tmp8 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(56, SHVT));
|
||||
Tmp7 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(40, SHVT));
|
||||
Tmp6 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(24, SHVT));
|
||||
Tmp5 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(8, SHVT));
|
||||
Tmp4 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(8, SHVT));
|
||||
Tmp3 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(24, SHVT));
|
||||
Tmp2 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(40, SHVT));
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(56, SHVT));
|
||||
Tmp7 = DAG.getNode(ISD::AND, dl, VT, Tmp7, DAG.getConstant(255ULL<<48, VT));
|
||||
Tmp6 = DAG.getNode(ISD::AND, dl, VT, Tmp6, DAG.getConstant(255ULL<<40, VT));
|
||||
Tmp5 = DAG.getNode(ISD::AND, dl, VT, Tmp5, DAG.getConstant(255ULL<<32, VT));
|
||||
Tmp4 = DAG.getNode(ISD::AND, dl, VT, Tmp4, DAG.getConstant(255ULL<<24, VT));
|
||||
Tmp3 = DAG.getNode(ISD::AND, dl, VT, Tmp3, DAG.getConstant(255ULL<<16, VT));
|
||||
Tmp2 = DAG.getNode(ISD::AND, dl, VT, Tmp2, DAG.getConstant(255ULL<<8 , VT));
|
||||
Tmp8 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(56, dl, SHVT));
|
||||
Tmp7 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(40, dl, SHVT));
|
||||
Tmp6 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(24, dl, SHVT));
|
||||
Tmp5 = DAG.getNode(ISD::SHL, dl, VT, Op, DAG.getConstant(8, dl, SHVT));
|
||||
Tmp4 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(8, dl, SHVT));
|
||||
Tmp3 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(24, dl, SHVT));
|
||||
Tmp2 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(40, dl, SHVT));
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, VT, Op, DAG.getConstant(56, dl, SHVT));
|
||||
Tmp7 = DAG.getNode(ISD::AND, dl, VT, Tmp7,
|
||||
DAG.getConstant(255ULL<<48, dl, VT));
|
||||
Tmp6 = DAG.getNode(ISD::AND, dl, VT, Tmp6,
|
||||
DAG.getConstant(255ULL<<40, dl, VT));
|
||||
Tmp5 = DAG.getNode(ISD::AND, dl, VT, Tmp5,
|
||||
DAG.getConstant(255ULL<<32, dl, VT));
|
||||
Tmp4 = DAG.getNode(ISD::AND, dl, VT, Tmp4,
|
||||
DAG.getConstant(255ULL<<24, dl, VT));
|
||||
Tmp3 = DAG.getNode(ISD::AND, dl, VT, Tmp3,
|
||||
DAG.getConstant(255ULL<<16, dl, VT));
|
||||
Tmp2 = DAG.getNode(ISD::AND, dl, VT, Tmp2,
|
||||
DAG.getConstant(255ULL<<8 , dl, VT));
|
||||
Tmp8 = DAG.getNode(ISD::OR, dl, VT, Tmp8, Tmp7);
|
||||
Tmp6 = DAG.getNode(ISD::OR, dl, VT, Tmp6, Tmp5);
|
||||
Tmp4 = DAG.getNode(ISD::OR, dl, VT, Tmp4, Tmp3);
|
||||
|
@ -2749,34 +2768,38 @@ SDValue SelectionDAGLegalize::ExpandBitCount(unsigned Opc, SDValue Op,
|
|||
// This is the "best" algorithm from
|
||||
// http://graphics.stanford.edu/~seander/bithacks.html#CountBitsSetParallel
|
||||
|
||||
SDValue Mask55 = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x55)), VT);
|
||||
SDValue Mask33 = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x33)), VT);
|
||||
SDValue Mask0F = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x0F)), VT);
|
||||
SDValue Mask01 = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x01)), VT);
|
||||
SDValue Mask55 = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x55)),
|
||||
dl, VT);
|
||||
SDValue Mask33 = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x33)),
|
||||
dl, VT);
|
||||
SDValue Mask0F = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x0F)),
|
||||
dl, VT);
|
||||
SDValue Mask01 = DAG.getConstant(APInt::getSplat(Len, APInt(8, 0x01)),
|
||||
dl, VT);
|
||||
|
||||
// v = v - ((v >> 1) & 0x55555555...)
|
||||
Op = DAG.getNode(ISD::SUB, dl, VT, Op,
|
||||
DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNode(ISD::SRL, dl, VT, Op,
|
||||
DAG.getConstant(1, ShVT)),
|
||||
DAG.getConstant(1, dl, ShVT)),
|
||||
Mask55));
|
||||
// v = (v & 0x33333333...) + ((v >> 2) & 0x33333333...)
|
||||
Op = DAG.getNode(ISD::ADD, dl, VT,
|
||||
DAG.getNode(ISD::AND, dl, VT, Op, Mask33),
|
||||
DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNode(ISD::SRL, dl, VT, Op,
|
||||
DAG.getConstant(2, ShVT)),
|
||||
DAG.getConstant(2, dl, ShVT)),
|
||||
Mask33));
|
||||
// v = (v + (v >> 4)) & 0x0F0F0F0F...
|
||||
Op = DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNode(ISD::ADD, dl, VT, Op,
|
||||
DAG.getNode(ISD::SRL, dl, VT, Op,
|
||||
DAG.getConstant(4, ShVT))),
|
||||
DAG.getConstant(4, dl, ShVT))),
|
||||
Mask0F);
|
||||
// v = (v * 0x01010101...) >> (Len - 8)
|
||||
Op = DAG.getNode(ISD::SRL, dl, VT,
|
||||
DAG.getNode(ISD::MUL, dl, VT, Op, Mask01),
|
||||
DAG.getConstant(Len - 8, ShVT));
|
||||
DAG.getConstant(Len - 8, dl, ShVT));
|
||||
|
||||
return Op;
|
||||
}
|
||||
|
@ -2797,7 +2820,7 @@ SDValue SelectionDAGLegalize::ExpandBitCount(unsigned Opc, SDValue Op,
|
|||
EVT ShVT = TLI.getShiftAmountTy(VT);
|
||||
unsigned len = VT.getSizeInBits();
|
||||
for (unsigned i = 0; (1U << i) <= (len / 2); ++i) {
|
||||
SDValue Tmp3 = DAG.getConstant(1ULL << i, ShVT);
|
||||
SDValue Tmp3 = DAG.getConstant(1ULL << i, dl, ShVT);
|
||||
Op = DAG.getNode(ISD::OR, dl, VT, Op,
|
||||
DAG.getNode(ISD::SRL, dl, VT, Op, Tmp3));
|
||||
}
|
||||
|
@ -2816,12 +2839,12 @@ SDValue SelectionDAGLegalize::ExpandBitCount(unsigned Opc, SDValue Op,
|
|||
SDValue Tmp3 = DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNOT(dl, Op, VT),
|
||||
DAG.getNode(ISD::SUB, dl, VT, Op,
|
||||
DAG.getConstant(1, VT)));
|
||||
DAG.getConstant(1, dl, VT)));
|
||||
// If ISD::CTLZ is legal and CTPOP isn't, then do that instead.
|
||||
if (!TLI.isOperationLegalOrCustom(ISD::CTPOP, VT) &&
|
||||
TLI.isOperationLegalOrCustom(ISD::CTLZ, VT))
|
||||
return DAG.getNode(ISD::SUB, dl, VT,
|
||||
DAG.getConstant(VT.getSizeInBits(), VT),
|
||||
DAG.getConstant(VT.getSizeInBits(), dl, VT),
|
||||
DAG.getNode(ISD::CTLZ, dl, VT, Tmp3));
|
||||
return DAG.getNode(ISD::CTPOP, dl, VT, Tmp3);
|
||||
}
|
||||
|
@ -2857,10 +2880,10 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
case ISD::FRAMEADDR:
|
||||
case ISD::RETURNADDR:
|
||||
case ISD::FRAME_TO_ARGS_OFFSET:
|
||||
Results.push_back(DAG.getConstant(0, Node->getValueType(0)));
|
||||
Results.push_back(DAG.getConstant(0, dl, Node->getValueType(0)));
|
||||
break;
|
||||
case ISD::FLT_ROUNDS_:
|
||||
Results.push_back(DAG.getConstant(1, Node->getValueType(0)));
|
||||
Results.push_back(DAG.getConstant(1, dl, Node->getValueType(0)));
|
||||
break;
|
||||
case ISD::EH_RETURN:
|
||||
case ISD::EH_LABEL:
|
||||
|
@ -2874,7 +2897,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
case ISD::EH_SJLJ_SETJMP:
|
||||
// If the target didn't expand this, just return 'zero' and preserve the
|
||||
// chain.
|
||||
Results.push_back(DAG.getConstant(0, MVT::i32));
|
||||
Results.push_back(DAG.getConstant(0, dl, MVT::i32));
|
||||
Results.push_back(Node->getOperand(0));
|
||||
break;
|
||||
case ISD::ATOMIC_FENCE: {
|
||||
|
@ -2895,7 +2918,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
}
|
||||
case ISD::ATOMIC_LOAD: {
|
||||
// There is no libcall for atomic load; fake it with ATOMIC_CMP_SWAP.
|
||||
SDValue Zero = DAG.getConstant(0, Node->getValueType(0));
|
||||
SDValue Zero = DAG.getConstant(0, dl, Node->getValueType(0));
|
||||
SDVTList VTs = DAG.getVTList(Node->getValueType(0), MVT::Other);
|
||||
SDValue Swap = DAG.getAtomicCmpSwap(
|
||||
ISD::ATOMIC_CMP_SWAP, dl, cast<AtomicSDNode>(Node)->getMemoryVT(), VTs,
|
||||
|
@ -2971,10 +2994,10 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
case ISD::UNDEF: {
|
||||
EVT VT = Node->getValueType(0);
|
||||
if (VT.isInteger())
|
||||
Results.push_back(DAG.getConstant(0, VT));
|
||||
Results.push_back(DAG.getConstant(0, dl, VT));
|
||||
else {
|
||||
assert(VT.isFloatingPoint() && "Unknown value type!");
|
||||
Results.push_back(DAG.getConstantFP(0, VT));
|
||||
Results.push_back(DAG.getConstantFP(0, dl, VT));
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -3013,7 +3036,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
ShiftAmountTy = VT;
|
||||
unsigned BitsDiff = VT.getScalarType().getSizeInBits() -
|
||||
ExtraVT.getScalarType().getSizeInBits();
|
||||
SDValue ShiftCst = DAG.getConstant(BitsDiff, ShiftAmountTy);
|
||||
SDValue ShiftCst = DAG.getConstant(BitsDiff, dl, ShiftAmountTy);
|
||||
Tmp1 = DAG.getNode(ISD::SHL, dl, Node->getValueType(0),
|
||||
Node->getOperand(0), ShiftCst);
|
||||
Tmp1 = DAG.getNode(ISD::SRA, dl, Node->getValueType(0), Tmp1, ShiftCst);
|
||||
|
@ -3051,7 +3074,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
APInt::getNullValue(VT.getSizeInBits()));
|
||||
APInt x = APInt::getSignBit(NVT.getSizeInBits());
|
||||
(void)apf.convertFromAPInt(x, false, APFloat::rmNearestTiesToEven);
|
||||
Tmp1 = DAG.getConstantFP(apf, VT);
|
||||
Tmp1 = DAG.getConstantFP(apf, dl, VT);
|
||||
Tmp2 = DAG.getSetCC(dl, getSetCCResultType(VT),
|
||||
Node->getOperand(0),
|
||||
Tmp1, ISD::SETLT);
|
||||
|
@ -3060,7 +3083,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
DAG.getNode(ISD::FSUB, dl, VT,
|
||||
Node->getOperand(0), Tmp1));
|
||||
False = DAG.getNode(ISD::XOR, dl, NVT, False,
|
||||
DAG.getConstant(x, NVT));
|
||||
DAG.getConstant(x, dl, NVT));
|
||||
Tmp1 = DAG.getSelect(dl, NVT, Tmp2, True, False);
|
||||
Results.push_back(Tmp1);
|
||||
break;
|
||||
|
@ -3081,11 +3104,11 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
assert(((Align & (Align-1)) == 0) && "Expected Align to be a power of 2");
|
||||
|
||||
VAList = DAG.getNode(ISD::ADD, dl, VAList.getValueType(), VAList,
|
||||
DAG.getConstant(Align - 1,
|
||||
DAG.getConstant(Align - 1, dl,
|
||||
VAList.getValueType()));
|
||||
|
||||
VAList = DAG.getNode(ISD::AND, dl, VAList.getValueType(), VAList,
|
||||
DAG.getConstant(-(int64_t)Align,
|
||||
DAG.getConstant(-(int64_t)Align, dl,
|
||||
VAList.getValueType()));
|
||||
}
|
||||
|
||||
|
@ -3093,6 +3116,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
Tmp3 = DAG.getNode(ISD::ADD, dl, VAList.getValueType(), VAList,
|
||||
DAG.getConstant(TLI.getDataLayout()->
|
||||
getTypeAllocSize(VT.getTypeForEVT(*DAG.getContext())),
|
||||
dl,
|
||||
VAList.getValueType()));
|
||||
// Store the incremented VAList to the legalized pointer
|
||||
Tmp3 = DAG.getStore(VAListLoad.getValue(1), dl, Tmp3, Tmp2,
|
||||
|
@ -3207,11 +3231,11 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
if (Idx < NumElems)
|
||||
Ops.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT,
|
||||
Op0,
|
||||
DAG.getConstant(Idx, TLI.getVectorIdxTy())));
|
||||
DAG.getConstant(Idx, dl, TLI.getVectorIdxTy())));
|
||||
else
|
||||
Ops.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT,
|
||||
Op1,
|
||||
DAG.getConstant(Idx - NumElems,
|
||||
DAG.getConstant(Idx - NumElems, dl,
|
||||
TLI.getVectorIdxTy())));
|
||||
}
|
||||
|
||||
|
@ -3226,7 +3250,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
if (cast<ConstantSDNode>(Node->getOperand(1))->getZExtValue()) {
|
||||
// 1 -> Hi
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, OpTy, Node->getOperand(0),
|
||||
DAG.getConstant(OpTy.getSizeInBits()/2,
|
||||
DAG.getConstant(OpTy.getSizeInBits()/2, dl,
|
||||
TLI.getShiftAmountTy(Node->getOperand(0).getValueType())));
|
||||
Tmp1 = DAG.getNode(ISD::TRUNCATE, dl, Node->getValueType(0), Tmp1);
|
||||
} else {
|
||||
|
@ -3264,7 +3288,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
break;
|
||||
case ISD::FNEG:
|
||||
// Expand Y = FNEG(X) -> Y = SUB -0.0, X
|
||||
Tmp1 = DAG.getConstantFP(-0.0, Node->getValueType(0));
|
||||
Tmp1 = DAG.getConstantFP(-0.0, dl, Node->getValueType(0));
|
||||
Tmp1 = DAG.getNode(ISD::FSUB, dl, Node->getValueType(0), Tmp1,
|
||||
Node->getOperand(0));
|
||||
Results.push_back(Tmp1);
|
||||
|
@ -3273,7 +3297,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
// Expand Y = FABS(X) -> Y = (X >u 0.0) ? X : fneg(X).
|
||||
EVT VT = Node->getValueType(0);
|
||||
Tmp1 = Node->getOperand(0);
|
||||
Tmp2 = DAG.getConstantFP(0.0, VT);
|
||||
Tmp2 = DAG.getConstantFP(0.0, dl, VT);
|
||||
Tmp2 = DAG.getSetCC(dl, getSetCCResultType(Tmp1.getValueType()),
|
||||
Tmp1, Tmp2, ISD::SETUGT);
|
||||
Tmp3 = DAG.getNode(ISD::FNEG, dl, VT, Tmp1);
|
||||
|
@ -3446,7 +3470,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
// Under fastmath, we can expand this node into a fround followed by
|
||||
// a float-half conversion.
|
||||
SDValue FloatVal = DAG.getNode(ISD::FP_ROUND, dl, MVT::f32, Op,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
Results.push_back(
|
||||
DAG.getNode(ISD::FP_TO_FP16, dl, MVT::i16, FloatVal));
|
||||
break;
|
||||
|
@ -3487,8 +3511,9 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
TLI.isOperationLegalOrCustom(ISD::XOR, VT) &&
|
||||
"Don't know how to expand this subtraction!");
|
||||
Tmp1 = DAG.getNode(ISD::XOR, dl, VT, Node->getOperand(1),
|
||||
DAG.getConstant(APInt::getAllOnesValue(VT.getSizeInBits()), VT));
|
||||
Tmp1 = DAG.getNode(ISD::ADD, dl, VT, Tmp1, DAG.getConstant(1, VT));
|
||||
DAG.getConstant(APInt::getAllOnesValue(VT.getSizeInBits()), dl,
|
||||
VT));
|
||||
Tmp1 = DAG.getNode(ISD::ADD, dl, VT, Tmp1, DAG.getConstant(1, dl, VT));
|
||||
Results.push_back(DAG.getNode(ISD::ADD, dl, VT, Node->getOperand(0), Tmp1));
|
||||
break;
|
||||
}
|
||||
|
@ -3604,7 +3629,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
TLI.expandMUL(Node, Lo, Hi, HalfType, DAG)) {
|
||||
Lo = DAG.getNode(ISD::ZERO_EXTEND, dl, VT, Lo);
|
||||
Hi = DAG.getNode(ISD::ANY_EXTEND, dl, VT, Hi);
|
||||
SDValue Shift = DAG.getConstant(HalfType.getSizeInBits(),
|
||||
SDValue Shift = DAG.getConstant(HalfType.getSizeInBits(), dl,
|
||||
TLI.getShiftAmountTy(HalfType));
|
||||
Hi = DAG.getNode(ISD::SHL, dl, VT, Hi, Shift);
|
||||
Results.push_back(DAG.getNode(ISD::OR, dl, VT, Lo, Hi));
|
||||
|
@ -3629,7 +3654,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
EVT ResultType = Node->getValueType(1);
|
||||
EVT OType = getSetCCResultType(Node->getValueType(0));
|
||||
|
||||
SDValue Zero = DAG.getConstant(0, LHS.getValueType());
|
||||
SDValue Zero = DAG.getConstant(0, dl, LHS.getValueType());
|
||||
|
||||
// LHSSign -> LHS >= 0
|
||||
// RHSSign -> RHS >= 0
|
||||
|
@ -3695,9 +3720,9 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
RHS = DAG.getNode(Ops[isSigned][2], dl, WideVT, RHS);
|
||||
Tmp1 = DAG.getNode(ISD::MUL, dl, WideVT, LHS, RHS);
|
||||
BottomHalf = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, VT, Tmp1,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
TopHalf = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, VT, Tmp1,
|
||||
DAG.getIntPtrConstant(1));
|
||||
DAG.getIntPtrConstant(1, dl));
|
||||
} else {
|
||||
// We can fall back to a libcall with an illegal type for the MUL if we
|
||||
// have a libcall big enough.
|
||||
|
@ -3718,9 +3743,11 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
// part.
|
||||
unsigned LoSize = VT.getSizeInBits();
|
||||
SDValue HiLHS = DAG.getNode(ISD::SRA, dl, VT, RHS,
|
||||
DAG.getConstant(LoSize-1, TLI.getPointerTy()));
|
||||
DAG.getConstant(LoSize - 1, dl,
|
||||
TLI.getPointerTy()));
|
||||
SDValue HiRHS = DAG.getNode(ISD::SRA, dl, VT, LHS,
|
||||
DAG.getConstant(LoSize-1, TLI.getPointerTy()));
|
||||
DAG.getConstant(LoSize - 1, dl,
|
||||
TLI.getPointerTy()));
|
||||
|
||||
// Here we're passing the 2 arguments explicitly as 4 arguments that are
|
||||
// pre-lowered to the correct types. This all depends upon WideVT not
|
||||
|
@ -3729,9 +3756,9 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
SDValue Args[] = { LHS, HiLHS, RHS, HiRHS };
|
||||
SDValue Ret = ExpandLibCall(LC, WideVT, Args, 4, isSigned, dl);
|
||||
BottomHalf = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, VT, Ret,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
TopHalf = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, VT, Ret,
|
||||
DAG.getIntPtrConstant(1));
|
||||
DAG.getIntPtrConstant(1, dl));
|
||||
// Ret is a node with an illegal type. Because such things are not
|
||||
// generally permitted during this phase of legalization, make sure the
|
||||
// node has no more uses. The above EXTRACT_ELEMENT nodes should have been
|
||||
|
@ -3741,14 +3768,14 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
}
|
||||
|
||||
if (isSigned) {
|
||||
Tmp1 = DAG.getConstant(VT.getSizeInBits() - 1,
|
||||
Tmp1 = DAG.getConstant(VT.getSizeInBits() - 1, dl,
|
||||
TLI.getShiftAmountTy(BottomHalf.getValueType()));
|
||||
Tmp1 = DAG.getNode(ISD::SRA, dl, VT, BottomHalf, Tmp1);
|
||||
TopHalf = DAG.getSetCC(dl, getSetCCResultType(VT), TopHalf, Tmp1,
|
||||
ISD::SETNE);
|
||||
} else {
|
||||
TopHalf = DAG.getSetCC(dl, getSetCCResultType(VT), TopHalf,
|
||||
DAG.getConstant(0, VT), ISD::SETNE);
|
||||
DAG.getConstant(0, dl, VT), ISD::SETNE);
|
||||
}
|
||||
Results.push_back(BottomHalf);
|
||||
Results.push_back(TopHalf);
|
||||
|
@ -3759,7 +3786,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
Tmp1 = DAG.getNode(ISD::ZERO_EXTEND, dl, PairTy, Node->getOperand(0));
|
||||
Tmp2 = DAG.getNode(ISD::ANY_EXTEND, dl, PairTy, Node->getOperand(1));
|
||||
Tmp2 = DAG.getNode(ISD::SHL, dl, PairTy, Tmp2,
|
||||
DAG.getConstant(PairTy.getSizeInBits()/2,
|
||||
DAG.getConstant(PairTy.getSizeInBits()/2, dl,
|
||||
TLI.getShiftAmountTy(PairTy)));
|
||||
Results.push_back(DAG.getNode(ISD::OR, dl, PairTy, Tmp1, Tmp2));
|
||||
break;
|
||||
|
@ -3774,7 +3801,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
cast<CondCodeSDNode>(Tmp1.getOperand(2))->get());
|
||||
} else {
|
||||
Tmp1 = DAG.getSelectCC(dl, Tmp1,
|
||||
DAG.getConstant(0, Tmp1.getValueType()),
|
||||
DAG.getConstant(0, dl, Tmp1.getValueType()),
|
||||
Tmp2, Tmp3, ISD::SETNE);
|
||||
}
|
||||
Results.push_back(Tmp1);
|
||||
|
@ -3790,8 +3817,8 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
unsigned EntrySize =
|
||||
DAG.getMachineFunction().getJumpTableInfo()->getEntrySize(TD);
|
||||
|
||||
Index = DAG.getNode(ISD::MUL, dl, Index.getValueType(),
|
||||
Index, DAG.getConstant(EntrySize, Index.getValueType()));
|
||||
Index = DAG.getNode(ISD::MUL, dl, Index.getValueType(), Index,
|
||||
DAG.getConstant(EntrySize, dl, Index.getValueType()));
|
||||
SDValue Addr = DAG.getNode(ISD::ADD, dl, Index.getValueType(),
|
||||
Index, Table);
|
||||
|
||||
|
@ -3825,10 +3852,10 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
// We test only the i1 bit. Skip the AND if UNDEF.
|
||||
Tmp3 = (Tmp2.getOpcode() == ISD::UNDEF) ? Tmp2 :
|
||||
DAG.getNode(ISD::AND, dl, Tmp2.getValueType(), Tmp2,
|
||||
DAG.getConstant(1, Tmp2.getValueType()));
|
||||
DAG.getConstant(1, dl, Tmp2.getValueType()));
|
||||
Tmp1 = DAG.getNode(ISD::BR_CC, dl, MVT::Other, Tmp1,
|
||||
DAG.getCondCode(ISD::SETNE), Tmp3,
|
||||
DAG.getConstant(0, Tmp3.getValueType()),
|
||||
DAG.getConstant(0, dl, Tmp3.getValueType()),
|
||||
Node->getOperand(2));
|
||||
}
|
||||
Results.push_back(Tmp1);
|
||||
|
@ -3870,7 +3897,8 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
break;
|
||||
}
|
||||
Tmp1 = DAG.getNode(ISD::SELECT_CC, dl, VT, Tmp1, Tmp2,
|
||||
DAG.getConstant(TrueValue, VT), DAG.getConstant(0, VT),
|
||||
DAG.getConstant(TrueValue, dl, VT),
|
||||
DAG.getConstant(0, dl, VT),
|
||||
Tmp3);
|
||||
Results.push_back(Tmp1);
|
||||
break;
|
||||
|
@ -3938,7 +3966,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
Tmp1 = DAG.getNode(ISD::SELECT_CC, dl, Node->getValueType(0),
|
||||
Tmp1, Tmp2, Tmp3, Tmp4, CC);
|
||||
} else {
|
||||
Tmp2 = DAG.getConstant(0, Tmp1.getValueType());
|
||||
Tmp2 = DAG.getConstant(0, dl, Tmp1.getValueType());
|
||||
CC = DAG.getCondCode(ISD::SETNE);
|
||||
Tmp1 = DAG.getNode(ISD::SELECT_CC, dl, Node->getValueType(0), Tmp1,
|
||||
Tmp2, Tmp3, Tmp4, CC);
|
||||
|
@ -3969,7 +3997,7 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
Tmp1 = DAG.getNode(ISD::BR_CC, dl, Node->getValueType(0), Tmp1,
|
||||
Tmp4, Tmp2, Tmp3, Node->getOperand(4));
|
||||
} else {
|
||||
Tmp3 = DAG.getConstant(0, Tmp2.getValueType());
|
||||
Tmp3 = DAG.getConstant(0, dl, Tmp2.getValueType());
|
||||
Tmp4 = DAG.getCondCode(ISD::SETNE);
|
||||
Tmp1 = DAG.getNode(ISD::BR_CC, dl, Node->getValueType(0), Tmp1, Tmp4,
|
||||
Tmp2, Tmp3, Node->getOperand(4));
|
||||
|
@ -3993,12 +4021,12 @@ void SelectionDAGLegalize::ExpandNode(SDNode *Node) {
|
|||
for (unsigned Idx = 0; Idx < NumElem; Idx++) {
|
||||
SDValue Ex = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
VT.getScalarType(),
|
||||
Node->getOperand(0), DAG.getConstant(Idx,
|
||||
TLI.getVectorIdxTy()));
|
||||
Node->getOperand(0),
|
||||
DAG.getConstant(Idx, dl, TLI.getVectorIdxTy()));
|
||||
SDValue Sh = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
VT.getScalarType(),
|
||||
Node->getOperand(1), DAG.getConstant(Idx,
|
||||
TLI.getVectorIdxTy()));
|
||||
Node->getOperand(1),
|
||||
DAG.getConstant(Idx, dl, TLI.getVectorIdxTy()));
|
||||
Scalars.push_back(DAG.getNode(Node->getOpcode(), dl,
|
||||
VT.getScalarType(), Ex, Sh));
|
||||
}
|
||||
|
@ -4052,16 +4080,16 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
if (Node->getOpcode() == ISD::CTTZ) {
|
||||
// FIXME: This should set a bit in the zero extended value instead.
|
||||
Tmp2 = DAG.getSetCC(dl, getSetCCResultType(NVT),
|
||||
Tmp1, DAG.getConstant(NVT.getSizeInBits(), NVT),
|
||||
Tmp1, DAG.getConstant(NVT.getSizeInBits(), dl, NVT),
|
||||
ISD::SETEQ);
|
||||
Tmp1 = DAG.getSelect(dl, NVT, Tmp2,
|
||||
DAG.getConstant(OVT.getSizeInBits(), NVT), Tmp1);
|
||||
DAG.getConstant(OVT.getSizeInBits(), dl, NVT), Tmp1);
|
||||
} else if (Node->getOpcode() == ISD::CTLZ ||
|
||||
Node->getOpcode() == ISD::CTLZ_ZERO_UNDEF) {
|
||||
// Tmp1 = Tmp1 - (sizeinbits(NVT) - sizeinbits(Old VT))
|
||||
Tmp1 = DAG.getNode(ISD::SUB, dl, NVT, Tmp1,
|
||||
DAG.getConstant(NVT.getSizeInBits() -
|
||||
OVT.getSizeInBits(), NVT));
|
||||
OVT.getSizeInBits(), dl, NVT));
|
||||
}
|
||||
Results.push_back(DAG.getNode(ISD::TRUNCATE, dl, OVT, Tmp1));
|
||||
break;
|
||||
|
@ -4070,7 +4098,8 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
Tmp1 = DAG.getNode(ISD::ZERO_EXTEND, dl, NVT, Node->getOperand(0));
|
||||
Tmp1 = DAG.getNode(ISD::BSWAP, dl, NVT, Tmp1);
|
||||
Tmp1 = DAG.getNode(ISD::SRL, dl, NVT, Tmp1,
|
||||
DAG.getConstant(DiffBits, TLI.getShiftAmountTy(NVT)));
|
||||
DAG.getConstant(DiffBits, dl,
|
||||
TLI.getShiftAmountTy(NVT)));
|
||||
Results.push_back(Tmp1);
|
||||
break;
|
||||
}
|
||||
|
@ -4160,7 +4189,7 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
Tmp1 = DAG.getNode(TruncOp, dl, Node->getValueType(0), Tmp1);
|
||||
else
|
||||
Tmp1 = DAG.getNode(TruncOp, dl, Node->getValueType(0), Tmp1,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
Results.push_back(Tmp1);
|
||||
break;
|
||||
}
|
||||
|
@ -4217,7 +4246,7 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
Tmp2 = DAG.getNode(ISD::FP_EXTEND, dl, NVT, Node->getOperand(1));
|
||||
Tmp3 = DAG.getNode(Node->getOpcode(), dl, NVT, Tmp1, Tmp2);
|
||||
Results.push_back(DAG.getNode(ISD::FP_ROUND, dl, OVT,
|
||||
Tmp3, DAG.getIntPtrConstant(0)));
|
||||
Tmp3, DAG.getIntPtrConstant(0, dl)));
|
||||
break;
|
||||
}
|
||||
case ISD::FMA: {
|
||||
|
@ -4227,7 +4256,7 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
Results.push_back(
|
||||
DAG.getNode(ISD::FP_ROUND, dl, OVT,
|
||||
DAG.getNode(Node->getOpcode(), dl, NVT, Tmp1, Tmp2, Tmp3),
|
||||
DAG.getIntPtrConstant(0)));
|
||||
DAG.getIntPtrConstant(0, dl)));
|
||||
break;
|
||||
}
|
||||
case ISD::FPOWI: {
|
||||
|
@ -4235,7 +4264,7 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
Tmp2 = Node->getOperand(1);
|
||||
Tmp3 = DAG.getNode(Node->getOpcode(), dl, NVT, Tmp1, Tmp2);
|
||||
Results.push_back(DAG.getNode(ISD::FP_ROUND, dl, OVT,
|
||||
Tmp3, DAG.getIntPtrConstant(0)));
|
||||
Tmp3, DAG.getIntPtrConstant(0, dl)));
|
||||
break;
|
||||
}
|
||||
case ISD::FFLOOR:
|
||||
|
@ -4257,7 +4286,7 @@ void SelectionDAGLegalize::PromoteNode(SDNode *Node) {
|
|||
Tmp1 = DAG.getNode(ISD::FP_EXTEND, dl, NVT, Node->getOperand(0));
|
||||
Tmp2 = DAG.getNode(Node->getOpcode(), dl, NVT, Tmp1);
|
||||
Results.push_back(DAG.getNode(ISD::FP_ROUND, dl, OVT,
|
||||
Tmp2, DAG.getIntPtrConstant(0)));
|
||||
Tmp2, DAG.getIntPtrConstant(0, dl)));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -131,7 +131,7 @@ SDValue DAGTypeLegalizer::SoftenFloatRes_BUILD_PAIR(SDNode *N) {
|
|||
}
|
||||
|
||||
SDValue DAGTypeLegalizer::SoftenFloatRes_ConstantFP(ConstantFPSDNode *N) {
|
||||
return DAG.getConstant(N->getValueAPF().bitcastToAPInt(),
|
||||
return DAG.getConstant(N->getValueAPF().bitcastToAPInt(), SDLoc(N),
|
||||
TLI.getTypeToTransformTo(*DAG.getContext(),
|
||||
N->getValueType(0)));
|
||||
}
|
||||
|
@ -149,8 +149,8 @@ SDValue DAGTypeLegalizer::SoftenFloatRes_FABS(SDNode *N) {
|
|||
|
||||
// Mask = ~(1 << (Size-1))
|
||||
APInt API = APInt::getAllOnesValue(Size);
|
||||
API.clearBit(Size-1);
|
||||
SDValue Mask = DAG.getConstant(API, NVT);
|
||||
API.clearBit(Size - 1);
|
||||
SDValue Mask = DAG.getConstant(API, SDLoc(N), NVT);
|
||||
SDValue Op = GetSoftenedFloat(N->getOperand(0));
|
||||
return DAG.getNode(ISD::AND, SDLoc(N), NVT, Op, Mask);
|
||||
}
|
||||
|
@ -218,8 +218,8 @@ SDValue DAGTypeLegalizer::SoftenFloatRes_FCOPYSIGN(SDNode *N) {
|
|||
unsigned RSize = RVT.getSizeInBits();
|
||||
|
||||
// First get the sign bit of second operand.
|
||||
SDValue SignBit = DAG.getNode(ISD::SHL, dl, RVT, DAG.getConstant(1, RVT),
|
||||
DAG.getConstant(RSize - 1,
|
||||
SDValue SignBit = DAG.getNode(ISD::SHL, dl, RVT, DAG.getConstant(1, dl, RVT),
|
||||
DAG.getConstant(RSize - 1, dl,
|
||||
TLI.getShiftAmountTy(RVT)));
|
||||
SignBit = DAG.getNode(ISD::AND, dl, RVT, RHS, SignBit);
|
||||
|
||||
|
@ -227,21 +227,21 @@ SDValue DAGTypeLegalizer::SoftenFloatRes_FCOPYSIGN(SDNode *N) {
|
|||
int SizeDiff = RVT.getSizeInBits() - LVT.getSizeInBits();
|
||||
if (SizeDiff > 0) {
|
||||
SignBit = DAG.getNode(ISD::SRL, dl, RVT, SignBit,
|
||||
DAG.getConstant(SizeDiff,
|
||||
DAG.getConstant(SizeDiff, dl,
|
||||
TLI.getShiftAmountTy(SignBit.getValueType())));
|
||||
SignBit = DAG.getNode(ISD::TRUNCATE, dl, LVT, SignBit);
|
||||
} else if (SizeDiff < 0) {
|
||||
SignBit = DAG.getNode(ISD::ANY_EXTEND, dl, LVT, SignBit);
|
||||
SignBit = DAG.getNode(ISD::SHL, dl, LVT, SignBit,
|
||||
DAG.getConstant(-SizeDiff,
|
||||
DAG.getConstant(-SizeDiff, dl,
|
||||
TLI.getShiftAmountTy(SignBit.getValueType())));
|
||||
}
|
||||
|
||||
// Clear the sign bit of the first operand.
|
||||
SDValue Mask = DAG.getNode(ISD::SHL, dl, LVT, DAG.getConstant(1, LVT),
|
||||
DAG.getConstant(LSize - 1,
|
||||
SDValue Mask = DAG.getNode(ISD::SHL, dl, LVT, DAG.getConstant(1, dl, LVT),
|
||||
DAG.getConstant(LSize - 1, dl,
|
||||
TLI.getShiftAmountTy(LVT)));
|
||||
Mask = DAG.getNode(ISD::SUB, dl, LVT, Mask, DAG.getConstant(1, LVT));
|
||||
Mask = DAG.getNode(ISD::SUB, dl, LVT, Mask, DAG.getConstant(1, dl, LVT));
|
||||
LHS = DAG.getNode(ISD::AND, dl, LVT, LHS, Mask);
|
||||
|
||||
// Or the value with the sign bit.
|
||||
|
@ -386,8 +386,9 @@ SDValue DAGTypeLegalizer::SoftenFloatRes_FNEARBYINT(SDNode *N) {
|
|||
|
||||
SDValue DAGTypeLegalizer::SoftenFloatRes_FNEG(SDNode *N) {
|
||||
EVT NVT = TLI.getTypeToTransformTo(*DAG.getContext(), N->getValueType(0));
|
||||
SDLoc dl(N);
|
||||
// Expand Y = FNEG(X) -> Y = SUB -0.0, X
|
||||
SDValue Ops[2] = { DAG.getConstantFP(-0.0, N->getValueType(0)),
|
||||
SDValue Ops[2] = { DAG.getConstantFP(-0.0, dl, N->getValueType(0)),
|
||||
GetSoftenedFloat(N->getOperand(0)) };
|
||||
return TLI.makeLibCall(DAG, GetFPLibCall(N->getValueType(0),
|
||||
RTLIB::SUB_F32,
|
||||
|
@ -395,7 +396,7 @@ SDValue DAGTypeLegalizer::SoftenFloatRes_FNEG(SDNode *N) {
|
|||
RTLIB::SUB_F80,
|
||||
RTLIB::SUB_F128,
|
||||
RTLIB::SUB_PPCF128),
|
||||
NVT, Ops, 2, false, SDLoc(N)).first;
|
||||
NVT, Ops, 2, false, dl).first;
|
||||
}
|
||||
|
||||
SDValue DAGTypeLegalizer::SoftenFloatRes_FP_EXTEND(SDNode *N) {
|
||||
|
@ -755,7 +756,7 @@ SDValue DAGTypeLegalizer::SoftenFloatOp_BR_CC(SDNode *N) {
|
|||
// If softenSetCCOperands returned a scalar, we need to compare the result
|
||||
// against zero to select between true and false values.
|
||||
if (!NewRHS.getNode()) {
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, SDLoc(N), NewLHS.getValueType());
|
||||
CCCode = ISD::SETNE;
|
||||
}
|
||||
|
||||
|
@ -794,7 +795,7 @@ SDValue DAGTypeLegalizer::SoftenFloatOp_SELECT_CC(SDNode *N) {
|
|||
// If softenSetCCOperands returned a scalar, we need to compare the result
|
||||
// against zero to select between true and false values.
|
||||
if (!NewRHS.getNode()) {
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, SDLoc(N), NewLHS.getValueType());
|
||||
CCCode = ISD::SETNE;
|
||||
}
|
||||
|
||||
|
@ -837,7 +838,7 @@ SDValue DAGTypeLegalizer::SoftenFloatOp_STORE(SDNode *N, unsigned OpNo) {
|
|||
if (ST->isTruncatingStore())
|
||||
// Do an FP_ROUND followed by a non-truncating store.
|
||||
Val = BitConvertToInteger(DAG.getNode(ISD::FP_ROUND, dl, ST->getMemoryVT(),
|
||||
Val, DAG.getIntPtrConstant(0)));
|
||||
Val, DAG.getIntPtrConstant(0, dl)));
|
||||
else
|
||||
Val = GetSoftenedFloat(Val);
|
||||
|
||||
|
@ -927,12 +928,13 @@ void DAGTypeLegalizer::ExpandFloatRes_ConstantFP(SDNode *N, SDValue &Lo,
|
|||
assert(NVT.getSizeInBits() == integerPartWidth &&
|
||||
"Do not know how to expand this float constant!");
|
||||
APInt C = cast<ConstantFPSDNode>(N)->getValueAPF().bitcastToAPInt();
|
||||
SDLoc dl(N);
|
||||
Lo = DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(NVT),
|
||||
APInt(integerPartWidth, C.getRawData()[1])),
|
||||
NVT);
|
||||
dl, NVT);
|
||||
Hi = DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(NVT),
|
||||
APInt(integerPartWidth, C.getRawData()[0])),
|
||||
NVT);
|
||||
dl, NVT);
|
||||
}
|
||||
|
||||
void DAGTypeLegalizer::ExpandFloatRes_FABS(SDNode *N, SDValue &Lo,
|
||||
|
@ -1136,9 +1138,10 @@ void DAGTypeLegalizer::ExpandFloatRes_FNEG(SDNode *N, SDValue &Lo,
|
|||
void DAGTypeLegalizer::ExpandFloatRes_FP_EXTEND(SDNode *N, SDValue &Lo,
|
||||
SDValue &Hi) {
|
||||
EVT NVT = TLI.getTypeToTransformTo(*DAG.getContext(), N->getValueType(0));
|
||||
Hi = DAG.getNode(ISD::FP_EXTEND, SDLoc(N), NVT, N->getOperand(0));
|
||||
SDLoc dl(N);
|
||||
Hi = DAG.getNode(ISD::FP_EXTEND, dl, NVT, N->getOperand(0));
|
||||
Lo = DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(NVT),
|
||||
APInt(NVT.getSizeInBits(), 0)), NVT);
|
||||
APInt(NVT.getSizeInBits(), 0)), dl, NVT);
|
||||
}
|
||||
|
||||
void DAGTypeLegalizer::ExpandFloatRes_FPOW(SDNode *N,
|
||||
|
@ -1262,7 +1265,7 @@ void DAGTypeLegalizer::ExpandFloatRes_LOAD(SDNode *N, SDValue &Lo,
|
|||
|
||||
// The low part is zero.
|
||||
Lo = DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(NVT),
|
||||
APInt(NVT.getSizeInBits(), 0)), NVT);
|
||||
APInt(NVT.getSizeInBits(), 0)), dl, NVT);
|
||||
|
||||
// Modified the chain - switch anything that used the old chain to use the
|
||||
// new one.
|
||||
|
@ -1287,7 +1290,7 @@ void DAGTypeLegalizer::ExpandFloatRes_XINT_TO_FP(SDNode *N, SDValue &Lo,
|
|||
Src = DAG.getNode(isSigned ? ISD::SIGN_EXTEND : ISD::ZERO_EXTEND, dl,
|
||||
MVT::i32, Src);
|
||||
Lo = DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(NVT),
|
||||
APInt(NVT.getSizeInBits(), 0)), NVT);
|
||||
APInt(NVT.getSizeInBits(), 0)), dl, NVT);
|
||||
Hi = DAG.getNode(ISD::SINT_TO_FP, dl, NVT, Src);
|
||||
} else {
|
||||
RTLIB::Libcall LC = RTLIB::UNKNOWN_LIBCALL;
|
||||
|
@ -1335,8 +1338,8 @@ void DAGTypeLegalizer::ExpandFloatRes_XINT_TO_FP(SDNode *N, SDValue &Lo,
|
|||
Lo = DAG.getNode(ISD::FADD, dl, VT, Hi,
|
||||
DAG.getConstantFP(APFloat(APFloat::PPCDoubleDouble,
|
||||
APInt(128, Parts)),
|
||||
MVT::ppcf128));
|
||||
Lo = DAG.getSelectCC(dl, Src, DAG.getConstant(0, SrcVT),
|
||||
dl, MVT::ppcf128));
|
||||
Lo = DAG.getSelectCC(dl, Src, DAG.getConstant(0, dl, SrcVT),
|
||||
Lo, Hi, ISD::SETLT);
|
||||
GetPairElements(Lo, Lo, Hi);
|
||||
}
|
||||
|
@ -1436,7 +1439,7 @@ SDValue DAGTypeLegalizer::ExpandFloatOp_BR_CC(SDNode *N) {
|
|||
// If ExpandSetCCOperands returned a scalar, we need to compare the result
|
||||
// against zero to select between true and false values.
|
||||
if (!NewRHS.getNode()) {
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, SDLoc(N), NewLHS.getValueType());
|
||||
CCCode = ISD::SETNE;
|
||||
}
|
||||
|
||||
|
@ -1479,7 +1482,7 @@ SDValue DAGTypeLegalizer::ExpandFloatOp_FP_TO_SINT(SDNode *N) {
|
|||
SDValue Res = DAG.getNode(ISD::FP_ROUND_INREG, dl, MVT::ppcf128,
|
||||
N->getOperand(0), DAG.getValueType(MVT::f64));
|
||||
Res = DAG.getNode(ISD::FP_ROUND, dl, MVT::f64, Res,
|
||||
DAG.getIntPtrConstant(1));
|
||||
DAG.getIntPtrConstant(1, dl));
|
||||
return DAG.getNode(ISD::FP_TO_SINT, dl, MVT::i32, Res);
|
||||
}
|
||||
|
||||
|
@ -1499,7 +1502,7 @@ SDValue DAGTypeLegalizer::ExpandFloatOp_FP_TO_UINT(SDNode *N) {
|
|||
"Logic only correct for ppcf128!");
|
||||
const uint64_t TwoE31[] = {0x41e0000000000000LL, 0};
|
||||
APFloat APF = APFloat(APFloat::PPCDoubleDouble, APInt(128, TwoE31));
|
||||
SDValue Tmp = DAG.getConstantFP(APF, MVT::ppcf128);
|
||||
SDValue Tmp = DAG.getConstantFP(APF, dl, MVT::ppcf128);
|
||||
// X>=2^31 ? (int)(X-2^31)+0x80000000 : (int)X
|
||||
// FIXME: generated code sucks.
|
||||
return DAG.getSelectCC(dl, N->getOperand(0), Tmp,
|
||||
|
@ -1509,7 +1512,8 @@ SDValue DAGTypeLegalizer::ExpandFloatOp_FP_TO_UINT(SDNode *N) {
|
|||
MVT::ppcf128,
|
||||
N->getOperand(0),
|
||||
Tmp)),
|
||||
DAG.getConstant(0x80000000, MVT::i32)),
|
||||
DAG.getConstant(0x80000000, dl,
|
||||
MVT::i32)),
|
||||
DAG.getNode(ISD::FP_TO_SINT, dl,
|
||||
MVT::i32, N->getOperand(0)),
|
||||
ISD::SETGE);
|
||||
|
@ -1529,7 +1533,7 @@ SDValue DAGTypeLegalizer::ExpandFloatOp_SELECT_CC(SDNode *N) {
|
|||
// If ExpandSetCCOperands returned a scalar, we need to compare the result
|
||||
// against zero to select between true and false values.
|
||||
if (!NewRHS.getNode()) {
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, SDLoc(N), NewLHS.getValueType());
|
||||
CCCode = ISD::SETNE;
|
||||
}
|
||||
|
||||
|
@ -1793,17 +1797,18 @@ SDValue DAGTypeLegalizer::PromoteFloatRes_BITCAST(SDNode *N) {
|
|||
SDValue DAGTypeLegalizer::PromoteFloatRes_ConstantFP(SDNode *N) {
|
||||
ConstantFPSDNode *CFPNode = cast<ConstantFPSDNode>(N);
|
||||
EVT VT = N->getValueType(0);
|
||||
SDLoc DL(N);
|
||||
|
||||
// Get the (bit-cast) APInt of the APFloat and build an integer constant
|
||||
EVT IVT = EVT::getIntegerVT(*DAG.getContext(), VT.getSizeInBits());
|
||||
SDValue C = DAG.getConstant(CFPNode->getValueAPF().bitcastToAPInt(),
|
||||
SDValue C = DAG.getConstant(CFPNode->getValueAPF().bitcastToAPInt(), DL,
|
||||
IVT);
|
||||
|
||||
// Convert the Constant to the desired FP type
|
||||
// FIXME We might be able to do the conversion during compilation and get rid
|
||||
// of it from the object code
|
||||
EVT NVT = TLI.getTypeToTransformTo(*DAG.getContext(), VT);
|
||||
return DAG.getNode(GetPromotionOpcode(VT, NVT), SDLoc(N), NVT, C);
|
||||
return DAG.getNode(GetPromotionOpcode(VT, NVT), DL, NVT, C);
|
||||
}
|
||||
|
||||
// If the Index operand is a constant, try to redirect the extract operation to
|
||||
|
@ -1846,7 +1851,7 @@ SDValue DAGTypeLegalizer::PromoteFloatRes_EXTRACT_VECTOR_ELT(SDNode *N) {
|
|||
Res = DAG.getNode(N->getOpcode(), DL, EltVT, Lo, Idx);
|
||||
else
|
||||
Res = DAG.getNode(N->getOpcode(), DL, EltVT, Hi,
|
||||
DAG.getConstant(IdxVal - LoElts,
|
||||
DAG.getConstant(IdxVal - LoElts, DL,
|
||||
Idx.getValueType()));
|
||||
ReplaceValueWith(SDValue(N, 0), Res);
|
||||
return SDValue();
|
||||
|
|
|
@ -307,7 +307,7 @@ SDValue DAGTypeLegalizer::PromoteIntRes_BSWAP(SDNode *N) {
|
|||
|
||||
unsigned DiffBits = NVT.getScalarSizeInBits() - OVT.getScalarSizeInBits();
|
||||
return DAG.getNode(ISD::SRL, dl, NVT, DAG.getNode(ISD::BSWAP, dl, NVT, Op),
|
||||
DAG.getConstant(DiffBits, TLI.getShiftAmountTy(NVT)));
|
||||
DAG.getConstant(DiffBits, dl, TLI.getShiftAmountTy(NVT)));
|
||||
}
|
||||
|
||||
SDValue DAGTypeLegalizer::PromoteIntRes_BUILD_PAIR(SDNode *N) {
|
||||
|
@ -355,7 +355,7 @@ SDValue DAGTypeLegalizer::PromoteIntRes_CTLZ(SDNode *N) {
|
|||
// Subtract off the extra leading bits in the bigger type.
|
||||
return DAG.getNode(
|
||||
ISD::SUB, dl, NVT, Op,
|
||||
DAG.getConstant(NVT.getScalarSizeInBits() - OVT.getScalarSizeInBits(),
|
||||
DAG.getConstant(NVT.getScalarSizeInBits() - OVT.getScalarSizeInBits(), dl,
|
||||
NVT));
|
||||
}
|
||||
|
||||
|
@ -376,7 +376,7 @@ SDValue DAGTypeLegalizer::PromoteIntRes_CTTZ(SDNode *N) {
|
|||
// the top of the original type.
|
||||
auto TopBit = APInt::getOneBitSet(NVT.getScalarSizeInBits(),
|
||||
OVT.getScalarSizeInBits());
|
||||
Op = DAG.getNode(ISD::OR, dl, NVT, Op, DAG.getConstant(TopBit, NVT));
|
||||
Op = DAG.getNode(ISD::OR, dl, NVT, Op, DAG.getConstant(TopBit, dl, NVT));
|
||||
}
|
||||
return DAG.getNode(N->getOpcode(), dl, NVT, Op);
|
||||
}
|
||||
|
@ -733,9 +733,11 @@ SDValue DAGTypeLegalizer::PromoteIntRes_XMULO(SDNode *N, unsigned ResNo) {
|
|||
if (N->getOpcode() == ISD::UMULO) {
|
||||
// Unsigned overflow occurred if the high part is non-zero.
|
||||
SDValue Hi = DAG.getNode(ISD::SRL, DL, Mul.getValueType(), Mul,
|
||||
DAG.getIntPtrConstant(SmallVT.getSizeInBits()));
|
||||
DAG.getIntPtrConstant(SmallVT.getSizeInBits(),
|
||||
DL));
|
||||
Overflow = DAG.getSetCC(DL, N->getValueType(1), Hi,
|
||||
DAG.getConstant(0, Hi.getValueType()), ISD::SETNE);
|
||||
DAG.getConstant(0, DL, Hi.getValueType()),
|
||||
ISD::SETNE);
|
||||
} else {
|
||||
// Signed overflow occurred if the high part does not sign extend the low.
|
||||
SDValue SExt = DAG.getNode(ISD::SIGN_EXTEND_INREG, DL, Mul.getValueType(),
|
||||
|
@ -794,7 +796,7 @@ SDValue DAGTypeLegalizer::PromoteIntRes_VAARG(SDNode *N) {
|
|||
SDValue Part = DAG.getNode(ISD::ZERO_EXTEND, dl, NVT, Parts[i]);
|
||||
// Shift it to the right position and "or" it in.
|
||||
Part = DAG.getNode(ISD::SHL, dl, NVT, Part,
|
||||
DAG.getConstant(i * RegVT.getSizeInBits(),
|
||||
DAG.getConstant(i*RegVT.getSizeInBits(), dl,
|
||||
TLI.getPointerTy()));
|
||||
Res = DAG.getNode(ISD::OR, dl, NVT, Res, Part);
|
||||
}
|
||||
|
@ -987,7 +989,8 @@ SDValue DAGTypeLegalizer::PromoteIntOp_BUILD_PAIR(SDNode *N) {
|
|||
SDLoc dl(N);
|
||||
|
||||
Hi = DAG.getNode(ISD::SHL, dl, N->getValueType(0), Hi,
|
||||
DAG.getConstant(OVT.getSizeInBits(), TLI.getPointerTy()));
|
||||
DAG.getConstant(OVT.getSizeInBits(), dl,
|
||||
TLI.getPointerTy()));
|
||||
return DAG.getNode(ISD::OR, dl, N->getValueType(0), Lo, Hi);
|
||||
}
|
||||
|
||||
|
@ -1157,7 +1160,7 @@ SDValue DAGTypeLegalizer::PromoteIntOp_MSTORE(MaskedStoreSDNode *N, unsigned OpN
|
|||
|
||||
unsigned NumConcat = WidenNumElts / MaskNumElts;
|
||||
SmallVector<SDValue, 16> Ops(NumConcat);
|
||||
SDValue ZeroVal = DAG.getConstant(0, MaskVT);
|
||||
SDValue ZeroVal = DAG.getConstant(0, dl, MaskVT);
|
||||
Ops[0] = Mask;
|
||||
for (unsigned i = 1; i != NumConcat; ++i)
|
||||
Ops[i] = ZeroVal;
|
||||
|
@ -1363,13 +1366,13 @@ void DAGTypeLegalizer::ExpandShiftByConstant(SDNode *N, unsigned Amt,
|
|||
|
||||
if (N->getOpcode() == ISD::SHL) {
|
||||
if (Amt > VTBits) {
|
||||
Lo = Hi = DAG.getConstant(0, NVT);
|
||||
Lo = Hi = DAG.getConstant(0, DL, NVT);
|
||||
} else if (Amt > NVTBits) {
|
||||
Lo = DAG.getConstant(0, NVT);
|
||||
Lo = DAG.getConstant(0, DL, NVT);
|
||||
Hi = DAG.getNode(ISD::SHL, DL,
|
||||
NVT, InL, DAG.getConstant(Amt-NVTBits, ShTy));
|
||||
NVT, InL, DAG.getConstant(Amt - NVTBits, DL, ShTy));
|
||||
} else if (Amt == NVTBits) {
|
||||
Lo = DAG.getConstant(0, NVT);
|
||||
Lo = DAG.getConstant(0, DL, NVT);
|
||||
Hi = InL;
|
||||
} else if (Amt == 1 &&
|
||||
TLI.isOperationLegalOrCustom(ISD::ADDC,
|
||||
|
@ -1381,34 +1384,34 @@ void DAGTypeLegalizer::ExpandShiftByConstant(SDNode *N, unsigned Amt,
|
|||
SDValue HiOps[3] = { InH, InH, Lo.getValue(1) };
|
||||
Hi = DAG.getNode(ISD::ADDE, DL, VTList, HiOps);
|
||||
} else {
|
||||
Lo = DAG.getNode(ISD::SHL, DL, NVT, InL, DAG.getConstant(Amt, ShTy));
|
||||
Lo = DAG.getNode(ISD::SHL, DL, NVT, InL, DAG.getConstant(Amt, DL, ShTy));
|
||||
Hi = DAG.getNode(ISD::OR, DL, NVT,
|
||||
DAG.getNode(ISD::SHL, DL, NVT, InH,
|
||||
DAG.getConstant(Amt, ShTy)),
|
||||
DAG.getConstant(Amt, DL, ShTy)),
|
||||
DAG.getNode(ISD::SRL, DL, NVT, InL,
|
||||
DAG.getConstant(NVTBits-Amt, ShTy)));
|
||||
DAG.getConstant(NVTBits - Amt, DL, ShTy)));
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if (N->getOpcode() == ISD::SRL) {
|
||||
if (Amt > VTBits) {
|
||||
Lo = DAG.getConstant(0, NVT);
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
Lo = DAG.getConstant(0, DL, NVT);
|
||||
Hi = DAG.getConstant(0, DL, NVT);
|
||||
} else if (Amt > NVTBits) {
|
||||
Lo = DAG.getNode(ISD::SRL, DL,
|
||||
NVT, InH, DAG.getConstant(Amt-NVTBits,ShTy));
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
NVT, InH, DAG.getConstant(Amt - NVTBits, DL, ShTy));
|
||||
Hi = DAG.getConstant(0, DL, NVT);
|
||||
} else if (Amt == NVTBits) {
|
||||
Lo = InH;
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
Hi = DAG.getConstant(0, DL, NVT);
|
||||
} else {
|
||||
Lo = DAG.getNode(ISD::OR, DL, NVT,
|
||||
DAG.getNode(ISD::SRL, DL, NVT, InL,
|
||||
DAG.getConstant(Amt, ShTy)),
|
||||
DAG.getConstant(Amt, DL, ShTy)),
|
||||
DAG.getNode(ISD::SHL, DL, NVT, InH,
|
||||
DAG.getConstant(NVTBits-Amt, ShTy)));
|
||||
Hi = DAG.getNode(ISD::SRL, DL, NVT, InH, DAG.getConstant(Amt, ShTy));
|
||||
DAG.getConstant(NVTBits - Amt, DL, ShTy)));
|
||||
Hi = DAG.getNode(ISD::SRL, DL, NVT, InH, DAG.getConstant(Amt, DL, ShTy));
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
@ -1416,23 +1419,23 @@ void DAGTypeLegalizer::ExpandShiftByConstant(SDNode *N, unsigned Amt,
|
|||
assert(N->getOpcode() == ISD::SRA && "Unknown shift!");
|
||||
if (Amt > VTBits) {
|
||||
Hi = Lo = DAG.getNode(ISD::SRA, DL, NVT, InH,
|
||||
DAG.getConstant(NVTBits-1, ShTy));
|
||||
DAG.getConstant(NVTBits - 1, DL, ShTy));
|
||||
} else if (Amt > NVTBits) {
|
||||
Lo = DAG.getNode(ISD::SRA, DL, NVT, InH,
|
||||
DAG.getConstant(Amt-NVTBits, ShTy));
|
||||
DAG.getConstant(Amt-NVTBits, DL, ShTy));
|
||||
Hi = DAG.getNode(ISD::SRA, DL, NVT, InH,
|
||||
DAG.getConstant(NVTBits-1, ShTy));
|
||||
DAG.getConstant(NVTBits - 1, DL, ShTy));
|
||||
} else if (Amt == NVTBits) {
|
||||
Lo = InH;
|
||||
Hi = DAG.getNode(ISD::SRA, DL, NVT, InH,
|
||||
DAG.getConstant(NVTBits-1, ShTy));
|
||||
DAG.getConstant(NVTBits - 1, DL, ShTy));
|
||||
} else {
|
||||
Lo = DAG.getNode(ISD::OR, DL, NVT,
|
||||
DAG.getNode(ISD::SRL, DL, NVT, InL,
|
||||
DAG.getConstant(Amt, ShTy)),
|
||||
DAG.getConstant(Amt, DL, ShTy)),
|
||||
DAG.getNode(ISD::SHL, DL, NVT, InH,
|
||||
DAG.getConstant(NVTBits-Amt, ShTy)));
|
||||
Hi = DAG.getNode(ISD::SRA, DL, NVT, InH, DAG.getConstant(Amt, ShTy));
|
||||
DAG.getConstant(NVTBits - Amt, DL, ShTy)));
|
||||
Hi = DAG.getNode(ISD::SRA, DL, NVT, InH, DAG.getConstant(Amt, DL, ShTy));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1468,21 +1471,21 @@ ExpandShiftWithKnownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
if (KnownOne.intersects(HighBitMask)) {
|
||||
// Mask out the high bit, which we know is set.
|
||||
Amt = DAG.getNode(ISD::AND, dl, ShTy, Amt,
|
||||
DAG.getConstant(~HighBitMask, ShTy));
|
||||
DAG.getConstant(~HighBitMask, dl, ShTy));
|
||||
|
||||
switch (N->getOpcode()) {
|
||||
default: llvm_unreachable("Unknown shift");
|
||||
case ISD::SHL:
|
||||
Lo = DAG.getConstant(0, NVT); // Low part is zero.
|
||||
Lo = DAG.getConstant(0, dl, NVT); // Low part is zero.
|
||||
Hi = DAG.getNode(ISD::SHL, dl, NVT, InL, Amt); // High part from Lo part.
|
||||
return true;
|
||||
case ISD::SRL:
|
||||
Hi = DAG.getConstant(0, NVT); // Hi part is zero.
|
||||
Hi = DAG.getConstant(0, dl, NVT); // Hi part is zero.
|
||||
Lo = DAG.getNode(ISD::SRL, dl, NVT, InH, Amt); // Lo part from Hi part.
|
||||
return true;
|
||||
case ISD::SRA:
|
||||
Hi = DAG.getNode(ISD::SRA, dl, NVT, InH, // Sign extend high part.
|
||||
DAG.getConstant(NVTBits-1, ShTy));
|
||||
DAG.getConstant(NVTBits - 1, dl, ShTy));
|
||||
Lo = DAG.getNode(ISD::SRA, dl, NVT, InH, Amt); // Lo part from Hi part.
|
||||
return true;
|
||||
}
|
||||
|
@ -1495,7 +1498,7 @@ ExpandShiftWithKnownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
// shift if x is zero. We can use XOR here because x is known to be smaller
|
||||
// than 32.
|
||||
SDValue Amt2 = DAG.getNode(ISD::XOR, dl, ShTy, Amt,
|
||||
DAG.getConstant(NVTBits-1, ShTy));
|
||||
DAG.getConstant(NVTBits - 1, dl, ShTy));
|
||||
|
||||
unsigned Op1, Op2;
|
||||
switch (N->getOpcode()) {
|
||||
|
@ -1511,7 +1514,7 @@ ExpandShiftWithKnownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
|
||||
// Use a little trick to get the bits that move from Lo to Hi. First
|
||||
// shift by one bit.
|
||||
SDValue Sh1 = DAG.getNode(Op2, dl, NVT, InL, DAG.getConstant(1, ShTy));
|
||||
SDValue Sh1 = DAG.getNode(Op2, dl, NVT, InL, DAG.getConstant(1, dl, ShTy));
|
||||
// Then compute the remaining shift with amount-1.
|
||||
SDValue Sh2 = DAG.getNode(Op2, dl, NVT, Sh1, Amt2);
|
||||
|
||||
|
@ -1542,13 +1545,13 @@ ExpandShiftWithUnknownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
SDValue InL, InH;
|
||||
GetExpandedInteger(N->getOperand(0), InL, InH);
|
||||
|
||||
SDValue NVBitsNode = DAG.getConstant(NVTBits, ShTy);
|
||||
SDValue NVBitsNode = DAG.getConstant(NVTBits, dl, ShTy);
|
||||
SDValue AmtExcess = DAG.getNode(ISD::SUB, dl, ShTy, Amt, NVBitsNode);
|
||||
SDValue AmtLack = DAG.getNode(ISD::SUB, dl, ShTy, NVBitsNode, Amt);
|
||||
SDValue isShort = DAG.getSetCC(dl, getSetCCResultType(ShTy),
|
||||
Amt, NVBitsNode, ISD::SETULT);
|
||||
SDValue isZero = DAG.getSetCC(dl, getSetCCResultType(ShTy),
|
||||
Amt, DAG.getConstant(0, ShTy),
|
||||
Amt, DAG.getConstant(0, dl, ShTy),
|
||||
ISD::SETEQ);
|
||||
|
||||
SDValue LoS, HiS, LoL, HiL;
|
||||
|
@ -1562,7 +1565,7 @@ ExpandShiftWithUnknownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
DAG.getNode(ISD::SRL, dl, NVT, InL, AmtLack));
|
||||
|
||||
// Long: ShAmt >= NVTBits
|
||||
LoL = DAG.getConstant(0, NVT); // Lo part is zero.
|
||||
LoL = DAG.getConstant(0, dl, NVT); // Lo part is zero.
|
||||
HiL = DAG.getNode(ISD::SHL, dl, NVT, InL, AmtExcess); // Hi from Lo part.
|
||||
|
||||
Lo = DAG.getSelect(dl, NVT, isShort, LoS, LoL);
|
||||
|
@ -1579,7 +1582,7 @@ ExpandShiftWithUnknownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
DAG.getNode(ISD::SHL, dl, NVT, InH, AmtLack));
|
||||
|
||||
// Long: ShAmt >= NVTBits
|
||||
HiL = DAG.getConstant(0, NVT); // Hi part is zero.
|
||||
HiL = DAG.getConstant(0, dl, NVT); // Hi part is zero.
|
||||
LoL = DAG.getNode(ISD::SRL, dl, NVT, InH, AmtExcess); // Lo from Hi part.
|
||||
|
||||
Lo = DAG.getSelect(dl, NVT, isZero, InL,
|
||||
|
@ -1595,7 +1598,7 @@ ExpandShiftWithUnknownAmountBit(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
|
||||
// Long: ShAmt >= NVTBits
|
||||
HiL = DAG.getNode(ISD::SRA, dl, NVT, InH, // Sign of Hi part.
|
||||
DAG.getConstant(NVTBits-1, ShTy));
|
||||
DAG.getConstant(NVTBits - 1, dl, ShTy));
|
||||
LoL = DAG.getNode(ISD::SRA, dl, NVT, InH, AmtExcess); // Lo from Hi part.
|
||||
|
||||
Lo = DAG.getSelect(dl, NVT, isZero, InL,
|
||||
|
@ -1647,12 +1650,12 @@ void DAGTypeLegalizer::ExpandIntRes_ADDSUB(SDNode *N,
|
|||
SDValue Cmp1 = DAG.getSetCC(dl, getSetCCResultType(NVT), Lo, LoOps[0],
|
||||
ISD::SETULT);
|
||||
SDValue Carry1 = DAG.getSelect(dl, NVT, Cmp1,
|
||||
DAG.getConstant(1, NVT),
|
||||
DAG.getConstant(0, NVT));
|
||||
DAG.getConstant(1, dl, NVT),
|
||||
DAG.getConstant(0, dl, NVT));
|
||||
SDValue Cmp2 = DAG.getSetCC(dl, getSetCCResultType(NVT), Lo, LoOps[1],
|
||||
ISD::SETULT);
|
||||
SDValue Carry2 = DAG.getSelect(dl, NVT, Cmp2,
|
||||
DAG.getConstant(1, NVT), Carry1);
|
||||
DAG.getConstant(1, dl, NVT), Carry1);
|
||||
Hi = DAG.getNode(ISD::ADD, dl, NVT, Hi, Carry2);
|
||||
} else {
|
||||
Lo = DAG.getNode(ISD::SUB, dl, NVT, LoOps);
|
||||
|
@ -1661,8 +1664,8 @@ void DAGTypeLegalizer::ExpandIntRes_ADDSUB(SDNode *N,
|
|||
DAG.getSetCC(dl, getSetCCResultType(LoOps[0].getValueType()),
|
||||
LoOps[0], LoOps[1], ISD::SETULT);
|
||||
SDValue Borrow = DAG.getSelect(dl, NVT, Cmp,
|
||||
DAG.getConstant(1, NVT),
|
||||
DAG.getConstant(0, NVT));
|
||||
DAG.getConstant(1, dl, NVT),
|
||||
DAG.getConstant(0, dl, NVT));
|
||||
Hi = DAG.getNode(ISD::SUB, dl, NVT, Hi, Borrow);
|
||||
}
|
||||
}
|
||||
|
@ -1759,7 +1762,7 @@ void DAGTypeLegalizer::ExpandIntRes_AssertSext(SDNode *N,
|
|||
Lo = DAG.getNode(ISD::AssertSext, dl, NVT, Lo, DAG.getValueType(EVT));
|
||||
// The high part replicates the sign bit of Lo, make it explicit.
|
||||
Hi = DAG.getNode(ISD::SRA, dl, NVT, Lo,
|
||||
DAG.getConstant(NVTBits-1, TLI.getPointerTy()));
|
||||
DAG.getConstant(NVTBits - 1, dl, TLI.getPointerTy()));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1779,7 +1782,7 @@ void DAGTypeLegalizer::ExpandIntRes_AssertZext(SDNode *N,
|
|||
} else {
|
||||
Lo = DAG.getNode(ISD::AssertZext, dl, NVT, Lo, DAG.getValueType(EVT));
|
||||
// The high part must be zero, make it explicit.
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
Hi = DAG.getConstant(0, dl, NVT);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1799,8 +1802,9 @@ void DAGTypeLegalizer::ExpandIntRes_Constant(SDNode *N,
|
|||
const APInt &Cst = Constant->getAPIntValue();
|
||||
bool IsTarget = Constant->isTargetOpcode();
|
||||
bool IsOpaque = Constant->isOpaque();
|
||||
Lo = DAG.getConstant(Cst.trunc(NBitWidth), NVT, IsTarget, IsOpaque);
|
||||
Hi = DAG.getConstant(Cst.lshr(NBitWidth).trunc(NBitWidth), NVT, IsTarget,
|
||||
SDLoc dl(N);
|
||||
Lo = DAG.getConstant(Cst.trunc(NBitWidth), dl, NVT, IsTarget, IsOpaque);
|
||||
Hi = DAG.getConstant(Cst.lshr(NBitWidth).trunc(NBitWidth), dl, NVT, IsTarget,
|
||||
IsOpaque);
|
||||
}
|
||||
|
||||
|
@ -1812,15 +1816,16 @@ void DAGTypeLegalizer::ExpandIntRes_CTLZ(SDNode *N,
|
|||
EVT NVT = Lo.getValueType();
|
||||
|
||||
SDValue HiNotZero = DAG.getSetCC(dl, getSetCCResultType(NVT), Hi,
|
||||
DAG.getConstant(0, NVT), ISD::SETNE);
|
||||
DAG.getConstant(0, dl, NVT), ISD::SETNE);
|
||||
|
||||
SDValue LoLZ = DAG.getNode(N->getOpcode(), dl, NVT, Lo);
|
||||
SDValue HiLZ = DAG.getNode(ISD::CTLZ_ZERO_UNDEF, dl, NVT, Hi);
|
||||
|
||||
Lo = DAG.getSelect(dl, NVT, HiNotZero, HiLZ,
|
||||
DAG.getNode(ISD::ADD, dl, NVT, LoLZ,
|
||||
DAG.getConstant(NVT.getSizeInBits(), NVT)));
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
DAG.getConstant(NVT.getSizeInBits(), dl,
|
||||
NVT)));
|
||||
Hi = DAG.getConstant(0, dl, NVT);
|
||||
}
|
||||
|
||||
void DAGTypeLegalizer::ExpandIntRes_CTPOP(SDNode *N,
|
||||
|
@ -1831,7 +1836,7 @@ void DAGTypeLegalizer::ExpandIntRes_CTPOP(SDNode *N,
|
|||
EVT NVT = Lo.getValueType();
|
||||
Lo = DAG.getNode(ISD::ADD, dl, NVT, DAG.getNode(ISD::CTPOP, dl, NVT, Lo),
|
||||
DAG.getNode(ISD::CTPOP, dl, NVT, Hi));
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
Hi = DAG.getConstant(0, dl, NVT);
|
||||
}
|
||||
|
||||
void DAGTypeLegalizer::ExpandIntRes_CTTZ(SDNode *N,
|
||||
|
@ -1842,15 +1847,16 @@ void DAGTypeLegalizer::ExpandIntRes_CTTZ(SDNode *N,
|
|||
EVT NVT = Lo.getValueType();
|
||||
|
||||
SDValue LoNotZero = DAG.getSetCC(dl, getSetCCResultType(NVT), Lo,
|
||||
DAG.getConstant(0, NVT), ISD::SETNE);
|
||||
DAG.getConstant(0, dl, NVT), ISD::SETNE);
|
||||
|
||||
SDValue LoLZ = DAG.getNode(ISD::CTTZ_ZERO_UNDEF, dl, NVT, Lo);
|
||||
SDValue HiLZ = DAG.getNode(N->getOpcode(), dl, NVT, Hi);
|
||||
|
||||
Lo = DAG.getSelect(dl, NVT, LoNotZero, LoLZ,
|
||||
DAG.getNode(ISD::ADD, dl, NVT, HiLZ,
|
||||
DAG.getConstant(NVT.getSizeInBits(), NVT)));
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
DAG.getConstant(NVT.getSizeInBits(), dl,
|
||||
NVT)));
|
||||
Hi = DAG.getConstant(0, dl, NVT);
|
||||
}
|
||||
|
||||
void DAGTypeLegalizer::ExpandIntRes_FP_TO_SINT(SDNode *N, SDValue &Lo,
|
||||
|
@ -1923,10 +1929,10 @@ void DAGTypeLegalizer::ExpandIntRes_LOAD(LoadSDNode *N,
|
|||
// lo part.
|
||||
unsigned LoSize = Lo.getValueType().getSizeInBits();
|
||||
Hi = DAG.getNode(ISD::SRA, dl, NVT, Lo,
|
||||
DAG.getConstant(LoSize-1, TLI.getPointerTy()));
|
||||
DAG.getConstant(LoSize - 1, dl, TLI.getPointerTy()));
|
||||
} else if (ExtType == ISD::ZEXTLOAD) {
|
||||
// The high part is just a zero.
|
||||
Hi = DAG.getConstant(0, NVT);
|
||||
Hi = DAG.getConstant(0, dl, NVT);
|
||||
} else {
|
||||
assert(ExtType == ISD::EXTLOAD && "Unknown extload!");
|
||||
// The high part is undefined.
|
||||
|
@ -1945,7 +1951,7 @@ void DAGTypeLegalizer::ExpandIntRes_LOAD(LoadSDNode *N,
|
|||
// Increment the pointer to the other half.
|
||||
unsigned IncrementSize = NVT.getSizeInBits()/8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getExtLoad(ExtType, dl, NVT, Ch, Ptr,
|
||||
N->getPointerInfo().getWithOffset(IncrementSize), NEVT,
|
||||
isVolatile, isNonTemporal, isInvariant,
|
||||
|
@ -1972,7 +1978,7 @@ void DAGTypeLegalizer::ExpandIntRes_LOAD(LoadSDNode *N,
|
|||
|
||||
// Increment the pointer to the other half.
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
// Load the rest of the low bits.
|
||||
Lo = DAG.getExtLoad(ISD::ZEXTLOAD, dl, NVT, Ch, Ptr,
|
||||
N->getPointerInfo().getWithOffset(IncrementSize),
|
||||
|
@ -1989,12 +1995,12 @@ void DAGTypeLegalizer::ExpandIntRes_LOAD(LoadSDNode *N,
|
|||
// Transfer low bits from the bottom of Hi to the top of Lo.
|
||||
Lo = DAG.getNode(ISD::OR, dl, NVT, Lo,
|
||||
DAG.getNode(ISD::SHL, dl, NVT, Hi,
|
||||
DAG.getConstant(ExcessBits,
|
||||
DAG.getConstant(ExcessBits, dl,
|
||||
TLI.getPointerTy())));
|
||||
// Move high bits to the right position in Hi.
|
||||
Hi = DAG.getNode(ExtType == ISD::SEXTLOAD ? ISD::SRA : ISD::SRL, dl,
|
||||
NVT, Hi,
|
||||
DAG.getConstant(NVT.getSizeInBits() - ExcessBits,
|
||||
DAG.getConstant(NVT.getSizeInBits() - ExcessBits, dl,
|
||||
TLI.getPointerTy()));
|
||||
}
|
||||
}
|
||||
|
@ -2070,7 +2076,7 @@ void DAGTypeLegalizer::ExpandIntRes_SADDSUBO(SDNode *Node,
|
|||
// Overflow -> (LHSSign != RHSSign) && (LHSSign != SumSign)
|
||||
//
|
||||
EVT OType = Node->getValueType(1);
|
||||
SDValue Zero = DAG.getConstant(0, LHS.getValueType());
|
||||
SDValue Zero = DAG.getConstant(0, dl, LHS.getValueType());
|
||||
|
||||
SDValue LHSSign = DAG.getSetCC(dl, OType, LHS, Zero, ISD::SETGE);
|
||||
SDValue RHSSign = DAG.getSetCC(dl, OType, RHS, Zero, ISD::SETGE);
|
||||
|
@ -2219,7 +2225,7 @@ void DAGTypeLegalizer::ExpandIntRes_SIGN_EXTEND(SDNode *N,
|
|||
// The high part is obtained by SRA'ing all but one of the bits of low part.
|
||||
unsigned LoSize = NVT.getSizeInBits();
|
||||
Hi = DAG.getNode(ISD::SRA, dl, NVT, Lo,
|
||||
DAG.getConstant(LoSize-1, TLI.getPointerTy()));
|
||||
DAG.getConstant(LoSize - 1, dl, TLI.getPointerTy()));
|
||||
} else {
|
||||
// For example, extension of an i48 to an i64. The operand type necessarily
|
||||
// promotes to the result type, so will end up being expanded too.
|
||||
|
@ -2253,7 +2259,7 @@ ExpandIntRes_SIGN_EXTEND_INREG(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
// The high part gets the sign extension from the lo-part. This handles
|
||||
// things like sextinreg V:i64 from i8.
|
||||
Hi = DAG.getNode(ISD::SRA, dl, Hi.getValueType(), Lo,
|
||||
DAG.getConstant(Hi.getValueType().getSizeInBits()-1,
|
||||
DAG.getConstant(Hi.getValueType().getSizeInBits() - 1, dl,
|
||||
TLI.getPointerTy()));
|
||||
} else {
|
||||
// For example, extension of an i48 to an i64. Leave the low part alone,
|
||||
|
@ -2293,7 +2299,8 @@ void DAGTypeLegalizer::ExpandIntRes_TRUNCATE(SDNode *N,
|
|||
Lo = DAG.getNode(ISD::TRUNCATE, dl, NVT, N->getOperand(0));
|
||||
Hi = DAG.getNode(ISD::SRL, dl,
|
||||
N->getOperand(0).getValueType(), N->getOperand(0),
|
||||
DAG.getConstant(NVT.getSizeInBits(), TLI.getPointerTy()));
|
||||
DAG.getConstant(NVT.getSizeInBits(), dl,
|
||||
TLI.getPointerTy()));
|
||||
Hi = DAG.getNode(ISD::TRUNCATE, dl, NVT, Hi);
|
||||
}
|
||||
|
||||
|
@ -2335,14 +2342,14 @@ void DAGTypeLegalizer::ExpandIntRes_XMULO(SDNode *N,
|
|||
// A divide for UMULO will be faster than a function call. Select to
|
||||
// make sure we aren't using 0.
|
||||
SDValue isZero = DAG.getSetCC(dl, getSetCCResultType(VT),
|
||||
RHS, DAG.getConstant(0, VT), ISD::SETEQ);
|
||||
RHS, DAG.getConstant(0, dl, VT), ISD::SETEQ);
|
||||
SDValue NotZero = DAG.getSelect(dl, VT, isZero,
|
||||
DAG.getConstant(1, VT), RHS);
|
||||
DAG.getConstant(1, dl, VT), RHS);
|
||||
SDValue DIV = DAG.getNode(ISD::UDIV, dl, VT, MUL, NotZero);
|
||||
SDValue Overflow = DAG.getSetCC(dl, N->getValueType(1), DIV, LHS,
|
||||
ISD::SETNE);
|
||||
Overflow = DAG.getSelect(dl, N->getValueType(1), isZero,
|
||||
DAG.getConstant(0, N->getValueType(1)),
|
||||
DAG.getConstant(0, dl, N->getValueType(1)),
|
||||
Overflow);
|
||||
ReplaceValueWith(SDValue(N, 1), Overflow);
|
||||
return;
|
||||
|
@ -2365,7 +2372,7 @@ void DAGTypeLegalizer::ExpandIntRes_XMULO(SDNode *N,
|
|||
SDValue Temp = DAG.CreateStackTemporary(PtrVT);
|
||||
// Temporary for the overflow value, default it to zero.
|
||||
SDValue Chain = DAG.getStore(DAG.getEntryNode(), dl,
|
||||
DAG.getConstant(0, PtrVT), Temp,
|
||||
DAG.getConstant(0, dl, PtrVT), Temp,
|
||||
MachinePointerInfo(), false, false, 0);
|
||||
|
||||
TargetLowering::ArgListTy Args;
|
||||
|
@ -2400,7 +2407,7 @@ void DAGTypeLegalizer::ExpandIntRes_XMULO(SDNode *N,
|
|||
SDValue Temp2 = DAG.getLoad(PtrVT, dl, CallInfo.second, Temp,
|
||||
MachinePointerInfo(), false, false, false, 0);
|
||||
SDValue Ofl = DAG.getSetCC(dl, N->getValueType(1), Temp2,
|
||||
DAG.getConstant(0, PtrVT),
|
||||
DAG.getConstant(0, dl, PtrVT),
|
||||
ISD::SETNE);
|
||||
// Use the overflow from the libcall everywhere.
|
||||
ReplaceValueWith(SDValue(N, 1), Ofl);
|
||||
|
@ -2454,7 +2461,7 @@ void DAGTypeLegalizer::ExpandIntRes_ZERO_EXTEND(SDNode *N,
|
|||
if (Op.getValueType().bitsLE(NVT)) {
|
||||
// The low part is zero extension of the input (degenerates to a copy).
|
||||
Lo = DAG.getNode(ISD::ZERO_EXTEND, dl, NVT, N->getOperand(0));
|
||||
Hi = DAG.getConstant(0, NVT); // The high part is just a zero.
|
||||
Hi = DAG.getConstant(0, dl, NVT); // The high part is just a zero.
|
||||
} else {
|
||||
// For example, extension of an i48 to an i64. The operand type necessarily
|
||||
// promotes to the result type, so will end up being expanded too.
|
||||
|
@ -2479,7 +2486,7 @@ void DAGTypeLegalizer::ExpandIntRes_ATOMIC_LOAD(SDNode *N,
|
|||
SDLoc dl(N);
|
||||
EVT VT = cast<AtomicSDNode>(N)->getMemoryVT();
|
||||
SDVTList VTs = DAG.getVTList(VT, MVT::i1, MVT::Other);
|
||||
SDValue Zero = DAG.getConstant(0, VT);
|
||||
SDValue Zero = DAG.getConstant(0, dl, VT);
|
||||
SDValue Swap = DAG.getAtomicCmpSwap(
|
||||
ISD::ATOMIC_CMP_SWAP_WITH_SUCCESS, dl,
|
||||
cast<AtomicSDNode>(N)->getMemoryVT(), VTs, N->getOperand(0),
|
||||
|
@ -2580,7 +2587,7 @@ void DAGTypeLegalizer::IntegerExpandSetCCOperands(SDValue &NewLHS,
|
|||
NewLHS = DAG.getNode(ISD::XOR, dl, LHSLo.getValueType(), LHSLo, RHSLo);
|
||||
NewRHS = DAG.getNode(ISD::XOR, dl, LHSLo.getValueType(), LHSHi, RHSHi);
|
||||
NewLHS = DAG.getNode(ISD::OR, dl, NewLHS.getValueType(), NewLHS, NewRHS);
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, dl, NewLHS.getValueType());
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -2669,7 +2676,7 @@ SDValue DAGTypeLegalizer::ExpandIntOp_BR_CC(SDNode *N) {
|
|||
// If ExpandSetCCOperands returned a scalar, we need to compare the result
|
||||
// against zero to select between true and false values.
|
||||
if (!NewRHS.getNode()) {
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, SDLoc(N), NewLHS.getValueType());
|
||||
CCCode = ISD::SETNE;
|
||||
}
|
||||
|
||||
|
@ -2687,7 +2694,7 @@ SDValue DAGTypeLegalizer::ExpandIntOp_SELECT_CC(SDNode *N) {
|
|||
// If ExpandSetCCOperands returned a scalar, we need to compare the result
|
||||
// against zero to select between true and false values.
|
||||
if (!NewRHS.getNode()) {
|
||||
NewRHS = DAG.getConstant(0, NewLHS.getValueType());
|
||||
NewRHS = DAG.getConstant(0, SDLoc(N), NewLHS.getValueType());
|
||||
CCCode = ISD::SETNE;
|
||||
}
|
||||
|
||||
|
@ -2782,7 +2789,7 @@ SDValue DAGTypeLegalizer::ExpandIntOp_STORE(StoreSDNode *N, unsigned OpNo) {
|
|||
// Increment the pointer to the other half.
|
||||
unsigned IncrementSize = NVT.getSizeInBits()/8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getTruncStore(Ch, dl, Hi, Ptr,
|
||||
N->getPointerInfo().getWithOffset(IncrementSize),
|
||||
NEVT, isVolatile, isNonTemporal,
|
||||
|
@ -2804,11 +2811,11 @@ SDValue DAGTypeLegalizer::ExpandIntOp_STORE(StoreSDNode *N, unsigned OpNo) {
|
|||
if (ExcessBits < NVT.getSizeInBits()) {
|
||||
// Transfer high bits from the top of Lo to the bottom of Hi.
|
||||
Hi = DAG.getNode(ISD::SHL, dl, NVT, Hi,
|
||||
DAG.getConstant(NVT.getSizeInBits() - ExcessBits,
|
||||
DAG.getConstant(NVT.getSizeInBits() - ExcessBits, dl,
|
||||
TLI.getPointerTy()));
|
||||
Hi = DAG.getNode(ISD::OR, dl, NVT, Hi,
|
||||
DAG.getNode(ISD::SRL, dl, NVT, Lo,
|
||||
DAG.getConstant(ExcessBits,
|
||||
DAG.getConstant(ExcessBits, dl,
|
||||
TLI.getPointerTy())));
|
||||
}
|
||||
|
||||
|
@ -2818,7 +2825,7 @@ SDValue DAGTypeLegalizer::ExpandIntOp_STORE(StoreSDNode *N, unsigned OpNo) {
|
|||
|
||||
// Increment the pointer to the other half.
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
// Store the lowest ExcessBits bits in the second half.
|
||||
Lo = DAG.getTruncStore(Ch, dl, Lo, Ptr,
|
||||
N->getPointerInfo().getWithOffset(IncrementSize),
|
||||
|
@ -2874,7 +2881,8 @@ SDValue DAGTypeLegalizer::ExpandIntOp_UINT_TO_FP(SDNode *N) {
|
|||
GetExpandedInteger(Op, Lo, Hi);
|
||||
SDValue SignSet = DAG.getSetCC(dl,
|
||||
getSetCCResultType(Hi.getValueType()),
|
||||
Hi, DAG.getConstant(0, Hi.getValueType()),
|
||||
Hi,
|
||||
DAG.getConstant(0, dl, Hi.getValueType()),
|
||||
ISD::SETLT);
|
||||
|
||||
// Build a 64 bit pair (0, FF) in the constant pool, with FF in the lo bits.
|
||||
|
@ -2883,8 +2891,8 @@ SDValue DAGTypeLegalizer::ExpandIntOp_UINT_TO_FP(SDNode *N) {
|
|||
TLI.getPointerTy());
|
||||
|
||||
// Get a pointer to FF if the sign bit was set, or to 0 otherwise.
|
||||
SDValue Zero = DAG.getIntPtrConstant(0);
|
||||
SDValue Four = DAG.getIntPtrConstant(4);
|
||||
SDValue Zero = DAG.getIntPtrConstant(0, dl);
|
||||
SDValue Four = DAG.getIntPtrConstant(4, dl);
|
||||
if (TLI.isBigEndian()) std::swap(Zero, Four);
|
||||
SDValue Offset = DAG.getSelect(dl, Zero.getValueType(), SignSet,
|
||||
Zero, Four);
|
||||
|
@ -2942,7 +2950,7 @@ SDValue DAGTypeLegalizer::PromoteIntRes_EXTRACT_SUBVECTOR(SDNode *N) {
|
|||
|
||||
// Extract the element from the original vector.
|
||||
SDValue Index = DAG.getNode(ISD::ADD, dl, BaseIdx.getValueType(),
|
||||
BaseIdx, DAG.getConstant(i, BaseIdx.getValueType()));
|
||||
BaseIdx, DAG.getConstant(i, dl, BaseIdx.getValueType()));
|
||||
SDValue Ext = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
InVT.getVectorElementType(), N->getOperand(0), Index);
|
||||
|
||||
|
@ -3036,7 +3044,7 @@ SDValue DAGTypeLegalizer::PromoteIntRes_CONCAT_VECTORS(SDNode *N) {
|
|||
SDValue Op = N->getOperand(i);
|
||||
for (unsigned j = 0; j < NumElem; ++j) {
|
||||
SDValue Ext = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
InElemTy, Op, DAG.getConstant(j,
|
||||
InElemTy, Op, DAG.getConstant(j, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
Ops[i * NumElem + j] = DAG.getNode(ISD::ANY_EXTEND, dl, OutElemTy, Ext);
|
||||
}
|
||||
|
@ -3092,7 +3100,7 @@ SDValue DAGTypeLegalizer::PromoteIntOp_CONCAT_VECTORS(SDNode *N) {
|
|||
for (unsigned i=0; i<NumElem; ++i) {
|
||||
// Extract element from incoming vector
|
||||
SDValue Ex = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, SclrTy,
|
||||
Incoming, DAG.getConstant(i, TLI.getVectorIdxTy()));
|
||||
Incoming, DAG.getConstant(i, dl, TLI.getVectorIdxTy()));
|
||||
SDValue Tr = DAG.getNode(ISD::TRUNCATE, dl, RetSclrTy, Ex);
|
||||
NewOps.push_back(Tr);
|
||||
}
|
||||
|
|
|
@ -997,9 +997,9 @@ void DAGTypeLegalizer::GetPairElements(SDValue Pair,
|
|||
SDLoc dl(Pair);
|
||||
EVT NVT = TLI.getTypeToTransformTo(*DAG.getContext(), Pair.getValueType());
|
||||
Lo = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, NVT, Pair,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
Hi = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, NVT, Pair,
|
||||
DAG.getIntPtrConstant(1));
|
||||
DAG.getIntPtrConstant(1, dl));
|
||||
}
|
||||
|
||||
SDValue DAGTypeLegalizer::GetVectorElementPointer(SDValue VecPtr, EVT EltVT,
|
||||
|
@ -1012,7 +1012,7 @@ SDValue DAGTypeLegalizer::GetVectorElementPointer(SDValue VecPtr, EVT EltVT,
|
|||
unsigned EltSize = EltVT.getSizeInBits() / 8; // FIXME: should be ABI size.
|
||||
|
||||
Index = DAG.getNode(ISD::MUL, dl, Index.getValueType(), Index,
|
||||
DAG.getConstant(EltSize, Index.getValueType()));
|
||||
DAG.getConstant(EltSize, dl, Index.getValueType()));
|
||||
return DAG.getNode(ISD::ADD, dl, Index.getValueType(), Index, VecPtr);
|
||||
}
|
||||
|
||||
|
@ -1029,7 +1029,8 @@ SDValue DAGTypeLegalizer::JoinIntegers(SDValue Lo, SDValue Hi) {
|
|||
Lo = DAG.getNode(ISD::ZERO_EXTEND, dlLo, NVT, Lo);
|
||||
Hi = DAG.getNode(ISD::ANY_EXTEND, dlHi, NVT, Hi);
|
||||
Hi = DAG.getNode(ISD::SHL, dlHi, NVT, Hi,
|
||||
DAG.getConstant(LVT.getSizeInBits(), TLI.getPointerTy()));
|
||||
DAG.getConstant(LVT.getSizeInBits(), dlHi,
|
||||
TLI.getPointerTy()));
|
||||
return DAG.getNode(ISD::OR, dlHi, NVT, Lo, Hi);
|
||||
}
|
||||
|
||||
|
@ -1115,7 +1116,8 @@ void DAGTypeLegalizer::SplitInteger(SDValue Op,
|
|||
Op.getValueType().getSizeInBits() && "Invalid integer splitting!");
|
||||
Lo = DAG.getNode(ISD::TRUNCATE, dl, LoVT, Op);
|
||||
Hi = DAG.getNode(ISD::SRL, dl, Op.getValueType(), Op,
|
||||
DAG.getConstant(LoVT.getSizeInBits(), TLI.getPointerTy()));
|
||||
DAG.getConstant(LoVT.getSizeInBits(), dl,
|
||||
TLI.getPointerTy()));
|
||||
Hi = DAG.getNode(ISD::TRUNCATE, dl, HiVT, Hi);
|
||||
}
|
||||
|
||||
|
|
|
@ -120,7 +120,7 @@ void DAGTypeLegalizer::ExpandRes_BITCAST(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
SmallVector<SDValue, 8> Vals;
|
||||
for (unsigned i = 0; i < NumElems; ++i)
|
||||
Vals.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, ElemVT,
|
||||
CastInOp, DAG.getConstant(i,
|
||||
CastInOp, DAG.getConstant(i, dl,
|
||||
TLI.getVectorIdxTy())));
|
||||
|
||||
// Build Lo, Hi pair by pairing extracted elements if needed.
|
||||
|
@ -173,7 +173,7 @@ void DAGTypeLegalizer::ExpandRes_BITCAST(SDNode *N, SDValue &Lo, SDValue &Hi) {
|
|||
// Increment the pointer to the other half.
|
||||
unsigned IncrementSize = NOutVT.getSizeInBits() / 8;
|
||||
StackPtr = DAG.getNode(ISD::ADD, dl, StackPtr.getValueType(), StackPtr,
|
||||
DAG.getConstant(IncrementSize,
|
||||
DAG.getConstant(IncrementSize, dl,
|
||||
StackPtr.getValueType()));
|
||||
|
||||
// Load the second half from the stack slot.
|
||||
|
@ -238,7 +238,7 @@ void DAGTypeLegalizer::ExpandRes_EXTRACT_VECTOR_ELT(SDNode *N, SDValue &Lo,
|
|||
Lo = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, NewVT, NewVec, Idx);
|
||||
|
||||
Idx = DAG.getNode(ISD::ADD, dl, Idx.getValueType(), Idx,
|
||||
DAG.getConstant(1, Idx.getValueType()));
|
||||
DAG.getConstant(1, dl, Idx.getValueType()));
|
||||
Hi = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, NewVT, NewVec, Idx);
|
||||
|
||||
if (TLI.isBigEndian())
|
||||
|
@ -270,7 +270,7 @@ void DAGTypeLegalizer::ExpandRes_NormalLoad(SDNode *N, SDValue &Lo,
|
|||
// Increment the pointer to the other half.
|
||||
unsigned IncrementSize = NVT.getSizeInBits() / 8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getLoad(NVT, dl, Chain, Ptr,
|
||||
LD->getPointerInfo().getWithOffset(IncrementSize),
|
||||
isVolatile, isNonTemporal, isInvariant,
|
||||
|
@ -439,7 +439,7 @@ SDValue DAGTypeLegalizer::ExpandOp_INSERT_VECTOR_ELT(SDNode *N) {
|
|||
NewVec = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, NewVecVT, NewVec, Lo, Idx);
|
||||
Idx = DAG.getNode(ISD::ADD, dl,
|
||||
Idx.getValueType(), Idx,
|
||||
DAG.getConstant(1, Idx.getValueType()));
|
||||
DAG.getConstant(1, dl, Idx.getValueType()));
|
||||
NewVec = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, NewVecVT, NewVec, Hi, Idx);
|
||||
|
||||
// Convert the new vector to the old vector type.
|
||||
|
@ -488,7 +488,7 @@ SDValue DAGTypeLegalizer::ExpandOp_NormalStore(SDNode *N, unsigned OpNo) {
|
|||
isVolatile, isNonTemporal, Alignment, AAInfo);
|
||||
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getStore(Chain, dl, Hi, Ptr,
|
||||
St->getPointerInfo().getWithOffset(IncrementSize),
|
||||
isVolatile, isNonTemporal,
|
||||
|
|
|
@ -407,7 +407,7 @@ SDValue VectorLegalizer::Promote(SDValue Op) {
|
|||
if ((VT.isFloatingPoint() && NVT.isFloatingPoint()) ||
|
||||
(VT.isVector() && VT.getVectorElementType().isFloatingPoint() &&
|
||||
NVT.isVector() && NVT.getVectorElementType().isFloatingPoint()))
|
||||
return DAG.getNode(ISD::FP_ROUND, dl, VT, Op, DAG.getIntPtrConstant(0));
|
||||
return DAG.getNode(ISD::FP_ROUND, dl, VT, Op, DAG.getIntPtrConstant(0, dl));
|
||||
else
|
||||
return DAG.getNode(ISD::BITCAST, dl, VT, Op);
|
||||
}
|
||||
|
@ -536,7 +536,8 @@ SDValue VectorLegalizer::ExpandLoad(SDValue Op) {
|
|||
RemainingBytes -= LoadBytes;
|
||||
Offset += LoadBytes;
|
||||
BasePTR = DAG.getNode(ISD::ADD, dl, BasePTR.getValueType(), BasePTR,
|
||||
DAG.getConstant(LoadBytes, BasePTR.getValueType()));
|
||||
DAG.getConstant(LoadBytes, dl,
|
||||
BasePTR.getValueType()));
|
||||
|
||||
LoadVals.push_back(ScalarLoad.getValue(0));
|
||||
LoadChains.push_back(ScalarLoad.getValue(1));
|
||||
|
@ -544,7 +545,7 @@ SDValue VectorLegalizer::ExpandLoad(SDValue Op) {
|
|||
|
||||
// Extract bits, pack and extend/trunc them into destination type.
|
||||
unsigned SrcEltBits = SrcEltVT.getSizeInBits();
|
||||
SDValue SrcEltBitMask = DAG.getConstant((1U << SrcEltBits) - 1, WideVT);
|
||||
SDValue SrcEltBitMask = DAG.getConstant((1U << SrcEltBits) - 1, dl, WideVT);
|
||||
|
||||
unsigned BitOffset = 0;
|
||||
unsigned WideIdx = 0;
|
||||
|
@ -554,7 +555,7 @@ SDValue VectorLegalizer::ExpandLoad(SDValue Op) {
|
|||
SDValue Lo, Hi, ShAmt;
|
||||
|
||||
if (BitOffset < WideBits) {
|
||||
ShAmt = DAG.getConstant(BitOffset, TLI.getShiftAmountTy(WideVT));
|
||||
ShAmt = DAG.getConstant(BitOffset, dl, TLI.getShiftAmountTy(WideVT));
|
||||
Lo = DAG.getNode(ISD::SRL, dl, WideVT, LoadVals[WideIdx], ShAmt);
|
||||
Lo = DAG.getNode(ISD::AND, dl, WideVT, Lo, SrcEltBitMask);
|
||||
}
|
||||
|
@ -564,7 +565,7 @@ SDValue VectorLegalizer::ExpandLoad(SDValue Op) {
|
|||
WideIdx++;
|
||||
BitOffset -= WideBits;
|
||||
if (BitOffset > 0) {
|
||||
ShAmt = DAG.getConstant(SrcEltBits - BitOffset,
|
||||
ShAmt = DAG.getConstant(SrcEltBits - BitOffset, dl,
|
||||
TLI.getShiftAmountTy(WideVT));
|
||||
Hi = DAG.getNode(ISD::SHL, dl, WideVT, LoadVals[WideIdx], ShAmt);
|
||||
Hi = DAG.getNode(ISD::AND, dl, WideVT, Hi, SrcEltBitMask);
|
||||
|
@ -583,7 +584,7 @@ SDValue VectorLegalizer::ExpandLoad(SDValue Op) {
|
|||
Lo = DAG.getZExtOrTrunc(Lo, dl, DstEltVT);
|
||||
break;
|
||||
case ISD::SEXTLOAD:
|
||||
ShAmt = DAG.getConstant(WideBits - SrcEltBits,
|
||||
ShAmt = DAG.getConstant(WideBits - SrcEltBits, dl,
|
||||
TLI.getShiftAmountTy(WideVT));
|
||||
Lo = DAG.getNode(ISD::SHL, dl, WideVT, Lo, ShAmt);
|
||||
Lo = DAG.getNode(ISD::SRA, dl, WideVT, Lo, ShAmt);
|
||||
|
@ -604,7 +605,7 @@ SDValue VectorLegalizer::ExpandLoad(SDValue Op) {
|
|||
MinAlign(LD->getAlignment(), Idx * Stride), LD->getAAInfo());
|
||||
|
||||
BasePTR = DAG.getNode(ISD::ADD, dl, BasePTR.getValueType(), BasePTR,
|
||||
DAG.getConstant(Stride, BasePTR.getValueType()));
|
||||
DAG.getConstant(Stride, dl, BasePTR.getValueType()));
|
||||
|
||||
Vals.push_back(ScalarLoad.getValue(0));
|
||||
LoadChains.push_back(ScalarLoad.getValue(1));
|
||||
|
@ -655,7 +656,7 @@ SDValue VectorLegalizer::ExpandStore(SDValue Op) {
|
|||
SmallVector<SDValue, 8> Stores;
|
||||
for (unsigned Idx = 0; Idx < NumElem; Idx++) {
|
||||
SDValue Ex = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
RegSclVT, Value, DAG.getConstant(Idx, TLI.getVectorIdxTy()));
|
||||
RegSclVT, Value, DAG.getConstant(Idx, dl, TLI.getVectorIdxTy()));
|
||||
|
||||
// This scalar TruncStore may be illegal, but we legalize it later.
|
||||
SDValue Store = DAG.getTruncStore(Chain, dl, Ex, BasePTR,
|
||||
|
@ -664,7 +665,7 @@ SDValue VectorLegalizer::ExpandStore(SDValue Op) {
|
|||
AAInfo);
|
||||
|
||||
BasePTR = DAG.getNode(ISD::ADD, dl, BasePTR.getValueType(), BasePTR,
|
||||
DAG.getConstant(Stride, BasePTR.getValueType()));
|
||||
DAG.getConstant(Stride, dl, BasePTR.getValueType()));
|
||||
|
||||
Stores.push_back(Store);
|
||||
}
|
||||
|
@ -734,8 +735,9 @@ SDValue VectorLegalizer::ExpandSELECT(SDValue Op) {
|
|||
EVT BitTy = MaskTy.getScalarType();
|
||||
|
||||
Mask = DAG.getSelect(DL, BitTy, Mask,
|
||||
DAG.getConstant(APInt::getAllOnesValue(BitTy.getSizeInBits()), BitTy),
|
||||
DAG.getConstant(0, BitTy));
|
||||
DAG.getConstant(APInt::getAllOnesValue(BitTy.getSizeInBits()), DL,
|
||||
BitTy),
|
||||
DAG.getConstant(0, DL, BitTy));
|
||||
|
||||
// Broadcast the mask so that the entire vector is all-one or all zero.
|
||||
SmallVector<SDValue, 8> Ops(NumElem, Mask);
|
||||
|
@ -748,7 +750,7 @@ SDValue VectorLegalizer::ExpandSELECT(SDValue Op) {
|
|||
Op2 = DAG.getNode(ISD::BITCAST, DL, MaskTy, Op2);
|
||||
|
||||
SDValue AllOnes = DAG.getConstant(
|
||||
APInt::getAllOnesValue(BitTy.getSizeInBits()), MaskTy);
|
||||
APInt::getAllOnesValue(BitTy.getSizeInBits()), DL, MaskTy);
|
||||
SDValue NotMask = DAG.getNode(ISD::XOR, DL, MaskTy, Mask, AllOnes);
|
||||
|
||||
Op1 = DAG.getNode(ISD::AND, DL, MaskTy, Op1, Mask);
|
||||
|
@ -770,7 +772,7 @@ SDValue VectorLegalizer::ExpandSEXTINREG(SDValue Op) {
|
|||
|
||||
unsigned BW = VT.getScalarType().getSizeInBits();
|
||||
unsigned OrigBW = OrigTy.getScalarType().getSizeInBits();
|
||||
SDValue ShiftSz = DAG.getConstant(BW - OrigBW, VT);
|
||||
SDValue ShiftSz = DAG.getConstant(BW - OrigBW, DL, VT);
|
||||
|
||||
Op = Op.getOperand(0);
|
||||
Op = DAG.getNode(ISD::SHL, DL, VT, Op, ShiftSz);
|
||||
|
@ -817,7 +819,7 @@ SDValue VectorLegalizer::ExpandSIGN_EXTEND_VECTOR_INREG(SDValue Op) {
|
|||
// without full scalarization than the sign extension does.
|
||||
unsigned EltWidth = VT.getVectorElementType().getSizeInBits();
|
||||
unsigned SrcEltWidth = SrcVT.getVectorElementType().getSizeInBits();
|
||||
SDValue ShiftAmount = DAG.getConstant(EltWidth - SrcEltWidth, VT);
|
||||
SDValue ShiftAmount = DAG.getConstant(EltWidth - SrcEltWidth, DL, VT);
|
||||
return DAG.getNode(ISD::SRA, DL, VT,
|
||||
DAG.getNode(ISD::SHL, DL, VT, Op, ShiftAmount),
|
||||
ShiftAmount);
|
||||
|
@ -836,7 +838,7 @@ SDValue VectorLegalizer::ExpandZERO_EXTEND_VECTOR_INREG(SDValue Op) {
|
|||
|
||||
// Build up a zero vector to blend into this one.
|
||||
EVT SrcScalarVT = SrcVT.getScalarType();
|
||||
SDValue ScalarZero = DAG.getTargetConstant(0, SrcScalarVT);
|
||||
SDValue ScalarZero = DAG.getTargetConstant(0, DL, SrcScalarVT);
|
||||
SmallVector<SDValue, 4> BuildVectorOperands(NumSrcElements, ScalarZero);
|
||||
SDValue Zero = DAG.getNode(ISD::BUILD_VECTOR, DL, SrcVT, BuildVectorOperands);
|
||||
|
||||
|
@ -917,7 +919,7 @@ SDValue VectorLegalizer::ExpandVSELECT(SDValue Op) {
|
|||
Op2 = DAG.getNode(ISD::BITCAST, DL, VT, Op2);
|
||||
|
||||
SDValue AllOnes = DAG.getConstant(
|
||||
APInt::getAllOnesValue(VT.getScalarType().getSizeInBits()), VT);
|
||||
APInt::getAllOnesValue(VT.getScalarType().getSizeInBits()), DL, VT);
|
||||
SDValue NotMask = DAG.getNode(ISD::XOR, DL, VT, Mask, AllOnes);
|
||||
|
||||
Op1 = DAG.getNode(ISD::AND, DL, VT, Op1, Mask);
|
||||
|
@ -940,16 +942,16 @@ SDValue VectorLegalizer::ExpandUINT_TO_FLOAT(SDValue Op) {
|
|||
"Elements in vector-UINT_TO_FP must be 32 or 64 bits wide");
|
||||
|
||||
unsigned BW = SVT.getSizeInBits();
|
||||
SDValue HalfWord = DAG.getConstant(BW/2, VT);
|
||||
SDValue HalfWord = DAG.getConstant(BW/2, DL, VT);
|
||||
|
||||
// Constants to clear the upper part of the word.
|
||||
// Notice that we can also use SHL+SHR, but using a constant is slightly
|
||||
// faster on x86.
|
||||
uint64_t HWMask = (SVT.getSizeInBits()==64)?0x00000000FFFFFFFF:0x0000FFFF;
|
||||
SDValue HalfWordMask = DAG.getConstant(HWMask, VT);
|
||||
SDValue HalfWordMask = DAG.getConstant(HWMask, DL, VT);
|
||||
|
||||
// Two to the power of half-word-size.
|
||||
SDValue TWOHW = DAG.getConstantFP((1<<(BW/2)), Op.getValueType());
|
||||
SDValue TWOHW = DAG.getConstantFP(1 << (BW/2), DL, Op.getValueType());
|
||||
|
||||
// Clear upper part of LO, lower HI
|
||||
SDValue HI = DAG.getNode(ISD::SRL, DL, VT, Op.getOperand(0), HalfWord);
|
||||
|
@ -968,8 +970,9 @@ SDValue VectorLegalizer::ExpandUINT_TO_FLOAT(SDValue Op) {
|
|||
|
||||
SDValue VectorLegalizer::ExpandFNEG(SDValue Op) {
|
||||
if (TLI.isOperationLegalOrCustom(ISD::FSUB, Op.getValueType())) {
|
||||
SDValue Zero = DAG.getConstantFP(-0.0, Op.getValueType());
|
||||
return DAG.getNode(ISD::FSUB, SDLoc(Op), Op.getValueType(),
|
||||
SDLoc DL(Op);
|
||||
SDValue Zero = DAG.getConstantFP(-0.0, DL, Op.getValueType());
|
||||
return DAG.getNode(ISD::FSUB, DL, Op.getValueType(),
|
||||
Zero, Op.getOperand(0));
|
||||
}
|
||||
return DAG.UnrollVectorOp(Op.getNode());
|
||||
|
@ -985,16 +988,16 @@ SDValue VectorLegalizer::UnrollVSETCC(SDValue Op) {
|
|||
SmallVector<SDValue, 8> Ops(NumElems);
|
||||
for (unsigned i = 0; i < NumElems; ++i) {
|
||||
SDValue LHSElem = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, TmpEltVT, LHS,
|
||||
DAG.getConstant(i, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(i, dl, TLI.getVectorIdxTy()));
|
||||
SDValue RHSElem = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, TmpEltVT, RHS,
|
||||
DAG.getConstant(i, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(i, dl, TLI.getVectorIdxTy()));
|
||||
Ops[i] = DAG.getNode(ISD::SETCC, dl,
|
||||
TLI.getSetCCResultType(*DAG.getContext(), TmpEltVT),
|
||||
LHSElem, RHSElem, CC);
|
||||
Ops[i] = DAG.getSelect(dl, EltVT, Ops[i],
|
||||
DAG.getConstant(APInt::getAllOnesValue
|
||||
(EltVT.getSizeInBits()), EltVT),
|
||||
DAG.getConstant(0, EltVT));
|
||||
(EltVT.getSizeInBits()), dl, EltVT),
|
||||
DAG.getConstant(0, dl, EltVT));
|
||||
}
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, dl, VT, Ops);
|
||||
}
|
||||
|
|
|
@ -252,7 +252,7 @@ SDValue DAGTypeLegalizer::ScalarizeVecRes_UnaryOp(SDNode *N) {
|
|||
} else {
|
||||
EVT VT = OpVT.getVectorElementType();
|
||||
Op = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, Op,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, DL, TLI.getVectorIdxTy()));
|
||||
}
|
||||
return DAG.getNode(N->getOpcode(), SDLoc(N), DestVT, Op);
|
||||
}
|
||||
|
@ -308,7 +308,7 @@ SDValue DAGTypeLegalizer::ScalarizeVecRes_VSELECT(SDNode *N) {
|
|||
VecBool == TargetLowering::ZeroOrNegativeOneBooleanContent);
|
||||
// Vector read from all ones, scalar expects a single 1 so mask.
|
||||
Cond = DAG.getNode(ISD::AND, SDLoc(N), CondVT,
|
||||
Cond, DAG.getConstant(1, CondVT));
|
||||
Cond, DAG.getConstant(1, SDLoc(N), CondVT));
|
||||
break;
|
||||
case TargetLowering::ZeroOrNegativeOneBooleanContent:
|
||||
assert(VecBool == TargetLowering::UndefinedBooleanContent ||
|
||||
|
@ -385,9 +385,9 @@ SDValue DAGTypeLegalizer::ScalarizeVecRes_VSETCC(SDNode *N) {
|
|||
} else {
|
||||
EVT VT = OpVT.getVectorElementType();
|
||||
LHS = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, LHS,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, DL, TLI.getVectorIdxTy()));
|
||||
RHS = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, RHS,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, DL, TLI.getVectorIdxTy()));
|
||||
}
|
||||
|
||||
// Turn it into a scalar SETCC.
|
||||
|
@ -811,7 +811,7 @@ void DAGTypeLegalizer::SplitVecRes_EXTRACT_SUBVECTOR(SDNode *N, SDValue &Lo,
|
|||
Lo = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, LoVT, Vec, Idx);
|
||||
uint64_t IdxVal = cast<ConstantSDNode>(Idx)->getZExtValue();
|
||||
Hi = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, HiVT, Vec,
|
||||
DAG.getConstant(IdxVal + LoVT.getVectorNumElements(),
|
||||
DAG.getConstant(IdxVal + LoVT.getVectorNumElements(), dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
}
|
||||
|
||||
|
@ -845,7 +845,7 @@ void DAGTypeLegalizer::SplitVecRes_INSERT_SUBVECTOR(SDNode *N, SDValue &Lo,
|
|||
unsigned IncrementSize = Lo.getValueType().getSizeInBits() / 8;
|
||||
StackPtr =
|
||||
DAG.getNode(ISD::ADD, dl, StackPtr.getValueType(), StackPtr,
|
||||
DAG.getConstant(IncrementSize, StackPtr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, StackPtr.getValueType()));
|
||||
|
||||
// Load the Hi part from the stack slot.
|
||||
Hi = DAG.getLoad(Hi.getValueType(), dl, Store, StackPtr, MachinePointerInfo(),
|
||||
|
@ -892,7 +892,7 @@ void DAGTypeLegalizer::SplitVecRes_INSERT_VECTOR_ELT(SDNode *N, SDValue &Lo,
|
|||
Lo.getValueType(), Lo, Elt, Idx);
|
||||
else
|
||||
Hi = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, Hi.getValueType(), Hi, Elt,
|
||||
DAG.getConstant(IdxVal - LoNumElts,
|
||||
DAG.getConstant(IdxVal - LoNumElts, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
return;
|
||||
}
|
||||
|
@ -924,7 +924,8 @@ void DAGTypeLegalizer::SplitVecRes_INSERT_VECTOR_ELT(SDNode *N, SDValue &Lo,
|
|||
// Increment the pointer to the other part.
|
||||
unsigned IncrementSize = Lo.getValueType().getSizeInBits() / 8;
|
||||
StackPtr = DAG.getNode(ISD::ADD, dl, StackPtr.getValueType(), StackPtr,
|
||||
DAG.getConstant(IncrementSize, StackPtr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl,
|
||||
StackPtr.getValueType()));
|
||||
|
||||
// Load the Hi part from the stack slot.
|
||||
Hi = DAG.getLoad(Hi.getValueType(), dl, Store, StackPtr, MachinePointerInfo(),
|
||||
|
@ -967,7 +968,7 @@ void DAGTypeLegalizer::SplitVecRes_LOAD(LoadSDNode *LD, SDValue &Lo,
|
|||
|
||||
unsigned IncrementSize = LoMemVT.getSizeInBits()/8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
Hi = DAG.getLoad(ISD::UNINDEXED, ExtType, HiVT, dl, Ch, Ptr, Offset,
|
||||
LD->getPointerInfo().getWithOffset(IncrementSize),
|
||||
HiMemVT, isVolatile, isNonTemporal, isInvariant, Alignment,
|
||||
|
@ -1022,7 +1023,7 @@ void DAGTypeLegalizer::SplitVecRes_MLOAD(MaskedLoadSDNode *MLD,
|
|||
|
||||
unsigned IncrementSize = LoMemVT.getSizeInBits()/8;
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, dl, Ptr.getValueType()));
|
||||
|
||||
MMO = DAG.getMachineFunction().
|
||||
getMachineMemOperand(MLD->getPointerInfo(),
|
||||
|
@ -1237,8 +1238,9 @@ void DAGTypeLegalizer::SplitVecRes_VECTOR_SHUFFLE(ShuffleVectorSDNode *N,
|
|||
|
||||
// Extract the vector element by hand.
|
||||
SVOps.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT,
|
||||
Inputs[Input], DAG.getConstant(Idx,
|
||||
TLI.getVectorIdxTy())));
|
||||
Inputs[Input],
|
||||
DAG.getConstant(Idx, dl,
|
||||
TLI.getVectorIdxTy())));
|
||||
}
|
||||
|
||||
// Construct the Lo/Hi output using a BUILD_VECTOR.
|
||||
|
@ -1433,7 +1435,8 @@ SDValue DAGTypeLegalizer::SplitVecOp_EXTRACT_SUBVECTOR(SDNode *N) {
|
|||
return DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, SubVT, Lo, Idx);
|
||||
} else {
|
||||
return DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, SubVT, Hi,
|
||||
DAG.getConstant(IdxVal - LoElts, Idx.getValueType()));
|
||||
DAG.getConstant(IdxVal - LoElts, dl,
|
||||
Idx.getValueType()));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1454,7 +1457,7 @@ SDValue DAGTypeLegalizer::SplitVecOp_EXTRACT_VECTOR_ELT(SDNode *N) {
|
|||
if (IdxVal < LoElts)
|
||||
return SDValue(DAG.UpdateNodeOperands(N, Lo, Idx), 0);
|
||||
return SDValue(DAG.UpdateNodeOperands(N, Hi,
|
||||
DAG.getConstant(IdxVal - LoElts,
|
||||
DAG.getConstant(IdxVal - LoElts, SDLoc(N),
|
||||
Idx.getValueType())), 0);
|
||||
}
|
||||
|
||||
|
@ -1510,7 +1513,7 @@ SDValue DAGTypeLegalizer::SplitVecOp_MSTORE(MaskedStoreSDNode *N,
|
|||
|
||||
unsigned IncrementSize = LoMemVT.getSizeInBits()/8;
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, DL, Ptr.getValueType()));
|
||||
|
||||
MMO = DAG.getMachineFunction().
|
||||
getMachineMemOperand(N->getPointerInfo(),
|
||||
|
@ -1557,7 +1560,7 @@ SDValue DAGTypeLegalizer::SplitVecOp_STORE(StoreSDNode *N, unsigned OpNo) {
|
|||
|
||||
// Increment the pointer to the other half.
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(IncrementSize, Ptr.getValueType()));
|
||||
DAG.getConstant(IncrementSize, DL, Ptr.getValueType()));
|
||||
|
||||
if (isTruncating)
|
||||
Hi = DAG.getTruncStore(Ch, DL, Hi, Ptr,
|
||||
|
@ -1586,7 +1589,7 @@ SDValue DAGTypeLegalizer::SplitVecOp_CONCAT_VECTORS(SDNode *N) {
|
|||
for (unsigned i = 0, e = Op.getValueType().getVectorNumElements();
|
||||
i != e; ++i) {
|
||||
Elts.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT,
|
||||
Op, DAG.getConstant(i, TLI.getVectorIdxTy())));
|
||||
Op, DAG.getConstant(i, DL, TLI.getVectorIdxTy())));
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -1653,7 +1656,7 @@ SDValue DAGTypeLegalizer::SplitVecOp_TruncateHelper(SDNode *N) {
|
|||
// restricted set of legal types, this split can chain to build things up.
|
||||
return IsFloat ?
|
||||
DAG.getNode(ISD::FP_ROUND, DL, OutVT, InterVec,
|
||||
DAG.getTargetConstant(0, TLI.getPointerTy())) :
|
||||
DAG.getTargetConstant(0, DL, TLI.getPointerTy())) :
|
||||
DAG.getNode(ISD::TRUNCATE, DL, OutVT, InterVec);
|
||||
}
|
||||
|
||||
|
@ -1885,9 +1888,11 @@ SDValue DAGTypeLegalizer::WidenVecRes_BinaryCanTrap(SDNode *N) {
|
|||
while (CurNumElts != 0) {
|
||||
while (CurNumElts >= NumElts) {
|
||||
SDValue EOp1 = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, VT, InOp1,
|
||||
DAG.getConstant(Idx, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(Idx, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
SDValue EOp2 = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, VT, InOp2,
|
||||
DAG.getConstant(Idx, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(Idx, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
ConcatOps[ConcatEnd++] = DAG.getNode(Opcode, dl, VT, EOp1, EOp2);
|
||||
Idx += NumElts;
|
||||
CurNumElts -= NumElts;
|
||||
|
@ -1900,11 +1905,13 @@ SDValue DAGTypeLegalizer::WidenVecRes_BinaryCanTrap(SDNode *N) {
|
|||
if (NumElts == 1) {
|
||||
for (unsigned i = 0; i != CurNumElts; ++i, ++Idx) {
|
||||
SDValue EOp1 = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, WidenEltVT,
|
||||
InOp1, DAG.getConstant(Idx,
|
||||
TLI.getVectorIdxTy()));
|
||||
InOp1,
|
||||
DAG.getConstant(Idx, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
SDValue EOp2 = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, WidenEltVT,
|
||||
InOp2, DAG.getConstant(Idx,
|
||||
TLI.getVectorIdxTy()));
|
||||
InOp2,
|
||||
DAG.getConstant(Idx, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
ConcatOps[ConcatEnd++] = DAG.getNode(Opcode, dl, WidenEltVT,
|
||||
EOp1, EOp2);
|
||||
}
|
||||
|
@ -1942,8 +1949,8 @@ SDValue DAGTypeLegalizer::WidenVecRes_BinaryCanTrap(SDNode *N) {
|
|||
unsigned NumToInsert = ConcatEnd - Idx - 1;
|
||||
for (unsigned i = 0, OpIdx = Idx+1; i < NumToInsert; i++, OpIdx++) {
|
||||
VecOp = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, NextVT, VecOp,
|
||||
ConcatOps[OpIdx], DAG.getConstant(i,
|
||||
TLI.getVectorIdxTy()));
|
||||
ConcatOps[OpIdx],
|
||||
DAG.getConstant(i, dl, TLI.getVectorIdxTy()));
|
||||
}
|
||||
ConcatOps[Idx+1] = VecOp;
|
||||
ConcatEnd = Idx + 2;
|
||||
|
@ -2029,9 +2036,8 @@ SDValue DAGTypeLegalizer::WidenVecRes_Convert(SDNode *N) {
|
|||
}
|
||||
|
||||
if (InVTNumElts % WidenNumElts == 0) {
|
||||
SDValue InVal = DAG.getNode(ISD::EXTRACT_SUBVECTOR, DL, InWidenVT,
|
||||
InOp, DAG.getConstant(0,
|
||||
TLI.getVectorIdxTy()));
|
||||
SDValue InVal = DAG.getNode(ISD::EXTRACT_SUBVECTOR, DL, InWidenVT, InOp,
|
||||
DAG.getConstant(0, DL, TLI.getVectorIdxTy()));
|
||||
// Extract the input and convert the shorten input vector.
|
||||
if (N->getNumOperands() == 1)
|
||||
return DAG.getNode(Opcode, DL, WidenVT, InVal);
|
||||
|
@ -2046,7 +2052,7 @@ SDValue DAGTypeLegalizer::WidenVecRes_Convert(SDNode *N) {
|
|||
unsigned i;
|
||||
for (i=0; i < MinElts; ++i) {
|
||||
SDValue Val = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, InEltVT, InOp,
|
||||
DAG.getConstant(i, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(i, DL, TLI.getVectorIdxTy()));
|
||||
if (N->getNumOperands() == 1)
|
||||
Ops[i] = DAG.getNode(Opcode, DL, EltVT, Val);
|
||||
else
|
||||
|
@ -2273,7 +2279,7 @@ SDValue DAGTypeLegalizer::WidenVecRes_CONCAT_VECTORS(SDNode *N) {
|
|||
InOp = GetWidenedVector(InOp);
|
||||
for (unsigned j=0; j < NumInElts; ++j)
|
||||
Ops[Idx++] = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, InOp,
|
||||
DAG.getConstant(j, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(j, dl, TLI.getVectorIdxTy()));
|
||||
}
|
||||
SDValue UndefVal = DAG.getUNDEF(EltVT);
|
||||
for (; Idx < WidenNumElts; ++Idx)
|
||||
|
@ -2331,7 +2337,7 @@ SDValue DAGTypeLegalizer::WidenVecRes_CONVERT_RNDSAT(SDNode *N) {
|
|||
if (InVTNumElts % WidenNumElts == 0) {
|
||||
// Extract the input and convert the shorten input vector.
|
||||
InOp = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, InWidenVT, InOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, dl, TLI.getVectorIdxTy()));
|
||||
return DAG.getConvertRndSat(WidenVT, dl, InOp, DTyOp, STyOp, RndOp,
|
||||
SatOp, CvtCode);
|
||||
}
|
||||
|
@ -2347,7 +2353,7 @@ SDValue DAGTypeLegalizer::WidenVecRes_CONVERT_RNDSAT(SDNode *N) {
|
|||
unsigned i;
|
||||
for (i=0; i < MinElts; ++i) {
|
||||
SDValue ExtVal = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, InEltVT, InOp,
|
||||
DAG.getConstant(i, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(i, dl, TLI.getVectorIdxTy()));
|
||||
Ops[i] = DAG.getConvertRndSat(WidenVT, dl, ExtVal, DTyOp, STyOp, RndOp,
|
||||
SatOp, CvtCode);
|
||||
}
|
||||
|
@ -2390,7 +2396,7 @@ SDValue DAGTypeLegalizer::WidenVecRes_EXTRACT_SUBVECTOR(SDNode *N) {
|
|||
unsigned i;
|
||||
for (i=0; i < NumElts; ++i)
|
||||
Ops[i] = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, InOp,
|
||||
DAG.getConstant(IdxVal+i, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(IdxVal + i, dl, TLI.getVectorIdxTy()));
|
||||
|
||||
SDValue UndefVal = DAG.getUNDEF(EltVT);
|
||||
for (; i < WidenNumElts; ++i)
|
||||
|
@ -2453,7 +2459,7 @@ SDValue DAGTypeLegalizer::WidenVecRes_MLOAD(MaskedLoadSDNode *N) {
|
|||
|
||||
unsigned NumConcat = WidenNumElts / MaskNumElts;
|
||||
SmallVector<SDValue, 16> Ops(NumConcat);
|
||||
SDValue ZeroVal = DAG.getConstant(0, MaskVT);
|
||||
SDValue ZeroVal = DAG.getConstant(0, dl, MaskVT);
|
||||
Ops[0] = Mask;
|
||||
for (unsigned i = 1; i != NumConcat; ++i)
|
||||
Ops[i] = ZeroVal;
|
||||
|
@ -2693,10 +2699,10 @@ SDValue DAGTypeLegalizer::WidenVecOp_EXTEND(SDNode *N) {
|
|||
if (FixedVT.getVectorNumElements() > InVT.getVectorNumElements())
|
||||
InOp = DAG.getNode(ISD::INSERT_SUBVECTOR, DL, FixedVT,
|
||||
DAG.getUNDEF(FixedVT), InOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, DL, TLI.getVectorIdxTy()));
|
||||
else
|
||||
InOp = DAG.getNode(ISD::EXTRACT_SUBVECTOR, DL, FixedVT, InOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, DL, TLI.getVectorIdxTy()));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -2741,7 +2747,8 @@ SDValue DAGTypeLegalizer::WidenVecOp_Convert(SDNode *N) {
|
|||
for (unsigned i=0; i < NumElts; ++i)
|
||||
Ops[i] = DAG.getNode(Opcode, dl, EltVT,
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, InEltVT, InOp,
|
||||
DAG.getConstant(i, TLI.getVectorIdxTy())));
|
||||
DAG.getConstant(i, dl,
|
||||
TLI.getVectorIdxTy())));
|
||||
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, dl, VT, Ops);
|
||||
}
|
||||
|
@ -2762,7 +2769,7 @@ SDValue DAGTypeLegalizer::WidenVecOp_BITCAST(SDNode *N) {
|
|||
if (TLI.isTypeLegal(NewVT)) {
|
||||
SDValue BitOp = DAG.getNode(ISD::BITCAST, dl, NewVT, InOp);
|
||||
return DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, VT, BitOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, dl, TLI.getVectorIdxTy()));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -2790,7 +2797,7 @@ SDValue DAGTypeLegalizer::WidenVecOp_CONCAT_VECTORS(SDNode *N) {
|
|||
InOp = GetWidenedVector(InOp);
|
||||
for (unsigned j=0; j < NumInElts; ++j)
|
||||
Ops[Idx++] = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, InOp,
|
||||
DAG.getConstant(j, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(j, dl, TLI.getVectorIdxTy()));
|
||||
}
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, dl, VT, Ops);
|
||||
}
|
||||
|
@ -2845,7 +2852,7 @@ SDValue DAGTypeLegalizer::WidenVecOp_MSTORE(SDNode *N, unsigned OpNo) {
|
|||
|
||||
unsigned NumConcat = WidenNumElts / MaskNumElts;
|
||||
SmallVector<SDValue, 16> Ops(NumConcat);
|
||||
SDValue ZeroVal = DAG.getConstant(0, MaskVT);
|
||||
SDValue ZeroVal = DAG.getConstant(0, dl, MaskVT);
|
||||
Ops[0] = Mask;
|
||||
for (unsigned i = 1; i != NumConcat; ++i)
|
||||
Ops[i] = ZeroVal;
|
||||
|
@ -2880,8 +2887,8 @@ SDValue DAGTypeLegalizer::WidenVecOp_SETCC(SDNode *N) {
|
|||
SVT.getVectorElementType(),
|
||||
N->getValueType(0).getVectorNumElements());
|
||||
SDValue CC = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl,
|
||||
ResVT, WideSETCC, DAG.getConstant(0,
|
||||
TLI.getVectorIdxTy()));
|
||||
ResVT, WideSETCC,
|
||||
DAG.getConstant(0, dl, TLI.getVectorIdxTy()));
|
||||
|
||||
return PromoteTargetBoolean(CC, N->getValueType(0));
|
||||
}
|
||||
|
@ -2975,7 +2982,7 @@ static SDValue BuildVectorFromScalar(SelectionDAG& DAG, EVT VecTy,
|
|||
LdTy = NewLdTy;
|
||||
}
|
||||
VecOp = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, NewVecVT, VecOp, LdOps[i],
|
||||
DAG.getConstant(Idx++, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(Idx++, dl, TLI.getVectorIdxTy()));
|
||||
}
|
||||
return DAG.getNode(ISD::BITCAST, dl, VecTy, VecOp);
|
||||
}
|
||||
|
@ -3046,7 +3053,7 @@ SDValue DAGTypeLegalizer::GenWidenVectorLoads(SmallVectorImpl<SDValue> &LdChain,
|
|||
unsigned Increment = NewVTWidth / 8;
|
||||
Offset += Increment;
|
||||
BasePtr = DAG.getNode(ISD::ADD, dl, BasePtr.getValueType(), BasePtr,
|
||||
DAG.getConstant(Increment, BasePtr.getValueType()));
|
||||
DAG.getConstant(Increment, dl, BasePtr.getValueType()));
|
||||
|
||||
SDValue L;
|
||||
if (LdWidth < NewVTWidth) {
|
||||
|
@ -3172,7 +3179,7 @@ DAGTypeLegalizer::GenWidenVectorExtLoads(SmallVectorImpl<SDValue> &LdChain,
|
|||
for (i=1; i < NumElts; ++i, Offset += Increment) {
|
||||
SDValue NewBasePtr = DAG.getNode(ISD::ADD, dl, BasePtr.getValueType(),
|
||||
BasePtr,
|
||||
DAG.getConstant(Offset,
|
||||
DAG.getConstant(Offset, dl,
|
||||
BasePtr.getValueType()));
|
||||
Ops[i] = DAG.getExtLoad(ExtType, dl, EltVT, Chain, NewBasePtr,
|
||||
LD->getPointerInfo().getWithOffset(Offset), LdEltVT,
|
||||
|
@ -3223,7 +3230,8 @@ void DAGTypeLegalizer::GenWidenVectorStores(SmallVectorImpl<SDValue> &StChain,
|
|||
unsigned NumVTElts = NewVT.getVectorNumElements();
|
||||
do {
|
||||
SDValue EOp = DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, NewVT, ValOp,
|
||||
DAG.getConstant(Idx, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(Idx, dl,
|
||||
TLI.getVectorIdxTy()));
|
||||
StChain.push_back(DAG.getStore(Chain, dl, EOp, BasePtr,
|
||||
ST->getPointerInfo().getWithOffset(Offset),
|
||||
isVolatile, isNonTemporal,
|
||||
|
@ -3232,7 +3240,8 @@ void DAGTypeLegalizer::GenWidenVectorStores(SmallVectorImpl<SDValue> &StChain,
|
|||
Offset += Increment;
|
||||
Idx += NumVTElts;
|
||||
BasePtr = DAG.getNode(ISD::ADD, dl, BasePtr.getValueType(), BasePtr,
|
||||
DAG.getConstant(Increment, BasePtr.getValueType()));
|
||||
DAG.getConstant(Increment, dl,
|
||||
BasePtr.getValueType()));
|
||||
} while (StWidth != 0 && StWidth >= NewVTWidth);
|
||||
} else {
|
||||
// Cast the vector to the scalar type we can store
|
||||
|
@ -3243,7 +3252,7 @@ void DAGTypeLegalizer::GenWidenVectorStores(SmallVectorImpl<SDValue> &StChain,
|
|||
Idx = Idx * ValEltWidth / NewVTWidth;
|
||||
do {
|
||||
SDValue EOp = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, NewVT, VecOp,
|
||||
DAG.getConstant(Idx++, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(Idx++, dl, TLI.getVectorIdxTy()));
|
||||
StChain.push_back(DAG.getStore(Chain, dl, EOp, BasePtr,
|
||||
ST->getPointerInfo().getWithOffset(Offset),
|
||||
isVolatile, isNonTemporal,
|
||||
|
@ -3251,7 +3260,8 @@ void DAGTypeLegalizer::GenWidenVectorStores(SmallVectorImpl<SDValue> &StChain,
|
|||
StWidth -= NewVTWidth;
|
||||
Offset += Increment;
|
||||
BasePtr = DAG.getNode(ISD::ADD, dl, BasePtr.getValueType(), BasePtr,
|
||||
DAG.getConstant(Increment, BasePtr.getValueType()));
|
||||
DAG.getConstant(Increment, dl,
|
||||
BasePtr.getValueType()));
|
||||
} while (StWidth != 0 && StWidth >= NewVTWidth);
|
||||
// Restore index back to be relative to the original widen element type
|
||||
Idx = Idx * NewVTWidth / ValEltWidth;
|
||||
|
@ -3289,7 +3299,7 @@ DAGTypeLegalizer::GenWidenVectorTruncStores(SmallVectorImpl<SDValue> &StChain,
|
|||
unsigned Increment = ValEltVT.getSizeInBits() / 8;
|
||||
unsigned NumElts = StVT.getVectorNumElements();
|
||||
SDValue EOp = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, ValEltVT, ValOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, dl, TLI.getVectorIdxTy()));
|
||||
StChain.push_back(DAG.getTruncStore(Chain, dl, EOp, BasePtr,
|
||||
ST->getPointerInfo(), StEltVT,
|
||||
isVolatile, isNonTemporal, Align,
|
||||
|
@ -3297,10 +3307,11 @@ DAGTypeLegalizer::GenWidenVectorTruncStores(SmallVectorImpl<SDValue> &StChain,
|
|||
unsigned Offset = Increment;
|
||||
for (unsigned i=1; i < NumElts; ++i, Offset += Increment) {
|
||||
SDValue NewBasePtr = DAG.getNode(ISD::ADD, dl, BasePtr.getValueType(),
|
||||
BasePtr, DAG.getConstant(Offset,
|
||||
BasePtr.getValueType()));
|
||||
BasePtr,
|
||||
DAG.getConstant(Offset, dl,
|
||||
BasePtr.getValueType()));
|
||||
SDValue EOp = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, ValEltVT, ValOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, dl, TLI.getVectorIdxTy()));
|
||||
StChain.push_back(DAG.getTruncStore(Chain, dl, EOp, NewBasePtr,
|
||||
ST->getPointerInfo().getWithOffset(Offset),
|
||||
StEltVT, isVolatile, isNonTemporal,
|
||||
|
@ -3337,7 +3348,7 @@ SDValue DAGTypeLegalizer::ModifyToType(SDValue InOp, EVT NVT) {
|
|||
|
||||
if (WidenNumElts < InNumElts && InNumElts % WidenNumElts)
|
||||
return DAG.getNode(ISD::EXTRACT_SUBVECTOR, dl, NVT, InOp,
|
||||
DAG.getConstant(0, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(0, dl, TLI.getVectorIdxTy()));
|
||||
|
||||
// Fall back to extract and build.
|
||||
SmallVector<SDValue, 16> Ops(WidenNumElts);
|
||||
|
@ -3346,7 +3357,7 @@ SDValue DAGTypeLegalizer::ModifyToType(SDValue InOp, EVT NVT) {
|
|||
unsigned Idx;
|
||||
for (Idx = 0; Idx < MinNumElts; ++Idx)
|
||||
Ops[Idx] = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, InOp,
|
||||
DAG.getConstant(Idx, TLI.getVectorIdxTy()));
|
||||
DAG.getConstant(Idx, dl, TLI.getVectorIdxTy()));
|
||||
|
||||
SDValue UndefVal = DAG.getUNDEF(EltVT);
|
||||
for ( ; Idx < WidenNumElts; ++Idx)
|
||||
|
|
|
@ -1030,7 +1030,7 @@ SDValue SelectionDAG::getZeroExtendInReg(SDValue Op, SDLoc DL, EVT VT) {
|
|||
APInt Imm = APInt::getLowBitsSet(BitWidth,
|
||||
VT.getSizeInBits());
|
||||
return getNode(ISD::AND, DL, Op.getValueType(), Op,
|
||||
getConstant(Imm, Op.getValueType()));
|
||||
getConstant(Imm, DL, Op.getValueType()));
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getAnyExtendVectorInReg(SDValue Op, SDLoc DL, EVT VT) {
|
||||
|
@ -1068,7 +1068,7 @@ SDValue SelectionDAG::getZeroExtendVectorInReg(SDValue Op, SDLoc DL, EVT VT) {
|
|||
SDValue SelectionDAG::getNOT(SDLoc DL, SDValue Val, EVT VT) {
|
||||
EVT EltVT = VT.getScalarType();
|
||||
SDValue NegOne =
|
||||
getConstant(APInt::getAllOnesValue(EltVT.getSizeInBits()), VT);
|
||||
getConstant(APInt::getAllOnesValue(EltVT.getSizeInBits()), DL, VT);
|
||||
return getNode(ISD::XOR, DL, VT, Val, NegOne);
|
||||
}
|
||||
|
||||
|
@ -1078,31 +1078,33 @@ SDValue SelectionDAG::getLogicalNOT(SDLoc DL, SDValue Val, EVT VT) {
|
|||
switch (TLI->getBooleanContents(VT)) {
|
||||
case TargetLowering::ZeroOrOneBooleanContent:
|
||||
case TargetLowering::UndefinedBooleanContent:
|
||||
TrueValue = getConstant(1, VT);
|
||||
TrueValue = getConstant(1, DL, VT);
|
||||
break;
|
||||
case TargetLowering::ZeroOrNegativeOneBooleanContent:
|
||||
TrueValue = getConstant(APInt::getAllOnesValue(EltVT.getSizeInBits()),
|
||||
TrueValue = getConstant(APInt::getAllOnesValue(EltVT.getSizeInBits()), DL,
|
||||
VT);
|
||||
break;
|
||||
}
|
||||
return getNode(ISD::XOR, DL, VT, Val, TrueValue);
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getConstant(uint64_t Val, EVT VT, bool isT, bool isO) {
|
||||
SDValue SelectionDAG::getConstant(uint64_t Val, SDLoc DL, EVT VT, bool isT,
|
||||
bool isO) {
|
||||
EVT EltVT = VT.getScalarType();
|
||||
assert((EltVT.getSizeInBits() >= 64 ||
|
||||
(uint64_t)((int64_t)Val >> EltVT.getSizeInBits()) + 1 < 2) &&
|
||||
"getConstant with a uint64_t value that doesn't fit in the type!");
|
||||
return getConstant(APInt(EltVT.getSizeInBits(), Val), VT, isT, isO);
|
||||
return getConstant(APInt(EltVT.getSizeInBits(), Val), DL, VT, isT, isO);
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getConstant(const APInt &Val, EVT VT, bool isT, bool isO)
|
||||
SDValue SelectionDAG::getConstant(const APInt &Val, SDLoc DL, EVT VT, bool isT,
|
||||
bool isO)
|
||||
{
|
||||
return getConstant(*ConstantInt::get(*Context, Val), VT, isT, isO);
|
||||
return getConstant(*ConstantInt::get(*Context, Val), DL, VT, isT, isO);
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getConstant(const ConstantInt &Val, EVT VT, bool isT,
|
||||
bool isO) {
|
||||
SDValue SelectionDAG::getConstant(const ConstantInt &Val, SDLoc DL, EVT VT,
|
||||
bool isT, bool isO) {
|
||||
assert(VT.isInteger() && "Cannot create FP integer constant!");
|
||||
|
||||
EVT EltVT = VT.getScalarType();
|
||||
|
@ -1141,7 +1143,7 @@ SDValue SelectionDAG::getConstant(const ConstantInt &Val, EVT VT, bool isT,
|
|||
SmallVector<SDValue, 2> EltParts;
|
||||
for (unsigned i = 0; i < ViaVecNumElts / VT.getVectorNumElements(); ++i) {
|
||||
EltParts.push_back(getConstant(NewVal.lshr(i * ViaEltSizeInBits)
|
||||
.trunc(ViaEltSizeInBits),
|
||||
.trunc(ViaEltSizeInBits), DL,
|
||||
ViaEltVT, isT, isO));
|
||||
}
|
||||
|
||||
|
@ -1181,7 +1183,8 @@ SDValue SelectionDAG::getConstant(const ConstantInt &Val, EVT VT, bool isT,
|
|||
return SDValue(N, 0);
|
||||
|
||||
if (!N) {
|
||||
N = new (NodeAllocator) ConstantSDNode(isT, isO, Elt, EltVT);
|
||||
N = new (NodeAllocator) ConstantSDNode(isT, isO, Elt, DL.getDebugLoc(),
|
||||
EltVT);
|
||||
CSEMap.InsertNode(N, IP);
|
||||
InsertNode(N);
|
||||
}
|
||||
|
@ -1195,16 +1198,17 @@ SDValue SelectionDAG::getConstant(const ConstantInt &Val, EVT VT, bool isT,
|
|||
return Result;
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getIntPtrConstant(uint64_t Val, bool isTarget) {
|
||||
return getConstant(Val, TLI->getPointerTy(), isTarget);
|
||||
SDValue SelectionDAG::getIntPtrConstant(uint64_t Val, SDLoc DL, bool isTarget) {
|
||||
return getConstant(Val, DL, TLI->getPointerTy(), isTarget);
|
||||
}
|
||||
|
||||
|
||||
SDValue SelectionDAG::getConstantFP(const APFloat& V, EVT VT, bool isTarget) {
|
||||
return getConstantFP(*ConstantFP::get(*getContext(), V), VT, isTarget);
|
||||
SDValue SelectionDAG::getConstantFP(const APFloat& V, SDLoc DL, EVT VT,
|
||||
bool isTarget) {
|
||||
return getConstantFP(*ConstantFP::get(*getContext(), V), DL, VT, isTarget);
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getConstantFP(const ConstantFP& V, EVT VT, bool isTarget){
|
||||
SDValue SelectionDAG::getConstantFP(const ConstantFP& V, SDLoc DL, EVT VT,
|
||||
bool isTarget){
|
||||
assert(VT.isFloatingPoint() && "Cannot create integer FP constant!");
|
||||
|
||||
EVT EltVT = VT.getScalarType();
|
||||
|
@ -1232,25 +1236,25 @@ SDValue SelectionDAG::getConstantFP(const ConstantFP& V, EVT VT, bool isTarget){
|
|||
if (VT.isVector()) {
|
||||
SmallVector<SDValue, 8> Ops;
|
||||
Ops.assign(VT.getVectorNumElements(), Result);
|
||||
// FIXME SDLoc info might be appropriate here
|
||||
Result = getNode(ISD::BUILD_VECTOR, SDLoc(), VT, Ops);
|
||||
}
|
||||
return Result;
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::getConstantFP(double Val, EVT VT, bool isTarget) {
|
||||
SDValue SelectionDAG::getConstantFP(double Val, SDLoc DL, EVT VT,
|
||||
bool isTarget) {
|
||||
EVT EltVT = VT.getScalarType();
|
||||
if (EltVT==MVT::f32)
|
||||
return getConstantFP(APFloat((float)Val), VT, isTarget);
|
||||
return getConstantFP(APFloat((float)Val), DL, VT, isTarget);
|
||||
else if (EltVT==MVT::f64)
|
||||
return getConstantFP(APFloat(Val), VT, isTarget);
|
||||
return getConstantFP(APFloat(Val), DL, VT, isTarget);
|
||||
else if (EltVT==MVT::f80 || EltVT==MVT::f128 || EltVT==MVT::ppcf128 ||
|
||||
EltVT==MVT::f16) {
|
||||
bool ignored;
|
||||
APFloat apf = APFloat(Val);
|
||||
apf.convert(EVTToAPFloatSemantics(EltVT), APFloat::rmNearestTiesToEven,
|
||||
&ignored);
|
||||
return getConstantFP(apf, VT, isTarget);
|
||||
return getConstantFP(apf, DL, VT, isTarget);
|
||||
} else
|
||||
llvm_unreachable("Unsupported type in getConstantFP");
|
||||
}
|
||||
|
@ -1836,13 +1840,14 @@ SDValue SelectionDAG::FoldSetCC(EVT VT, SDValue N1,
|
|||
switch (Cond) {
|
||||
default: break;
|
||||
case ISD::SETFALSE:
|
||||
case ISD::SETFALSE2: return getConstant(0, VT);
|
||||
case ISD::SETFALSE2: return getConstant(0, dl, VT);
|
||||
case ISD::SETTRUE:
|
||||
case ISD::SETTRUE2: {
|
||||
TargetLowering::BooleanContent Cnt =
|
||||
TLI->getBooleanContents(N1->getValueType(0));
|
||||
return getConstant(
|
||||
Cnt == TargetLowering::ZeroOrNegativeOneBooleanContent ? -1ULL : 1, VT);
|
||||
Cnt == TargetLowering::ZeroOrNegativeOneBooleanContent ? -1ULL : 1, dl,
|
||||
VT);
|
||||
}
|
||||
|
||||
case ISD::SETOEQ:
|
||||
|
@ -1866,16 +1871,16 @@ SDValue SelectionDAG::FoldSetCC(EVT VT, SDValue N1,
|
|||
|
||||
switch (Cond) {
|
||||
default: llvm_unreachable("Unknown integer setcc!");
|
||||
case ISD::SETEQ: return getConstant(C1 == C2, VT);
|
||||
case ISD::SETNE: return getConstant(C1 != C2, VT);
|
||||
case ISD::SETULT: return getConstant(C1.ult(C2), VT);
|
||||
case ISD::SETUGT: return getConstant(C1.ugt(C2), VT);
|
||||
case ISD::SETULE: return getConstant(C1.ule(C2), VT);
|
||||
case ISD::SETUGE: return getConstant(C1.uge(C2), VT);
|
||||
case ISD::SETLT: return getConstant(C1.slt(C2), VT);
|
||||
case ISD::SETGT: return getConstant(C1.sgt(C2), VT);
|
||||
case ISD::SETLE: return getConstant(C1.sle(C2), VT);
|
||||
case ISD::SETGE: return getConstant(C1.sge(C2), VT);
|
||||
case ISD::SETEQ: return getConstant(C1 == C2, dl, VT);
|
||||
case ISD::SETNE: return getConstant(C1 != C2, dl, VT);
|
||||
case ISD::SETULT: return getConstant(C1.ult(C2), dl, VT);
|
||||
case ISD::SETUGT: return getConstant(C1.ugt(C2), dl, VT);
|
||||
case ISD::SETULE: return getConstant(C1.ule(C2), dl, VT);
|
||||
case ISD::SETUGE: return getConstant(C1.uge(C2), dl, VT);
|
||||
case ISD::SETLT: return getConstant(C1.slt(C2), dl, VT);
|
||||
case ISD::SETGT: return getConstant(C1.sgt(C2), dl, VT);
|
||||
case ISD::SETLE: return getConstant(C1.sle(C2), dl, VT);
|
||||
case ISD::SETGE: return getConstant(C1.sge(C2), dl, VT);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1887,41 +1892,41 @@ SDValue SelectionDAG::FoldSetCC(EVT VT, SDValue N1,
|
|||
case ISD::SETEQ: if (R==APFloat::cmpUnordered)
|
||||
return getUNDEF(VT);
|
||||
// fall through
|
||||
case ISD::SETOEQ: return getConstant(R==APFloat::cmpEqual, VT);
|
||||
case ISD::SETOEQ: return getConstant(R==APFloat::cmpEqual, dl, VT);
|
||||
case ISD::SETNE: if (R==APFloat::cmpUnordered)
|
||||
return getUNDEF(VT);
|
||||
// fall through
|
||||
case ISD::SETONE: return getConstant(R==APFloat::cmpGreaterThan ||
|
||||
R==APFloat::cmpLessThan, VT);
|
||||
R==APFloat::cmpLessThan, dl, VT);
|
||||
case ISD::SETLT: if (R==APFloat::cmpUnordered)
|
||||
return getUNDEF(VT);
|
||||
// fall through
|
||||
case ISD::SETOLT: return getConstant(R==APFloat::cmpLessThan, VT);
|
||||
case ISD::SETOLT: return getConstant(R==APFloat::cmpLessThan, dl, VT);
|
||||
case ISD::SETGT: if (R==APFloat::cmpUnordered)
|
||||
return getUNDEF(VT);
|
||||
// fall through
|
||||
case ISD::SETOGT: return getConstant(R==APFloat::cmpGreaterThan, VT);
|
||||
case ISD::SETOGT: return getConstant(R==APFloat::cmpGreaterThan, dl, VT);
|
||||
case ISD::SETLE: if (R==APFloat::cmpUnordered)
|
||||
return getUNDEF(VT);
|
||||
// fall through
|
||||
case ISD::SETOLE: return getConstant(R==APFloat::cmpLessThan ||
|
||||
R==APFloat::cmpEqual, VT);
|
||||
R==APFloat::cmpEqual, dl, VT);
|
||||
case ISD::SETGE: if (R==APFloat::cmpUnordered)
|
||||
return getUNDEF(VT);
|
||||
// fall through
|
||||
case ISD::SETOGE: return getConstant(R==APFloat::cmpGreaterThan ||
|
||||
R==APFloat::cmpEqual, VT);
|
||||
case ISD::SETO: return getConstant(R!=APFloat::cmpUnordered, VT);
|
||||
case ISD::SETUO: return getConstant(R==APFloat::cmpUnordered, VT);
|
||||
R==APFloat::cmpEqual, dl, VT);
|
||||
case ISD::SETO: return getConstant(R!=APFloat::cmpUnordered, dl, VT);
|
||||
case ISD::SETUO: return getConstant(R==APFloat::cmpUnordered, dl, VT);
|
||||
case ISD::SETUEQ: return getConstant(R==APFloat::cmpUnordered ||
|
||||
R==APFloat::cmpEqual, VT);
|
||||
case ISD::SETUNE: return getConstant(R!=APFloat::cmpEqual, VT);
|
||||
R==APFloat::cmpEqual, dl, VT);
|
||||
case ISD::SETUNE: return getConstant(R!=APFloat::cmpEqual, dl, VT);
|
||||
case ISD::SETULT: return getConstant(R==APFloat::cmpUnordered ||
|
||||
R==APFloat::cmpLessThan, VT);
|
||||
R==APFloat::cmpLessThan, dl, VT);
|
||||
case ISD::SETUGT: return getConstant(R==APFloat::cmpGreaterThan ||
|
||||
R==APFloat::cmpUnordered, VT);
|
||||
case ISD::SETULE: return getConstant(R!=APFloat::cmpGreaterThan, VT);
|
||||
case ISD::SETUGE: return getConstant(R!=APFloat::cmpLessThan, VT);
|
||||
R==APFloat::cmpUnordered, dl, VT);
|
||||
case ISD::SETULE: return getConstant(R!=APFloat::cmpGreaterThan, dl, VT);
|
||||
case ISD::SETUGE: return getConstant(R!=APFloat::cmpLessThan, dl, VT);
|
||||
}
|
||||
} else {
|
||||
// Ensure that the constant occurs on the RHS.
|
||||
|
@ -2741,12 +2746,12 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
switch (Opcode) {
|
||||
default: break;
|
||||
case ISD::SIGN_EXTEND:
|
||||
return getConstant(Val.sextOrTrunc(VT.getSizeInBits()), VT,
|
||||
return getConstant(Val.sextOrTrunc(VT.getSizeInBits()), DL, VT,
|
||||
C->isTargetOpcode(), C->isOpaque());
|
||||
case ISD::ANY_EXTEND:
|
||||
case ISD::ZERO_EXTEND:
|
||||
case ISD::TRUNCATE:
|
||||
return getConstant(Val.zextOrTrunc(VT.getSizeInBits()), VT,
|
||||
return getConstant(Val.zextOrTrunc(VT.getSizeInBits()), DL, VT,
|
||||
C->isTargetOpcode(), C->isOpaque());
|
||||
case ISD::UINT_TO_FP:
|
||||
case ISD::SINT_TO_FP: {
|
||||
|
@ -2755,29 +2760,29 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
(void)apf.convertFromAPInt(Val,
|
||||
Opcode==ISD::SINT_TO_FP,
|
||||
APFloat::rmNearestTiesToEven);
|
||||
return getConstantFP(apf, VT);
|
||||
return getConstantFP(apf, DL, VT);
|
||||
}
|
||||
case ISD::BITCAST:
|
||||
if (VT == MVT::f16 && C->getValueType(0) == MVT::i16)
|
||||
return getConstantFP(APFloat(APFloat::IEEEhalf, Val), VT);
|
||||
return getConstantFP(APFloat(APFloat::IEEEhalf, Val), DL, VT);
|
||||
if (VT == MVT::f32 && C->getValueType(0) == MVT::i32)
|
||||
return getConstantFP(APFloat(APFloat::IEEEsingle, Val), VT);
|
||||
return getConstantFP(APFloat(APFloat::IEEEsingle, Val), DL, VT);
|
||||
else if (VT == MVT::f64 && C->getValueType(0) == MVT::i64)
|
||||
return getConstantFP(APFloat(APFloat::IEEEdouble, Val), VT);
|
||||
return getConstantFP(APFloat(APFloat::IEEEdouble, Val), DL, VT);
|
||||
break;
|
||||
case ISD::BSWAP:
|
||||
return getConstant(Val.byteSwap(), VT, C->isTargetOpcode(),
|
||||
return getConstant(Val.byteSwap(), DL, VT, C->isTargetOpcode(),
|
||||
C->isOpaque());
|
||||
case ISD::CTPOP:
|
||||
return getConstant(Val.countPopulation(), VT, C->isTargetOpcode(),
|
||||
return getConstant(Val.countPopulation(), DL, VT, C->isTargetOpcode(),
|
||||
C->isOpaque());
|
||||
case ISD::CTLZ:
|
||||
case ISD::CTLZ_ZERO_UNDEF:
|
||||
return getConstant(Val.countLeadingZeros(), VT, C->isTargetOpcode(),
|
||||
return getConstant(Val.countLeadingZeros(), DL, VT, C->isTargetOpcode(),
|
||||
C->isOpaque());
|
||||
case ISD::CTTZ:
|
||||
case ISD::CTTZ_ZERO_UNDEF:
|
||||
return getConstant(Val.countTrailingZeros(), VT, C->isTargetOpcode(),
|
||||
return getConstant(Val.countTrailingZeros(), DL, VT, C->isTargetOpcode(),
|
||||
C->isOpaque());
|
||||
}
|
||||
}
|
||||
|
@ -2788,26 +2793,26 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
switch (Opcode) {
|
||||
case ISD::FNEG:
|
||||
V.changeSign();
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
case ISD::FABS:
|
||||
V.clearSign();
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
case ISD::FCEIL: {
|
||||
APFloat::opStatus fs = V.roundToIntegral(APFloat::rmTowardPositive);
|
||||
if (fs == APFloat::opOK || fs == APFloat::opInexact)
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
break;
|
||||
}
|
||||
case ISD::FTRUNC: {
|
||||
APFloat::opStatus fs = V.roundToIntegral(APFloat::rmTowardZero);
|
||||
if (fs == APFloat::opOK || fs == APFloat::opInexact)
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
break;
|
||||
}
|
||||
case ISD::FFLOOR: {
|
||||
APFloat::opStatus fs = V.roundToIntegral(APFloat::rmTowardNegative);
|
||||
if (fs == APFloat::opOK || fs == APFloat::opInexact)
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
break;
|
||||
}
|
||||
case ISD::FP_EXTEND: {
|
||||
|
@ -2816,7 +2821,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
// FIXME need to be more flexible about rounding mode.
|
||||
(void)V.convert(EVTToAPFloatSemantics(VT),
|
||||
APFloat::rmNearestTiesToEven, &ignored);
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
}
|
||||
case ISD::FP_TO_SINT:
|
||||
case ISD::FP_TO_UINT: {
|
||||
|
@ -2830,15 +2835,15 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
if (s==APFloat::opInvalidOp) // inexact is OK, in fact usual
|
||||
break;
|
||||
APInt api(VT.getSizeInBits(), x);
|
||||
return getConstant(api, VT);
|
||||
return getConstant(api, DL, VT);
|
||||
}
|
||||
case ISD::BITCAST:
|
||||
if (VT == MVT::i16 && C->getValueType(0) == MVT::f16)
|
||||
return getConstant((uint16_t)V.bitcastToAPInt().getZExtValue(), VT);
|
||||
return getConstant((uint16_t)V.bitcastToAPInt().getZExtValue(), DL, VT);
|
||||
else if (VT == MVT::i32 && C->getValueType(0) == MVT::f32)
|
||||
return getConstant((uint32_t)V.bitcastToAPInt().getZExtValue(), VT);
|
||||
return getConstant((uint32_t)V.bitcastToAPInt().getZExtValue(), DL, VT);
|
||||
else if (VT == MVT::i64 && C->getValueType(0) == MVT::f64)
|
||||
return getConstant(V.bitcastToAPInt().getZExtValue(), VT);
|
||||
return getConstant(V.bitcastToAPInt().getZExtValue(), DL, VT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -2914,7 +2919,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
return getNode(OpOpcode, DL, VT, Operand.getNode()->getOperand(0));
|
||||
else if (OpOpcode == ISD::UNDEF)
|
||||
// sext(undef) = 0, because the top bits will all be the same.
|
||||
return getConstant(0, VT);
|
||||
return getConstant(0, DL, VT);
|
||||
break;
|
||||
case ISD::ZERO_EXTEND:
|
||||
assert(VT.isInteger() && Operand.getValueType().isInteger() &&
|
||||
|
@ -2931,7 +2936,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
Operand.getNode()->getOperand(0));
|
||||
else if (OpOpcode == ISD::UNDEF)
|
||||
// zext(undef) = 0, because the top bits will be zero.
|
||||
return getConstant(0, VT);
|
||||
return getConstant(0, DL, VT);
|
||||
break;
|
||||
case ISD::ANY_EXTEND:
|
||||
assert(VT.isInteger() && Operand.getValueType().isInteger() &&
|
||||
|
@ -3045,7 +3050,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL,
|
|||
return SDValue(N, 0);
|
||||
}
|
||||
|
||||
SDValue SelectionDAG::FoldConstantArithmetic(unsigned Opcode, EVT VT,
|
||||
SDValue SelectionDAG::FoldConstantArithmetic(unsigned Opcode, SDLoc DL, EVT VT,
|
||||
SDNode *Cst1, SDNode *Cst2) {
|
||||
// If the opcode is a target-specific ISD node, there's nothing we can
|
||||
// do here and the operand rules may not line up with the below, so
|
||||
|
@ -3100,57 +3105,57 @@ SDValue SelectionDAG::FoldConstantArithmetic(unsigned Opcode, EVT VT,
|
|||
|
||||
switch (Opcode) {
|
||||
case ISD::ADD:
|
||||
Outputs.push_back(getConstant(C1 + C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 + C2, DL, SVT));
|
||||
break;
|
||||
case ISD::SUB:
|
||||
Outputs.push_back(getConstant(C1 - C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 - C2, DL, SVT));
|
||||
break;
|
||||
case ISD::MUL:
|
||||
Outputs.push_back(getConstant(C1 * C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 * C2, DL, SVT));
|
||||
break;
|
||||
case ISD::UDIV:
|
||||
if (!C2.getBoolValue())
|
||||
return SDValue();
|
||||
Outputs.push_back(getConstant(C1.udiv(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.udiv(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::UREM:
|
||||
if (!C2.getBoolValue())
|
||||
return SDValue();
|
||||
Outputs.push_back(getConstant(C1.urem(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.urem(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::SDIV:
|
||||
if (!C2.getBoolValue())
|
||||
return SDValue();
|
||||
Outputs.push_back(getConstant(C1.sdiv(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.sdiv(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::SREM:
|
||||
if (!C2.getBoolValue())
|
||||
return SDValue();
|
||||
Outputs.push_back(getConstant(C1.srem(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.srem(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::AND:
|
||||
Outputs.push_back(getConstant(C1 & C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 & C2, DL, SVT));
|
||||
break;
|
||||
case ISD::OR:
|
||||
Outputs.push_back(getConstant(C1 | C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 | C2, DL, SVT));
|
||||
break;
|
||||
case ISD::XOR:
|
||||
Outputs.push_back(getConstant(C1 ^ C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 ^ C2, DL, SVT));
|
||||
break;
|
||||
case ISD::SHL:
|
||||
Outputs.push_back(getConstant(C1 << C2, SVT));
|
||||
Outputs.push_back(getConstant(C1 << C2, DL, SVT));
|
||||
break;
|
||||
case ISD::SRL:
|
||||
Outputs.push_back(getConstant(C1.lshr(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.lshr(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::SRA:
|
||||
Outputs.push_back(getConstant(C1.ashr(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.ashr(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::ROTL:
|
||||
Outputs.push_back(getConstant(C1.rotl(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.rotl(C2), DL, SVT));
|
||||
break;
|
||||
case ISD::ROTR:
|
||||
Outputs.push_back(getConstant(C1.rotr(C2), SVT));
|
||||
Outputs.push_back(getConstant(C1.rotr(C2), DL, SVT));
|
||||
break;
|
||||
default:
|
||||
return SDValue();
|
||||
|
@ -3379,7 +3384,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
unsigned FromBits = EVT.getScalarType().getSizeInBits();
|
||||
Val <<= Val.getBitWidth()-FromBits;
|
||||
Val = Val.ashr(Val.getBitWidth()-FromBits);
|
||||
return getConstant(Val, VT);
|
||||
return getConstant(Val, DL, VT);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -3397,7 +3402,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
N1.getOperand(0).getValueType().getVectorNumElements();
|
||||
return getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT,
|
||||
N1.getOperand(N2C->getZExtValue() / Factor),
|
||||
getConstant(N2C->getZExtValue() % Factor,
|
||||
getConstant(N2C->getZExtValue() % Factor, DL,
|
||||
N2.getValueType()));
|
||||
}
|
||||
|
||||
|
@ -3454,7 +3459,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
unsigned ElementSize = VT.getSizeInBits();
|
||||
unsigned Shift = ElementSize * N2C->getZExtValue();
|
||||
APInt ShiftedVal = C->getAPIntValue().lshr(Shift);
|
||||
return getConstant(ShiftedVal.trunc(ElementSize), VT);
|
||||
return getConstant(ShiftedVal.trunc(ElementSize), DL, VT);
|
||||
}
|
||||
break;
|
||||
case ISD::EXTRACT_SUBVECTOR: {
|
||||
|
@ -3485,7 +3490,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
|
||||
// Perform trivial constant folding.
|
||||
if (SDValue SV =
|
||||
FoldConstantArithmetic(Opcode, VT, N1.getNode(), N2.getNode()))
|
||||
FoldConstantArithmetic(Opcode, DL, VT, N1.getNode(), N2.getNode()))
|
||||
return SV;
|
||||
|
||||
// Canonicalize constant to RHS if commutative.
|
||||
|
@ -3510,35 +3515,35 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
case ISD::FADD:
|
||||
s = V1.add(V2, APFloat::rmNearestTiesToEven);
|
||||
if (!HasFPExceptions || s != APFloat::opInvalidOp)
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
break;
|
||||
case ISD::FSUB:
|
||||
s = V1.subtract(V2, APFloat::rmNearestTiesToEven);
|
||||
if (!HasFPExceptions || s!=APFloat::opInvalidOp)
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
break;
|
||||
case ISD::FMUL:
|
||||
s = V1.multiply(V2, APFloat::rmNearestTiesToEven);
|
||||
if (!HasFPExceptions || s!=APFloat::opInvalidOp)
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
break;
|
||||
case ISD::FDIV:
|
||||
s = V1.divide(V2, APFloat::rmNearestTiesToEven);
|
||||
if (!HasFPExceptions || (s!=APFloat::opInvalidOp &&
|
||||
s!=APFloat::opDivByZero)) {
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
}
|
||||
break;
|
||||
case ISD::FREM :
|
||||
s = V1.mod(V2, APFloat::rmNearestTiesToEven);
|
||||
if (!HasFPExceptions || (s!=APFloat::opInvalidOp &&
|
||||
s!=APFloat::opDivByZero)) {
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
}
|
||||
break;
|
||||
case ISD::FCOPYSIGN:
|
||||
V1.copySign(V2);
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
default: break;
|
||||
}
|
||||
}
|
||||
|
@ -3550,7 +3555,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
// FIXME need to be more flexible about rounding mode.
|
||||
(void)V.convert(EVTToAPFloatSemantics(VT),
|
||||
APFloat::rmNearestTiesToEven, &ignored);
|
||||
return getConstantFP(V, VT);
|
||||
return getConstantFP(V, DL, VT);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -3575,7 +3580,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
case ISD::SRL:
|
||||
case ISD::SHL:
|
||||
if (!VT.isVector())
|
||||
return getConstant(0, VT); // fold op(undef, arg2) -> 0
|
||||
return getConstant(0, DL, VT); // fold op(undef, arg2) -> 0
|
||||
// For vectors, we can't easily build an all zero vector, just return
|
||||
// the LHS.
|
||||
return N2;
|
||||
|
@ -3590,7 +3595,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
if (N1.getOpcode() == ISD::UNDEF)
|
||||
// Handle undef ^ undef -> 0 special case. This is a common
|
||||
// idiom (misuse).
|
||||
return getConstant(0, VT);
|
||||
return getConstant(0, DL, VT);
|
||||
// fallthrough
|
||||
case ISD::ADD:
|
||||
case ISD::ADDC:
|
||||
|
@ -3614,13 +3619,13 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT, SDValue N1,
|
|||
case ISD::SRL:
|
||||
case ISD::SHL:
|
||||
if (!VT.isVector())
|
||||
return getConstant(0, VT); // fold op(arg1, undef) -> 0
|
||||
return getConstant(0, DL, VT); // fold op(arg1, undef) -> 0
|
||||
// For vectors, we can't easily build an all zero vector, just return
|
||||
// the LHS.
|
||||
return N1;
|
||||
case ISD::OR:
|
||||
if (!VT.isVector())
|
||||
return getConstant(APInt::getAllOnesValue(VT.getSizeInBits()), VT);
|
||||
return getConstant(APInt::getAllOnesValue(VT.getSizeInBits()), DL, VT);
|
||||
// For vectors, we can't easily build an all one vector, just return
|
||||
// the LHS.
|
||||
return N1;
|
||||
|
@ -3670,7 +3675,7 @@ SDValue SelectionDAG::getNode(unsigned Opcode, SDLoc DL, EVT VT,
|
|||
APFloat::opStatus s =
|
||||
V1.fusedMultiplyAdd(V2, V3, APFloat::rmNearestTiesToEven);
|
||||
if (!TLI->hasFloatingPointExceptions() || s != APFloat::opInvalidOp)
|
||||
return getConstantFP(V1, VT);
|
||||
return getConstantFP(V1, DL, VT);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -3805,8 +3810,9 @@ static SDValue getMemsetValue(SDValue Value, EVT VT, SelectionDAG &DAG,
|
|||
assert(C->getAPIntValue().getBitWidth() == 8);
|
||||
APInt Val = APInt::getSplat(NumBits, C->getAPIntValue());
|
||||
if (VT.isInteger())
|
||||
return DAG.getConstant(Val, VT);
|
||||
return DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(VT), Val), VT);
|
||||
return DAG.getConstant(Val, dl, VT);
|
||||
return DAG.getConstantFP(APFloat(DAG.EVTToAPFloatSemantics(VT), Val), dl,
|
||||
VT);
|
||||
}
|
||||
|
||||
assert(Value.getValueType() == MVT::i8 && "memset with non-byte fill value?");
|
||||
|
@ -3820,7 +3826,7 @@ static SDValue getMemsetValue(SDValue Value, EVT VT, SelectionDAG &DAG,
|
|||
// required length.
|
||||
APInt Magic = APInt::getSplat(NumBits, APInt(8, 0x01));
|
||||
Value = DAG.getNode(ISD::MUL, dl, IntVT, Value,
|
||||
DAG.getConstant(Magic, IntVT));
|
||||
DAG.getConstant(Magic, dl, IntVT));
|
||||
}
|
||||
|
||||
if (VT != Value.getValueType() && !VT.isInteger())
|
||||
|
@ -3843,15 +3849,16 @@ static SDValue getMemsetStringVal(EVT VT, SDLoc dl, SelectionDAG &DAG,
|
|||
// Handle vector with all elements zero.
|
||||
if (Str.empty()) {
|
||||
if (VT.isInteger())
|
||||
return DAG.getConstant(0, VT);
|
||||
return DAG.getConstant(0, dl, VT);
|
||||
else if (VT == MVT::f32 || VT == MVT::f64 || VT == MVT::f128)
|
||||
return DAG.getConstantFP(0.0, VT);
|
||||
return DAG.getConstantFP(0.0, dl, VT);
|
||||
else if (VT.isVector()) {
|
||||
unsigned NumElts = VT.getVectorNumElements();
|
||||
MVT EltVT = (VT.getVectorElementType() == MVT::f32) ? MVT::i32 : MVT::i64;
|
||||
return DAG.getNode(ISD::BITCAST, dl, VT,
|
||||
DAG.getConstant(0, EVT::getVectorVT(*DAG.getContext(),
|
||||
EltVT, NumElts)));
|
||||
DAG.getConstant(0, dl,
|
||||
EVT::getVectorVT(*DAG.getContext(),
|
||||
EltVT, NumElts)));
|
||||
} else
|
||||
llvm_unreachable("Expected type!");
|
||||
}
|
||||
|
@ -3874,7 +3881,7 @@ static SDValue getMemsetStringVal(EVT VT, SDLoc dl, SelectionDAG &DAG,
|
|||
// of a load, then it is cost effective to turn the load into the immediate.
|
||||
Type *Ty = VT.getTypeForEVT(*DAG.getContext());
|
||||
if (TLI.shouldConvertConstantLoadToIntImm(Val, Ty))
|
||||
return DAG.getConstant(Val, VT);
|
||||
return DAG.getConstant(Val, dl, VT);
|
||||
return SDValue(nullptr, 0);
|
||||
}
|
||||
|
||||
|
@ -3884,7 +3891,7 @@ static SDValue getMemBasePlusOffset(SDValue Base, unsigned Offset, SDLoc dl,
|
|||
SelectionDAG &DAG) {
|
||||
EVT VT = Base.getValueType();
|
||||
return DAG.getNode(ISD::ADD, dl,
|
||||
VT, Base, DAG.getConstant(Offset, VT));
|
||||
VT, Base, DAG.getConstant(Offset, dl, VT));
|
||||
}
|
||||
|
||||
/// isMemSrcFromString - Returns true if memcpy source is a string constant.
|
||||
|
@ -5150,7 +5157,7 @@ SDValue SelectionDAG::getVAArg(EVT VT, SDLoc dl,
|
|||
SDValue Chain, SDValue Ptr,
|
||||
SDValue SV,
|
||||
unsigned Align) {
|
||||
SDValue Ops[] = { Chain, Ptr, SV, getTargetConstant(Align, MVT::i32) };
|
||||
SDValue Ops[] = { Chain, Ptr, SV, getTargetConstant(Align, dl, MVT::i32) };
|
||||
return getNode(ISD::VAARG, dl, getVTList(VT, MVT::Other), Ops);
|
||||
}
|
||||
|
||||
|
@ -5929,7 +5936,7 @@ SelectionDAG::getMachineNode(unsigned Opcode, SDLoc DL, SDVTList VTs,
|
|||
SDValue
|
||||
SelectionDAG::getTargetExtractSubreg(int SRIdx, SDLoc DL, EVT VT,
|
||||
SDValue Operand) {
|
||||
SDValue SRIdxVal = getTargetConstant(SRIdx, MVT::i32);
|
||||
SDValue SRIdxVal = getTargetConstant(SRIdx, DL, MVT::i32);
|
||||
SDNode *Subreg = getMachineNode(TargetOpcode::EXTRACT_SUBREG, DL,
|
||||
VT, Operand, SRIdxVal);
|
||||
return SDValue(Subreg, 0);
|
||||
|
@ -5940,7 +5947,7 @@ SelectionDAG::getTargetExtractSubreg(int SRIdx, SDLoc DL, EVT VT,
|
|||
SDValue
|
||||
SelectionDAG::getTargetInsertSubreg(int SRIdx, SDLoc DL, EVT VT,
|
||||
SDValue Operand, SDValue Subreg) {
|
||||
SDValue SRIdxVal = getTargetConstant(SRIdx, MVT::i32);
|
||||
SDValue SRIdxVal = getTargetConstant(SRIdx, DL, MVT::i32);
|
||||
SDNode *Result = getMachineNode(TargetOpcode::INSERT_SUBREG, DL,
|
||||
VT, Operand, Subreg, SRIdxVal);
|
||||
return SDValue(Result, 0);
|
||||
|
@ -6655,7 +6662,7 @@ SDValue SelectionDAG::UnrollVectorOp(SDNode *N, unsigned ResNE) {
|
|||
Operands[j] = getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
OperandEltVT,
|
||||
Operand,
|
||||
getConstant(i, TLI->getVectorIdxTy()));
|
||||
getConstant(i, dl, TLI->getVectorIdxTy()));
|
||||
} else {
|
||||
// A scalar operand; just use it as is.
|
||||
Operands[j] = Operand;
|
||||
|
@ -6818,9 +6825,10 @@ SelectionDAG::SplitVector(const SDValue &N, const SDLoc &DL, const EVT &LoVT,
|
|||
"More vector elements requested than available!");
|
||||
SDValue Lo, Hi;
|
||||
Lo = getNode(ISD::EXTRACT_SUBVECTOR, DL, LoVT, N,
|
||||
getConstant(0, TLI->getVectorIdxTy()));
|
||||
getConstant(0, DL, TLI->getVectorIdxTy()));
|
||||
Hi = getNode(ISD::EXTRACT_SUBVECTOR, DL, HiVT, N,
|
||||
getConstant(LoVT.getVectorNumElements(), TLI->getVectorIdxTy()));
|
||||
getConstant(LoVT.getVectorNumElements(), DL,
|
||||
TLI->getVectorIdxTy()));
|
||||
return std::make_pair(Lo, Hi);
|
||||
}
|
||||
|
||||
|
@ -6836,7 +6844,7 @@ void SelectionDAG::ExtractVectorElements(SDValue Op,
|
|||
SDLoc SL(Op);
|
||||
for (unsigned i = Start, e = Start + Count; i != e; ++i) {
|
||||
Args.push_back(getNode(ISD::EXTRACT_VECTOR_ELT, SL, EltVT,
|
||||
Op, getConstant(i, IdxTy)));
|
||||
Op, getConstant(i, SL, IdxTy)));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1710,11 +1710,10 @@ bool SelectionDAGISel::CheckOrMask(SDValue LHS, ConstantSDNode *RHS,
|
|||
return false;
|
||||
}
|
||||
|
||||
|
||||
/// SelectInlineAsmMemoryOperands - Calls to this are automatically generated
|
||||
/// by tblgen. Others should not call it.
|
||||
void SelectionDAGISel::
|
||||
SelectInlineAsmMemoryOperands(std::vector<SDValue> &Ops) {
|
||||
SelectInlineAsmMemoryOperands(std::vector<SDValue> &Ops, SDLoc DL) {
|
||||
std::vector<SDValue> InOps;
|
||||
std::swap(InOps, Ops);
|
||||
|
||||
|
@ -1760,7 +1759,7 @@ SelectInlineAsmMemoryOperands(std::vector<SDValue> &Ops) {
|
|||
// Add this to the output node.
|
||||
unsigned NewFlags =
|
||||
InlineAsm::getFlagWord(InlineAsm::Kind_Mem, SelOps.size());
|
||||
Ops.push_back(CurDAG->getTargetConstant(NewFlags, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(NewFlags, DL, MVT::i32));
|
||||
Ops.insert(Ops.end(), SelOps.begin(), SelOps.end());
|
||||
i += 2;
|
||||
}
|
||||
|
@ -1906,11 +1905,13 @@ bool SelectionDAGISel::IsLegalToFold(SDValue N, SDNode *U, SDNode *Root,
|
|||
}
|
||||
|
||||
SDNode *SelectionDAGISel::Select_INLINEASM(SDNode *N) {
|
||||
SDLoc DL(N);
|
||||
|
||||
std::vector<SDValue> Ops(N->op_begin(), N->op_end());
|
||||
SelectInlineAsmMemoryOperands(Ops);
|
||||
SelectInlineAsmMemoryOperands(Ops, DL);
|
||||
|
||||
const EVT VTs[] = {MVT::Other, MVT::Glue};
|
||||
SDValue New = CurDAG->getNode(ISD::INLINEASM, SDLoc(N), VTs, Ops);
|
||||
SDValue New = CurDAG->getNode(ISD::INLINEASM, DL, VTs, Ops);
|
||||
New->setNodeId(-1);
|
||||
return New.getNode();
|
||||
}
|
||||
|
@ -2932,7 +2933,8 @@ SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable,
|
|||
if (Val & 128)
|
||||
Val = GetVBR(Val, MatcherTable, MatcherIndex);
|
||||
RecordedNodes.push_back(std::pair<SDValue, SDNode*>(
|
||||
CurDAG->getTargetConstant(Val, VT), nullptr));
|
||||
CurDAG->getTargetConstant(Val, SDLoc(NodeToMatch),
|
||||
VT), nullptr));
|
||||
continue;
|
||||
}
|
||||
case OPC_EmitRegister: {
|
||||
|
@ -2964,10 +2966,12 @@ SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable,
|
|||
|
||||
if (Imm->getOpcode() == ISD::Constant) {
|
||||
const ConstantInt *Val=cast<ConstantSDNode>(Imm)->getConstantIntValue();
|
||||
Imm = CurDAG->getConstant(*Val, Imm.getValueType(), true);
|
||||
Imm = CurDAG->getConstant(*Val, SDLoc(NodeToMatch), Imm.getValueType(),
|
||||
true);
|
||||
} else if (Imm->getOpcode() == ISD::ConstantFP) {
|
||||
const ConstantFP *Val=cast<ConstantFPSDNode>(Imm)->getConstantFPValue();
|
||||
Imm = CurDAG->getConstantFP(*Val, Imm.getValueType(), true);
|
||||
Imm = CurDAG->getConstantFP(*Val, SDLoc(NodeToMatch),
|
||||
Imm.getValueType(), true);
|
||||
}
|
||||
|
||||
RecordedNodes.push_back(std::make_pair(Imm, RecordedNodes[RecNo].second));
|
||||
|
|
|
@ -271,7 +271,8 @@ static SDNode *lowerCallFromStatepoint(ImmutableStatepoint StatepointSite,
|
|||
}
|
||||
} else {
|
||||
// The token value is never used from here on, just generate a poison value
|
||||
Builder.setValue(CS.getInstruction(), Builder.DAG.getIntPtrConstant(-1));
|
||||
Builder.setValue(CS.getInstruction(),
|
||||
Builder.DAG.getIntPtrConstant(-1, Builder.getCurSDLoc()));
|
||||
}
|
||||
// Remove the fake entry we created so we don't have a hanging reference
|
||||
// after we delete this node.
|
||||
|
@ -393,9 +394,12 @@ static void lowerIncomingStatepointValue(SDValue Incoming,
|
|||
// such in the stackmap. This is required so that the consumer can
|
||||
// parse any internal format to the deopt state. It also handles null
|
||||
// pointers and other constant pointers in GC states
|
||||
Ops.push_back(
|
||||
Builder.DAG.getTargetConstant(StackMaps::ConstantOp, MVT::i64));
|
||||
Ops.push_back(Builder.DAG.getTargetConstant(C->getSExtValue(), MVT::i64));
|
||||
Ops.push_back(Builder.DAG.getTargetConstant(StackMaps::ConstantOp,
|
||||
Builder.getCurSDLoc(),
|
||||
MVT::i64));
|
||||
Ops.push_back(Builder.DAG.getTargetConstant(C->getSExtValue(),
|
||||
Builder.getCurSDLoc(),
|
||||
MVT::i64));
|
||||
} else if (FrameIndexSDNode *FI = dyn_cast<FrameIndexSDNode>(Incoming)) {
|
||||
// This handles allocas as arguments to the statepoint (this is only
|
||||
// really meaningful for a deopt value. For GC, we'd be trying to
|
||||
|
@ -490,9 +494,11 @@ static void lowerStatepointMetaArgs(SmallVectorImpl<SDValue> &Ops,
|
|||
// lowered. Note that this is the number of *Values* not the
|
||||
// number of SDValues required to lower them.
|
||||
const int NumVMSArgs = StatepointSite.numTotalVMSArgs();
|
||||
Ops.push_back(
|
||||
Builder.DAG.getTargetConstant(StackMaps::ConstantOp, MVT::i64));
|
||||
Ops.push_back(Builder.DAG.getTargetConstant(NumVMSArgs, MVT::i64));
|
||||
Ops.push_back( Builder.DAG.getTargetConstant(StackMaps::ConstantOp,
|
||||
Builder.getCurSDLoc(),
|
||||
MVT::i64));
|
||||
Ops.push_back(Builder.DAG.getTargetConstant(NumVMSArgs, Builder.getCurSDLoc(),
|
||||
MVT::i64));
|
||||
|
||||
assert(NumVMSArgs + 1 == std::distance(StatepointSite.vm_state_begin(),
|
||||
StatepointSite.vm_state_end()));
|
||||
|
@ -608,7 +614,7 @@ SelectionDAGBuilder::LowerStatepoint(ImmutableStatepoint ISP,
|
|||
// Get number of arguments incoming directly into call node
|
||||
unsigned NumCallRegArgs =
|
||||
CallNode->getNumOperands() - (Glue.getNode() ? 4 : 3);
|
||||
Ops.push_back(DAG.getTargetConstant(NumCallRegArgs, MVT::i32));
|
||||
Ops.push_back(DAG.getTargetConstant(NumCallRegArgs, getCurSDLoc(), MVT::i32));
|
||||
|
||||
// Add call target
|
||||
SDValue CallTarget = SDValue(CallNode->getOperand(1).getNode(), 0);
|
||||
|
@ -628,9 +634,10 @@ SelectionDAGBuilder::LowerStatepoint(ImmutableStatepoint ISP,
|
|||
CallingConv::ID CallConv = CS.getCallingConv();
|
||||
int Flags = cast<ConstantInt>(CS.getArgument(2))->getZExtValue();
|
||||
assert(Flags == 0 && "not expected to be used");
|
||||
Ops.push_back(DAG.getTargetConstant(StackMaps::ConstantOp, MVT::i64));
|
||||
Ops.push_back(
|
||||
DAG.getTargetConstant(Flags | ((unsigned)CallConv << 1), MVT::i64));
|
||||
Ops.push_back(DAG.getTargetConstant(StackMaps::ConstantOp, getCurSDLoc(),
|
||||
MVT::i64));
|
||||
Ops.push_back(DAG.getTargetConstant(Flags | ((unsigned)CallConv << 1),
|
||||
getCurSDLoc(), MVT::i64));
|
||||
|
||||
// Insert all vmstate and gcstate arguments
|
||||
Ops.insert(Ops.end(), LoweredArgs.begin(), LoweredArgs.end());
|
||||
|
|
|
@ -203,7 +203,7 @@ void TargetLowering::softenSetCCOperands(SelectionDAG &DAG, EVT VT,
|
|||
SDValue Ops[2] = { NewLHS, NewRHS };
|
||||
NewLHS = makeLibCall(DAG, LC1, RetVT, Ops, 2, false/*sign irrelevant*/,
|
||||
dl).first;
|
||||
NewRHS = DAG.getConstant(0, RetVT);
|
||||
NewRHS = DAG.getConstant(0, dl, RetVT);
|
||||
CCCode = getCmpLibcallCC(LC1);
|
||||
if (LC2 != RTLIB::UNKNOWN_LIBCALL) {
|
||||
SDValue Tmp = DAG.getNode(ISD::SETCC, dl,
|
||||
|
@ -305,7 +305,7 @@ bool TargetLowering::TargetLoweringOpt::ShrinkDemandedConstant(SDValue Op,
|
|||
SDValue New = DAG.getNode(Op.getOpcode(), dl, VT, Op.getOperand(0),
|
||||
DAG.getConstant(Demanded &
|
||||
C->getAPIntValue(),
|
||||
VT));
|
||||
dl, VT));
|
||||
return CombineTo(Op, New);
|
||||
}
|
||||
|
||||
|
@ -449,7 +449,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
return TLO.CombineTo(Op, Op.getOperand(1));
|
||||
// If all of the demanded bits in the inputs are known zeros, return zero.
|
||||
if ((NewMask & (KnownZero|KnownZero2)) == NewMask)
|
||||
return TLO.CombineTo(Op, TLO.DAG.getConstant(0, Op.getValueType()));
|
||||
return TLO.CombineTo(Op, TLO.DAG.getConstant(0, dl, Op.getValueType()));
|
||||
// If the RHS is a constant, see if we can simplify it.
|
||||
if (TLO.ShrinkDemandedConstant(Op, ~KnownZero2 & NewMask))
|
||||
return true;
|
||||
|
@ -537,7 +537,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
if ((NewMask & (KnownZero|KnownOne)) == NewMask) { // all known on one side
|
||||
if (KnownOne == KnownOne2) { // set bits are the same on both sides
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue ANDC = TLO.DAG.getConstant(~KnownOne & NewMask, VT);
|
||||
SDValue ANDC = TLO.DAG.getConstant(~KnownOne & NewMask, dl, VT);
|
||||
return TLO.CombineTo(Op, TLO.DAG.getNode(ISD::AND, dl, VT,
|
||||
Op.getOperand(0), ANDC));
|
||||
}
|
||||
|
@ -553,7 +553,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
if (Expanded != C->getAPIntValue()) {
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue New = TLO.DAG.getNode(Op.getOpcode(), dl,VT, Op.getOperand(0),
|
||||
TLO.DAG.getConstant(Expanded, VT));
|
||||
TLO.DAG.getConstant(Expanded, dl, VT));
|
||||
return TLO.CombineTo(Op, New);
|
||||
}
|
||||
// if it already has all the bits set, nothing to change
|
||||
|
@ -626,7 +626,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
}
|
||||
|
||||
SDValue NewSA =
|
||||
TLO.DAG.getConstant(Diff, Op.getOperand(1).getValueType());
|
||||
TLO.DAG.getConstant(Diff, dl, Op.getOperand(1).getValueType());
|
||||
EVT VT = Op.getValueType();
|
||||
return TLO.CombineTo(Op, TLO.DAG.getNode(Opc, dl, VT,
|
||||
InOp.getOperand(0), NewSA));
|
||||
|
@ -650,7 +650,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
ShTy = InnerVT;
|
||||
SDValue NarrowShl =
|
||||
TLO.DAG.getNode(ISD::SHL, dl, InnerVT, InnerOp,
|
||||
TLO.DAG.getConstant(ShAmt, ShTy));
|
||||
TLO.DAG.getConstant(ShAmt, dl, ShTy));
|
||||
return
|
||||
TLO.CombineTo(Op,
|
||||
TLO.DAG.getNode(ISD::ANY_EXTEND, dl, Op.getValueType(),
|
||||
|
@ -672,7 +672,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
NewMask.lshr(InnerBits - InnerShAmt + ShAmt) == 0 &&
|
||||
NewMask.trunc(ShAmt) == 0) {
|
||||
SDValue NewSA =
|
||||
TLO.DAG.getConstant(ShAmt - InnerShAmt,
|
||||
TLO.DAG.getConstant(ShAmt - InnerShAmt, dl,
|
||||
Op.getOperand(1).getValueType());
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue NewExt = TLO.DAG.getNode(ISD::ANY_EXTEND, dl, VT,
|
||||
|
@ -715,7 +715,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
}
|
||||
|
||||
SDValue NewSA =
|
||||
TLO.DAG.getConstant(Diff, Op.getOperand(1).getValueType());
|
||||
TLO.DAG.getConstant(Diff, dl, Op.getOperand(1).getValueType());
|
||||
return TLO.CombineTo(Op, TLO.DAG.getNode(Opc, dl, VT,
|
||||
InOp.getOperand(0), NewSA));
|
||||
}
|
||||
|
@ -780,7 +780,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
if (Log2 >= 0) {
|
||||
// The bit must come from the sign.
|
||||
SDValue NewSA =
|
||||
TLO.DAG.getConstant(BitWidth - 1 - Log2,
|
||||
TLO.DAG.getConstant(BitWidth - 1 - Log2, dl,
|
||||
Op.getOperand(1).getValueType());
|
||||
return TLO.CombineTo(Op, TLO.DAG.getNode(ISD::SRL, dl, VT,
|
||||
Op.getOperand(0), NewSA));
|
||||
|
@ -811,7 +811,8 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
if (TLO.LegalTypes() && !ShiftAmtTy.isVector())
|
||||
ShiftAmtTy = getShiftAmountTy(ShiftAmtTy);
|
||||
|
||||
SDValue ShiftAmt = TLO.DAG.getConstant(BitWidth - ShAmt, ShiftAmtTy);
|
||||
SDValue ShiftAmt = TLO.DAG.getConstant(BitWidth - ShAmt, dl,
|
||||
ShiftAmtTy);
|
||||
return TLO.CombineTo(Op, TLO.DAG.getNode(ISD::SHL, dl,
|
||||
Op.getValueType(), InOp,
|
||||
ShiftAmt));
|
||||
|
@ -994,7 +995,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
if (TLO.LegalTypes()) {
|
||||
uint64_t ShVal = ShAmt->getZExtValue();
|
||||
Shift =
|
||||
TLO.DAG.getConstant(ShVal, getShiftAmountTy(Op.getValueType()));
|
||||
TLO.DAG.getConstant(ShVal, dl, getShiftAmountTy(Op.getValueType()));
|
||||
}
|
||||
|
||||
APInt HighBits = APInt::getHighBitsSet(OperandBitWidth,
|
||||
|
@ -1052,7 +1053,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
if (!OpVTLegal && OpVTSizeInBits > 32)
|
||||
Sign = TLO.DAG.getNode(ISD::ZERO_EXTEND, dl, Op.getValueType(), Sign);
|
||||
unsigned ShVal = Op.getValueType().getSizeInBits()-1;
|
||||
SDValue ShAmt = TLO.DAG.getConstant(ShVal, Op.getValueType());
|
||||
SDValue ShAmt = TLO.DAG.getConstant(ShVal, dl, Op.getValueType());
|
||||
return TLO.CombineTo(Op, TLO.DAG.getNode(ISD::SHL, dl,
|
||||
Op.getValueType(),
|
||||
Sign, ShAmt));
|
||||
|
@ -1086,7 +1087,8 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,
|
|||
// If we know the value of all of the demanded bits, return this as a
|
||||
// constant.
|
||||
if ((NewMask & (KnownZero|KnownOne)) == NewMask)
|
||||
return TLO.CombineTo(Op, TLO.DAG.getConstant(KnownOne, Op.getValueType()));
|
||||
return TLO.CombineTo(Op,
|
||||
TLO.DAG.getConstant(KnownOne, dl, Op.getValueType()));
|
||||
|
||||
return false;
|
||||
}
|
||||
|
@ -1222,13 +1224,14 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
switch (Cond) {
|
||||
default: break;
|
||||
case ISD::SETFALSE:
|
||||
case ISD::SETFALSE2: return DAG.getConstant(0, VT);
|
||||
case ISD::SETFALSE2: return DAG.getConstant(0, dl, VT);
|
||||
case ISD::SETTRUE:
|
||||
case ISD::SETTRUE2: {
|
||||
TargetLowering::BooleanContent Cnt =
|
||||
getBooleanContents(N0->getValueType(0));
|
||||
return DAG.getConstant(
|
||||
Cnt == TargetLowering::ZeroOrNegativeOneBooleanContent ? -1ULL : 1, VT);
|
||||
Cnt == TargetLowering::ZeroOrNegativeOneBooleanContent ? -1ULL : 1, dl,
|
||||
VT);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1262,7 +1265,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
// (srl (ctlz x), 5) == 1 -> X == 0
|
||||
Cond = ISD::SETEQ;
|
||||
}
|
||||
SDValue Zero = DAG.getConstant(0, N0.getValueType());
|
||||
SDValue Zero = DAG.getConstant(0, dl, N0.getValueType());
|
||||
return DAG.getSetCC(dl, VT, N0.getOperand(0).getOperand(0),
|
||||
Zero, Cond);
|
||||
}
|
||||
|
@ -1283,10 +1286,10 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
// (ctpop x) u> 1 -> (x & x-1) != 0
|
||||
if ((Cond == ISD::SETULT && C1 == 2) || (Cond == ISD::SETUGT && C1 == 1)){
|
||||
SDValue Sub = DAG.getNode(ISD::SUB, dl, CTVT, CTOp,
|
||||
DAG.getConstant(1, CTVT));
|
||||
DAG.getConstant(1, dl, CTVT));
|
||||
SDValue And = DAG.getNode(ISD::AND, dl, CTVT, CTOp, Sub);
|
||||
ISD::CondCode CC = Cond == ISD::SETULT ? ISD::SETEQ : ISD::SETNE;
|
||||
return DAG.getSetCC(dl, VT, And, DAG.getConstant(0, CTVT), CC);
|
||||
return DAG.getSetCC(dl, VT, And, DAG.getConstant(0, dl, CTVT), CC);
|
||||
}
|
||||
|
||||
// TODO: (ctpop x) == 1 -> x && (x & x-1) == 0 iff ctpop is illegal.
|
||||
|
@ -1340,7 +1343,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
if (isTypeDesirableForOp(ISD::SETCC, MinVT)) {
|
||||
// Will get folded away.
|
||||
SDValue Trunc = DAG.getNode(ISD::TRUNCATE, dl, MinVT, PreExt);
|
||||
SDValue C = DAG.getConstant(C1.trunc(MinBits), MinVT);
|
||||
SDValue C = DAG.getConstant(C1.trunc(MinBits), dl, MinVT);
|
||||
return DAG.getSetCC(dl, VT, Trunc, C, Cond);
|
||||
}
|
||||
}
|
||||
|
@ -1391,7 +1394,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
SDValue Ptr = Lod->getBasePtr();
|
||||
if (bestOffset != 0)
|
||||
Ptr = DAG.getNode(ISD::ADD, dl, PtrType, Lod->getBasePtr(),
|
||||
DAG.getConstant(bestOffset, PtrType));
|
||||
DAG.getConstant(bestOffset, dl, PtrType));
|
||||
unsigned NewAlign = MinAlign(Lod->getAlignment(), bestOffset);
|
||||
SDValue NewLoad = DAG.getLoad(newVT, dl, Lod->getChain(), Ptr,
|
||||
Lod->getPointerInfo().getWithOffset(bestOffset),
|
||||
|
@ -1399,8 +1402,8 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
return DAG.getSetCC(dl, VT,
|
||||
DAG.getNode(ISD::AND, dl, newVT, NewLoad,
|
||||
DAG.getConstant(bestMask.trunc(bestWidth),
|
||||
newVT)),
|
||||
DAG.getConstant(0LL, newVT), Cond);
|
||||
dl, newVT)),
|
||||
DAG.getConstant(0LL, dl, newVT), Cond);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1416,18 +1419,18 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
switch (Cond) {
|
||||
case ISD::SETUGT:
|
||||
case ISD::SETUGE:
|
||||
case ISD::SETEQ: return DAG.getConstant(0, VT);
|
||||
case ISD::SETEQ: return DAG.getConstant(0, dl, VT);
|
||||
case ISD::SETULT:
|
||||
case ISD::SETULE:
|
||||
case ISD::SETNE: return DAG.getConstant(1, VT);
|
||||
case ISD::SETNE: return DAG.getConstant(1, dl, VT);
|
||||
case ISD::SETGT:
|
||||
case ISD::SETGE:
|
||||
// True if the sign bit of C1 is set.
|
||||
return DAG.getConstant(C1.isNegative(), VT);
|
||||
return DAG.getConstant(C1.isNegative(), dl, VT);
|
||||
case ISD::SETLT:
|
||||
case ISD::SETLE:
|
||||
// True if the sign bit of C1 isn't set.
|
||||
return DAG.getConstant(C1.isNonNegative(), VT);
|
||||
return DAG.getConstant(C1.isNonNegative(), dl, VT);
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@ -1446,7 +1449,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
(isOperationLegal(ISD::SETCC, newVT) &&
|
||||
getCondCodeAction(Cond, newVT.getSimpleVT()) == Legal)) {
|
||||
EVT NewSetCCVT = getSetCCResultType(*DAG.getContext(), newVT);
|
||||
SDValue NewConst = DAG.getConstant(C1.trunc(InSize), newVT);
|
||||
SDValue NewConst = DAG.getConstant(C1.trunc(InSize), dl, newVT);
|
||||
|
||||
SDValue NewSetCC = DAG.getSetCC(dl, NewSetCCVT, N0.getOperand(0),
|
||||
NewConst, Cond);
|
||||
|
@ -1467,7 +1470,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
// If the constant doesn't fit into the number of bits for the source of
|
||||
// the sign extension, it is impossible for both sides to be equal.
|
||||
if (C1.getMinSignedBits() > ExtSrcTyBits)
|
||||
return DAG.getConstant(Cond == ISD::SETNE, VT);
|
||||
return DAG.getConstant(Cond == ISD::SETNE, dl, VT);
|
||||
|
||||
SDValue ZextOp;
|
||||
EVT Op0Ty = N0.getOperand(0).getValueType();
|
||||
|
@ -1476,7 +1479,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
} else {
|
||||
APInt Imm = APInt::getLowBitsSet(ExtDstTyBits, ExtSrcTyBits);
|
||||
ZextOp = DAG.getNode(ISD::AND, dl, Op0Ty, N0.getOperand(0),
|
||||
DAG.getConstant(Imm, Op0Ty));
|
||||
DAG.getConstant(Imm, dl, Op0Ty));
|
||||
}
|
||||
if (!DCI.isCalledByLegalizer())
|
||||
DCI.AddToWorklist(ZextOp.getNode());
|
||||
|
@ -1485,7 +1488,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
DAG.getConstant(C1 & APInt::getLowBitsSet(
|
||||
ExtDstTyBits,
|
||||
ExtSrcTyBits),
|
||||
ExtDstTy),
|
||||
dl, ExtDstTy),
|
||||
Cond);
|
||||
} else if ((N1C->isNullValue() || N1C->getAPIntValue() == 1) &&
|
||||
(Cond == ISD::SETEQ || Cond == ISD::SETNE)) {
|
||||
|
@ -1555,20 +1558,20 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
if (Op0.getValueType().bitsGT(VT))
|
||||
Op0 = DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNode(ISD::TRUNCATE, dl, VT, Op0.getOperand(0)),
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, dl, VT));
|
||||
else if (Op0.getValueType().bitsLT(VT))
|
||||
Op0 = DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNode(ISD::ANY_EXTEND, dl, VT, Op0.getOperand(0)),
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, dl, VT));
|
||||
|
||||
return DAG.getSetCC(dl, VT, Op0,
|
||||
DAG.getConstant(0, Op0.getValueType()),
|
||||
DAG.getConstant(0, dl, Op0.getValueType()),
|
||||
Cond == ISD::SETEQ ? ISD::SETNE : ISD::SETEQ);
|
||||
}
|
||||
if (Op0.getOpcode() == ISD::AssertZext &&
|
||||
cast<VTSDNode>(Op0.getOperand(1))->getVT() == MVT::i1)
|
||||
return DAG.getSetCC(dl, VT, Op0,
|
||||
DAG.getConstant(0, Op0.getValueType()),
|
||||
DAG.getConstant(0, dl, Op0.getValueType()),
|
||||
Cond == ISD::SETEQ ? ISD::SETNE : ISD::SETEQ);
|
||||
}
|
||||
}
|
||||
|
@ -1585,7 +1588,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
|
||||
// Canonicalize GE/LE comparisons to use GT/LT comparisons.
|
||||
if (Cond == ISD::SETGE || Cond == ISD::SETUGE) {
|
||||
if (C1 == MinVal) return DAG.getConstant(1, VT); // X >= MIN --> true
|
||||
if (C1 == MinVal) return DAG.getConstant(1, dl, VT); // X >= MIN --> true
|
||||
// X >= C0 --> X > (C0 - 1)
|
||||
APInt C = C1 - 1;
|
||||
ISD::CondCode NewCC = (Cond == ISD::SETGE) ? ISD::SETGT : ISD::SETUGT;
|
||||
|
@ -1594,13 +1597,13 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
(!N1C->isOpaque() || (N1C->isOpaque() && C.getBitWidth() <= 64 &&
|
||||
isLegalICmpImmediate(C.getSExtValue())))) {
|
||||
return DAG.getSetCC(dl, VT, N0,
|
||||
DAG.getConstant(C, N1.getValueType()),
|
||||
DAG.getConstant(C, dl, N1.getValueType()),
|
||||
NewCC);
|
||||
}
|
||||
}
|
||||
|
||||
if (Cond == ISD::SETLE || Cond == ISD::SETULE) {
|
||||
if (C1 == MaxVal) return DAG.getConstant(1, VT); // X <= MAX --> true
|
||||
if (C1 == MaxVal) return DAG.getConstant(1, dl, VT); // X <= MAX --> true
|
||||
// X <= C0 --> X < (C0 + 1)
|
||||
APInt C = C1 + 1;
|
||||
ISD::CondCode NewCC = (Cond == ISD::SETLE) ? ISD::SETLT : ISD::SETULT;
|
||||
|
@ -1609,19 +1612,19 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
(!N1C->isOpaque() || (N1C->isOpaque() && C.getBitWidth() <= 64 &&
|
||||
isLegalICmpImmediate(C.getSExtValue())))) {
|
||||
return DAG.getSetCC(dl, VT, N0,
|
||||
DAG.getConstant(C, N1.getValueType()),
|
||||
DAG.getConstant(C, dl, N1.getValueType()),
|
||||
NewCC);
|
||||
}
|
||||
}
|
||||
|
||||
if ((Cond == ISD::SETLT || Cond == ISD::SETULT) && C1 == MinVal)
|
||||
return DAG.getConstant(0, VT); // X < MIN --> false
|
||||
return DAG.getConstant(0, dl, VT); // X < MIN --> false
|
||||
if ((Cond == ISD::SETGE || Cond == ISD::SETUGE) && C1 == MinVal)
|
||||
return DAG.getConstant(1, VT); // X >= MIN --> true
|
||||
return DAG.getConstant(1, dl, VT); // X >= MIN --> true
|
||||
if ((Cond == ISD::SETGT || Cond == ISD::SETUGT) && C1 == MaxVal)
|
||||
return DAG.getConstant(0, VT); // X > MAX --> false
|
||||
return DAG.getConstant(0, dl, VT); // X > MAX --> false
|
||||
if ((Cond == ISD::SETLE || Cond == ISD::SETULE) && C1 == MaxVal)
|
||||
return DAG.getConstant(1, VT); // X <= MAX --> true
|
||||
return DAG.getConstant(1, dl, VT); // X <= MAX --> true
|
||||
|
||||
// Canonicalize setgt X, Min --> setne X, Min
|
||||
if ((Cond == ISD::SETGT || Cond == ISD::SETUGT) && C1 == MinVal)
|
||||
|
@ -1633,12 +1636,12 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
// If we have setult X, 1, turn it into seteq X, 0
|
||||
if ((Cond == ISD::SETLT || Cond == ISD::SETULT) && C1 == MinVal+1)
|
||||
return DAG.getSetCC(dl, VT, N0,
|
||||
DAG.getConstant(MinVal, N0.getValueType()),
|
||||
DAG.getConstant(MinVal, dl, N0.getValueType()),
|
||||
ISD::SETEQ);
|
||||
// If we have setugt X, Max-1, turn it into seteq X, Max
|
||||
if ((Cond == ISD::SETGT || Cond == ISD::SETUGT) && C1 == MaxVal-1)
|
||||
return DAG.getSetCC(dl, VT, N0,
|
||||
DAG.getConstant(MaxVal, N0.getValueType()),
|
||||
DAG.getConstant(MaxVal, dl, N0.getValueType()),
|
||||
ISD::SETEQ);
|
||||
|
||||
// If we have "setcc X, C0", check to see if we can shrink the immediate
|
||||
|
@ -1648,14 +1651,14 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
if (Cond == ISD::SETUGT &&
|
||||
C1 == APInt::getSignedMaxValue(OperandBitSize))
|
||||
return DAG.getSetCC(dl, VT, N0,
|
||||
DAG.getConstant(0, N1.getValueType()),
|
||||
DAG.getConstant(0, dl, N1.getValueType()),
|
||||
ISD::SETLT);
|
||||
|
||||
// SETULT X, SINTMIN -> SETGT X, -1
|
||||
if (Cond == ISD::SETULT &&
|
||||
C1 == APInt::getSignedMinValue(OperandBitSize)) {
|
||||
SDValue ConstMinusOne =
|
||||
DAG.getConstant(APInt::getAllOnesValue(OperandBitSize),
|
||||
DAG.getConstant(APInt::getAllOnesValue(OperandBitSize), dl,
|
||||
N1.getValueType());
|
||||
return DAG.getSetCC(dl, VT, N0, ConstMinusOne, ISD::SETGT);
|
||||
}
|
||||
|
@ -1674,7 +1677,8 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
if (AndRHS->getAPIntValue().isPowerOf2()) {
|
||||
return DAG.getNode(ISD::TRUNCATE, dl, VT,
|
||||
DAG.getNode(ISD::SRL, dl, N0.getValueType(), N0,
|
||||
DAG.getConstant(AndRHS->getAPIntValue().logBase2(), ShiftTy)));
|
||||
DAG.getConstant(AndRHS->getAPIntValue().logBase2(), dl,
|
||||
ShiftTy)));
|
||||
}
|
||||
} else if (Cond == ISD::SETEQ && C1 == AndRHS->getAPIntValue()) {
|
||||
// (X & 8) == 8 --> (X & 8) >> 3
|
||||
|
@ -1682,7 +1686,8 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
if (C1.isPowerOf2()) {
|
||||
return DAG.getNode(ISD::TRUNCATE, dl, VT,
|
||||
DAG.getNode(ISD::SRL, dl, N0.getValueType(), N0,
|
||||
DAG.getConstant(C1.logBase2(), ShiftTy)));
|
||||
DAG.getConstant(C1.logBase2(), dl,
|
||||
ShiftTy)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1701,8 +1706,9 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
getPointerTy() : getShiftAmountTy(N0.getValueType());
|
||||
EVT CmpTy = N0.getValueType();
|
||||
SDValue Shift = DAG.getNode(ISD::SRL, dl, CmpTy, N0.getOperand(0),
|
||||
DAG.getConstant(ShiftBits, ShiftTy));
|
||||
SDValue CmpRHS = DAG.getConstant(C1.lshr(ShiftBits), CmpTy);
|
||||
DAG.getConstant(ShiftBits, dl,
|
||||
ShiftTy));
|
||||
SDValue CmpRHS = DAG.getConstant(C1.lshr(ShiftBits), dl, CmpTy);
|
||||
return DAG.getSetCC(dl, VT, Shift, CmpRHS, Cond);
|
||||
}
|
||||
}
|
||||
|
@ -1729,8 +1735,8 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
getPointerTy() : getShiftAmountTy(N0.getValueType());
|
||||
EVT CmpTy = N0.getValueType();
|
||||
SDValue Shift = DAG.getNode(ISD::SRL, dl, CmpTy, N0,
|
||||
DAG.getConstant(ShiftBits, ShiftTy));
|
||||
SDValue CmpRHS = DAG.getConstant(NewC, CmpTy);
|
||||
DAG.getConstant(ShiftBits, dl, ShiftTy));
|
||||
SDValue CmpRHS = DAG.getConstant(NewC, dl, CmpTy);
|
||||
return DAG.getSetCC(dl, VT, Shift, CmpRHS, NewCond);
|
||||
}
|
||||
}
|
||||
|
@ -1749,9 +1755,9 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
switch (ISD::getUnorderedFlavor(Cond)) {
|
||||
default: llvm_unreachable("Unknown flavor!");
|
||||
case 0: // Known false.
|
||||
return DAG.getConstant(0, VT);
|
||||
return DAG.getConstant(0, dl, VT);
|
||||
case 1: // Known true.
|
||||
return DAG.getConstant(1, VT);
|
||||
return DAG.getConstant(1, dl, VT);
|
||||
case 2: // Undefined.
|
||||
return DAG.getUNDEF(VT);
|
||||
}
|
||||
|
@ -1818,13 +1824,13 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
|
||||
// We can always fold X == X for integer setcc's.
|
||||
if (N0.getValueType().isInteger()) {
|
||||
return DAG.getConstant(EqVal, VT);
|
||||
return DAG.getConstant(EqVal, dl, VT);
|
||||
}
|
||||
unsigned UOF = ISD::getUnorderedFlavor(Cond);
|
||||
if (UOF == 2) // FP operators that are undefined on NaNs.
|
||||
return DAG.getConstant(EqVal, VT);
|
||||
return DAG.getConstant(EqVal, dl, VT);
|
||||
if (UOF == unsigned(ISD::isTrueWhenEqual(Cond)))
|
||||
return DAG.getConstant(EqVal, VT);
|
||||
return DAG.getConstant(EqVal, dl, VT);
|
||||
// Otherwise, we can't fold it. However, we can simplify it to SETUO/SETO
|
||||
// if it is not already.
|
||||
ISD::CondCode NewCond = UOF == 0 ? ISD::SETO : ISD::SETUO;
|
||||
|
@ -1865,7 +1871,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
return DAG.getSetCC(dl, VT, N0.getOperand(0),
|
||||
DAG.getConstant(RHSC->getAPIntValue()-
|
||||
LHSR->getAPIntValue(),
|
||||
N0.getValueType()), Cond);
|
||||
dl, N0.getValueType()), Cond);
|
||||
}
|
||||
|
||||
// Turn (X^C1) == C2 into X == C1^C2 iff X&~C1 = 0.
|
||||
|
@ -1877,7 +1883,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
DAG.getSetCC(dl, VT, N0.getOperand(0),
|
||||
DAG.getConstant(LHSR->getAPIntValue() ^
|
||||
RHSC->getAPIntValue(),
|
||||
N0.getValueType()),
|
||||
dl, N0.getValueType()),
|
||||
Cond);
|
||||
}
|
||||
|
||||
|
@ -1888,7 +1894,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
DAG.getSetCC(dl, VT, N0.getOperand(1),
|
||||
DAG.getConstant(SUBC->getAPIntValue() -
|
||||
RHSC->getAPIntValue(),
|
||||
N0.getValueType()),
|
||||
dl, N0.getValueType()),
|
||||
Cond);
|
||||
}
|
||||
}
|
||||
|
@ -1905,16 +1911,18 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
if (!LegalRHSImm || N0.getNode()->hasOneUse()) {
|
||||
if (N0.getOperand(0) == N1)
|
||||
return DAG.getSetCC(dl, VT, N0.getOperand(1),
|
||||
DAG.getConstant(0, N0.getValueType()), Cond);
|
||||
DAG.getConstant(0, dl, N0.getValueType()), Cond);
|
||||
if (N0.getOperand(1) == N1) {
|
||||
if (DAG.isCommutativeBinOp(N0.getOpcode()))
|
||||
return DAG.getSetCC(dl, VT, N0.getOperand(0),
|
||||
DAG.getConstant(0, N0.getValueType()), Cond);
|
||||
DAG.getConstant(0, dl, N0.getValueType()),
|
||||
Cond);
|
||||
if (N0.getNode()->hasOneUse()) {
|
||||
assert(N0.getOpcode() == ISD::SUB && "Unexpected operation!");
|
||||
// (Z-X) == X --> Z == X<<1
|
||||
SDValue SH = DAG.getNode(ISD::SHL, dl, N1.getValueType(), N1,
|
||||
DAG.getConstant(1, getShiftAmountTy(N1.getValueType())));
|
||||
DAG.getConstant(1, dl,
|
||||
getShiftAmountTy(N1.getValueType())));
|
||||
if (!DCI.isCalledByLegalizer())
|
||||
DCI.AddToWorklist(SH.getNode());
|
||||
return DAG.getSetCC(dl, VT, N0.getOperand(0), SH, Cond);
|
||||
|
@ -1928,16 +1936,17 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
// Simplify X == (X+Z) --> Z == 0
|
||||
if (N1.getOperand(0) == N0)
|
||||
return DAG.getSetCC(dl, VT, N1.getOperand(1),
|
||||
DAG.getConstant(0, N1.getValueType()), Cond);
|
||||
DAG.getConstant(0, dl, N1.getValueType()), Cond);
|
||||
if (N1.getOperand(1) == N0) {
|
||||
if (DAG.isCommutativeBinOp(N1.getOpcode()))
|
||||
return DAG.getSetCC(dl, VT, N1.getOperand(0),
|
||||
DAG.getConstant(0, N1.getValueType()), Cond);
|
||||
DAG.getConstant(0, dl, N1.getValueType()), Cond);
|
||||
if (N1.getNode()->hasOneUse()) {
|
||||
assert(N1.getOpcode() == ISD::SUB && "Unexpected operation!");
|
||||
// X == (Z-X) --> X<<1 == Z
|
||||
SDValue SH = DAG.getNode(ISD::SHL, dl, N1.getValueType(), N0,
|
||||
DAG.getConstant(1, getShiftAmountTy(N0.getValueType())));
|
||||
DAG.getConstant(1, dl,
|
||||
getShiftAmountTy(N0.getValueType())));
|
||||
if (!DCI.isCalledByLegalizer())
|
||||
DCI.AddToWorklist(SH.getNode());
|
||||
return DAG.getSetCC(dl, VT, SH, N1.getOperand(0), Cond);
|
||||
|
@ -1955,7 +1964,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
Cond = ISD::getSetCCInverse(Cond, /*isInteger=*/true);
|
||||
if (DCI.isBeforeLegalizeOps() ||
|
||||
isCondCodeLegal(Cond, N0.getSimpleValueType())) {
|
||||
SDValue Zero = DAG.getConstant(0, N1.getValueType());
|
||||
SDValue Zero = DAG.getConstant(0, dl, N1.getValueType());
|
||||
return DAG.getSetCC(dl, VT, N0, Zero, Cond);
|
||||
}
|
||||
}
|
||||
|
@ -1966,7 +1975,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
|||
Cond = ISD::getSetCCInverse(Cond, /*isInteger=*/true);
|
||||
if (DCI.isBeforeLegalizeOps() ||
|
||||
isCondCodeLegal(Cond, N1.getSimpleValueType())) {
|
||||
SDValue Zero = DAG.getConstant(0, N0.getValueType());
|
||||
SDValue Zero = DAG.getConstant(0, dl, N0.getValueType());
|
||||
return DAG.getSetCC(dl, VT, N1, Zero, Cond);
|
||||
}
|
||||
}
|
||||
|
@ -2181,7 +2190,7 @@ void TargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
// now; without this it would get ZExt'd later in
|
||||
// ScheduleDAGSDNodes::EmitNode, which is very generic.
|
||||
Ops.push_back(DAG.getTargetConstant(C->getAPIntValue().getSExtValue(),
|
||||
MVT::i64));
|
||||
SDLoc(C), MVT::i64));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -2649,7 +2658,8 @@ SDValue TargetLowering::BuildExactSDIV(SDValue Op1, SDValue Op2, SDLoc dl,
|
|||
unsigned ShAmt = d.countTrailingZeros();
|
||||
if (ShAmt) {
|
||||
// TODO: For UDIV use SRL instead of SRA.
|
||||
SDValue Amt = DAG.getConstant(ShAmt, getShiftAmountTy(Op1.getValueType()));
|
||||
SDValue Amt = DAG.getConstant(ShAmt, dl,
|
||||
getShiftAmountTy(Op1.getValueType()));
|
||||
Op1 = DAG.getNode(ISD::SRA, dl, Op1.getValueType(), Op1, Amt, false, false,
|
||||
true);
|
||||
d = d.ashr(ShAmt);
|
||||
|
@ -2660,7 +2670,7 @@ SDValue TargetLowering::BuildExactSDIV(SDValue Op1, SDValue Op2, SDLoc dl,
|
|||
while ((t = d*xn) != 1)
|
||||
xn *= APInt(d.getBitWidth(), 2) - t;
|
||||
|
||||
Op2 = DAG.getConstant(xn, Op1.getValueType());
|
||||
Op2 = DAG.getConstant(xn, dl, Op1.getValueType());
|
||||
return DAG.getNode(ISD::MUL, dl, Op1.getValueType(), Op1, Op2);
|
||||
}
|
||||
|
||||
|
@ -2689,12 +2699,12 @@ SDValue TargetLowering::BuildSDIV(SDNode *N, const APInt &Divisor,
|
|||
if (IsAfterLegalization ? isOperationLegal(ISD::MULHS, VT) :
|
||||
isOperationLegalOrCustom(ISD::MULHS, VT))
|
||||
Q = DAG.getNode(ISD::MULHS, dl, VT, N->getOperand(0),
|
||||
DAG.getConstant(magics.m, VT));
|
||||
DAG.getConstant(magics.m, dl, VT));
|
||||
else if (IsAfterLegalization ? isOperationLegal(ISD::SMUL_LOHI, VT) :
|
||||
isOperationLegalOrCustom(ISD::SMUL_LOHI, VT))
|
||||
Q = SDValue(DAG.getNode(ISD::SMUL_LOHI, dl, DAG.getVTList(VT, VT),
|
||||
N->getOperand(0),
|
||||
DAG.getConstant(magics.m, VT)).getNode(), 1);
|
||||
DAG.getConstant(magics.m, dl, VT)).getNode(), 1);
|
||||
else
|
||||
return SDValue(); // No mulhs or equvialent
|
||||
// If d > 0 and m < 0, add the numerator
|
||||
|
@ -2710,12 +2720,13 @@ SDValue TargetLowering::BuildSDIV(SDNode *N, const APInt &Divisor,
|
|||
// Shift right algebraic if shift value is nonzero
|
||||
if (magics.s > 0) {
|
||||
Q = DAG.getNode(ISD::SRA, dl, VT, Q,
|
||||
DAG.getConstant(magics.s, getShiftAmountTy(Q.getValueType())));
|
||||
DAG.getConstant(magics.s, dl,
|
||||
getShiftAmountTy(Q.getValueType())));
|
||||
Created->push_back(Q.getNode());
|
||||
}
|
||||
// Extract the sign bit and add it to the quotient
|
||||
SDValue T = DAG.getNode(ISD::SRL, dl, VT, Q,
|
||||
DAG.getConstant(VT.getScalarSizeInBits() - 1,
|
||||
DAG.getConstant(VT.getScalarSizeInBits() - 1, dl,
|
||||
getShiftAmountTy(Q.getValueType())));
|
||||
Created->push_back(T.getNode());
|
||||
return DAG.getNode(ISD::ADD, dl, VT, Q, T);
|
||||
|
@ -2749,7 +2760,8 @@ SDValue TargetLowering::BuildUDIV(SDNode *N, const APInt &Divisor,
|
|||
if (magics.a != 0 && !Divisor[0]) {
|
||||
unsigned Shift = Divisor.countTrailingZeros();
|
||||
Q = DAG.getNode(ISD::SRL, dl, VT, Q,
|
||||
DAG.getConstant(Shift, getShiftAmountTy(Q.getValueType())));
|
||||
DAG.getConstant(Shift, dl,
|
||||
getShiftAmountTy(Q.getValueType())));
|
||||
Created->push_back(Q.getNode());
|
||||
|
||||
// Get magic number for the shifted divisor.
|
||||
|
@ -2761,11 +2773,11 @@ SDValue TargetLowering::BuildUDIV(SDNode *N, const APInt &Divisor,
|
|||
// FIXME: We should support doing a MUL in a wider type
|
||||
if (IsAfterLegalization ? isOperationLegal(ISD::MULHU, VT) :
|
||||
isOperationLegalOrCustom(ISD::MULHU, VT))
|
||||
Q = DAG.getNode(ISD::MULHU, dl, VT, Q, DAG.getConstant(magics.m, VT));
|
||||
Q = DAG.getNode(ISD::MULHU, dl, VT, Q, DAG.getConstant(magics.m, dl, VT));
|
||||
else if (IsAfterLegalization ? isOperationLegal(ISD::UMUL_LOHI, VT) :
|
||||
isOperationLegalOrCustom(ISD::UMUL_LOHI, VT))
|
||||
Q = SDValue(DAG.getNode(ISD::UMUL_LOHI, dl, DAG.getVTList(VT, VT), Q,
|
||||
DAG.getConstant(magics.m, VT)).getNode(), 1);
|
||||
DAG.getConstant(magics.m, dl, VT)).getNode(), 1);
|
||||
else
|
||||
return SDValue(); // No mulhu or equvialent
|
||||
|
||||
|
@ -2775,17 +2787,20 @@ SDValue TargetLowering::BuildUDIV(SDNode *N, const APInt &Divisor,
|
|||
assert(magics.s < Divisor.getBitWidth() &&
|
||||
"We shouldn't generate an undefined shift!");
|
||||
return DAG.getNode(ISD::SRL, dl, VT, Q,
|
||||
DAG.getConstant(magics.s, getShiftAmountTy(Q.getValueType())));
|
||||
DAG.getConstant(magics.s, dl,
|
||||
getShiftAmountTy(Q.getValueType())));
|
||||
} else {
|
||||
SDValue NPQ = DAG.getNode(ISD::SUB, dl, VT, N->getOperand(0), Q);
|
||||
Created->push_back(NPQ.getNode());
|
||||
NPQ = DAG.getNode(ISD::SRL, dl, VT, NPQ,
|
||||
DAG.getConstant(1, getShiftAmountTy(NPQ.getValueType())));
|
||||
DAG.getConstant(1, dl,
|
||||
getShiftAmountTy(NPQ.getValueType())));
|
||||
Created->push_back(NPQ.getNode());
|
||||
NPQ = DAG.getNode(ISD::ADD, dl, VT, NPQ, Q);
|
||||
Created->push_back(NPQ.getNode());
|
||||
return DAG.getNode(ISD::SRL, dl, VT, NPQ,
|
||||
DAG.getConstant(magics.s-1, getShiftAmountTy(NPQ.getValueType())));
|
||||
DAG.getConstant(magics.s - 1, dl,
|
||||
getShiftAmountTy(NPQ.getValueType())));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -2872,7 +2887,7 @@ bool TargetLowering::expandMUL(SDNode *N, SDValue &Lo, SDValue &Hi, EVT HiLoVT,
|
|||
isOperationLegalOrCustom(ISD::SRL, VT) &&
|
||||
isOperationLegalOrCustom(ISD::TRUNCATE, HiLoVT)) {
|
||||
unsigned ShiftAmt = VT.getSizeInBits() - HiLoVT.getSizeInBits();
|
||||
SDValue Shift = DAG.getConstant(ShiftAmt, getShiftAmountTy(VT));
|
||||
SDValue Shift = DAG.getConstant(ShiftAmt, dl, getShiftAmountTy(VT));
|
||||
LH = DAG.getNode(ISD::SRL, dl, VT, N->getOperand(0), Shift);
|
||||
LH = DAG.getNode(ISD::TRUNCATE, dl, HiLoVT, LH);
|
||||
RH = DAG.getNode(ISD::SRL, dl, VT, N->getOperand(1), Shift);
|
||||
|
@ -2922,13 +2937,13 @@ bool TargetLowering::expandFP_TO_SINT(SDNode *Node, SDValue &Result,
|
|||
// https://github.com/llvm-mirror/compiler-rt/blob/master/lib/builtins/fixsfdi.c
|
||||
EVT IntVT = EVT::getIntegerVT(*DAG.getContext(),
|
||||
VT.getSizeInBits());
|
||||
SDValue ExponentMask = DAG.getConstant(0x7F800000, IntVT);
|
||||
SDValue ExponentLoBit = DAG.getConstant(23, IntVT);
|
||||
SDValue Bias = DAG.getConstant(127, IntVT);
|
||||
SDValue SignMask = DAG.getConstant(APInt::getSignBit(VT.getSizeInBits()),
|
||||
SDValue ExponentMask = DAG.getConstant(0x7F800000, dl, IntVT);
|
||||
SDValue ExponentLoBit = DAG.getConstant(23, dl, IntVT);
|
||||
SDValue Bias = DAG.getConstant(127, dl, IntVT);
|
||||
SDValue SignMask = DAG.getConstant(APInt::getSignBit(VT.getSizeInBits()), dl,
|
||||
IntVT);
|
||||
SDValue SignLowBit = DAG.getConstant(VT.getSizeInBits() - 1, IntVT);
|
||||
SDValue MantissaMask = DAG.getConstant(0x007FFFFF, IntVT);
|
||||
SDValue SignLowBit = DAG.getConstant(VT.getSizeInBits() - 1, dl, IntVT);
|
||||
SDValue MantissaMask = DAG.getConstant(0x007FFFFF, dl, IntVT);
|
||||
|
||||
SDValue Bits = DAG.getNode(ISD::BITCAST, dl, IntVT, Node->getOperand(0));
|
||||
|
||||
|
@ -2944,7 +2959,7 @@ bool TargetLowering::expandFP_TO_SINT(SDNode *Node, SDValue &Result,
|
|||
|
||||
SDValue R = DAG.getNode(ISD::OR, dl, IntVT,
|
||||
DAG.getNode(ISD::AND, dl, IntVT, Bits, MantissaMask),
|
||||
DAG.getConstant(0x00800000, IntVT));
|
||||
DAG.getConstant(0x00800000, dl, IntVT));
|
||||
|
||||
R = DAG.getZExtOrTrunc(R, dl, NVT);
|
||||
|
||||
|
@ -2964,7 +2979,7 @@ bool TargetLowering::expandFP_TO_SINT(SDNode *Node, SDValue &Result,
|
|||
DAG.getNode(ISD::XOR, dl, NVT, R, Sign),
|
||||
Sign);
|
||||
|
||||
Result = DAG.getSelectCC(dl, Exponent, DAG.getConstant(0, IntVT),
|
||||
DAG.getConstant(0, NVT), Ret, ISD::SETLT);
|
||||
Result = DAG.getSelectCC(dl, Exponent, DAG.getConstant(0, dl, IntVT),
|
||||
DAG.getConstant(0, dl, NVT), Ret, ISD::SETLT);
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -252,8 +252,9 @@ bool AArch64DAGToDAGISel::SelectArithImmed(SDValue N, SDValue &Val,
|
|||
return false;
|
||||
|
||||
unsigned ShVal = AArch64_AM::getShifterImm(AArch64_AM::LSL, ShiftAmt);
|
||||
Val = CurDAG->getTargetConstant(Immed, MVT::i32);
|
||||
Shift = CurDAG->getTargetConstant(ShVal, MVT::i32);
|
||||
SDLoc dl(N);
|
||||
Val = CurDAG->getTargetConstant(Immed, dl, MVT::i32);
|
||||
Shift = CurDAG->getTargetConstant(ShVal, dl, MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -286,7 +287,8 @@ bool AArch64DAGToDAGISel::SelectNegArithImmed(SDValue N, SDValue &Val,
|
|||
return false;
|
||||
|
||||
Immed &= 0xFFFFFFULL;
|
||||
return SelectArithImmed(CurDAG->getConstant(Immed, MVT::i32), Val, Shift);
|
||||
return SelectArithImmed(CurDAG->getConstant(Immed, SDLoc(N), MVT::i32), Val,
|
||||
Shift);
|
||||
}
|
||||
|
||||
/// getShiftTypeForNode - Translate a shift node to the corresponding
|
||||
|
@ -334,7 +336,7 @@ bool AArch64DAGToDAGISel::SelectShiftedRegister(SDValue N, bool AllowROR,
|
|||
unsigned ShVal = AArch64_AM::getShifterImm(ShType, Val);
|
||||
|
||||
Reg = N.getOperand(0);
|
||||
Shift = CurDAG->getTargetConstant(ShVal, MVT::i32);
|
||||
Shift = CurDAG->getTargetConstant(ShVal, SDLoc(N), MVT::i32);
|
||||
return isWorthFolding(N);
|
||||
}
|
||||
|
||||
|
@ -435,6 +437,7 @@ static bool checkV64LaneV128(SDValue Op0, SDValue Op1, SDValue &StdOp,
|
|||
/// is a lane in the upper half of a 128-bit vector. Recognize and select this
|
||||
/// so that we don't emit unnecessary lane extracts.
|
||||
SDNode *AArch64DAGToDAGISel::SelectMLAV64LaneV128(SDNode *N) {
|
||||
SDLoc dl(N);
|
||||
SDValue Op0 = N->getOperand(0);
|
||||
SDValue Op1 = N->getOperand(1);
|
||||
SDValue MLAOp1; // Will hold ordinary multiplicand for MLA.
|
||||
|
@ -451,7 +454,7 @@ SDNode *AArch64DAGToDAGISel::SelectMLAV64LaneV128(SDNode *N) {
|
|||
return nullptr;
|
||||
}
|
||||
|
||||
SDValue LaneIdxVal = CurDAG->getTargetConstant(LaneIdx, MVT::i64);
|
||||
SDValue LaneIdxVal = CurDAG->getTargetConstant(LaneIdx, dl, MVT::i64);
|
||||
|
||||
SDValue Ops[] = { Op0, MLAOp1, MLAOp2, LaneIdxVal };
|
||||
|
||||
|
@ -474,10 +477,11 @@ SDNode *AArch64DAGToDAGISel::SelectMLAV64LaneV128(SDNode *N) {
|
|||
break;
|
||||
}
|
||||
|
||||
return CurDAG->getMachineNode(MLAOpc, SDLoc(N), N->getValueType(0), Ops);
|
||||
return CurDAG->getMachineNode(MLAOpc, dl, N->getValueType(0), Ops);
|
||||
}
|
||||
|
||||
SDNode *AArch64DAGToDAGISel::SelectMULLV64LaneV128(unsigned IntNo, SDNode *N) {
|
||||
SDLoc dl(N);
|
||||
SDValue SMULLOp0;
|
||||
SDValue SMULLOp1;
|
||||
int LaneIdx;
|
||||
|
@ -486,7 +490,7 @@ SDNode *AArch64DAGToDAGISel::SelectMULLV64LaneV128(unsigned IntNo, SDNode *N) {
|
|||
LaneIdx))
|
||||
return nullptr;
|
||||
|
||||
SDValue LaneIdxVal = CurDAG->getTargetConstant(LaneIdx, MVT::i64);
|
||||
SDValue LaneIdxVal = CurDAG->getTargetConstant(LaneIdx, dl, MVT::i64);
|
||||
|
||||
SDValue Ops[] = { SMULLOp0, SMULLOp1, LaneIdxVal };
|
||||
|
||||
|
@ -517,7 +521,7 @@ SDNode *AArch64DAGToDAGISel::SelectMULLV64LaneV128(unsigned IntNo, SDNode *N) {
|
|||
} else
|
||||
llvm_unreachable("Unrecognized intrinsic.");
|
||||
|
||||
return CurDAG->getMachineNode(SMULLOpc, SDLoc(N), N->getValueType(0), Ops);
|
||||
return CurDAG->getMachineNode(SMULLOpc, dl, N->getValueType(0), Ops);
|
||||
}
|
||||
|
||||
/// Instructions that accept extend modifiers like UXTW expect the register
|
||||
|
@ -528,9 +532,10 @@ static SDValue narrowIfNeeded(SelectionDAG *CurDAG, SDValue N) {
|
|||
if (N.getValueType() == MVT::i32)
|
||||
return N;
|
||||
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, MVT::i32);
|
||||
SDLoc dl(N);
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, dl, MVT::i32);
|
||||
MachineSDNode *Node = CurDAG->getMachineNode(TargetOpcode::EXTRACT_SUBREG,
|
||||
SDLoc(N), MVT::i32, N, SubReg);
|
||||
dl, MVT::i32, N, SubReg);
|
||||
return SDValue(Node, 0);
|
||||
}
|
||||
|
||||
|
@ -570,7 +575,8 @@ bool AArch64DAGToDAGISel::SelectArithExtendedRegister(SDValue N, SDValue &Reg,
|
|||
// (harmlessly) synthesize one by injected an EXTRACT_SUBREG here.
|
||||
assert(Ext != AArch64_AM::UXTX && Ext != AArch64_AM::SXTX);
|
||||
Reg = narrowIfNeeded(CurDAG, Reg);
|
||||
Shift = CurDAG->getTargetConstant(getArithExtendImm(Ext, ShiftVal), MVT::i32);
|
||||
Shift = CurDAG->getTargetConstant(getArithExtendImm(Ext, ShiftVal), SDLoc(N),
|
||||
MVT::i32);
|
||||
return isWorthFolding(N);
|
||||
}
|
||||
|
||||
|
@ -600,11 +606,12 @@ static bool isWorthFoldingADDlow(SDValue N) {
|
|||
/// reference, which determines the scale.
|
||||
bool AArch64DAGToDAGISel::SelectAddrModeIndexed(SDValue N, unsigned Size,
|
||||
SDValue &Base, SDValue &OffImm) {
|
||||
SDLoc dl(N);
|
||||
const TargetLowering *TLI = getTargetLowering();
|
||||
if (N.getOpcode() == ISD::FrameIndex) {
|
||||
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i64);
|
||||
OffImm = CurDAG->getTargetConstant(0, dl, MVT::i64);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -637,7 +644,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeIndexed(SDValue N, unsigned Size,
|
|||
int FI = cast<FrameIndexSDNode>(Base)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
OffImm = CurDAG->getTargetConstant(RHSC >> Scale, MVT::i64);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC >> Scale, dl, MVT::i64);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -653,7 +660,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeIndexed(SDValue N, unsigned Size,
|
|||
// add x0, Xbase, #offset
|
||||
// ldr x0, [x0]
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i64);
|
||||
OffImm = CurDAG->getTargetConstant(0, dl, MVT::i64);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -680,7 +687,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeUnscaled(SDValue N, unsigned Size,
|
|||
const TargetLowering *TLI = getTargetLowering();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, MVT::i64);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i64);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -688,12 +695,12 @@ bool AArch64DAGToDAGISel::SelectAddrModeUnscaled(SDValue N, unsigned Size,
|
|||
}
|
||||
|
||||
static SDValue Widen(SelectionDAG *CurDAG, SDValue N) {
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, MVT::i32);
|
||||
SDLoc dl(N);
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, dl, MVT::i32);
|
||||
SDValue ImpDef = SDValue(
|
||||
CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF, SDLoc(N), MVT::i64),
|
||||
0);
|
||||
CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF, dl, MVT::i64), 0);
|
||||
MachineSDNode *Node = CurDAG->getMachineNode(
|
||||
TargetOpcode::INSERT_SUBREG, SDLoc(N), MVT::i64, ImpDef, N, SubReg);
|
||||
TargetOpcode::INSERT_SUBREG, dl, MVT::i64, ImpDef, N, SubReg);
|
||||
return SDValue(Node, 0);
|
||||
}
|
||||
|
||||
|
@ -707,6 +714,7 @@ bool AArch64DAGToDAGISel::SelectExtendedSHL(SDValue N, unsigned Size,
|
|||
if (!CSD || (CSD->getZExtValue() & 0x7) != CSD->getZExtValue())
|
||||
return false;
|
||||
|
||||
SDLoc dl(N);
|
||||
if (WantExtend) {
|
||||
AArch64_AM::ShiftExtendType Ext =
|
||||
getExtendTypeForNode(N.getOperand(0), true);
|
||||
|
@ -714,10 +722,11 @@ bool AArch64DAGToDAGISel::SelectExtendedSHL(SDValue N, unsigned Size,
|
|||
return false;
|
||||
|
||||
Offset = narrowIfNeeded(CurDAG, N.getOperand(0).getOperand(0));
|
||||
SignExtend = CurDAG->getTargetConstant(Ext == AArch64_AM::SXTW, MVT::i32);
|
||||
SignExtend = CurDAG->getTargetConstant(Ext == AArch64_AM::SXTW, dl,
|
||||
MVT::i32);
|
||||
} else {
|
||||
Offset = N.getOperand(0);
|
||||
SignExtend = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SignExtend = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
}
|
||||
|
||||
unsigned LegalShiftVal = Log2_32(Size);
|
||||
|
@ -740,6 +749,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeWRO(SDValue N, unsigned Size,
|
|||
return false;
|
||||
SDValue LHS = N.getOperand(0);
|
||||
SDValue RHS = N.getOperand(1);
|
||||
SDLoc dl(N);
|
||||
|
||||
// We don't want to match immediate adds here, because they are better lowered
|
||||
// to the register-immediate addressing modes.
|
||||
|
@ -762,7 +772,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeWRO(SDValue N, unsigned Size,
|
|||
if (IsExtendedRegisterWorthFolding && RHS.getOpcode() == ISD::SHL &&
|
||||
SelectExtendedSHL(RHS, Size, true, Offset, SignExtend)) {
|
||||
Base = LHS;
|
||||
DoShift = CurDAG->getTargetConstant(true, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(true, dl, MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -770,12 +780,12 @@ bool AArch64DAGToDAGISel::SelectAddrModeWRO(SDValue N, unsigned Size,
|
|||
if (IsExtendedRegisterWorthFolding && LHS.getOpcode() == ISD::SHL &&
|
||||
SelectExtendedSHL(LHS, Size, true, Offset, SignExtend)) {
|
||||
Base = RHS;
|
||||
DoShift = CurDAG->getTargetConstant(true, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(true, dl, MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
// There was no shift, whatever else we find.
|
||||
DoShift = CurDAG->getTargetConstant(false, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(false, dl, MVT::i32);
|
||||
|
||||
AArch64_AM::ShiftExtendType Ext = AArch64_AM::InvalidShiftExtend;
|
||||
// Try to match an unshifted extend on the LHS.
|
||||
|
@ -784,7 +794,8 @@ bool AArch64DAGToDAGISel::SelectAddrModeWRO(SDValue N, unsigned Size,
|
|||
AArch64_AM::InvalidShiftExtend) {
|
||||
Base = RHS;
|
||||
Offset = narrowIfNeeded(CurDAG, LHS.getOperand(0));
|
||||
SignExtend = CurDAG->getTargetConstant(Ext == AArch64_AM::SXTW, MVT::i32);
|
||||
SignExtend = CurDAG->getTargetConstant(Ext == AArch64_AM::SXTW, dl,
|
||||
MVT::i32);
|
||||
if (isWorthFolding(LHS))
|
||||
return true;
|
||||
}
|
||||
|
@ -795,7 +806,8 @@ bool AArch64DAGToDAGISel::SelectAddrModeWRO(SDValue N, unsigned Size,
|
|||
AArch64_AM::InvalidShiftExtend) {
|
||||
Base = LHS;
|
||||
Offset = narrowIfNeeded(CurDAG, RHS.getOperand(0));
|
||||
SignExtend = CurDAG->getTargetConstant(Ext == AArch64_AM::SXTW, MVT::i32);
|
||||
SignExtend = CurDAG->getTargetConstant(Ext == AArch64_AM::SXTW, dl,
|
||||
MVT::i32);
|
||||
if (isWorthFolding(RHS))
|
||||
return true;
|
||||
}
|
||||
|
@ -826,6 +838,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeXRO(SDValue N, unsigned Size,
|
|||
return false;
|
||||
SDValue LHS = N.getOperand(0);
|
||||
SDValue RHS = N.getOperand(1);
|
||||
SDLoc DL(N);
|
||||
|
||||
// Check if this particular node is reused in any non-memory related
|
||||
// operation. If yes, do not try to fold this node into the address
|
||||
|
@ -857,7 +870,6 @@ bool AArch64DAGToDAGISel::SelectAddrModeXRO(SDValue N, unsigned Size,
|
|||
isPreferredADD(ImmOff) || isPreferredADD(-ImmOff))
|
||||
return false;
|
||||
|
||||
SDLoc DL(N.getNode());
|
||||
SDValue Ops[] = { RHS };
|
||||
SDNode *MOVI =
|
||||
CurDAG->getMachineNode(AArch64::MOVi64imm, DL, MVT::i64, Ops);
|
||||
|
@ -873,7 +885,7 @@ bool AArch64DAGToDAGISel::SelectAddrModeXRO(SDValue N, unsigned Size,
|
|||
if (IsExtendedRegisterWorthFolding && RHS.getOpcode() == ISD::SHL &&
|
||||
SelectExtendedSHL(RHS, Size, false, Offset, SignExtend)) {
|
||||
Base = LHS;
|
||||
DoShift = CurDAG->getTargetConstant(true, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(true, DL, MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -881,15 +893,15 @@ bool AArch64DAGToDAGISel::SelectAddrModeXRO(SDValue N, unsigned Size,
|
|||
if (IsExtendedRegisterWorthFolding && LHS.getOpcode() == ISD::SHL &&
|
||||
SelectExtendedSHL(LHS, Size, false, Offset, SignExtend)) {
|
||||
Base = RHS;
|
||||
DoShift = CurDAG->getTargetConstant(true, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(true, DL, MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
// Match any non-shifted, non-extend, non-immediate add expression.
|
||||
Base = LHS;
|
||||
Offset = RHS;
|
||||
SignExtend = CurDAG->getTargetConstant(false, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(false, MVT::i32);
|
||||
SignExtend = CurDAG->getTargetConstant(false, DL, MVT::i32);
|
||||
DoShift = CurDAG->getTargetConstant(false, DL, MVT::i32);
|
||||
// Reg1 + Reg2 is free: no check needed.
|
||||
return true;
|
||||
}
|
||||
|
@ -922,18 +934,18 @@ SDValue AArch64DAGToDAGISel::createTuple(ArrayRef<SDValue> Regs,
|
|||
|
||||
assert(Regs.size() >= 2 && Regs.size() <= 4);
|
||||
|
||||
SDLoc DL(Regs[0].getNode());
|
||||
SDLoc DL(Regs[0]);
|
||||
|
||||
SmallVector<SDValue, 4> Ops;
|
||||
|
||||
// First operand of REG_SEQUENCE is the desired RegClass.
|
||||
Ops.push_back(
|
||||
CurDAG->getTargetConstant(RegClassIDs[Regs.size() - 2], MVT::i32));
|
||||
CurDAG->getTargetConstant(RegClassIDs[Regs.size() - 2], DL, MVT::i32));
|
||||
|
||||
// Then we get pairs of source & subregister-position for the components.
|
||||
for (unsigned i = 0; i < Regs.size(); ++i) {
|
||||
Ops.push_back(Regs[i]);
|
||||
Ops.push_back(CurDAG->getTargetConstant(SubRegs[i], MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(SubRegs[i], DL, MVT::i32));
|
||||
}
|
||||
|
||||
SDNode *N =
|
||||
|
@ -1030,19 +1042,21 @@ SDNode *AArch64DAGToDAGISel::SelectIndexedLoad(SDNode *N, bool &Done) {
|
|||
SDValue Base = LD->getBasePtr();
|
||||
ConstantSDNode *OffsetOp = cast<ConstantSDNode>(LD->getOffset());
|
||||
int OffsetVal = (int)OffsetOp->getZExtValue();
|
||||
SDValue Offset = CurDAG->getTargetConstant(OffsetVal, MVT::i64);
|
||||
SDLoc dl(N);
|
||||
SDValue Offset = CurDAG->getTargetConstant(OffsetVal, dl, MVT::i64);
|
||||
SDValue Ops[] = { Base, Offset, Chain };
|
||||
SDNode *Res = CurDAG->getMachineNode(Opcode, SDLoc(N), MVT::i64, DstVT,
|
||||
SDNode *Res = CurDAG->getMachineNode(Opcode, dl, MVT::i64, DstVT,
|
||||
MVT::Other, Ops);
|
||||
// Either way, we're replacing the node, so tell the caller that.
|
||||
Done = true;
|
||||
SDValue LoadedVal = SDValue(Res, 1);
|
||||
if (InsertTo64) {
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, MVT::i32);
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, dl, MVT::i32);
|
||||
LoadedVal =
|
||||
SDValue(CurDAG->getMachineNode(
|
||||
AArch64::SUBREG_TO_REG, SDLoc(N), MVT::i64,
|
||||
CurDAG->getTargetConstant(0, MVT::i64), LoadedVal, SubReg),
|
||||
AArch64::SUBREG_TO_REG, dl, MVT::i64,
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i64), LoadedVal,
|
||||
SubReg),
|
||||
0);
|
||||
}
|
||||
|
||||
|
@ -1198,7 +1212,7 @@ SDNode *AArch64DAGToDAGISel::SelectLoadLane(SDNode *N, unsigned NumVecs,
|
|||
unsigned LaneNo =
|
||||
cast<ConstantSDNode>(N->getOperand(NumVecs + 2))->getZExtValue();
|
||||
|
||||
SDValue Ops[] = {RegSeq, CurDAG->getTargetConstant(LaneNo, MVT::i64),
|
||||
SDValue Ops[] = {RegSeq, CurDAG->getTargetConstant(LaneNo, dl, MVT::i64),
|
||||
N->getOperand(NumVecs + 3), N->getOperand(0)};
|
||||
SDNode *Ld = CurDAG->getMachineNode(Opc, dl, ResTys, Ops);
|
||||
SDValue SuperReg = SDValue(Ld, 0);
|
||||
|
@ -1240,7 +1254,8 @@ SDNode *AArch64DAGToDAGISel::SelectPostLoadLane(SDNode *N, unsigned NumVecs,
|
|||
cast<ConstantSDNode>(N->getOperand(NumVecs + 1))->getZExtValue();
|
||||
|
||||
SDValue Ops[] = {RegSeq,
|
||||
CurDAG->getTargetConstant(LaneNo, MVT::i64), // Lane Number
|
||||
CurDAG->getTargetConstant(LaneNo, dl,
|
||||
MVT::i64), // Lane Number
|
||||
N->getOperand(NumVecs + 2), // Base register
|
||||
N->getOperand(NumVecs + 3), // Incremental
|
||||
N->getOperand(0)};
|
||||
|
@ -1291,7 +1306,7 @@ SDNode *AArch64DAGToDAGISel::SelectStoreLane(SDNode *N, unsigned NumVecs,
|
|||
unsigned LaneNo =
|
||||
cast<ConstantSDNode>(N->getOperand(NumVecs + 2))->getZExtValue();
|
||||
|
||||
SDValue Ops[] = {RegSeq, CurDAG->getTargetConstant(LaneNo, MVT::i64),
|
||||
SDValue Ops[] = {RegSeq, CurDAG->getTargetConstant(LaneNo, dl, MVT::i64),
|
||||
N->getOperand(NumVecs + 3), N->getOperand(0)};
|
||||
SDNode *St = CurDAG->getMachineNode(Opc, dl, MVT::Other, Ops);
|
||||
|
||||
|
@ -1324,7 +1339,7 @@ SDNode *AArch64DAGToDAGISel::SelectPostStoreLane(SDNode *N, unsigned NumVecs,
|
|||
unsigned LaneNo =
|
||||
cast<ConstantSDNode>(N->getOperand(NumVecs + 1))->getZExtValue();
|
||||
|
||||
SDValue Ops[] = {RegSeq, CurDAG->getTargetConstant(LaneNo, MVT::i64),
|
||||
SDValue Ops[] = {RegSeq, CurDAG->getTargetConstant(LaneNo, dl, MVT::i64),
|
||||
N->getOperand(NumVecs + 2), // Base Register
|
||||
N->getOperand(NumVecs + 3), // Incremental
|
||||
N->getOperand(0)};
|
||||
|
@ -1590,23 +1605,24 @@ SDNode *AArch64DAGToDAGISel::SelectBitfieldExtractOp(SDNode *N) {
|
|||
return nullptr;
|
||||
|
||||
EVT VT = N->getValueType(0);
|
||||
SDLoc dl(N);
|
||||
|
||||
// If the bit extract operation is 64bit but the original type is 32bit, we
|
||||
// need to add one EXTRACT_SUBREG.
|
||||
if ((Opc == AArch64::SBFMXri || Opc == AArch64::UBFMXri) && VT == MVT::i32) {
|
||||
SDValue Ops64[] = {Opd0, CurDAG->getTargetConstant(LSB, MVT::i64),
|
||||
CurDAG->getTargetConstant(MSB, MVT::i64)};
|
||||
SDValue Ops64[] = {Opd0, CurDAG->getTargetConstant(LSB, dl, MVT::i64),
|
||||
CurDAG->getTargetConstant(MSB, dl, MVT::i64)};
|
||||
|
||||
SDNode *BFM = CurDAG->getMachineNode(Opc, SDLoc(N), MVT::i64, Ops64);
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, MVT::i32);
|
||||
SDNode *BFM = CurDAG->getMachineNode(Opc, dl, MVT::i64, Ops64);
|
||||
SDValue SubReg = CurDAG->getTargetConstant(AArch64::sub_32, dl, MVT::i32);
|
||||
MachineSDNode *Node =
|
||||
CurDAG->getMachineNode(TargetOpcode::EXTRACT_SUBREG, SDLoc(N), MVT::i32,
|
||||
CurDAG->getMachineNode(TargetOpcode::EXTRACT_SUBREG, dl, MVT::i32,
|
||||
SDValue(BFM, 0), SubReg);
|
||||
return Node;
|
||||
}
|
||||
|
||||
SDValue Ops[] = {Opd0, CurDAG->getTargetConstant(LSB, VT),
|
||||
CurDAG->getTargetConstant(MSB, VT)};
|
||||
SDValue Ops[] = {Opd0, CurDAG->getTargetConstant(LSB, dl, VT),
|
||||
CurDAG->getTargetConstant(MSB, dl, VT)};
|
||||
return CurDAG->SelectNodeTo(N, Opc, VT, Ops);
|
||||
}
|
||||
|
||||
|
@ -1810,6 +1826,7 @@ static SDValue getLeftShift(SelectionDAG *CurDAG, SDValue Op, int ShlAmount) {
|
|||
return Op;
|
||||
|
||||
EVT VT = Op.getValueType();
|
||||
SDLoc dl(Op);
|
||||
unsigned BitWidth = VT.getSizeInBits();
|
||||
unsigned UBFMOpc = BitWidth == 32 ? AArch64::UBFMWri : AArch64::UBFMXri;
|
||||
|
||||
|
@ -1817,16 +1834,16 @@ static SDValue getLeftShift(SelectionDAG *CurDAG, SDValue Op, int ShlAmount) {
|
|||
if (ShlAmount > 0) {
|
||||
// LSL wD, wN, #Amt == UBFM wD, wN, #32-Amt, #31-Amt
|
||||
ShiftNode = CurDAG->getMachineNode(
|
||||
UBFMOpc, SDLoc(Op), VT, Op,
|
||||
CurDAG->getTargetConstant(BitWidth - ShlAmount, VT),
|
||||
CurDAG->getTargetConstant(BitWidth - 1 - ShlAmount, VT));
|
||||
UBFMOpc, dl, VT, Op,
|
||||
CurDAG->getTargetConstant(BitWidth - ShlAmount, dl, VT),
|
||||
CurDAG->getTargetConstant(BitWidth - 1 - ShlAmount, dl, VT));
|
||||
} else {
|
||||
// LSR wD, wN, #Amt == UBFM wD, wN, #Amt, #32-1
|
||||
assert(ShlAmount < 0 && "expected right shift");
|
||||
int ShrAmount = -ShlAmount;
|
||||
ShiftNode = CurDAG->getMachineNode(
|
||||
UBFMOpc, SDLoc(Op), VT, Op, CurDAG->getTargetConstant(ShrAmount, VT),
|
||||
CurDAG->getTargetConstant(BitWidth - 1, VT));
|
||||
UBFMOpc, dl, VT, Op, CurDAG->getTargetConstant(ShrAmount, dl, VT),
|
||||
CurDAG->getTargetConstant(BitWidth - 1, dl, VT));
|
||||
}
|
||||
|
||||
return SDValue(ShiftNode, 0);
|
||||
|
@ -1991,10 +2008,11 @@ SDNode *AArch64DAGToDAGISel::SelectBitfieldInsertOp(SDNode *N) {
|
|||
return nullptr;
|
||||
|
||||
EVT VT = N->getValueType(0);
|
||||
SDLoc dl(N);
|
||||
SDValue Ops[] = { Opd0,
|
||||
Opd1,
|
||||
CurDAG->getTargetConstant(LSB, VT),
|
||||
CurDAG->getTargetConstant(MSB, VT) };
|
||||
CurDAG->getTargetConstant(LSB, dl, VT),
|
||||
CurDAG->getTargetConstant(MSB, dl, VT) };
|
||||
return CurDAG->SelectNodeTo(N, Opc, VT, Ops);
|
||||
}
|
||||
|
||||
|
@ -2092,7 +2110,7 @@ AArch64DAGToDAGISel::SelectCVTFixedPosOperand(SDValue N, SDValue &FixedPos,
|
|||
// finding FBits, but it must still be in range.
|
||||
if (FBits == 0 || FBits > RegWidth) return false;
|
||||
|
||||
FixedPos = CurDAG->getTargetConstant(FBits, MVT::i32);
|
||||
FixedPos = CurDAG->getTargetConstant(FBits, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -2207,8 +2225,9 @@ SDNode *AArch64DAGToDAGISel::Select(SDNode *Node) {
|
|||
unsigned Shifter = AArch64_AM::getShifterImm(AArch64_AM::LSL, 0);
|
||||
const TargetLowering *TLI = getTargetLowering();
|
||||
SDValue TFI = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
SDValue Ops[] = { TFI, CurDAG->getTargetConstant(0, MVT::i32),
|
||||
CurDAG->getTargetConstant(Shifter, MVT::i32) };
|
||||
SDLoc DL(Node);
|
||||
SDValue Ops[] = { TFI, CurDAG->getTargetConstant(0, DL, MVT::i32),
|
||||
CurDAG->getTargetConstant(Shifter, DL, MVT::i32) };
|
||||
return CurDAG->SelectNodeTo(Node, AArch64::ADDXri, MVT::i64, Ops);
|
||||
}
|
||||
case ISD::INTRINSIC_W_CHAIN: {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -441,11 +441,11 @@ def vecshiftL64 : Operand<i32>, ImmLeaf<i32, [{
|
|||
// instructions for splatting repeating bit patterns across the immediate.
|
||||
def logical_imm32_XFORM : SDNodeXForm<imm, [{
|
||||
uint64_t enc = AArch64_AM::encodeLogicalImmediate(N->getZExtValue(), 32);
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def logical_imm64_XFORM : SDNodeXForm<imm, [{
|
||||
uint64_t enc = AArch64_AM::encodeLogicalImmediate(N->getZExtValue(), 64);
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
let DiagnosticType = "LogicalSecondSource" in {
|
||||
|
@ -682,7 +682,7 @@ def fpimm32 : Operand<f32>,
|
|||
}], SDNodeXForm<fpimm, [{
|
||||
APFloat InVal = N->getValueAPF();
|
||||
uint32_t enc = AArch64_AM::getFP32Imm(InVal);
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>> {
|
||||
let ParserMatchClass = FPImmOperand;
|
||||
let PrintMethod = "printFPImmOperand";
|
||||
|
@ -693,7 +693,7 @@ def fpimm64 : Operand<f64>,
|
|||
}], SDNodeXForm<fpimm, [{
|
||||
APFloat InVal = N->getValueAPF();
|
||||
uint32_t enc = AArch64_AM::getFP64Imm(InVal);
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>> {
|
||||
let ParserMatchClass = FPImmOperand;
|
||||
let PrintMethod = "printFPImmOperand";
|
||||
|
@ -768,7 +768,7 @@ def simdimmtype10 : Operand<i32>,
|
|||
uint32_t enc = AArch64_AM::encodeAdvSIMDModImmType10(N->getValueAPF()
|
||||
.bitcastToAPInt()
|
||||
.getZExtValue());
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>> {
|
||||
let ParserMatchClass = SIMDImmType10Operand;
|
||||
let PrintMethod = "printSIMDType10Operand";
|
||||
|
@ -2192,7 +2192,8 @@ class BaseCondSelectOp<bit op, bits<2> op2, RegisterClass regtype, string asm,
|
|||
|
||||
def inv_cond_XFORM : SDNodeXForm<imm, [{
|
||||
AArch64CC::CondCode CC = static_cast<AArch64CC::CondCode>(N->getZExtValue());
|
||||
return CurDAG->getTargetConstant(AArch64CC::getInvertedCondCode(CC), MVT::i32);
|
||||
return CurDAG->getTargetConstant(AArch64CC::getInvertedCondCode(CC), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
multiclass CondSelectOp<bit op, bits<2> op2, string asm, PatFrag frag> {
|
||||
|
|
|
@ -498,7 +498,7 @@ def i64imm_32bit : ImmLeaf<i64, [{
|
|||
}]>;
|
||||
|
||||
def trunc_imm : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def : Pat<(i64 i64imm_32bit:$src),
|
||||
|
@ -507,12 +507,12 @@ def : Pat<(i64 i64imm_32bit:$src),
|
|||
// Materialize FP constants via MOVi32imm/MOVi64imm (MachO large code model).
|
||||
def bitcast_fpimm_to_i32 : SDNodeXForm<fpimm, [{
|
||||
return CurDAG->getTargetConstant(
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), MVT::i32);
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def bitcast_fpimm_to_i64 : SDNodeXForm<fpimm, [{
|
||||
return CurDAG->getTargetConstant(
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), MVT::i64);
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
|
||||
|
@ -857,57 +857,57 @@ defm UBFM : BitfieldImm<0b10, "ubfm">;
|
|||
|
||||
def i32shift_a : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = (32 - N->getZExtValue()) & 0x1f;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
def i32shift_b : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 31 - N->getZExtValue();
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// min(7, 31 - shift_amt)
|
||||
def i32shift_sext_i8 : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 31 - N->getZExtValue();
|
||||
enc = enc > 7 ? 7 : enc;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// min(15, 31 - shift_amt)
|
||||
def i32shift_sext_i16 : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 31 - N->getZExtValue();
|
||||
enc = enc > 15 ? 15 : enc;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
def i64shift_a : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = (64 - N->getZExtValue()) & 0x3f;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
def i64shift_b : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 63 - N->getZExtValue();
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// min(7, 63 - shift_amt)
|
||||
def i64shift_sext_i8 : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 63 - N->getZExtValue();
|
||||
enc = enc > 7 ? 7 : enc;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// min(15, 63 - shift_amt)
|
||||
def i64shift_sext_i16 : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 63 - N->getZExtValue();
|
||||
enc = enc > 15 ? 15 : enc;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// min(31, 63 - shift_amt)
|
||||
def i64shift_sext_i32 : Operand<i64>, SDNodeXForm<imm, [{
|
||||
uint64_t enc = 63 - N->getZExtValue();
|
||||
enc = enc > 31 ? 31 : enc;
|
||||
return CurDAG->getTargetConstant(enc, MVT::i64);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
def : Pat<(shl GPR32:$Rn, (i64 imm0_31:$imm)),
|
||||
|
@ -3563,13 +3563,13 @@ def : Pat<(v2f64 (AArch64duplane64 (v2f64 V128:$Rn), VectorIndexD:$imm)),
|
|||
// instruction even if the types don't match: we just have to remap the lane
|
||||
// carefully. N.b. this trick only applies to truncations.
|
||||
def VecIndex_x2 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(2 * N->getZExtValue(), MVT::i64);
|
||||
return CurDAG->getTargetConstant(2 * N->getZExtValue(), SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
def VecIndex_x4 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(4 * N->getZExtValue(), MVT::i64);
|
||||
return CurDAG->getTargetConstant(4 * N->getZExtValue(), SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
def VecIndex_x8 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(8 * N->getZExtValue(), MVT::i64);
|
||||
return CurDAG->getTargetConstant(8 * N->getZExtValue(), SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
multiclass DUPWithTruncPats<ValueType ResVT, ValueType Src64VT,
|
||||
|
|
|
@ -83,8 +83,8 @@ public:
|
|||
|
||||
/// getI32Imm - Return a target constant of type i32 with the specified
|
||||
/// value.
|
||||
inline SDValue getI32Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
inline SDValue getI32Imm(unsigned Imm, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i32);
|
||||
}
|
||||
|
||||
SDNode *Select(SDNode *N) override;
|
||||
|
@ -134,7 +134,7 @@ public:
|
|||
|
||||
bool SelectCMOVPred(SDValue N, SDValue &Pred, SDValue &Reg) {
|
||||
const ConstantSDNode *CN = cast<ConstantSDNode>(N);
|
||||
Pred = CurDAG->getTargetConstant(CN->getZExtValue(), MVT::i32);
|
||||
Pred = CurDAG->getTargetConstant(CN->getZExtValue(), SDLoc(N), MVT::i32);
|
||||
Reg = CurDAG->getRegister(ARM::CPSR, MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
@ -272,7 +272,8 @@ private:
|
|||
SDNode *createQuadQRegsNode(EVT VT, SDValue V0, SDValue V1, SDValue V2, SDValue V3);
|
||||
|
||||
// Get the alignment operand for a NEON VLD or VST instruction.
|
||||
SDValue GetVLDSTAlign(SDValue Align, unsigned NumVecs, bool is64BitVector);
|
||||
SDValue GetVLDSTAlign(SDValue Align, SDLoc dl, unsigned NumVecs,
|
||||
bool is64BitVector);
|
||||
};
|
||||
}
|
||||
|
||||
|
@ -394,11 +395,13 @@ void ARMDAGToDAGISel::PreprocessISelDAG() {
|
|||
// Now make the transformation.
|
||||
Srl = CurDAG->getNode(ISD::SRL, SDLoc(Srl), MVT::i32,
|
||||
Srl.getOperand(0),
|
||||
CurDAG->getConstant(Srl_imm+TZ, MVT::i32));
|
||||
CurDAG->getConstant(Srl_imm + TZ, SDLoc(Srl),
|
||||
MVT::i32));
|
||||
N1 = CurDAG->getNode(ISD::AND, SDLoc(N1), MVT::i32,
|
||||
Srl, CurDAG->getConstant(And_imm, MVT::i32));
|
||||
Srl,
|
||||
CurDAG->getConstant(And_imm, SDLoc(Srl), MVT::i32));
|
||||
N1 = CurDAG->getNode(ISD::SHL, SDLoc(N1), MVT::i32,
|
||||
N1, CurDAG->getConstant(TZ, MVT::i32));
|
||||
N1, CurDAG->getConstant(TZ, SDLoc(Srl), MVT::i32));
|
||||
CurDAG->UpdateNodeOperands(N, N0, N1);
|
||||
}
|
||||
}
|
||||
|
@ -483,7 +486,7 @@ bool ARMDAGToDAGISel::SelectImmShifterOperand(SDValue N,
|
|||
if (!RHS) return false;
|
||||
ShImmVal = RHS->getZExtValue() & 31;
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getSORegOpc(ShOpcVal, ShImmVal),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -510,7 +513,7 @@ bool ARMDAGToDAGISel::SelectRegShifterOperand(SDValue N,
|
|||
if (CheckProfitability && !isShifterOpProfitable(N, ShOpcVal, ShImmVal))
|
||||
return false;
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getSORegOpc(ShOpcVal, ShImmVal),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -527,7 +530,7 @@ bool ARMDAGToDAGISel::SelectAddrModeImm12(SDValue N,
|
|||
// Match frame index.
|
||||
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -536,7 +539,7 @@ bool ARMDAGToDAGISel::SelectAddrModeImm12(SDValue N,
|
|||
Base = N.getOperand(0);
|
||||
} else
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -551,14 +554,14 @@ bool ARMDAGToDAGISel::SelectAddrModeImm12(SDValue N,
|
|||
int FI = cast<FrameIndexSDNode>(Base)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// Base only.
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -583,7 +586,7 @@ bool ARMDAGToDAGISel::SelectLdStSOReg(SDValue N, SDValue &Base, SDValue &Offset,
|
|||
Base = Offset = N.getOperand(0);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, ShAmt,
|
||||
ARM_AM::lsl),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -654,7 +657,7 @@ bool ARMDAGToDAGISel::SelectLdStSOReg(SDValue N, SDValue &Base, SDValue &Offset,
|
|||
}
|
||||
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, ShAmt, ShOpcVal),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -682,7 +685,7 @@ AddrMode2Type ARMDAGToDAGISel::SelectAddrMode2Worker(SDValue N,
|
|||
Base = Offset = N.getOperand(0);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, ShAmt,
|
||||
ARM_AM::lsl),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return AM2_SHOP;
|
||||
}
|
||||
}
|
||||
|
@ -703,7 +706,7 @@ AddrMode2Type ARMDAGToDAGISel::SelectAddrMode2Worker(SDValue N,
|
|||
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(ARM_AM::add, 0,
|
||||
ARM_AM::no_shift),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return AM2_BASE;
|
||||
}
|
||||
|
||||
|
@ -726,7 +729,7 @@ AddrMode2Type ARMDAGToDAGISel::SelectAddrMode2Worker(SDValue N,
|
|||
}
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, RHSC,
|
||||
ARM_AM::no_shift),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return AM2_BASE;
|
||||
}
|
||||
}
|
||||
|
@ -737,7 +740,7 @@ AddrMode2Type ARMDAGToDAGISel::SelectAddrMode2Worker(SDValue N,
|
|||
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(ARM_AM::add, 0,
|
||||
ARM_AM::no_shift),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return AM2_BASE;
|
||||
}
|
||||
|
||||
|
@ -792,7 +795,7 @@ AddrMode2Type ARMDAGToDAGISel::SelectAddrMode2Worker(SDValue N,
|
|||
}
|
||||
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, ShAmt, ShOpcVal),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return AM2_SHOP;
|
||||
}
|
||||
|
||||
|
@ -828,7 +831,7 @@ bool ARMDAGToDAGISel::SelectAddrMode2OffsetReg(SDNode *Op, SDValue N,
|
|||
}
|
||||
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, ShAmt, ShOpcVal),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -844,7 +847,7 @@ bool ARMDAGToDAGISel::SelectAddrMode2OffsetImmPre(SDNode *Op, SDValue N,
|
|||
if (isScaledConstantInRange(N, /*Scale=*/1, 0, 0x1000, Val)) { // 12 bits.
|
||||
if (AddSub == ARM_AM::sub) Val *= -1;
|
||||
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(Val, SDLoc(Op), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -865,7 +868,7 @@ bool ARMDAGToDAGISel::SelectAddrMode2OffsetImm(SDNode *Op, SDValue N,
|
|||
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM2Opc(AddSub, Val,
|
||||
ARM_AM::no_shift),
|
||||
MVT::i32);
|
||||
SDLoc(Op), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -884,7 +887,8 @@ bool ARMDAGToDAGISel::SelectAddrMode3(SDValue N,
|
|||
// X - C is canonicalize to X + -C, no need to handle it here.
|
||||
Base = N.getOperand(0);
|
||||
Offset = N.getOperand(1);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(ARM_AM::sub, 0),MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(ARM_AM::sub, 0), SDLoc(N),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -895,7 +899,8 @@ bool ARMDAGToDAGISel::SelectAddrMode3(SDValue N,
|
|||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(ARM_AM::add, 0),MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(ARM_AM::add, 0), SDLoc(N),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -915,13 +920,15 @@ bool ARMDAGToDAGISel::SelectAddrMode3(SDValue N,
|
|||
AddSub = ARM_AM::sub;
|
||||
RHSC = -RHSC;
|
||||
}
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(AddSub, RHSC),MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(AddSub, RHSC), SDLoc(N),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
Base = N.getOperand(0);
|
||||
Offset = N.getOperand(1);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(ARM_AM::add, 0), MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(ARM_AM::add, 0), SDLoc(N),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -936,12 +943,14 @@ bool ARMDAGToDAGISel::SelectAddrMode3Offset(SDNode *Op, SDValue N,
|
|||
int Val;
|
||||
if (isScaledConstantInRange(N, /*Scale=*/1, 0, 256, Val)) { // 12 bits.
|
||||
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(AddSub, Val), MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(AddSub, Val), SDLoc(Op),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
Offset = N;
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(AddSub, 0), MVT::i32);
|
||||
Opc = CurDAG->getTargetConstant(ARM_AM::getAM3Opc(AddSub, 0), SDLoc(Op),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -957,7 +966,7 @@ bool ARMDAGToDAGISel::SelectAddrMode5(SDValue N,
|
|||
Base = N.getOperand(0);
|
||||
}
|
||||
Offset = CurDAG->getTargetConstant(ARM_AM::getAM5Opc(ARM_AM::add, 0),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -977,13 +986,13 @@ bool ARMDAGToDAGISel::SelectAddrMode5(SDValue N,
|
|||
RHSC = -RHSC;
|
||||
}
|
||||
Offset = CurDAG->getTargetConstant(ARM_AM::getAM5Opc(AddSub, RHSC),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
Base = N;
|
||||
Offset = CurDAG->getTargetConstant(ARM_AM::getAM5Opc(ARM_AM::add, 0),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1012,7 +1021,7 @@ bool ARMDAGToDAGISel::SelectAddrMode6(SDNode *Parent, SDValue N, SDValue &Addr,
|
|||
Alignment = MemN->getAlignment();
|
||||
}
|
||||
|
||||
Align = CurDAG->getTargetConstant(Alignment, MVT::i32);
|
||||
Align = CurDAG->getTargetConstant(Alignment, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1036,7 +1045,7 @@ bool ARMDAGToDAGISel::SelectAddrModePC(SDValue N,
|
|||
Offset = N.getOperand(0);
|
||||
SDValue N1 = N.getOperand(1);
|
||||
Label = CurDAG->getTargetConstant(cast<ConstantSDNode>(N1)->getZExtValue(),
|
||||
MVT::i32);
|
||||
SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1141,7 +1150,7 @@ ARMDAGToDAGISel::SelectThumbAddrModeImm5S(SDValue N, unsigned Scale,
|
|||
Base = N;
|
||||
}
|
||||
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1158,7 +1167,7 @@ ARMDAGToDAGISel::SelectThumbAddrModeImm5S(SDValue N, unsigned Scale,
|
|||
if (LHSC != 0 || RHSC != 0) return false;
|
||||
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1166,12 +1175,12 @@ ARMDAGToDAGISel::SelectThumbAddrModeImm5S(SDValue N, unsigned Scale,
|
|||
int RHSC;
|
||||
if (isScaledConstantInRange(N.getOperand(1), Scale, 0, 32, RHSC)) {
|
||||
Base = N.getOperand(0);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
Base = N.getOperand(0);
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1203,7 +1212,7 @@ bool ARMDAGToDAGISel::SelectThumbAddrModeSP(SDValue N,
|
|||
if (MFI->getObjectAlignment(FI) < 4)
|
||||
MFI->setObjectAlignment(FI, 4);
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1226,7 +1235,7 @@ bool ARMDAGToDAGISel::SelectThumbAddrModeSP(SDValue N,
|
|||
MFI->setObjectAlignment(FI, 4);
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -1255,7 +1264,7 @@ bool ARMDAGToDAGISel::SelectT2ShifterOperandReg(SDValue N, SDValue &BaseReg,
|
|||
unsigned ShImmVal = 0;
|
||||
if (ConstantSDNode *RHS = dyn_cast<ConstantSDNode>(N.getOperand(1))) {
|
||||
ShImmVal = RHS->getZExtValue() & 31;
|
||||
Opc = getI32Imm(ARM_AM::getSORegOpc(ShOpcVal, ShImmVal));
|
||||
Opc = getI32Imm(ARM_AM::getSORegOpc(ShOpcVal, ShImmVal), SDLoc(N));
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1273,7 +1282,7 @@ bool ARMDAGToDAGISel::SelectT2AddrModeImm12(SDValue N,
|
|||
// Match frame index.
|
||||
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1284,7 +1293,7 @@ bool ARMDAGToDAGISel::SelectT2AddrModeImm12(SDValue N,
|
|||
return false; // We want to select t2LDRpci instead.
|
||||
} else
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1303,14 +1312,14 @@ bool ARMDAGToDAGISel::SelectT2AddrModeImm12(SDValue N,
|
|||
int FI = cast<FrameIndexSDNode>(Base)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// Base only.
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1332,7 +1341,7 @@ bool ARMDAGToDAGISel::SelectT2AddrModeImm8(SDValue N,
|
|||
int FI = cast<FrameIndexSDNode>(Base)->getIndex();
|
||||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -1349,8 +1358,8 @@ bool ARMDAGToDAGISel::SelectT2AddrModeImm8Offset(SDNode *Op, SDValue N,
|
|||
int RHSC;
|
||||
if (isScaledConstantInRange(N, /*Scale=*/1, 0, 0x100, RHSC)) { // 8 bits.
|
||||
OffImm = ((AM == ISD::PRE_INC) || (AM == ISD::POST_INC))
|
||||
? CurDAG->getTargetConstant(RHSC, MVT::i32)
|
||||
: CurDAG->getTargetConstant(-RHSC, MVT::i32);
|
||||
? CurDAG->getTargetConstant(RHSC, SDLoc(N), MVT::i32)
|
||||
: CurDAG->getTargetConstant(-RHSC, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1399,7 +1408,7 @@ bool ARMDAGToDAGISel::SelectT2AddrModeSoReg(SDValue N,
|
|||
}
|
||||
}
|
||||
|
||||
ShImm = CurDAG->getTargetConstant(ShAmt, MVT::i32);
|
||||
ShImm = CurDAG->getTargetConstant(ShAmt, SDLoc(N), MVT::i32);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -1409,7 +1418,7 @@ bool ARMDAGToDAGISel::SelectT2AddrModeExclusive(SDValue N, SDValue &Base,
|
|||
// This *must* succeed since it's used for the irreplaceable ldrex and strex
|
||||
// instructions.
|
||||
Base = N;
|
||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
|
||||
if (N.getOpcode() != ISD::ADD || !CurDAG->isBaseWithConstantOffset(N))
|
||||
return true;
|
||||
|
@ -1428,15 +1437,15 @@ bool ARMDAGToDAGISel::SelectT2AddrModeExclusive(SDValue N, SDValue &Base,
|
|||
Base = CurDAG->getTargetFrameIndex(FI, TLI->getPointerTy());
|
||||
}
|
||||
|
||||
OffImm = CurDAG->getTargetConstant(RHSC / 4, MVT::i32);
|
||||
OffImm = CurDAG->getTargetConstant(RHSC/4, SDLoc(N), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
//===--------------------------------------------------------------------===//
|
||||
|
||||
/// getAL - Returns a ARMCC::AL immediate node.
|
||||
static inline SDValue getAL(SelectionDAG *CurDAG) {
|
||||
return CurDAG->getTargetConstant((uint64_t)ARMCC::AL, MVT::i32);
|
||||
static inline SDValue getAL(SelectionDAG *CurDAG, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant((uint64_t)ARMCC::AL, dl, MVT::i32);
|
||||
}
|
||||
|
||||
SDNode *ARMDAGToDAGISel::SelectARMIndexedLoad(SDNode *N) {
|
||||
|
@ -1495,14 +1504,14 @@ SDNode *ARMDAGToDAGISel::SelectARMIndexedLoad(SDNode *N) {
|
|||
if (Opcode == ARM::LDR_PRE_IMM || Opcode == ARM::LDRB_PRE_IMM) {
|
||||
SDValue Chain = LD->getChain();
|
||||
SDValue Base = LD->getBasePtr();
|
||||
SDValue Ops[]= { Base, AMOpc, getAL(CurDAG),
|
||||
SDValue Ops[]= { Base, AMOpc, getAL(CurDAG, SDLoc(N)),
|
||||
CurDAG->getRegister(0, MVT::i32), Chain };
|
||||
return CurDAG->getMachineNode(Opcode, SDLoc(N), MVT::i32,
|
||||
MVT::i32, MVT::Other, Ops);
|
||||
} else {
|
||||
SDValue Chain = LD->getChain();
|
||||
SDValue Base = LD->getBasePtr();
|
||||
SDValue Ops[]= { Base, Offset, AMOpc, getAL(CurDAG),
|
||||
SDValue Ops[]= { Base, Offset, AMOpc, getAL(CurDAG, SDLoc(N)),
|
||||
CurDAG->getRegister(0, MVT::i32), Chain };
|
||||
return CurDAG->getMachineNode(Opcode, SDLoc(N), MVT::i32,
|
||||
MVT::i32, MVT::Other, Ops);
|
||||
|
@ -1551,7 +1560,7 @@ SDNode *ARMDAGToDAGISel::SelectT2IndexedLoad(SDNode *N) {
|
|||
if (Match) {
|
||||
SDValue Chain = LD->getChain();
|
||||
SDValue Base = LD->getBasePtr();
|
||||
SDValue Ops[]= { Base, Offset, getAL(CurDAG),
|
||||
SDValue Ops[]= { Base, Offset, getAL(CurDAG, SDLoc(N)),
|
||||
CurDAG->getRegister(0, MVT::i32), Chain };
|
||||
return CurDAG->getMachineNode(Opcode, SDLoc(N), MVT::i32, MVT::i32,
|
||||
MVT::Other, Ops);
|
||||
|
@ -1564,9 +1573,9 @@ SDNode *ARMDAGToDAGISel::SelectT2IndexedLoad(SDNode *N) {
|
|||
SDNode *ARMDAGToDAGISel::createGPRPairNode(EVT VT, SDValue V0, SDValue V1) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass =
|
||||
CurDAG->getTargetConstant(ARM::GPRPairRegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::gsub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::gsub_1, MVT::i32);
|
||||
CurDAG->getTargetConstant(ARM::GPRPairRegClassID, dl, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::gsub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::gsub_1, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
}
|
||||
|
@ -1575,9 +1584,9 @@ SDNode *ARMDAGToDAGISel::createGPRPairNode(EVT VT, SDValue V0, SDValue V1) {
|
|||
SDNode *ARMDAGToDAGISel::createSRegPairNode(EVT VT, SDValue V0, SDValue V1) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass =
|
||||
CurDAG->getTargetConstant(ARM::DPR_VFP2RegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::ssub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::ssub_1, MVT::i32);
|
||||
CurDAG->getTargetConstant(ARM::DPR_VFP2RegClassID, dl, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::ssub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::ssub_1, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
}
|
||||
|
@ -1585,9 +1594,10 @@ SDNode *ARMDAGToDAGISel::createSRegPairNode(EVT VT, SDValue V0, SDValue V1) {
|
|||
/// \brief Form a quad register from a pair of D registers.
|
||||
SDNode *ARMDAGToDAGISel::createDRegPairNode(EVT VT, SDValue V0, SDValue V1) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QPRRegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::dsub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::dsub_1, MVT::i32);
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QPRRegClassID, dl,
|
||||
MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::dsub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::dsub_1, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
}
|
||||
|
@ -1595,9 +1605,10 @@ SDNode *ARMDAGToDAGISel::createDRegPairNode(EVT VT, SDValue V0, SDValue V1) {
|
|||
/// \brief Form 4 consecutive D registers from a pair of Q registers.
|
||||
SDNode *ARMDAGToDAGISel::createQRegPairNode(EVT VT, SDValue V0, SDValue V1) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QQPRRegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::qsub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::qsub_1, MVT::i32);
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QQPRRegClassID, dl,
|
||||
MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::qsub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::qsub_1, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
}
|
||||
|
@ -1607,11 +1618,11 @@ SDNode *ARMDAGToDAGISel::createQuadSRegsNode(EVT VT, SDValue V0, SDValue V1,
|
|||
SDValue V2, SDValue V3) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass =
|
||||
CurDAG->getTargetConstant(ARM::QPR_VFP2RegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::ssub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::ssub_1, MVT::i32);
|
||||
SDValue SubReg2 = CurDAG->getTargetConstant(ARM::ssub_2, MVT::i32);
|
||||
SDValue SubReg3 = CurDAG->getTargetConstant(ARM::ssub_3, MVT::i32);
|
||||
CurDAG->getTargetConstant(ARM::QPR_VFP2RegClassID, dl, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::ssub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::ssub_1, dl, MVT::i32);
|
||||
SDValue SubReg2 = CurDAG->getTargetConstant(ARM::ssub_2, dl, MVT::i32);
|
||||
SDValue SubReg3 = CurDAG->getTargetConstant(ARM::ssub_3, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1,
|
||||
V2, SubReg2, V3, SubReg3 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
|
@ -1621,11 +1632,12 @@ SDNode *ARMDAGToDAGISel::createQuadSRegsNode(EVT VT, SDValue V0, SDValue V1,
|
|||
SDNode *ARMDAGToDAGISel::createQuadDRegsNode(EVT VT, SDValue V0, SDValue V1,
|
||||
SDValue V2, SDValue V3) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QQPRRegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::dsub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::dsub_1, MVT::i32);
|
||||
SDValue SubReg2 = CurDAG->getTargetConstant(ARM::dsub_2, MVT::i32);
|
||||
SDValue SubReg3 = CurDAG->getTargetConstant(ARM::dsub_3, MVT::i32);
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QQPRRegClassID, dl,
|
||||
MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::dsub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::dsub_1, dl, MVT::i32);
|
||||
SDValue SubReg2 = CurDAG->getTargetConstant(ARM::dsub_2, dl, MVT::i32);
|
||||
SDValue SubReg3 = CurDAG->getTargetConstant(ARM::dsub_3, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1,
|
||||
V2, SubReg2, V3, SubReg3 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
|
@ -1635,11 +1647,12 @@ SDNode *ARMDAGToDAGISel::createQuadDRegsNode(EVT VT, SDValue V0, SDValue V1,
|
|||
SDNode *ARMDAGToDAGISel::createQuadQRegsNode(EVT VT, SDValue V0, SDValue V1,
|
||||
SDValue V2, SDValue V3) {
|
||||
SDLoc dl(V0.getNode());
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QQQQPRRegClassID, MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::qsub_0, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::qsub_1, MVT::i32);
|
||||
SDValue SubReg2 = CurDAG->getTargetConstant(ARM::qsub_2, MVT::i32);
|
||||
SDValue SubReg3 = CurDAG->getTargetConstant(ARM::qsub_3, MVT::i32);
|
||||
SDValue RegClass = CurDAG->getTargetConstant(ARM::QQQQPRRegClassID, dl,
|
||||
MVT::i32);
|
||||
SDValue SubReg0 = CurDAG->getTargetConstant(ARM::qsub_0, dl, MVT::i32);
|
||||
SDValue SubReg1 = CurDAG->getTargetConstant(ARM::qsub_1, dl, MVT::i32);
|
||||
SDValue SubReg2 = CurDAG->getTargetConstant(ARM::qsub_2, dl, MVT::i32);
|
||||
SDValue SubReg3 = CurDAG->getTargetConstant(ARM::qsub_3, dl, MVT::i32);
|
||||
const SDValue Ops[] = { RegClass, V0, SubReg0, V1, SubReg1,
|
||||
V2, SubReg2, V3, SubReg3 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, dl, VT, Ops);
|
||||
|
@ -1648,8 +1661,8 @@ SDNode *ARMDAGToDAGISel::createQuadQRegsNode(EVT VT, SDValue V0, SDValue V1,
|
|||
/// GetVLDSTAlign - Get the alignment (in bytes) for the alignment operand
|
||||
/// of a NEON VLD or VST instruction. The supported values depend on the
|
||||
/// number of registers being loaded.
|
||||
SDValue ARMDAGToDAGISel::GetVLDSTAlign(SDValue Align, unsigned NumVecs,
|
||||
bool is64BitVector) {
|
||||
SDValue ARMDAGToDAGISel::GetVLDSTAlign(SDValue Align, SDLoc dl,
|
||||
unsigned NumVecs, bool is64BitVector) {
|
||||
unsigned NumRegs = NumVecs;
|
||||
if (!is64BitVector && NumVecs < 3)
|
||||
NumRegs *= 2;
|
||||
|
@ -1664,7 +1677,7 @@ SDValue ARMDAGToDAGISel::GetVLDSTAlign(SDValue Align, unsigned NumVecs,
|
|||
else
|
||||
Alignment = 0;
|
||||
|
||||
return CurDAG->getTargetConstant(Alignment, MVT::i32);
|
||||
return CurDAG->getTargetConstant(Alignment, dl, MVT::i32);
|
||||
}
|
||||
|
||||
static bool isVLDfixed(unsigned Opc)
|
||||
|
@ -1784,7 +1797,7 @@ SDNode *ARMDAGToDAGISel::SelectVLD(SDNode *N, bool isUpdating, unsigned NumVecs,
|
|||
SDValue Chain = N->getOperand(0);
|
||||
EVT VT = N->getValueType(0);
|
||||
bool is64BitVector = VT.is64BitVector();
|
||||
Align = GetVLDSTAlign(Align, NumVecs, is64BitVector);
|
||||
Align = GetVLDSTAlign(Align, dl, NumVecs, is64BitVector);
|
||||
|
||||
unsigned OpcodeIndex;
|
||||
switch (VT.getSimpleVT().SimpleTy) {
|
||||
|
@ -1821,7 +1834,7 @@ SDNode *ARMDAGToDAGISel::SelectVLD(SDNode *N, bool isUpdating, unsigned NumVecs,
|
|||
ResTys.push_back(MVT::i32);
|
||||
ResTys.push_back(MVT::Other);
|
||||
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
SDNode *VLd;
|
||||
SmallVector<SDValue, 7> Ops;
|
||||
|
@ -1921,7 +1934,7 @@ SDNode *ARMDAGToDAGISel::SelectVST(SDNode *N, bool isUpdating, unsigned NumVecs,
|
|||
SDValue Chain = N->getOperand(0);
|
||||
EVT VT = N->getOperand(Vec0Idx).getValueType();
|
||||
bool is64BitVector = VT.is64BitVector();
|
||||
Align = GetVLDSTAlign(Align, NumVecs, is64BitVector);
|
||||
Align = GetVLDSTAlign(Align, dl, NumVecs, is64BitVector);
|
||||
|
||||
unsigned OpcodeIndex;
|
||||
switch (VT.getSimpleVT().SimpleTy) {
|
||||
|
@ -1948,7 +1961,7 @@ SDNode *ARMDAGToDAGISel::SelectVST(SDNode *N, bool isUpdating, unsigned NumVecs,
|
|||
ResTys.push_back(MVT::i32);
|
||||
ResTys.push_back(MVT::Other);
|
||||
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
SmallVector<SDValue, 7> Ops;
|
||||
|
||||
|
@ -2084,7 +2097,7 @@ SDNode *ARMDAGToDAGISel::SelectVLDSTLane(SDNode *N, bool IsLoad,
|
|||
if (Alignment == 1)
|
||||
Alignment = 0;
|
||||
}
|
||||
Align = CurDAG->getTargetConstant(Alignment, MVT::i32);
|
||||
Align = CurDAG->getTargetConstant(Alignment, dl, MVT::i32);
|
||||
|
||||
unsigned OpcodeIndex;
|
||||
switch (VT.getSimpleVT().SimpleTy) {
|
||||
|
@ -2112,7 +2125,7 @@ SDNode *ARMDAGToDAGISel::SelectVLDSTLane(SDNode *N, bool IsLoad,
|
|||
ResTys.push_back(MVT::i32);
|
||||
ResTys.push_back(MVT::Other);
|
||||
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
|
||||
SmallVector<SDValue, 8> Ops;
|
||||
|
@ -2142,7 +2155,7 @@ SDNode *ARMDAGToDAGISel::SelectVLDSTLane(SDNode *N, bool IsLoad,
|
|||
SuperReg = SDValue(createQuadQRegsNode(MVT::v8i64, V0, V1, V2, V3), 0);
|
||||
}
|
||||
Ops.push_back(SuperReg);
|
||||
Ops.push_back(getI32Imm(Lane));
|
||||
Ops.push_back(getI32Imm(Lane, dl));
|
||||
Ops.push_back(Pred);
|
||||
Ops.push_back(Reg0);
|
||||
Ops.push_back(Chain);
|
||||
|
@ -2197,7 +2210,7 @@ SDNode *ARMDAGToDAGISel::SelectVLDDup(SDNode *N, bool isUpdating,
|
|||
if (Alignment == 1)
|
||||
Alignment = 0;
|
||||
}
|
||||
Align = CurDAG->getTargetConstant(Alignment, MVT::i32);
|
||||
Align = CurDAG->getTargetConstant(Alignment, dl, MVT::i32);
|
||||
|
||||
unsigned OpcodeIndex;
|
||||
switch (VT.getSimpleVT().SimpleTy) {
|
||||
|
@ -2208,7 +2221,7 @@ SDNode *ARMDAGToDAGISel::SelectVLDDup(SDNode *N, bool isUpdating,
|
|||
case MVT::v2i32: OpcodeIndex = 2; break;
|
||||
}
|
||||
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue SuperReg;
|
||||
unsigned Opc = Opcodes[OpcodeIndex];
|
||||
|
@ -2279,7 +2292,7 @@ SDNode *ARMDAGToDAGISel::SelectVTBL(SDNode *N, bool IsExt, unsigned NumVecs,
|
|||
Ops.push_back(N->getOperand(1));
|
||||
Ops.push_back(RegSeq);
|
||||
Ops.push_back(N->getOperand(FirstTblReg + NumVecs));
|
||||
Ops.push_back(getAL(CurDAG)); // predicate
|
||||
Ops.push_back(getAL(CurDAG, dl)); // predicate
|
||||
Ops.push_back(CurDAG->getRegister(0, MVT::i32)); // predicate register
|
||||
return CurDAG->getMachineNode(Opc, dl, VT, Ops);
|
||||
}
|
||||
|
@ -2292,6 +2305,7 @@ SDNode *ARMDAGToDAGISel::SelectV6T2BitfieldExtractOp(SDNode *N,
|
|||
unsigned Opc = isSigned
|
||||
? (Subtarget->isThumb() ? ARM::t2SBFX : ARM::SBFX)
|
||||
: (Subtarget->isThumb() ? ARM::t2UBFX : ARM::UBFX);
|
||||
SDLoc dl(N);
|
||||
|
||||
// For unsigned extracts, check for a shift right and mask
|
||||
unsigned And_imm = 0;
|
||||
|
@ -2318,25 +2332,25 @@ SDNode *ARMDAGToDAGISel::SelectV6T2BitfieldExtractOp(SDNode *N,
|
|||
if (Subtarget->isThumb()) {
|
||||
Opc = isSigned ? ARM::t2ASRri : ARM::t2LSRri;
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
CurDAG->getTargetConstant(LSB, MVT::i32),
|
||||
getAL(CurDAG), Reg0, Reg0 };
|
||||
CurDAG->getTargetConstant(LSB, dl, MVT::i32),
|
||||
getAL(CurDAG, dl), Reg0, Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, Opc, MVT::i32, Ops);
|
||||
}
|
||||
|
||||
// ARM models shift instructions as MOVsi with shifter operand.
|
||||
ARM_AM::ShiftOpc ShOpcVal = ARM_AM::getShiftOpcForNode(ISD::SRL);
|
||||
SDValue ShOpc =
|
||||
CurDAG->getTargetConstant(ARM_AM::getSORegOpc(ShOpcVal, LSB),
|
||||
CurDAG->getTargetConstant(ARM_AM::getSORegOpc(ShOpcVal, LSB), dl,
|
||||
MVT::i32);
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0), ShOpc,
|
||||
getAL(CurDAG), Reg0, Reg0 };
|
||||
getAL(CurDAG, dl), Reg0, Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, ARM::MOVsi, MVT::i32, Ops);
|
||||
}
|
||||
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
CurDAG->getTargetConstant(LSB, MVT::i32),
|
||||
CurDAG->getTargetConstant(Width, MVT::i32),
|
||||
getAL(CurDAG), Reg0 };
|
||||
CurDAG->getTargetConstant(LSB, dl, MVT::i32),
|
||||
CurDAG->getTargetConstant(Width, dl, MVT::i32),
|
||||
getAL(CurDAG, dl), Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, Opc, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2357,9 +2371,9 @@ SDNode *ARMDAGToDAGISel::SelectV6T2BitfieldExtractOp(SDNode *N,
|
|||
return nullptr;
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
CurDAG->getTargetConstant(LSB, MVT::i32),
|
||||
CurDAG->getTargetConstant(Width, MVT::i32),
|
||||
getAL(CurDAG), Reg0 };
|
||||
CurDAG->getTargetConstant(LSB, dl, MVT::i32),
|
||||
CurDAG->getTargetConstant(Width, dl, MVT::i32),
|
||||
getAL(CurDAG, dl), Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, Opc, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2376,9 +2390,9 @@ SDNode *ARMDAGToDAGISel::SelectV6T2BitfieldExtractOp(SDNode *N,
|
|||
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
CurDAG->getTargetConstant(LSB, MVT::i32),
|
||||
CurDAG->getTargetConstant(Width - 1, MVT::i32),
|
||||
getAL(CurDAG), Reg0 };
|
||||
CurDAG->getTargetConstant(LSB, dl, MVT::i32),
|
||||
CurDAG->getTargetConstant(Width - 1, dl, MVT::i32),
|
||||
getAL(CurDAG, dl), Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, Opc, MVT::i32, Ops);
|
||||
}
|
||||
|
||||
|
@ -2484,7 +2498,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
|
||||
SDNode *ResNode;
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue PredReg = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue Ops[] = { CPIdx, Pred, PredReg, CurDAG->getEntryNode() };
|
||||
ResNode = CurDAG->getMachineNode(ARM::tLDRpci, dl, MVT::i32, MVT::Other,
|
||||
|
@ -2492,8 +2506,8 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
} else {
|
||||
SDValue Ops[] = {
|
||||
CPIdx,
|
||||
CurDAG->getTargetConstant(0, MVT::i32),
|
||||
getAL(CurDAG),
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i32),
|
||||
getAL(CurDAG, dl),
|
||||
CurDAG->getRegister(0, MVT::i32),
|
||||
CurDAG->getEntryNode()
|
||||
};
|
||||
|
@ -2518,12 +2532,12 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
if (MFI->getObjectAlignment(FI) < 4)
|
||||
MFI->setObjectAlignment(FI, 4);
|
||||
return CurDAG->SelectNodeTo(N, ARM::tADDframe, MVT::i32, TFI,
|
||||
CurDAG->getTargetConstant(0, MVT::i32));
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i32));
|
||||
} else {
|
||||
unsigned Opc = ((Subtarget->isThumb() && Subtarget->hasThumb2()) ?
|
||||
ARM::t2ADDri : ARM::ADDri);
|
||||
SDValue Ops[] = { TFI, CurDAG->getTargetConstant(0, MVT::i32),
|
||||
getAL(CurDAG), CurDAG->getRegister(0, MVT::i32),
|
||||
SDValue Ops[] = { TFI, CurDAG->getTargetConstant(0, dl, MVT::i32),
|
||||
getAL(CurDAG, dl), CurDAG->getRegister(0, MVT::i32),
|
||||
CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->SelectNodeTo(N, Opc, MVT::i32, Ops);
|
||||
}
|
||||
|
@ -2549,13 +2563,14 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
break;
|
||||
SDValue V = N->getOperand(0);
|
||||
ShImm = ARM_AM::getSORegOpc(ARM_AM::lsl, ShImm);
|
||||
SDValue ShImmOp = CurDAG->getTargetConstant(ShImm, MVT::i32);
|
||||
SDValue ShImmOp = CurDAG->getTargetConstant(ShImm, dl, MVT::i32);
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Ops[] = { V, V, ShImmOp, getAL(CurDAG), Reg0, Reg0 };
|
||||
SDValue Ops[] = { V, V, ShImmOp, getAL(CurDAG, dl), Reg0, Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, ARM::t2ADDrs, MVT::i32, Ops);
|
||||
} else {
|
||||
SDValue Ops[] = { V, V, Reg0, ShImmOp, getAL(CurDAG), Reg0, Reg0 };
|
||||
SDValue Ops[] = { V, V, Reg0, ShImmOp, getAL(CurDAG, dl), Reg0,
|
||||
Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, ARM::ADDrsi, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2565,13 +2580,14 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
break;
|
||||
SDValue V = N->getOperand(0);
|
||||
ShImm = ARM_AM::getSORegOpc(ARM_AM::lsl, ShImm);
|
||||
SDValue ShImmOp = CurDAG->getTargetConstant(ShImm, MVT::i32);
|
||||
SDValue ShImmOp = CurDAG->getTargetConstant(ShImm, dl, MVT::i32);
|
||||
SDValue Reg0 = CurDAG->getRegister(0, MVT::i32);
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Ops[] = { V, V, ShImmOp, getAL(CurDAG), Reg0, Reg0 };
|
||||
SDValue Ops[] = { V, V, ShImmOp, getAL(CurDAG, dl), Reg0, Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, ARM::t2RSBrs, MVT::i32, Ops);
|
||||
} else {
|
||||
SDValue Ops[] = { V, V, Reg0, ShImmOp, getAL(CurDAG), Reg0, Reg0 };
|
||||
SDValue Ops[] = { V, V, Reg0, ShImmOp, getAL(CurDAG, dl), Reg0,
|
||||
Reg0 };
|
||||
return CurDAG->SelectNodeTo(N, ARM::RSBrsi, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2610,9 +2626,9 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
(N1CVal & 0xffffU) == 0xffffU &&
|
||||
(N2CVal & 0xffffU) == 0x0U) {
|
||||
SDValue Imm16 = CurDAG->getTargetConstant((N2CVal & 0xFFFF0000U) >> 16,
|
||||
MVT::i32);
|
||||
dl, MVT::i32);
|
||||
SDValue Ops[] = { N0.getOperand(0), Imm16,
|
||||
getAL(CurDAG), CurDAG->getRegister(0, MVT::i32) };
|
||||
getAL(CurDAG, dl), CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(Opc, dl, VT, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2620,18 +2636,18 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
}
|
||||
case ARMISD::VMOVRRD:
|
||||
return CurDAG->getMachineNode(ARM::VMOVRRD, dl, MVT::i32, MVT::i32,
|
||||
N->getOperand(0), getAL(CurDAG),
|
||||
N->getOperand(0), getAL(CurDAG, dl),
|
||||
CurDAG->getRegister(0, MVT::i32));
|
||||
case ISD::UMUL_LOHI: {
|
||||
if (Subtarget->isThumb1Only())
|
||||
break;
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1),
|
||||
getAL(CurDAG), CurDAG->getRegister(0, MVT::i32) };
|
||||
getAL(CurDAG, dl), CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(ARM::t2UMULL, dl, MVT::i32, MVT::i32, Ops);
|
||||
} else {
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1),
|
||||
getAL(CurDAG), CurDAG->getRegister(0, MVT::i32),
|
||||
getAL(CurDAG, dl), CurDAG->getRegister(0, MVT::i32),
|
||||
CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(Subtarget->hasV6Ops() ?
|
||||
ARM::UMULL : ARM::UMULLv5,
|
||||
|
@ -2643,11 +2659,11 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
break;
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1),
|
||||
getAL(CurDAG), CurDAG->getRegister(0, MVT::i32) };
|
||||
getAL(CurDAG, dl), CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(ARM::t2SMULL, dl, MVT::i32, MVT::i32, Ops);
|
||||
} else {
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1),
|
||||
getAL(CurDAG), CurDAG->getRegister(0, MVT::i32),
|
||||
getAL(CurDAG, dl), CurDAG->getRegister(0, MVT::i32),
|
||||
CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(Subtarget->hasV6Ops() ?
|
||||
ARM::SMULL : ARM::SMULLv5,
|
||||
|
@ -2657,12 +2673,12 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
case ARMISD::UMLAL:{
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), N->getOperand(2),
|
||||
N->getOperand(3), getAL(CurDAG),
|
||||
N->getOperand(3), getAL(CurDAG, dl),
|
||||
CurDAG->getRegister(0, MVT::i32)};
|
||||
return CurDAG->getMachineNode(ARM::t2UMLAL, dl, MVT::i32, MVT::i32, Ops);
|
||||
}else{
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), N->getOperand(2),
|
||||
N->getOperand(3), getAL(CurDAG),
|
||||
N->getOperand(3), getAL(CurDAG, dl),
|
||||
CurDAG->getRegister(0, MVT::i32),
|
||||
CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(Subtarget->hasV6Ops() ?
|
||||
|
@ -2673,12 +2689,12 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
case ARMISD::SMLAL:{
|
||||
if (Subtarget->isThumb()) {
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), N->getOperand(2),
|
||||
N->getOperand(3), getAL(CurDAG),
|
||||
N->getOperand(3), getAL(CurDAG, dl),
|
||||
CurDAG->getRegister(0, MVT::i32)};
|
||||
return CurDAG->getMachineNode(ARM::t2SMLAL, dl, MVT::i32, MVT::i32, Ops);
|
||||
}else{
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), N->getOperand(2),
|
||||
N->getOperand(3), getAL(CurDAG),
|
||||
N->getOperand(3), getAL(CurDAG, dl),
|
||||
CurDAG->getRegister(0, MVT::i32),
|
||||
CurDAG->getRegister(0, MVT::i32) };
|
||||
return CurDAG->getMachineNode(Subtarget->hasV6Ops() ?
|
||||
|
@ -2722,7 +2738,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
assert(N3.getOpcode() == ISD::Register);
|
||||
|
||||
SDValue Tmp2 = CurDAG->getTargetConstant(((unsigned)
|
||||
cast<ConstantSDNode>(N2)->getZExtValue()),
|
||||
cast<ConstantSDNode>(N2)->getZExtValue()), dl,
|
||||
MVT::i32);
|
||||
SDValue Ops[] = { N1, Tmp2, N3, Chain, InFlag };
|
||||
SDNode *ResNode = CurDAG->getMachineNode(Opc, dl, MVT::Other,
|
||||
|
@ -2751,7 +2767,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
case MVT::v4f32:
|
||||
case MVT::v4i32: Opc = ARM::VZIPq32; break;
|
||||
}
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue PredReg = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), Pred, PredReg };
|
||||
return CurDAG->getMachineNode(Opc, dl, VT, VT, Ops);
|
||||
|
@ -2771,7 +2787,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
case MVT::v4f32:
|
||||
case MVT::v4i32: Opc = ARM::VUZPq32; break;
|
||||
}
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue PredReg = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), Pred, PredReg };
|
||||
return CurDAG->getMachineNode(Opc, dl, VT, VT, Ops);
|
||||
|
@ -2790,7 +2806,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
case MVT::v4f32:
|
||||
case MVT::v4i32: Opc = ARM::VTRNq32; break;
|
||||
}
|
||||
SDValue Pred = getAL(CurDAG);
|
||||
SDValue Pred = getAL(CurDAG, dl);
|
||||
SDValue PredReg = CurDAG->getRegister(0, MVT::i32);
|
||||
SDValue Ops[] = { N->getOperand(0), N->getOperand(1), Pred, PredReg };
|
||||
return CurDAG->getMachineNode(Opc, dl, VT, VT, Ops);
|
||||
|
@ -3038,7 +3054,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
// Place arguments in the right order.
|
||||
SmallVector<SDValue, 7> Ops;
|
||||
Ops.push_back(MemAddr);
|
||||
Ops.push_back(getAL(CurDAG));
|
||||
Ops.push_back(getAL(CurDAG, dl));
|
||||
Ops.push_back(CurDAG->getRegister(0, MVT::i32));
|
||||
Ops.push_back(Chain);
|
||||
SDNode *Ld = CurDAG->getMachineNode(NewOpc, dl, ResTys, Ops);
|
||||
|
@ -3054,7 +3070,8 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
if (isThumb)
|
||||
Result = SDValue(Ld, 0);
|
||||
else {
|
||||
SDValue SubRegIdx = CurDAG->getTargetConstant(ARM::gsub_0, MVT::i32);
|
||||
SDValue SubRegIdx =
|
||||
CurDAG->getTargetConstant(ARM::gsub_0, dl, MVT::i32);
|
||||
SDNode *ResNode = CurDAG->getMachineNode(TargetOpcode::EXTRACT_SUBREG,
|
||||
dl, MVT::i32, SDValue(Ld, 0), SubRegIdx);
|
||||
Result = SDValue(ResNode,0);
|
||||
|
@ -3066,7 +3083,8 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
if (isThumb)
|
||||
Result = SDValue(Ld, 1);
|
||||
else {
|
||||
SDValue SubRegIdx = CurDAG->getTargetConstant(ARM::gsub_1, MVT::i32);
|
||||
SDValue SubRegIdx =
|
||||
CurDAG->getTargetConstant(ARM::gsub_1, dl, MVT::i32);
|
||||
SDNode *ResNode = CurDAG->getMachineNode(TargetOpcode::EXTRACT_SUBREG,
|
||||
dl, MVT::i32, SDValue(Ld, 0), SubRegIdx);
|
||||
Result = SDValue(ResNode,0);
|
||||
|
@ -3098,7 +3116,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
// arm_strexd uses GPRPair.
|
||||
Ops.push_back(SDValue(createGPRPairNode(MVT::Untyped, Val0, Val1), 0));
|
||||
Ops.push_back(MemAddr);
|
||||
Ops.push_back(getAL(CurDAG));
|
||||
Ops.push_back(getAL(CurDAG, dl));
|
||||
Ops.push_back(CurDAG->getRegister(0, MVT::i32));
|
||||
Ops.push_back(Chain);
|
||||
|
||||
|
@ -3290,7 +3308,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
|
||||
Ops.push_back(N->getOperand(0));
|
||||
Ops.push_back(N->getOperand(1));
|
||||
Ops.push_back(getAL(CurDAG)); // Predicate
|
||||
Ops.push_back(getAL(CurDAG, dl)); // Predicate
|
||||
Ops.push_back(CurDAG->getRegister(0, MVT::i32)); // Predicate Register
|
||||
return CurDAG->getMachineNode(ARM::VTBL1, dl, VT, Ops);
|
||||
}
|
||||
|
@ -3306,7 +3324,7 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) {
|
|||
SmallVector<SDValue, 6> Ops;
|
||||
Ops.push_back(RegSeq);
|
||||
Ops.push_back(N->getOperand(2));
|
||||
Ops.push_back(getAL(CurDAG)); // Predicate
|
||||
Ops.push_back(getAL(CurDAG, dl)); // Predicate
|
||||
Ops.push_back(CurDAG->getRegister(0, MVT::i32)); // Predicate Register
|
||||
return CurDAG->getMachineNode(ARM::VTBL2, dl, VT, Ops);
|
||||
}
|
||||
|
@ -3451,7 +3469,7 @@ SDNode *ARMDAGToDAGISel::SelectInlineAsm(SDNode *N){
|
|||
Flag = InlineAsm::getFlagWordForRegClass(Flag, ARM::GPRPairRegClassID);
|
||||
// Replace the current flag.
|
||||
AsmNodeOperands[AsmNodeOperands.size() -1] = CurDAG->getTargetConstant(
|
||||
Flag, MVT::i32);
|
||||
Flag, dl, MVT::i32);
|
||||
// Add the new register node and skip the original two GPRs.
|
||||
AsmNodeOperands.push_back(PairedReg);
|
||||
// Skip the next two GPRs.
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -323,12 +323,12 @@ class RegConstraint<string C> {
|
|||
|
||||
// imm_neg_XFORM - Return the negation of an i32 immediate value.
|
||||
def imm_neg_XFORM : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(-(int)N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(-(int)N->getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
// imm_not_XFORM - Return the complement of a i32 immediate value.
|
||||
def imm_not_XFORM : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(~(int)N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(~(int)N->getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
/// imm16_31 predicate - True if the 32-bit immediate is in the range [16,31].
|
||||
|
@ -343,7 +343,8 @@ def sext_16_node : PatLeaf<(i32 GPR:$a), [{
|
|||
|
||||
/// Split a 32-bit immediate into two 16 bit parts.
|
||||
def hi16 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant((uint32_t)N->getZExtValue() >> 16, MVT::i32);
|
||||
return CurDAG->getTargetConstant((uint32_t)N->getZExtValue() >> 16, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
def lo16AllZero : PatLeaf<(i32 imm), [{
|
||||
|
@ -485,10 +486,10 @@ def neon_vcvt_imm32 : Operand<i32> {
|
|||
def rot_imm_XFORM: SDNodeXForm<imm, [{
|
||||
switch (N->getZExtValue()){
|
||||
default: llvm_unreachable(nullptr);
|
||||
case 0: return CurDAG->getTargetConstant(0, MVT::i32);
|
||||
case 8: return CurDAG->getTargetConstant(1, MVT::i32);
|
||||
case 16: return CurDAG->getTargetConstant(2, MVT::i32);
|
||||
case 24: return CurDAG->getTargetConstant(3, MVT::i32);
|
||||
case 0: return CurDAG->getTargetConstant(0, SDLoc(N), MVT::i32);
|
||||
case 8: return CurDAG->getTargetConstant(1, SDLoc(N), MVT::i32);
|
||||
case 16: return CurDAG->getTargetConstant(2, SDLoc(N), MVT::i32);
|
||||
case 24: return CurDAG->getTargetConstant(3, SDLoc(N), MVT::i32);
|
||||
}
|
||||
}]>;
|
||||
def RotImmAsmOperand : AsmOperandClass {
|
||||
|
@ -767,7 +768,8 @@ def bf_inv_mask_imm : Operand<i32>,
|
|||
}
|
||||
|
||||
def imm1_32_XFORM: SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant((int)N->getZExtValue() - 1, MVT::i32);
|
||||
return CurDAG->getTargetConstant((int)N->getZExtValue() - 1, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
def Imm1_32AsmOperand: AsmOperandClass { let Name = "Imm1_32"; }
|
||||
def imm1_32 : Operand<i32>, PatLeaf<(imm), [{
|
||||
|
@ -780,7 +782,8 @@ def imm1_32 : Operand<i32>, PatLeaf<(imm), [{
|
|||
}
|
||||
|
||||
def imm1_16_XFORM: SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant((int)N->getZExtValue() - 1, MVT::i32);
|
||||
return CurDAG->getTargetConstant((int)N->getZExtValue() - 1, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
def Imm1_16AsmOperand: AsmOperandClass { let Name = "Imm1_16"; }
|
||||
def imm1_16 : Operand<i32>, PatLeaf<(imm), [{ return Imm > 0 && Imm <= 16; }],
|
||||
|
|
|
@ -2393,36 +2393,41 @@ def : Pat<(byte_alignedstore (v2f64 QPR:$value), addrmode6:$addr),
|
|||
// Extract D sub-registers of Q registers.
|
||||
def DSubReg_i8_reg : SDNodeXForm<imm, [{
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/8, MVT::i32);
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/8, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_i16_reg : SDNodeXForm<imm, [{
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/4, MVT::i32);
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/4, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_i32_reg : SDNodeXForm<imm, [{
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/2, MVT::i32);
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/2, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_f64_reg : SDNodeXForm<imm, [{
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue(), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
// Extract S sub-registers of Q/D registers.
|
||||
def SSubReg_f32_reg : SDNodeXForm<imm, [{
|
||||
assert(ARM::ssub_3 == ARM::ssub_0+3 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::ssub_0 + N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(ARM::ssub_0 + N->getZExtValue(), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
// Translate lane numbers from Q registers to D subregs.
|
||||
def SubReg_i8_lane : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 7, MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 7, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def SubReg_i16_lane : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 3, MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 3, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def SubReg_i32_lane : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 1, MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 1, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
|
@ -21,7 +21,7 @@ def ARMtcall : SDNode<"ARMISD::tCALL", SDT_ARMcall,
|
|||
|
||||
def imm_sr_XFORM: SDNodeXForm<imm, [{
|
||||
unsigned Imm = N->getZExtValue();
|
||||
return CurDAG->getTargetConstant((Imm == 32 ? 0 : Imm), MVT::i32);
|
||||
return CurDAG->getTargetConstant((Imm == 32 ? 0 : Imm), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def ThumbSRImmAsmOperand: AsmOperandClass { let Name = "ImmThumbSR"; }
|
||||
def imm_sr : Operand<i32>, PatLeaf<(imm), [{
|
||||
|
@ -33,7 +33,8 @@ def imm_sr : Operand<i32>, PatLeaf<(imm), [{
|
|||
}
|
||||
|
||||
def imm_comp_XFORM : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(~((uint32_t)N->getZExtValue()), MVT::i32);
|
||||
return CurDAG->getTargetConstant(~((uint32_t)N->getZExtValue()), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
def imm0_7_neg : PatLeaf<(i32 imm), [{
|
||||
|
@ -61,12 +62,12 @@ def thumb_immshifted : PatLeaf<(imm), [{
|
|||
|
||||
def thumb_immshifted_val : SDNodeXForm<imm, [{
|
||||
unsigned V = ARM_AM::getThumbImmNonShiftedVal((unsigned)N->getZExtValue());
|
||||
return CurDAG->getTargetConstant(V, MVT::i32);
|
||||
return CurDAG->getTargetConstant(V, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def thumb_immshifted_shamt : SDNodeXForm<imm, [{
|
||||
unsigned V = ARM_AM::getThumbImmValShift((unsigned)N->getZExtValue());
|
||||
return CurDAG->getTargetConstant(V, MVT::i32);
|
||||
return CurDAG->getTargetConstant(V, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
// Scaled 4 immediate.
|
||||
|
|
|
@ -54,12 +54,14 @@ def t2_so_reg : Operand<i32>, // reg imm
|
|||
|
||||
// t2_so_imm_not_XFORM - Return the complement of a t2_so_imm value
|
||||
def t2_so_imm_not_XFORM : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(~((uint32_t)N->getZExtValue()), MVT::i32);
|
||||
return CurDAG->getTargetConstant(~((uint32_t)N->getZExtValue()), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
// t2_so_imm_neg_XFORM - Return the negation of a t2_so_imm value
|
||||
def t2_so_imm_neg_XFORM : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(-((int)N->getZExtValue()), MVT::i32);
|
||||
return CurDAG->getTargetConstant(-((int)N->getZExtValue()), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
// so_imm_notSext_XFORM - Return a so_imm value packed into the format
|
||||
|
@ -68,7 +70,7 @@ def t2_so_imm_neg_XFORM : SDNodeXForm<imm, [{
|
|||
def t2_so_imm_notSext16_XFORM : SDNodeXForm<imm, [{
|
||||
APInt apIntN = N->getAPIntValue();
|
||||
unsigned N16bitSignExt = apIntN.trunc(16).sext(32).getZExtValue();
|
||||
return CurDAG->getTargetConstant(~N16bitSignExt, MVT::i32);
|
||||
return CurDAG->getTargetConstant(~N16bitSignExt, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
// t2_so_imm - Match a 32-bit immediate operand, which is an
|
||||
|
|
|
@ -37,7 +37,7 @@ def vfp_f32imm : Operand<f32>,
|
|||
}], SDNodeXForm<fpimm, [{
|
||||
APFloat InVal = N->getValueAPF();
|
||||
uint32_t enc = ARM_AM::getFP32Imm(InVal);
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>> {
|
||||
let PrintMethod = "printFPImmOperand";
|
||||
let ParserMatchClass = FPImmOperand;
|
||||
|
@ -49,7 +49,7 @@ def vfp_f64imm : Operand<f64>,
|
|||
}], SDNodeXForm<fpimm, [{
|
||||
APFloat InVal = N->getValueAPF();
|
||||
uint32_t enc = ARM_AM::getFP64Imm(InVal);
|
||||
return CurDAG->getTargetConstant(enc, MVT::i32);
|
||||
return CurDAG->getTargetConstant(enc, SDLoc(N), MVT::i32);
|
||||
}]>> {
|
||||
let PrintMethod = "printFPImmOperand";
|
||||
let ParserMatchClass = FPImmOperand;
|
||||
|
|
|
@ -67,7 +67,7 @@ ARMSelectionDAGInfo::EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl,
|
|||
i < MAX_LOADS_IN_LDM && EmittedNumMemOps + i < NumMemOps; ++i) {
|
||||
Loads[i] = DAG.getLoad(VT, dl, Chain,
|
||||
DAG.getNode(ISD::ADD, dl, MVT::i32, Src,
|
||||
DAG.getConstant(SrcOff, MVT::i32)),
|
||||
DAG.getConstant(SrcOff, dl, MVT::i32)),
|
||||
SrcPtrInfo.getWithOffset(SrcOff), isVolatile,
|
||||
false, false, 0);
|
||||
TFOps[i] = Loads[i].getValue(1);
|
||||
|
@ -80,7 +80,7 @@ ARMSelectionDAGInfo::EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl,
|
|||
i < MAX_LOADS_IN_LDM && EmittedNumMemOps + i < NumMemOps; ++i) {
|
||||
TFOps[i] = DAG.getStore(Chain, dl, Loads[i],
|
||||
DAG.getNode(ISD::ADD, dl, MVT::i32, Dst,
|
||||
DAG.getConstant(DstOff, MVT::i32)),
|
||||
DAG.getConstant(DstOff, dl, MVT::i32)),
|
||||
DstPtrInfo.getWithOffset(DstOff),
|
||||
isVolatile, false, 0);
|
||||
DstOff += VTSize;
|
||||
|
@ -108,7 +108,7 @@ ARMSelectionDAGInfo::EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl,
|
|||
|
||||
Loads[i] = DAG.getLoad(VT, dl, Chain,
|
||||
DAG.getNode(ISD::ADD, dl, MVT::i32, Src,
|
||||
DAG.getConstant(SrcOff, MVT::i32)),
|
||||
DAG.getConstant(SrcOff, dl, MVT::i32)),
|
||||
SrcPtrInfo.getWithOffset(SrcOff),
|
||||
false, false, false, 0);
|
||||
TFOps[i] = Loads[i].getValue(1);
|
||||
|
@ -132,7 +132,7 @@ ARMSelectionDAGInfo::EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl,
|
|||
|
||||
TFOps[i] = DAG.getStore(Chain, dl, Loads[i],
|
||||
DAG.getNode(ISD::ADD, dl, MVT::i32, Dst,
|
||||
DAG.getConstant(DstOff, MVT::i32)),
|
||||
DAG.getConstant(DstOff, dl, MVT::i32)),
|
||||
DstPtrInfo.getWithOffset(DstOff), false, false, 0);
|
||||
++i;
|
||||
DstOff += VTSize;
|
||||
|
|
|
@ -108,24 +108,24 @@ public:
|
|||
// XformMskToBitPosU5Imm - Returns the bit position which
|
||||
// the single bit 32 bit mask represents.
|
||||
// Used in Clr and Set bit immediate memops.
|
||||
SDValue XformMskToBitPosU5Imm(uint32_t Imm) {
|
||||
SDValue XformMskToBitPosU5Imm(uint32_t Imm, SDLoc DL) {
|
||||
int32_t bitPos;
|
||||
bitPos = Log2_32(Imm);
|
||||
assert(bitPos >= 0 && bitPos < 32 &&
|
||||
"Constant out of range for 32 BitPos Memops");
|
||||
return CurDAG->getTargetConstant(bitPos, MVT::i32);
|
||||
return CurDAG->getTargetConstant(bitPos, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// XformMskToBitPosU4Imm - Returns the bit position which the single-bit
|
||||
// 16 bit mask represents. Used in Clr and Set bit immediate memops.
|
||||
SDValue XformMskToBitPosU4Imm(uint16_t Imm) {
|
||||
return XformMskToBitPosU5Imm(Imm);
|
||||
SDValue XformMskToBitPosU4Imm(uint16_t Imm, SDLoc DL) {
|
||||
return XformMskToBitPosU5Imm(Imm, DL);
|
||||
}
|
||||
|
||||
// XformMskToBitPosU3Imm - Returns the bit position which the single-bit
|
||||
// 8 bit mask represents. Used in Clr and Set bit immediate memops.
|
||||
SDValue XformMskToBitPosU3Imm(uint8_t Imm) {
|
||||
return XformMskToBitPosU5Imm(Imm);
|
||||
SDValue XformMskToBitPosU3Imm(uint8_t Imm, SDLoc DL) {
|
||||
return XformMskToBitPosU5Imm(Imm, DL);
|
||||
}
|
||||
|
||||
// Return true if there is exactly one bit set in V, i.e., if V is one of the
|
||||
|
@ -137,37 +137,37 @@ public:
|
|||
// XformM5ToU5Imm - Return a target constant with the specified value, of
|
||||
// type i32 where the negative literal is transformed into a positive literal
|
||||
// for use in -= memops.
|
||||
inline SDValue XformM5ToU5Imm(signed Imm) {
|
||||
inline SDValue XformM5ToU5Imm(signed Imm, SDLoc DL) {
|
||||
assert( (Imm >= -31 && Imm <= -1) && "Constant out of range for Memops");
|
||||
return CurDAG->getTargetConstant( - Imm, MVT::i32);
|
||||
return CurDAG->getTargetConstant( - Imm, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// XformU7ToU7M1Imm - Return a target constant decremented by 1, in range
|
||||
// [1..128], used in cmpb.gtu instructions.
|
||||
inline SDValue XformU7ToU7M1Imm(signed Imm) {
|
||||
inline SDValue XformU7ToU7M1Imm(signed Imm, SDLoc DL) {
|
||||
assert((Imm >= 1 && Imm <= 128) && "Constant out of range for cmpb op");
|
||||
return CurDAG->getTargetConstant(Imm - 1, MVT::i8);
|
||||
return CurDAG->getTargetConstant(Imm - 1, DL, MVT::i8);
|
||||
}
|
||||
|
||||
// XformS8ToS8M1Imm - Return a target constant decremented by 1.
|
||||
inline SDValue XformSToSM1Imm(signed Imm) {
|
||||
return CurDAG->getTargetConstant(Imm - 1, MVT::i32);
|
||||
inline SDValue XformSToSM1Imm(signed Imm, SDLoc DL) {
|
||||
return CurDAG->getTargetConstant(Imm - 1, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// XformU8ToU8M1Imm - Return a target constant decremented by 1.
|
||||
inline SDValue XformUToUM1Imm(unsigned Imm) {
|
||||
inline SDValue XformUToUM1Imm(unsigned Imm, SDLoc DL) {
|
||||
assert((Imm >= 1) && "Cannot decrement unsigned int less than 1");
|
||||
return CurDAG->getTargetConstant(Imm - 1, MVT::i32);
|
||||
return CurDAG->getTargetConstant(Imm - 1, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// XformSToSM2Imm - Return a target constant decremented by 2.
|
||||
inline SDValue XformSToSM2Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm - 2, MVT::i32);
|
||||
inline SDValue XformSToSM2Imm(unsigned Imm, SDLoc DL) {
|
||||
return CurDAG->getTargetConstant(Imm - 2, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// XformSToSM3Imm - Return a target constant decremented by 3.
|
||||
inline SDValue XformSToSM3Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm - 3, MVT::i32);
|
||||
inline SDValue XformSToSM3Imm(unsigned Imm, SDLoc DL) {
|
||||
return CurDAG->getTargetConstant(Imm - 3, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// Include the pieces autogenerated from the target description.
|
||||
|
@ -259,7 +259,7 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedLoadSignExtend64(LoadSDNode *LD,
|
|||
|
||||
const HexagonInstrInfo &TII = *HST->getInstrInfo();
|
||||
if (TII.isValidAutoIncImm(LoadedVT, Val)) {
|
||||
SDValue TargetConst = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConst = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDNode *Result_1 = CurDAG->getMachineNode(Opcode, dl, MVT::i32, MVT::i32,
|
||||
MVT::Other, Base, TargetConst,
|
||||
Chain);
|
||||
|
@ -278,8 +278,8 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedLoadSignExtend64(LoadSDNode *LD,
|
|||
return Result_2;
|
||||
}
|
||||
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDNode *Result_1 = CurDAG->getMachineNode(Opcode, dl, MVT::i32, MVT::Other,
|
||||
Base, TargetConst0, Chain);
|
||||
SDNode *Result_2 = CurDAG->getMachineNode(Hexagon::A2_sxtw, dl, MVT::i64,
|
||||
|
@ -313,8 +313,8 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedLoadZeroExtend64(LoadSDNode *LD,
|
|||
|
||||
const HexagonInstrInfo &TII = *HST->getInstrInfo();
|
||||
if (TII.isValidAutoIncImm(LoadedVT, Val)) {
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
SDNode *Result_1 = CurDAG->getMachineNode(Opcode, dl, MVT::i32,
|
||||
MVT::i32, MVT::Other, Base,
|
||||
TargetConstVal, Chain);
|
||||
|
@ -336,8 +336,8 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedLoadZeroExtend64(LoadSDNode *LD,
|
|||
}
|
||||
|
||||
// Generate an indirect load.
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDNode *Result_1 = CurDAG->getMachineNode(Opcode, dl, MVT::i32,
|
||||
MVT::Other, Base, TargetConst0,
|
||||
Chain);
|
||||
|
@ -411,7 +411,7 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedLoad(LoadSDNode *LD, SDLoc dl) {
|
|||
return SelectIndexedLoadSignExtend64(LD, Opcode, dl);
|
||||
|
||||
if (TII.isValidAutoIncImm(LoadedVT, Val)) {
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDNode* Result = CurDAG->getMachineNode(Opcode, dl,
|
||||
LD->getValueType(0),
|
||||
MVT::i32, MVT::Other, Base,
|
||||
|
@ -430,8 +430,8 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedLoad(LoadSDNode *LD, SDLoc dl) {
|
|||
ReplaceUses(Froms, Tos, 3);
|
||||
return Result;
|
||||
} else {
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDNode* Result_1 = CurDAG->getMachineNode(Opcode, dl,
|
||||
LD->getValueType(0),
|
||||
MVT::Other, Base, TargetConst0,
|
||||
|
@ -502,7 +502,7 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedStore(StoreSDNode *ST, SDLoc dl) {
|
|||
Value = CurDAG->getTargetExtractSubreg(Hexagon::subreg_loreg,
|
||||
dl, MVT::i32, Value);
|
||||
}
|
||||
SDValue Ops[] = {Base, CurDAG->getTargetConstant(Val, MVT::i32), Value,
|
||||
SDValue Ops[] = {Base, CurDAG->getTargetConstant(Val, dl, MVT::i32), Value,
|
||||
Chain};
|
||||
// Build post increment store.
|
||||
SDNode* Result = CurDAG->getMachineNode(Opcode, dl, MVT::i32,
|
||||
|
@ -520,7 +520,7 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedStore(StoreSDNode *ST, SDLoc dl) {
|
|||
// def S2_storerd_io
|
||||
// : STInst<(outs), (ins IntRegs:$base, imm:$offset, DoubleRegs:$src1), ...
|
||||
// and it differs for POST_ST* for instance.
|
||||
SDValue Ops[] = { Base, CurDAG->getTargetConstant(0, MVT::i32), Value,
|
||||
SDValue Ops[] = { Base, CurDAG->getTargetConstant(0, dl, MVT::i32), Value,
|
||||
Chain};
|
||||
unsigned Opcode = 0;
|
||||
|
||||
|
@ -532,7 +532,7 @@ SDNode *HexagonDAGToDAGISel::SelectIndexedStore(StoreSDNode *ST, SDLoc dl) {
|
|||
else llvm_unreachable("unknown memory type");
|
||||
|
||||
// Build regular store.
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
SDValue TargetConstVal = CurDAG->getTargetConstant(Val, dl, MVT::i32);
|
||||
SDNode* Result_1 = CurDAG->getMachineNode(Opcode, dl, MVT::Other, Ops);
|
||||
// Build splitted incriment instruction.
|
||||
SDNode* Result_2 = CurDAG->getMachineNode(Hexagon::A2_addi, dl, MVT::i32,
|
||||
|
@ -599,7 +599,7 @@ SDNode *HexagonDAGToDAGISel::SelectMul(SDNode *N) {
|
|||
}
|
||||
|
||||
SDValue Chain = LD->getChain();
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
OP0 = SDValue(CurDAG->getMachineNode(Hexagon::L2_loadri_io, dl, MVT::i32,
|
||||
MVT::Other,
|
||||
LD->getBasePtr(), TargetConst0,
|
||||
|
@ -625,7 +625,7 @@ SDNode *HexagonDAGToDAGISel::SelectMul(SDNode *N) {
|
|||
}
|
||||
|
||||
SDValue Chain = LD->getChain();
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
OP1 = SDValue(CurDAG->getMachineNode(Hexagon::L2_loadri_io, dl, MVT::i32,
|
||||
MVT::Other,
|
||||
LD->getBasePtr(), TargetConst0,
|
||||
|
@ -661,7 +661,7 @@ SDNode *HexagonDAGToDAGISel::SelectSHL(SDNode *N) {
|
|||
int32_t MulConst =
|
||||
cast<ConstantSDNode>(Mul_1.getNode())->getSExtValue();
|
||||
int32_t ValConst = MulConst << ShlConst;
|
||||
SDValue Val = CurDAG->getTargetConstant(ValConst,
|
||||
SDValue Val = CurDAG->getTargetConstant(ValConst, dl,
|
||||
MVT::i32);
|
||||
if (ConstantSDNode *CN = dyn_cast<ConstantSDNode>(Val.getNode()))
|
||||
if (isInt<9>(CN->getSExtValue())) {
|
||||
|
@ -689,7 +689,8 @@ SDNode *HexagonDAGToDAGISel::SelectSHL(SDNode *N) {
|
|||
int32_t Shl2Const =
|
||||
cast<ConstantSDNode>(Shl2_1.getNode())->getSExtValue();
|
||||
int32_t ValConst = 1 << (ShlConst+Shl2Const);
|
||||
SDValue Val = CurDAG->getTargetConstant(-ValConst, MVT::i32);
|
||||
SDValue Val = CurDAG->getTargetConstant(-ValConst, dl,
|
||||
MVT::i32);
|
||||
if (ConstantSDNode *CN =
|
||||
dyn_cast<ConstantSDNode>(Val.getNode()))
|
||||
if (isInt<9>(CN->getSExtValue())) {
|
||||
|
@ -738,13 +739,14 @@ SDNode *HexagonDAGToDAGISel::SelectZeroExtend(SDNode *N) {
|
|||
MV |= Bit;
|
||||
Bit <<= ES;
|
||||
}
|
||||
SDValue Ones = CurDAG->getTargetConstant(MV, MVT::i64);
|
||||
SDValue Ones = CurDAG->getTargetConstant(MV, dl, MVT::i64);
|
||||
SDNode *OnesReg = CurDAG->getMachineNode(Hexagon::CONST64_Int_Real, dl,
|
||||
MVT::i64, Ones);
|
||||
if (ExVT.getSizeInBits() == 32) {
|
||||
SDNode *And = CurDAG->getMachineNode(Hexagon::A2_andp, dl, MVT::i64,
|
||||
SDValue(Mask,0), SDValue(OnesReg,0));
|
||||
SDValue SubR = CurDAG->getTargetConstant(Hexagon::subreg_loreg, MVT::i32);
|
||||
SDValue SubR = CurDAG->getTargetConstant(Hexagon::subreg_loreg, dl,
|
||||
MVT::i32);
|
||||
return CurDAG->getMachineNode(Hexagon::EXTRACT_SUBREG, dl, ExVT,
|
||||
SDValue(And,0), SubR);
|
||||
}
|
||||
|
@ -760,7 +762,7 @@ SDNode *HexagonDAGToDAGISel::SelectZeroExtend(SDNode *N) {
|
|||
// Now we need to differentiate target data types.
|
||||
if (N->getValueType(0) == MVT::i64) {
|
||||
// Convert the zero_extend to Rs = Pd followed by A2_combinew(0,Rs).
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue TargetConst0 = CurDAG->getTargetConstant(0, dl, MVT::i32);
|
||||
SDNode *Result_1 = CurDAG->getMachineNode(Hexagon::C2_tfrpr, dl,
|
||||
MVT::i32,
|
||||
SDValue(IsIntrinsic, 0));
|
||||
|
@ -867,7 +869,7 @@ SDNode *HexagonDAGToDAGISel::SelectIntrinsicWChain(SDNode *N) {
|
|||
Ops.push_back(Load);
|
||||
Ops.push_back(ModifierExpr);
|
||||
int32_t Val = cast<ConstantSDNode>(Offset.getNode())->getSExtValue();
|
||||
Ops.push_back(CurDAG->getTargetConstant(Val, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(Val, dl, MVT::i32));
|
||||
Ops.push_back(Chain);
|
||||
SDNode* Result = CurDAG->getMachineNode(opc, dl, ResTys, Ops);
|
||||
|
||||
|
@ -1022,11 +1024,11 @@ SDNode *HexagonDAGToDAGISel::SelectConstantFP(SDNode *N) {
|
|||
APFloat APF = CN->getValueAPF();
|
||||
if (N->getValueType(0) == MVT::f32) {
|
||||
return CurDAG->getMachineNode(Hexagon::TFRI_f, dl, MVT::f32,
|
||||
CurDAG->getTargetConstantFP(APF.convertToFloat(), MVT::f32));
|
||||
CurDAG->getTargetConstantFP(APF.convertToFloat(), dl, MVT::f32));
|
||||
}
|
||||
else if (N->getValueType(0) == MVT::f64) {
|
||||
return CurDAG->getMachineNode(Hexagon::CONST64_Float_Real, dl, MVT::f64,
|
||||
CurDAG->getTargetConstantFP(APF.convertToDouble(), MVT::f64));
|
||||
CurDAG->getTargetConstantFP(APF.convertToDouble(), dl, MVT::f64));
|
||||
}
|
||||
|
||||
return SelectCode(N);
|
||||
|
@ -1166,7 +1168,7 @@ SDNode *HexagonDAGToDAGISel::SelectBitOp(SDNode *N) {
|
|||
|
||||
SDNode *Result;
|
||||
// Get the right SDVal for the opcode.
|
||||
SDValue SDVal = CurDAG->getTargetConstant(bitpos, MVT::i32);
|
||||
SDValue SDVal = CurDAG->getTargetConstant(bitpos, dl, MVT::i32);
|
||||
|
||||
if (ValueVT == MVT::i32 || ValueVT == MVT::f32) {
|
||||
Result = CurDAG->getMachineNode(BitOpc, dl, ValueVT,
|
||||
|
@ -1181,11 +1183,11 @@ SDNode *HexagonDAGToDAGISel::SelectBitOp(SDNode *N) {
|
|||
|
||||
SDNode *Reg = N->getOperand(0).getNode();
|
||||
SDValue RegClass = CurDAG->getTargetConstant(Hexagon::DoubleRegsRegClassID,
|
||||
MVT::i64);
|
||||
dl, MVT::i64);
|
||||
|
||||
SDValue SubregHiIdx = CurDAG->getTargetConstant(Hexagon::subreg_hireg,
|
||||
SDValue SubregHiIdx = CurDAG->getTargetConstant(Hexagon::subreg_hireg, dl,
|
||||
MVT::i32);
|
||||
SDValue SubregLoIdx = CurDAG->getTargetConstant(Hexagon::subreg_loreg,
|
||||
SDValue SubregLoIdx = CurDAG->getTargetConstant(Hexagon::subreg_loreg, dl,
|
||||
MVT::i32);
|
||||
|
||||
SDValue SubregHI = CurDAG->getTargetExtractSubreg(Hexagon::subreg_hireg, dl,
|
||||
|
@ -1204,7 +1206,7 @@ SDNode *HexagonDAGToDAGISel::SelectBitOp(SDNode *N) {
|
|||
dl, ValueVT, Ops);
|
||||
} else {
|
||||
if (Opc != ISD::FABS && Opc != ISD::FNEG)
|
||||
SDVal = CurDAG->getTargetConstant(bitpos-32, MVT::i32);
|
||||
SDVal = CurDAG->getTargetConstant(bitpos - 32, dl, MVT::i32);
|
||||
SDNode *Result0 = CurDAG->getMachineNode(BitOpc, dl, SubValueVT,
|
||||
SubregHI, SDVal);
|
||||
const SDValue Ops[] = { RegClass, SDValue(Result0, 0), SubregHiIdx,
|
||||
|
@ -1226,8 +1228,8 @@ SDNode *HexagonDAGToDAGISel::SelectFrameIndex(SDNode *N) {
|
|||
unsigned StkA = HFI->getStackAlignment();
|
||||
unsigned MaxA = MFI->getMaxAlignment();
|
||||
SDValue FI = CurDAG->getTargetFrameIndex(FX, MVT::i32);
|
||||
SDValue Zero = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDLoc DL(N);
|
||||
SDValue Zero = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
SDNode *R = 0;
|
||||
|
||||
// Use TFR_FI when:
|
||||
|
@ -1321,7 +1323,7 @@ SelectInlineAsmMemoryOperand(const SDValue &Op, unsigned ConstraintID,
|
|||
break;
|
||||
}
|
||||
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, MVT::i32));
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, SDLoc(Op), MVT::i32));
|
||||
return false;
|
||||
}
|
||||
|
||||
|
|
|
@ -344,7 +344,7 @@ CreateCopyOfByValArgument(SDValue Src, SDValue Dst, SDValue Chain,
|
|||
ISD::ArgFlagsTy Flags, SelectionDAG &DAG,
|
||||
SDLoc dl) {
|
||||
|
||||
SDValue SizeNode = DAG.getConstant(Flags.getByValSize(), MVT::i32);
|
||||
SDValue SizeNode = DAG.getConstant(Flags.getByValSize(), dl, MVT::i32);
|
||||
return DAG.getMemcpy(Chain, dl, Dst, Src, SizeNode, Flags.getByValAlign(),
|
||||
/*isVolatile=*/false, /*AlwaysInline=*/false,
|
||||
/*isTailCall=*/false,
|
||||
|
@ -542,7 +542,8 @@ HexagonTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
|
||||
if (VA.isMemLoc()) {
|
||||
unsigned LocMemOffset = VA.getLocMemOffset();
|
||||
SDValue MemAddr = DAG.getConstant(LocMemOffset, StackPtr.getValueType());
|
||||
SDValue MemAddr = DAG.getConstant(LocMemOffset, dl,
|
||||
StackPtr.getValueType());
|
||||
MemAddr = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, MemAddr);
|
||||
if (Flags.isByVal()) {
|
||||
// The argument is a struct passed by value. According to LLVM, "Arg"
|
||||
|
@ -570,7 +571,7 @@ HexagonTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, MemOpChains);
|
||||
|
||||
if (!isTailCall) {
|
||||
SDValue C = DAG.getConstant(NumBytes, getPointerTy(), true);
|
||||
SDValue C = DAG.getConstant(NumBytes, dl, getPointerTy(), true);
|
||||
Chain = DAG.getCALLSEQ_START(Chain, C, dl);
|
||||
}
|
||||
|
||||
|
@ -644,8 +645,8 @@ HexagonTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
InFlag = Chain.getValue(1);
|
||||
|
||||
// Create the CALLSEQ_END node.
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(NumBytes, true),
|
||||
DAG.getIntPtrConstant(0, true), InFlag, dl);
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(NumBytes, dl, true),
|
||||
DAG.getIntPtrConstant(0, dl, true), InFlag, dl);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
// Handle result values, copying them out of physregs into vregs that we
|
||||
|
@ -808,7 +809,7 @@ LowerBR_JT(SDValue Op, SelectionDAG &DAG) const
|
|||
SDValue JumpTableBase = DAG.getNode(HexagonISD::JT, dl,
|
||||
getPointerTy(), TargetJT);
|
||||
SDValue ShiftIndex = DAG.getNode(ISD::SHL, dl, MVT::i32, Index,
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, dl, MVT::i32));
|
||||
SDValue JTAddress = DAG.getNode(ISD::ADD, dl, MVT::i32, JumpTableBase,
|
||||
ShiftIndex);
|
||||
SDValue LoadTarget = DAG.getLoad(MVT::i32, dl, Chain, JTAddress,
|
||||
|
@ -841,7 +842,7 @@ HexagonTargetLowering::LowerDYNAMIC_STACKALLOC(SDValue Op,
|
|||
dbgs() << "\n";
|
||||
});
|
||||
|
||||
SDValue AC = DAG.getConstant(A, MVT::i32);
|
||||
SDValue AC = DAG.getConstant(A, dl, MVT::i32);
|
||||
SDVTList VTs = DAG.getVTList(MVT::i32, MVT::Other);
|
||||
return DAG.getNode(HexagonISD::ALLOCA, dl, VTs, Chain, Size, AC);
|
||||
}
|
||||
|
@ -994,7 +995,7 @@ SDValue HexagonTargetLowering::LowerCTPOP(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue InpVal = Op.getOperand(0);
|
||||
if (isa<ConstantSDNode>(InpVal)) {
|
||||
uint64_t V = cast<ConstantSDNode>(InpVal)->getZExtValue();
|
||||
return DAG.getTargetConstant(countPopulation(V), MVT::i64);
|
||||
return DAG.getTargetConstant(countPopulation(V), dl, MVT::i64);
|
||||
}
|
||||
SDValue PopOut = DAG.getNode(HexagonISD::POPCOUNT, dl, MVT::i32, InpVal);
|
||||
return DAG.getNode(ISD::ZERO_EXTEND, dl, MVT::i64, PopOut);
|
||||
|
@ -1095,7 +1096,7 @@ SDValue HexagonTargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
LoadNode->isInvariant(),
|
||||
Alignment);
|
||||
// Base+2 load.
|
||||
SDValue Increment = DAG.getConstant(2, MVT::i32);
|
||||
SDValue Increment = DAG.getConstant(2, DL, MVT::i32);
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, Base.getValueType(), Base, Increment);
|
||||
Loads[1] = DAG.getExtLoad(Ext, DL, MVT::i32, Chain, Ptr,
|
||||
LoadNode->getPointerInfo(), MVT::i16,
|
||||
|
@ -1104,11 +1105,11 @@ SDValue HexagonTargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
LoadNode->isInvariant(),
|
||||
Alignment);
|
||||
// SHL 16, then OR base and base+2.
|
||||
SDValue ShiftAmount = DAG.getConstant(16, MVT::i32);
|
||||
SDValue ShiftAmount = DAG.getConstant(16, DL, MVT::i32);
|
||||
SDValue Tmp1 = DAG.getNode(ISD::SHL, DL, MVT::i32, Loads[1], ShiftAmount);
|
||||
SDValue Tmp2 = DAG.getNode(ISD::OR, DL, MVT::i32, Tmp1, Loads[0]);
|
||||
// Base + 4.
|
||||
Increment = DAG.getConstant(4, MVT::i32);
|
||||
Increment = DAG.getConstant(4, DL, MVT::i32);
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, Base.getValueType(), Base, Increment);
|
||||
Loads[2] = DAG.getExtLoad(Ext, DL, MVT::i32, Chain, Ptr,
|
||||
LoadNode->getPointerInfo(), MVT::i16,
|
||||
|
@ -1117,7 +1118,7 @@ SDValue HexagonTargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
LoadNode->isInvariant(),
|
||||
Alignment);
|
||||
// Base + 6.
|
||||
Increment = DAG.getConstant(6, MVT::i32);
|
||||
Increment = DAG.getConstant(6, DL, MVT::i32);
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, Base.getValueType(), Base, Increment);
|
||||
Loads[3] = DAG.getExtLoad(Ext, DL, MVT::i32, Chain, Ptr,
|
||||
LoadNode->getPointerInfo(), MVT::i16,
|
||||
|
@ -1183,7 +1184,7 @@ HexagonTargetLowering::LowerRETURNADDR(SDValue Op, SelectionDAG &DAG) const {
|
|||
unsigned Depth = cast<ConstantSDNode>(Op.getOperand(0))->getZExtValue();
|
||||
if (Depth) {
|
||||
SDValue FrameAddr = LowerFRAMEADDR(Op, DAG);
|
||||
SDValue Offset = DAG.getConstant(4, MVT::i32);
|
||||
SDValue Offset = DAG.getConstant(4, dl, MVT::i32);
|
||||
return DAG.getLoad(VT, dl, DAG.getEntryNode(),
|
||||
DAG.getNode(ISD::ADD, dl, VT, FrameAddr, Offset),
|
||||
MachinePointerInfo(), false, false, false, 0);
|
||||
|
@ -1822,7 +1823,7 @@ static SDValue LowerVECTOR_SHUFFLE(SDValue Op, SelectionDAG &DAG) {
|
|||
if (IsScalarToVector)
|
||||
return createSplat(DAG, dl, VT, V1.getOperand(0));
|
||||
}
|
||||
return createSplat(DAG, dl, VT, DAG.getConstant(Lane, MVT::i32));
|
||||
return createSplat(DAG, dl, VT, DAG.getConstant(Lane, dl, MVT::i32));
|
||||
}
|
||||
|
||||
// FIXME: We need to support more general vector shuffles. See
|
||||
|
@ -1930,7 +1931,7 @@ HexagonTargetLowering::LowerBUILD_VECTOR(SDValue Op, SelectionDAG &DAG) const {
|
|||
unsigned SplatBits = APSplatBits.getZExtValue();
|
||||
int32_t SextVal = ((int32_t) (SplatBits << (32 - SplatBitSize)) >>
|
||||
(32 - SplatBitSize));
|
||||
return createSplat(DAG, dl, VT, DAG.getConstant(SextVal, MVT::i32));
|
||||
return createSplat(DAG, dl, VT, DAG.getConstant(SextVal, dl, MVT::i32));
|
||||
}
|
||||
|
||||
// Try to generate COMBINE to build v2i32 vectors.
|
||||
|
@ -1939,9 +1940,9 @@ HexagonTargetLowering::LowerBUILD_VECTOR(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue V1 = BVN->getOperand(1);
|
||||
|
||||
if (V0.getOpcode() == ISD::UNDEF)
|
||||
V0 = DAG.getConstant(0, MVT::i32);
|
||||
V0 = DAG.getConstant(0, dl, MVT::i32);
|
||||
if (V1.getOpcode() == ISD::UNDEF)
|
||||
V1 = DAG.getConstant(0, MVT::i32);
|
||||
V1 = DAG.getConstant(0, dl, MVT::i32);
|
||||
|
||||
ConstantSDNode *C0 = dyn_cast<ConstantSDNode>(V0);
|
||||
ConstantSDNode *C1 = dyn_cast<ConstantSDNode>(V1);
|
||||
|
@ -2002,17 +2003,17 @@ HexagonTargetLowering::LowerBUILD_VECTOR(SDValue Op, SelectionDAG &DAG) const {
|
|||
}
|
||||
|
||||
if (Size == 64)
|
||||
ConstVal = DAG.getConstant(Res, MVT::i64);
|
||||
ConstVal = DAG.getConstant(Res, dl, MVT::i64);
|
||||
else
|
||||
ConstVal = DAG.getConstant(Res, MVT::i32);
|
||||
ConstVal = DAG.getConstant(Res, dl, MVT::i32);
|
||||
|
||||
// When there are non constant operands, add them with INSERT_VECTOR_ELT to
|
||||
// ConstVal, the constant part of the vector.
|
||||
if (HasNonConstantElements) {
|
||||
EVT EltVT = VT.getVectorElementType();
|
||||
SDValue Width = DAG.getConstant(EltVT.getSizeInBits(), MVT::i64);
|
||||
SDValue Width = DAG.getConstant(EltVT.getSizeInBits(), dl, MVT::i64);
|
||||
SDValue Shifted = DAG.getNode(ISD::SHL, dl, MVT::i64, Width,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
|
||||
for (unsigned i = 0, e = NElts; i != e; ++i) {
|
||||
// LLVM's BUILD_VECTOR operands are in Little Endian mode, whereas Hexagon
|
||||
|
@ -2025,11 +2026,11 @@ HexagonTargetLowering::LowerBUILD_VECTOR(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
if (VT.getSizeInBits() == 64 &&
|
||||
Operand.getValueType().getSizeInBits() == 32) {
|
||||
SDValue C = DAG.getConstant(0, MVT::i32);
|
||||
SDValue C = DAG.getConstant(0, dl, MVT::i32);
|
||||
Operand = DAG.getNode(HexagonISD::COMBINE, dl, VT, C, Operand);
|
||||
}
|
||||
|
||||
SDValue Idx = DAG.getConstant(OpIdx, MVT::i64);
|
||||
SDValue Idx = DAG.getConstant(OpIdx, dl, MVT::i64);
|
||||
SDValue Offset = DAG.getNode(ISD::MUL, dl, MVT::i64, Idx, Width);
|
||||
SDValue Combined = DAG.getNode(ISD::OR, dl, MVT::i64, Shifted, Offset);
|
||||
const SDValue Ops[] = {ConstVal, Operand, Combined};
|
||||
|
@ -2052,10 +2053,10 @@ HexagonTargetLowering::LowerCONCAT_VECTORS(SDValue Op,
|
|||
unsigned NElts = Op.getNumOperands();
|
||||
SDValue Vec = Op.getOperand(0);
|
||||
EVT VecVT = Vec.getValueType();
|
||||
SDValue Width = DAG.getConstant(VecVT.getSizeInBits(), MVT::i64);
|
||||
SDValue Width = DAG.getConstant(VecVT.getSizeInBits(), dl, MVT::i64);
|
||||
SDValue Shifted = DAG.getNode(ISD::SHL, dl, MVT::i64, Width,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
SDValue ConstVal = DAG.getConstant(0, MVT::i64);
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
SDValue ConstVal = DAG.getConstant(0, dl, MVT::i64);
|
||||
|
||||
ConstantSDNode *W = dyn_cast<ConstantSDNode>(Width);
|
||||
ConstantSDNode *S = dyn_cast<ConstantSDNode>(Shifted);
|
||||
|
@ -2084,11 +2085,11 @@ HexagonTargetLowering::LowerCONCAT_VECTORS(SDValue Op,
|
|||
|
||||
if (VT.getSizeInBits() == 64 &&
|
||||
Operand.getValueType().getSizeInBits() == 32) {
|
||||
SDValue C = DAG.getConstant(0, MVT::i32);
|
||||
SDValue C = DAG.getConstant(0, dl, MVT::i32);
|
||||
Operand = DAG.getNode(HexagonISD::COMBINE, dl, VT, C, Operand);
|
||||
}
|
||||
|
||||
SDValue Idx = DAG.getConstant(OpIdx, MVT::i64);
|
||||
SDValue Idx = DAG.getConstant(OpIdx, dl, MVT::i64);
|
||||
SDValue Offset = DAG.getNode(ISD::MUL, dl, MVT::i64, Idx, Width);
|
||||
SDValue Combined = DAG.getNode(ISD::OR, dl, MVT::i64, Shifted, Offset);
|
||||
const SDValue Ops[] = {ConstVal, Operand, Combined};
|
||||
|
@ -2114,12 +2115,12 @@ HexagonTargetLowering::LowerEXTRACT_VECTOR(SDValue Op,
|
|||
EVT EltVT = VecVT.getVectorElementType();
|
||||
int EltSize = EltVT.getSizeInBits();
|
||||
SDValue Width = DAG.getConstant(Op.getOpcode() == ISD::EXTRACT_VECTOR_ELT ?
|
||||
EltSize : VTN * EltSize, MVT::i64);
|
||||
EltSize : VTN * EltSize, dl, MVT::i64);
|
||||
|
||||
// Constant element number.
|
||||
if (ConstantSDNode *CI = dyn_cast<ConstantSDNode>(Idx)) {
|
||||
uint64_t X = CI->getZExtValue();
|
||||
SDValue Offset = DAG.getConstant(X * EltSize, MVT::i32);
|
||||
SDValue Offset = DAG.getConstant(X * EltSize, dl, MVT::i32);
|
||||
const SDValue Ops[] = {Vec, Width, Offset};
|
||||
|
||||
ConstantSDNode *CW = dyn_cast<ConstantSDNode>(Width);
|
||||
|
@ -2158,9 +2159,9 @@ HexagonTargetLowering::LowerEXTRACT_VECTOR(SDValue Op,
|
|||
|
||||
// Variable element number.
|
||||
SDValue Offset = DAG.getNode(ISD::MUL, dl, MVT::i32, Idx,
|
||||
DAG.getConstant(EltSize, MVT::i32));
|
||||
DAG.getConstant(EltSize, dl, MVT::i32));
|
||||
SDValue Shifted = DAG.getNode(ISD::SHL, dl, MVT::i64, Width,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
SDValue Combined = DAG.getNode(ISD::OR, dl, MVT::i64, Shifted, Offset);
|
||||
|
||||
const SDValue Ops[] = {Vec, Combined};
|
||||
|
@ -2189,10 +2190,10 @@ HexagonTargetLowering::LowerINSERT_VECTOR(SDValue Op,
|
|||
EVT EltVT = VecVT.getVectorElementType();
|
||||
int EltSize = EltVT.getSizeInBits();
|
||||
SDValue Width = DAG.getConstant(Op.getOpcode() == ISD::INSERT_VECTOR_ELT ?
|
||||
EltSize : VTN * EltSize, MVT::i64);
|
||||
EltSize : VTN * EltSize, dl, MVT::i64);
|
||||
|
||||
if (ConstantSDNode *C = cast<ConstantSDNode>(Idx)) {
|
||||
SDValue Offset = DAG.getConstant(C->getSExtValue() * EltSize, MVT::i32);
|
||||
SDValue Offset = DAG.getConstant(C->getSExtValue() * EltSize, dl, MVT::i32);
|
||||
const SDValue Ops[] = {Vec, Val, Width, Offset};
|
||||
|
||||
SDValue N;
|
||||
|
@ -2206,14 +2207,14 @@ HexagonTargetLowering::LowerINSERT_VECTOR(SDValue Op,
|
|||
|
||||
// Variable element number.
|
||||
SDValue Offset = DAG.getNode(ISD::MUL, dl, MVT::i32, Idx,
|
||||
DAG.getConstant(EltSize, MVT::i32));
|
||||
DAG.getConstant(EltSize, dl, MVT::i32));
|
||||
SDValue Shifted = DAG.getNode(ISD::SHL, dl, MVT::i64, Width,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
SDValue Combined = DAG.getNode(ISD::OR, dl, MVT::i64, Shifted, Offset);
|
||||
|
||||
if (VT.getSizeInBits() == 64 &&
|
||||
Val.getValueType().getSizeInBits() == 32) {
|
||||
SDValue C = DAG.getConstant(0, MVT::i32);
|
||||
SDValue C = DAG.getConstant(0, dl, MVT::i32);
|
||||
Val = DAG.getNode(HexagonISD::COMBINE, dl, VT, C, Val);
|
||||
}
|
||||
|
||||
|
@ -2257,7 +2258,7 @@ HexagonTargetLowering::LowerEH_RETURN(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
SDValue StoreAddr = DAG.getNode(ISD::ADD, dl, getPointerTy(),
|
||||
DAG.getRegister(Hexagon::R30, getPointerTy()),
|
||||
DAG.getIntPtrConstant(4));
|
||||
DAG.getIntPtrConstant(4, dl));
|
||||
Chain = DAG.getStore(Chain, dl, Handler, StoreAddr, MachinePointerInfo(),
|
||||
false, false, 0);
|
||||
Chain = DAG.getCopyToReg(Chain, dl, OffsetReg, Offset);
|
||||
|
|
|
@ -36,28 +36,28 @@ def HiReg: OutPatFrag<(ops node:$Rs),
|
|||
def DEC_CONST_SIGNED : SDNodeXForm<imm, [{
|
||||
// Return the byte immediate const-1 as an SDNode.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformSToSM1Imm(imm);
|
||||
return XformSToSM1Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// SDNode for converting immediate C to C-2.
|
||||
def DEC2_CONST_SIGNED : SDNodeXForm<imm, [{
|
||||
// Return the byte immediate const-2 as an SDNode.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformSToSM2Imm(imm);
|
||||
return XformSToSM2Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// SDNode for converting immediate C to C-3.
|
||||
def DEC3_CONST_SIGNED : SDNodeXForm<imm, [{
|
||||
// Return the byte immediate const-3 as an SDNode.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformSToSM3Imm(imm);
|
||||
return XformSToSM3Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// SDNode for converting immediate C to C-1.
|
||||
def DEC_CONST_UNSIGNED : SDNodeXForm<imm, [{
|
||||
// Return the byte immediate const-1 as an SDNode.
|
||||
uint32_t imm = N->getZExtValue();
|
||||
return XformUToUM1Imm(imm);
|
||||
return XformUToUM1Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
|
@ -57,7 +57,7 @@ def BITPOS32 : SDNodeXForm<imm, [{
|
|||
// Return the bit position we will set [0-31].
|
||||
// As an SDNode.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformMskToBitPosU5Imm(imm);
|
||||
return XformMskToBitPosU5Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
|
||||
|
@ -1153,14 +1153,14 @@ def IMM_BYTE : SDNodeXForm<imm, [{
|
|||
// -1 etc is represented as 255 etc
|
||||
// assigning to a byte restores our desired signed value.
|
||||
int8_t imm = N->getSExtValue();
|
||||
return CurDAG->getTargetConstant(imm, MVT::i32);
|
||||
return CurDAG->getTargetConstant(imm, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def IMM_HALF : SDNodeXForm<imm, [{
|
||||
// -1 etc is represented as 65535 etc
|
||||
// assigning to a short restores our desired signed value.
|
||||
int16_t imm = N->getSExtValue();
|
||||
return CurDAG->getTargetConstant(imm, MVT::i32);
|
||||
return CurDAG->getTargetConstant(imm, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def IMM_WORD : SDNodeXForm<imm, [{
|
||||
|
@ -1169,7 +1169,7 @@ def IMM_WORD : SDNodeXForm<imm, [{
|
|||
// might convert -1 to a large +ve number.
|
||||
// assigning to a word restores our desired signed value.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return CurDAG->getTargetConstant(imm, MVT::i32);
|
||||
return CurDAG->getTargetConstant(imm, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def ToImmByte : OutPatFrag<(ops node:$R), (IMM_BYTE $R)>;
|
||||
|
@ -2805,7 +2805,7 @@ def MEMOPIMM : SDNodeXForm<imm, [{
|
|||
// Call the transformation function XformM5ToU5Imm to get the negative
|
||||
// immediate's positive counterpart.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformM5ToU5Imm(imm);
|
||||
return XformM5ToU5Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def MEMOPIMM_HALF : SDNodeXForm<imm, [{
|
||||
|
@ -2814,7 +2814,7 @@ def MEMOPIMM_HALF : SDNodeXForm<imm, [{
|
|||
// Call the transformation function XformM5ToU5Imm to get the negative
|
||||
// immediate's positive counterpart.
|
||||
int16_t imm = N->getSExtValue();
|
||||
return XformM5ToU5Imm(imm);
|
||||
return XformM5ToU5Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def MEMOPIMM_BYTE : SDNodeXForm<imm, [{
|
||||
|
@ -2823,14 +2823,14 @@ def MEMOPIMM_BYTE : SDNodeXForm<imm, [{
|
|||
// Call the transformation function XformM5ToU5Imm to get the negative
|
||||
// immediate's positive counterpart.
|
||||
int8_t imm = N->getSExtValue();
|
||||
return XformM5ToU5Imm(imm);
|
||||
return XformM5ToU5Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def SETMEMIMM : SDNodeXForm<imm, [{
|
||||
// Return the bit position we will set [0-31].
|
||||
// As an SDNode.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformMskToBitPosU5Imm(imm);
|
||||
return XformMskToBitPosU5Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def CLRMEMIMM : SDNodeXForm<imm, [{
|
||||
|
@ -2838,14 +2838,14 @@ def CLRMEMIMM : SDNodeXForm<imm, [{
|
|||
// As an SDNode.
|
||||
// we bit negate the value first
|
||||
int32_t imm = ~(N->getSExtValue());
|
||||
return XformMskToBitPosU5Imm(imm);
|
||||
return XformMskToBitPosU5Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def SETMEMIMM_SHORT : SDNodeXForm<imm, [{
|
||||
// Return the bit position we will set [0-15].
|
||||
// As an SDNode.
|
||||
int16_t imm = N->getSExtValue();
|
||||
return XformMskToBitPosU4Imm(imm);
|
||||
return XformMskToBitPosU4Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def CLRMEMIMM_SHORT : SDNodeXForm<imm, [{
|
||||
|
@ -2853,14 +2853,14 @@ def CLRMEMIMM_SHORT : SDNodeXForm<imm, [{
|
|||
// As an SDNode.
|
||||
// we bit negate the value first
|
||||
int16_t imm = ~(N->getSExtValue());
|
||||
return XformMskToBitPosU4Imm(imm);
|
||||
return XformMskToBitPosU4Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def SETMEMIMM_BYTE : SDNodeXForm<imm, [{
|
||||
// Return the bit position we will set [0-7].
|
||||
// As an SDNode.
|
||||
int8_t imm = N->getSExtValue();
|
||||
return XformMskToBitPosU3Imm(imm);
|
||||
return XformMskToBitPosU3Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def CLRMEMIMM_BYTE : SDNodeXForm<imm, [{
|
||||
|
@ -2868,7 +2868,7 @@ def CLRMEMIMM_BYTE : SDNodeXForm<imm, [{
|
|||
// As an SDNode.
|
||||
// we bit negate the value first
|
||||
int8_t imm = ~(N->getSExtValue());
|
||||
return XformMskToBitPosU3Imm(imm);
|
||||
return XformMskToBitPosU3Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
@ -3202,7 +3202,7 @@ def: Pat<(i1 (setne (i32 IntRegs:$src1), s32ImmPred:$src2)),
|
|||
def DEC_CONST_BYTE : SDNodeXForm<imm, [{
|
||||
// Return the byte immediate const-1 as an SDNode.
|
||||
int32_t imm = N->getSExtValue();
|
||||
return XformU7ToU7M1Imm(imm);
|
||||
return XformU7ToU7M1Imm(imm, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// For the sequence
|
||||
|
|
|
@ -274,7 +274,7 @@ bool MSP430DAGToDAGISel::SelectAddr(SDValue N,
|
|||
Disp = CurDAG->getTargetBlockAddress(AM.BlockAddr, MVT::i32, 0,
|
||||
0/*AM.SymbolFlags*/);
|
||||
else
|
||||
Disp = CurDAG->getTargetConstant(AM.Disp, MVT::i16);
|
||||
Disp = CurDAG->getTargetConstant(AM.Disp, SDLoc(N), MVT::i16);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -401,10 +401,10 @@ SDNode *MSP430DAGToDAGISel::Select(SDNode *Node) {
|
|||
int FI = cast<FrameIndexSDNode>(Node)->getIndex();
|
||||
SDValue TFI = CurDAG->getTargetFrameIndex(FI, MVT::i16);
|
||||
if (Node->hasOneUse())
|
||||
return CurDAG->SelectNodeTo(Node, MSP430::ADD16ri, MVT::i16,
|
||||
TFI, CurDAG->getTargetConstant(0, MVT::i16));
|
||||
return CurDAG->getMachineNode(MSP430::ADD16ri, dl, MVT::i16,
|
||||
TFI, CurDAG->getTargetConstant(0, MVT::i16));
|
||||
return CurDAG->SelectNodeTo(Node, MSP430::ADD16ri, MVT::i16, TFI,
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i16));
|
||||
return CurDAG->getMachineNode(MSP430::ADD16ri, dl, MVT::i16, TFI,
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i16));
|
||||
}
|
||||
case ISD::LOAD:
|
||||
if (SDNode *ResNode = SelectIndexedLoad(Node))
|
||||
|
|
|
@ -593,7 +593,7 @@ MSP430TargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
|||
// Get a count of how many bytes are to be pushed on the stack.
|
||||
unsigned NumBytes = CCInfo.getNextStackOffset();
|
||||
|
||||
Chain = DAG.getCALLSEQ_START(Chain ,DAG.getConstant(NumBytes,
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getConstant(NumBytes, dl,
|
||||
getPointerTy(), true),
|
||||
dl);
|
||||
|
||||
|
@ -634,13 +634,14 @@ MSP430TargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
|||
|
||||
SDValue PtrOff = DAG.getNode(ISD::ADD, dl, getPointerTy(),
|
||||
StackPtr,
|
||||
DAG.getIntPtrConstant(VA.getLocMemOffset()));
|
||||
DAG.getIntPtrConstant(VA.getLocMemOffset(),
|
||||
dl));
|
||||
|
||||
SDValue MemOp;
|
||||
ISD::ArgFlagsTy Flags = Outs[i].Flags;
|
||||
|
||||
if (Flags.isByVal()) {
|
||||
SDValue SizeNode = DAG.getConstant(Flags.getByValSize(), MVT::i16);
|
||||
SDValue SizeNode = DAG.getConstant(Flags.getByValSize(), dl, MVT::i16);
|
||||
MemOp = DAG.getMemcpy(Chain, dl, PtrOff, Arg, SizeNode,
|
||||
Flags.getByValAlign(),
|
||||
/*isVolatile*/false,
|
||||
|
@ -700,8 +701,9 @@ MSP430TargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
|||
|
||||
// Create the CALLSEQ_END node.
|
||||
Chain = DAG.getCALLSEQ_END(Chain,
|
||||
DAG.getConstant(NumBytes, getPointerTy(), true),
|
||||
DAG.getConstant(0, getPointerTy(), true),
|
||||
DAG.getConstant(NumBytes, dl, getPointerTy(),
|
||||
true),
|
||||
DAG.getConstant(0, dl, getPointerTy(), true),
|
||||
InFlag, dl);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
|
@ -843,7 +845,7 @@ static SDValue EmitCMP(SDValue &LHS, SDValue &RHS, SDValue &TargetCC,
|
|||
// fold constant into instruction.
|
||||
if (const ConstantSDNode * C = dyn_cast<ConstantSDNode>(LHS)) {
|
||||
LHS = RHS;
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, C->getValueType(0));
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, dl, C->getValueType(0));
|
||||
TCC = MSP430CC::COND_LO;
|
||||
break;
|
||||
}
|
||||
|
@ -856,7 +858,7 @@ static SDValue EmitCMP(SDValue &LHS, SDValue &RHS, SDValue &TargetCC,
|
|||
// fold constant into instruction.
|
||||
if (const ConstantSDNode * C = dyn_cast<ConstantSDNode>(LHS)) {
|
||||
LHS = RHS;
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, C->getValueType(0));
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, dl, C->getValueType(0));
|
||||
TCC = MSP430CC::COND_HS;
|
||||
break;
|
||||
}
|
||||
|
@ -869,7 +871,7 @@ static SDValue EmitCMP(SDValue &LHS, SDValue &RHS, SDValue &TargetCC,
|
|||
// fold constant into instruction.
|
||||
if (const ConstantSDNode * C = dyn_cast<ConstantSDNode>(LHS)) {
|
||||
LHS = RHS;
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, C->getValueType(0));
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, dl, C->getValueType(0));
|
||||
TCC = MSP430CC::COND_L;
|
||||
break;
|
||||
}
|
||||
|
@ -882,7 +884,7 @@ static SDValue EmitCMP(SDValue &LHS, SDValue &RHS, SDValue &TargetCC,
|
|||
// fold constant into instruction.
|
||||
if (const ConstantSDNode * C = dyn_cast<ConstantSDNode>(LHS)) {
|
||||
LHS = RHS;
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, C->getValueType(0));
|
||||
RHS = DAG.getConstant(C->getSExtValue() + 1, dl, C->getValueType(0));
|
||||
TCC = MSP430CC::COND_GE;
|
||||
break;
|
||||
}
|
||||
|
@ -890,7 +892,7 @@ static SDValue EmitCMP(SDValue &LHS, SDValue &RHS, SDValue &TargetCC,
|
|||
break;
|
||||
}
|
||||
|
||||
TargetCC = DAG.getConstant(TCC, MVT::i8);
|
||||
TargetCC = DAG.getConstant(TCC, dl, MVT::i8);
|
||||
return DAG.getNode(MSP430ISD::CMP, dl, MVT::Glue, LHS, RHS);
|
||||
}
|
||||
|
||||
|
@ -967,7 +969,7 @@ SDValue MSP430TargetLowering::LowerSETCC(SDValue Op, SelectionDAG &DAG) const {
|
|||
break;
|
||||
}
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue One = DAG.getConstant(1, VT);
|
||||
SDValue One = DAG.getConstant(1, dl, VT);
|
||||
if (Convert) {
|
||||
SDValue SR = DAG.getCopyFromReg(DAG.getEntryNode(), dl, MSP430::SR,
|
||||
MVT::i16, Flag);
|
||||
|
@ -979,7 +981,7 @@ SDValue MSP430TargetLowering::LowerSETCC(SDValue Op, SelectionDAG &DAG) const {
|
|||
SR = DAG.getNode(ISD::XOR, dl, MVT::i16, SR, One);
|
||||
return SR;
|
||||
} else {
|
||||
SDValue Zero = DAG.getConstant(0, VT);
|
||||
SDValue Zero = DAG.getConstant(0, dl, VT);
|
||||
SDVTList VTs = DAG.getVTList(Op.getValueType(), MVT::Glue);
|
||||
SDValue Ops[] = {One, Zero, TargetCC, Flag};
|
||||
return DAG.getNode(MSP430ISD::SELECT_CC, dl, VTs, Ops);
|
||||
|
@ -1048,7 +1050,7 @@ SDValue MSP430TargetLowering::LowerRETURNADDR(SDValue Op,
|
|||
if (Depth > 0) {
|
||||
SDValue FrameAddr = LowerFRAMEADDR(Op, DAG);
|
||||
SDValue Offset =
|
||||
DAG.getConstant(getDataLayout()->getPointerSize(), MVT::i16);
|
||||
DAG.getConstant(getDataLayout()->getPointerSize(), dl, MVT::i16);
|
||||
return DAG.getLoad(getPointerTy(), dl, DAG.getEntryNode(),
|
||||
DAG.getNode(ISD::ADD, dl, getPointerTy(),
|
||||
FrameAddr, Offset),
|
||||
|
@ -1129,7 +1131,7 @@ bool MSP430TargetLowering::getPostIndexedAddressParts(SDNode *N, SDNode *Op,
|
|||
return false;
|
||||
|
||||
Base = Op->getOperand(0);
|
||||
Offset = DAG.getConstant(RHSC, VT);
|
||||
Offset = DAG.getConstant(RHSC, SDLoc(N), VT);
|
||||
AM = ISD::POST_INC;
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -163,14 +163,15 @@ void Mips16DAGToDAGISel::getMips16SPRefReg(SDNode *Parent, SDValue &AliasReg) {
|
|||
bool Mips16DAGToDAGISel::selectAddr16(
|
||||
SDNode *Parent, SDValue Addr, SDValue &Base, SDValue &Offset,
|
||||
SDValue &Alias) {
|
||||
SDLoc DL(Addr);
|
||||
EVT ValTy = Addr.getValueType();
|
||||
|
||||
Alias = CurDAG->getTargetConstant(0, ValTy);
|
||||
Alias = CurDAG->getTargetConstant(0, DL, ValTy);
|
||||
|
||||
// if Address is FI, get the TargetFrameIndex.
|
||||
if (FrameIndexSDNode *FIN = dyn_cast<FrameIndexSDNode>(Addr)) {
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), ValTy);
|
||||
Offset = CurDAG->getTargetConstant(0, ValTy);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, ValTy);
|
||||
getMips16SPRefReg(Parent, Alias);
|
||||
return true;
|
||||
}
|
||||
|
@ -199,7 +200,7 @@ bool Mips16DAGToDAGISel::selectAddr16(
|
|||
else
|
||||
Base = Addr.getOperand(0);
|
||||
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), ValTy);
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), DL, ValTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -235,7 +236,7 @@ bool Mips16DAGToDAGISel::selectAddr16(
|
|||
}
|
||||
}
|
||||
Base = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, ValTy);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, ValTy);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -119,7 +119,7 @@ private:
|
|||
|
||||
// getImm - Return a target constant with the specified value.
|
||||
inline SDValue getImm(const SDNode *Node, uint64_t Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, Node->getValueType(0));
|
||||
return CurDAG->getTargetConstant(Imm, SDLoc(Node), Node->getValueType(0));
|
||||
}
|
||||
|
||||
virtual void processFunctionAfterISel(MachineFunction &MF) = 0;
|
||||
|
|
|
@ -544,7 +544,7 @@ static SDValue createFPCmp(SelectionDAG &DAG, const SDValue &Op) {
|
|||
ISD::CondCode CC = cast<CondCodeSDNode>(Op.getOperand(2))->get();
|
||||
|
||||
return DAG.getNode(MipsISD::FPCmp, DL, MVT::Glue, LHS, RHS,
|
||||
DAG.getConstant(condCodeToFCC(CC), MVT::i32));
|
||||
DAG.getConstant(condCodeToFCC(CC), DL, MVT::i32));
|
||||
}
|
||||
|
||||
// Creates and returns a CMovFPT/F node.
|
||||
|
@ -699,9 +699,11 @@ static SDValue performANDCombine(SDNode *N, SelectionDAG &DAG,
|
|||
if (SMPos != 0 || Pos + SMSize > ValTy.getSizeInBits())
|
||||
return SDValue();
|
||||
|
||||
return DAG.getNode(MipsISD::Ext, SDLoc(N), ValTy,
|
||||
ShiftRight.getOperand(0), DAG.getConstant(Pos, MVT::i32),
|
||||
DAG.getConstant(SMSize, MVT::i32));
|
||||
SDLoc DL(N);
|
||||
return DAG.getNode(MipsISD::Ext, DL, ValTy,
|
||||
ShiftRight.getOperand(0),
|
||||
DAG.getConstant(Pos, DL, MVT::i32),
|
||||
DAG.getConstant(SMSize, DL, MVT::i32));
|
||||
}
|
||||
|
||||
static SDValue performORCombine(SDNode *N, SelectionDAG &DAG,
|
||||
|
@ -753,9 +755,11 @@ static SDValue performORCombine(SDNode *N, SelectionDAG &DAG,
|
|||
if ((Shamt != SMPos0) || (SMPos0 + SMSize0 > ValTy.getSizeInBits()))
|
||||
return SDValue();
|
||||
|
||||
return DAG.getNode(MipsISD::Ins, SDLoc(N), ValTy, Shl.getOperand(0),
|
||||
DAG.getConstant(SMPos0, MVT::i32),
|
||||
DAG.getConstant(SMSize0, MVT::i32), And0.getOperand(0));
|
||||
SDLoc DL(N);
|
||||
return DAG.getNode(MipsISD::Ins, DL, ValTy, Shl.getOperand(0),
|
||||
DAG.getConstant(SMPos0, DL, MVT::i32),
|
||||
DAG.getConstant(SMSize0, DL, MVT::i32),
|
||||
And0.getOperand(0));
|
||||
}
|
||||
|
||||
static SDValue performADDCombine(SDNode *N, SelectionDAG &DAG,
|
||||
|
@ -1556,7 +1560,7 @@ SDValue MipsTargetLowering::lowerBR_JT(SDValue Op, SelectionDAG &DAG) const {
|
|||
DAG.getMachineFunction().getJumpTableInfo()->getEntrySize(*getDataLayout());
|
||||
|
||||
Index = DAG.getNode(ISD::MUL, DL, PTy, Index,
|
||||
DAG.getConstant(EntrySize, PTy));
|
||||
DAG.getConstant(EntrySize, DL, PTy));
|
||||
SDValue Addr = DAG.getNode(ISD::ADD, DL, PTy, Index, Table);
|
||||
|
||||
EVT MemVT = EVT::getIntegerVT(*DAG.getContext(), EntrySize * 8);
|
||||
|
@ -1594,7 +1598,7 @@ SDValue MipsTargetLowering::lowerBRCOND(SDValue Op, SelectionDAG &DAG) const {
|
|||
Mips::CondCode CC =
|
||||
(Mips::CondCode)cast<ConstantSDNode>(CCNode)->getZExtValue();
|
||||
unsigned Opc = invertFPCondCodeUser(CC) ? Mips::BRANCH_F : Mips::BRANCH_T;
|
||||
SDValue BrCode = DAG.getConstant(Opc, MVT::i32);
|
||||
SDValue BrCode = DAG.getConstant(Opc, DL, MVT::i32);
|
||||
SDValue FCC0 = DAG.getRegister(Mips::FCC0, MVT::i32);
|
||||
return DAG.getNode(MipsISD::FPBrcond, DL, Op.getValueType(), Chain, BrCode,
|
||||
FCC0, Dest, CondRes);
|
||||
|
@ -1635,10 +1639,11 @@ SDValue MipsTargetLowering::lowerSETCC(SDValue Op, SelectionDAG &DAG) const {
|
|||
assert(Cond.getOpcode() == MipsISD::FPCmp &&
|
||||
"Floating point operand expected.");
|
||||
|
||||
SDValue True = DAG.getConstant(1, MVT::i32);
|
||||
SDValue False = DAG.getConstant(0, MVT::i32);
|
||||
SDLoc DL(Op);
|
||||
SDValue True = DAG.getConstant(1, DL, MVT::i32);
|
||||
SDValue False = DAG.getConstant(0, DL, MVT::i32);
|
||||
|
||||
return createCMovFP(DAG, Cond, True, False, SDLoc(Op));
|
||||
return createCMovFP(DAG, Cond, True, False, DL);
|
||||
}
|
||||
|
||||
SDValue MipsTargetLowering::lowerGlobalAddress(SDValue Op,
|
||||
|
@ -1837,19 +1842,19 @@ SDValue MipsTargetLowering::lowerVAARG(SDValue Op, SelectionDAG &DAG) const {
|
|||
assert(((Align & (Align-1)) == 0) && "Expected Align to be a power of 2");
|
||||
|
||||
VAList = DAG.getNode(ISD::ADD, DL, VAList.getValueType(), VAList,
|
||||
DAG.getConstant(Align - 1,
|
||||
VAList.getValueType()));
|
||||
DAG.getConstant(Align - 1, DL, VAList.getValueType()));
|
||||
|
||||
VAList = DAG.getNode(ISD::AND, DL, VAList.getValueType(), VAList,
|
||||
DAG.getConstant(-(int64_t)Align,
|
||||
DAG.getConstant(-(int64_t)Align, DL,
|
||||
VAList.getValueType()));
|
||||
}
|
||||
|
||||
// Increment the pointer, VAList, to the next vaarg.
|
||||
unsigned ArgSizeInBytes = getDataLayout()->getTypeAllocSize(VT.getTypeForEVT(*DAG.getContext()));
|
||||
SDValue Tmp3 = DAG.getNode(ISD::ADD, DL, VAList.getValueType(), VAList,
|
||||
DAG.getConstant(RoundUpToAlignment(ArgSizeInBytes, ArgSlotSizeInBytes),
|
||||
VAList.getValueType()));
|
||||
DAG.getConstant(RoundUpToAlignment(ArgSizeInBytes,
|
||||
ArgSlotSizeInBytes),
|
||||
DL, VAList.getValueType()));
|
||||
// Store the incremented VAList to the legalized pointer
|
||||
Chain = DAG.getStore(VAListLoad.getValue(1), DL, Tmp3, VAListPtr,
|
||||
MachinePointerInfo(SV), false, false, 0);
|
||||
|
@ -1862,7 +1867,7 @@ SDValue MipsTargetLowering::lowerVAARG(SDValue Op, SelectionDAG &DAG) const {
|
|||
if (!Subtarget.isLittle() && ArgSizeInBytes < ArgSlotSizeInBytes) {
|
||||
unsigned Adjustment = ArgSlotSizeInBytes - ArgSizeInBytes;
|
||||
VAList = DAG.getNode(ISD::ADD, DL, VAListPtr.getValueType(), VAList,
|
||||
DAG.getIntPtrConstant(Adjustment));
|
||||
DAG.getIntPtrConstant(Adjustment, DL));
|
||||
}
|
||||
// Load the actual argument out of the pointer VAList
|
||||
return DAG.getLoad(VT, DL, Chain, VAList, MachinePointerInfo(), false, false,
|
||||
|
@ -1873,9 +1878,9 @@ static SDValue lowerFCOPYSIGN32(SDValue Op, SelectionDAG &DAG,
|
|||
bool HasExtractInsert) {
|
||||
EVT TyX = Op.getOperand(0).getValueType();
|
||||
EVT TyY = Op.getOperand(1).getValueType();
|
||||
SDValue Const1 = DAG.getConstant(1, MVT::i32);
|
||||
SDValue Const31 = DAG.getConstant(31, MVT::i32);
|
||||
SDLoc DL(Op);
|
||||
SDValue Const1 = DAG.getConstant(1, DL, MVT::i32);
|
||||
SDValue Const31 = DAG.getConstant(31, DL, MVT::i32);
|
||||
SDValue Res;
|
||||
|
||||
// If operand is of type f64, extract the upper 32-bit. Otherwise, bitcast it
|
||||
|
@ -1911,7 +1916,8 @@ static SDValue lowerFCOPYSIGN32(SDValue Op, SelectionDAG &DAG,
|
|||
return DAG.getNode(ISD::BITCAST, DL, Op.getOperand(0).getValueType(), Res);
|
||||
|
||||
SDValue LowX = DAG.getNode(MipsISD::ExtractElementF64, DL, MVT::i32,
|
||||
Op.getOperand(0), DAG.getConstant(0, MVT::i32));
|
||||
Op.getOperand(0),
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
return DAG.getNode(MipsISD::BuildPairF64, DL, MVT::f64, LowX, Res);
|
||||
}
|
||||
|
||||
|
@ -1920,8 +1926,8 @@ static SDValue lowerFCOPYSIGN64(SDValue Op, SelectionDAG &DAG,
|
|||
unsigned WidthX = Op.getOperand(0).getValueSizeInBits();
|
||||
unsigned WidthY = Op.getOperand(1).getValueSizeInBits();
|
||||
EVT TyX = MVT::getIntegerVT(WidthX), TyY = MVT::getIntegerVT(WidthY);
|
||||
SDValue Const1 = DAG.getConstant(1, MVT::i32);
|
||||
SDLoc DL(Op);
|
||||
SDValue Const1 = DAG.getConstant(1, DL, MVT::i32);
|
||||
|
||||
// Bitcast to integer nodes.
|
||||
SDValue X = DAG.getNode(ISD::BITCAST, DL, TyX, Op.getOperand(0));
|
||||
|
@ -1931,7 +1937,7 @@ static SDValue lowerFCOPYSIGN64(SDValue Op, SelectionDAG &DAG,
|
|||
// ext E, Y, width(Y) - 1, 1 ; extract bit width(Y)-1 of Y
|
||||
// ins X, E, width(X) - 1, 1 ; insert extracted bit at bit width(X)-1 of X
|
||||
SDValue E = DAG.getNode(MipsISD::Ext, DL, TyY, Y,
|
||||
DAG.getConstant(WidthY - 1, MVT::i32), Const1);
|
||||
DAG.getConstant(WidthY - 1, DL, MVT::i32), Const1);
|
||||
|
||||
if (WidthX > WidthY)
|
||||
E = DAG.getNode(ISD::ZERO_EXTEND, DL, TyX, E);
|
||||
|
@ -1939,7 +1945,8 @@ static SDValue lowerFCOPYSIGN64(SDValue Op, SelectionDAG &DAG,
|
|||
E = DAG.getNode(ISD::TRUNCATE, DL, TyX, E);
|
||||
|
||||
SDValue I = DAG.getNode(MipsISD::Ins, DL, TyX, E,
|
||||
DAG.getConstant(WidthX - 1, MVT::i32), Const1, X);
|
||||
DAG.getConstant(WidthX - 1, DL, MVT::i32), Const1,
|
||||
X);
|
||||
return DAG.getNode(ISD::BITCAST, DL, Op.getOperand(0).getValueType(), I);
|
||||
}
|
||||
|
||||
|
@ -1951,7 +1958,7 @@ static SDValue lowerFCOPYSIGN64(SDValue Op, SelectionDAG &DAG,
|
|||
SDValue SllX = DAG.getNode(ISD::SHL, DL, TyX, X, Const1);
|
||||
SDValue SrlX = DAG.getNode(ISD::SRL, DL, TyX, SllX, Const1);
|
||||
SDValue SrlY = DAG.getNode(ISD::SRL, DL, TyY, Y,
|
||||
DAG.getConstant(WidthY - 1, MVT::i32));
|
||||
DAG.getConstant(WidthY - 1, DL, MVT::i32));
|
||||
|
||||
if (WidthX > WidthY)
|
||||
SrlY = DAG.getNode(ISD::ZERO_EXTEND, DL, TyX, SrlY);
|
||||
|
@ -1959,7 +1966,7 @@ static SDValue lowerFCOPYSIGN64(SDValue Op, SelectionDAG &DAG,
|
|||
SrlY = DAG.getNode(ISD::TRUNCATE, DL, TyX, SrlY);
|
||||
|
||||
SDValue SllY = DAG.getNode(ISD::SHL, DL, TyX, SrlY,
|
||||
DAG.getConstant(WidthX - 1, MVT::i32));
|
||||
DAG.getConstant(WidthX - 1, DL, MVT::i32));
|
||||
SDValue Or = DAG.getNode(ISD::OR, DL, TyX, SrlX, SllY);
|
||||
return DAG.getNode(ISD::BITCAST, DL, Op.getOperand(0).getValueType(), Or);
|
||||
}
|
||||
|
@ -2042,7 +2049,7 @@ SDValue MipsTargetLowering::lowerATOMIC_FENCE(SDValue Op,
|
|||
unsigned SType = 0;
|
||||
SDLoc DL(Op);
|
||||
return DAG.getNode(MipsISD::Sync, DL, MVT::Other, Op.getOperand(0),
|
||||
DAG.getConstant(SType, MVT::i32));
|
||||
DAG.getConstant(SType, DL, MVT::i32));
|
||||
}
|
||||
|
||||
SDValue MipsTargetLowering::lowerShiftLeftParts(SDValue Op,
|
||||
|
@ -2059,17 +2066,17 @@ SDValue MipsTargetLowering::lowerShiftLeftParts(SDValue Op,
|
|||
// lo = 0
|
||||
// hi = (shl lo, shamt[4:0])
|
||||
SDValue Not = DAG.getNode(ISD::XOR, DL, MVT::i32, Shamt,
|
||||
DAG.getConstant(-1, MVT::i32));
|
||||
DAG.getConstant(-1, DL, MVT::i32));
|
||||
SDValue ShiftRight1Lo = DAG.getNode(ISD::SRL, DL, VT, Lo,
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, DL, VT));
|
||||
SDValue ShiftRightLo = DAG.getNode(ISD::SRL, DL, VT, ShiftRight1Lo, Not);
|
||||
SDValue ShiftLeftHi = DAG.getNode(ISD::SHL, DL, VT, Hi, Shamt);
|
||||
SDValue Or = DAG.getNode(ISD::OR, DL, VT, ShiftLeftHi, ShiftRightLo);
|
||||
SDValue ShiftLeftLo = DAG.getNode(ISD::SHL, DL, VT, Lo, Shamt);
|
||||
SDValue Cond = DAG.getNode(ISD::AND, DL, MVT::i32, Shamt,
|
||||
DAG.getConstant(0x20, MVT::i32));
|
||||
DAG.getConstant(0x20, DL, MVT::i32));
|
||||
Lo = DAG.getNode(ISD::SELECT, DL, VT, Cond,
|
||||
DAG.getConstant(0, VT), ShiftLeftLo);
|
||||
DAG.getConstant(0, DL, VT), ShiftLeftLo);
|
||||
Hi = DAG.getNode(ISD::SELECT, DL, VT, Cond, ShiftLeftLo, Or);
|
||||
|
||||
SDValue Ops[2] = {Lo, Hi};
|
||||
|
@ -2097,20 +2104,21 @@ SDValue MipsTargetLowering::lowerShiftRightParts(SDValue Op, SelectionDAG &DAG,
|
|||
// lo = (srl hi, shamt[4:0])
|
||||
// hi = 0
|
||||
SDValue Not = DAG.getNode(ISD::XOR, DL, MVT::i32, Shamt,
|
||||
DAG.getConstant(-1, MVT::i32));
|
||||
DAG.getConstant(-1, DL, MVT::i32));
|
||||
SDValue ShiftLeft1Hi = DAG.getNode(ISD::SHL, DL, VT, Hi,
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, DL, VT));
|
||||
SDValue ShiftLeftHi = DAG.getNode(ISD::SHL, DL, VT, ShiftLeft1Hi, Not);
|
||||
SDValue ShiftRightLo = DAG.getNode(ISD::SRL, DL, VT, Lo, Shamt);
|
||||
SDValue Or = DAG.getNode(ISD::OR, DL, VT, ShiftLeftHi, ShiftRightLo);
|
||||
SDValue ShiftRightHi = DAG.getNode(IsSRA ? ISD::SRA : ISD::SRL,
|
||||
DL, VT, Hi, Shamt);
|
||||
SDValue Cond = DAG.getNode(ISD::AND, DL, MVT::i32, Shamt,
|
||||
DAG.getConstant(0x20, MVT::i32));
|
||||
SDValue Shift31 = DAG.getNode(ISD::SRA, DL, VT, Hi, DAG.getConstant(31, VT));
|
||||
DAG.getConstant(0x20, DL, MVT::i32));
|
||||
SDValue Shift31 = DAG.getNode(ISD::SRA, DL, VT, Hi,
|
||||
DAG.getConstant(31, DL, VT));
|
||||
Lo = DAG.getNode(ISD::SELECT, DL, VT, Cond, ShiftRightHi, Or);
|
||||
Hi = DAG.getNode(ISD::SELECT, DL, VT, Cond,
|
||||
IsSRA ? Shift31 : DAG.getConstant(0, VT), ShiftRightHi);
|
||||
IsSRA ? Shift31 : DAG.getConstant(0, DL, VT), ShiftRightHi);
|
||||
|
||||
SDValue Ops[2] = {Lo, Hi};
|
||||
return DAG.getMergeValues(Ops, DL);
|
||||
|
@ -2126,7 +2134,7 @@ static SDValue createLoadLR(unsigned Opc, SelectionDAG &DAG, LoadSDNode *LD,
|
|||
|
||||
if (Offset)
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, BasePtrVT, Ptr,
|
||||
DAG.getConstant(Offset, BasePtrVT));
|
||||
DAG.getConstant(Offset, DL, BasePtrVT));
|
||||
|
||||
SDValue Ops[] = { Chain, Ptr, Src };
|
||||
return DAG.getMemIntrinsicNode(Opc, DL, VTList, Ops, MemVT,
|
||||
|
@ -2191,7 +2199,7 @@ SDValue MipsTargetLowering::lowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
// (set tmp2, (shl tmp1, 32))
|
||||
// (set dst, (srl tmp2, 32))
|
||||
SDLoc DL(LD);
|
||||
SDValue Const32 = DAG.getConstant(32, MVT::i32);
|
||||
SDValue Const32 = DAG.getConstant(32, DL, MVT::i32);
|
||||
SDValue SLL = DAG.getNode(ISD::SHL, DL, MVT::i64, LWR, Const32);
|
||||
SDValue SRL = DAG.getNode(ISD::SRL, DL, MVT::i64, SLL, Const32);
|
||||
SDValue Ops[] = { SRL, LWR.getValue(1) };
|
||||
|
@ -2207,7 +2215,7 @@ static SDValue createStoreLR(unsigned Opc, SelectionDAG &DAG, StoreSDNode *SD,
|
|||
|
||||
if (Offset)
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, BasePtrVT, Ptr,
|
||||
DAG.getConstant(Offset, BasePtrVT));
|
||||
DAG.getConstant(Offset, DL, BasePtrVT));
|
||||
|
||||
SDValue Ops[] = { Chain, Value, Ptr };
|
||||
return DAG.getMemIntrinsicNode(Opc, DL, VTList, Ops, MemVT,
|
||||
|
@ -2289,8 +2297,9 @@ SDValue MipsTargetLowering::lowerADD(SDValue Op, SelectionDAG &DAG) const {
|
|||
EVT ValTy = Op->getValueType(0);
|
||||
int FI = MFI->CreateFixedObject(Op.getValueSizeInBits() / 8, 0, false);
|
||||
SDValue InArgsAddr = DAG.getFrameIndex(FI, ValTy);
|
||||
return DAG.getNode(ISD::ADD, SDLoc(Op), ValTy, InArgsAddr,
|
||||
DAG.getConstant(0, ValTy));
|
||||
SDLoc DL(Op);
|
||||
return DAG.getNode(ISD::ADD, DL, ValTy, InArgsAddr,
|
||||
DAG.getConstant(0, DL, ValTy));
|
||||
}
|
||||
|
||||
SDValue MipsTargetLowering::lowerFP_TO_SINT(SDValue Op,
|
||||
|
@ -2447,7 +2456,7 @@ MipsTargetLowering::passArgOnStack(SDValue StackPtr, unsigned Offset,
|
|||
bool IsTailCall, SelectionDAG &DAG) const {
|
||||
if (!IsTailCall) {
|
||||
SDValue PtrOff = DAG.getNode(ISD::ADD, DL, getPointerTy(), StackPtr,
|
||||
DAG.getIntPtrConstant(Offset));
|
||||
DAG.getIntPtrConstant(Offset, DL));
|
||||
return DAG.getStore(Chain, DL, Arg, PtrOff, MachinePointerInfo(), false,
|
||||
false, 0);
|
||||
}
|
||||
|
@ -2573,7 +2582,7 @@ MipsTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
// byval arguments to the stack.
|
||||
unsigned StackAlignment = TFL->getStackAlignment();
|
||||
NextStackOffset = RoundUpToAlignment(NextStackOffset, StackAlignment);
|
||||
SDValue NextStackOffsetVal = DAG.getIntPtrConstant(NextStackOffset, true);
|
||||
SDValue NextStackOffsetVal = DAG.getIntPtrConstant(NextStackOffset, DL, true);
|
||||
|
||||
if (!IsTailCall)
|
||||
Chain = DAG.getCALLSEQ_START(Chain, NextStackOffsetVal, DL);
|
||||
|
@ -2625,9 +2634,9 @@ MipsTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
Arg = DAG.getNode(ISD::BITCAST, DL, LocVT, Arg);
|
||||
else if (ValVT == MVT::f64 && LocVT == MVT::i32) {
|
||||
SDValue Lo = DAG.getNode(MipsISD::ExtractElementF64, DL, MVT::i32,
|
||||
Arg, DAG.getConstant(0, MVT::i32));
|
||||
Arg, DAG.getConstant(0, DL, MVT::i32));
|
||||
SDValue Hi = DAG.getNode(MipsISD::ExtractElementF64, DL, MVT::i32,
|
||||
Arg, DAG.getConstant(1, MVT::i32));
|
||||
Arg, DAG.getConstant(1, DL, MVT::i32));
|
||||
if (!Subtarget.isLittle())
|
||||
std::swap(Lo, Hi);
|
||||
unsigned LocRegLo = VA.getLocReg();
|
||||
|
@ -2666,7 +2675,7 @@ MipsTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
unsigned LocSizeInBits = VA.getLocVT().getSizeInBits();
|
||||
Arg = DAG.getNode(
|
||||
ISD::SHL, DL, VA.getLocVT(), Arg,
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, VA.getLocVT()));
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, DL, VA.getLocVT()));
|
||||
}
|
||||
|
||||
// Arguments that can be passed on register must be kept at
|
||||
|
@ -2755,7 +2764,7 @@ MipsTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
|
||||
// Create the CALLSEQ_END node.
|
||||
Chain = DAG.getCALLSEQ_END(Chain, NextStackOffsetVal,
|
||||
DAG.getIntPtrConstant(0, true), InFlag, DL);
|
||||
DAG.getIntPtrConstant(0, DL, true), InFlag, DL);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
// Handle result values, copying them out of physregs into vregs that we
|
||||
|
@ -2794,7 +2803,7 @@ SDValue MipsTargetLowering::LowerCallResult(
|
|||
VA.getLocInfo() == CCValAssign::ZExtUpper ? ISD::SRL : ISD::SRA;
|
||||
Val = DAG.getNode(
|
||||
Shift, DL, VA.getLocVT(), Val,
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, VA.getLocVT()));
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, DL, VA.getLocVT()));
|
||||
}
|
||||
|
||||
switch (VA.getLocInfo()) {
|
||||
|
@ -2847,7 +2856,7 @@ static SDValue UnpackFromArgumentSlot(SDValue Val, const CCValAssign &VA,
|
|||
VA.getLocInfo() == CCValAssign::ZExtUpper ? ISD::SRL : ISD::SRA;
|
||||
Val = DAG.getNode(
|
||||
Opcode, DL, VA.getLocVT(), Val,
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, VA.getLocVT()));
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, DL, VA.getLocVT()));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3121,7 +3130,7 @@ MipsTargetLowering::LowerReturn(SDValue Chain,
|
|||
unsigned LocSizeInBits = VA.getLocVT().getSizeInBits();
|
||||
Val = DAG.getNode(
|
||||
ISD::SHL, DL, VA.getLocVT(), Val,
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, VA.getLocVT()));
|
||||
DAG.getConstant(LocSizeInBits - ValSizeInBits, DL, VA.getLocVT()));
|
||||
}
|
||||
|
||||
Chain = DAG.getCopyToReg(Chain, DL, VA.getLocReg(), Val, Flag);
|
||||
|
@ -3423,6 +3432,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
std::string &Constraint,
|
||||
std::vector<SDValue>&Ops,
|
||||
SelectionDAG &DAG) const {
|
||||
SDLoc DL(Op);
|
||||
SDValue Result;
|
||||
|
||||
// Only support length 1 constraints for now.
|
||||
|
@ -3437,7 +3447,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
int64_t Val = C->getSExtValue();
|
||||
if (isInt<16>(Val)) {
|
||||
Result = DAG.getTargetConstant(Val, Type);
|
||||
Result = DAG.getTargetConstant(Val, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3447,7 +3457,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
int64_t Val = C->getZExtValue();
|
||||
if (Val == 0) {
|
||||
Result = DAG.getTargetConstant(0, Type);
|
||||
Result = DAG.getTargetConstant(0, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3457,7 +3467,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
uint64_t Val = (uint64_t)C->getZExtValue();
|
||||
if (isUInt<16>(Val)) {
|
||||
Result = DAG.getTargetConstant(Val, Type);
|
||||
Result = DAG.getTargetConstant(Val, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3467,7 +3477,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
int64_t Val = C->getSExtValue();
|
||||
if ((isInt<32>(Val)) && ((Val & 0xffff) == 0)){
|
||||
Result = DAG.getTargetConstant(Val, Type);
|
||||
Result = DAG.getTargetConstant(Val, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3477,7 +3487,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
int64_t Val = C->getSExtValue();
|
||||
if ((Val >= -65535) && (Val <= -1)) {
|
||||
Result = DAG.getTargetConstant(Val, Type);
|
||||
Result = DAG.getTargetConstant(Val, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3487,7 +3497,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
int64_t Val = C->getSExtValue();
|
||||
if ((isInt<15>(Val))) {
|
||||
Result = DAG.getTargetConstant(Val, Type);
|
||||
Result = DAG.getTargetConstant(Val, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3497,7 +3507,7 @@ void MipsTargetLowering::LowerAsmOperandForConstraint(SDValue Op,
|
|||
EVT Type = Op.getValueType();
|
||||
int64_t Val = C->getSExtValue();
|
||||
if ((Val <= 65535) && (Val >= 1)) {
|
||||
Result = DAG.getTargetConstant(Val, Type);
|
||||
Result = DAG.getTargetConstant(Val, DL, Type);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -3603,7 +3613,7 @@ void MipsTargetLowering::copyByValRegs(
|
|||
unsigned VReg = addLiveIn(MF, ArgReg, RC);
|
||||
unsigned Offset = I * GPRSizeInBytes;
|
||||
SDValue StorePtr = DAG.getNode(ISD::ADD, DL, PtrTy, FIN,
|
||||
DAG.getConstant(Offset, PtrTy));
|
||||
DAG.getConstant(Offset, DL, PtrTy));
|
||||
SDValue Store = DAG.getStore(Chain, DL, DAG.getRegister(VReg, RegTy),
|
||||
StorePtr, MachinePointerInfo(FuncArg, Offset),
|
||||
false, false, 0);
|
||||
|
@ -3634,7 +3644,7 @@ void MipsTargetLowering::passByValArg(
|
|||
// Copy words to registers.
|
||||
for (; I < NumRegs - LeftoverBytes; ++I, OffsetInBytes += RegSizeInBytes) {
|
||||
SDValue LoadPtr = DAG.getNode(ISD::ADD, DL, PtrTy, Arg,
|
||||
DAG.getConstant(OffsetInBytes, PtrTy));
|
||||
DAG.getConstant(OffsetInBytes, DL, PtrTy));
|
||||
SDValue LoadVal = DAG.getLoad(RegTy, DL, Chain, LoadPtr,
|
||||
MachinePointerInfo(), false, false, false,
|
||||
Alignment);
|
||||
|
@ -3660,7 +3670,8 @@ void MipsTargetLowering::passByValArg(
|
|||
|
||||
// Load subword.
|
||||
SDValue LoadPtr = DAG.getNode(ISD::ADD, DL, PtrTy, Arg,
|
||||
DAG.getConstant(OffsetInBytes, PtrTy));
|
||||
DAG.getConstant(OffsetInBytes, DL,
|
||||
PtrTy));
|
||||
SDValue LoadVal = DAG.getExtLoad(
|
||||
ISD::ZEXTLOAD, DL, RegTy, Chain, LoadPtr, MachinePointerInfo(),
|
||||
MVT::getIntegerVT(LoadSizeInBytes * 8), false, false, false,
|
||||
|
@ -3676,7 +3687,7 @@ void MipsTargetLowering::passByValArg(
|
|||
Shamt = (RegSizeInBytes - (TotalBytesLoaded + LoadSizeInBytes)) * 8;
|
||||
|
||||
SDValue Shift = DAG.getNode(ISD::SHL, DL, RegTy, LoadVal,
|
||||
DAG.getConstant(Shamt, MVT::i32));
|
||||
DAG.getConstant(Shamt, DL, MVT::i32));
|
||||
|
||||
if (Val.getNode())
|
||||
Val = DAG.getNode(ISD::OR, DL, RegTy, Val, Shift);
|
||||
|
@ -3697,10 +3708,11 @@ void MipsTargetLowering::passByValArg(
|
|||
// Copy remainder of byval arg to it with memcpy.
|
||||
unsigned MemCpySize = ByValSizeInBytes - OffsetInBytes;
|
||||
SDValue Src = DAG.getNode(ISD::ADD, DL, PtrTy, Arg,
|
||||
DAG.getConstant(OffsetInBytes, PtrTy));
|
||||
DAG.getConstant(OffsetInBytes, DL, PtrTy));
|
||||
SDValue Dst = DAG.getNode(ISD::ADD, DL, PtrTy, StackPtr,
|
||||
DAG.getIntPtrConstant(VA.getLocMemOffset()));
|
||||
Chain = DAG.getMemcpy(Chain, DL, Dst, Src, DAG.getConstant(MemCpySize, PtrTy),
|
||||
DAG.getIntPtrConstant(VA.getLocMemOffset(), DL));
|
||||
Chain = DAG.getMemcpy(Chain, DL, Dst, Src,
|
||||
DAG.getConstant(MemCpySize, DL, PtrTy),
|
||||
Alignment, /*isVolatile=*/false, /*AlwaysInline=*/false,
|
||||
/*isTailCall=*/false,
|
||||
MachinePointerInfo(), MachinePointerInfo());
|
||||
|
|
|
@ -253,9 +253,10 @@ SDNode *MipsSEDAGToDAGISel::selectAddESubE(unsigned MOp, SDValue InFlag,
|
|||
// that SLTu64 produces an i32. We need to fix this in the long run but for
|
||||
// now, just make the DAG type-correct by asserting the upper bits are zero.
|
||||
Carry = CurDAG->getMachineNode(Mips::SUBREG_TO_REG, DL, VT,
|
||||
CurDAG->getTargetConstant(0, VT),
|
||||
CurDAG->getTargetConstant(0, DL, VT),
|
||||
SDValue(Carry, 0),
|
||||
CurDAG->getTargetConstant(Mips::sub_32, VT));
|
||||
CurDAG->getTargetConstant(Mips::sub_32, DL,
|
||||
VT));
|
||||
}
|
||||
|
||||
// Generate a second addition only if we know that RHS is not a
|
||||
|
@ -276,7 +277,7 @@ bool MipsSEDAGToDAGISel::selectAddrFrameIndex(SDValue Addr, SDValue &Base,
|
|||
EVT ValTy = Addr.getValueType();
|
||||
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), ValTy);
|
||||
Offset = CurDAG->getTargetConstant(0, ValTy);
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(Addr), ValTy);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
@ -298,7 +299,8 @@ bool MipsSEDAGToDAGISel::selectAddrFrameIndexOffset(SDValue Addr, SDValue &Base,
|
|||
else
|
||||
Base = Addr.getOperand(0);
|
||||
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), ValTy);
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), SDLoc(Addr),
|
||||
ValTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -372,7 +374,7 @@ bool MipsSEDAGToDAGISel::selectAddrRegReg(SDValue Addr, SDValue &Base,
|
|||
bool MipsSEDAGToDAGISel::selectAddrDefault(SDValue Addr, SDValue &Base,
|
||||
SDValue &Offset) const {
|
||||
Base = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, Addr.getValueType());
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(Addr), Addr.getValueType());
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -523,7 +525,7 @@ selectVSplatCommon(SDValue N, SDValue &Imm, bool Signed,
|
|||
ImmValue.getBitWidth() == EltTy.getSizeInBits()) {
|
||||
if (( Signed && ImmValue.isSignedIntN(ImmBitSize)) ||
|
||||
(!Signed && ImmValue.isIntN(ImmBitSize))) {
|
||||
Imm = CurDAG->getTargetConstant(ImmValue, EltTy);
|
||||
Imm = CurDAG->getTargetConstant(ImmValue, SDLoc(N), EltTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -599,7 +601,7 @@ bool MipsSEDAGToDAGISel::selectVSplatUimmPow2(SDValue N, SDValue &Imm) const {
|
|||
int32_t Log2 = ImmValue.exactLogBase2();
|
||||
|
||||
if (Log2 != -1) {
|
||||
Imm = CurDAG->getTargetConstant(Log2, EltTy);
|
||||
Imm = CurDAG->getTargetConstant(Log2, SDLoc(N), EltTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -632,7 +634,8 @@ bool MipsSEDAGToDAGISel::selectVSplatMaskL(SDValue N, SDValue &Imm) const {
|
|||
// as the original value.
|
||||
if (ImmValue == ~(~ImmValue & ~(~ImmValue + 1))) {
|
||||
|
||||
Imm = CurDAG->getTargetConstant(ImmValue.countPopulation(), EltTy);
|
||||
Imm = CurDAG->getTargetConstant(ImmValue.countPopulation(), SDLoc(N),
|
||||
EltTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -663,7 +666,8 @@ bool MipsSEDAGToDAGISel::selectVSplatMaskR(SDValue N, SDValue &Imm) const {
|
|||
// Extract the run of set bits starting with bit zero, and test that the
|
||||
// result is the same as the original value
|
||||
if (ImmValue == (ImmValue & ~(ImmValue + 1))) {
|
||||
Imm = CurDAG->getTargetConstant(ImmValue.countPopulation(), EltTy);
|
||||
Imm = CurDAG->getTargetConstant(ImmValue.countPopulation(), SDLoc(N),
|
||||
EltTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -684,7 +688,7 @@ bool MipsSEDAGToDAGISel::selectVSplatUimmInvPow2(SDValue N,
|
|||
int32_t Log2 = (~ImmValue).exactLogBase2();
|
||||
|
||||
if (Log2 != -1) {
|
||||
Imm = CurDAG->getTargetConstant(Log2, EltTy);
|
||||
Imm = CurDAG->getTargetConstant(Log2, SDLoc(N), EltTy);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -762,7 +766,7 @@ std::pair<bool, SDNode*> MipsSEDAGToDAGISel::selectNode(SDNode *Node) {
|
|||
SDLoc DL(CN);
|
||||
SDNode *RegOpnd;
|
||||
SDValue ImmOpnd = CurDAG->getTargetConstant(SignExtend64<16>(Inst->ImmOpnd),
|
||||
MVT::i64);
|
||||
DL, MVT::i64);
|
||||
|
||||
// The first instruction can be a LUi which is different from other
|
||||
// instructions (ADDiu, ORI and SLL) in that it does not have a register
|
||||
|
@ -777,7 +781,7 @@ std::pair<bool, SDNode*> MipsSEDAGToDAGISel::selectNode(SDNode *Node) {
|
|||
|
||||
// The remaining instructions in the sequence are handled here.
|
||||
for (++Inst; Inst != Seq.end(); ++Inst) {
|
||||
ImmOpnd = CurDAG->getTargetConstant(SignExtend64<16>(Inst->ImmOpnd),
|
||||
ImmOpnd = CurDAG->getTargetConstant(SignExtend64<16>(Inst->ImmOpnd), DL,
|
||||
MVT::i64);
|
||||
RegOpnd = CurDAG->getMachineNode(Inst->Opc, DL, MVT::i64,
|
||||
SDValue(RegOpnd, 0), ImmOpnd);
|
||||
|
@ -848,7 +852,7 @@ std::pair<bool, SDNode*> MipsSEDAGToDAGISel::selectNode(SDNode *Node) {
|
|||
}
|
||||
|
||||
SDNode *Rdhwr =
|
||||
CurDAG->getMachineNode(RdhwrOpc, SDLoc(Node),
|
||||
CurDAG->getMachineNode(RdhwrOpc, DL,
|
||||
Node->getValueType(0),
|
||||
CurDAG->getRegister(Mips::HWR29, MVT::i32));
|
||||
SDValue Chain = CurDAG->getCopyToReg(CurDAG->getEntryNode(), DL, DestReg,
|
||||
|
@ -911,10 +915,10 @@ std::pair<bool, SDNode*> MipsSEDAGToDAGISel::selectNode(SDNode *Node) {
|
|||
if (!SplatValue.isSignedIntN(10))
|
||||
return std::make_pair(false, nullptr);
|
||||
|
||||
SDValue Imm = CurDAG->getTargetConstant(SplatValue,
|
||||
SDValue Imm = CurDAG->getTargetConstant(SplatValue, DL,
|
||||
ViaVecTy.getVectorElementType());
|
||||
|
||||
SDNode *Res = CurDAG->getMachineNode(LdiOp, SDLoc(Node), ViaVecTy, Imm);
|
||||
SDNode *Res = CurDAG->getMachineNode(LdiOp, DL, ViaVecTy, Imm);
|
||||
|
||||
if (ResVecTy != ViaVecTy) {
|
||||
// If LdiOp is writing to a different register class to ResVecTy, then
|
||||
|
@ -924,9 +928,9 @@ std::pair<bool, SDNode*> MipsSEDAGToDAGISel::selectNode(SDNode *Node) {
|
|||
const TargetLowering *TLI = getTargetLowering();
|
||||
MVT ResVecTySimple = ResVecTy.getSimpleVT();
|
||||
const TargetRegisterClass *RC = TLI->getRegClassFor(ResVecTySimple);
|
||||
Res = CurDAG->getMachineNode(Mips::COPY_TO_REGCLASS, SDLoc(Node),
|
||||
Res = CurDAG->getMachineNode(Mips::COPY_TO_REGCLASS, DL,
|
||||
ResVecTy, SDValue(Res, 0),
|
||||
CurDAG->getTargetConstant(RC->getID(),
|
||||
CurDAG->getTargetConstant(RC->getID(), DL,
|
||||
MVT::i32));
|
||||
}
|
||||
|
||||
|
@ -949,7 +953,7 @@ SelectInlineAsmMemoryOperand(const SDValue &Op, unsigned ConstraintID,
|
|||
// All memory constraints can at least accept raw pointers.
|
||||
case InlineAsm::Constraint_i:
|
||||
OutOps.push_back(Op);
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, MVT::i32));
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, SDLoc(Op), MVT::i32));
|
||||
return false;
|
||||
case InlineAsm::Constraint_m:
|
||||
if (selectAddrRegImm16(Op, Base, Offset)) {
|
||||
|
@ -958,7 +962,7 @@ SelectInlineAsmMemoryOperand(const SDValue &Op, unsigned ConstraintID,
|
|||
return false;
|
||||
}
|
||||
OutOps.push_back(Op);
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, MVT::i32));
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, SDLoc(Op), MVT::i32));
|
||||
return false;
|
||||
case InlineAsm::Constraint_R:
|
||||
// The 'R' constraint is supposed to be much more complicated than this.
|
||||
|
@ -972,7 +976,7 @@ SelectInlineAsmMemoryOperand(const SDValue &Op, unsigned ConstraintID,
|
|||
return false;
|
||||
}
|
||||
OutOps.push_back(Op);
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, MVT::i32));
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, SDLoc(Op), MVT::i32));
|
||||
return false;
|
||||
case InlineAsm::Constraint_ZC:
|
||||
// ZC matches whatever the pref, ll, and sc instructions can handle for the
|
||||
|
@ -999,7 +1003,7 @@ SelectInlineAsmMemoryOperand(const SDValue &Op, unsigned ConstraintID,
|
|||
}
|
||||
// In all cases, 0-bit offsets are acceptable.
|
||||
OutOps.push_back(Op);
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, MVT::i32));
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, SDLoc(Op), MVT::i32));
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
|
|
|
@ -800,7 +800,7 @@ static SDValue genConstMult(SDValue X, uint64_t C, SDLoc DL, EVT VT,
|
|||
|
||||
// Return 0.
|
||||
if (C == 0)
|
||||
return DAG.getConstant(0, VT);
|
||||
return DAG.getConstant(0, DL, VT);
|
||||
|
||||
// Return x.
|
||||
if (C == 1)
|
||||
|
@ -809,7 +809,7 @@ static SDValue genConstMult(SDValue X, uint64_t C, SDLoc DL, EVT VT,
|
|||
// If c is power of 2, return (shl x, log2(c)).
|
||||
if (isPowerOf2_64(C))
|
||||
return DAG.getNode(ISD::SHL, DL, VT, X,
|
||||
DAG.getConstant(Log2_64(C), ShiftTy));
|
||||
DAG.getConstant(Log2_64(C), DL, ShiftTy));
|
||||
|
||||
unsigned Log2Ceil = Log2_64_Ceil(C);
|
||||
uint64_t Floor = 1LL << Log2_64(C);
|
||||
|
@ -864,8 +864,9 @@ static SDValue performDSPShiftCombine(unsigned Opc, SDNode *N, EVT Ty,
|
|||
(SplatValue.getZExtValue() >= EltSize))
|
||||
return SDValue();
|
||||
|
||||
return DAG.getNode(Opc, SDLoc(N), Ty, N->getOperand(0),
|
||||
DAG.getConstant(SplatValue.getZExtValue(), MVT::i32));
|
||||
SDLoc DL(N);
|
||||
return DAG.getNode(Opc, DL, Ty, N->getOperand(0),
|
||||
DAG.getConstant(SplatValue.getZExtValue(), DL, MVT::i32));
|
||||
}
|
||||
|
||||
static SDValue performSHLCombine(SDNode *N, SelectionDAG &DAG,
|
||||
|
@ -1212,7 +1213,7 @@ SDValue MipsSETargetLowering::lowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
Nd.getAlignment());
|
||||
|
||||
// i32 load from higher address.
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, PtrVT, Ptr, DAG.getConstant(4, PtrVT));
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, PtrVT, Ptr, DAG.getConstant(4, DL, PtrVT));
|
||||
SDValue Hi = DAG.getLoad(MVT::i32, DL, Lo.getValue(1), Ptr,
|
||||
MachinePointerInfo(), Nd.isVolatile(),
|
||||
Nd.isNonTemporal(), Nd.isInvariant(),
|
||||
|
@ -1237,9 +1238,9 @@ SDValue MipsSETargetLowering::lowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue Val = Nd.getValue(), Ptr = Nd.getBasePtr(), Chain = Nd.getChain();
|
||||
EVT PtrVT = Ptr.getValueType();
|
||||
SDValue Lo = DAG.getNode(MipsISD::ExtractElementF64, DL, MVT::i32,
|
||||
Val, DAG.getConstant(0, MVT::i32));
|
||||
Val, DAG.getConstant(0, DL, MVT::i32));
|
||||
SDValue Hi = DAG.getNode(MipsISD::ExtractElementF64, DL, MVT::i32,
|
||||
Val, DAG.getConstant(1, MVT::i32));
|
||||
Val, DAG.getConstant(1, DL, MVT::i32));
|
||||
|
||||
if (!Subtarget.isLittle())
|
||||
std::swap(Lo, Hi);
|
||||
|
@ -1250,7 +1251,7 @@ SDValue MipsSETargetLowering::lowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
Nd.getAAInfo());
|
||||
|
||||
// i32 store to higher address.
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, PtrVT, Ptr, DAG.getConstant(4, PtrVT));
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, PtrVT, Ptr, DAG.getConstant(4, DL, PtrVT));
|
||||
return DAG.getStore(Chain, DL, Hi, Ptr, MachinePointerInfo(),
|
||||
Nd.isVolatile(), Nd.isNonTemporal(),
|
||||
std::min(Nd.getAlignment(), 4U), Nd.getAAInfo());
|
||||
|
@ -1283,9 +1284,9 @@ SDValue MipsSETargetLowering::lowerMulDiv(SDValue Op, unsigned NewOpc,
|
|||
|
||||
static SDValue initAccumulator(SDValue In, SDLoc DL, SelectionDAG &DAG) {
|
||||
SDValue InLo = DAG.getNode(ISD::EXTRACT_ELEMENT, DL, MVT::i32, In,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
SDValue InHi = DAG.getNode(ISD::EXTRACT_ELEMENT, DL, MVT::i32, In,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, DL, MVT::i32));
|
||||
return DAG.getNode(MipsISD::MTLOHI, DL, MVT::Untyped, InLo, InHi);
|
||||
}
|
||||
|
||||
|
@ -1381,7 +1382,7 @@ static SDValue lowerMSASplatZExt(SDValue Op, unsigned OpNr, SelectionDAG &DAG) {
|
|||
SDValue LaneB = Op->getOperand(2);
|
||||
|
||||
if (ResVecTy == MVT::v2i64) {
|
||||
LaneA = DAG.getConstant(0, MVT::i32);
|
||||
LaneA = DAG.getConstant(0, DL, MVT::i32);
|
||||
ViaVecTy = MVT::v4i32;
|
||||
} else
|
||||
LaneA = LaneB;
|
||||
|
@ -1399,7 +1400,8 @@ static SDValue lowerMSASplatZExt(SDValue Op, unsigned OpNr, SelectionDAG &DAG) {
|
|||
}
|
||||
|
||||
static SDValue lowerMSASplatImm(SDValue Op, unsigned ImmOp, SelectionDAG &DAG) {
|
||||
return DAG.getConstant(Op->getConstantOperandVal(ImmOp), Op->getValueType(0));
|
||||
return DAG.getConstant(Op->getConstantOperandVal(ImmOp), SDLoc(Op),
|
||||
Op->getValueType(0));
|
||||
}
|
||||
|
||||
static SDValue getBuildVectorSplat(EVT VecTy, SDValue SplatValue,
|
||||
|
@ -1415,7 +1417,7 @@ static SDValue getBuildVectorSplat(EVT VecTy, SDValue SplatValue,
|
|||
|
||||
SplatValueA = DAG.getNode(ISD::TRUNCATE, DL, MVT::i32, SplatValue);
|
||||
SplatValueB = DAG.getNode(ISD::SRL, DL, MVT::i64, SplatValue,
|
||||
DAG.getConstant(32, MVT::i32));
|
||||
DAG.getConstant(32, DL, MVT::i32));
|
||||
SplatValueB = DAG.getNode(ISD::TRUNCATE, DL, MVT::i32, SplatValueB);
|
||||
}
|
||||
|
||||
|
@ -1451,8 +1453,9 @@ static SDValue lowerMSABinaryBitImmIntr(SDValue Op, SelectionDAG &DAG,
|
|||
if (ConstantSDNode *CImm = dyn_cast<ConstantSDNode>(Imm)) {
|
||||
APInt BitImm = APInt(64, 1) << CImm->getAPIntValue();
|
||||
|
||||
SDValue BitImmHiOp = DAG.getConstant(BitImm.lshr(32).trunc(32), MVT::i32);
|
||||
SDValue BitImmLoOp = DAG.getConstant(BitImm.trunc(32), MVT::i32);
|
||||
SDValue BitImmHiOp = DAG.getConstant(BitImm.lshr(32).trunc(32), DL,
|
||||
MVT::i32);
|
||||
SDValue BitImmLoOp = DAG.getConstant(BitImm.trunc(32), DL, MVT::i32);
|
||||
|
||||
if (BigEndian)
|
||||
std::swap(BitImmLoOp, BitImmHiOp);
|
||||
|
@ -1474,8 +1477,8 @@ static SDValue lowerMSABinaryBitImmIntr(SDValue Op, SelectionDAG &DAG,
|
|||
|
||||
Exp2Imm = getBuildVectorSplat(VecTy, Imm, BigEndian, DAG);
|
||||
|
||||
Exp2Imm =
|
||||
DAG.getNode(ISD::SHL, DL, VecTy, DAG.getConstant(1, VecTy), Exp2Imm);
|
||||
Exp2Imm = DAG.getNode(ISD::SHL, DL, VecTy, DAG.getConstant(1, DL, VecTy),
|
||||
Exp2Imm);
|
||||
}
|
||||
|
||||
return DAG.getNode(Opc, DL, VecTy, Op->getOperand(1), Exp2Imm);
|
||||
|
@ -1484,7 +1487,7 @@ static SDValue lowerMSABinaryBitImmIntr(SDValue Op, SelectionDAG &DAG,
|
|||
static SDValue lowerMSABitClear(SDValue Op, SelectionDAG &DAG) {
|
||||
EVT ResTy = Op->getValueType(0);
|
||||
SDLoc DL(Op);
|
||||
SDValue One = DAG.getConstant(1, ResTy);
|
||||
SDValue One = DAG.getConstant(1, DL, ResTy);
|
||||
SDValue Bit = DAG.getNode(ISD::SHL, DL, ResTy, One, Op->getOperand(2));
|
||||
|
||||
return DAG.getNode(ISD::AND, DL, ResTy, Op->getOperand(1),
|
||||
|
@ -1496,7 +1499,7 @@ static SDValue lowerMSABitClearImm(SDValue Op, SelectionDAG &DAG) {
|
|||
EVT ResTy = Op->getValueType(0);
|
||||
APInt BitImm = APInt(ResTy.getVectorElementType().getSizeInBits(), 1)
|
||||
<< cast<ConstantSDNode>(Op->getOperand(2))->getAPIntValue();
|
||||
SDValue BitMask = DAG.getConstant(~BitImm, ResTy);
|
||||
SDValue BitMask = DAG.getConstant(~BitImm, DL, ResTy);
|
||||
|
||||
return DAG.getNode(ISD::AND, DL, ResTy, Op->getOperand(1), BitMask);
|
||||
}
|
||||
|
@ -1578,8 +1581,8 @@ SDValue MipsSETargetLowering::lowerINTRINSIC_WO_CHAIN(SDValue Op,
|
|||
APInt Mask = APInt::getHighBitsSet(EltTy.getSizeInBits(),
|
||||
Op->getConstantOperandVal(3));
|
||||
return DAG.getNode(ISD::VSELECT, DL, VecTy,
|
||||
DAG.getConstant(Mask, VecTy, true), Op->getOperand(2),
|
||||
Op->getOperand(1));
|
||||
DAG.getConstant(Mask, DL, VecTy, true),
|
||||
Op->getOperand(2), Op->getOperand(1));
|
||||
}
|
||||
case Intrinsic::mips_binsri_b:
|
||||
case Intrinsic::mips_binsri_h:
|
||||
|
@ -1591,8 +1594,8 @@ SDValue MipsSETargetLowering::lowerINTRINSIC_WO_CHAIN(SDValue Op,
|
|||
APInt Mask = APInt::getLowBitsSet(EltTy.getSizeInBits(),
|
||||
Op->getConstantOperandVal(3));
|
||||
return DAG.getNode(ISD::VSELECT, DL, VecTy,
|
||||
DAG.getConstant(Mask, VecTy, true), Op->getOperand(2),
|
||||
Op->getOperand(1));
|
||||
DAG.getConstant(Mask, DL, VecTy, true),
|
||||
Op->getOperand(2), Op->getOperand(1));
|
||||
}
|
||||
case Intrinsic::mips_bmnz_v:
|
||||
return DAG.getNode(ISD::VSELECT, DL, Op->getValueType(0), Op->getOperand(3),
|
||||
|
@ -1613,7 +1616,7 @@ SDValue MipsSETargetLowering::lowerINTRINSIC_WO_CHAIN(SDValue Op,
|
|||
case Intrinsic::mips_bneg_w:
|
||||
case Intrinsic::mips_bneg_d: {
|
||||
EVT VecTy = Op->getValueType(0);
|
||||
SDValue One = DAG.getConstant(1, VecTy);
|
||||
SDValue One = DAG.getConstant(1, DL, VecTy);
|
||||
|
||||
return DAG.getNode(ISD::XOR, DL, VecTy, Op->getOperand(1),
|
||||
DAG.getNode(ISD::SHL, DL, VecTy, One,
|
||||
|
@ -1649,7 +1652,7 @@ SDValue MipsSETargetLowering::lowerINTRINSIC_WO_CHAIN(SDValue Op,
|
|||
case Intrinsic::mips_bset_w:
|
||||
case Intrinsic::mips_bset_d: {
|
||||
EVT VecTy = Op->getValueType(0);
|
||||
SDValue One = DAG.getConstant(1, VecTy);
|
||||
SDValue One = DAG.getConstant(1, DL, VecTy);
|
||||
|
||||
return DAG.getNode(ISD::OR, DL, VecTy, Op->getOperand(1),
|
||||
DAG.getNode(ISD::SHL, DL, VecTy, One,
|
||||
|
@ -1923,7 +1926,7 @@ SDValue MipsSETargetLowering::lowerINTRINSIC_WO_CHAIN(SDValue Op,
|
|||
case Intrinsic::mips_insve_d:
|
||||
return DAG.getNode(MipsISD::INSVE, DL, Op->getValueType(0),
|
||||
Op->getOperand(1), Op->getOperand(2), Op->getOperand(3),
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
case Intrinsic::mips_ldi_b:
|
||||
case Intrinsic::mips_ldi_h:
|
||||
case Intrinsic::mips_ldi_w:
|
||||
|
@ -2363,7 +2366,7 @@ SDValue MipsSETargetLowering::lowerBUILD_VECTOR(SDValue Op,
|
|||
}
|
||||
|
||||
// SelectionDAG::getConstant will promote SplatValue appropriately.
|
||||
SDValue Result = DAG.getConstant(SplatValue, ViaVecTy);
|
||||
SDValue Result = DAG.getConstant(SplatValue, DL, ViaVecTy);
|
||||
|
||||
// Bitcast to the type we originally wanted
|
||||
if (ViaVecTy != ResTy)
|
||||
|
@ -2385,7 +2388,7 @@ SDValue MipsSETargetLowering::lowerBUILD_VECTOR(SDValue Op,
|
|||
for (unsigned i = 0; i < NumElts; ++i) {
|
||||
Vector = DAG.getNode(ISD::INSERT_VECTOR_ELT, DL, ResTy, Vector,
|
||||
Node->getOperand(i),
|
||||
DAG.getConstant(i, MVT::i32));
|
||||
DAG.getConstant(i, DL, MVT::i32));
|
||||
}
|
||||
return Vector;
|
||||
}
|
||||
|
@ -2455,8 +2458,9 @@ static SDValue lowerVECTOR_SHUFFLE_SHF(SDValue Op, EVT ResTy,
|
|||
Imm |= Idx & 0x3;
|
||||
}
|
||||
|
||||
return DAG.getNode(MipsISD::SHF, SDLoc(Op), ResTy,
|
||||
DAG.getConstant(Imm, MVT::i32), Op->getOperand(0));
|
||||
SDLoc DL(Op);
|
||||
return DAG.getNode(MipsISD::SHF, DL, ResTy,
|
||||
DAG.getConstant(Imm, DL, MVT::i32), Op->getOperand(0));
|
||||
}
|
||||
|
||||
// Lower VECTOR_SHUFFLE into ILVEV (if possible).
|
||||
|
@ -2665,7 +2669,7 @@ static SDValue lowerVECTOR_SHUFFLE_VSHF(SDValue Op, EVT ResTy,
|
|||
|
||||
for (SmallVector<int, 16>::iterator I = Indices.begin(); I != Indices.end();
|
||||
++I)
|
||||
Ops.push_back(DAG.getTargetConstant(*I, MaskEltTy));
|
||||
Ops.push_back(DAG.getTargetConstant(*I, DL, MaskEltTy));
|
||||
|
||||
SDValue MaskVec = DAG.getNode(ISD::BUILD_VECTOR, DL, MaskVecTy, Ops);
|
||||
|
||||
|
|
|
@ -703,9 +703,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoad(SDNode *N) {
|
|||
default:
|
||||
return nullptr;
|
||||
}
|
||||
SDValue Ops[] = { getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(fromType),
|
||||
getI32Imm(fromTypeWidth), Addr, Chain };
|
||||
SDValue Ops[] = { getI32Imm(isVolatile, dl), getI32Imm(codeAddrSpace, dl),
|
||||
getI32Imm(vecType, dl), getI32Imm(fromType, dl),
|
||||
getI32Imm(fromTypeWidth, dl), Addr, Chain };
|
||||
NVPTXLD = CurDAG->getMachineNode(Opcode, dl, TargetVT, MVT::Other, Ops);
|
||||
} else if (TM.is64Bit() ? SelectADDRsi64(N1.getNode(), N1, Base, Offset)
|
||||
: SelectADDRsi(N1.getNode(), N1, Base, Offset)) {
|
||||
|
@ -731,9 +731,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoad(SDNode *N) {
|
|||
default:
|
||||
return nullptr;
|
||||
}
|
||||
SDValue Ops[] = { getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(fromType),
|
||||
getI32Imm(fromTypeWidth), Base, Offset, Chain };
|
||||
SDValue Ops[] = { getI32Imm(isVolatile, dl), getI32Imm(codeAddrSpace, dl),
|
||||
getI32Imm(vecType, dl), getI32Imm(fromType, dl),
|
||||
getI32Imm(fromTypeWidth, dl), Base, Offset, Chain };
|
||||
NVPTXLD = CurDAG->getMachineNode(Opcode, dl, TargetVT, MVT::Other, Ops);
|
||||
} else if (TM.is64Bit() ? SelectADDRri64(N1.getNode(), N1, Base, Offset)
|
||||
: SelectADDRri(N1.getNode(), N1, Base, Offset)) {
|
||||
|
@ -784,9 +784,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoad(SDNode *N) {
|
|||
return nullptr;
|
||||
}
|
||||
}
|
||||
SDValue Ops[] = { getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(fromType),
|
||||
getI32Imm(fromTypeWidth), Base, Offset, Chain };
|
||||
SDValue Ops[] = { getI32Imm(isVolatile, dl), getI32Imm(codeAddrSpace, dl),
|
||||
getI32Imm(vecType, dl), getI32Imm(fromType, dl),
|
||||
getI32Imm(fromTypeWidth, dl), Base, Offset, Chain };
|
||||
NVPTXLD = CurDAG->getMachineNode(Opcode, dl, TargetVT, MVT::Other, Ops);
|
||||
} else {
|
||||
if (TM.is64Bit()) {
|
||||
|
@ -836,9 +836,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoad(SDNode *N) {
|
|||
return nullptr;
|
||||
}
|
||||
}
|
||||
SDValue Ops[] = { getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(fromType),
|
||||
getI32Imm(fromTypeWidth), N1, Chain };
|
||||
SDValue Ops[] = { getI32Imm(isVolatile, dl), getI32Imm(codeAddrSpace, dl),
|
||||
getI32Imm(vecType, dl), getI32Imm(fromType, dl),
|
||||
getI32Imm(fromTypeWidth, dl), N1, Chain };
|
||||
NVPTXLD = CurDAG->getMachineNode(Opcode, dl, TargetVT, MVT::Other, Ops);
|
||||
}
|
||||
|
||||
|
@ -962,9 +962,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoadVector(SDNode *N) {
|
|||
break;
|
||||
}
|
||||
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile), getI32Imm(CodeAddrSpace),
|
||||
getI32Imm(VecType), getI32Imm(FromType),
|
||||
getI32Imm(FromTypeWidth), Addr, Chain };
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile, DL), getI32Imm(CodeAddrSpace, DL),
|
||||
getI32Imm(VecType, DL), getI32Imm(FromType, DL),
|
||||
getI32Imm(FromTypeWidth, DL), Addr, Chain };
|
||||
LD = CurDAG->getMachineNode(Opcode, DL, N->getVTList(), Ops);
|
||||
} else if (TM.is64Bit() ? SelectADDRsi64(Op1.getNode(), Op1, Base, Offset)
|
||||
: SelectADDRsi(Op1.getNode(), Op1, Base, Offset)) {
|
||||
|
@ -1015,9 +1015,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoadVector(SDNode *N) {
|
|||
break;
|
||||
}
|
||||
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile), getI32Imm(CodeAddrSpace),
|
||||
getI32Imm(VecType), getI32Imm(FromType),
|
||||
getI32Imm(FromTypeWidth), Base, Offset, Chain };
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile, DL), getI32Imm(CodeAddrSpace, DL),
|
||||
getI32Imm(VecType, DL), getI32Imm(FromType, DL),
|
||||
getI32Imm(FromTypeWidth, DL), Base, Offset, Chain };
|
||||
LD = CurDAG->getMachineNode(Opcode, DL, N->getVTList(), Ops);
|
||||
} else if (TM.is64Bit() ? SelectADDRri64(Op1.getNode(), Op1, Base, Offset)
|
||||
: SelectADDRri(Op1.getNode(), Op1, Base, Offset)) {
|
||||
|
@ -1117,9 +1117,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoadVector(SDNode *N) {
|
|||
}
|
||||
}
|
||||
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile), getI32Imm(CodeAddrSpace),
|
||||
getI32Imm(VecType), getI32Imm(FromType),
|
||||
getI32Imm(FromTypeWidth), Base, Offset, Chain };
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile, DL), getI32Imm(CodeAddrSpace, DL),
|
||||
getI32Imm(VecType, DL), getI32Imm(FromType, DL),
|
||||
getI32Imm(FromTypeWidth, DL), Base, Offset, Chain };
|
||||
|
||||
LD = CurDAG->getMachineNode(Opcode, DL, N->getVTList(), Ops);
|
||||
} else {
|
||||
|
@ -1219,9 +1219,9 @@ SDNode *NVPTXDAGToDAGISel::SelectLoadVector(SDNode *N) {
|
|||
}
|
||||
}
|
||||
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile), getI32Imm(CodeAddrSpace),
|
||||
getI32Imm(VecType), getI32Imm(FromType),
|
||||
getI32Imm(FromTypeWidth), Op1, Chain };
|
||||
SDValue Ops[] = { getI32Imm(IsVolatile, DL), getI32Imm(CodeAddrSpace, DL),
|
||||
getI32Imm(VecType, DL), getI32Imm(FromType, DL),
|
||||
getI32Imm(FromTypeWidth, DL), Op1, Chain };
|
||||
LD = CurDAG->getMachineNode(Opcode, DL, N->getVTList(), Ops);
|
||||
}
|
||||
|
||||
|
@ -2068,9 +2068,10 @@ SDNode *NVPTXDAGToDAGISel::SelectStore(SDNode *N) {
|
|||
default:
|
||||
return nullptr;
|
||||
}
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(toType),
|
||||
getI32Imm(toTypeWidth), Addr, Chain };
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile, dl),
|
||||
getI32Imm(codeAddrSpace, dl), getI32Imm(vecType, dl),
|
||||
getI32Imm(toType, dl), getI32Imm(toTypeWidth, dl), Addr,
|
||||
Chain };
|
||||
NVPTXST = CurDAG->getMachineNode(Opcode, dl, MVT::Other, Ops);
|
||||
} else if (TM.is64Bit() ? SelectADDRsi64(N2.getNode(), N2, Base, Offset)
|
||||
: SelectADDRsi(N2.getNode(), N2, Base, Offset)) {
|
||||
|
@ -2096,9 +2097,10 @@ SDNode *NVPTXDAGToDAGISel::SelectStore(SDNode *N) {
|
|||
default:
|
||||
return nullptr;
|
||||
}
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(toType),
|
||||
getI32Imm(toTypeWidth), Base, Offset, Chain };
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile, dl),
|
||||
getI32Imm(codeAddrSpace, dl), getI32Imm(vecType, dl),
|
||||
getI32Imm(toType, dl), getI32Imm(toTypeWidth, dl), Base,
|
||||
Offset, Chain };
|
||||
NVPTXST = CurDAG->getMachineNode(Opcode, dl, MVT::Other, Ops);
|
||||
} else if (TM.is64Bit() ? SelectADDRri64(N2.getNode(), N2, Base, Offset)
|
||||
: SelectADDRri(N2.getNode(), N2, Base, Offset)) {
|
||||
|
@ -2149,9 +2151,10 @@ SDNode *NVPTXDAGToDAGISel::SelectStore(SDNode *N) {
|
|||
return nullptr;
|
||||
}
|
||||
}
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(toType),
|
||||
getI32Imm(toTypeWidth), Base, Offset, Chain };
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile, dl),
|
||||
getI32Imm(codeAddrSpace, dl), getI32Imm(vecType, dl),
|
||||
getI32Imm(toType, dl), getI32Imm(toTypeWidth, dl), Base,
|
||||
Offset, Chain };
|
||||
NVPTXST = CurDAG->getMachineNode(Opcode, dl, MVT::Other, Ops);
|
||||
} else {
|
||||
if (TM.is64Bit()) {
|
||||
|
@ -2201,9 +2204,10 @@ SDNode *NVPTXDAGToDAGISel::SelectStore(SDNode *N) {
|
|||
return nullptr;
|
||||
}
|
||||
}
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile), getI32Imm(codeAddrSpace),
|
||||
getI32Imm(vecType), getI32Imm(toType),
|
||||
getI32Imm(toTypeWidth), N2, Chain };
|
||||
SDValue Ops[] = { N1, getI32Imm(isVolatile, dl),
|
||||
getI32Imm(codeAddrSpace, dl), getI32Imm(vecType, dl),
|
||||
getI32Imm(toType, dl), getI32Imm(toTypeWidth, dl), N2,
|
||||
Chain };
|
||||
NVPTXST = CurDAG->getMachineNode(Opcode, dl, MVT::Other, Ops);
|
||||
}
|
||||
|
||||
|
@ -2277,11 +2281,11 @@ SDNode *NVPTXDAGToDAGISel::SelectStoreVector(SDNode *N) {
|
|||
return nullptr;
|
||||
}
|
||||
|
||||
StOps.push_back(getI32Imm(IsVolatile));
|
||||
StOps.push_back(getI32Imm(CodeAddrSpace));
|
||||
StOps.push_back(getI32Imm(VecType));
|
||||
StOps.push_back(getI32Imm(ToType));
|
||||
StOps.push_back(getI32Imm(ToTypeWidth));
|
||||
StOps.push_back(getI32Imm(IsVolatile, DL));
|
||||
StOps.push_back(getI32Imm(CodeAddrSpace, DL));
|
||||
StOps.push_back(getI32Imm(VecType, DL));
|
||||
StOps.push_back(getI32Imm(ToType, DL));
|
||||
StOps.push_back(getI32Imm(ToTypeWidth, DL));
|
||||
|
||||
if (SelectDirectAddr(N2, Addr)) {
|
||||
switch (N->getOpcode()) {
|
||||
|
@ -2710,13 +2714,11 @@ SDNode *NVPTXDAGToDAGISel::SelectLoadParam(SDNode *Node) {
|
|||
unsigned OffsetVal = cast<ConstantSDNode>(Offset)->getZExtValue();
|
||||
|
||||
SmallVector<SDValue, 2> Ops;
|
||||
Ops.push_back(CurDAG->getTargetConstant(OffsetVal, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(OffsetVal, DL, MVT::i32));
|
||||
Ops.push_back(Chain);
|
||||
Ops.push_back(Flag);
|
||||
|
||||
SDNode *Ret =
|
||||
CurDAG->getMachineNode(Opc, DL, VTs, Ops);
|
||||
return Ret;
|
||||
return CurDAG->getMachineNode(Opc, DL, VTs, Ops);
|
||||
}
|
||||
|
||||
SDNode *NVPTXDAGToDAGISel::SelectStoreRetval(SDNode *N) {
|
||||
|
@ -2746,7 +2748,7 @@ SDNode *NVPTXDAGToDAGISel::SelectStoreRetval(SDNode *N) {
|
|||
SmallVector<SDValue, 6> Ops;
|
||||
for (unsigned i = 0; i < NumElts; ++i)
|
||||
Ops.push_back(N->getOperand(i + 2));
|
||||
Ops.push_back(CurDAG->getTargetConstant(OffsetVal, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(OffsetVal, DL, MVT::i32));
|
||||
Ops.push_back(Chain);
|
||||
|
||||
// Determine target opcode
|
||||
|
@ -2874,8 +2876,8 @@ SDNode *NVPTXDAGToDAGISel::SelectStoreParam(SDNode *N) {
|
|||
SmallVector<SDValue, 8> Ops;
|
||||
for (unsigned i = 0; i < NumElts; ++i)
|
||||
Ops.push_back(N->getOperand(i + 3));
|
||||
Ops.push_back(CurDAG->getTargetConstant(ParamVal, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(OffsetVal, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(ParamVal, DL, MVT::i32));
|
||||
Ops.push_back(CurDAG->getTargetConstant(OffsetVal, DL, MVT::i32));
|
||||
Ops.push_back(Chain);
|
||||
Ops.push_back(Flag);
|
||||
|
||||
|
@ -2970,7 +2972,7 @@ SDNode *NVPTXDAGToDAGISel::SelectStoreParam(SDNode *N) {
|
|||
// the selected StoreParam node.
|
||||
case NVPTXISD::StoreParamU32: {
|
||||
Opcode = NVPTX::StoreParamI32;
|
||||
SDValue CvtNone = CurDAG->getTargetConstant(NVPTX::PTXCvtMode::NONE,
|
||||
SDValue CvtNone = CurDAG->getTargetConstant(NVPTX::PTXCvtMode::NONE, DL,
|
||||
MVT::i32);
|
||||
SDNode *Cvt = CurDAG->getMachineNode(NVPTX::CVT_u32_u16, DL,
|
||||
MVT::i32, Ops[0], CvtNone);
|
||||
|
@ -2979,7 +2981,7 @@ SDNode *NVPTXDAGToDAGISel::SelectStoreParam(SDNode *N) {
|
|||
}
|
||||
case NVPTXISD::StoreParamS32: {
|
||||
Opcode = NVPTX::StoreParamI32;
|
||||
SDValue CvtNone = CurDAG->getTargetConstant(NVPTX::PTXCvtMode::NONE,
|
||||
SDValue CvtNone = CurDAG->getTargetConstant(NVPTX::PTXCvtMode::NONE, DL,
|
||||
MVT::i32);
|
||||
SDNode *Cvt = CurDAG->getMachineNode(NVPTX::CVT_s32_s16, DL,
|
||||
MVT::i32, Ops[0], CvtNone);
|
||||
|
@ -4727,6 +4729,7 @@ SDNode *NVPTXDAGToDAGISel::SelectSurfaceIntrinsic(SDNode *N) {
|
|||
/// SelectBFE - Look for instruction sequences that can be made more efficient
|
||||
/// by using the 'bfe' (bit-field extract) PTX instruction
|
||||
SDNode *NVPTXDAGToDAGISel::SelectBFE(SDNode *N) {
|
||||
SDLoc DL(N);
|
||||
SDValue LHS = N->getOperand(0);
|
||||
SDValue RHS = N->getOperand(1);
|
||||
SDValue Len;
|
||||
|
@ -4758,7 +4761,7 @@ SDNode *NVPTXDAGToDAGISel::SelectBFE(SDNode *N) {
|
|||
|
||||
// How many bits are in our mask?
|
||||
uint64_t NumBits = countTrailingOnes(MaskVal);
|
||||
Len = CurDAG->getTargetConstant(NumBits, MVT::i32);
|
||||
Len = CurDAG->getTargetConstant(NumBits, DL, MVT::i32);
|
||||
|
||||
if (LHS.getOpcode() == ISD::SRL || LHS.getOpcode() == ISD::SRA) {
|
||||
// We have a 'srl/and' pair, extract the effective start bit and length
|
||||
|
@ -4776,7 +4779,7 @@ SDNode *NVPTXDAGToDAGISel::SelectBFE(SDNode *N) {
|
|||
// emitting the srl/and pair.
|
||||
return NULL;
|
||||
}
|
||||
Start = CurDAG->getTargetConstant(StartVal, MVT::i32);
|
||||
Start = CurDAG->getTargetConstant(StartVal, DL, MVT::i32);
|
||||
} else {
|
||||
// Do not handle the case where the shift amount (can be zero if no srl
|
||||
// was found) is not constant. We could handle this case, but it would
|
||||
|
@ -4841,8 +4844,8 @@ SDNode *NVPTXDAGToDAGISel::SelectBFE(SDNode *N) {
|
|||
}
|
||||
|
||||
Val = AndLHS;
|
||||
Start = CurDAG->getTargetConstant(ShiftAmt, MVT::i32);
|
||||
Len = CurDAG->getTargetConstant(NumBits, MVT::i32);
|
||||
Start = CurDAG->getTargetConstant(ShiftAmt, DL, MVT::i32);
|
||||
Len = CurDAG->getTargetConstant(NumBits, DL, MVT::i32);
|
||||
} else if (LHS->getOpcode() == ISD::SHL) {
|
||||
// Here, we have a pattern like:
|
||||
//
|
||||
|
@ -4882,10 +4885,10 @@ SDNode *NVPTXDAGToDAGISel::SelectBFE(SDNode *N) {
|
|||
}
|
||||
|
||||
Start =
|
||||
CurDAG->getTargetConstant(OuterShiftAmt - InnerShiftAmt, MVT::i32);
|
||||
CurDAG->getTargetConstant(OuterShiftAmt - InnerShiftAmt, DL, MVT::i32);
|
||||
Len =
|
||||
CurDAG->getTargetConstant(Val.getValueType().getSizeInBits() -
|
||||
OuterShiftAmt, MVT::i32);
|
||||
OuterShiftAmt, DL, MVT::i32);
|
||||
|
||||
if (N->getOpcode() == ISD::SRA) {
|
||||
// If we have a arithmetic right shift, we need to use the signed bfe
|
||||
|
@ -4926,10 +4929,7 @@ SDNode *NVPTXDAGToDAGISel::SelectBFE(SDNode *N) {
|
|||
Val, Start, Len
|
||||
};
|
||||
|
||||
SDNode *Ret =
|
||||
CurDAG->getMachineNode(Opc, SDLoc(N), N->getVTList(), Ops);
|
||||
|
||||
return Ret;
|
||||
return CurDAG->getMachineNode(Opc, DL, N->getVTList(), Ops);
|
||||
}
|
||||
|
||||
// SelectDirectAddr - Match a direct address for DAG.
|
||||
|
@ -4961,7 +4961,8 @@ bool NVPTXDAGToDAGISel::SelectADDRsi_imp(
|
|||
if (ConstantSDNode *CN = dyn_cast<ConstantSDNode>(Addr.getOperand(1))) {
|
||||
SDValue base = Addr.getOperand(0);
|
||||
if (SelectDirectAddr(base, Base)) {
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), mvt);
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), SDLoc(OpNode),
|
||||
mvt);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -4986,7 +4987,7 @@ bool NVPTXDAGToDAGISel::SelectADDRri_imp(
|
|||
SDNode *OpNode, SDValue Addr, SDValue &Base, SDValue &Offset, MVT mvt) {
|
||||
if (FrameIndexSDNode *FIN = dyn_cast<FrameIndexSDNode>(Addr)) {
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), mvt);
|
||||
Offset = CurDAG->getTargetConstant(0, mvt);
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(OpNode), mvt);
|
||||
return true;
|
||||
}
|
||||
if (Addr.getOpcode() == ISD::TargetExternalSymbol ||
|
||||
|
@ -5004,7 +5005,8 @@ bool NVPTXDAGToDAGISel::SelectADDRri_imp(
|
|||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), mvt);
|
||||
else
|
||||
Base = Addr.getOperand(0);
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), mvt);
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), SDLoc(OpNode),
|
||||
mvt);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -5049,7 +5051,7 @@ bool NVPTXDAGToDAGISel::SelectInlineAsmMemoryOperand(
|
|||
case InlineAsm::Constraint_m: // memory
|
||||
if (SelectDirectAddr(Op, Op0)) {
|
||||
OutOps.push_back(Op0);
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, MVT::i32));
|
||||
OutOps.push_back(CurDAG->getTargetConstant(0, SDLoc(Op), MVT::i32));
|
||||
return false;
|
||||
}
|
||||
if (SelectADDRri(Op.getNode(), Op, Op0, Op1)) {
|
||||
|
|
|
@ -71,8 +71,8 @@ private:
|
|||
SDNode *SelectSurfaceIntrinsic(SDNode *N);
|
||||
SDNode *SelectBFE(SDNode *N);
|
||||
|
||||
inline SDValue getI32Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
inline SDValue getI32Imm(unsigned Imm, SDLoc DL) {
|
||||
return CurDAG->getTargetConstant(Imm, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// Match direct address complex pattern.
|
||||
|
|
|
@ -1053,9 +1053,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
const Function *F = MF.getFunction();
|
||||
|
||||
SDValue tempChain = Chain;
|
||||
Chain =
|
||||
DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(uniqueCallSite, true),
|
||||
dl);
|
||||
Chain = DAG.getCALLSEQ_START(Chain,
|
||||
DAG.getIntPtrConstant(uniqueCallSite, dl, true),
|
||||
dl);
|
||||
SDValue InFlag = Chain.getValue(1);
|
||||
|
||||
unsigned paramCount = 0;
|
||||
|
@ -1086,9 +1086,11 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
// declare .param .align <align> .b8 .param<n>[<size>];
|
||||
unsigned sz = TD->getTypeAllocSize(Ty);
|
||||
SDVTList DeclareParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue DeclareParamOps[] = { Chain, DAG.getConstant(align, MVT::i32),
|
||||
DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(sz, MVT::i32), InFlag };
|
||||
SDValue DeclareParamOps[] = { Chain, DAG.getConstant(align, dl,
|
||||
MVT::i32),
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(sz, dl, MVT::i32),
|
||||
InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::DeclareParam, dl, DeclareParamVTs,
|
||||
DeclareParamOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
@ -1103,8 +1105,8 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
}
|
||||
SDVTList CopyParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CopyParamOps[] = { Chain,
|
||||
DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(Offsets[j], MVT::i32),
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(Offsets[j], dl, MVT::i32),
|
||||
StVal, InFlag };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreParam, dl,
|
||||
CopyParamVTs, CopyParamOps,
|
||||
|
@ -1124,9 +1126,11 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
// declare .param .align <align> .b8 .param<n>[<size>];
|
||||
unsigned sz = TD->getTypeAllocSize(Ty);
|
||||
SDVTList DeclareParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue DeclareParamOps[] = { Chain, DAG.getConstant(align, MVT::i32),
|
||||
DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(sz, MVT::i32), InFlag };
|
||||
SDValue DeclareParamOps[] = { Chain,
|
||||
DAG.getConstant(align, dl, MVT::i32),
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(sz, dl, MVT::i32),
|
||||
InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::DeclareParam, dl, DeclareParamVTs,
|
||||
DeclareParamOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
@ -1147,8 +1151,8 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
|
||||
SDVTList CopyParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CopyParamOps[] = { Chain,
|
||||
DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), Elt,
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), Elt,
|
||||
InFlag };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreParam, dl,
|
||||
CopyParamVTs, CopyParamOps,
|
||||
|
@ -1164,9 +1168,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
|
||||
SDVTList CopyParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CopyParamOps[] = { Chain,
|
||||
DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), Elt0, Elt1,
|
||||
InFlag };
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), Elt0,
|
||||
Elt1, InFlag };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreParamV2, dl,
|
||||
CopyParamVTs, CopyParamOps,
|
||||
MemVT, MachinePointerInfo());
|
||||
|
@ -1196,8 +1200,8 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
SDValue StoreVal;
|
||||
SmallVector<SDValue, 8> Ops;
|
||||
Ops.push_back(Chain);
|
||||
Ops.push_back(DAG.getConstant(paramCount, MVT::i32));
|
||||
Ops.push_back(DAG.getConstant(curOffset, MVT::i32));
|
||||
Ops.push_back(DAG.getConstant(paramCount, dl, MVT::i32));
|
||||
Ops.push_back(DAG.getConstant(curOffset, dl, MVT::i32));
|
||||
|
||||
unsigned Opc = NVPTXISD::StoreParamV2;
|
||||
|
||||
|
@ -1264,9 +1268,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
}
|
||||
SDVTList DeclareParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue DeclareParamOps[] = { Chain,
|
||||
DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(sz, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), InFlag };
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(sz, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::DeclareScalarParam, dl, DeclareParamVTs,
|
||||
DeclareParamOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
@ -1279,8 +1283,10 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
OutV = DAG.getNode(opc, dl, MVT::i16, OutV);
|
||||
}
|
||||
SDVTList CopyParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CopyParamOps[] = { Chain, DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), OutV, InFlag };
|
||||
SDValue CopyParamOps[] = { Chain,
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), OutV,
|
||||
InFlag };
|
||||
|
||||
unsigned opcode = NVPTXISD::StoreParam;
|
||||
if (Outs[OIdx].Flags.isZExt())
|
||||
|
@ -1309,9 +1315,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
// so we don't need to worry about natural alignment or not.
|
||||
// See TargetLowering::LowerCallTo().
|
||||
SDValue DeclareParamOps[] = {
|
||||
Chain, DAG.getConstant(Outs[OIdx].Flags.getByValAlign(), MVT::i32),
|
||||
DAG.getConstant(paramCount, MVT::i32), DAG.getConstant(sz, MVT::i32),
|
||||
InFlag
|
||||
Chain, DAG.getConstant(Outs[OIdx].Flags.getByValAlign(), dl, MVT::i32),
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(sz, dl, MVT::i32), InFlag
|
||||
};
|
||||
Chain = DAG.getNode(NVPTXISD::DeclareParam, dl, DeclareParamVTs,
|
||||
DeclareParamOps);
|
||||
|
@ -1322,7 +1328,7 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
unsigned PartAlign = GreatestCommonDivisor64(ArgAlign, curOffset);
|
||||
SDValue srcAddr =
|
||||
DAG.getNode(ISD::ADD, dl, getPointerTy(), OutVals[OIdx],
|
||||
DAG.getConstant(curOffset, getPointerTy()));
|
||||
DAG.getConstant(curOffset, dl, getPointerTy()));
|
||||
SDValue theVal = DAG.getLoad(elemtype, dl, tempChain, srcAddr,
|
||||
MachinePointerInfo(), false, false, false,
|
||||
PartAlign);
|
||||
|
@ -1330,9 +1336,10 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
theVal = DAG.getNode(ISD::ANY_EXTEND, dl, MVT::i16, theVal);
|
||||
}
|
||||
SDVTList CopyParamVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CopyParamOps[] = { Chain, DAG.getConstant(paramCount, MVT::i32),
|
||||
DAG.getConstant(curOffset, MVT::i32), theVal,
|
||||
InFlag };
|
||||
SDValue CopyParamOps[] = { Chain,
|
||||
DAG.getConstant(paramCount, dl, MVT::i32),
|
||||
DAG.getConstant(curOffset, dl, MVT::i32),
|
||||
theVal, InFlag };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreParam, dl, CopyParamVTs,
|
||||
CopyParamOps, elemtype,
|
||||
MachinePointerInfo());
|
||||
|
@ -1364,9 +1371,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
if (resultsz < 32)
|
||||
resultsz = 32;
|
||||
SDVTList DeclareRetVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue DeclareRetOps[] = { Chain, DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(resultsz, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), InFlag };
|
||||
SDValue DeclareRetOps[] = { Chain, DAG.getConstant(1, dl, MVT::i32),
|
||||
DAG.getConstant(resultsz, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::DeclareRet, dl, DeclareRetVTs,
|
||||
DeclareRetOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
@ -1374,9 +1381,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
retAlignment = getArgumentAlignment(Callee, CS, retTy, 0);
|
||||
SDVTList DeclareRetVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue DeclareRetOps[] = { Chain,
|
||||
DAG.getConstant(retAlignment, MVT::i32),
|
||||
DAG.getConstant(resultsz / 8, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), InFlag };
|
||||
DAG.getConstant(retAlignment, dl, MVT::i32),
|
||||
DAG.getConstant(resultsz / 8, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::DeclareRetParam, dl, DeclareRetVTs,
|
||||
DeclareRetOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
@ -1404,7 +1411,7 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
// Op to just print "call"
|
||||
SDVTList PrintCallVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue PrintCallOps[] = {
|
||||
Chain, DAG.getConstant((Ins.size() == 0) ? 0 : 1, MVT::i32), InFlag
|
||||
Chain, DAG.getConstant((Ins.size() == 0) ? 0 : 1, dl, MVT::i32), InFlag
|
||||
};
|
||||
Chain = DAG.getNode(Func ? (NVPTXISD::PrintCallUni) : (NVPTXISD::PrintCall),
|
||||
dl, PrintCallVTs, PrintCallOps);
|
||||
|
@ -1430,20 +1437,22 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
else
|
||||
opcode = NVPTXISD::CallArg;
|
||||
SDVTList CallArgVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CallArgOps[] = { Chain, DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(i, MVT::i32), InFlag };
|
||||
SDValue CallArgOps[] = { Chain, DAG.getConstant(1, dl, MVT::i32),
|
||||
DAG.getConstant(i, dl, MVT::i32), InFlag };
|
||||
Chain = DAG.getNode(opcode, dl, CallArgVTs, CallArgOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
}
|
||||
SDVTList CallArgEndVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue CallArgEndOps[] = { Chain, DAG.getConstant(Func ? 1 : 0, MVT::i32),
|
||||
SDValue CallArgEndOps[] = { Chain,
|
||||
DAG.getConstant(Func ? 1 : 0, dl, MVT::i32),
|
||||
InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::CallArgEnd, dl, CallArgEndVTs, CallArgEndOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
if (!Func) {
|
||||
SDVTList PrototypeVTs = DAG.getVTList(MVT::Other, MVT::Glue);
|
||||
SDValue PrototypeOps[] = { Chain, DAG.getConstant(uniqueCallSite, MVT::i32),
|
||||
SDValue PrototypeOps[] = { Chain,
|
||||
DAG.getConstant(uniqueCallSite, dl, MVT::i32),
|
||||
InFlag };
|
||||
Chain = DAG.getNode(NVPTXISD::Prototype, dl, PrototypeVTs, PrototypeOps);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
@ -1474,8 +1483,8 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
LoadRetVTs.push_back(EltVT);
|
||||
LoadRetVTs.push_back(MVT::Other);
|
||||
LoadRetVTs.push_back(MVT::Glue);
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), InFlag};
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), InFlag};
|
||||
SDValue retval = DAG.getMemIntrinsicNode(
|
||||
NVPTXISD::LoadParam, dl,
|
||||
DAG.getVTList(LoadRetVTs), LoadRetOps, EltVT, MachinePointerInfo());
|
||||
|
@ -1501,8 +1510,8 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
}
|
||||
LoadRetVTs.push_back(MVT::Other);
|
||||
LoadRetVTs.push_back(MVT::Glue);
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32), InFlag};
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, dl, MVT::i32),
|
||||
DAG.getConstant(0, dl, MVT::i32), InFlag};
|
||||
SDValue retval = DAG.getMemIntrinsicNode(
|
||||
NVPTXISD::LoadParamV2, dl,
|
||||
DAG.getVTList(LoadRetVTs), LoadRetOps, EltVT, MachinePointerInfo());
|
||||
|
@ -1544,8 +1553,8 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
}
|
||||
LoadRetVTs.push_back(MVT::Other);
|
||||
LoadRetVTs.push_back(MVT::Glue);
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(Ofst, MVT::i32), InFlag};
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, dl, MVT::i32),
|
||||
DAG.getConstant(Ofst, dl, MVT::i32), InFlag};
|
||||
SDValue retval = DAG.getMemIntrinsicNode(
|
||||
Opc, dl, DAG.getVTList(LoadRetVTs),
|
||||
LoadRetOps, EltVT, MachinePointerInfo());
|
||||
|
@ -1599,8 +1608,9 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
LoadRetVTs.push_back(MVT::Other);
|
||||
LoadRetVTs.push_back(MVT::Glue);
|
||||
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(Offsets[i], MVT::i32), InFlag};
|
||||
SDValue LoadRetOps[] = {Chain, DAG.getConstant(1, dl, MVT::i32),
|
||||
DAG.getConstant(Offsets[i], dl, MVT::i32),
|
||||
InFlag};
|
||||
SDValue retval = DAG.getMemIntrinsicNode(
|
||||
NVPTXISD::LoadParam, dl,
|
||||
DAG.getVTList(LoadRetVTs), LoadRetOps,
|
||||
|
@ -1615,8 +1625,10 @@ SDValue NVPTXTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
|||
}
|
||||
}
|
||||
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(uniqueCallSite, true),
|
||||
DAG.getIntPtrConstant(uniqueCallSite + 1, true),
|
||||
Chain = DAG.getCALLSEQ_END(Chain,
|
||||
DAG.getIntPtrConstant(uniqueCallSite, dl, true),
|
||||
DAG.getIntPtrConstant(uniqueCallSite + 1, dl,
|
||||
true),
|
||||
InFlag, dl);
|
||||
uniqueCallSite++;
|
||||
|
||||
|
@ -1642,7 +1654,7 @@ NVPTXTargetLowering::LowerCONCAT_VECTORS(SDValue Op, SelectionDAG &DAG) const {
|
|||
unsigned NumSubElem = VVT.getVectorNumElements();
|
||||
for (unsigned j = 0; j < NumSubElem; ++j) {
|
||||
Ops.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, SubOp,
|
||||
DAG.getIntPtrConstant(j)));
|
||||
DAG.getIntPtrConstant(j, dl)));
|
||||
}
|
||||
}
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, dl, Node->getValueType(0), Ops);
|
||||
|
@ -1691,16 +1703,18 @@ SDValue NVPTXTargetLowering::LowerShiftRightParts(SDValue Op,
|
|||
// dHi = aHi >> Amt
|
||||
|
||||
SDValue RevShAmt = DAG.getNode(ISD::SUB, dl, MVT::i32,
|
||||
DAG.getConstant(VTBits, MVT::i32), ShAmt);
|
||||
DAG.getConstant(VTBits, dl, MVT::i32),
|
||||
ShAmt);
|
||||
SDValue Tmp1 = DAG.getNode(ISD::SRL, dl, VT, ShOpLo, ShAmt);
|
||||
SDValue ExtraShAmt = DAG.getNode(ISD::SUB, dl, MVT::i32, ShAmt,
|
||||
DAG.getConstant(VTBits, MVT::i32));
|
||||
DAG.getConstant(VTBits, dl, MVT::i32));
|
||||
SDValue Tmp2 = DAG.getNode(ISD::SHL, dl, VT, ShOpHi, RevShAmt);
|
||||
SDValue FalseVal = DAG.getNode(ISD::OR, dl, VT, Tmp1, Tmp2);
|
||||
SDValue TrueVal = DAG.getNode(Opc, dl, VT, ShOpHi, ExtraShAmt);
|
||||
|
||||
SDValue Cmp = DAG.getSetCC(dl, MVT::i1, ShAmt,
|
||||
DAG.getConstant(VTBits, MVT::i32), ISD::SETGE);
|
||||
DAG.getConstant(VTBits, dl, MVT::i32),
|
||||
ISD::SETGE);
|
||||
SDValue Hi = DAG.getNode(Opc, dl, VT, ShOpHi, ShAmt);
|
||||
SDValue Lo = DAG.getNode(ISD::SELECT, dl, VT, Cmp, TrueVal, FalseVal);
|
||||
|
||||
|
@ -1751,16 +1765,18 @@ SDValue NVPTXTargetLowering::LowerShiftLeftParts(SDValue Op,
|
|||
// dHi = (aHi << Amt) | (aLo >> (size-Amt))
|
||||
|
||||
SDValue RevShAmt = DAG.getNode(ISD::SUB, dl, MVT::i32,
|
||||
DAG.getConstant(VTBits, MVT::i32), ShAmt);
|
||||
DAG.getConstant(VTBits, dl, MVT::i32),
|
||||
ShAmt);
|
||||
SDValue Tmp1 = DAG.getNode(ISD::SHL, dl, VT, ShOpHi, ShAmt);
|
||||
SDValue ExtraShAmt = DAG.getNode(ISD::SUB, dl, MVT::i32, ShAmt,
|
||||
DAG.getConstant(VTBits, MVT::i32));
|
||||
DAG.getConstant(VTBits, dl, MVT::i32));
|
||||
SDValue Tmp2 = DAG.getNode(ISD::SRL, dl, VT, ShOpLo, RevShAmt);
|
||||
SDValue FalseVal = DAG.getNode(ISD::OR, dl, VT, Tmp1, Tmp2);
|
||||
SDValue TrueVal = DAG.getNode(ISD::SHL, dl, VT, ShOpLo, ExtraShAmt);
|
||||
|
||||
SDValue Cmp = DAG.getSetCC(dl, MVT::i1, ShAmt,
|
||||
DAG.getConstant(VTBits, MVT::i32), ISD::SETGE);
|
||||
DAG.getConstant(VTBits, dl, MVT::i32),
|
||||
ISD::SETGE);
|
||||
SDValue Lo = DAG.getNode(ISD::SHL, dl, VT, ShOpLo, ShAmt);
|
||||
SDValue Hi = DAG.getNode(ISD::SELECT, dl, VT, Cmp, TrueVal, FalseVal);
|
||||
|
||||
|
@ -1933,7 +1949,7 @@ NVPTXTargetLowering::LowerSTOREVector(SDValue Op, SelectionDAG &DAG) const {
|
|||
// Then the split values
|
||||
for (unsigned i = 0; i < NumElts; ++i) {
|
||||
SDValue ExtVal = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Val,
|
||||
DAG.getIntPtrConstant(i));
|
||||
DAG.getIntPtrConstant(i, DL));
|
||||
if (NeedExt)
|
||||
ExtVal = DAG.getNode(ISD::ANY_EXTEND, DL, MVT::i16, ExtVal);
|
||||
Ops.push_back(ExtVal);
|
||||
|
@ -2077,7 +2093,7 @@ SDValue NVPTXTargetLowering::LowerFormalArguments(
|
|||
(theArgs[i]->getParent() ? theArgs[i]->getParent()->getParent()
|
||||
: nullptr))) {
|
||||
assert(isKernel && "Only kernels can have image/sampler params");
|
||||
InVals.push_back(DAG.getConstant(i + 1, MVT::i32));
|
||||
InVals.push_back(DAG.getConstant(i + 1, dl, MVT::i32));
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -2139,7 +2155,7 @@ SDValue NVPTXTargetLowering::LowerFormalArguments(
|
|||
llvm::ADDRESS_SPACE_PARAM));
|
||||
SDValue srcAddr =
|
||||
DAG.getNode(ISD::ADD, dl, getPointerTy(), Arg,
|
||||
DAG.getConstant(offsets[parti], getPointerTy()));
|
||||
DAG.getConstant(offsets[parti], dl, getPointerTy()));
|
||||
unsigned partAlign =
|
||||
aggregateIsPacked ? 1
|
||||
: TD->getABITypeAlignment(
|
||||
|
@ -2204,9 +2220,9 @@ SDValue NVPTXTargetLowering::LowerFormalArguments(
|
|||
P.getNode()->setIROrder(idx + 1);
|
||||
|
||||
SDValue Elt0 = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, P,
|
||||
DAG.getIntPtrConstant(0));
|
||||
DAG.getIntPtrConstant(0, dl));
|
||||
SDValue Elt1 = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, P,
|
||||
DAG.getIntPtrConstant(1));
|
||||
DAG.getIntPtrConstant(1, dl));
|
||||
|
||||
if (Ins[InsIdx].VT.getSizeInBits() > EltVT.getSizeInBits()) {
|
||||
Elt0 = DAG.getNode(ISD::ANY_EXTEND, dl, Ins[InsIdx].VT, Elt0);
|
||||
|
@ -2239,7 +2255,7 @@ SDValue NVPTXTargetLowering::LowerFormalArguments(
|
|||
llvm::ADDRESS_SPACE_PARAM));
|
||||
SDValue SrcAddr =
|
||||
DAG.getNode(ISD::ADD, dl, getPointerTy(), Arg,
|
||||
DAG.getConstant(Ofst, getPointerTy()));
|
||||
DAG.getConstant(Ofst, dl, getPointerTy()));
|
||||
SDValue P = DAG.getLoad(
|
||||
VecVT, dl, Root, SrcAddr, MachinePointerInfo(SrcValue), false,
|
||||
false, true,
|
||||
|
@ -2251,7 +2267,7 @@ SDValue NVPTXTargetLowering::LowerFormalArguments(
|
|||
if (i + j >= NumElts)
|
||||
break;
|
||||
SDValue Elt = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl, EltVT, P,
|
||||
DAG.getIntPtrConstant(j));
|
||||
DAG.getIntPtrConstant(j, dl));
|
||||
if (Ins[InsIdx].VT.getSizeInBits() > EltVT.getSizeInBits())
|
||||
Elt = DAG.getNode(ISD::ANY_EXTEND, dl, Ins[InsIdx].VT, Elt);
|
||||
InVals.push_back(Elt);
|
||||
|
@ -2309,7 +2325,7 @@ SDValue NVPTXTargetLowering::LowerFormalArguments(
|
|||
else {
|
||||
SDValue p2 = DAG.getNode(
|
||||
ISD::INTRINSIC_WO_CHAIN, dl, ObjectVT,
|
||||
DAG.getConstant(Intrinsic::nvvm_ptr_local_to_gen, MVT::i32), p);
|
||||
DAG.getConstant(Intrinsic::nvvm_ptr_local_to_gen, dl, MVT::i32), p);
|
||||
InVals.push_back(p2);
|
||||
}
|
||||
}
|
||||
|
@ -2363,7 +2379,7 @@ NVPTXTargetLowering::LowerReturn(SDValue Chain, CallingConv::ID CallConv,
|
|||
// We only have one element, so just directly store it
|
||||
if (NeedExtend)
|
||||
StoreVal = DAG.getNode(ISD::ZERO_EXTEND, dl, MVT::i16, StoreVal);
|
||||
SDValue Ops[] = { Chain, DAG.getConstant(0, MVT::i32), StoreVal };
|
||||
SDValue Ops[] = { Chain, DAG.getConstant(0, dl, MVT::i32), StoreVal };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreRetval, dl,
|
||||
DAG.getVTList(MVT::Other), Ops,
|
||||
EltVT, MachinePointerInfo());
|
||||
|
@ -2378,7 +2394,7 @@ NVPTXTargetLowering::LowerReturn(SDValue Chain, CallingConv::ID CallConv,
|
|||
StoreVal1 = DAG.getNode(ISD::ZERO_EXTEND, dl, MVT::i16, StoreVal1);
|
||||
}
|
||||
|
||||
SDValue Ops[] = { Chain, DAG.getConstant(0, MVT::i32), StoreVal0,
|
||||
SDValue Ops[] = { Chain, DAG.getConstant(0, dl, MVT::i32), StoreVal0,
|
||||
StoreVal1 };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreRetvalV2, dl,
|
||||
DAG.getVTList(MVT::Other), Ops,
|
||||
|
@ -2410,7 +2426,7 @@ NVPTXTargetLowering::LowerReturn(SDValue Chain, CallingConv::ID CallConv,
|
|||
SDValue StoreVal;
|
||||
SmallVector<SDValue, 8> Ops;
|
||||
Ops.push_back(Chain);
|
||||
Ops.push_back(DAG.getConstant(Offset, MVT::i32));
|
||||
Ops.push_back(DAG.getConstant(Offset, dl, MVT::i32));
|
||||
unsigned Opc = NVPTXISD::StoreRetvalV2;
|
||||
EVT ExtendedVT = (NeedExtend) ? MVT::i16 : OutVals[0].getValueType();
|
||||
|
||||
|
@ -2475,7 +2491,7 @@ NVPTXTargetLowering::LowerReturn(SDValue Chain, CallingConv::ID CallConv,
|
|||
if (TheValType.isVector())
|
||||
TmpVal = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, dl,
|
||||
TheValType.getVectorElementType(), TmpVal,
|
||||
DAG.getIntPtrConstant(j));
|
||||
DAG.getIntPtrConstant(j, dl));
|
||||
EVT TheStoreType = ValVTs[i];
|
||||
if (RetTy->isIntegerTy() &&
|
||||
TD->getTypeAllocSizeInBits(RetTy) < 32) {
|
||||
|
@ -2489,7 +2505,7 @@ NVPTXTargetLowering::LowerReturn(SDValue Chain, CallingConv::ID CallConv,
|
|||
|
||||
SDValue Ops[] = {
|
||||
Chain,
|
||||
DAG.getConstant(Offsets[i], MVT::i32),
|
||||
DAG.getConstant(Offsets[i], dl, MVT::i32),
|
||||
TmpVal };
|
||||
Chain = DAG.getMemIntrinsicNode(NVPTXISD::StoreRetval, dl,
|
||||
DAG.getVTList(MVT::Other), Ops,
|
||||
|
@ -4111,6 +4127,7 @@ static SDValue TryMULWIDECombine(SDNode *N,
|
|||
return SDValue();
|
||||
}
|
||||
|
||||
SDLoc DL(N);
|
||||
unsigned OptSize = MulType.getSizeInBits() >> 1;
|
||||
SDValue LHS = N->getOperand(0);
|
||||
SDValue RHS = N->getOperand(1);
|
||||
|
@ -4133,7 +4150,7 @@ static SDValue TryMULWIDECombine(SDNode *N,
|
|||
unsigned BitWidth = MulType.getSizeInBits();
|
||||
if (ShiftAmt.sge(0) && ShiftAmt.slt(BitWidth)) {
|
||||
APInt MulVal = APInt(BitWidth, 1) << ShiftAmt;
|
||||
RHS = DCI.DAG.getConstant(MulVal, MulType);
|
||||
RHS = DCI.DAG.getConstant(MulVal, DL, MulType);
|
||||
} else {
|
||||
return SDValue();
|
||||
}
|
||||
|
@ -4155,9 +4172,9 @@ static SDValue TryMULWIDECombine(SDNode *N,
|
|||
// Truncate the operands to the correct size. Note that these are just for
|
||||
// type consistency and will (likely) be eliminated in later phases.
|
||||
SDValue TruncLHS =
|
||||
DCI.DAG.getNode(ISD::TRUNCATE, SDLoc(N), DemotedVT, LHS);
|
||||
DCI.DAG.getNode(ISD::TRUNCATE, DL, DemotedVT, LHS);
|
||||
SDValue TruncRHS =
|
||||
DCI.DAG.getNode(ISD::TRUNCATE, SDLoc(N), DemotedVT, RHS);
|
||||
DCI.DAG.getNode(ISD::TRUNCATE, DL, DemotedVT, RHS);
|
||||
|
||||
unsigned Opc;
|
||||
if (Signed) {
|
||||
|
@ -4166,7 +4183,7 @@ static SDValue TryMULWIDECombine(SDNode *N,
|
|||
Opc = NVPTXISD::MUL_WIDE_UNSIGNED;
|
||||
}
|
||||
|
||||
return DCI.DAG.getNode(Opc, SDLoc(N), MulType, TruncLHS, TruncRHS);
|
||||
return DCI.DAG.getNode(Opc, DL, MulType, TruncLHS, TruncRHS);
|
||||
}
|
||||
|
||||
/// PerformMULCombine - Runs PTX-specific DAG combine patterns on MUL nodes.
|
||||
|
@ -4294,7 +4311,7 @@ static void ReplaceLoadVector(SDNode *N, SelectionDAG &DAG,
|
|||
|
||||
// The select routine does not have access to the LoadSDNode instance, so
|
||||
// pass along the extension information
|
||||
OtherOps.push_back(DAG.getIntPtrConstant(LD->getExtensionType()));
|
||||
OtherOps.push_back(DAG.getIntPtrConstant(LD->getExtensionType(), DL));
|
||||
|
||||
SDValue NewLD = DAG.getMemIntrinsicNode(Opcode, DL, LdResVTs, OtherOps,
|
||||
LD->getMemoryVT(),
|
||||
|
|
|
@ -452,13 +452,13 @@ def Int4Const : PatLeaf<(imm), [{
|
|||
def SHL2MUL32 : SDNodeXForm<imm, [{
|
||||
const APInt &v = N->getAPIntValue();
|
||||
APInt temp(32, 1);
|
||||
return CurDAG->getTargetConstant(temp.shl(v), MVT::i32);
|
||||
return CurDAG->getTargetConstant(temp.shl(v), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def SHL2MUL16 : SDNodeXForm<imm, [{
|
||||
const APInt &v = N->getAPIntValue();
|
||||
APInt temp(16, 1);
|
||||
return CurDAG->getTargetConstant(temp.shl(v), MVT::i16);
|
||||
return CurDAG->getTargetConstant(temp.shl(v), SDLoc(N), MVT::i16);
|
||||
}]>;
|
||||
|
||||
def MULWIDES64
|
||||
|
@ -1138,7 +1138,7 @@ def ROT32imm_sw : NVPTXInst<(outs Int32Regs:$dst),
|
|||
[]>;
|
||||
|
||||
def SUB_FRM_32 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(32-N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(32-N->getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def : Pat<(rotl Int32Regs:$src, (i32 imm:$amt)),
|
||||
|
@ -1189,7 +1189,7 @@ def ROT64imm_sw : NVPTXInst<(outs Int64Regs:$dst), (ins Int64Regs:$src,
|
|||
[]>;
|
||||
|
||||
def SUB_FRM_64 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(64-N->getZExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(64-N->getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def : Pat<(rotl Int64Regs:$src, (i32 imm:$amt)),
|
||||
|
|
|
@ -735,19 +735,19 @@ def VecShuffle_v2i64 : NVPTXVecInst<(outs V2I64Regs:$dst),
|
|||
|
||||
def ShuffleMask0 : SDNodeXForm<vector_shuffle, [{
|
||||
ShuffleVectorSDNode *SVOp = cast<ShuffleVectorSDNode>(N);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(0), MVT::i32);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(0), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def ShuffleMask1 : SDNodeXForm<vector_shuffle, [{
|
||||
ShuffleVectorSDNode *SVOp = cast<ShuffleVectorSDNode>(N);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(1), MVT::i32);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(1), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def ShuffleMask2 : SDNodeXForm<vector_shuffle, [{
|
||||
ShuffleVectorSDNode *SVOp = cast<ShuffleVectorSDNode>(N);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(2), MVT::i32);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(2), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def ShuffleMask3 : SDNodeXForm<vector_shuffle, [{
|
||||
ShuffleVectorSDNode *SVOp = cast<ShuffleVectorSDNode>(N);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(3), MVT::i32);
|
||||
return CurDAG->getTargetConstant(SVOp->getMaskElt(3), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
// The spurious call is here to silence a compiler warning about N being
|
||||
|
|
|
@ -90,19 +90,19 @@ namespace {
|
|||
|
||||
/// getI32Imm - Return a target constant with the specified value, of type
|
||||
/// i32.
|
||||
inline SDValue getI32Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
inline SDValue getI32Imm(unsigned Imm, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i32);
|
||||
}
|
||||
|
||||
/// getI64Imm - Return a target constant with the specified value, of type
|
||||
/// i64.
|
||||
inline SDValue getI64Imm(uint64_t Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i64);
|
||||
inline SDValue getI64Imm(uint64_t Imm, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i64);
|
||||
}
|
||||
|
||||
/// getSmallIPtrImm - Return a target constant of pointer type.
|
||||
inline SDValue getSmallIPtrImm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, PPCLowering->getPointerTy());
|
||||
inline SDValue getSmallIPtrImm(unsigned Imm, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, PPCLowering->getPointerTy());
|
||||
}
|
||||
|
||||
/// isRotateAndMask - Returns true if Mask and Shift can be folded into a
|
||||
|
@ -197,10 +197,11 @@ namespace {
|
|||
// (because we might end up lowering this as 0(%op)).
|
||||
const TargetRegisterInfo *TRI = PPCSubTarget->getRegisterInfo();
|
||||
const TargetRegisterClass *TRC = TRI->getPointerRegClass(*MF, /*Kind=*/1);
|
||||
SDValue RC = CurDAG->getTargetConstant(TRC->getID(), MVT::i32);
|
||||
SDLoc dl(Op);
|
||||
SDValue RC = CurDAG->getTargetConstant(TRC->getID(), dl, MVT::i32);
|
||||
SDValue NewOp =
|
||||
SDValue(CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
|
||||
SDLoc(Op), Op.getValueType(),
|
||||
dl, Op.getValueType(),
|
||||
Op, RC), 0);
|
||||
|
||||
OutOps.push_back(NewOp);
|
||||
|
@ -406,9 +407,9 @@ SDNode *PPCDAGToDAGISel::getFrameIndex(SDNode *SN, SDNode *N, unsigned Offset) {
|
|||
unsigned Opc = N->getValueType(0) == MVT::i32 ? PPC::ADDI : PPC::ADDI8;
|
||||
if (SN->hasOneUse())
|
||||
return CurDAG->SelectNodeTo(SN, Opc, N->getValueType(0), TFI,
|
||||
getSmallIPtrImm(Offset));
|
||||
getSmallIPtrImm(Offset, dl));
|
||||
return CurDAG->getMachineNode(Opc, dl, N->getValueType(0), TFI,
|
||||
getSmallIPtrImm(Offset));
|
||||
getSmallIPtrImm(Offset, dl));
|
||||
}
|
||||
|
||||
bool PPCDAGToDAGISel::isRotateAndMask(SDNode *N, unsigned Mask,
|
||||
|
@ -523,8 +524,8 @@ SDNode *PPCDAGToDAGISel::SelectBitfieldInsert(SDNode *N) {
|
|||
}
|
||||
|
||||
SH &= 31;
|
||||
SDValue Ops[] = { Op0, Op1, getI32Imm(SH), getI32Imm(MB),
|
||||
getI32Imm(ME) };
|
||||
SDValue Ops[] = { Op0, Op1, getI32Imm(SH, dl), getI32Imm(MB, dl),
|
||||
getI32Imm(ME, dl) };
|
||||
return CurDAG->getMachineNode(PPC::RLWIMI, dl, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -652,8 +653,8 @@ static SDNode *SelectInt64Direct(SelectionDAG *CurDAG, SDLoc dl, int64_t Imm) {
|
|||
unsigned Lo = Imm & 0xFFFF;
|
||||
unsigned Hi = (Imm >> 16) & 0xFFFF;
|
||||
|
||||
auto getI32Imm = [CurDAG](unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
auto getI32Imm = [CurDAG, dl](unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i32);
|
||||
};
|
||||
|
||||
// Simple value.
|
||||
|
@ -743,8 +744,8 @@ static SDNode *SelectInt64(SelectionDAG *CurDAG, SDLoc dl, int64_t Imm) {
|
|||
if (!RMin)
|
||||
return SelectInt64Direct(CurDAG, dl, Imm);
|
||||
|
||||
auto getI32Imm = [CurDAG](unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
auto getI32Imm = [CurDAG, dl](unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i32);
|
||||
};
|
||||
|
||||
SDValue Val = SDValue(SelectInt64Direct(CurDAG, dl, MatImm), 0);
|
||||
|
@ -1194,8 +1195,8 @@ class BitPermutationSelector {
|
|||
}
|
||||
}
|
||||
|
||||
SDValue getI32Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
SDValue getI32Imm(unsigned Imm, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i32);
|
||||
}
|
||||
|
||||
uint64_t getZerosMask() {
|
||||
|
@ -1267,7 +1268,8 @@ class BitPermutationSelector {
|
|||
SDValue VRot;
|
||||
if (VRI.RLAmt) {
|
||||
SDValue Ops[] =
|
||||
{ VRI.V, getI32Imm(VRI.RLAmt), getI32Imm(0), getI32Imm(31) };
|
||||
{ VRI.V, getI32Imm(VRI.RLAmt, dl), getI32Imm(0, dl),
|
||||
getI32Imm(31, dl) };
|
||||
VRot = SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32,
|
||||
Ops), 0);
|
||||
} else {
|
||||
|
@ -1277,10 +1279,10 @@ class BitPermutationSelector {
|
|||
SDValue ANDIVal, ANDISVal;
|
||||
if (ANDIMask != 0)
|
||||
ANDIVal = SDValue(CurDAG->getMachineNode(PPC::ANDIo, dl, MVT::i32,
|
||||
VRot, getI32Imm(ANDIMask)), 0);
|
||||
VRot, getI32Imm(ANDIMask, dl)), 0);
|
||||
if (ANDISMask != 0)
|
||||
ANDISVal = SDValue(CurDAG->getMachineNode(PPC::ANDISo, dl, MVT::i32,
|
||||
VRot, getI32Imm(ANDISMask)), 0);
|
||||
VRot, getI32Imm(ANDISMask, dl)), 0);
|
||||
|
||||
SDValue TotalVal;
|
||||
if (!ANDIVal)
|
||||
|
@ -1326,8 +1328,10 @@ class BitPermutationSelector {
|
|||
if (VRI.RLAmt) {
|
||||
if (InstCnt) *InstCnt += 1;
|
||||
SDValue Ops[] =
|
||||
{ VRI.V, getI32Imm(VRI.RLAmt), getI32Imm(0), getI32Imm(31) };
|
||||
Res = SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32, Ops), 0);
|
||||
{ VRI.V, getI32Imm(VRI.RLAmt, dl), getI32Imm(0, dl),
|
||||
getI32Imm(31, dl) };
|
||||
Res = SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32, Ops),
|
||||
0);
|
||||
} else {
|
||||
Res = VRI.V;
|
||||
}
|
||||
|
@ -1347,13 +1351,15 @@ class BitPermutationSelector {
|
|||
for (auto &BG : BitGroups) {
|
||||
if (!Res) {
|
||||
SDValue Ops[] =
|
||||
{ BG.V, getI32Imm(BG.RLAmt), getI32Imm(Bits.size() - BG.EndIdx - 1),
|
||||
getI32Imm(Bits.size() - BG.StartIdx - 1) };
|
||||
{ BG.V, getI32Imm(BG.RLAmt, dl),
|
||||
getI32Imm(Bits.size() - BG.EndIdx - 1, dl),
|
||||
getI32Imm(Bits.size() - BG.StartIdx - 1, dl) };
|
||||
Res = SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32, Ops), 0);
|
||||
} else {
|
||||
SDValue Ops[] =
|
||||
{ Res, BG.V, getI32Imm(BG.RLAmt), getI32Imm(Bits.size() - BG.EndIdx - 1),
|
||||
getI32Imm(Bits.size() - BG.StartIdx - 1) };
|
||||
{ Res, BG.V, getI32Imm(BG.RLAmt, dl),
|
||||
getI32Imm(Bits.size() - BG.EndIdx - 1, dl),
|
||||
getI32Imm(Bits.size() - BG.StartIdx - 1, dl) };
|
||||
Res = SDValue(CurDAG->getMachineNode(PPC::RLWIMI, dl, MVT::i32, Ops), 0);
|
||||
}
|
||||
}
|
||||
|
@ -1372,10 +1378,10 @@ class BitPermutationSelector {
|
|||
SDValue ANDIVal, ANDISVal;
|
||||
if (ANDIMask != 0)
|
||||
ANDIVal = SDValue(CurDAG->getMachineNode(PPC::ANDIo, dl, MVT::i32,
|
||||
Res, getI32Imm(ANDIMask)), 0);
|
||||
Res, getI32Imm(ANDIMask, dl)), 0);
|
||||
if (ANDISMask != 0)
|
||||
ANDISVal = SDValue(CurDAG->getMachineNode(PPC::ANDISo, dl, MVT::i32,
|
||||
Res, getI32Imm(ANDISMask)), 0);
|
||||
Res, getI32Imm(ANDISMask, dl)), 0);
|
||||
|
||||
if (!ANDIVal)
|
||||
Res = ANDISVal;
|
||||
|
@ -1426,27 +1432,27 @@ class BitPermutationSelector {
|
|||
assert(InstMaskStart >= 32 && "Mask cannot start out of range");
|
||||
assert(InstMaskEnd >= 32 && "Mask cannot end out of range");
|
||||
SDValue Ops[] =
|
||||
{ V, getI32Imm(RLAmt), getI32Imm(InstMaskStart - 32),
|
||||
getI32Imm(InstMaskEnd - 32) };
|
||||
{ V, getI32Imm(RLAmt, dl), getI32Imm(InstMaskStart - 32, dl),
|
||||
getI32Imm(InstMaskEnd - 32, dl) };
|
||||
return SDValue(CurDAG->getMachineNode(PPC::RLWINM8, dl, MVT::i64,
|
||||
Ops), 0);
|
||||
}
|
||||
|
||||
if (InstMaskEnd == 63) {
|
||||
SDValue Ops[] =
|
||||
{ V, getI32Imm(RLAmt), getI32Imm(InstMaskStart) };
|
||||
{ V, getI32Imm(RLAmt, dl), getI32Imm(InstMaskStart, dl) };
|
||||
return SDValue(CurDAG->getMachineNode(PPC::RLDICL, dl, MVT::i64, Ops), 0);
|
||||
}
|
||||
|
||||
if (InstMaskStart == 0) {
|
||||
SDValue Ops[] =
|
||||
{ V, getI32Imm(RLAmt), getI32Imm(InstMaskEnd) };
|
||||
{ V, getI32Imm(RLAmt, dl), getI32Imm(InstMaskEnd, dl) };
|
||||
return SDValue(CurDAG->getMachineNode(PPC::RLDICR, dl, MVT::i64, Ops), 0);
|
||||
}
|
||||
|
||||
if (InstMaskEnd == 63 - RLAmt) {
|
||||
SDValue Ops[] =
|
||||
{ V, getI32Imm(RLAmt), getI32Imm(InstMaskStart) };
|
||||
{ V, getI32Imm(RLAmt, dl), getI32Imm(InstMaskStart, dl) };
|
||||
return SDValue(CurDAG->getMachineNode(PPC::RLDIC, dl, MVT::i64, Ops), 0);
|
||||
}
|
||||
|
||||
|
@ -1487,15 +1493,15 @@ class BitPermutationSelector {
|
|||
assert(InstMaskStart >= 32 && "Mask cannot start out of range");
|
||||
assert(InstMaskEnd >= 32 && "Mask cannot end out of range");
|
||||
SDValue Ops[] =
|
||||
{ Base, V, getI32Imm(RLAmt), getI32Imm(InstMaskStart - 32),
|
||||
getI32Imm(InstMaskEnd - 32) };
|
||||
{ Base, V, getI32Imm(RLAmt, dl), getI32Imm(InstMaskStart - 32, dl),
|
||||
getI32Imm(InstMaskEnd - 32, dl) };
|
||||
return SDValue(CurDAG->getMachineNode(PPC::RLWIMI8, dl, MVT::i64,
|
||||
Ops), 0);
|
||||
}
|
||||
|
||||
if (InstMaskEnd == 63 - RLAmt) {
|
||||
SDValue Ops[] =
|
||||
{ Base, V, getI32Imm(RLAmt), getI32Imm(InstMaskStart) };
|
||||
{ Base, V, getI32Imm(RLAmt, dl), getI32Imm(InstMaskStart, dl) };
|
||||
return SDValue(CurDAG->getMachineNode(PPC::RLDIMI, dl, MVT::i64, Ops), 0);
|
||||
}
|
||||
|
||||
|
@ -1642,10 +1648,10 @@ class BitPermutationSelector {
|
|||
SDValue ANDIVal, ANDISVal;
|
||||
if (ANDIMask != 0)
|
||||
ANDIVal = SDValue(CurDAG->getMachineNode(PPC::ANDIo8, dl, MVT::i64,
|
||||
VRot, getI32Imm(ANDIMask)), 0);
|
||||
VRot, getI32Imm(ANDIMask, dl)), 0);
|
||||
if (ANDISMask != 0)
|
||||
ANDISVal = SDValue(CurDAG->getMachineNode(PPC::ANDISo8, dl, MVT::i64,
|
||||
VRot, getI32Imm(ANDISMask)), 0);
|
||||
VRot, getI32Imm(ANDISMask, dl)), 0);
|
||||
|
||||
if (!ANDIVal)
|
||||
TotalVal = ANDISVal;
|
||||
|
@ -1792,10 +1798,10 @@ class BitPermutationSelector {
|
|||
SDValue ANDIVal, ANDISVal;
|
||||
if (ANDIMask != 0)
|
||||
ANDIVal = SDValue(CurDAG->getMachineNode(PPC::ANDIo8, dl, MVT::i64,
|
||||
Res, getI32Imm(ANDIMask)), 0);
|
||||
Res, getI32Imm(ANDIMask, dl)), 0);
|
||||
if (ANDISMask != 0)
|
||||
ANDISVal = SDValue(CurDAG->getMachineNode(PPC::ANDISo8, dl, MVT::i64,
|
||||
Res, getI32Imm(ANDISMask)), 0);
|
||||
Res, getI32Imm(ANDISMask, dl)), 0);
|
||||
|
||||
if (!ANDIVal)
|
||||
Res = ANDISVal;
|
||||
|
@ -1940,11 +1946,13 @@ SDValue PPCDAGToDAGISel::SelectCC(SDValue LHS, SDValue RHS,
|
|||
// SETEQ/SETNE comparison with 16-bit immediate, fold it.
|
||||
if (isUInt<16>(Imm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPLWI, dl, MVT::i32, LHS,
|
||||
getI32Imm(Imm & 0xFFFF)), 0);
|
||||
getI32Imm(Imm & 0xFFFF, dl)),
|
||||
0);
|
||||
// If this is a 16-bit signed immediate, fold it.
|
||||
if (isInt<16>((int)Imm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPWI, dl, MVT::i32, LHS,
|
||||
getI32Imm(Imm & 0xFFFF)), 0);
|
||||
getI32Imm(Imm & 0xFFFF, dl)),
|
||||
0);
|
||||
|
||||
// For non-equality comparisons, the default code would materialize the
|
||||
// constant, then compare against it, like this:
|
||||
|
@ -1956,21 +1964,22 @@ SDValue PPCDAGToDAGISel::SelectCC(SDValue LHS, SDValue RHS,
|
|||
// cmplwi cr0,r0,0x5678
|
||||
// beq cr0,L6
|
||||
SDValue Xor(CurDAG->getMachineNode(PPC::XORIS, dl, MVT::i32, LHS,
|
||||
getI32Imm(Imm >> 16)), 0);
|
||||
getI32Imm(Imm >> 16, dl)), 0);
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPLWI, dl, MVT::i32, Xor,
|
||||
getI32Imm(Imm & 0xFFFF)), 0);
|
||||
getI32Imm(Imm & 0xFFFF, dl)), 0);
|
||||
}
|
||||
Opc = PPC::CMPLW;
|
||||
} else if (ISD::isUnsignedIntSetCC(CC)) {
|
||||
if (isInt32Immediate(RHS, Imm) && isUInt<16>(Imm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPLWI, dl, MVT::i32, LHS,
|
||||
getI32Imm(Imm & 0xFFFF)), 0);
|
||||
getI32Imm(Imm & 0xFFFF, dl)), 0);
|
||||
Opc = PPC::CMPLW;
|
||||
} else {
|
||||
short SImm;
|
||||
if (isIntS16Immediate(RHS, SImm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPWI, dl, MVT::i32, LHS,
|
||||
getI32Imm((int)SImm & 0xFFFF)),
|
||||
getI32Imm((int)SImm & 0xFFFF,
|
||||
dl)),
|
||||
0);
|
||||
Opc = PPC::CMPW;
|
||||
}
|
||||
|
@ -1981,11 +1990,13 @@ SDValue PPCDAGToDAGISel::SelectCC(SDValue LHS, SDValue RHS,
|
|||
// SETEQ/SETNE comparison with 16-bit immediate, fold it.
|
||||
if (isUInt<16>(Imm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPLDI, dl, MVT::i64, LHS,
|
||||
getI32Imm(Imm & 0xFFFF)), 0);
|
||||
getI32Imm(Imm & 0xFFFF, dl)),
|
||||
0);
|
||||
// If this is a 16-bit signed immediate, fold it.
|
||||
if (isInt<16>(Imm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPDI, dl, MVT::i64, LHS,
|
||||
getI32Imm(Imm & 0xFFFF)), 0);
|
||||
getI32Imm(Imm & 0xFFFF, dl)),
|
||||
0);
|
||||
|
||||
// For non-equality comparisons, the default code would materialize the
|
||||
// constant, then compare against it, like this:
|
||||
|
@ -1998,22 +2009,23 @@ SDValue PPCDAGToDAGISel::SelectCC(SDValue LHS, SDValue RHS,
|
|||
// beq cr0,L6
|
||||
if (isUInt<32>(Imm)) {
|
||||
SDValue Xor(CurDAG->getMachineNode(PPC::XORIS8, dl, MVT::i64, LHS,
|
||||
getI64Imm(Imm >> 16)), 0);
|
||||
getI64Imm(Imm >> 16, dl)), 0);
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPLDI, dl, MVT::i64, Xor,
|
||||
getI64Imm(Imm & 0xFFFF)), 0);
|
||||
getI64Imm(Imm & 0xFFFF, dl)),
|
||||
0);
|
||||
}
|
||||
}
|
||||
Opc = PPC::CMPLD;
|
||||
} else if (ISD::isUnsignedIntSetCC(CC)) {
|
||||
if (isInt64Immediate(RHS.getNode(), Imm) && isUInt<16>(Imm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPLDI, dl, MVT::i64, LHS,
|
||||
getI64Imm(Imm & 0xFFFF)), 0);
|
||||
getI64Imm(Imm & 0xFFFF, dl)), 0);
|
||||
Opc = PPC::CMPLD;
|
||||
} else {
|
||||
short SImm;
|
||||
if (isIntS16Immediate(RHS, SImm))
|
||||
return SDValue(CurDAG->getMachineNode(PPC::CMPDI, dl, MVT::i64, LHS,
|
||||
getI64Imm(SImm & 0xFFFF)),
|
||||
getI64Imm(SImm & 0xFFFF, dl)),
|
||||
0);
|
||||
Opc = PPC::CMPD;
|
||||
}
|
||||
|
@ -2215,26 +2227,29 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDNode *N) {
|
|||
default: break;
|
||||
case ISD::SETEQ: {
|
||||
Op = SDValue(CurDAG->getMachineNode(PPC::CNTLZW, dl, MVT::i32, Op), 0);
|
||||
SDValue Ops[] = { Op, getI32Imm(27), getI32Imm(5), getI32Imm(31) };
|
||||
SDValue Ops[] = { Op, getI32Imm(27, dl), getI32Imm(5, dl),
|
||||
getI32Imm(31, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
case ISD::SETNE: {
|
||||
if (isPPC64) break;
|
||||
SDValue AD =
|
||||
SDValue(CurDAG->getMachineNode(PPC::ADDIC, dl, MVT::i32, MVT::Glue,
|
||||
Op, getI32Imm(~0U)), 0);
|
||||
Op, getI32Imm(~0U, dl)), 0);
|
||||
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32, AD, Op,
|
||||
AD.getValue(1));
|
||||
}
|
||||
case ISD::SETLT: {
|
||||
SDValue Ops[] = { Op, getI32Imm(1), getI32Imm(31), getI32Imm(31) };
|
||||
SDValue Ops[] = { Op, getI32Imm(1, dl), getI32Imm(31, dl),
|
||||
getI32Imm(31, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
case ISD::SETGT: {
|
||||
SDValue T =
|
||||
SDValue(CurDAG->getMachineNode(PPC::NEG, dl, MVT::i32, Op), 0);
|
||||
T = SDValue(CurDAG->getMachineNode(PPC::ANDC, dl, MVT::i32, T, Op), 0);
|
||||
SDValue Ops[] = { T, getI32Imm(1), getI32Imm(31), getI32Imm(31) };
|
||||
SDValue Ops[] = { T, getI32Imm(1, dl), getI32Imm(31, dl),
|
||||
getI32Imm(31, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2245,34 +2260,35 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDNode *N) {
|
|||
case ISD::SETEQ:
|
||||
if (isPPC64) break;
|
||||
Op = SDValue(CurDAG->getMachineNode(PPC::ADDIC, dl, MVT::i32, MVT::Glue,
|
||||
Op, getI32Imm(1)), 0);
|
||||
Op, getI32Imm(1, dl)), 0);
|
||||
return CurDAG->SelectNodeTo(N, PPC::ADDZE, MVT::i32,
|
||||
SDValue(CurDAG->getMachineNode(PPC::LI, dl,
|
||||
MVT::i32,
|
||||
getI32Imm(0)), 0),
|
||||
Op.getValue(1));
|
||||
getI32Imm(0, dl)),
|
||||
0), Op.getValue(1));
|
||||
case ISD::SETNE: {
|
||||
if (isPPC64) break;
|
||||
Op = SDValue(CurDAG->getMachineNode(PPC::NOR, dl, MVT::i32, Op, Op), 0);
|
||||
SDNode *AD = CurDAG->getMachineNode(PPC::ADDIC, dl, MVT::i32, MVT::Glue,
|
||||
Op, getI32Imm(~0U));
|
||||
Op, getI32Imm(~0U, dl));
|
||||
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32, SDValue(AD, 0),
|
||||
Op, SDValue(AD, 1));
|
||||
}
|
||||
case ISD::SETLT: {
|
||||
SDValue AD = SDValue(CurDAG->getMachineNode(PPC::ADDI, dl, MVT::i32, Op,
|
||||
getI32Imm(1)), 0);
|
||||
getI32Imm(1, dl)), 0);
|
||||
SDValue AN = SDValue(CurDAG->getMachineNode(PPC::AND, dl, MVT::i32, AD,
|
||||
Op), 0);
|
||||
SDValue Ops[] = { AN, getI32Imm(1), getI32Imm(31), getI32Imm(31) };
|
||||
SDValue Ops[] = { AN, getI32Imm(1, dl), getI32Imm(31, dl),
|
||||
getI32Imm(31, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
case ISD::SETGT: {
|
||||
SDValue Ops[] = { Op, getI32Imm(1), getI32Imm(31), getI32Imm(31) };
|
||||
Op = SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32, Ops),
|
||||
0);
|
||||
SDValue Ops[] = { Op, getI32Imm(1, dl), getI32Imm(31, dl),
|
||||
getI32Imm(31, dl) };
|
||||
Op = SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32, Ops), 0);
|
||||
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Op,
|
||||
getI32Imm(1));
|
||||
getI32Imm(1, dl));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -2322,15 +2338,15 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDNode *N) {
|
|||
IntCR = SDValue(CurDAG->getMachineNode(PPC::MFOCRF, dl, MVT::i32, CR7Reg,
|
||||
CCReg), 0);
|
||||
|
||||
SDValue Ops[] = { IntCR, getI32Imm((32-(3-Idx)) & 31),
|
||||
getI32Imm(31), getI32Imm(31) };
|
||||
SDValue Ops[] = { IntCR, getI32Imm((32 - (3 - Idx)) & 31, dl),
|
||||
getI32Imm(31, dl), getI32Imm(31, dl) };
|
||||
if (!Inv)
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
|
||||
// Get the specified bit.
|
||||
SDValue Tmp =
|
||||
SDValue(CurDAG->getMachineNode(PPC::RLWINM, dl, MVT::i32, Ops), 0);
|
||||
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Tmp, getI32Imm(1));
|
||||
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Tmp, getI32Imm(1, dl));
|
||||
}
|
||||
|
||||
SDNode *PPCDAGToDAGISel::transferMemOperands(SDNode *N, SDNode *Result) {
|
||||
|
@ -2398,7 +2414,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
SDValue N0 = N->getOperand(0);
|
||||
SDValue ShiftAmt =
|
||||
CurDAG->getTargetConstant(*cast<ConstantSDNode>(N->getOperand(1))->
|
||||
getConstantIntValue(), N->getValueType(0));
|
||||
getConstantIntValue(), dl,
|
||||
N->getValueType(0));
|
||||
if (N->getValueType(0) == MVT::i64) {
|
||||
SDNode *Op =
|
||||
CurDAG->getMachineNode(PPC::SRADI, dl, MVT::i64, MVT::Glue,
|
||||
|
@ -2513,7 +2530,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
if (isInt32Immediate(N->getOperand(1), Imm) &&
|
||||
isRotateAndMask(N->getOperand(0).getNode(), Imm, false, SH, MB, ME)) {
|
||||
SDValue Val = N->getOperand(0).getOperand(0);
|
||||
SDValue Ops[] = { Val, getI32Imm(SH), getI32Imm(MB), getI32Imm(ME) };
|
||||
SDValue Ops[] = { Val, getI32Imm(SH, dl), getI32Imm(MB, dl),
|
||||
getI32Imm(ME, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
// If this is just a masked value where the input is not handled above, and
|
||||
|
@ -2522,7 +2540,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
isRunOfOnes(Imm, MB, ME) &&
|
||||
N->getOperand(0).getOpcode() != ISD::ROTL) {
|
||||
SDValue Val = N->getOperand(0);
|
||||
SDValue Ops[] = { Val, getI32Imm(0), getI32Imm(MB), getI32Imm(ME) };
|
||||
SDValue Ops[] = { Val, getI32Imm(0, dl), getI32Imm(MB, dl),
|
||||
getI32Imm(ME, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
// If this is a 64-bit zero-extension mask, emit rldicl.
|
||||
|
@ -2544,7 +2563,7 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
SH = 64 - Imm;
|
||||
}
|
||||
|
||||
SDValue Ops[] = { Val, getI32Imm(SH), getI32Imm(MB) };
|
||||
SDValue Ops[] = { Val, getI32Imm(SH, dl), getI32Imm(MB, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLDICL, MVT::i64, Ops);
|
||||
}
|
||||
// AND X, 0 -> 0, not "rlwinm 32".
|
||||
|
@ -2562,7 +2581,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
if (isRunOfOnes(Imm, MB, ME)) {
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
N->getOperand(0).getOperand(1),
|
||||
getI32Imm(0), getI32Imm(MB),getI32Imm(ME) };
|
||||
getI32Imm(0, dl), getI32Imm(MB, dl),
|
||||
getI32Imm(ME, dl) };
|
||||
return CurDAG->getMachineNode(PPC::RLWIMI, dl, MVT::i32, Ops);
|
||||
}
|
||||
}
|
||||
|
@ -2603,7 +2623,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
if (isOpcWithIntImmediate(N->getOperand(0).getNode(), ISD::AND, Imm) &&
|
||||
isRotateAndMask(N, Imm, true, SH, MB, ME)) {
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
getI32Imm(SH), getI32Imm(MB), getI32Imm(ME) };
|
||||
getI32Imm(SH, dl), getI32Imm(MB, dl),
|
||||
getI32Imm(ME, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
|
||||
|
@ -2615,7 +2636,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
if (isOpcWithIntImmediate(N->getOperand(0).getNode(), ISD::AND, Imm) &&
|
||||
isRotateAndMask(N, Imm, true, SH, MB, ME)) {
|
||||
SDValue Ops[] = { N->getOperand(0).getOperand(0),
|
||||
getI32Imm(SH), getI32Imm(MB), getI32Imm(ME) };
|
||||
getI32Imm(SH, dl), getI32Imm(MB, dl),
|
||||
getI32Imm(ME, dl) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Ops);
|
||||
}
|
||||
|
||||
|
@ -2635,11 +2657,12 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
unsigned Opcode = (InVT == MVT::i64) ? PPC::ANDIo8 : PPC::ANDIo;
|
||||
SDValue AndI(CurDAG->getMachineNode(Opcode, dl, InVT, MVT::Glue,
|
||||
N->getOperand(0),
|
||||
CurDAG->getTargetConstant(1, InVT)), 0);
|
||||
CurDAG->getTargetConstant(1, dl, InVT)),
|
||||
0);
|
||||
SDValue CR0Reg = CurDAG->getRegister(PPC::CR0, MVT::i32);
|
||||
SDValue SRIdxVal =
|
||||
CurDAG->getTargetConstant(N->getOpcode() == PPCISD::ANDIo_1_EQ_BIT ?
|
||||
PPC::sub_eq : PPC::sub_gt, MVT::i32);
|
||||
PPC::sub_eq : PPC::sub_gt, dl, MVT::i32);
|
||||
|
||||
return CurDAG->SelectNodeTo(N, TargetOpcode::EXTRACT_SUBREG, MVT::i1,
|
||||
CR0Reg, SRIdxVal,
|
||||
|
@ -2666,7 +2689,7 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
N->getValueType(0) == MVT::i32) {
|
||||
SDNode *Tmp =
|
||||
CurDAG->getMachineNode(PPC::ADDIC, dl, MVT::i32, MVT::Glue,
|
||||
N->getOperand(0), getI32Imm(~0U));
|
||||
N->getOperand(0), getI32Imm(~0U, dl));
|
||||
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32,
|
||||
SDValue(Tmp, 0), N->getOperand(0),
|
||||
SDValue(Tmp, 1));
|
||||
|
@ -2730,7 +2753,7 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
SelectCCOp = PPC::SELECT_CC_VRRC;
|
||||
|
||||
SDValue Ops[] = { CCReg, N->getOperand(2), N->getOperand(3),
|
||||
getI32Imm(BROpc) };
|
||||
getI32Imm(BROpc, dl) };
|
||||
return CurDAG->SelectNodeTo(N, SelectCCOp, N->getValueType(0), Ops);
|
||||
}
|
||||
case ISD::VSELECT:
|
||||
|
@ -2764,7 +2787,8 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
DM[1] = 1 - tmp;
|
||||
}
|
||||
|
||||
SDValue DMV = CurDAG->getTargetConstant(DM[1] | (DM[0] << 1), MVT::i32);
|
||||
SDValue DMV = CurDAG->getTargetConstant(DM[1] | (DM[0] << 1), dl,
|
||||
MVT::i32);
|
||||
|
||||
if (Op1 == Op2 && DM[0] == 0 && DM[1] == 0 &&
|
||||
Op1.getOpcode() == ISD::SCALAR_TO_VECTOR &&
|
||||
|
@ -2803,7 +2827,7 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
// Op #4 is the Flag.
|
||||
// Prevent PPC::PRED_* from being selected into LI.
|
||||
SDValue Pred =
|
||||
getI32Imm(cast<ConstantSDNode>(N->getOperand(1))->getZExtValue());
|
||||
getI32Imm(cast<ConstantSDNode>(N->getOperand(1))->getZExtValue(), dl);
|
||||
SDValue Ops[] = { Pred, N->getOperand(2), N->getOperand(3),
|
||||
N->getOperand(0), N->getOperand(4) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::BCC, MVT::Other, Ops);
|
||||
|
@ -2833,7 +2857,7 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
}
|
||||
|
||||
SDValue CondCode = SelectCC(N->getOperand(2), N->getOperand(3), CC, dl);
|
||||
SDValue Ops[] = { getI32Imm(PCC), CondCode,
|
||||
SDValue Ops[] = { getI32Imm(PCC, dl), CondCode,
|
||||
N->getOperand(4), N->getOperand(0) };
|
||||
return CurDAG->SelectNodeTo(N, PPC::BCC, MVT::Other, Ops);
|
||||
}
|
||||
|
@ -2936,7 +2960,7 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
// Into: tmp = VSPLTIS[BHW] elt
|
||||
// VADDU[BHW]M tmp, tmp
|
||||
// Where: [BHW] = B for size = 1, H for size = 2, W for size = 4
|
||||
SDValue EltVal = getI32Imm(Elt >> 1);
|
||||
SDValue EltVal = getI32Imm(Elt >> 1, dl);
|
||||
SDNode *Tmp = CurDAG->getMachineNode(Opc1, dl, VT, EltVal);
|
||||
SDValue TmpVal = SDValue(Tmp, 0);
|
||||
return CurDAG->getMachineNode(Opc2, dl, VT, TmpVal, TmpVal);
|
||||
|
@ -2948,9 +2972,9 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
// Into: tmp1 = VSPLTIS[BHW] elt-16
|
||||
// tmp2 = VSPLTIS[BHW] -16
|
||||
// VSUBU[BHW]M tmp1, tmp2
|
||||
SDValue EltVal = getI32Imm(Elt - 16);
|
||||
SDValue EltVal = getI32Imm(Elt - 16, dl);
|
||||
SDNode *Tmp1 = CurDAG->getMachineNode(Opc1, dl, VT, EltVal);
|
||||
EltVal = getI32Imm(-16);
|
||||
EltVal = getI32Imm(-16, dl);
|
||||
SDNode *Tmp2 = CurDAG->getMachineNode(Opc1, dl, VT, EltVal);
|
||||
return CurDAG->getMachineNode(Opc3, dl, VT, SDValue(Tmp1, 0),
|
||||
SDValue(Tmp2, 0));
|
||||
|
@ -2962,9 +2986,9 @@ SDNode *PPCDAGToDAGISel::Select(SDNode *N) {
|
|||
// Into: tmp1 = VSPLTIS[BHW] elt+16
|
||||
// tmp2 = VSPLTIS[BHW] -16
|
||||
// VADDU[BHW]M tmp1, tmp2
|
||||
SDValue EltVal = getI32Imm(Elt + 16);
|
||||
SDValue EltVal = getI32Imm(Elt + 16, dl);
|
||||
SDNode *Tmp1 = CurDAG->getMachineNode(Opc1, dl, VT, EltVal);
|
||||
EltVal = getI32Imm(-16);
|
||||
EltVal = getI32Imm(-16, dl);
|
||||
SDNode *Tmp2 = CurDAG->getMachineNode(Opc1, dl, VT, EltVal);
|
||||
return CurDAG->getMachineNode(Opc2, dl, VT, SDValue(Tmp1, 0),
|
||||
SDValue(Tmp2, 0));
|
||||
|
@ -3173,7 +3197,8 @@ SDValue PPCDAGToDAGISel::combineToCMPB(SDNode *N) {
|
|||
bool NonTrivialMask = ((int64_t) Mask) != INT64_C(-1);
|
||||
if (NonTrivialMask && !Alt) {
|
||||
// Res = Mask & CMPB
|
||||
Res = CurDAG->getNode(ISD::AND, dl, VT, Res, CurDAG->getConstant(Mask, VT));
|
||||
Res = CurDAG->getNode(ISD::AND, dl, VT, Res,
|
||||
CurDAG->getConstant(Mask, dl, VT));
|
||||
} else if (Alt) {
|
||||
// Res = (CMPB & Mask) | (~CMPB & Alt)
|
||||
// Which, as suggested here:
|
||||
|
@ -3182,8 +3207,9 @@ SDValue PPCDAGToDAGISel::combineToCMPB(SDNode *N) {
|
|||
// Res = Alt ^ ((Alt ^ Mask) & CMPB)
|
||||
// useful because the (Alt ^ Mask) can be pre-computed.
|
||||
Res = CurDAG->getNode(ISD::AND, dl, VT, Res,
|
||||
CurDAG->getConstant(Mask ^ Alt, VT));
|
||||
Res = CurDAG->getNode(ISD::XOR, dl, VT, Res, CurDAG->getConstant(Alt, VT));
|
||||
CurDAG->getConstant(Mask ^ Alt, dl, VT));
|
||||
Res = CurDAG->getNode(ISD::XOR, dl, VT, Res,
|
||||
CurDAG->getConstant(Alt, dl, VT));
|
||||
}
|
||||
|
||||
return Res;
|
||||
|
@ -3215,20 +3241,20 @@ void PPCDAGToDAGISel::foldBoolExts(SDValue &Res, SDNode *&N) {
|
|||
EVT VT = N->getValueType(0);
|
||||
SDValue Cond = N->getOperand(0);
|
||||
SDValue ConstTrue =
|
||||
CurDAG->getConstant(N->getOpcode() == ISD::SIGN_EXTEND ? -1 : 1, VT);
|
||||
SDValue ConstFalse = CurDAG->getConstant(0, VT);
|
||||
CurDAG->getConstant(N->getOpcode() == ISD::SIGN_EXTEND ? -1 : 1, dl, VT);
|
||||
SDValue ConstFalse = CurDAG->getConstant(0, dl, VT);
|
||||
|
||||
do {
|
||||
SDNode *User = *N->use_begin();
|
||||
if (User->getNumOperands() != 2)
|
||||
break;
|
||||
|
||||
auto TryFold = [this, N, User](SDValue Val) {
|
||||
auto TryFold = [this, N, User, dl](SDValue Val) {
|
||||
SDValue UserO0 = User->getOperand(0), UserO1 = User->getOperand(1);
|
||||
SDValue O0 = UserO0.getNode() == N ? Val : UserO0;
|
||||
SDValue O1 = UserO1.getNode() == N ? Val : UserO1;
|
||||
|
||||
return CurDAG->FoldConstantArithmetic(User->getOpcode(),
|
||||
return CurDAG->FoldConstantArithmetic(User->getOpcode(), dl,
|
||||
User->getValueType(0),
|
||||
O0.getNode(), O1.getNode());
|
||||
};
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -56,22 +56,23 @@ def tlscall : Operand<i64> {
|
|||
|
||||
def SHL64 : SDNodeXForm<imm, [{
|
||||
// Transformation function: 63 - imm
|
||||
return getI32Imm(63 - N->getZExtValue());
|
||||
return getI32Imm(63 - N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def SRL64 : SDNodeXForm<imm, [{
|
||||
// Transformation function: 64 - imm
|
||||
return N->getZExtValue() ? getI32Imm(64 - N->getZExtValue()) : getI32Imm(0);
|
||||
return N->getZExtValue() ? getI32Imm(64 - N->getZExtValue(), SDLoc(N))
|
||||
: getI32Imm(0, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def HI32_48 : SDNodeXForm<imm, [{
|
||||
// Transformation function: shift the immediate value down into the low bits.
|
||||
return getI32Imm((unsigned short)(N->getZExtValue() >> 32));
|
||||
return getI32Imm((unsigned short)(N->getZExtValue() >> 32, SDLoc(N)));
|
||||
}]>;
|
||||
|
||||
def HI48_64 : SDNodeXForm<imm, [{
|
||||
// Transformation function: shift the immediate value down into the low bits.
|
||||
return getI32Imm((unsigned short)(N->getZExtValue() >> 48));
|
||||
return getI32Imm((unsigned short)(N->getZExtValue() >> 48, SDLoc(N)));
|
||||
}]>;
|
||||
|
||||
|
||||
|
|
|
@ -144,7 +144,7 @@ def vmrghw_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
|||
|
||||
|
||||
def VSLDOI_get_imm : SDNodeXForm<vector_shuffle, [{
|
||||
return getI32Imm(PPC::isVSLDOIShuffleMask(N, 0, *CurDAG));
|
||||
return getI32Imm(PPC::isVSLDOIShuffleMask(N, 0, *CurDAG), SDLoc(N));
|
||||
}]>;
|
||||
def vsldoi_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
||||
(vector_shuffle node:$lhs, node:$rhs), [{
|
||||
|
@ -155,7 +155,7 @@ def vsldoi_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
|||
/// VSLDOI_unary* - These are used to match vsldoi(X,X), which is turned into
|
||||
/// vector_shuffle(X,undef,mask) by the dag combiner.
|
||||
def VSLDOI_unary_get_imm : SDNodeXForm<vector_shuffle, [{
|
||||
return getI32Imm(PPC::isVSLDOIShuffleMask(N, 1, *CurDAG));
|
||||
return getI32Imm(PPC::isVSLDOIShuffleMask(N, 1, *CurDAG), SDLoc(N));
|
||||
}]>;
|
||||
def vsldoi_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
||||
(vector_shuffle node:$lhs, node:$rhs), [{
|
||||
|
@ -166,7 +166,7 @@ def vsldoi_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
|||
/// VSLDOI_swapped* - These fragments are provided for little-endian, where
|
||||
/// the inputs must be swapped for correct semantics.
|
||||
def VSLDOI_swapped_get_imm : SDNodeXForm<vector_shuffle, [{
|
||||
return getI32Imm(PPC::isVSLDOIShuffleMask(N, 2, *CurDAG));
|
||||
return getI32Imm(PPC::isVSLDOIShuffleMask(N, 2, *CurDAG), SDLoc(N));
|
||||
}]>;
|
||||
def vsldoi_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
||||
(vector_shuffle node:$lhs, node:$rhs), [{
|
||||
|
@ -176,21 +176,21 @@ def vsldoi_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
|||
|
||||
// VSPLT*_get_imm xform function: convert vector_shuffle mask to VSPLT* imm.
|
||||
def VSPLTB_get_imm : SDNodeXForm<vector_shuffle, [{
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N, 1, *CurDAG));
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N, 1, *CurDAG), SDLoc(N));
|
||||
}]>;
|
||||
def vspltb_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
||||
(vector_shuffle node:$lhs, node:$rhs), [{
|
||||
return PPC::isSplatShuffleMask(cast<ShuffleVectorSDNode>(N), 1);
|
||||
}], VSPLTB_get_imm>;
|
||||
def VSPLTH_get_imm : SDNodeXForm<vector_shuffle, [{
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N, 2, *CurDAG));
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N, 2, *CurDAG), SDLoc(N));
|
||||
}]>;
|
||||
def vsplth_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
||||
(vector_shuffle node:$lhs, node:$rhs), [{
|
||||
return PPC::isSplatShuffleMask(cast<ShuffleVectorSDNode>(N), 2);
|
||||
}], VSPLTH_get_imm>;
|
||||
def VSPLTW_get_imm : SDNodeXForm<vector_shuffle, [{
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N, 4, *CurDAG));
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N, 4, *CurDAG), SDLoc(N));
|
||||
}]>;
|
||||
def vspltw_shuffle : PatFrag<(ops node:$lhs, node:$rhs),
|
||||
(vector_shuffle node:$lhs, node:$rhs), [{
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
def HasHTM : Predicate<"PPCSubTarget->hasHTM()">;
|
||||
|
||||
def HTM_get_imm : SDNodeXForm<imm, [{
|
||||
return getI32Imm (N->getZExtValue());
|
||||
return getI32Imm (N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
let hasSideEffects = 1, usesCustomInserter = 1 in {
|
||||
|
|
|
@ -228,41 +228,42 @@ def PPCdynalloc : SDNode<"PPCISD::DYNALLOC", SDTDynOp, [SDNPHasChain]>;
|
|||
|
||||
def SHL32 : SDNodeXForm<imm, [{
|
||||
// Transformation function: 31 - imm
|
||||
return getI32Imm(31 - N->getZExtValue());
|
||||
return getI32Imm(31 - N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def SRL32 : SDNodeXForm<imm, [{
|
||||
// Transformation function: 32 - imm
|
||||
return N->getZExtValue() ? getI32Imm(32 - N->getZExtValue()) : getI32Imm(0);
|
||||
return N->getZExtValue() ? getI32Imm(32 - N->getZExtValue(), SDLoc(N))
|
||||
: getI32Imm(0, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def LO16 : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the low 16 bits.
|
||||
return getI32Imm((unsigned short)N->getZExtValue());
|
||||
return getI32Imm((unsigned short)N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def HI16 : SDNodeXForm<imm, [{
|
||||
// Transformation function: shift the immediate value down into the low bits.
|
||||
return getI32Imm((unsigned)N->getZExtValue() >> 16);
|
||||
return getI32Imm((unsigned)N->getZExtValue() >> 16, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def HA16 : SDNodeXForm<imm, [{
|
||||
// Transformation function: shift the immediate value down into the low bits.
|
||||
signed int Val = N->getZExtValue();
|
||||
return getI32Imm((Val - (signed short)Val) >> 16);
|
||||
return getI32Imm((Val - (signed short)Val) >> 16, SDLoc(N));
|
||||
}]>;
|
||||
def MB : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the start bit of a mask
|
||||
unsigned mb = 0, me;
|
||||
(void)isRunOfOnes((unsigned)N->getZExtValue(), mb, me);
|
||||
return getI32Imm(mb);
|
||||
return getI32Imm(mb, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def ME : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the end bit of a mask
|
||||
unsigned mb, me = 0;
|
||||
(void)isRunOfOnes((unsigned)N->getZExtValue(), mb, me);
|
||||
return getI32Imm(me);
|
||||
return getI32Imm(me, SDLoc(N));
|
||||
}]>;
|
||||
def maskimm32 : PatLeaf<(imm), [{
|
||||
// maskImm predicate - True if immediate is a run of ones.
|
||||
|
|
|
@ -50,7 +50,6 @@ public:
|
|||
|
||||
private:
|
||||
bool isInlineImmediate(SDNode *N) const;
|
||||
inline SDValue getSmallIPtrImm(unsigned Imm);
|
||||
bool FoldOperand(SDValue &Src, SDValue &Sel, SDValue &Neg, SDValue &Abs,
|
||||
const R600InstrInfo *TII);
|
||||
bool FoldOperands(unsigned, const R600InstrInfo *, std::vector<SDValue> &);
|
||||
|
@ -189,27 +188,23 @@ const TargetRegisterClass *AMDGPUDAGToDAGISel::getOperandRegClass(SDNode *N,
|
|||
}
|
||||
}
|
||||
|
||||
SDValue AMDGPUDAGToDAGISel::getSmallIPtrImm(unsigned int Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
}
|
||||
|
||||
bool AMDGPUDAGToDAGISel::SelectADDRParam(
|
||||
SDValue Addr, SDValue& R1, SDValue& R2) {
|
||||
|
||||
if (Addr.getOpcode() == ISD::FrameIndex) {
|
||||
if (FrameIndexSDNode *FIN = dyn_cast<FrameIndexSDNode>(Addr)) {
|
||||
R1 = CurDAG->getTargetFrameIndex(FIN->getIndex(), MVT::i32);
|
||||
R2 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
R2 = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
} else {
|
||||
R1 = Addr;
|
||||
R2 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
R2 = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
}
|
||||
} else if (Addr.getOpcode() == ISD::ADD) {
|
||||
R1 = Addr.getOperand(0);
|
||||
R2 = Addr.getOperand(1);
|
||||
} else {
|
||||
R1 = Addr;
|
||||
R2 = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
R2 = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
@ -232,17 +227,17 @@ bool AMDGPUDAGToDAGISel::SelectADDR64(SDValue Addr, SDValue& R1, SDValue& R2) {
|
|||
if (Addr.getOpcode() == ISD::FrameIndex) {
|
||||
if (FrameIndexSDNode *FIN = dyn_cast<FrameIndexSDNode>(Addr)) {
|
||||
R1 = CurDAG->getTargetFrameIndex(FIN->getIndex(), MVT::i64);
|
||||
R2 = CurDAG->getTargetConstant(0, MVT::i64);
|
||||
R2 = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i64);
|
||||
} else {
|
||||
R1 = Addr;
|
||||
R2 = CurDAG->getTargetConstant(0, MVT::i64);
|
||||
R2 = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i64);
|
||||
}
|
||||
} else if (Addr.getOpcode() == ISD::ADD) {
|
||||
R1 = Addr.getOperand(0);
|
||||
R2 = Addr.getOperand(1);
|
||||
} else {
|
||||
R1 = Addr;
|
||||
R2 = CurDAG->getTargetConstant(0, MVT::i64);
|
||||
R2 = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i64);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
@ -326,7 +321,8 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
}
|
||||
}
|
||||
|
||||
SDValue RegClass = CurDAG->getTargetConstant(RegClassID, MVT::i32);
|
||||
SDLoc DL(N);
|
||||
SDValue RegClass = CurDAG->getTargetConstant(RegClassID, DL, MVT::i32);
|
||||
|
||||
if (NumVectorElts == 1) {
|
||||
return CurDAG->SelectNodeTo(N, AMDGPU::COPY_TO_REGCLASS, EltVT,
|
||||
|
@ -340,7 +336,7 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
// 1 = Vector Register Class
|
||||
SmallVector<SDValue, 16 * 2 + 1> RegSeqArgs(NumVectorElts * 2 + 1);
|
||||
|
||||
RegSeqArgs[0] = CurDAG->getTargetConstant(RegClassID, MVT::i32);
|
||||
RegSeqArgs[0] = CurDAG->getTargetConstant(RegClassID, DL, MVT::i32);
|
||||
bool IsRegSeq = true;
|
||||
unsigned NOps = N->getNumOperands();
|
||||
for (unsigned i = 0; i < NOps; i++) {
|
||||
|
@ -351,7 +347,8 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
}
|
||||
RegSeqArgs[1 + (2 * i)] = N->getOperand(i);
|
||||
RegSeqArgs[1 + (2 * i) + 1] =
|
||||
CurDAG->getTargetConstant(TRI->getSubRegFromChannel(i), MVT::i32);
|
||||
CurDAG->getTargetConstant(TRI->getSubRegFromChannel(i), DL,
|
||||
MVT::i32);
|
||||
}
|
||||
|
||||
if (NOps != NumVectorElts) {
|
||||
|
@ -359,11 +356,11 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
assert(Opc == ISD::SCALAR_TO_VECTOR && NOps < NumVectorElts);
|
||||
|
||||
MachineSDNode *ImpDef = CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
|
||||
SDLoc(N), EltVT);
|
||||
DL, EltVT);
|
||||
for (unsigned i = NOps; i < NumVectorElts; ++i) {
|
||||
RegSeqArgs[1 + (2 * i)] = SDValue(ImpDef, 0);
|
||||
RegSeqArgs[1 + (2 * i) + 1] =
|
||||
CurDAG->getTargetConstant(TRI->getSubRegFromChannel(i), MVT::i32);
|
||||
CurDAG->getTargetConstant(TRI->getSubRegFromChannel(i), DL, MVT::i32);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -377,21 +374,22 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
if (Subtarget->getGeneration() <= AMDGPUSubtarget::NORTHERN_ISLANDS) {
|
||||
break;
|
||||
}
|
||||
SDLoc DL(N);
|
||||
if (N->getValueType(0) == MVT::i128) {
|
||||
RC = CurDAG->getTargetConstant(AMDGPU::SReg_128RegClassID, MVT::i32);
|
||||
SubReg0 = CurDAG->getTargetConstant(AMDGPU::sub0_sub1, MVT::i32);
|
||||
SubReg1 = CurDAG->getTargetConstant(AMDGPU::sub2_sub3, MVT::i32);
|
||||
RC = CurDAG->getTargetConstant(AMDGPU::SReg_128RegClassID, DL, MVT::i32);
|
||||
SubReg0 = CurDAG->getTargetConstant(AMDGPU::sub0_sub1, DL, MVT::i32);
|
||||
SubReg1 = CurDAG->getTargetConstant(AMDGPU::sub2_sub3, DL, MVT::i32);
|
||||
} else if (N->getValueType(0) == MVT::i64) {
|
||||
RC = CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, MVT::i32);
|
||||
SubReg0 = CurDAG->getTargetConstant(AMDGPU::sub0, MVT::i32);
|
||||
SubReg1 = CurDAG->getTargetConstant(AMDGPU::sub1, MVT::i32);
|
||||
RC = CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, DL, MVT::i32);
|
||||
SubReg0 = CurDAG->getTargetConstant(AMDGPU::sub0, DL, MVT::i32);
|
||||
SubReg1 = CurDAG->getTargetConstant(AMDGPU::sub1, DL, MVT::i32);
|
||||
} else {
|
||||
llvm_unreachable("Unhandled value type for BUILD_PAIR");
|
||||
}
|
||||
const SDValue Ops[] = { RC, N->getOperand(0), SubReg0,
|
||||
N->getOperand(1), SubReg1 };
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE,
|
||||
SDLoc(N), N->getValueType(0), Ops);
|
||||
DL, N->getValueType(0), Ops);
|
||||
}
|
||||
|
||||
case ISD::Constant:
|
||||
|
@ -408,17 +406,19 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
Imm = C->getZExtValue();
|
||||
}
|
||||
|
||||
SDNode *Lo = CurDAG->getMachineNode(AMDGPU::S_MOV_B32, SDLoc(N), MVT::i32,
|
||||
CurDAG->getConstant(Imm & 0xFFFFFFFF, MVT::i32));
|
||||
SDNode *Hi = CurDAG->getMachineNode(AMDGPU::S_MOV_B32, SDLoc(N), MVT::i32,
|
||||
CurDAG->getConstant(Imm >> 32, MVT::i32));
|
||||
SDLoc DL(N);
|
||||
SDNode *Lo = CurDAG->getMachineNode(AMDGPU::S_MOV_B32, DL, MVT::i32,
|
||||
CurDAG->getConstant(Imm & 0xFFFFFFFF, DL,
|
||||
MVT::i32));
|
||||
SDNode *Hi = CurDAG->getMachineNode(AMDGPU::S_MOV_B32, DL, MVT::i32,
|
||||
CurDAG->getConstant(Imm >> 32, DL, MVT::i32));
|
||||
const SDValue Ops[] = {
|
||||
CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, MVT::i32),
|
||||
SDValue(Lo, 0), CurDAG->getTargetConstant(AMDGPU::sub0, MVT::i32),
|
||||
SDValue(Hi, 0), CurDAG->getTargetConstant(AMDGPU::sub1, MVT::i32)
|
||||
CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, DL, MVT::i32),
|
||||
SDValue(Lo, 0), CurDAG->getTargetConstant(AMDGPU::sub0, DL, MVT::i32),
|
||||
SDValue(Hi, 0), CurDAG->getTargetConstant(AMDGPU::sub1, DL, MVT::i32)
|
||||
};
|
||||
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, SDLoc(N),
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE, DL,
|
||||
N->getValueType(0), Ops);
|
||||
}
|
||||
|
||||
|
@ -474,15 +474,17 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
break;
|
||||
SDValue Addr, Offset;
|
||||
|
||||
SDLoc DL(N);
|
||||
SelectADDRIndirect(N->getOperand(1), Addr, Offset);
|
||||
const SDValue Ops[] = {
|
||||
Addr,
|
||||
Offset,
|
||||
CurDAG->getTargetConstant(0, MVT::i32),
|
||||
CurDAG->getTargetConstant(0, DL, MVT::i32),
|
||||
N->getOperand(0),
|
||||
};
|
||||
return CurDAG->getMachineNode(AMDGPU::SI_RegisterLoad, SDLoc(N),
|
||||
CurDAG->getVTList(MVT::i32, MVT::i64, MVT::Other),
|
||||
return CurDAG->getMachineNode(AMDGPU::SI_RegisterLoad, DL,
|
||||
CurDAG->getVTList(MVT::i32, MVT::i64,
|
||||
MVT::Other),
|
||||
Ops);
|
||||
}
|
||||
case AMDGPUISD::REGISTER_STORE: {
|
||||
|
@ -490,14 +492,15 @@ SDNode *AMDGPUDAGToDAGISel::Select(SDNode *N) {
|
|||
break;
|
||||
SDValue Addr, Offset;
|
||||
SelectADDRIndirect(N->getOperand(2), Addr, Offset);
|
||||
SDLoc DL(N);
|
||||
const SDValue Ops[] = {
|
||||
N->getOperand(1),
|
||||
Addr,
|
||||
Offset,
|
||||
CurDAG->getTargetConstant(0, MVT::i32),
|
||||
CurDAG->getTargetConstant(0, DL, MVT::i32),
|
||||
N->getOperand(0),
|
||||
};
|
||||
return CurDAG->getMachineNode(AMDGPU::SI_RegisterStorePseudo, SDLoc(N),
|
||||
return CurDAG->getMachineNode(AMDGPU::SI_RegisterStorePseudo, DL,
|
||||
CurDAG->getVTList(MVT::Other),
|
||||
Ops);
|
||||
}
|
||||
|
@ -682,7 +685,8 @@ const char *AMDGPUDAGToDAGISel::getPassName() const {
|
|||
bool AMDGPUDAGToDAGISel::SelectGlobalValueConstantOffset(SDValue Addr,
|
||||
SDValue& IntPtr) {
|
||||
if (ConstantSDNode *Cst = dyn_cast<ConstantSDNode>(Addr)) {
|
||||
IntPtr = CurDAG->getIntPtrConstant(Cst->getZExtValue() / 4, true);
|
||||
IntPtr = CurDAG->getIntPtrConstant(Cst->getZExtValue() / 4, SDLoc(Addr),
|
||||
true);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
@ -692,7 +696,7 @@ bool AMDGPUDAGToDAGISel::SelectGlobalValueVariableOffset(SDValue Addr,
|
|||
SDValue& BaseReg, SDValue &Offset) {
|
||||
if (!isa<ConstantSDNode>(Addr)) {
|
||||
BaseReg = Addr;
|
||||
Offset = CurDAG->getIntPtrConstant(0, true);
|
||||
Offset = CurDAG->getIntPtrConstant(0, SDLoc(Addr), true);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
@ -707,7 +711,8 @@ bool AMDGPUDAGToDAGISel::SelectADDRVTX_READ(SDValue Addr, SDValue &Base,
|
|||
&& isInt<16>(IMMOffset->getZExtValue())) {
|
||||
|
||||
Base = Addr.getOperand(0);
|
||||
Offset = CurDAG->getTargetConstant(IMMOffset->getZExtValue(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(IMMOffset->getZExtValue(), SDLoc(Addr),
|
||||
MVT::i32);
|
||||
return true;
|
||||
// If the pointer address is constant, we can move it to the offset field.
|
||||
} else if ((IMMOffset = dyn_cast<ConstantSDNode>(Addr))
|
||||
|
@ -715,30 +720,32 @@ bool AMDGPUDAGToDAGISel::SelectADDRVTX_READ(SDValue Addr, SDValue &Base,
|
|||
Base = CurDAG->getCopyFromReg(CurDAG->getEntryNode(),
|
||||
SDLoc(CurDAG->getEntryNode()),
|
||||
AMDGPU::ZERO, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(IMMOffset->getZExtValue(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(IMMOffset->getZExtValue(), SDLoc(Addr),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
// Default case, no offset
|
||||
Base = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool AMDGPUDAGToDAGISel::SelectADDRIndirect(SDValue Addr, SDValue &Base,
|
||||
SDValue &Offset) {
|
||||
ConstantSDNode *C;
|
||||
SDLoc DL(Addr);
|
||||
|
||||
if ((C = dyn_cast<ConstantSDNode>(Addr))) {
|
||||
Base = CurDAG->getRegister(AMDGPU::INDIRECT_BASE_ADDR, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(C->getZExtValue(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(C->getZExtValue(), DL, MVT::i32);
|
||||
} else if ((Addr.getOpcode() == ISD::ADD || Addr.getOpcode() == ISD::OR) &&
|
||||
(C = dyn_cast<ConstantSDNode>(Addr.getOperand(1)))) {
|
||||
Base = Addr.getOperand(0);
|
||||
Offset = CurDAG->getTargetConstant(C->getZExtValue(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(C->getZExtValue(), DL, MVT::i32);
|
||||
} else {
|
||||
Base = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
}
|
||||
|
||||
return true;
|
||||
|
@ -751,8 +758,8 @@ SDNode *AMDGPUDAGToDAGISel::SelectADD_SUB_I64(SDNode *N) {
|
|||
|
||||
bool IsAdd = (N->getOpcode() == ISD::ADD);
|
||||
|
||||
SDValue Sub0 = CurDAG->getTargetConstant(AMDGPU::sub0, MVT::i32);
|
||||
SDValue Sub1 = CurDAG->getTargetConstant(AMDGPU::sub1, MVT::i32);
|
||||
SDValue Sub0 = CurDAG->getTargetConstant(AMDGPU::sub0, DL, MVT::i32);
|
||||
SDValue Sub1 = CurDAG->getTargetConstant(AMDGPU::sub1, DL, MVT::i32);
|
||||
|
||||
SDNode *Lo0 = CurDAG->getMachineNode(TargetOpcode::EXTRACT_SUBREG,
|
||||
DL, MVT::i32, LHS, Sub0);
|
||||
|
@ -778,7 +785,7 @@ SDNode *AMDGPUDAGToDAGISel::SelectADD_SUB_I64(SDNode *N) {
|
|||
SDValue(Hi0, 0), SDValue(Hi1, 0), Carry);
|
||||
|
||||
SDValue Args[5] = {
|
||||
CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, MVT::i32),
|
||||
CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, DL, MVT::i32),
|
||||
SDValue(AddLo,0),
|
||||
Sub0,
|
||||
SDValue(AddHi,0),
|
||||
|
@ -835,15 +842,17 @@ bool AMDGPUDAGToDAGISel::SelectDS1Addr1Offset(SDValue Addr, SDValue &Base,
|
|||
}
|
||||
}
|
||||
|
||||
SDLoc DL(Addr);
|
||||
|
||||
// If we have a constant address, prefer to put the constant into the
|
||||
// offset. This can save moves to load the constant address since multiple
|
||||
// operations can share the zero base address register, and enables merging
|
||||
// into read2 / write2 instructions.
|
||||
if (const ConstantSDNode *CAddr = dyn_cast<ConstantSDNode>(Addr)) {
|
||||
if (isUInt<16>(CAddr->getZExtValue())) {
|
||||
SDValue Zero = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue Zero = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
MachineSDNode *MovZero = CurDAG->getMachineNode(AMDGPU::V_MOV_B32_e32,
|
||||
SDLoc(Addr), MVT::i32, Zero);
|
||||
DL, MVT::i32, Zero);
|
||||
Base = SDValue(MovZero, 0);
|
||||
Offset = Addr;
|
||||
return true;
|
||||
|
@ -852,13 +861,15 @@ bool AMDGPUDAGToDAGISel::SelectDS1Addr1Offset(SDValue Addr, SDValue &Base,
|
|||
|
||||
// default case
|
||||
Base = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i16);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, MVT::i16);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool AMDGPUDAGToDAGISel::SelectDS64Bit4ByteAligned(SDValue Addr, SDValue &Base,
|
||||
SDValue &Offset0,
|
||||
SDValue &Offset1) const {
|
||||
SDLoc DL(Addr);
|
||||
|
||||
if (CurDAG->isBaseWithConstantOffset(Addr)) {
|
||||
SDValue N0 = Addr.getOperand(0);
|
||||
SDValue N1 = Addr.getOperand(1);
|
||||
|
@ -868,8 +879,8 @@ bool AMDGPUDAGToDAGISel::SelectDS64Bit4ByteAligned(SDValue Addr, SDValue &Base,
|
|||
// (add n0, c0)
|
||||
if (isDSOffsetLegal(N0, DWordOffset1, 8)) {
|
||||
Base = N0;
|
||||
Offset0 = CurDAG->getTargetConstant(DWordOffset0, MVT::i8);
|
||||
Offset1 = CurDAG->getTargetConstant(DWordOffset1, MVT::i8);
|
||||
Offset0 = CurDAG->getTargetConstant(DWordOffset0, DL, MVT::i8);
|
||||
Offset1 = CurDAG->getTargetConstant(DWordOffset1, DL, MVT::i8);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -880,21 +891,21 @@ bool AMDGPUDAGToDAGISel::SelectDS64Bit4ByteAligned(SDValue Addr, SDValue &Base,
|
|||
assert(4 * DWordOffset0 == CAddr->getZExtValue());
|
||||
|
||||
if (isUInt<8>(DWordOffset0) && isUInt<8>(DWordOffset1)) {
|
||||
SDValue Zero = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue Zero = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
MachineSDNode *MovZero
|
||||
= CurDAG->getMachineNode(AMDGPU::V_MOV_B32_e32,
|
||||
SDLoc(Addr), MVT::i32, Zero);
|
||||
DL, MVT::i32, Zero);
|
||||
Base = SDValue(MovZero, 0);
|
||||
Offset0 = CurDAG->getTargetConstant(DWordOffset0, MVT::i8);
|
||||
Offset1 = CurDAG->getTargetConstant(DWordOffset1, MVT::i8);
|
||||
Offset0 = CurDAG->getTargetConstant(DWordOffset0, DL, MVT::i8);
|
||||
Offset1 = CurDAG->getTargetConstant(DWordOffset1, DL, MVT::i8);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// default case
|
||||
Base = Addr;
|
||||
Offset0 = CurDAG->getTargetConstant(0, MVT::i8);
|
||||
Offset1 = CurDAG->getTargetConstant(1, MVT::i8);
|
||||
Offset0 = CurDAG->getTargetConstant(0, DL, MVT::i8);
|
||||
Offset1 = CurDAG->getTargetConstant(1, DL, MVT::i8);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -910,14 +921,14 @@ void AMDGPUDAGToDAGISel::SelectMUBUF(SDValue Addr, SDValue &Ptr,
|
|||
SDValue &TFE) const {
|
||||
SDLoc DL(Addr);
|
||||
|
||||
GLC = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
SLC = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
TFE = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
GLC = CurDAG->getTargetConstant(0, DL, MVT::i1);
|
||||
SLC = CurDAG->getTargetConstant(0, DL, MVT::i1);
|
||||
TFE = CurDAG->getTargetConstant(0, DL, MVT::i1);
|
||||
|
||||
Idxen = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
Offen = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
Addr64 = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
SOffset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Idxen = CurDAG->getTargetConstant(0, DL, MVT::i1);
|
||||
Offen = CurDAG->getTargetConstant(0, DL, MVT::i1);
|
||||
Addr64 = CurDAG->getTargetConstant(0, DL, MVT::i1);
|
||||
SOffset = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
|
||||
if (CurDAG->isBaseWithConstantOffset(Addr)) {
|
||||
SDValue N0 = Addr.getOperand(0);
|
||||
|
@ -928,24 +939,25 @@ void AMDGPUDAGToDAGISel::SelectMUBUF(SDValue Addr, SDValue &Ptr,
|
|||
// (add (add N2, N3), C1) -> addr64
|
||||
SDValue N2 = N0.getOperand(0);
|
||||
SDValue N3 = N0.getOperand(1);
|
||||
Addr64 = CurDAG->getTargetConstant(1, MVT::i1);
|
||||
Addr64 = CurDAG->getTargetConstant(1, DL, MVT::i1);
|
||||
Ptr = N2;
|
||||
VAddr = N3;
|
||||
} else {
|
||||
|
||||
// (add N0, C1) -> offset
|
||||
VAddr = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
VAddr = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
Ptr = N0;
|
||||
}
|
||||
|
||||
if (isLegalMUBUFImmOffset(C1)) {
|
||||
Offset = CurDAG->getTargetConstant(C1->getZExtValue(), MVT::i16);
|
||||
Offset = CurDAG->getTargetConstant(C1->getZExtValue(), DL, MVT::i16);
|
||||
return;
|
||||
} else if (isUInt<32>(C1->getZExtValue())) {
|
||||
// Illegal offset, store it in soffset.
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i16);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, MVT::i16);
|
||||
SOffset = SDValue(CurDAG->getMachineNode(AMDGPU::S_MOV_B32, DL, MVT::i32,
|
||||
CurDAG->getTargetConstant(C1->getZExtValue(), MVT::i32)), 0);
|
||||
CurDAG->getTargetConstant(C1->getZExtValue(), DL, MVT::i32)),
|
||||
0);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -954,17 +966,17 @@ void AMDGPUDAGToDAGISel::SelectMUBUF(SDValue Addr, SDValue &Ptr,
|
|||
// (add N0, N1) -> addr64
|
||||
SDValue N0 = Addr.getOperand(0);
|
||||
SDValue N1 = Addr.getOperand(1);
|
||||
Addr64 = CurDAG->getTargetConstant(1, MVT::i1);
|
||||
Addr64 = CurDAG->getTargetConstant(1, DL, MVT::i1);
|
||||
Ptr = N0;
|
||||
VAddr = N1;
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i16);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, MVT::i16);
|
||||
return;
|
||||
}
|
||||
|
||||
// default case -> offset
|
||||
VAddr = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
VAddr = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
Ptr = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i16);
|
||||
Offset = CurDAG->getTargetConstant(0, DL, MVT::i16);
|
||||
|
||||
}
|
||||
|
||||
|
@ -995,7 +1007,7 @@ bool AMDGPUDAGToDAGISel::SelectMUBUFAddr64(SDValue Addr, SDValue &SRsrc,
|
|||
SDValue &VAddr, SDValue &SOffset,
|
||||
SDValue &Offset,
|
||||
SDValue &SLC) const {
|
||||
SLC = CurDAG->getTargetConstant(0, MVT::i1);
|
||||
SLC = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i1);
|
||||
SDValue GLC, TFE;
|
||||
|
||||
return SelectMUBUFAddr64(Addr, SRsrc, VAddr, SOffset, Offset, GLC, SLC, TFE);
|
||||
|
@ -1026,11 +1038,11 @@ bool AMDGPUDAGToDAGISel::SelectMUBUFScratch(SDValue Addr, SDValue &Rsrc,
|
|||
SDValue(CurDAG->getMachineNode(AMDGPU::S_MOV_B32, DL, MVT::i32, Sym1), 0);
|
||||
|
||||
const SDValue RsrcOps[] = {
|
||||
CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, MVT::i32),
|
||||
CurDAG->getTargetConstant(AMDGPU::SReg_64RegClassID, DL, MVT::i32),
|
||||
ScratchRsrcDword0,
|
||||
CurDAG->getTargetConstant(AMDGPU::sub0, MVT::i32),
|
||||
CurDAG->getTargetConstant(AMDGPU::sub0, DL, MVT::i32),
|
||||
ScratchRsrcDword1,
|
||||
CurDAG->getTargetConstant(AMDGPU::sub1, MVT::i32),
|
||||
CurDAG->getTargetConstant(AMDGPU::sub1, DL, MVT::i32),
|
||||
};
|
||||
SDValue ScratchPtr = SDValue(CurDAG->getMachineNode(AMDGPU::REG_SEQUENCE, DL,
|
||||
MVT::v2i32, RsrcOps), 0);
|
||||
|
@ -1045,14 +1057,14 @@ bool AMDGPUDAGToDAGISel::SelectMUBUFScratch(SDValue Addr, SDValue &Rsrc,
|
|||
|
||||
if (isLegalMUBUFImmOffset(C1)) {
|
||||
VAddr = Addr.getOperand(0);
|
||||
ImmOffset = CurDAG->getTargetConstant(C1->getZExtValue(), MVT::i16);
|
||||
ImmOffset = CurDAG->getTargetConstant(C1->getZExtValue(), DL, MVT::i16);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// (node)
|
||||
VAddr = Addr;
|
||||
ImmOffset = CurDAG->getTargetConstant(0, MVT::i16);
|
||||
ImmOffset = CurDAG->getTargetConstant(0, DL, MVT::i16);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1125,7 +1137,7 @@ SDNode *AMDGPUDAGToDAGISel::SelectAddrSpaceCast(SDNode *N) {
|
|||
DL,
|
||||
DestVT,
|
||||
Src,
|
||||
CurDAG->getTargetConstant(AMDGPU::sub0, MVT::i32));
|
||||
CurDAG->getTargetConstant(AMDGPU::sub0, DL, MVT::i32));
|
||||
}
|
||||
|
||||
|
||||
|
@ -1134,19 +1146,20 @@ SDNode *AMDGPUDAGToDAGISel::SelectAddrSpaceCast(SDNode *N) {
|
|||
|
||||
// FIXME: This is probably wrong, we should never be defining
|
||||
// a register class with both VGPRs and SGPRs
|
||||
SDValue RC = CurDAG->getTargetConstant(AMDGPU::VS_64RegClassID, MVT::i32);
|
||||
SDValue RC = CurDAG->getTargetConstant(AMDGPU::VS_64RegClassID, DL,
|
||||
MVT::i32);
|
||||
|
||||
const SDValue Ops[] = {
|
||||
RC,
|
||||
Src,
|
||||
CurDAG->getTargetConstant(AMDGPU::sub0, MVT::i32),
|
||||
SDValue(CurDAG->getMachineNode(AMDGPU::S_MOV_B32, SDLoc(N), MVT::i32,
|
||||
CurDAG->getConstant(0, MVT::i32)), 0),
|
||||
CurDAG->getTargetConstant(AMDGPU::sub1, MVT::i32)
|
||||
CurDAG->getTargetConstant(AMDGPU::sub0, DL, MVT::i32),
|
||||
SDValue(CurDAG->getMachineNode(AMDGPU::S_MOV_B32, DL, MVT::i32,
|
||||
CurDAG->getConstant(0, DL, MVT::i32)), 0),
|
||||
CurDAG->getTargetConstant(AMDGPU::sub1, DL, MVT::i32)
|
||||
};
|
||||
|
||||
return CurDAG->getMachineNode(TargetOpcode::REG_SEQUENCE,
|
||||
SDLoc(N), N->getValueType(0), Ops);
|
||||
DL, N->getValueType(0), Ops);
|
||||
}
|
||||
|
||||
assert(SrcSize == 64 && DestSize == 64);
|
||||
|
@ -1159,7 +1172,7 @@ SDNode *AMDGPUDAGToDAGISel::getS_BFE(unsigned Opcode, SDLoc DL, SDValue Val,
|
|||
// the format expected by the S_BFE_I32 / S_BFE_U32. In the second
|
||||
// source, bits [5:0] contain the offset and bits [22:16] the width.
|
||||
uint32_t PackedVal = Offset | (Width << 16);
|
||||
SDValue PackedConst = CurDAG->getTargetConstant(PackedVal, MVT::i32);
|
||||
SDValue PackedConst = CurDAG->getTargetConstant(PackedVal, DL, MVT::i32);
|
||||
|
||||
return CurDAG->getMachineNode(Opcode, DL, MVT::i32, Val, PackedConst);
|
||||
}
|
||||
|
@ -1259,7 +1272,7 @@ bool AMDGPUDAGToDAGISel::SelectVOP3Mods(SDValue In, SDValue &Src,
|
|||
Src = Src.getOperand(0);
|
||||
}
|
||||
|
||||
SrcMods = CurDAG->getTargetConstant(Mods, MVT::i32);
|
||||
SrcMods = CurDAG->getTargetConstant(Mods, SDLoc(In), MVT::i32);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -1267,9 +1280,10 @@ bool AMDGPUDAGToDAGISel::SelectVOP3Mods(SDValue In, SDValue &Src,
|
|||
bool AMDGPUDAGToDAGISel::SelectVOP3Mods0(SDValue In, SDValue &Src,
|
||||
SDValue &SrcMods, SDValue &Clamp,
|
||||
SDValue &Omod) const {
|
||||
SDLoc DL(In);
|
||||
// FIXME: Handle Clamp and Omod
|
||||
Clamp = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Omod = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Clamp = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
Omod = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
|
||||
return SelectVOP3Mods(In, Src, SrcMods);
|
||||
}
|
||||
|
@ -1278,7 +1292,7 @@ bool AMDGPUDAGToDAGISel::SelectVOP3Mods0Clamp(SDValue In, SDValue &Src,
|
|||
SDValue &SrcMods,
|
||||
SDValue &Omod) const {
|
||||
// FIXME: Handle Omod
|
||||
Omod = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Omod = CurDAG->getTargetConstant(0, SDLoc(In), MVT::i32);
|
||||
|
||||
return SelectVOP3Mods(In, Src, SrcMods);
|
||||
}
|
||||
|
@ -1287,7 +1301,7 @@ bool AMDGPUDAGToDAGISel::SelectVOP3Mods0Clamp0OMod(SDValue In, SDValue &Src,
|
|||
SDValue &SrcMods,
|
||||
SDValue &Clamp,
|
||||
SDValue &Omod) const {
|
||||
Clamp = Omod = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Clamp = Omod = CurDAG->getTargetConstant(0, SDLoc(In), MVT::i32);
|
||||
return SelectVOP3Mods(In, Src, SrcMods);
|
||||
}
|
||||
|
||||
|
|
|
@ -680,7 +680,7 @@ SDValue AMDGPUTargetLowering::LowerConstantInitializer(const Constant* Init,
|
|||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(Init)) {
|
||||
EVT VT = EVT::getEVT(InitTy);
|
||||
PointerType *PtrTy = PointerType::get(InitTy, AMDGPUAS::PRIVATE_ADDRESS);
|
||||
return DAG.getStore(Chain, DL, DAG.getConstant(*CI, VT), InitPtr,
|
||||
return DAG.getStore(Chain, DL, DAG.getConstant(*CI, DL, VT), InitPtr,
|
||||
MachinePointerInfo(UndefValue::get(PtrTy)), false, false,
|
||||
TD->getPrefTypeAlignment(InitTy));
|
||||
}
|
||||
|
@ -688,7 +688,7 @@ SDValue AMDGPUTargetLowering::LowerConstantInitializer(const Constant* Init,
|
|||
if (const ConstantFP *CFP = dyn_cast<ConstantFP>(Init)) {
|
||||
EVT VT = EVT::getEVT(CFP->getType());
|
||||
PointerType *PtrTy = PointerType::get(CFP->getType(), 0);
|
||||
return DAG.getStore(Chain, DL, DAG.getConstantFP(*CFP, VT), InitPtr,
|
||||
return DAG.getStore(Chain, DL, DAG.getConstantFP(*CFP, DL, VT), InitPtr,
|
||||
MachinePointerInfo(UndefValue::get(PtrTy)), false, false,
|
||||
TD->getPrefTypeAlignment(CFP->getType()));
|
||||
}
|
||||
|
@ -700,7 +700,7 @@ SDValue AMDGPUTargetLowering::LowerConstantInitializer(const Constant* Init,
|
|||
SmallVector<SDValue, 8> Chains;
|
||||
|
||||
for (unsigned I = 0, N = ST->getNumElements(); I != N; ++I) {
|
||||
SDValue Offset = DAG.getConstant(SL->getElementOffset(I), PtrVT);
|
||||
SDValue Offset = DAG.getConstant(SL->getElementOffset(I), DL, PtrVT);
|
||||
SDValue Ptr = DAG.getNode(ISD::ADD, DL, PtrVT, InitPtr, Offset);
|
||||
|
||||
Constant *Elt = Init->getAggregateElement(I);
|
||||
|
@ -724,7 +724,7 @@ SDValue AMDGPUTargetLowering::LowerConstantInitializer(const Constant* Init,
|
|||
unsigned EltSize = TD->getTypeAllocSize(SeqTy->getElementType());
|
||||
SmallVector<SDValue, 8> Chains;
|
||||
for (unsigned i = 0; i < NumElements; ++i) {
|
||||
SDValue Offset = DAG.getConstant(i * EltSize, PtrVT);
|
||||
SDValue Offset = DAG.getConstant(i * EltSize, DL, PtrVT);
|
||||
SDValue Ptr = DAG.getNode(ISD::ADD, DL, PtrVT, InitPtr, Offset);
|
||||
|
||||
Constant *Elt = Init->getAggregateElement(i);
|
||||
|
@ -786,7 +786,8 @@ SDValue AMDGPUTargetLowering::LowerGlobalAddress(AMDGPUMachineFunction* MFI,
|
|||
Offset = MFI->LocalMemoryObjects[GV];
|
||||
}
|
||||
|
||||
return DAG.getConstant(Offset, getPointerTy(AMDGPUAS::LOCAL_ADDRESS));
|
||||
return DAG.getConstant(Offset, SDLoc(Op),
|
||||
getPointerTy(AMDGPUAS::LOCAL_ADDRESS));
|
||||
}
|
||||
case AMDGPUAS::CONSTANT_ADDRESS: {
|
||||
MachineFrameInfo *FrameInfo = DAG.getMachineFunction().getFrameInfo();
|
||||
|
@ -868,7 +869,7 @@ SDValue AMDGPUTargetLowering::LowerFrameIndex(SDValue Op,
|
|||
|
||||
unsigned FrameIndex = FIN->getIndex();
|
||||
unsigned Offset = TFL->getFrameIndexOffset(MF, FrameIndex);
|
||||
return DAG.getConstant(Offset * 4 * TFL->getStackWidth(MF),
|
||||
return DAG.getConstant(Offset * 4 * TFL->getStackWidth(MF), SDLoc(Op),
|
||||
Op.getValueType());
|
||||
}
|
||||
|
||||
|
@ -943,9 +944,9 @@ SDValue AMDGPUTargetLowering::LowerINTRINSIC_WO_CHAIN(SDValue Op,
|
|||
|
||||
SDValue Rsq = DAG.getNode(AMDGPUISD::RSQ, DL, VT, Op.getOperand(1));
|
||||
SDValue Tmp = DAG.getNode(ISD::FMINNUM, DL, VT, Rsq,
|
||||
DAG.getConstantFP(Max, VT));
|
||||
DAG.getConstantFP(Max, DL, VT));
|
||||
return DAG.getNode(ISD::FMAXNUM, DL, VT, Tmp,
|
||||
DAG.getConstantFP(Min, VT));
|
||||
DAG.getConstantFP(Min, DL, VT));
|
||||
} else {
|
||||
return DAG.getNode(AMDGPUISD::RSQ_CLAMPED, DL, VT, Op.getOperand(1));
|
||||
}
|
||||
|
@ -1040,8 +1041,8 @@ SDValue AMDGPUTargetLowering::LowerIntrinsicIABS(SDValue Op,
|
|||
SelectionDAG &DAG) const {
|
||||
SDLoc DL(Op);
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue Neg = DAG.getNode(ISD::SUB, DL, VT, DAG.getConstant(0, VT),
|
||||
Op.getOperand(1));
|
||||
SDValue Neg = DAG.getNode(ISD::SUB, DL, VT, DAG.getConstant(0, DL, VT),
|
||||
Op.getOperand(1));
|
||||
|
||||
return DAG.getNode(AMDGPUISD::SMAX, DL, VT, Neg, Op.getOperand(1));
|
||||
}
|
||||
|
@ -1053,7 +1054,7 @@ SDValue AMDGPUTargetLowering::LowerIntrinsicLRP(SDValue Op,
|
|||
SDLoc DL(Op);
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue OneSubA = DAG.getNode(ISD::FSUB, DL, VT,
|
||||
DAG.getConstantFP(1.0f, MVT::f32),
|
||||
DAG.getConstantFP(1.0f, DL, MVT::f32),
|
||||
Op.getOperand(1));
|
||||
SDValue OneSubAC = DAG.getNode(ISD::FMUL, DL, VT, OneSubA,
|
||||
Op.getOperand(3));
|
||||
|
@ -1201,7 +1202,7 @@ SDValue AMDGPUTargetLowering::ScalarizeVectorLoad(const SDValue Op,
|
|||
|
||||
for (unsigned i = 0; i < NumElts; ++i) {
|
||||
SDValue Ptr = DAG.getNode(ISD::ADD, SL, PtrVT, Load->getBasePtr(),
|
||||
DAG.getConstant(i * MemEltSize, PtrVT));
|
||||
DAG.getConstant(i * MemEltSize, SL, PtrVT));
|
||||
|
||||
SDValue NewLoad
|
||||
= DAG.getExtLoad(Load->getExtensionType(), SL, EltVT,
|
||||
|
@ -1252,7 +1253,8 @@ SDValue AMDGPUTargetLowering::SplitVectorLoad(const SDValue Op,
|
|||
Load->isInvariant(), Load->getAlignment());
|
||||
|
||||
SDValue HiPtr = DAG.getNode(ISD::ADD, SL, PtrVT, BasePtr,
|
||||
DAG.getConstant(LoMemVT.getStoreSize(), PtrVT));
|
||||
DAG.getConstant(LoMemVT.getStoreSize(), SL,
|
||||
PtrVT));
|
||||
|
||||
SDValue HiLoad
|
||||
= DAG.getExtLoad(Load->getExtensionType(), SL, HiVT,
|
||||
|
@ -1292,18 +1294,18 @@ SDValue AMDGPUTargetLowering::MergeVectorStore(const SDValue &Op,
|
|||
unsigned MemEltBits = MemEltVT.getSizeInBits();
|
||||
unsigned MemNumElements = MemVT.getVectorNumElements();
|
||||
unsigned PackedSize = MemVT.getStoreSizeInBits();
|
||||
SDValue Mask = DAG.getConstant((1 << MemEltBits) - 1, MVT::i32);
|
||||
SDValue Mask = DAG.getConstant((1 << MemEltBits) - 1, DL, MVT::i32);
|
||||
|
||||
assert(Value.getValueType().getScalarSizeInBits() >= 32);
|
||||
|
||||
SDValue PackedValue;
|
||||
for (unsigned i = 0; i < MemNumElements; ++i) {
|
||||
SDValue Elt = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, ElemVT, Value,
|
||||
DAG.getConstant(i, MVT::i32));
|
||||
DAG.getConstant(i, DL, MVT::i32));
|
||||
Elt = DAG.getZExtOrTrunc(Elt, DL, MVT::i32);
|
||||
Elt = DAG.getNode(ISD::AND, DL, MVT::i32, Elt, Mask); // getZeroExtendInReg
|
||||
|
||||
SDValue Shift = DAG.getConstant(MemEltBits * i, MVT::i32);
|
||||
SDValue Shift = DAG.getConstant(MemEltBits * i, DL, MVT::i32);
|
||||
Elt = DAG.getNode(ISD::SHL, DL, MVT::i32, Elt, Shift);
|
||||
|
||||
if (i == 0) {
|
||||
|
@ -1345,9 +1347,9 @@ SDValue AMDGPUTargetLowering::ScalarizeVectorStore(SDValue Op,
|
|||
for (unsigned i = 0, e = NumElts; i != e; ++i) {
|
||||
SDValue Val = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, SL, EltVT,
|
||||
Store->getValue(),
|
||||
DAG.getConstant(i, MVT::i32));
|
||||
DAG.getConstant(i, SL, MVT::i32));
|
||||
|
||||
SDValue Offset = DAG.getConstant(i * MemEltVT.getStoreSize(), PtrVT);
|
||||
SDValue Offset = DAG.getConstant(i * MemEltVT.getStoreSize(), SL, PtrVT);
|
||||
SDValue Ptr = DAG.getNode(ISD::ADD, SL, PtrVT, Store->getBasePtr(), Offset);
|
||||
SDValue NewStore =
|
||||
DAG.getTruncStore(Store->getChain(), SL, Val, Ptr,
|
||||
|
@ -1386,7 +1388,8 @@ SDValue AMDGPUTargetLowering::SplitVectorStore(SDValue Op,
|
|||
|
||||
EVT PtrVT = BasePtr.getValueType();
|
||||
SDValue HiPtr = DAG.getNode(ISD::ADD, SL, PtrVT, BasePtr,
|
||||
DAG.getConstant(LoMemVT.getStoreSize(), PtrVT));
|
||||
DAG.getConstant(LoMemVT.getStoreSize(), SL,
|
||||
PtrVT));
|
||||
|
||||
MachinePointerInfo SrcValue(Store->getMemOperand()->getValue());
|
||||
SDValue LoStore
|
||||
|
@ -1444,16 +1447,16 @@ SDValue AMDGPUTargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
|
||||
SDValue Ptr = DAG.getNode(ISD::SRL, DL, MVT::i32, Load->getBasePtr(),
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, DL, MVT::i32));
|
||||
SDValue Ret = DAG.getNode(AMDGPUISD::REGISTER_LOAD, DL, Op.getValueType(),
|
||||
Load->getChain(), Ptr,
|
||||
DAG.getTargetConstant(0, MVT::i32),
|
||||
DAG.getTargetConstant(0, DL, MVT::i32),
|
||||
Op.getOperand(2));
|
||||
SDValue ByteIdx = DAG.getNode(ISD::AND, DL, MVT::i32,
|
||||
Load->getBasePtr(),
|
||||
DAG.getConstant(0x3, MVT::i32));
|
||||
DAG.getConstant(0x3, DL, MVT::i32));
|
||||
SDValue ShiftAmt = DAG.getNode(ISD::SHL, DL, MVT::i32, ByteIdx,
|
||||
DAG.getConstant(3, MVT::i32));
|
||||
DAG.getConstant(3, DL, MVT::i32));
|
||||
|
||||
Ret = DAG.getNode(ISD::SRL, DL, MVT::i32, Ret, ShiftAmt);
|
||||
|
||||
|
@ -1503,15 +1506,16 @@ SDValue AMDGPUTargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
}
|
||||
SDValue BasePtr = Store->getBasePtr();
|
||||
SDValue Ptr = DAG.getNode(ISD::SRL, DL, MVT::i32, BasePtr,
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, DL, MVT::i32));
|
||||
SDValue Dst = DAG.getNode(AMDGPUISD::REGISTER_LOAD, DL, MVT::i32,
|
||||
Chain, Ptr, DAG.getTargetConstant(0, MVT::i32));
|
||||
Chain, Ptr,
|
||||
DAG.getTargetConstant(0, DL, MVT::i32));
|
||||
|
||||
SDValue ByteIdx = DAG.getNode(ISD::AND, DL, MVT::i32, BasePtr,
|
||||
DAG.getConstant(0x3, MVT::i32));
|
||||
DAG.getConstant(0x3, DL, MVT::i32));
|
||||
|
||||
SDValue ShiftAmt = DAG.getNode(ISD::SHL, DL, MVT::i32, ByteIdx,
|
||||
DAG.getConstant(3, MVT::i32));
|
||||
DAG.getConstant(3, DL, MVT::i32));
|
||||
|
||||
SDValue SExtValue = DAG.getNode(ISD::SIGN_EXTEND, DL, MVT::i32,
|
||||
Store->getValue());
|
||||
|
@ -1521,15 +1525,17 @@ SDValue AMDGPUTargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue ShiftedValue = DAG.getNode(ISD::SHL, DL, MVT::i32,
|
||||
MaskedValue, ShiftAmt);
|
||||
|
||||
SDValue DstMask = DAG.getNode(ISD::SHL, DL, MVT::i32, DAG.getConstant(Mask, MVT::i32),
|
||||
SDValue DstMask = DAG.getNode(ISD::SHL, DL, MVT::i32,
|
||||
DAG.getConstant(Mask, DL, MVT::i32),
|
||||
ShiftAmt);
|
||||
DstMask = DAG.getNode(ISD::XOR, DL, MVT::i32, DstMask,
|
||||
DAG.getConstant(0xffffffff, MVT::i32));
|
||||
DAG.getConstant(0xffffffff, DL, MVT::i32));
|
||||
Dst = DAG.getNode(ISD::AND, DL, MVT::i32, Dst, DstMask);
|
||||
|
||||
SDValue Value = DAG.getNode(ISD::OR, DL, MVT::i32, Dst, ShiftedValue);
|
||||
return DAG.getNode(AMDGPUISD::REGISTER_STORE, DL, MVT::Other,
|
||||
Chain, Value, Ptr, DAG.getTargetConstant(0, MVT::i32));
|
||||
Chain, Value, Ptr,
|
||||
DAG.getTargetConstant(0, DL, MVT::i32));
|
||||
}
|
||||
return SDValue();
|
||||
}
|
||||
|
@ -1556,17 +1562,18 @@ SDValue AMDGPUTargetLowering::LowerDIVREM24(SDValue Op, SelectionDAG &DAG, bool
|
|||
|
||||
unsigned BitSize = VT.getScalarType().getSizeInBits();
|
||||
|
||||
SDValue jq = DAG.getConstant(1, IntVT);
|
||||
SDValue jq = DAG.getConstant(1, DL, IntVT);
|
||||
|
||||
if (sign) {
|
||||
// char|short jq = ia ^ ib;
|
||||
jq = DAG.getNode(ISD::XOR, DL, VT, LHS, RHS);
|
||||
|
||||
// jq = jq >> (bitsize - 2)
|
||||
jq = DAG.getNode(ISD::SRA, DL, VT, jq, DAG.getConstant(BitSize - 2, VT));
|
||||
jq = DAG.getNode(ISD::SRA, DL, VT, jq,
|
||||
DAG.getConstant(BitSize - 2, DL, VT));
|
||||
|
||||
// jq = jq | 0x1
|
||||
jq = DAG.getNode(ISD::OR, DL, VT, jq, DAG.getConstant(1, VT));
|
||||
jq = DAG.getNode(ISD::OR, DL, VT, jq, DAG.getConstant(1, DL, VT));
|
||||
|
||||
// jq = (int)jq
|
||||
jq = DAG.getSExtOrTrunc(jq, DL, IntVT);
|
||||
|
@ -1615,7 +1622,7 @@ SDValue AMDGPUTargetLowering::LowerDIVREM24(SDValue Op, SelectionDAG &DAG, bool
|
|||
SDValue cv = DAG.getSetCC(DL, SetCCVT, fr, fb, ISD::SETOGE);
|
||||
|
||||
// jq = (cv ? jq : 0);
|
||||
jq = DAG.getNode(ISD::SELECT, DL, VT, cv, jq, DAG.getConstant(0, VT));
|
||||
jq = DAG.getNode(ISD::SELECT, DL, VT, cv, jq, DAG.getConstant(0, DL, VT));
|
||||
|
||||
// dst = trunc/extend to legal type
|
||||
iq = sign ? DAG.getSExtOrTrunc(iq, DL, VT) : DAG.getZExtOrTrunc(iq, DL, VT);
|
||||
|
@ -1643,8 +1650,8 @@ void AMDGPUTargetLowering::LowerUDIVREM64(SDValue Op,
|
|||
EVT VT = Op.getValueType();
|
||||
EVT HalfVT = VT.getHalfSizedIntegerVT(*DAG.getContext());
|
||||
|
||||
SDValue one = DAG.getConstant(1, HalfVT);
|
||||
SDValue zero = DAG.getConstant(0, HalfVT);
|
||||
SDValue one = DAG.getConstant(1, DL, HalfVT);
|
||||
SDValue zero = DAG.getConstant(0, DL, HalfVT);
|
||||
|
||||
//HiLo split
|
||||
SDValue LHS = Op.getOperand(0);
|
||||
|
@ -1683,18 +1690,18 @@ void AMDGPUTargetLowering::LowerUDIVREM64(SDValue Op,
|
|||
|
||||
for (unsigned i = 0; i < halfBitWidth; ++i) {
|
||||
const unsigned bitPos = halfBitWidth - i - 1;
|
||||
SDValue POS = DAG.getConstant(bitPos, HalfVT);
|
||||
SDValue POS = DAG.getConstant(bitPos, DL, HalfVT);
|
||||
// Get value of high bit
|
||||
SDValue HBit = DAG.getNode(ISD::SRL, DL, HalfVT, LHS_Lo, POS);
|
||||
HBit = DAG.getNode(ISD::AND, DL, HalfVT, HBit, one);
|
||||
HBit = DAG.getNode(ISD::ZERO_EXTEND, DL, VT, HBit);
|
||||
|
||||
// Shift
|
||||
REM = DAG.getNode(ISD::SHL, DL, VT, REM, DAG.getConstant(1, VT));
|
||||
REM = DAG.getNode(ISD::SHL, DL, VT, REM, DAG.getConstant(1, DL, VT));
|
||||
// Add LHS high bit
|
||||
REM = DAG.getNode(ISD::OR, DL, VT, REM, HBit);
|
||||
|
||||
SDValue BIT = DAG.getConstant(1 << bitPos, HalfVT);
|
||||
SDValue BIT = DAG.getConstant(1 << bitPos, DL, HalfVT);
|
||||
SDValue realBIT = DAG.getSelectCC(DL, REM, RHS, BIT, zero, ISD::SETUGE);
|
||||
|
||||
DIV_Lo = DAG.getNode(ISD::OR, DL, HalfVT, DIV_Lo, realBIT);
|
||||
|
@ -1744,11 +1751,11 @@ SDValue AMDGPUTargetLowering::LowerUDIVREM(SDValue Op,
|
|||
SDValue RCP_HI = DAG.getNode(ISD::MULHU, DL, VT, RCP, Den);
|
||||
|
||||
// NEG_RCP_LO = -RCP_LO
|
||||
SDValue NEG_RCP_LO = DAG.getNode(ISD::SUB, DL, VT, DAG.getConstant(0, VT),
|
||||
SDValue NEG_RCP_LO = DAG.getNode(ISD::SUB, DL, VT, DAG.getConstant(0, DL, VT),
|
||||
RCP_LO);
|
||||
|
||||
// ABS_RCP_LO = (RCP_HI == 0 ? NEG_RCP_LO : RCP_LO)
|
||||
SDValue ABS_RCP_LO = DAG.getSelectCC(DL, RCP_HI, DAG.getConstant(0, VT),
|
||||
SDValue ABS_RCP_LO = DAG.getSelectCC(DL, RCP_HI, DAG.getConstant(0, DL, VT),
|
||||
NEG_RCP_LO, RCP_LO,
|
||||
ISD::SETEQ);
|
||||
// Calculate the rounding error from the URECIP instruction
|
||||
|
@ -1762,7 +1769,7 @@ SDValue AMDGPUTargetLowering::LowerUDIVREM(SDValue Op,
|
|||
SDValue RCP_S_E = DAG.getNode(ISD::SUB, DL, VT, RCP, E);
|
||||
|
||||
// Tmp0 = (RCP_HI == 0 ? RCP_A_E : RCP_SUB_E)
|
||||
SDValue Tmp0 = DAG.getSelectCC(DL, RCP_HI, DAG.getConstant(0, VT),
|
||||
SDValue Tmp0 = DAG.getSelectCC(DL, RCP_HI, DAG.getConstant(0, DL, VT),
|
||||
RCP_A_E, RCP_S_E,
|
||||
ISD::SETEQ);
|
||||
// Quotient = mulhu(Tmp0, Num)
|
||||
|
@ -1776,14 +1783,14 @@ SDValue AMDGPUTargetLowering::LowerUDIVREM(SDValue Op,
|
|||
|
||||
// Remainder_GE_Den = (Remainder >= Den ? -1 : 0)
|
||||
SDValue Remainder_GE_Den = DAG.getSelectCC(DL, Remainder, Den,
|
||||
DAG.getConstant(-1, VT),
|
||||
DAG.getConstant(0, VT),
|
||||
DAG.getConstant(-1, DL, VT),
|
||||
DAG.getConstant(0, DL, VT),
|
||||
ISD::SETUGE);
|
||||
// Remainder_GE_Zero = (Num >= Num_S_Remainder ? -1 : 0)
|
||||
SDValue Remainder_GE_Zero = DAG.getSelectCC(DL, Num,
|
||||
Num_S_Remainder,
|
||||
DAG.getConstant(-1, VT),
|
||||
DAG.getConstant(0, VT),
|
||||
DAG.getConstant(-1, DL, VT),
|
||||
DAG.getConstant(0, DL, VT),
|
||||
ISD::SETUGE);
|
||||
// Tmp1 = Remainder_GE_Den & Remainder_GE_Zero
|
||||
SDValue Tmp1 = DAG.getNode(ISD::AND, DL, VT, Remainder_GE_Den,
|
||||
|
@ -1793,18 +1800,18 @@ SDValue AMDGPUTargetLowering::LowerUDIVREM(SDValue Op,
|
|||
|
||||
// Quotient_A_One = Quotient + 1
|
||||
SDValue Quotient_A_One = DAG.getNode(ISD::ADD, DL, VT, Quotient,
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, DL, VT));
|
||||
|
||||
// Quotient_S_One = Quotient - 1
|
||||
SDValue Quotient_S_One = DAG.getNode(ISD::SUB, DL, VT, Quotient,
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, DL, VT));
|
||||
|
||||
// Div = (Tmp1 == 0 ? Quotient : Quotient_A_One)
|
||||
SDValue Div = DAG.getSelectCC(DL, Tmp1, DAG.getConstant(0, VT),
|
||||
SDValue Div = DAG.getSelectCC(DL, Tmp1, DAG.getConstant(0, DL, VT),
|
||||
Quotient, Quotient_A_One, ISD::SETEQ);
|
||||
|
||||
// Div = (Remainder_GE_Zero == 0 ? Quotient_S_One : Div)
|
||||
Div = DAG.getSelectCC(DL, Remainder_GE_Zero, DAG.getConstant(0, VT),
|
||||
Div = DAG.getSelectCC(DL, Remainder_GE_Zero, DAG.getConstant(0, DL, VT),
|
||||
Quotient_S_One, Div, ISD::SETEQ);
|
||||
|
||||
// Calculate Rem result:
|
||||
|
@ -1816,11 +1823,11 @@ SDValue AMDGPUTargetLowering::LowerUDIVREM(SDValue Op,
|
|||
SDValue Remainder_A_Den = DAG.getNode(ISD::ADD, DL, VT, Remainder, Den);
|
||||
|
||||
// Rem = (Tmp1 == 0 ? Remainder : Remainder_S_Den)
|
||||
SDValue Rem = DAG.getSelectCC(DL, Tmp1, DAG.getConstant(0, VT),
|
||||
SDValue Rem = DAG.getSelectCC(DL, Tmp1, DAG.getConstant(0, DL, VT),
|
||||
Remainder, Remainder_S_Den, ISD::SETEQ);
|
||||
|
||||
// Rem = (Remainder_GE_Zero == 0 ? Remainder_A_Den : Rem)
|
||||
Rem = DAG.getSelectCC(DL, Remainder_GE_Zero, DAG.getConstant(0, VT),
|
||||
Rem = DAG.getSelectCC(DL, Remainder_GE_Zero, DAG.getConstant(0, DL, VT),
|
||||
Remainder_A_Den, Rem, ISD::SETEQ);
|
||||
SDValue Ops[2] = {
|
||||
Div,
|
||||
|
@ -1837,8 +1844,8 @@ SDValue AMDGPUTargetLowering::LowerSDIVREM(SDValue Op,
|
|||
SDValue LHS = Op.getOperand(0);
|
||||
SDValue RHS = Op.getOperand(1);
|
||||
|
||||
SDValue Zero = DAG.getConstant(0, VT);
|
||||
SDValue NegOne = DAG.getConstant(-1, VT);
|
||||
SDValue Zero = DAG.getConstant(0, DL, VT);
|
||||
SDValue NegOne = DAG.getConstant(-1, DL, VT);
|
||||
|
||||
if (VT == MVT::i32 &&
|
||||
DAG.ComputeNumSignBits(LHS) > 8 &&
|
||||
|
@ -1913,8 +1920,8 @@ SDValue AMDGPUTargetLowering::LowerFCEIL(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
SDValue Trunc = DAG.getNode(ISD::FTRUNC, SL, MVT::f64, Src);
|
||||
|
||||
const SDValue Zero = DAG.getConstantFP(0.0, MVT::f64);
|
||||
const SDValue One = DAG.getConstantFP(1.0, MVT::f64);
|
||||
const SDValue Zero = DAG.getConstantFP(0.0, SL, MVT::f64);
|
||||
const SDValue One = DAG.getConstantFP(1.0, SL, MVT::f64);
|
||||
|
||||
EVT SetCCVT = getSetCCResultType(*DAG.getContext(), MVT::f64);
|
||||
|
||||
|
@ -1932,10 +1939,10 @@ static SDValue extractF64Exponent(SDValue Hi, SDLoc SL, SelectionDAG &DAG) {
|
|||
|
||||
SDValue ExpPart = DAG.getNode(AMDGPUISD::BFE_U32, SL, MVT::i32,
|
||||
Hi,
|
||||
DAG.getConstant(FractBits - 32, MVT::i32),
|
||||
DAG.getConstant(ExpBits, MVT::i32));
|
||||
DAG.getConstant(FractBits - 32, SL, MVT::i32),
|
||||
DAG.getConstant(ExpBits, SL, MVT::i32));
|
||||
SDValue Exp = DAG.getNode(ISD::SUB, SL, MVT::i32, ExpPart,
|
||||
DAG.getConstant(1023, MVT::i32));
|
||||
DAG.getConstant(1023, SL, MVT::i32));
|
||||
|
||||
return Exp;
|
||||
}
|
||||
|
@ -1946,8 +1953,8 @@ SDValue AMDGPUTargetLowering::LowerFTRUNC(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
assert(Op.getValueType() == MVT::f64);
|
||||
|
||||
const SDValue Zero = DAG.getConstant(0, MVT::i32);
|
||||
const SDValue One = DAG.getConstant(1, MVT::i32);
|
||||
const SDValue Zero = DAG.getConstant(0, SL, MVT::i32);
|
||||
const SDValue One = DAG.getConstant(1, SL, MVT::i32);
|
||||
|
||||
SDValue VecSrc = DAG.getNode(ISD::BITCAST, SL, MVT::v2i32, Src);
|
||||
|
||||
|
@ -1960,7 +1967,7 @@ SDValue AMDGPUTargetLowering::LowerFTRUNC(SDValue Op, SelectionDAG &DAG) const {
|
|||
const unsigned FractBits = 52;
|
||||
|
||||
// Extract the sign bit.
|
||||
const SDValue SignBitMask = DAG.getConstant(UINT32_C(1) << 31, MVT::i32);
|
||||
const SDValue SignBitMask = DAG.getConstant(UINT32_C(1) << 31, SL, MVT::i32);
|
||||
SDValue SignBit = DAG.getNode(ISD::AND, SL, MVT::i32, Hi, SignBitMask);
|
||||
|
||||
// Extend back to to 64-bits.
|
||||
|
@ -1970,7 +1977,7 @@ SDValue AMDGPUTargetLowering::LowerFTRUNC(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
SDValue BcInt = DAG.getNode(ISD::BITCAST, SL, MVT::i64, Src);
|
||||
const SDValue FractMask
|
||||
= DAG.getConstant((UINT64_C(1) << FractBits) - 1, MVT::i64);
|
||||
= DAG.getConstant((UINT64_C(1) << FractBits) - 1, SL, MVT::i64);
|
||||
|
||||
SDValue Shr = DAG.getNode(ISD::SRA, SL, MVT::i64, FractMask, Exp);
|
||||
SDValue Not = DAG.getNOT(SL, Shr, MVT::i64);
|
||||
|
@ -1978,7 +1985,7 @@ SDValue AMDGPUTargetLowering::LowerFTRUNC(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
EVT SetCCVT = getSetCCResultType(*DAG.getContext(), MVT::i32);
|
||||
|
||||
const SDValue FiftyOne = DAG.getConstant(FractBits - 1, MVT::i32);
|
||||
const SDValue FiftyOne = DAG.getConstant(FractBits - 1, SL, MVT::i32);
|
||||
|
||||
SDValue ExpLt0 = DAG.getSetCC(SL, SetCCVT, Exp, Zero, ISD::SETLT);
|
||||
SDValue ExpGt51 = DAG.getSetCC(SL, SetCCVT, Exp, FiftyOne, ISD::SETGT);
|
||||
|
@ -1996,7 +2003,7 @@ SDValue AMDGPUTargetLowering::LowerFRINT(SDValue Op, SelectionDAG &DAG) const {
|
|||
assert(Op.getValueType() == MVT::f64);
|
||||
|
||||
APFloat C1Val(APFloat::IEEEdouble, "0x1.0p+52");
|
||||
SDValue C1 = DAG.getConstantFP(C1Val, MVT::f64);
|
||||
SDValue C1 = DAG.getConstantFP(C1Val, SL, MVT::f64);
|
||||
SDValue CopySign = DAG.getNode(ISD::FCOPYSIGN, SL, MVT::f64, C1, Src);
|
||||
|
||||
SDValue Tmp1 = DAG.getNode(ISD::FADD, SL, MVT::f64, Src, CopySign);
|
||||
|
@ -2005,7 +2012,7 @@ SDValue AMDGPUTargetLowering::LowerFRINT(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue Fabs = DAG.getNode(ISD::FABS, SL, MVT::f64, Src);
|
||||
|
||||
APFloat C2Val(APFloat::IEEEdouble, "0x1.fffffffffffffp+51");
|
||||
SDValue C2 = DAG.getConstantFP(C2Val, MVT::f64);
|
||||
SDValue C2 = DAG.getConstantFP(C2Val, SL, MVT::f64);
|
||||
|
||||
EVT SetCCVT = getSetCCResultType(*DAG.getContext(), MVT::f64);
|
||||
SDValue Cond = DAG.getSetCC(SL, SetCCVT, Fabs, C2, ISD::SETOGT);
|
||||
|
@ -2031,9 +2038,9 @@ SDValue AMDGPUTargetLowering::LowerFROUND32(SDValue Op, SelectionDAG &DAG) const
|
|||
|
||||
SDValue AbsDiff = DAG.getNode(ISD::FABS, SL, MVT::f32, Diff);
|
||||
|
||||
const SDValue Zero = DAG.getConstantFP(0.0, MVT::f32);
|
||||
const SDValue One = DAG.getConstantFP(1.0, MVT::f32);
|
||||
const SDValue Half = DAG.getConstantFP(0.5, MVT::f32);
|
||||
const SDValue Zero = DAG.getConstantFP(0.0, SL, MVT::f32);
|
||||
const SDValue One = DAG.getConstantFP(1.0, SL, MVT::f32);
|
||||
const SDValue Half = DAG.getConstantFP(0.5, SL, MVT::f32);
|
||||
|
||||
SDValue SignOne = DAG.getNode(ISD::FCOPYSIGN, SL, MVT::f32, One, X);
|
||||
|
||||
|
@ -2052,10 +2059,10 @@ SDValue AMDGPUTargetLowering::LowerFROUND64(SDValue Op, SelectionDAG &DAG) const
|
|||
|
||||
SDValue L = DAG.getNode(ISD::BITCAST, SL, MVT::i64, X);
|
||||
|
||||
const SDValue Zero = DAG.getConstant(0, MVT::i32);
|
||||
const SDValue One = DAG.getConstant(1, MVT::i32);
|
||||
const SDValue NegOne = DAG.getConstant(-1, MVT::i32);
|
||||
const SDValue FiftyOne = DAG.getConstant(51, MVT::i32);
|
||||
const SDValue Zero = DAG.getConstant(0, SL, MVT::i32);
|
||||
const SDValue One = DAG.getConstant(1, SL, MVT::i32);
|
||||
const SDValue NegOne = DAG.getConstant(-1, SL, MVT::i32);
|
||||
const SDValue FiftyOne = DAG.getConstant(51, SL, MVT::i32);
|
||||
EVT SetCCVT = getSetCCResultType(*DAG.getContext(), MVT::i32);
|
||||
|
||||
|
||||
|
@ -2065,20 +2072,22 @@ SDValue AMDGPUTargetLowering::LowerFROUND64(SDValue Op, SelectionDAG &DAG) const
|
|||
|
||||
SDValue Exp = extractF64Exponent(Hi, SL, DAG);
|
||||
|
||||
const SDValue Mask = DAG.getConstant(INT64_C(0x000fffffffffffff), MVT::i64);
|
||||
const SDValue Mask = DAG.getConstant(INT64_C(0x000fffffffffffff), SL,
|
||||
MVT::i64);
|
||||
|
||||
SDValue M = DAG.getNode(ISD::SRA, SL, MVT::i64, Mask, Exp);
|
||||
SDValue D = DAG.getNode(ISD::SRA, SL, MVT::i64,
|
||||
DAG.getConstant(INT64_C(0x0008000000000000), MVT::i64),
|
||||
DAG.getConstant(INT64_C(0x0008000000000000), SL,
|
||||
MVT::i64),
|
||||
Exp);
|
||||
|
||||
SDValue Tmp0 = DAG.getNode(ISD::AND, SL, MVT::i64, L, M);
|
||||
SDValue Tmp1 = DAG.getSetCC(SL, SetCCVT,
|
||||
DAG.getConstant(0, MVT::i64), Tmp0,
|
||||
DAG.getConstant(0, SL, MVT::i64), Tmp0,
|
||||
ISD::SETNE);
|
||||
|
||||
SDValue Tmp2 = DAG.getNode(ISD::SELECT, SL, MVT::i64, Tmp1,
|
||||
D, DAG.getConstant(0, MVT::i64));
|
||||
D, DAG.getConstant(0, SL, MVT::i64));
|
||||
SDValue K = DAG.getNode(ISD::ADD, SL, MVT::i64, L, Tmp2);
|
||||
|
||||
K = DAG.getNode(ISD::AND, SL, MVT::i64, K, DAG.getNOT(SL, M, MVT::i64));
|
||||
|
@ -2090,8 +2099,8 @@ SDValue AMDGPUTargetLowering::LowerFROUND64(SDValue Op, SelectionDAG &DAG) const
|
|||
|
||||
SDValue Mag = DAG.getNode(ISD::SELECT, SL, MVT::f64,
|
||||
ExpEqNegOne,
|
||||
DAG.getConstantFP(1.0, MVT::f64),
|
||||
DAG.getConstantFP(0.0, MVT::f64));
|
||||
DAG.getConstantFP(1.0, SL, MVT::f64),
|
||||
DAG.getConstantFP(0.0, SL, MVT::f64));
|
||||
|
||||
SDValue S = DAG.getNode(ISD::FCOPYSIGN, SL, MVT::f64, Mag, X);
|
||||
|
||||
|
@ -2123,8 +2132,8 @@ SDValue AMDGPUTargetLowering::LowerFFLOOR(SDValue Op, SelectionDAG &DAG) const {
|
|||
|
||||
SDValue Trunc = DAG.getNode(ISD::FTRUNC, SL, MVT::f64, Src);
|
||||
|
||||
const SDValue Zero = DAG.getConstantFP(0.0, MVT::f64);
|
||||
const SDValue NegOne = DAG.getConstantFP(-1.0, MVT::f64);
|
||||
const SDValue Zero = DAG.getConstantFP(0.0, SL, MVT::f64);
|
||||
const SDValue NegOne = DAG.getConstantFP(-1.0, SL, MVT::f64);
|
||||
|
||||
EVT SetCCVT = getSetCCResultType(*DAG.getContext(), MVT::f64);
|
||||
|
||||
|
@ -2144,9 +2153,9 @@ SDValue AMDGPUTargetLowering::LowerINT_TO_FP64(SDValue Op, SelectionDAG &DAG,
|
|||
SDValue BC = DAG.getNode(ISD::BITCAST, SL, MVT::v2i32, Src);
|
||||
|
||||
SDValue Lo = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, SL, MVT::i32, BC,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, SL, MVT::i32));
|
||||
SDValue Hi = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, SL, MVT::i32, BC,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, SL, MVT::i32));
|
||||
|
||||
SDValue CvtHi = DAG.getNode(Signed ? ISD::SINT_TO_FP : ISD::UINT_TO_FP,
|
||||
SL, MVT::f64, Hi);
|
||||
|
@ -2154,7 +2163,7 @@ SDValue AMDGPUTargetLowering::LowerINT_TO_FP64(SDValue Op, SelectionDAG &DAG,
|
|||
SDValue CvtLo = DAG.getNode(ISD::UINT_TO_FP, SL, MVT::f64, Lo);
|
||||
|
||||
SDValue LdExp = DAG.getNode(AMDGPUISD::LDEXP, SL, MVT::f64, CvtHi,
|
||||
DAG.getConstant(32, MVT::i32));
|
||||
DAG.getConstant(32, SL, MVT::i32));
|
||||
|
||||
return DAG.getNode(ISD::FADD, SL, MVT::f64, LdExp, CvtLo);
|
||||
}
|
||||
|
@ -2175,13 +2184,13 @@ SDValue AMDGPUTargetLowering::LowerUINT_TO_FP(SDValue Op,
|
|||
|
||||
// f32 uint_to_fp i64
|
||||
SDValue Lo = DAG.getNode(ISD::EXTRACT_ELEMENT, DL, MVT::i32, S0,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
SDValue FloatLo = DAG.getNode(ISD::UINT_TO_FP, DL, MVT::f32, Lo);
|
||||
SDValue Hi = DAG.getNode(ISD::EXTRACT_ELEMENT, DL, MVT::i32, S0,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, DL, MVT::i32));
|
||||
SDValue FloatHi = DAG.getNode(ISD::UINT_TO_FP, DL, MVT::f32, Hi);
|
||||
FloatHi = DAG.getNode(ISD::FMUL, DL, MVT::f32, FloatHi,
|
||||
DAG.getConstantFP(4294967296.0f, MVT::f32)); // 2^32
|
||||
DAG.getConstantFP(4294967296.0f, DL, MVT::f32)); // 2^32
|
||||
return DAG.getNode(ISD::FADD, DL, MVT::f32, FloatLo, FloatHi);
|
||||
}
|
||||
|
||||
|
@ -2202,10 +2211,10 @@ SDValue AMDGPUTargetLowering::LowerFP64_TO_INT(SDValue Op, SelectionDAG &DAG,
|
|||
|
||||
SDValue Trunc = DAG.getNode(ISD::FTRUNC, SL, MVT::f64, Src);
|
||||
|
||||
SDValue K0
|
||||
= DAG.getConstantFP(BitsToDouble(UINT64_C(0x3df0000000000000)), MVT::f64);
|
||||
SDValue K1
|
||||
= DAG.getConstantFP(BitsToDouble(UINT64_C(0xc1f0000000000000)), MVT::f64);
|
||||
SDValue K0 = DAG.getConstantFP(BitsToDouble(UINT64_C(0x3df0000000000000)), SL,
|
||||
MVT::f64);
|
||||
SDValue K1 = DAG.getConstantFP(BitsToDouble(UINT64_C(0xc1f0000000000000)), SL,
|
||||
MVT::f64);
|
||||
|
||||
SDValue Mul = DAG.getNode(ISD::FMUL, SL, MVT::f64, Trunc, K0);
|
||||
|
||||
|
@ -2304,14 +2313,14 @@ static void simplifyI24(SDValue Op, TargetLowering::DAGCombinerInfo &DCI) {
|
|||
|
||||
template <typename IntTy>
|
||||
static SDValue constantFoldBFE(SelectionDAG &DAG, IntTy Src0,
|
||||
uint32_t Offset, uint32_t Width) {
|
||||
uint32_t Offset, uint32_t Width, SDLoc DL) {
|
||||
if (Width + Offset < 32) {
|
||||
uint32_t Shl = static_cast<uint32_t>(Src0) << (32 - Offset - Width);
|
||||
IntTy Result = static_cast<IntTy>(Shl) >> (32 - Width);
|
||||
return DAG.getConstant(Result, MVT::i32);
|
||||
return DAG.getConstant(Result, DL, MVT::i32);
|
||||
}
|
||||
|
||||
return DAG.getConstant(Src0 >> Offset, MVT::i32);
|
||||
return DAG.getConstant(Src0 >> Offset, DL, MVT::i32);
|
||||
}
|
||||
|
||||
static bool usesAllNormalStores(SDNode *LoadVal) {
|
||||
|
@ -2416,7 +2425,6 @@ SDValue AMDGPUTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
case ISD::SELECT: {
|
||||
SDValue Cond = N->getOperand(0);
|
||||
if (Cond.getOpcode() == ISD::SETCC && Cond.hasOneUse()) {
|
||||
SDLoc DL(N);
|
||||
EVT VT = N->getValueType(0);
|
||||
SDValue LHS = Cond.getOperand(0);
|
||||
SDValue RHS = Cond.getOperand(1);
|
||||
|
@ -2447,7 +2455,7 @@ SDValue AMDGPUTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
|
||||
uint32_t WidthVal = Width->getZExtValue() & 0x1f;
|
||||
if (WidthVal == 0)
|
||||
return DAG.getConstant(0, MVT::i32);
|
||||
return DAG.getConstant(0, DL, MVT::i32);
|
||||
|
||||
ConstantSDNode *Offset = dyn_cast<ConstantSDNode>(N->getOperand(1));
|
||||
if (!Offset)
|
||||
|
@ -2486,17 +2494,19 @@ SDValue AMDGPUTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
return constantFoldBFE<int32_t>(DAG,
|
||||
CVal->getSExtValue(),
|
||||
OffsetVal,
|
||||
WidthVal);
|
||||
WidthVal,
|
||||
DL);
|
||||
}
|
||||
|
||||
return constantFoldBFE<uint32_t>(DAG,
|
||||
CVal->getZExtValue(),
|
||||
OffsetVal,
|
||||
WidthVal);
|
||||
WidthVal,
|
||||
DL);
|
||||
}
|
||||
|
||||
if ((OffsetVal + WidthVal) >= 32) {
|
||||
SDValue ShiftVal = DAG.getConstant(OffsetVal, MVT::i32);
|
||||
SDValue ShiftVal = DAG.getConstant(OffsetVal, DL, MVT::i32);
|
||||
return DAG.getNode(Signed ? ISD::SRA : ISD::SRL, DL, MVT::i32,
|
||||
BitsFrom, ShiftVal);
|
||||
}
|
||||
|
|
|
@ -583,7 +583,7 @@ def IMMZeroBasedBitfieldMask : PatLeaf <(imm), [{
|
|||
}]>;
|
||||
|
||||
def IMMPopCount : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(countPopulation(N->getZExtValue()),
|
||||
return CurDAG->getTargetConstant(countPopulation(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
|
|
|
@ -611,17 +611,18 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
|||
return DAG.getCopyToReg(Chain, SDLoc(Op), Reg, Op.getOperand(2));
|
||||
}
|
||||
case AMDGPUIntrinsic::R600_store_swizzle: {
|
||||
SDLoc DL(Op);
|
||||
const SDValue Args[8] = {
|
||||
Chain,
|
||||
Op.getOperand(2), // Export Value
|
||||
Op.getOperand(3), // ArrayBase
|
||||
Op.getOperand(4), // Type
|
||||
DAG.getConstant(0, MVT::i32), // SWZ_X
|
||||
DAG.getConstant(1, MVT::i32), // SWZ_Y
|
||||
DAG.getConstant(2, MVT::i32), // SWZ_Z
|
||||
DAG.getConstant(3, MVT::i32) // SWZ_W
|
||||
DAG.getConstant(0, DL, MVT::i32), // SWZ_X
|
||||
DAG.getConstant(1, DL, MVT::i32), // SWZ_Y
|
||||
DAG.getConstant(2, DL, MVT::i32), // SWZ_Z
|
||||
DAG.getConstant(3, DL, MVT::i32) // SWZ_W
|
||||
};
|
||||
return DAG.getNode(AMDGPUISD::EXPORT, SDLoc(Op), Op.getValueType(), Args);
|
||||
return DAG.getNode(AMDGPUISD::EXPORT, DL, Op.getValueType(), Args);
|
||||
}
|
||||
|
||||
// default for switch(IntrinsicID)
|
||||
|
@ -655,7 +656,7 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
|||
const R600InstrInfo *TII =
|
||||
static_cast<const R600InstrInfo *>(Subtarget->getInstrInfo());
|
||||
interp = DAG.getMachineNode(AMDGPU::INTERP_VEC_LOAD, DL,
|
||||
MVT::v4f32, DAG.getTargetConstant(slot / 4 , MVT::i32));
|
||||
MVT::v4f32, DAG.getTargetConstant(slot / 4, DL, MVT::i32));
|
||||
return DAG.getTargetExtractSubreg(
|
||||
TII->getRegisterInfo().getSubRegFromChannel(slot % 4),
|
||||
DL, MVT::f32, SDValue(interp, 0));
|
||||
|
@ -673,11 +674,11 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
|||
|
||||
if (slot % 4 < 2)
|
||||
interp = DAG.getMachineNode(AMDGPU::INTERP_PAIR_XY, DL,
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot / 4 , MVT::i32),
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot / 4, DL, MVT::i32),
|
||||
RegisterJNode, RegisterINode);
|
||||
else
|
||||
interp = DAG.getMachineNode(AMDGPU::INTERP_PAIR_ZW, DL,
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot / 4 , MVT::i32),
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot / 4, DL, MVT::i32),
|
||||
RegisterJNode, RegisterINode);
|
||||
return SDValue(interp, slot % 2);
|
||||
}
|
||||
|
@ -690,11 +691,11 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
|||
|
||||
if (IntrinsicID == AMDGPUIntrinsic::R600_interp_xy)
|
||||
interp = DAG.getMachineNode(AMDGPU::INTERP_PAIR_XY, DL,
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot, MVT::i32),
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot, DL, MVT::i32),
|
||||
RegisterJNode, RegisterINode);
|
||||
else
|
||||
interp = DAG.getMachineNode(AMDGPU::INTERP_PAIR_ZW, DL,
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot, MVT::i32),
|
||||
MVT::f32, MVT::f32, DAG.getTargetConstant(slot, DL, MVT::i32),
|
||||
RegisterJNode, RegisterINode);
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, DL, MVT::v2f32,
|
||||
SDValue(interp, 0), SDValue(interp, 1));
|
||||
|
@ -750,19 +751,19 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
|||
}
|
||||
|
||||
SDValue TexArgs[19] = {
|
||||
DAG.getConstant(TextureOp, MVT::i32),
|
||||
DAG.getConstant(TextureOp, DL, MVT::i32),
|
||||
Op.getOperand(1),
|
||||
DAG.getConstant(0, MVT::i32),
|
||||
DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(2, MVT::i32),
|
||||
DAG.getConstant(3, MVT::i32),
|
||||
DAG.getConstant(0, DL, MVT::i32),
|
||||
DAG.getConstant(1, DL, MVT::i32),
|
||||
DAG.getConstant(2, DL, MVT::i32),
|
||||
DAG.getConstant(3, DL, MVT::i32),
|
||||
Op.getOperand(2),
|
||||
Op.getOperand(3),
|
||||
Op.getOperand(4),
|
||||
DAG.getConstant(0, MVT::i32),
|
||||
DAG.getConstant(1, MVT::i32),
|
||||
DAG.getConstant(2, MVT::i32),
|
||||
DAG.getConstant(3, MVT::i32),
|
||||
DAG.getConstant(0, DL, MVT::i32),
|
||||
DAG.getConstant(1, DL, MVT::i32),
|
||||
DAG.getConstant(2, DL, MVT::i32),
|
||||
DAG.getConstant(3, DL, MVT::i32),
|
||||
Op.getOperand(5),
|
||||
Op.getOperand(6),
|
||||
Op.getOperand(7),
|
||||
|
@ -775,21 +776,21 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
|||
case AMDGPUIntrinsic::AMDGPU_dp4: {
|
||||
SDValue Args[8] = {
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(1),
|
||||
DAG.getConstant(0, MVT::i32)),
|
||||
DAG.getConstant(0, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(2),
|
||||
DAG.getConstant(0, MVT::i32)),
|
||||
DAG.getConstant(0, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(1),
|
||||
DAG.getConstant(1, MVT::i32)),
|
||||
DAG.getConstant(1, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(2),
|
||||
DAG.getConstant(1, MVT::i32)),
|
||||
DAG.getConstant(1, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(1),
|
||||
DAG.getConstant(2, MVT::i32)),
|
||||
DAG.getConstant(2, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(2),
|
||||
DAG.getConstant(2, MVT::i32)),
|
||||
DAG.getConstant(2, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(1),
|
||||
DAG.getConstant(3, MVT::i32)),
|
||||
DAG.getConstant(3, DL, MVT::i32)),
|
||||
DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::f32, Op.getOperand(2),
|
||||
DAG.getConstant(3, MVT::i32))
|
||||
DAG.getConstant(3, DL, MVT::i32))
|
||||
};
|
||||
return DAG.getNode(AMDGPUISD::DOT4, DL, MVT::f32, Args);
|
||||
}
|
||||
|
@ -931,8 +932,8 @@ SDValue R600TargetLowering::vectorToVerticalVector(SelectionDAG &DAG,
|
|||
|
||||
for (unsigned i = 0, e = VecVT.getVectorNumElements();
|
||||
i != e; ++i) {
|
||||
Args.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT,
|
||||
Vector, DAG.getConstant(i, getVectorIdxTy())));
|
||||
Args.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, EltVT, Vector,
|
||||
DAG.getConstant(i, DL, getVectorIdxTy())));
|
||||
}
|
||||
|
||||
return DAG.getNode(AMDGPUISD::BUILD_VERTICAL_VECTOR, DL, VecVT, Args);
|
||||
|
@ -976,11 +977,12 @@ SDValue R600TargetLowering::LowerTrig(SDValue Op, SelectionDAG &DAG) const {
|
|||
// Thus we lower them to TRIG ( FRACT ( x / 2Pi + 0.5) - 0.5)
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue Arg = Op.getOperand(0);
|
||||
SDValue FractPart = DAG.getNode(AMDGPUISD::FRACT, SDLoc(Op), VT,
|
||||
DAG.getNode(ISD::FADD, SDLoc(Op), VT,
|
||||
DAG.getNode(ISD::FMUL, SDLoc(Op), VT, Arg,
|
||||
DAG.getConstantFP(0.15915494309, MVT::f32)),
|
||||
DAG.getConstantFP(0.5, MVT::f32)));
|
||||
SDLoc DL(Op);
|
||||
SDValue FractPart = DAG.getNode(AMDGPUISD::FRACT, DL, VT,
|
||||
DAG.getNode(ISD::FADD, DL, VT,
|
||||
DAG.getNode(ISD::FMUL, DL, VT, Arg,
|
||||
DAG.getConstantFP(0.15915494309, DL, MVT::f32)),
|
||||
DAG.getConstantFP(0.5, DL, MVT::f32)));
|
||||
unsigned TrigNode;
|
||||
switch (Op.getOpcode()) {
|
||||
case ISD::FCOS:
|
||||
|
@ -992,14 +994,14 @@ SDValue R600TargetLowering::LowerTrig(SDValue Op, SelectionDAG &DAG) const {
|
|||
default:
|
||||
llvm_unreachable("Wrong trig opcode");
|
||||
}
|
||||
SDValue TrigVal = DAG.getNode(TrigNode, SDLoc(Op), VT,
|
||||
DAG.getNode(ISD::FADD, SDLoc(Op), VT, FractPart,
|
||||
DAG.getConstantFP(-0.5, MVT::f32)));
|
||||
SDValue TrigVal = DAG.getNode(TrigNode, DL, VT,
|
||||
DAG.getNode(ISD::FADD, DL, VT, FractPart,
|
||||
DAG.getConstantFP(-0.5, DL, MVT::f32)));
|
||||
if (Gen >= AMDGPUSubtarget::R700)
|
||||
return TrigVal;
|
||||
// On R600 hw, COS/SIN input must be between -Pi and Pi.
|
||||
return DAG.getNode(ISD::FMUL, SDLoc(Op), VT, TrigVal,
|
||||
DAG.getConstantFP(3.14159265359, MVT::f32));
|
||||
return DAG.getNode(ISD::FMUL, DL, VT, TrigVal,
|
||||
DAG.getConstantFP(3.14159265359, DL, MVT::f32));
|
||||
}
|
||||
|
||||
SDValue R600TargetLowering::LowerSHLParts(SDValue Op, SelectionDAG &DAG) const {
|
||||
|
@ -1009,11 +1011,11 @@ SDValue R600TargetLowering::LowerSHLParts(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue Lo = Op.getOperand(0);
|
||||
SDValue Hi = Op.getOperand(1);
|
||||
SDValue Shift = Op.getOperand(2);
|
||||
SDValue Zero = DAG.getConstant(0, VT);
|
||||
SDValue One = DAG.getConstant(1, VT);
|
||||
SDValue Zero = DAG.getConstant(0, DL, VT);
|
||||
SDValue One = DAG.getConstant(1, DL, VT);
|
||||
|
||||
SDValue Width = DAG.getConstant(VT.getSizeInBits(), VT);
|
||||
SDValue Width1 = DAG.getConstant(VT.getSizeInBits() - 1, VT);
|
||||
SDValue Width = DAG.getConstant(VT.getSizeInBits(), DL, VT);
|
||||
SDValue Width1 = DAG.getConstant(VT.getSizeInBits() - 1, DL, VT);
|
||||
SDValue BigShift = DAG.getNode(ISD::SUB, DL, VT, Shift, Width);
|
||||
SDValue CompShift = DAG.getNode(ISD::SUB, DL, VT, Width1, Shift);
|
||||
|
||||
|
@ -1045,13 +1047,13 @@ SDValue R600TargetLowering::LowerSRXParts(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue Lo = Op.getOperand(0);
|
||||
SDValue Hi = Op.getOperand(1);
|
||||
SDValue Shift = Op.getOperand(2);
|
||||
SDValue Zero = DAG.getConstant(0, VT);
|
||||
SDValue One = DAG.getConstant(1, VT);
|
||||
SDValue Zero = DAG.getConstant(0, DL, VT);
|
||||
SDValue One = DAG.getConstant(1, DL, VT);
|
||||
|
||||
const bool SRA = Op.getOpcode() == ISD::SRA_PARTS;
|
||||
|
||||
SDValue Width = DAG.getConstant(VT.getSizeInBits(), VT);
|
||||
SDValue Width1 = DAG.getConstant(VT.getSizeInBits() - 1, VT);
|
||||
SDValue Width = DAG.getConstant(VT.getSizeInBits(), DL, VT);
|
||||
SDValue Width1 = DAG.getConstant(VT.getSizeInBits() - 1, DL, VT);
|
||||
SDValue BigShift = DAG.getNode(ISD::SUB, DL, VT, Shift, Width);
|
||||
SDValue CompShift = DAG.getNode(ISD::SUB, DL, VT, Width1, Shift);
|
||||
|
||||
|
@ -1077,11 +1079,12 @@ SDValue R600TargetLowering::LowerSRXParts(SDValue Op, SelectionDAG &DAG) const {
|
|||
}
|
||||
|
||||
SDValue R600TargetLowering::LowerFPTOUINT(SDValue Op, SelectionDAG &DAG) const {
|
||||
SDLoc DL(Op);
|
||||
return DAG.getNode(
|
||||
ISD::SETCC,
|
||||
SDLoc(Op),
|
||||
DL,
|
||||
MVT::i1,
|
||||
Op, DAG.getConstantFP(0.0f, MVT::f32),
|
||||
Op, DAG.getConstantFP(0.0f, DL, MVT::f32),
|
||||
DAG.getCondCode(ISD::SETNE)
|
||||
);
|
||||
}
|
||||
|
@ -1097,7 +1100,7 @@ SDValue R600TargetLowering::LowerImplicitParameter(SelectionDAG &DAG, EVT VT,
|
|||
assert(isInt<16>(ByteOffset));
|
||||
|
||||
return DAG.getLoad(VT, DL, DAG.getEntryNode(),
|
||||
DAG.getConstant(ByteOffset, MVT::i32), // PTR
|
||||
DAG.getConstant(ByteOffset, DL, MVT::i32), // PTR
|
||||
MachinePointerInfo(ConstantPointerNull::get(PtrType)),
|
||||
false, false, false, 0);
|
||||
}
|
||||
|
@ -1234,11 +1237,11 @@ SDValue R600TargetLowering::LowerSELECT_CC(SDValue Op, SelectionDAG &DAG) const
|
|||
SDValue HWTrue, HWFalse;
|
||||
|
||||
if (CompareVT == MVT::f32) {
|
||||
HWTrue = DAG.getConstantFP(1.0f, CompareVT);
|
||||
HWFalse = DAG.getConstantFP(0.0f, CompareVT);
|
||||
HWTrue = DAG.getConstantFP(1.0f, DL, CompareVT);
|
||||
HWFalse = DAG.getConstantFP(0.0f, DL, CompareVT);
|
||||
} else if (CompareVT == MVT::i32) {
|
||||
HWTrue = DAG.getConstant(-1, CompareVT);
|
||||
HWFalse = DAG.getConstant(0, CompareVT);
|
||||
HWTrue = DAG.getConstant(-1, DL, CompareVT);
|
||||
HWFalse = DAG.getConstant(0, DL, CompareVT);
|
||||
}
|
||||
else {
|
||||
llvm_unreachable("Unhandled value type in LowerSELECT_CC");
|
||||
|
@ -1276,8 +1279,9 @@ SDValue R600TargetLowering::stackPtrToRegIndex(SDValue Ptr,
|
|||
default: llvm_unreachable("Invalid stack width");
|
||||
}
|
||||
|
||||
return DAG.getNode(ISD::SRL, SDLoc(Ptr), Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(SRLPad, MVT::i32));
|
||||
SDLoc DL(Ptr);
|
||||
return DAG.getNode(ISD::SRL, DL, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(SRLPad, DL, MVT::i32));
|
||||
}
|
||||
|
||||
void R600TargetLowering::getStackAddress(unsigned StackWidth,
|
||||
|
@ -1328,26 +1332,26 @@ SDValue R600TargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
EVT MemVT = StoreNode->getMemoryVT();
|
||||
SDValue MaskConstant;
|
||||
if (MemVT == MVT::i8) {
|
||||
MaskConstant = DAG.getConstant(0xFF, MVT::i32);
|
||||
MaskConstant = DAG.getConstant(0xFF, DL, MVT::i32);
|
||||
} else {
|
||||
assert(MemVT == MVT::i16);
|
||||
MaskConstant = DAG.getConstant(0xFFFF, MVT::i32);
|
||||
MaskConstant = DAG.getConstant(0xFFFF, DL, MVT::i32);
|
||||
}
|
||||
SDValue DWordAddr = DAG.getNode(ISD::SRL, DL, VT, Ptr,
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, DL, MVT::i32));
|
||||
SDValue ByteIndex = DAG.getNode(ISD::AND, DL, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(0x00000003, VT));
|
||||
DAG.getConstant(0x00000003, DL, VT));
|
||||
SDValue TruncValue = DAG.getNode(ISD::AND, DL, VT, Value, MaskConstant);
|
||||
SDValue Shift = DAG.getNode(ISD::SHL, DL, VT, ByteIndex,
|
||||
DAG.getConstant(3, VT));
|
||||
DAG.getConstant(3, DL, VT));
|
||||
SDValue ShiftedValue = DAG.getNode(ISD::SHL, DL, VT, TruncValue, Shift);
|
||||
SDValue Mask = DAG.getNode(ISD::SHL, DL, VT, MaskConstant, Shift);
|
||||
// XXX: If we add a 64-bit ZW register class, then we could use a 2 x i32
|
||||
// vector instead.
|
||||
SDValue Src[4] = {
|
||||
ShiftedValue,
|
||||
DAG.getConstant(0, MVT::i32),
|
||||
DAG.getConstant(0, MVT::i32),
|
||||
DAG.getConstant(0, DL, MVT::i32),
|
||||
DAG.getConstant(0, DL, MVT::i32),
|
||||
Mask
|
||||
};
|
||||
SDValue Input = DAG.getNode(ISD::BUILD_VECTOR, DL, MVT::v4i32, Src);
|
||||
|
@ -1360,7 +1364,7 @@ SDValue R600TargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
// Convert pointer from byte address to dword address.
|
||||
Ptr = DAG.getNode(AMDGPUISD::DWORDADDR, DL, Ptr.getValueType(),
|
||||
DAG.getNode(ISD::SRL, DL, Ptr.getValueType(),
|
||||
Ptr, DAG.getConstant(2, MVT::i32)));
|
||||
Ptr, DAG.getConstant(2, DL, MVT::i32)));
|
||||
|
||||
if (StoreNode->isTruncatingStore() || StoreNode->isIndexed()) {
|
||||
llvm_unreachable("Truncated and indexed stores not supported yet");
|
||||
|
@ -1402,13 +1406,13 @@ SDValue R600TargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
unsigned Channel, PtrIncr;
|
||||
getStackAddress(StackWidth, i, Channel, PtrIncr);
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, MVT::i32, Ptr,
|
||||
DAG.getConstant(PtrIncr, MVT::i32));
|
||||
DAG.getConstant(PtrIncr, DL, MVT::i32));
|
||||
SDValue Elem = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, ElemVT,
|
||||
Value, DAG.getConstant(i, MVT::i32));
|
||||
Value, DAG.getConstant(i, DL, MVT::i32));
|
||||
|
||||
Stores[i] = DAG.getNode(AMDGPUISD::REGISTER_STORE, DL, MVT::Other,
|
||||
Chain, Elem, Ptr,
|
||||
DAG.getTargetConstant(Channel, MVT::i32));
|
||||
DAG.getTargetConstant(Channel, DL, MVT::i32));
|
||||
}
|
||||
Chain = DAG.getNode(ISD::TokenFactor, DL, MVT::Other, Stores);
|
||||
} else {
|
||||
|
@ -1416,7 +1420,7 @@ SDValue R600TargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
Value = DAG.getNode(ISD::ZERO_EXTEND, DL, MVT::i32, Value);
|
||||
}
|
||||
Chain = DAG.getNode(AMDGPUISD::REGISTER_STORE, DL, MVT::Other, Chain, Value, Ptr,
|
||||
DAG.getTargetConstant(0, MVT::i32)); // Channel
|
||||
DAG.getTargetConstant(0, DL, MVT::i32)); // Channel
|
||||
}
|
||||
|
||||
return Chain;
|
||||
|
@ -1489,10 +1493,11 @@ SDValue R600TargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const
|
|||
SDValue Ptr = DAG.getZExtOrTrunc(LoadNode->getBasePtr(), DL,
|
||||
getPointerTy(AMDGPUAS::PRIVATE_ADDRESS));
|
||||
Ptr = DAG.getNode(ISD::SRL, DL, MVT::i32, Ptr,
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, DL, MVT::i32));
|
||||
return DAG.getNode(AMDGPUISD::REGISTER_LOAD, DL, Op->getVTList(),
|
||||
LoadNode->getChain(), Ptr,
|
||||
DAG.getTargetConstant(0, MVT::i32), Op.getOperand(2));
|
||||
DAG.getTargetConstant(0, DL, MVT::i32),
|
||||
Op.getOperand(2));
|
||||
}
|
||||
|
||||
if (LoadNode->getAddressSpace() == AMDGPUAS::LOCAL_ADDRESS && VT.isVector()) {
|
||||
|
@ -1519,7 +1524,7 @@ SDValue R600TargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const
|
|||
// Thus we add (((512 + (kc_bank << 12)) + chan ) * 4 here and
|
||||
// then div by 4 at the ISel step
|
||||
SDValue NewPtr = DAG.getNode(ISD::ADD, DL, Ptr.getValueType(), Ptr,
|
||||
DAG.getConstant(4 * i + ConstantBlock * 16, MVT::i32));
|
||||
DAG.getConstant(4 * i + ConstantBlock * 16, DL, MVT::i32));
|
||||
Slots[i] = DAG.getNode(AMDGPUISD::CONST_ADDRESS, DL, MVT::i32, NewPtr);
|
||||
}
|
||||
EVT NewVT = MVT::v4i32;
|
||||
|
@ -1533,15 +1538,16 @@ SDValue R600TargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const
|
|||
} else {
|
||||
// non-constant ptr can't be folded, keeps it as a v4f32 load
|
||||
Result = DAG.getNode(AMDGPUISD::CONST_ADDRESS, DL, MVT::v4i32,
|
||||
DAG.getNode(ISD::SRL, DL, MVT::i32, Ptr, DAG.getConstant(4, MVT::i32)),
|
||||
DAG.getConstant(LoadNode->getAddressSpace() -
|
||||
AMDGPUAS::CONSTANT_BUFFER_0, MVT::i32)
|
||||
DAG.getNode(ISD::SRL, DL, MVT::i32, Ptr,
|
||||
DAG.getConstant(4, DL, MVT::i32)),
|
||||
DAG.getConstant(LoadNode->getAddressSpace() -
|
||||
AMDGPUAS::CONSTANT_BUFFER_0, DL, MVT::i32)
|
||||
);
|
||||
}
|
||||
|
||||
if (!VT.isVector()) {
|
||||
Result = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, MVT::i32, Result,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
}
|
||||
|
||||
SDValue MergedValues[2] = {
|
||||
|
@ -1562,7 +1568,8 @@ SDValue R600TargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const
|
|||
EVT MemVT = LoadNode->getMemoryVT();
|
||||
assert(!MemVT.isVector() && (MemVT == MVT::i16 || MemVT == MVT::i8));
|
||||
SDValue ShiftAmount =
|
||||
DAG.getConstant(VT.getSizeInBits() - MemVT.getSizeInBits(), MVT::i32);
|
||||
DAG.getConstant(VT.getSizeInBits() - MemVT.getSizeInBits(), DL,
|
||||
MVT::i32);
|
||||
SDValue NewLoad = DAG.getExtLoad(ISD::EXTLOAD, DL, VT, Chain, Ptr,
|
||||
LoadNode->getPointerInfo(), MemVT,
|
||||
LoadNode->isVolatile(),
|
||||
|
@ -1600,10 +1607,10 @@ SDValue R600TargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const
|
|||
unsigned Channel, PtrIncr;
|
||||
getStackAddress(StackWidth, i, Channel, PtrIncr);
|
||||
Ptr = DAG.getNode(ISD::ADD, DL, MVT::i32, Ptr,
|
||||
DAG.getConstant(PtrIncr, MVT::i32));
|
||||
DAG.getConstant(PtrIncr, DL, MVT::i32));
|
||||
Loads[i] = DAG.getNode(AMDGPUISD::REGISTER_LOAD, DL, ElemVT,
|
||||
Chain, Ptr,
|
||||
DAG.getTargetConstant(Channel, MVT::i32),
|
||||
DAG.getTargetConstant(Channel, DL, MVT::i32),
|
||||
Op.getOperand(2));
|
||||
}
|
||||
for (unsigned i = NumElemVT; i < 4; ++i) {
|
||||
|
@ -1614,7 +1621,7 @@ SDValue R600TargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const
|
|||
} else {
|
||||
LoweredLoad = DAG.getNode(AMDGPUISD::REGISTER_LOAD, DL, VT,
|
||||
Chain, Ptr,
|
||||
DAG.getTargetConstant(0, MVT::i32), // Channel
|
||||
DAG.getTargetConstant(0, DL, MVT::i32), // Channel
|
||||
Op.getOperand(2));
|
||||
}
|
||||
|
||||
|
@ -1703,7 +1710,7 @@ SDValue R600TargetLowering::LowerFormalArguments(
|
|||
|
||||
MachinePointerInfo PtrInfo(UndefValue::get(PtrTy), PartOffset - ValBase);
|
||||
SDValue Arg = DAG.getLoad(ISD::UNINDEXED, Ext, VT, DL, Chain,
|
||||
DAG.getConstant(Offset, MVT::i32),
|
||||
DAG.getConstant(Offset, DL, MVT::i32),
|
||||
DAG.getUNDEF(MVT::i32),
|
||||
PtrInfo,
|
||||
MemVT, false, true, true, 4);
|
||||
|
@ -1804,7 +1811,8 @@ static SDValue ReorganizeVector(SelectionDAG &DAG, SDValue VectorEntry,
|
|||
|
||||
|
||||
SDValue R600TargetLowering::OptimizeSwizzle(SDValue BuildVector,
|
||||
SDValue Swz[4], SelectionDAG &DAG) const {
|
||||
SDValue Swz[4], SelectionDAG &DAG,
|
||||
SDLoc DL) const {
|
||||
assert(BuildVector.getOpcode() == ISD::BUILD_VECTOR);
|
||||
// Old -> New swizzle values
|
||||
DenseMap<unsigned, unsigned> SwizzleRemap;
|
||||
|
@ -1813,7 +1821,7 @@ SDValue Swz[4], SelectionDAG &DAG) const {
|
|||
for (unsigned i = 0; i < 4; i++) {
|
||||
unsigned Idx = cast<ConstantSDNode>(Swz[i])->getZExtValue();
|
||||
if (SwizzleRemap.find(Idx) != SwizzleRemap.end())
|
||||
Swz[i] = DAG.getConstant(SwizzleRemap[Idx], MVT::i32);
|
||||
Swz[i] = DAG.getConstant(SwizzleRemap[Idx], DL, MVT::i32);
|
||||
}
|
||||
|
||||
SwizzleRemap.clear();
|
||||
|
@ -1821,7 +1829,7 @@ SDValue Swz[4], SelectionDAG &DAG) const {
|
|||
for (unsigned i = 0; i < 4; i++) {
|
||||
unsigned Idx = cast<ConstantSDNode>(Swz[i])->getZExtValue();
|
||||
if (SwizzleRemap.find(Idx) != SwizzleRemap.end())
|
||||
Swz[i] = DAG.getConstant(SwizzleRemap[Idx], MVT::i32);
|
||||
Swz[i] = DAG.getConstant(SwizzleRemap[Idx], DL, MVT::i32);
|
||||
}
|
||||
|
||||
return BuildVector;
|
||||
|
@ -1867,11 +1875,12 @@ SDValue R600TargetLowering::PerformDAGCombine(SDNode *N,
|
|||
return SDValue();
|
||||
}
|
||||
|
||||
return DAG.getNode(ISD::SELECT_CC, SDLoc(N), N->getValueType(0),
|
||||
SDLoc dl(N);
|
||||
return DAG.getNode(ISD::SELECT_CC, dl, N->getValueType(0),
|
||||
SelectCC.getOperand(0), // LHS
|
||||
SelectCC.getOperand(1), // RHS
|
||||
DAG.getConstant(-1, MVT::i32), // True
|
||||
DAG.getConstant(0, MVT::i32), // False
|
||||
DAG.getConstant(-1, dl, MVT::i32), // True
|
||||
DAG.getConstant(0, dl, MVT::i32), // False
|
||||
SelectCC.getOperand(4)); // CC
|
||||
|
||||
break;
|
||||
|
@ -2014,7 +2023,7 @@ SDValue R600TargetLowering::PerformDAGCombine(SDNode *N,
|
|||
N->getOperand(7) // SWZ_W
|
||||
};
|
||||
SDLoc DL(N);
|
||||
NewArgs[1] = OptimizeSwizzle(N->getOperand(1), &NewArgs[4], DAG);
|
||||
NewArgs[1] = OptimizeSwizzle(N->getOperand(1), &NewArgs[4], DAG, DL);
|
||||
return DAG.getNode(AMDGPUISD::EXPORT, DL, N->getVTList(), NewArgs);
|
||||
}
|
||||
case AMDGPUISD::TEXTURE_FETCH: {
|
||||
|
@ -2043,9 +2052,9 @@ SDValue R600TargetLowering::PerformDAGCombine(SDNode *N,
|
|||
N->getOperand(17),
|
||||
N->getOperand(18),
|
||||
};
|
||||
NewArgs[1] = OptimizeSwizzle(N->getOperand(1), &NewArgs[2], DAG);
|
||||
return DAG.getNode(AMDGPUISD::TEXTURE_FETCH, SDLoc(N), N->getVTList(),
|
||||
NewArgs);
|
||||
SDLoc DL(N);
|
||||
NewArgs[1] = OptimizeSwizzle(N->getOperand(1), &NewArgs[2], DAG, DL);
|
||||
return DAG.getNode(AMDGPUISD::TEXTURE_FETCH, DL, N->getVTList(), NewArgs);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -2064,13 +2073,13 @@ FoldOperand(SDNode *ParentNode, unsigned SrcIdx, SDValue &Src, SDValue &Neg,
|
|||
if (!Neg.getNode())
|
||||
return false;
|
||||
Src = Src.getOperand(0);
|
||||
Neg = DAG.getTargetConstant(1, MVT::i32);
|
||||
Neg = DAG.getTargetConstant(1, SDLoc(ParentNode), MVT::i32);
|
||||
return true;
|
||||
case AMDGPU::FABS_R600:
|
||||
if (!Abs.getNode())
|
||||
return false;
|
||||
Src = Src.getOperand(0);
|
||||
Abs = DAG.getTargetConstant(1, MVT::i32);
|
||||
Abs = DAG.getTargetConstant(1, SDLoc(ParentNode), MVT::i32);
|
||||
return true;
|
||||
case AMDGPU::CONST_COPY: {
|
||||
unsigned Opcode = ParentNode->getMachineOpcode();
|
||||
|
@ -2166,7 +2175,7 @@ FoldOperand(SDNode *ParentNode, unsigned SrcIdx, SDValue &Src, SDValue &Neg,
|
|||
assert(C);
|
||||
if (C->getZExtValue())
|
||||
return false;
|
||||
Imm = DAG.getTargetConstant(ImmValue, MVT::i32);
|
||||
Imm = DAG.getTargetConstant(ImmValue, SDLoc(ParentNode), MVT::i32);
|
||||
}
|
||||
Src = DAG.getRegister(ImmReg, MVT::i32);
|
||||
return true;
|
||||
|
@ -2249,10 +2258,11 @@ SDNode *R600TargetLowering::PostISelFolding(MachineSDNode *Node,
|
|||
AMDGPU::OpName::clamp);
|
||||
if (ClampIdx < 0)
|
||||
return Node;
|
||||
SDLoc DL(Node);
|
||||
std::vector<SDValue> Ops(Src->op_begin(), Src->op_end());
|
||||
Ops[ClampIdx - 1] = DAG.getTargetConstant(1, MVT::i32);
|
||||
return DAG.getMachineNode(Src.getMachineOpcode(), SDLoc(Node),
|
||||
Node->getVTList(), Ops);
|
||||
Ops[ClampIdx - 1] = DAG.getTargetConstant(1, DL, MVT::i32);
|
||||
return DAG.getMachineNode(Src.getMachineOpcode(), DL,
|
||||
Node->getVTList(), Ops);
|
||||
} else {
|
||||
if (!TII->hasInstrModifiers(Opcode))
|
||||
return Node;
|
||||
|
|
|
@ -50,7 +50,8 @@ private:
|
|||
|
||||
void lowerImplicitParameter(MachineInstr *MI, MachineBasicBlock &BB,
|
||||
MachineRegisterInfo & MRI, unsigned dword_offset) const;
|
||||
SDValue OptimizeSwizzle(SDValue BuildVector, SDValue Swz[], SelectionDAG &DAG) const;
|
||||
SDValue OptimizeSwizzle(SDValue BuildVector, SDValue Swz[], SelectionDAG &DAG,
|
||||
SDLoc DL) const;
|
||||
SDValue vectorToVerticalVector(SelectionDAG &DAG, SDValue Vector) const;
|
||||
|
||||
SDValue LowerEXTRACT_VECTOR_ELT(SDValue Op, SelectionDAG &DAG) const;
|
||||
|
|
|
@ -384,7 +384,7 @@ SDValue SITargetLowering::LowerParameter(SelectionDAG &DAG, EVT VT, EVT MemVT,
|
|||
SDValue BasePtr = DAG.getCopyFromReg(Chain, SL,
|
||||
MRI.getLiveInVirtReg(InputPtrReg), MVT::i64);
|
||||
SDValue Ptr = DAG.getNode(ISD::ADD, SL, MVT::i64, BasePtr,
|
||||
DAG.getConstant(Offset, MVT::i64));
|
||||
DAG.getConstant(Offset, SL, MVT::i64));
|
||||
SDValue PtrOffset = DAG.getUNDEF(getPointerTy(AMDGPUAS::CONSTANT_ADDRESS));
|
||||
MachinePointerInfo PtrInfo(UndefValue::get(PtrTy));
|
||||
|
||||
|
@ -826,14 +826,14 @@ SDValue SITargetLowering::LowerGlobalAddress(AMDGPUMachineFunction *MFI,
|
|||
SDValue GA = DAG.getTargetGlobalAddress(GV, DL, MVT::i32);
|
||||
|
||||
SDValue PtrLo = DAG.getNode(ISD::EXTRACT_ELEMENT, DL, MVT::i32, Ptr,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
SDValue PtrHi = DAG.getNode(ISD::EXTRACT_ELEMENT, DL, MVT::i32, Ptr,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, DL, MVT::i32));
|
||||
|
||||
SDValue Lo = DAG.getNode(ISD::ADDC, DL, DAG.getVTList(MVT::i32, MVT::Glue),
|
||||
PtrLo, GA);
|
||||
SDValue Hi = DAG.getNode(ISD::ADDE, DL, DAG.getVTList(MVT::i32, MVT::Glue),
|
||||
PtrHi, DAG.getConstant(0, MVT::i32),
|
||||
PtrHi, DAG.getConstant(0, DL, MVT::i32),
|
||||
SDValue(Lo.getNode(), 1));
|
||||
return DAG.getNode(ISD::BUILD_PAIR, DL, MVT::i64, Lo, Hi);
|
||||
}
|
||||
|
@ -1018,8 +1018,8 @@ SDValue SITargetLowering::LowerSELECT(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDLoc DL(Op);
|
||||
SDValue Cond = Op.getOperand(0);
|
||||
|
||||
SDValue Zero = DAG.getConstant(0, MVT::i32);
|
||||
SDValue One = DAG.getConstant(1, MVT::i32);
|
||||
SDValue Zero = DAG.getConstant(0, DL, MVT::i32);
|
||||
SDValue One = DAG.getConstant(1, DL, MVT::i32);
|
||||
|
||||
SDValue LHS = DAG.getNode(ISD::BITCAST, DL, MVT::v2i32, Op.getOperand(1));
|
||||
SDValue RHS = DAG.getNode(ISD::BITCAST, DL, MVT::v2i32, Op.getOperand(2));
|
||||
|
@ -1094,12 +1094,12 @@ SDValue SITargetLowering::LowerFDIV32(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue r1 = DAG.getNode(ISD::FABS, SL, MVT::f32, RHS);
|
||||
|
||||
const APFloat K0Val(BitsToFloat(0x6f800000));
|
||||
const SDValue K0 = DAG.getConstantFP(K0Val, MVT::f32);
|
||||
const SDValue K0 = DAG.getConstantFP(K0Val, SL, MVT::f32);
|
||||
|
||||
const APFloat K1Val(BitsToFloat(0x2f800000));
|
||||
const SDValue K1 = DAG.getConstantFP(K1Val, MVT::f32);
|
||||
const SDValue K1 = DAG.getConstantFP(K1Val, SL, MVT::f32);
|
||||
|
||||
const SDValue One = DAG.getConstantFP(1.0, MVT::f32);
|
||||
const SDValue One = DAG.getConstantFP(1.0, SL, MVT::f32);
|
||||
|
||||
EVT SetCCVT = getSetCCResultType(*DAG.getContext(), MVT::f32);
|
||||
|
||||
|
@ -1124,7 +1124,7 @@ SDValue SITargetLowering::LowerFDIV64(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue X = Op.getOperand(0);
|
||||
SDValue Y = Op.getOperand(1);
|
||||
|
||||
const SDValue One = DAG.getConstantFP(1.0, MVT::f64);
|
||||
const SDValue One = DAG.getConstantFP(1.0, SL, MVT::f64);
|
||||
|
||||
SDVTList ScaleVT = DAG.getVTList(MVT::f64, MVT::i1);
|
||||
|
||||
|
@ -1154,7 +1154,7 @@ SDValue SITargetLowering::LowerFDIV64(SDValue Op, SelectionDAG &DAG) const {
|
|||
// Workaround a hardware bug on SI where the condition output from div_scale
|
||||
// is not usable.
|
||||
|
||||
const SDValue Hi = DAG.getConstant(1, MVT::i32);
|
||||
const SDValue Hi = DAG.getConstant(1, SL, MVT::i32);
|
||||
|
||||
// Figure out if the scale to use for div_fmas.
|
||||
SDValue NumBC = DAG.getNode(ISD::BITCAST, SL, MVT::v2i32, X);
|
||||
|
@ -1223,11 +1223,13 @@ SDValue SITargetLowering::LowerSTORE(SDValue Op, SelectionDAG &DAG) const {
|
|||
}
|
||||
|
||||
SDValue SITargetLowering::LowerTrig(SDValue Op, SelectionDAG &DAG) const {
|
||||
SDLoc DL(Op);
|
||||
EVT VT = Op.getValueType();
|
||||
SDValue Arg = Op.getOperand(0);
|
||||
SDValue FractPart = DAG.getNode(AMDGPUISD::FRACT, SDLoc(Op), VT,
|
||||
DAG.getNode(ISD::FMUL, SDLoc(Op), VT, Arg,
|
||||
DAG.getConstantFP(0.5 / M_PI, VT)));
|
||||
SDValue FractPart = DAG.getNode(AMDGPUISD::FRACT, DL, VT,
|
||||
DAG.getNode(ISD::FMUL, DL, VT, Arg,
|
||||
DAG.getConstantFP(0.5/M_PI, DL,
|
||||
VT)));
|
||||
|
||||
switch (Op.getOpcode()) {
|
||||
case ISD::FCOS:
|
||||
|
@ -1417,7 +1419,7 @@ SDValue SITargetLowering::performSHLPtrCombine(SDNode *N,
|
|||
EVT VT = N->getValueType(0);
|
||||
|
||||
SDValue ShlX = DAG.getNode(ISD::SHL, SL, VT, N0.getOperand(0), N1);
|
||||
SDValue COffset = DAG.getConstant(Offset, MVT::i32);
|
||||
SDValue COffset = DAG.getConstant(Offset, SL, MVT::i32);
|
||||
|
||||
return DAG.getNode(ISD::ADD, SL, VT, ShlX, COffset);
|
||||
}
|
||||
|
@ -1466,8 +1468,9 @@ SDValue SITargetLowering::performAndCombine(SDNode *N,
|
|||
SIInstrFlags::P_INFINITY)) & 0x3ff) == Mask,
|
||||
"mask not equal");
|
||||
|
||||
return DAG.getNode(AMDGPUISD::FP_CLASS, SDLoc(N), MVT::i1,
|
||||
X, DAG.getConstant(Mask, MVT::i32));
|
||||
SDLoc DL(N);
|
||||
return DAG.getNode(AMDGPUISD::FP_CLASS, DL, MVT::i1,
|
||||
X, DAG.getConstant(Mask, DL, MVT::i32));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1497,8 +1500,9 @@ SDValue SITargetLowering::performOrCombine(SDNode *N,
|
|||
static const uint32_t MaxMask = 0x3ff;
|
||||
|
||||
uint32_t NewMask = (CLHS->getZExtValue() | CRHS->getZExtValue()) & MaxMask;
|
||||
return DAG.getNode(AMDGPUISD::FP_CLASS, SDLoc(N), MVT::i1,
|
||||
Src, DAG.getConstant(NewMask, MVT::i32));
|
||||
SDLoc DL(N);
|
||||
return DAG.getNode(AMDGPUISD::FP_CLASS, DL, MVT::i1,
|
||||
Src, DAG.getConstant(NewMask, DL, MVT::i32));
|
||||
}
|
||||
|
||||
return SDValue();
|
||||
|
@ -1512,7 +1516,7 @@ SDValue SITargetLowering::performClassCombine(SDNode *N,
|
|||
// fp_class x, 0 -> false
|
||||
if (const ConstantSDNode *CMask = dyn_cast<ConstantSDNode>(Mask)) {
|
||||
if (CMask->isNullValue())
|
||||
return DAG.getConstant(0, MVT::i1);
|
||||
return DAG.getConstant(0, SDLoc(N), MVT::i1);
|
||||
}
|
||||
|
||||
return SDValue();
|
||||
|
@ -1596,8 +1600,8 @@ SDValue SITargetLowering::performSetCCCombine(SDNode *N,
|
|||
const APFloat &APF = CRHS->getValueAPF();
|
||||
if (APF.isInfinity() && !APF.isNegative()) {
|
||||
unsigned Mask = SIInstrFlags::P_INFINITY | SIInstrFlags::N_INFINITY;
|
||||
return DAG.getNode(AMDGPUISD::FP_CLASS, SL, MVT::i1,
|
||||
LHS.getOperand(0), DAG.getConstant(Mask, MVT::i32));
|
||||
return DAG.getNode(AMDGPUISD::FP_CLASS, SL, MVT::i1, LHS.getOperand(0),
|
||||
DAG.getConstant(Mask, SL, MVT::i32));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1674,7 +1678,7 @@ SDValue SITargetLowering::PerformDAGCombine(SDNode *N,
|
|||
if (LHS.getOpcode() == ISD::FADD) {
|
||||
SDValue A = LHS.getOperand(0);
|
||||
if (A == LHS.getOperand(1)) {
|
||||
const SDValue Two = DAG.getConstantFP(2.0, MVT::f32);
|
||||
const SDValue Two = DAG.getConstantFP(2.0, DL, MVT::f32);
|
||||
return DAG.getNode(ISD::FMAD, DL, VT, Two, A, RHS);
|
||||
}
|
||||
}
|
||||
|
@ -1683,7 +1687,7 @@ SDValue SITargetLowering::PerformDAGCombine(SDNode *N,
|
|||
if (RHS.getOpcode() == ISD::FADD) {
|
||||
SDValue A = RHS.getOperand(0);
|
||||
if (A == RHS.getOperand(1)) {
|
||||
const SDValue Two = DAG.getConstantFP(2.0, MVT::f32);
|
||||
const SDValue Two = DAG.getConstantFP(2.0, DL, MVT::f32);
|
||||
return DAG.getNode(ISD::FMAD, DL, VT, Two, A, LHS);
|
||||
}
|
||||
}
|
||||
|
@ -1710,7 +1714,7 @@ SDValue SITargetLowering::PerformDAGCombine(SDNode *N,
|
|||
|
||||
SDValue A = LHS.getOperand(0);
|
||||
if (A == LHS.getOperand(1)) {
|
||||
const SDValue Two = DAG.getConstantFP(2.0, MVT::f32);
|
||||
const SDValue Two = DAG.getConstantFP(2.0, DL, MVT::f32);
|
||||
SDValue NegRHS = DAG.getNode(ISD::FNEG, DL, VT, RHS);
|
||||
|
||||
return DAG.getNode(ISD::FMAD, DL, VT, Two, A, NegRHS);
|
||||
|
@ -1722,7 +1726,7 @@ SDValue SITargetLowering::PerformDAGCombine(SDNode *N,
|
|||
|
||||
SDValue A = RHS.getOperand(0);
|
||||
if (A == RHS.getOperand(1)) {
|
||||
const SDValue NegTwo = DAG.getConstantFP(-2.0, MVT::f32);
|
||||
const SDValue NegTwo = DAG.getConstantFP(-2.0, DL, MVT::f32);
|
||||
return DAG.getNode(ISD::FMAD, DL, VT, NegTwo, A, LHS);
|
||||
}
|
||||
}
|
||||
|
@ -1865,14 +1869,15 @@ void SITargetLowering::adjustWritemask(MachineSDNode *&Node,
|
|||
|
||||
// Adjust the writemask in the node
|
||||
std::vector<SDValue> Ops;
|
||||
Ops.push_back(DAG.getTargetConstant(NewDmask, MVT::i32));
|
||||
Ops.push_back(DAG.getTargetConstant(NewDmask, SDLoc(Node), MVT::i32));
|
||||
Ops.insert(Ops.end(), Node->op_begin() + 1, Node->op_end());
|
||||
Node = (MachineSDNode*)DAG.UpdateNodeOperands(Node, Ops);
|
||||
|
||||
// If we only got one lane, replace it with a copy
|
||||
// (if NewDmask has only one bit set...)
|
||||
if (NewDmask && (NewDmask & (NewDmask-1)) == 0) {
|
||||
SDValue RC = DAG.getTargetConstant(AMDGPU::VGPR_32RegClassID, MVT::i32);
|
||||
SDValue RC = DAG.getTargetConstant(AMDGPU::VGPR_32RegClassID, SDLoc(),
|
||||
MVT::i32);
|
||||
SDNode *Copy = DAG.getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
|
||||
SDLoc(), Users[Lane]->getValueType(0),
|
||||
SDValue(Node, 0), RC);
|
||||
|
@ -1887,7 +1892,7 @@ void SITargetLowering::adjustWritemask(MachineSDNode *&Node,
|
|||
if (!User)
|
||||
continue;
|
||||
|
||||
SDValue Op = DAG.getTargetConstant(Idx, MVT::i32);
|
||||
SDValue Op = DAG.getTargetConstant(Idx, SDLoc(User), MVT::i32);
|
||||
DAG.UpdateNodeOperands(User, User->getOperand(0), Op);
|
||||
|
||||
switch (Idx) {
|
||||
|
@ -1982,7 +1987,7 @@ void SITargetLowering::AdjustInstrPostInstrSelection(MachineInstr *MI,
|
|||
}
|
||||
|
||||
static SDValue buildSMovImm32(SelectionDAG &DAG, SDLoc DL, uint64_t Val) {
|
||||
SDValue K = DAG.getTargetConstant(Val, MVT::i32);
|
||||
SDValue K = DAG.getTargetConstant(Val, DL, MVT::i32);
|
||||
return SDValue(DAG.getMachineNode(AMDGPU::S_MOV_B32, DL, MVT::i32, K), 0);
|
||||
}
|
||||
|
||||
|
@ -1997,11 +2002,11 @@ MachineSDNode *SITargetLowering::wrapAddr64Rsrc(SelectionDAG &DAG,
|
|||
|
||||
// Build the half of the subregister with the constants.
|
||||
const SDValue Ops0[] = {
|
||||
DAG.getTargetConstant(AMDGPU::SGPR_64RegClassID, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::SGPR_64RegClassID, DL, MVT::i32),
|
||||
buildSMovImm32(DAG, DL, 0),
|
||||
DAG.getTargetConstant(AMDGPU::sub0, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::sub0, DL, MVT::i32),
|
||||
buildSMovImm32(DAG, DL, TII->getDefaultRsrcDataFormat() >> 32),
|
||||
DAG.getTargetConstant(AMDGPU::sub1, MVT::i32)
|
||||
DAG.getTargetConstant(AMDGPU::sub1, DL, MVT::i32)
|
||||
};
|
||||
|
||||
SDValue SubRegHi = SDValue(DAG.getMachineNode(AMDGPU::REG_SEQUENCE, DL,
|
||||
|
@ -2009,11 +2014,11 @@ MachineSDNode *SITargetLowering::wrapAddr64Rsrc(SelectionDAG &DAG,
|
|||
|
||||
// Combine the constants and the pointer.
|
||||
const SDValue Ops1[] = {
|
||||
DAG.getTargetConstant(AMDGPU::SReg_128RegClassID, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::SReg_128RegClassID, DL, MVT::i32),
|
||||
Ptr,
|
||||
DAG.getTargetConstant(AMDGPU::sub0_sub1, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::sub0_sub1, DL, MVT::i32),
|
||||
SubRegHi,
|
||||
DAG.getTargetConstant(AMDGPU::sub2_sub3, MVT::i32)
|
||||
DAG.getTargetConstant(AMDGPU::sub2_sub3, DL, MVT::i32)
|
||||
};
|
||||
|
||||
return DAG.getMachineNode(AMDGPU::REG_SEQUENCE, DL, MVT::v4i32, Ops1);
|
||||
|
@ -2046,7 +2051,8 @@ MachineSDNode *SITargetLowering::buildRSRC(SelectionDAG &DAG,
|
|||
SDValue PtrHi = DAG.getTargetExtractSubreg(AMDGPU::sub1, DL, MVT::i32, Ptr);
|
||||
if (RsrcDword1) {
|
||||
PtrHi = SDValue(DAG.getMachineNode(AMDGPU::S_OR_B32, DL, MVT::i32, PtrHi,
|
||||
DAG.getConstant(RsrcDword1, MVT::i32)), 0);
|
||||
DAG.getConstant(RsrcDword1, DL, MVT::i32)),
|
||||
0);
|
||||
}
|
||||
|
||||
SDValue DataLo = buildSMovImm32(DAG, DL,
|
||||
|
@ -2054,15 +2060,15 @@ MachineSDNode *SITargetLowering::buildRSRC(SelectionDAG &DAG,
|
|||
SDValue DataHi = buildSMovImm32(DAG, DL, RsrcDword2And3 >> 32);
|
||||
|
||||
const SDValue Ops[] = {
|
||||
DAG.getTargetConstant(AMDGPU::SReg_128RegClassID, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::SReg_128RegClassID, DL, MVT::i32),
|
||||
PtrLo,
|
||||
DAG.getTargetConstant(AMDGPU::sub0, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::sub0, DL, MVT::i32),
|
||||
PtrHi,
|
||||
DAG.getTargetConstant(AMDGPU::sub1, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::sub1, DL, MVT::i32),
|
||||
DataLo,
|
||||
DAG.getTargetConstant(AMDGPU::sub2, MVT::i32),
|
||||
DAG.getTargetConstant(AMDGPU::sub2, DL, MVT::i32),
|
||||
DataHi,
|
||||
DAG.getTargetConstant(AMDGPU::sub3, MVT::i32)
|
||||
DAG.getTargetConstant(AMDGPU::sub3, DL, MVT::i32)
|
||||
};
|
||||
|
||||
return DAG.getMachineNode(AMDGPU::REG_SEQUENCE, DL, MVT::v4i32, Ops);
|
||||
|
|
|
@ -126,7 +126,8 @@ def SIconstdata_ptr : SDNode<
|
|||
|
||||
// Transformation function, extract the lower 32bit of a 64bit immediate
|
||||
def LO32 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 0xffffffff, MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() & 0xffffffff, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
def LO32f : SDNodeXForm<fpimm, [{
|
||||
|
@ -136,12 +137,13 @@ def LO32f : SDNodeXForm<fpimm, [{
|
|||
|
||||
// Transformation function, extract the upper 32bit of a 64bit immediate
|
||||
def HI32 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() >> 32, MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() >> 32, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def HI32f : SDNodeXForm<fpimm, [{
|
||||
APInt V = N->getValueAPF().bitcastToAPInt().lshr(32).trunc(32);
|
||||
return CurDAG->getTargetConstantFP(APFloat(APFloat::IEEEsingle, V), MVT::f32);
|
||||
return CurDAG->getTargetConstantFP(APFloat(APFloat::IEEEsingle, V), SDLoc(N),
|
||||
MVT::f32);
|
||||
}]>;
|
||||
|
||||
def IMM8bitDWORD : PatLeaf <(imm),
|
||||
|
@ -149,39 +151,39 @@ def IMM8bitDWORD : PatLeaf <(imm),
|
|||
>;
|
||||
|
||||
def as_dword_i32imm : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() >> 2, MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue() >> 2, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def as_i1imm : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue(), MVT::i1);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue(), SDLoc(N), MVT::i1);
|
||||
}]>;
|
||||
|
||||
def as_i8imm : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getZExtValue(), MVT::i8);
|
||||
return CurDAG->getTargetConstant(N->getZExtValue(), SDLoc(N), MVT::i8);
|
||||
}]>;
|
||||
|
||||
def as_i16imm : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), MVT::i16);
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), SDLoc(N), MVT::i16);
|
||||
}]>;
|
||||
|
||||
def as_i32imm: SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
def as_i64imm: SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), MVT::i64);
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Copied from the AArch64 backend:
|
||||
def bitcast_fpimm_to_i32 : SDNodeXForm<fpimm, [{
|
||||
return CurDAG->getTargetConstant(
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), MVT::i32);
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
|
||||
// Copied from the AArch64 backend:
|
||||
def bitcast_fpimm_to_i64 : SDNodeXForm<fpimm, [{
|
||||
return CurDAG->getTargetConstant(
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), MVT::i64);
|
||||
N->getValueAPF().bitcastToAPInt().getZExtValue(), SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
def IMM8bit : PatLeaf <(imm),
|
||||
|
|
|
@ -74,7 +74,7 @@ bool SparcDAGToDAGISel::SelectADDRri(SDValue Addr,
|
|||
SDValue &Base, SDValue &Offset) {
|
||||
if (FrameIndexSDNode *FIN = dyn_cast<FrameIndexSDNode>(Addr)) {
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), TLI->getPointerTy());
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
if (Addr.getOpcode() == ISD::TargetExternalSymbol ||
|
||||
|
@ -93,7 +93,8 @@ bool SparcDAGToDAGISel::SelectADDRri(SDValue Addr,
|
|||
} else {
|
||||
Base = Addr.getOperand(0);
|
||||
}
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(CN->getZExtValue(), SDLoc(Addr),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -109,7 +110,7 @@ bool SparcDAGToDAGISel::SelectADDRri(SDValue Addr,
|
|||
}
|
||||
}
|
||||
Base = Addr;
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -162,7 +163,8 @@ SDNode *SparcDAGToDAGISel::Select(SDNode *N) {
|
|||
SDValue TopPart;
|
||||
if (N->getOpcode() == ISD::SDIV) {
|
||||
TopPart = SDValue(CurDAG->getMachineNode(SP::SRAri, dl, MVT::i32, DivLHS,
|
||||
CurDAG->getTargetConstant(31, MVT::i32)), 0);
|
||||
CurDAG->getTargetConstant(31, dl, MVT::i32)),
|
||||
0);
|
||||
} else {
|
||||
TopPart = CurDAG->getRegister(SP::G0, MVT::i32);
|
||||
}
|
||||
|
|
|
@ -229,7 +229,7 @@ SparcTargetLowering::LowerReturn_32(SDValue Chain,
|
|||
}
|
||||
|
||||
RetOps[0] = Chain; // Update chain.
|
||||
RetOps[1] = DAG.getConstant(RetAddrOffset, MVT::i32);
|
||||
RetOps[1] = DAG.getConstant(RetAddrOffset, DL, MVT::i32);
|
||||
|
||||
// Add the flag if we have it.
|
||||
if (Flag.getNode())
|
||||
|
@ -261,7 +261,7 @@ SparcTargetLowering::LowerReturn_64(SDValue Chain,
|
|||
|
||||
// The second operand on the return instruction is the return address offset.
|
||||
// The return address is always %i7+8 with the 64-bit ABI.
|
||||
RetOps.push_back(DAG.getConstant(8, MVT::i32));
|
||||
RetOps.push_back(DAG.getConstant(8, DL, MVT::i32));
|
||||
|
||||
// Copy the result values into the output registers.
|
||||
for (unsigned i = 0; i != RVLocs.size(); ++i) {
|
||||
|
@ -289,7 +289,7 @@ SparcTargetLowering::LowerReturn_64(SDValue Chain,
|
|||
// in the high bits of the register.
|
||||
if (VA.getValVT() == MVT::i32 && VA.needsCustom()) {
|
||||
OutVal = DAG.getNode(ISD::SHL, DL, MVT::i64, OutVal,
|
||||
DAG.getConstant(32, MVT::i32));
|
||||
DAG.getConstant(32, DL, MVT::i32));
|
||||
|
||||
// The next value may go in the low bits of the same register.
|
||||
// Handle both at once.
|
||||
|
@ -471,7 +471,7 @@ LowerFormalArguments_32(SDValue Chain,
|
|||
// Sparc is big endian, so add an offset based on the ObjectVT.
|
||||
unsigned Offset = 4-std::max(1U, VA.getValVT().getSizeInBits()/8);
|
||||
FIPtr = DAG.getNode(ISD::ADD, dl, MVT::i32, FIPtr,
|
||||
DAG.getConstant(Offset, MVT::i32));
|
||||
DAG.getConstant(Offset, dl, MVT::i32));
|
||||
Load = DAG.getExtLoad(LoadOp, dl, MVT::i32, Chain, FIPtr,
|
||||
MachinePointerInfo(),
|
||||
VA.getValVT(), false, false, false,0);
|
||||
|
@ -570,7 +570,7 @@ LowerFormalArguments_64(SDValue Chain,
|
|||
// Get the high bits for i32 struct elements.
|
||||
if (VA.getValVT() == MVT::i32 && VA.needsCustom())
|
||||
Arg = DAG.getNode(ISD::SRL, DL, VA.getLocVT(), Arg,
|
||||
DAG.getConstant(32, MVT::i32));
|
||||
DAG.getConstant(32, DL, MVT::i32));
|
||||
|
||||
// The caller promoted the argument, so insert an Assert?ext SDNode so we
|
||||
// won't promote the value again in this function.
|
||||
|
@ -723,7 +723,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
|
||||
int FI = MFI->CreateStackObject(Size, Align, false);
|
||||
SDValue FIPtr = DAG.getFrameIndex(FI, getPointerTy());
|
||||
SDValue SizeNode = DAG.getConstant(Size, MVT::i32);
|
||||
SDValue SizeNode = DAG.getConstant(Size, dl, MVT::i32);
|
||||
|
||||
Chain = DAG.getMemcpy(Chain, dl, FIPtr, Arg, SizeNode, Align,
|
||||
false, // isVolatile,
|
||||
|
@ -733,7 +733,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
ByValArgs.push_back(FIPtr);
|
||||
}
|
||||
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(ArgsSize, true),
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(ArgsSize, dl, true),
|
||||
dl);
|
||||
|
||||
SmallVector<std::pair<unsigned, SDValue>, 8> RegsToPass;
|
||||
|
@ -776,7 +776,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
assert(VA.needsCustom());
|
||||
// store SRet argument in %sp+64
|
||||
SDValue StackPtr = DAG.getRegister(SP::O6, MVT::i32);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(64);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(64, dl);
|
||||
PtrOff = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, dl, Arg, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
|
@ -793,7 +793,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
// if it is double-word aligned, just store.
|
||||
if (Offset % 8 == 0) {
|
||||
SDValue StackPtr = DAG.getRegister(SP::O6, MVT::i32);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(Offset);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(Offset, dl);
|
||||
PtrOff = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, dl, Arg, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
|
@ -811,7 +811,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
MachinePointerInfo(), false, false, false, 0);
|
||||
// Increment the pointer to the other half.
|
||||
StackPtr = DAG.getNode(ISD::ADD, dl, StackPtr.getValueType(), StackPtr,
|
||||
DAG.getIntPtrConstant(4));
|
||||
DAG.getIntPtrConstant(4, dl));
|
||||
// Load the low part.
|
||||
SDValue Lo = DAG.getLoad(MVT::i32, dl, Store, StackPtr,
|
||||
MachinePointerInfo(), false, false, false, 0);
|
||||
|
@ -826,7 +826,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
// Store the low part in stack.
|
||||
unsigned Offset = NextVA.getLocMemOffset() + StackOffset;
|
||||
SDValue StackPtr = DAG.getRegister(SP::O6, MVT::i32);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(Offset);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(Offset, dl);
|
||||
PtrOff = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, dl, Lo, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
|
@ -836,13 +836,13 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
unsigned Offset = VA.getLocMemOffset() + StackOffset;
|
||||
// Store the high part.
|
||||
SDValue StackPtr = DAG.getRegister(SP::O6, MVT::i32);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(Offset);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(Offset, dl);
|
||||
PtrOff = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, dl, Hi, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
false, false, 0));
|
||||
// Store the low part.
|
||||
PtrOff = DAG.getIntPtrConstant(Offset+4);
|
||||
PtrOff = DAG.getIntPtrConstant(Offset + 4, dl);
|
||||
PtrOff = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, dl, Lo, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
|
@ -867,7 +867,8 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
|
||||
// Create a store off the stack pointer for this argument.
|
||||
SDValue StackPtr = DAG.getRegister(SP::O6, MVT::i32);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(VA.getLocMemOffset()+StackOffset);
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(VA.getLocMemOffset() + StackOffset,
|
||||
dl);
|
||||
PtrOff = DAG.getNode(ISD::ADD, dl, MVT::i32, StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, dl, Arg, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
|
@ -909,7 +910,7 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
Ops.push_back(Chain);
|
||||
Ops.push_back(Callee);
|
||||
if (hasStructRetAttr)
|
||||
Ops.push_back(DAG.getTargetConstant(SRetArgSize, MVT::i32));
|
||||
Ops.push_back(DAG.getTargetConstant(SRetArgSize, dl, MVT::i32));
|
||||
for (unsigned i = 0, e = RegsToPass.size(); i != e; ++i)
|
||||
Ops.push_back(DAG.getRegister(toCallerWindow(RegsToPass[i].first),
|
||||
RegsToPass[i].second.getValueType()));
|
||||
|
@ -929,8 +930,8 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
|||
Chain = DAG.getNode(SPISD::CALL, dl, NodeTys, Ops);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(ArgsSize, true),
|
||||
DAG.getIntPtrConstant(0, true), InFlag, dl);
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(ArgsSize, dl, true),
|
||||
DAG.getIntPtrConstant(0, dl, true), InFlag, dl);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
// Assign locations to each value returned by this call.
|
||||
|
@ -1082,7 +1083,7 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
|||
// Adjust the stack pointer to make room for the arguments.
|
||||
// FIXME: Use hasReservedCallFrame to avoid %sp adjustments around all calls
|
||||
// with more than 6 arguments.
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(ArgsSize, true),
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(ArgsSize, DL, true),
|
||||
DL);
|
||||
|
||||
// Collect the set of registers to pass to the function and their values.
|
||||
|
@ -1130,10 +1131,10 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
|||
unsigned Offset = 8 * (VA.getLocReg() - SP::I0);
|
||||
unsigned StackOffset = Offset + Subtarget->getStackPointerBias() + 128;
|
||||
SDValue StackPtr = DAG.getRegister(SP::O6, getPointerTy());
|
||||
SDValue HiPtrOff = DAG.getIntPtrConstant(StackOffset);
|
||||
SDValue HiPtrOff = DAG.getIntPtrConstant(StackOffset, DL);
|
||||
HiPtrOff = DAG.getNode(ISD::ADD, DL, getPointerTy(), StackPtr,
|
||||
HiPtrOff);
|
||||
SDValue LoPtrOff = DAG.getIntPtrConstant(StackOffset + 8);
|
||||
SDValue LoPtrOff = DAG.getIntPtrConstant(StackOffset + 8, DL);
|
||||
LoPtrOff = DAG.getNode(ISD::ADD, DL, getPointerTy(), StackPtr,
|
||||
LoPtrOff);
|
||||
|
||||
|
@ -1159,7 +1160,7 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
|||
// passed in the high bits of the register.
|
||||
if (VA.getValVT() == MVT::i32 && VA.needsCustom()) {
|
||||
Arg = DAG.getNode(ISD::SHL, DL, MVT::i64, Arg,
|
||||
DAG.getConstant(32, MVT::i32));
|
||||
DAG.getConstant(32, DL, MVT::i32));
|
||||
|
||||
// The next value may go in the low bits of the same register.
|
||||
// Handle both at once.
|
||||
|
@ -1184,7 +1185,7 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
|||
// %sp+BIAS+128 in ours.
|
||||
SDValue PtrOff = DAG.getIntPtrConstant(VA.getLocMemOffset() +
|
||||
Subtarget->getStackPointerBias() +
|
||||
128);
|
||||
128, DL);
|
||||
PtrOff = DAG.getNode(ISD::ADD, DL, getPointerTy(), StackPtr, PtrOff);
|
||||
MemOpChains.push_back(DAG.getStore(Chain, DL, Arg, PtrOff,
|
||||
MachinePointerInfo(),
|
||||
|
@ -1247,8 +1248,8 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
|||
InGlue = Chain.getValue(1);
|
||||
|
||||
// Revert the stack pointer immediately after the call.
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(ArgsSize, true),
|
||||
DAG.getIntPtrConstant(0, true), InGlue, DL);
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(ArgsSize, DL, true),
|
||||
DAG.getIntPtrConstant(0, DL, true), InGlue, DL);
|
||||
InGlue = Chain.getValue(1);
|
||||
|
||||
// Now extract the return values. This is more or less the same as
|
||||
|
@ -1289,7 +1290,7 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
|||
// Get the high bits for i32 struct elements.
|
||||
if (VA.getValVT() == MVT::i32 && VA.needsCustom())
|
||||
RV = DAG.getNode(ISD::SRL, DL, VA.getLocVT(), RV,
|
||||
DAG.getConstant(32, MVT::i32));
|
||||
DAG.getConstant(32, DL, MVT::i32));
|
||||
|
||||
// The callee promoted the return value, so insert an Assert?ext SDNode so
|
||||
// we won't promote the value again in this function.
|
||||
|
@ -1831,7 +1832,7 @@ SDValue SparcTargetLowering::makeAddress(SDValue Op, SelectionDAG &DAG) const {
|
|||
// abs44.
|
||||
SDValue H44 = makeHiLoPair(Op, SparcMCExpr::VK_Sparc_H44,
|
||||
SparcMCExpr::VK_Sparc_M44, DAG);
|
||||
H44 = DAG.getNode(ISD::SHL, DL, VT, H44, DAG.getConstant(12, MVT::i32));
|
||||
H44 = DAG.getNode(ISD::SHL, DL, VT, H44, DAG.getConstant(12, DL, MVT::i32));
|
||||
SDValue L44 = withTargetFlags(Op, SparcMCExpr::VK_Sparc_L44, DAG);
|
||||
L44 = DAG.getNode(SPISD::Lo, DL, VT, L44);
|
||||
return DAG.getNode(ISD::ADD, DL, VT, H44, L44);
|
||||
|
@ -1840,7 +1841,7 @@ SDValue SparcTargetLowering::makeAddress(SDValue Op, SelectionDAG &DAG) const {
|
|||
// abs64.
|
||||
SDValue Hi = makeHiLoPair(Op, SparcMCExpr::VK_Sparc_HH,
|
||||
SparcMCExpr::VK_Sparc_HM, DAG);
|
||||
Hi = DAG.getNode(ISD::SHL, DL, VT, Hi, DAG.getConstant(32, MVT::i32));
|
||||
Hi = DAG.getNode(ISD::SHL, DL, VT, Hi, DAG.getConstant(32, DL, MVT::i32));
|
||||
SDValue Lo = makeHiLoPair(Op, SparcMCExpr::VK_Sparc_HI,
|
||||
SparcMCExpr::VK_Sparc_LO, DAG);
|
||||
return DAG.getNode(ISD::ADD, DL, VT, Hi, Lo);
|
||||
|
@ -1895,7 +1896,7 @@ SDValue SparcTargetLowering::LowerGlobalTLSAddress(SDValue Op,
|
|||
SDValue Chain = DAG.getEntryNode();
|
||||
SDValue InFlag;
|
||||
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(1, true), DL);
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getIntPtrConstant(1, DL, true), DL);
|
||||
Chain = DAG.getCopyToReg(Chain, DL, SP::O0, Argument, InFlag);
|
||||
InFlag = Chain.getValue(1);
|
||||
SDValue Callee = DAG.getTargetExternalSymbol("__tls_get_addr", PtrVT);
|
||||
|
@ -1914,8 +1915,8 @@ SDValue SparcTargetLowering::LowerGlobalTLSAddress(SDValue Op,
|
|||
Ops.push_back(InFlag);
|
||||
Chain = DAG.getNode(SPISD::TLS_CALL, DL, NodeTys, Ops);
|
||||
InFlag = Chain.getValue(1);
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(1, true),
|
||||
DAG.getIntPtrConstant(0, true), InFlag, DL);
|
||||
Chain = DAG.getCALLSEQ_END(Chain, DAG.getIntPtrConstant(1, DL, true),
|
||||
DAG.getIntPtrConstant(0, DL, true), InFlag, DL);
|
||||
InFlag = Chain.getValue(1);
|
||||
SDValue Ret = DAG.getCopyFromReg(Chain, DL, SP::O0, PtrVT, InFlag);
|
||||
|
||||
|
@ -2098,54 +2099,54 @@ SparcTargetLowering::LowerF128Compare(SDValue LHS, SDValue RHS,
|
|||
|
||||
switch(SPCC) {
|
||||
default: {
|
||||
SDValue RHS = DAG.getTargetConstant(0, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(0, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_NE;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_UL : {
|
||||
SDValue Mask = DAG.getTargetConstant(1, Result.getValueType());
|
||||
SDValue Mask = DAG.getTargetConstant(1, DL, Result.getValueType());
|
||||
Result = DAG.getNode(ISD::AND, DL, Result.getValueType(), Result, Mask);
|
||||
SDValue RHS = DAG.getTargetConstant(0, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(0, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_NE;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_ULE: {
|
||||
SDValue RHS = DAG.getTargetConstant(2, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(2, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_NE;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_UG : {
|
||||
SDValue RHS = DAG.getTargetConstant(1, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(1, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_G;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_UGE: {
|
||||
SDValue RHS = DAG.getTargetConstant(1, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(1, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_NE;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
|
||||
case SPCC::FCC_U : {
|
||||
SDValue RHS = DAG.getTargetConstant(3, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(3, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_E;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_O : {
|
||||
SDValue RHS = DAG.getTargetConstant(3, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(3, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_NE;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_LG : {
|
||||
SDValue Mask = DAG.getTargetConstant(3, Result.getValueType());
|
||||
SDValue Mask = DAG.getTargetConstant(3, DL, Result.getValueType());
|
||||
Result = DAG.getNode(ISD::AND, DL, Result.getValueType(), Result, Mask);
|
||||
SDValue RHS = DAG.getTargetConstant(0, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(0, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_NE;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
case SPCC::FCC_UE : {
|
||||
SDValue Mask = DAG.getTargetConstant(3, Result.getValueType());
|
||||
SDValue Mask = DAG.getTargetConstant(3, DL, Result.getValueType());
|
||||
Result = DAG.getNode(ISD::AND, DL, Result.getValueType(), Result, Mask);
|
||||
SDValue RHS = DAG.getTargetConstant(0, Result.getValueType());
|
||||
SDValue RHS = DAG.getTargetConstant(0, DL, Result.getValueType());
|
||||
SPCC = SPCC::ICC_E;
|
||||
return DAG.getNode(SPISD::CMPICC, DL, MVT::Glue, Result, RHS);
|
||||
}
|
||||
|
@ -2317,7 +2318,7 @@ static SDValue LowerBR_CC(SDValue Op, SelectionDAG &DAG,
|
|||
}
|
||||
}
|
||||
return DAG.getNode(Opc, dl, MVT::Other, Chain, Dest,
|
||||
DAG.getConstant(SPCC, MVT::i32), CompareFlag);
|
||||
DAG.getConstant(SPCC, dl, MVT::i32), CompareFlag);
|
||||
}
|
||||
|
||||
static SDValue LowerSELECT_CC(SDValue Op, SelectionDAG &DAG,
|
||||
|
@ -2353,7 +2354,7 @@ static SDValue LowerSELECT_CC(SDValue Op, SelectionDAG &DAG,
|
|||
}
|
||||
}
|
||||
return DAG.getNode(Opc, dl, TrueVal.getValueType(), TrueVal, FalseVal,
|
||||
DAG.getConstant(SPCC, MVT::i32), CompareFlag);
|
||||
DAG.getConstant(SPCC, dl, MVT::i32), CompareFlag);
|
||||
}
|
||||
|
||||
static SDValue LowerVASTART(SDValue Op, SelectionDAG &DAG,
|
||||
|
@ -2370,7 +2371,7 @@ static SDValue LowerVASTART(SDValue Op, SelectionDAG &DAG,
|
|||
SDValue Offset =
|
||||
DAG.getNode(ISD::ADD, DL, TLI.getPointerTy(),
|
||||
DAG.getRegister(SP::I6, TLI.getPointerTy()),
|
||||
DAG.getIntPtrConstant(FuncInfo->getVarArgsFrameOffset()));
|
||||
DAG.getIntPtrConstant(FuncInfo->getVarArgsFrameOffset(), DL));
|
||||
const Value *SV = cast<SrcValueSDNode>(Op.getOperand(2))->getValue();
|
||||
return DAG.getStore(Op.getOperand(0), DL, Offset, Op.getOperand(1),
|
||||
MachinePointerInfo(SV), false, false, 0);
|
||||
|
@ -2388,7 +2389,8 @@ static SDValue LowerVAARG(SDValue Op, SelectionDAG &DAG) {
|
|||
MachinePointerInfo(SV), false, false, false, 0);
|
||||
// Increment the pointer, VAList, to the next vaarg.
|
||||
SDValue NextPtr = DAG.getNode(ISD::ADD, DL, PtrVT, VAList,
|
||||
DAG.getIntPtrConstant(VT.getSizeInBits()/8));
|
||||
DAG.getIntPtrConstant(VT.getSizeInBits()/8,
|
||||
DL));
|
||||
// Store the incremented VAList to the legalized pointer.
|
||||
InChain = DAG.getStore(VAList.getValue(1), DL, NextPtr,
|
||||
VAListPtr, MachinePointerInfo(SV), false, false, 0);
|
||||
|
@ -2417,7 +2419,7 @@ static SDValue LowerDYNAMIC_STACKALLOC(SDValue Op, SelectionDAG &DAG,
|
|||
regSpillArea += Subtarget->getStackPointerBias();
|
||||
|
||||
SDValue NewVal = DAG.getNode(ISD::ADD, dl, VT, NewSP,
|
||||
DAG.getConstant(regSpillArea, VT));
|
||||
DAG.getConstant(regSpillArea, dl, VT));
|
||||
SDValue Ops[2] = { NewVal, Chain };
|
||||
return DAG.getMergeValues(Ops, dl);
|
||||
}
|
||||
|
@ -2446,7 +2448,7 @@ static SDValue getFRAMEADDR(uint64_t depth, SDValue Op, SelectionDAG &DAG,
|
|||
FrameAddr = DAG.getCopyFromReg(DAG.getEntryNode(), dl, FrameReg, VT);
|
||||
if (Subtarget->is64Bit())
|
||||
FrameAddr = DAG.getNode(ISD::ADD, dl, VT, FrameAddr,
|
||||
DAG.getIntPtrConstant(stackBias));
|
||||
DAG.getIntPtrConstant(stackBias, dl));
|
||||
return FrameAddr;
|
||||
}
|
||||
|
||||
|
@ -2458,13 +2460,13 @@ static SDValue getFRAMEADDR(uint64_t depth, SDValue Op, SelectionDAG &DAG,
|
|||
|
||||
while (depth--) {
|
||||
SDValue Ptr = DAG.getNode(ISD::ADD, dl, VT, FrameAddr,
|
||||
DAG.getIntPtrConstant(Offset));
|
||||
DAG.getIntPtrConstant(Offset, dl));
|
||||
FrameAddr = DAG.getLoad(VT, dl, Chain, Ptr, MachinePointerInfo(),
|
||||
false, false, false, 0);
|
||||
}
|
||||
if (Subtarget->is64Bit())
|
||||
FrameAddr = DAG.getNode(ISD::ADD, dl, VT, FrameAddr,
|
||||
DAG.getIntPtrConstant(stackBias));
|
||||
DAG.getIntPtrConstant(stackBias, dl));
|
||||
return FrameAddr;
|
||||
}
|
||||
|
||||
|
@ -2507,7 +2509,7 @@ static SDValue LowerRETURNADDR(SDValue Op, SelectionDAG &DAG,
|
|||
SDValue Ptr = DAG.getNode(ISD::ADD,
|
||||
dl, VT,
|
||||
FrameAddr,
|
||||
DAG.getIntPtrConstant(Offset));
|
||||
DAG.getIntPtrConstant(Offset, dl));
|
||||
RetAddr = DAG.getLoad(VT, dl, DAG.getEntryNode(), Ptr,
|
||||
MachinePointerInfo(), false, false, false, 0);
|
||||
|
||||
|
@ -2563,7 +2565,7 @@ static SDValue LowerF128Load(SDValue Op, SelectionDAG &DAG)
|
|||
EVT addrVT = LdNode->getBasePtr().getValueType();
|
||||
SDValue LoPtr = DAG.getNode(ISD::ADD, dl, addrVT,
|
||||
LdNode->getBasePtr(),
|
||||
DAG.getConstant(8, addrVT));
|
||||
DAG.getConstant(8, dl, addrVT));
|
||||
SDValue Lo64 = DAG.getLoad(MVT::f64,
|
||||
dl,
|
||||
LdNode->getChain(),
|
||||
|
@ -2571,8 +2573,8 @@ static SDValue LowerF128Load(SDValue Op, SelectionDAG &DAG)
|
|||
LdNode->getPointerInfo(),
|
||||
false, false, false, alignment);
|
||||
|
||||
SDValue SubRegEven = DAG.getTargetConstant(SP::sub_even64, MVT::i32);
|
||||
SDValue SubRegOdd = DAG.getTargetConstant(SP::sub_odd64, MVT::i32);
|
||||
SDValue SubRegEven = DAG.getTargetConstant(SP::sub_even64, dl, MVT::i32);
|
||||
SDValue SubRegOdd = DAG.getTargetConstant(SP::sub_odd64, dl, MVT::i32);
|
||||
|
||||
SDNode *InFP128 = DAG.getMachineNode(TargetOpcode::IMPLICIT_DEF,
|
||||
dl, MVT::f128);
|
||||
|
@ -2599,8 +2601,8 @@ static SDValue LowerF128Store(SDValue Op, SelectionDAG &DAG) {
|
|||
StoreSDNode *StNode = dyn_cast<StoreSDNode>(Op.getNode());
|
||||
assert(StNode && StNode->getOffset().getOpcode() == ISD::UNDEF
|
||||
&& "Unexpected node type");
|
||||
SDValue SubRegEven = DAG.getTargetConstant(SP::sub_even64, MVT::i32);
|
||||
SDValue SubRegOdd = DAG.getTargetConstant(SP::sub_odd64, MVT::i32);
|
||||
SDValue SubRegEven = DAG.getTargetConstant(SP::sub_even64, dl, MVT::i32);
|
||||
SDValue SubRegOdd = DAG.getTargetConstant(SP::sub_odd64, dl, MVT::i32);
|
||||
|
||||
SDNode *Hi64 = DAG.getMachineNode(TargetOpcode::EXTRACT_SUBREG,
|
||||
dl,
|
||||
|
@ -2627,7 +2629,7 @@ static SDValue LowerF128Store(SDValue Op, SelectionDAG &DAG) {
|
|||
EVT addrVT = StNode->getBasePtr().getValueType();
|
||||
SDValue LoPtr = DAG.getNode(ISD::ADD, dl, addrVT,
|
||||
StNode->getBasePtr(),
|
||||
DAG.getConstant(8, addrVT));
|
||||
DAG.getConstant(8, dl, addrVT));
|
||||
OutChains[1] = DAG.getStore(StNode->getChain(),
|
||||
dl,
|
||||
SDValue(Lo64, 0),
|
||||
|
@ -2678,13 +2680,13 @@ static SDValue LowerADDC_ADDE_SUBC_SUBE(SDValue Op, SelectionDAG &DAG) {
|
|||
SDValue Src1 = Op.getOperand(0);
|
||||
SDValue Src1Lo = DAG.getNode(ISD::TRUNCATE, dl, MVT::i32, Src1);
|
||||
SDValue Src1Hi = DAG.getNode(ISD::SRL, dl, MVT::i64, Src1,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
Src1Hi = DAG.getNode(ISD::TRUNCATE, dl, MVT::i32, Src1Hi);
|
||||
|
||||
SDValue Src2 = Op.getOperand(1);
|
||||
SDValue Src2Lo = DAG.getNode(ISD::TRUNCATE, dl, MVT::i32, Src2);
|
||||
SDValue Src2Hi = DAG.getNode(ISD::SRL, dl, MVT::i64, Src2,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
Src2Hi = DAG.getNode(ISD::TRUNCATE, dl, MVT::i32, Src2Hi);
|
||||
|
||||
|
||||
|
@ -2711,7 +2713,7 @@ static SDValue LowerADDC_ADDE_SUBC_SUBE(SDValue Op, SelectionDAG &DAG) {
|
|||
Lo = DAG.getNode(ISD::ZERO_EXTEND, dl, MVT::i64, Lo);
|
||||
Hi = DAG.getNode(ISD::ZERO_EXTEND, dl, MVT::i64, Hi);
|
||||
Hi = DAG.getNode(ISD::SHL, dl, MVT::i64, Hi,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, dl, MVT::i64));
|
||||
|
||||
SDValue Dst = DAG.getNode(ISD::OR, dl, MVT::i64, Hi, Lo);
|
||||
SDValue Ops[2] = { Dst, Carry };
|
||||
|
@ -2735,7 +2737,7 @@ static SDValue LowerUMULO_SMULO(SDValue Op, SelectionDAG &DAG,
|
|||
if (LHS.getValueType() != VT)
|
||||
return Op;
|
||||
|
||||
SDValue ShiftAmt = DAG.getConstant(63, VT);
|
||||
SDValue ShiftAmt = DAG.getConstant(63, dl, VT);
|
||||
|
||||
SDValue RHS = Op.getOperand(1);
|
||||
SDValue HiLHS = DAG.getNode(ISD::SRA, dl, VT, LHS, ShiftAmt);
|
||||
|
@ -2746,14 +2748,14 @@ static SDValue LowerUMULO_SMULO(SDValue Op, SelectionDAG &DAG,
|
|||
RTLIB::MUL_I128, WideVT,
|
||||
Args, 4, isSigned, dl).first;
|
||||
SDValue BottomHalf = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, VT,
|
||||
MulResult, DAG.getIntPtrConstant(0));
|
||||
MulResult, DAG.getIntPtrConstant(0, dl));
|
||||
SDValue TopHalf = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, VT,
|
||||
MulResult, DAG.getIntPtrConstant(1));
|
||||
MulResult, DAG.getIntPtrConstant(1, dl));
|
||||
if (isSigned) {
|
||||
SDValue Tmp1 = DAG.getNode(ISD::SRA, dl, VT, BottomHalf, ShiftAmt);
|
||||
TopHalf = DAG.getSetCC(dl, MVT::i32, TopHalf, Tmp1, ISD::SETNE);
|
||||
} else {
|
||||
TopHalf = DAG.getSetCC(dl, MVT::i32, TopHalf, DAG.getConstant(0, VT),
|
||||
TopHalf = DAG.getSetCC(dl, MVT::i32, TopHalf, DAG.getConstant(0, dl, VT),
|
||||
ISD::SETNE);
|
||||
}
|
||||
// MulResult is a node with an illegal type. Because such things are not
|
||||
|
@ -3119,7 +3121,8 @@ LowerAsmOperandForConstraint(SDValue Op,
|
|||
case 'I':
|
||||
if (ConstantSDNode *C = dyn_cast<ConstantSDNode>(Op)) {
|
||||
if (isInt<13>(C->getSExtValue())) {
|
||||
Result = DAG.getTargetConstant(C->getSExtValue(), Op.getValueType());
|
||||
Result = DAG.getTargetConstant(C->getSExtValue(), SDLoc(Op),
|
||||
Op.getValueType());
|
||||
break;
|
||||
}
|
||||
return;
|
||||
|
|
|
@ -63,7 +63,7 @@ defm SRAX : F3_S<"srax", 0b100111, 1, sra, i64, I64Regs>;
|
|||
|
||||
// The ALU instructions want their simm13 operands as i32 immediates.
|
||||
def as_i32imm : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), MVT::i32);
|
||||
return CurDAG->getTargetConstant(N->getSExtValue(), SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def : Pat<(i64 simm13:$val), (ORri (i64 G0), (as_i32imm $val))>;
|
||||
def : Pat<(i64 SETHIimm:$val), (SETHIi (HI22 $val))>;
|
||||
|
@ -83,11 +83,12 @@ def nimm33 : PatLeaf<(imm), [{
|
|||
// Bits 10-31 inverted. Same as assembler's %hix.
|
||||
def HIX22 : SDNodeXForm<imm, [{
|
||||
uint64_t Val = (~N->getZExtValue() >> 10) & ((1u << 22) - 1);
|
||||
return CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
return CurDAG->getTargetConstant(Val, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
// Bits 0-9 with ones in bits 10-31. Same as assembler's %lox.
|
||||
def LOX10 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(~(~N->getZExtValue() & 0x3ff), MVT::i32);
|
||||
return CurDAG->getTargetConstant(~(~N->getZExtValue() & 0x3ff), SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
def : Pat<(i64 nimm33:$val), (XORri (SETHIi (HIX22 $val)), (LOX10 $val))>,
|
||||
Requires<[Is64Bit]>;
|
||||
|
@ -121,12 +122,12 @@ def : Pat<(i64 nimm33:$val), (XORri (SETHIi (HIX22 $val)), (LOX10 $val))>,
|
|||
// Bits 42-63, same as assembler's %hh.
|
||||
def HH22 : SDNodeXForm<imm, [{
|
||||
uint64_t Val = (N->getZExtValue() >> 42) & ((1u << 22) - 1);
|
||||
return CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
return CurDAG->getTargetConstant(Val, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
// Bits 32-41, same as assembler's %hm.
|
||||
def HM10 : SDNodeXForm<imm, [{
|
||||
uint64_t Val = (N->getZExtValue() >> 32) & ((1u << 10) - 1);
|
||||
return CurDAG->getTargetConstant(Val, MVT::i32);
|
||||
return CurDAG->getTargetConstant(Val, SDLoc(N), MVT::i32);
|
||||
}]>;
|
||||
def : Pat<(i64 imm:$val),
|
||||
(ORrr (SLLXri (ORri (SETHIi (HH22 $val)), (HM10 $val)), (i32 32)),
|
||||
|
|
|
@ -64,13 +64,14 @@ def simm11 : PatLeaf<(imm), [{ return isInt<11>(N->getSExtValue()); }]>;
|
|||
def simm13 : PatLeaf<(imm), [{ return isInt<13>(N->getSExtValue()); }]>;
|
||||
|
||||
def LO10 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant((unsigned)N->getZExtValue() & 1023,
|
||||
return CurDAG->getTargetConstant((unsigned)N->getZExtValue() & 1023, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
def HI22 : SDNodeXForm<imm, [{
|
||||
// Transformation function: shift the immediate value down into the low bits.
|
||||
return CurDAG->getTargetConstant((unsigned)N->getZExtValue() >> 10, MVT::i32);
|
||||
return CurDAG->getTargetConstant((unsigned)N->getZExtValue() >> 10, SDLoc(N),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
def SETHIimm : PatLeaf<(imm), [{
|
||||
|
|
|
@ -131,7 +131,7 @@ class SystemZDAGToDAGISel : public SelectionDAGISel {
|
|||
|
||||
// Used by SystemZOperands.td to create integer constants.
|
||||
inline SDValue getImm(const SDNode *Node, uint64_t Imm) const {
|
||||
return CurDAG->getTargetConstant(Imm, Node->getValueType(0));
|
||||
return CurDAG->getTargetConstant(Imm, SDLoc(Node), Node->getValueType(0));
|
||||
}
|
||||
|
||||
const SystemZTargetMachine &getTargetMachine() const {
|
||||
|
@ -596,7 +596,7 @@ void SystemZDAGToDAGISel::getAddressOperands(const SystemZAddressingMode &AM,
|
|||
}
|
||||
|
||||
// Lower the displacement to a TargetConstant.
|
||||
Disp = CurDAG->getTargetConstant(AM.Disp, VT);
|
||||
Disp = CurDAG->getTargetConstant(AM.Disp, SDLoc(Base), VT);
|
||||
}
|
||||
|
||||
void SystemZDAGToDAGISel::getAddressOperands(const SystemZAddressingMode &AM,
|
||||
|
@ -864,6 +864,7 @@ SDValue SystemZDAGToDAGISel::convertTo(SDLoc DL, EVT VT, SDValue N) const {
|
|||
}
|
||||
|
||||
SDNode *SystemZDAGToDAGISel::tryRISBGZero(SDNode *N) {
|
||||
SDLoc DL(N);
|
||||
EVT VT = N->getValueType(0);
|
||||
RxSBGOperands RISBG(SystemZ::RISBG, SDValue(N, 0));
|
||||
unsigned Count = 0;
|
||||
|
@ -889,7 +890,7 @@ SDNode *SystemZDAGToDAGISel::tryRISBGZero(SDNode *N) {
|
|||
// Force the new mask into the DAG, since it may include known-one bits.
|
||||
auto *MaskN = cast<ConstantSDNode>(N->getOperand(1).getNode());
|
||||
if (MaskN->getZExtValue() != RISBG.Mask) {
|
||||
SDValue NewMask = CurDAG->getConstant(RISBG.Mask, VT);
|
||||
SDValue NewMask = CurDAG->getConstant(RISBG.Mask, DL, VT);
|
||||
N = CurDAG->UpdateNodeOperands(N, N->getOperand(0), NewMask);
|
||||
return SelectCode(N);
|
||||
}
|
||||
|
@ -909,14 +910,14 @@ SDNode *SystemZDAGToDAGISel::tryRISBGZero(SDNode *N) {
|
|||
RISBG.End &= 31;
|
||||
}
|
||||
SDValue Ops[5] = {
|
||||
getUNDEF(SDLoc(N), OpcodeVT),
|
||||
convertTo(SDLoc(N), OpcodeVT, RISBG.Input),
|
||||
CurDAG->getTargetConstant(RISBG.Start, MVT::i32),
|
||||
CurDAG->getTargetConstant(RISBG.End | 128, MVT::i32),
|
||||
CurDAG->getTargetConstant(RISBG.Rotate, MVT::i32)
|
||||
getUNDEF(DL, OpcodeVT),
|
||||
convertTo(DL, OpcodeVT, RISBG.Input),
|
||||
CurDAG->getTargetConstant(RISBG.Start, DL, MVT::i32),
|
||||
CurDAG->getTargetConstant(RISBG.End | 128, DL, MVT::i32),
|
||||
CurDAG->getTargetConstant(RISBG.Rotate, DL, MVT::i32)
|
||||
};
|
||||
N = CurDAG->getMachineNode(Opcode, SDLoc(N), OpcodeVT, Ops);
|
||||
return convertTo(SDLoc(N), VT, SDValue(N, 0)).getNode();
|
||||
N = CurDAG->getMachineNode(Opcode, DL, OpcodeVT, Ops);
|
||||
return convertTo(DL, VT, SDValue(N, 0)).getNode();
|
||||
}
|
||||
|
||||
SDNode *SystemZDAGToDAGISel::tryRxSBG(SDNode *N, unsigned Opcode) {
|
||||
|
@ -955,16 +956,17 @@ SDNode *SystemZDAGToDAGISel::tryRxSBG(SDNode *N, unsigned Opcode) {
|
|||
Opcode = SystemZ::RISBGN;
|
||||
}
|
||||
|
||||
SDLoc DL(N);
|
||||
EVT VT = N->getValueType(0);
|
||||
SDValue Ops[5] = {
|
||||
convertTo(SDLoc(N), MVT::i64, Op0),
|
||||
convertTo(SDLoc(N), MVT::i64, RxSBG[I].Input),
|
||||
CurDAG->getTargetConstant(RxSBG[I].Start, MVT::i32),
|
||||
CurDAG->getTargetConstant(RxSBG[I].End, MVT::i32),
|
||||
CurDAG->getTargetConstant(RxSBG[I].Rotate, MVT::i32)
|
||||
convertTo(DL, MVT::i64, Op0),
|
||||
convertTo(DL, MVT::i64, RxSBG[I].Input),
|
||||
CurDAG->getTargetConstant(RxSBG[I].Start, DL, MVT::i32),
|
||||
CurDAG->getTargetConstant(RxSBG[I].End, DL, MVT::i32),
|
||||
CurDAG->getTargetConstant(RxSBG[I].Rotate, DL, MVT::i32)
|
||||
};
|
||||
N = CurDAG->getMachineNode(Opcode, SDLoc(N), MVT::i64, Ops);
|
||||
return convertTo(SDLoc(N), VT, SDValue(N, 0)).getNode();
|
||||
N = CurDAG->getMachineNode(Opcode, DL, MVT::i64, Ops);
|
||||
return convertTo(DL, VT, SDValue(N, 0)).getNode();
|
||||
}
|
||||
|
||||
SDNode *SystemZDAGToDAGISel::splitLargeImmediate(unsigned Opcode, SDNode *Node,
|
||||
|
@ -972,12 +974,12 @@ SDNode *SystemZDAGToDAGISel::splitLargeImmediate(unsigned Opcode, SDNode *Node,
|
|||
uint64_t LowerVal) {
|
||||
EVT VT = Node->getValueType(0);
|
||||
SDLoc DL(Node);
|
||||
SDValue Upper = CurDAG->getConstant(UpperVal, VT);
|
||||
SDValue Upper = CurDAG->getConstant(UpperVal, DL, VT);
|
||||
if (Op0.getNode())
|
||||
Upper = CurDAG->getNode(Opcode, DL, VT, Op0, Upper);
|
||||
Upper = SDValue(Select(Upper.getNode()), 0);
|
||||
|
||||
SDValue Lower = CurDAG->getConstant(LowerVal, VT);
|
||||
SDValue Lower = CurDAG->getConstant(LowerVal, DL, VT);
|
||||
SDValue Or = CurDAG->getNode(Opcode, DL, VT, Upper, Lower);
|
||||
return Or.getNode();
|
||||
}
|
||||
|
@ -1111,7 +1113,7 @@ SDNode *SystemZDAGToDAGISel::Select(SDNode *Node) {
|
|||
uint64_t ConstCCMask =
|
||||
cast<ConstantSDNode>(CCMask.getNode())->getZExtValue();
|
||||
// Invert the condition.
|
||||
CCMask = CurDAG->getConstant(ConstCCValid ^ ConstCCMask,
|
||||
CCMask = CurDAG->getConstant(ConstCCValid ^ ConstCCMask, SDLoc(Node),
|
||||
CCMask.getValueType());
|
||||
SDValue Op4 = Node->getOperand(4);
|
||||
Node = CurDAG->UpdateNodeOperands(Node, Op1, Op0, CCValid, CCMask, Op4);
|
||||
|
|
|
@ -591,35 +591,35 @@ LowerAsmOperandForConstraint(SDValue Op, std::string &Constraint,
|
|||
case 'I': // Unsigned 8-bit constant
|
||||
if (auto *C = dyn_cast<ConstantSDNode>(Op))
|
||||
if (isUInt<8>(C->getZExtValue()))
|
||||
Ops.push_back(DAG.getTargetConstant(C->getZExtValue(),
|
||||
Ops.push_back(DAG.getTargetConstant(C->getZExtValue(), SDLoc(Op),
|
||||
Op.getValueType()));
|
||||
return;
|
||||
|
||||
case 'J': // Unsigned 12-bit constant
|
||||
if (auto *C = dyn_cast<ConstantSDNode>(Op))
|
||||
if (isUInt<12>(C->getZExtValue()))
|
||||
Ops.push_back(DAG.getTargetConstant(C->getZExtValue(),
|
||||
Ops.push_back(DAG.getTargetConstant(C->getZExtValue(), SDLoc(Op),
|
||||
Op.getValueType()));
|
||||
return;
|
||||
|
||||
case 'K': // Signed 16-bit constant
|
||||
if (auto *C = dyn_cast<ConstantSDNode>(Op))
|
||||
if (isInt<16>(C->getSExtValue()))
|
||||
Ops.push_back(DAG.getTargetConstant(C->getSExtValue(),
|
||||
Ops.push_back(DAG.getTargetConstant(C->getSExtValue(), SDLoc(Op),
|
||||
Op.getValueType()));
|
||||
return;
|
||||
|
||||
case 'L': // Signed 20-bit displacement (on all targets we support)
|
||||
if (auto *C = dyn_cast<ConstantSDNode>(Op))
|
||||
if (isInt<20>(C->getSExtValue()))
|
||||
Ops.push_back(DAG.getTargetConstant(C->getSExtValue(),
|
||||
Ops.push_back(DAG.getTargetConstant(C->getSExtValue(), SDLoc(Op),
|
||||
Op.getValueType()));
|
||||
return;
|
||||
|
||||
case 'M': // 0x7fffffff
|
||||
if (auto *C = dyn_cast<ConstantSDNode>(Op))
|
||||
if (C->getZExtValue() == 0x7fffffff)
|
||||
Ops.push_back(DAG.getTargetConstant(C->getZExtValue(),
|
||||
Ops.push_back(DAG.getTargetConstant(C->getZExtValue(), SDLoc(Op),
|
||||
Op.getValueType()));
|
||||
return;
|
||||
}
|
||||
|
@ -753,7 +753,8 @@ LowerFormalArguments(SDValue Chain, CallingConv::ID CallConv, bool IsVarArg,
|
|||
EVT PtrVT = getPointerTy();
|
||||
SDValue FIN = DAG.getFrameIndex(FI, PtrVT);
|
||||
if (VA.getLocVT() == MVT::i32 || VA.getLocVT() == MVT::f32)
|
||||
FIN = DAG.getNode(ISD::ADD, DL, PtrVT, FIN, DAG.getIntPtrConstant(4));
|
||||
FIN = DAG.getNode(ISD::ADD, DL, PtrVT, FIN,
|
||||
DAG.getIntPtrConstant(4, DL));
|
||||
ArgValue = DAG.getLoad(LocVT, DL, Chain, FIN,
|
||||
MachinePointerInfo::getFixedStack(FI),
|
||||
false, false, false, 0);
|
||||
|
@ -854,7 +855,8 @@ SystemZTargetLowering::LowerCall(CallLoweringInfo &CLI,
|
|||
|
||||
// Mark the start of the call.
|
||||
if (!IsTailCall)
|
||||
Chain = DAG.getCALLSEQ_START(Chain, DAG.getConstant(NumBytes, PtrVT, true),
|
||||
Chain = DAG.getCALLSEQ_START(Chain,
|
||||
DAG.getConstant(NumBytes, DL, PtrVT, true),
|
||||
DL);
|
||||
|
||||
// Copy argument values to their designated locations.
|
||||
|
@ -890,7 +892,7 @@ SystemZTargetLowering::LowerCall(CallLoweringInfo &CLI,
|
|||
if (VA.getLocVT() == MVT::i32 || VA.getLocVT() == MVT::f32)
|
||||
Offset += 4;
|
||||
SDValue Address = DAG.getNode(ISD::ADD, DL, PtrVT, StackPtr,
|
||||
DAG.getIntPtrConstant(Offset));
|
||||
DAG.getIntPtrConstant(Offset, DL));
|
||||
|
||||
// Emit the store.
|
||||
MemOpChains.push_back(DAG.getStore(Chain, DL, ArgValue, Address,
|
||||
|
@ -956,8 +958,8 @@ SystemZTargetLowering::LowerCall(CallLoweringInfo &CLI,
|
|||
|
||||
// Mark the end of the call, which is glued to the call itself.
|
||||
Chain = DAG.getCALLSEQ_END(Chain,
|
||||
DAG.getConstant(NumBytes, PtrVT, true),
|
||||
DAG.getConstant(0, PtrVT, true),
|
||||
DAG.getConstant(NumBytes, DL, PtrVT, true),
|
||||
DAG.getConstant(0, DL, PtrVT, true),
|
||||
Glue, DL);
|
||||
Glue = Chain.getValue(1);
|
||||
|
||||
|
@ -1179,7 +1181,7 @@ static IPMConversion getIPMConversion(unsigned CCValid, unsigned CCMask) {
|
|||
|
||||
// If C can be converted to a comparison against zero, adjust the operands
|
||||
// as necessary.
|
||||
static void adjustZeroCmp(SelectionDAG &DAG, Comparison &C) {
|
||||
static void adjustZeroCmp(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
|
||||
if (C.ICmpType == SystemZICMP::UnsignedOnly)
|
||||
return;
|
||||
|
||||
|
@ -1193,13 +1195,13 @@ static void adjustZeroCmp(SelectionDAG &DAG, Comparison &C) {
|
|||
(Value == 1 && C.CCMask == SystemZ::CCMASK_CMP_LT) ||
|
||||
(Value == 1 && C.CCMask == SystemZ::CCMASK_CMP_GE)) {
|
||||
C.CCMask ^= SystemZ::CCMASK_CMP_EQ;
|
||||
C.Op1 = DAG.getConstant(0, C.Op1.getValueType());
|
||||
C.Op1 = DAG.getConstant(0, DL, C.Op1.getValueType());
|
||||
}
|
||||
}
|
||||
|
||||
// If a comparison described by C is suitable for CLI(Y), CHHSI or CLHHSI,
|
||||
// adjust the operands as necessary.
|
||||
static void adjustSubwordCmp(SelectionDAG &DAG, Comparison &C) {
|
||||
static void adjustSubwordCmp(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
|
||||
// For us to make any changes, it must a comparison between a single-use
|
||||
// load and a constant.
|
||||
if (!C.Op0.hasOneUse() ||
|
||||
|
@ -1264,7 +1266,7 @@ static void adjustSubwordCmp(SelectionDAG &DAG, Comparison &C) {
|
|||
// Make sure that the second operand is an i32 with the right value.
|
||||
if (C.Op1.getValueType() != MVT::i32 ||
|
||||
Value != ConstOp1->getZExtValue())
|
||||
C.Op1 = DAG.getConstant(Value, MVT::i32);
|
||||
C.Op1 = DAG.getConstant(Value, DL, MVT::i32);
|
||||
}
|
||||
|
||||
// Return true if Op is either an unextended load, or a load suitable
|
||||
|
@ -1360,7 +1362,7 @@ static unsigned reverseCCMask(unsigned CCMask) {
|
|||
// Check whether C tests for equality between X and Y and whether X - Y
|
||||
// or Y - X is also computed. In that case it's better to compare the
|
||||
// result of the subtraction against zero.
|
||||
static void adjustForSubtraction(SelectionDAG &DAG, Comparison &C) {
|
||||
static void adjustForSubtraction(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
|
||||
if (C.CCMask == SystemZ::CCMASK_CMP_EQ ||
|
||||
C.CCMask == SystemZ::CCMASK_CMP_NE) {
|
||||
for (auto I = C.Op0->use_begin(), E = C.Op0->use_end(); I != E; ++I) {
|
||||
|
@ -1369,7 +1371,7 @@ static void adjustForSubtraction(SelectionDAG &DAG, Comparison &C) {
|
|||
((N->getOperand(0) == C.Op0 && N->getOperand(1) == C.Op1) ||
|
||||
(N->getOperand(0) == C.Op1 && N->getOperand(1) == C.Op0))) {
|
||||
C.Op0 = SDValue(N, 0);
|
||||
C.Op1 = DAG.getConstant(0, N->getValueType(0));
|
||||
C.Op1 = DAG.getConstant(0, DL, N->getValueType(0));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -1425,7 +1427,7 @@ static void adjustForLTGFR(Comparison &C) {
|
|||
// If C compares the truncation of an extending load, try to compare
|
||||
// the untruncated value instead. This exposes more opportunities to
|
||||
// reuse CC.
|
||||
static void adjustICmpTruncate(SelectionDAG &DAG, Comparison &C) {
|
||||
static void adjustICmpTruncate(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
|
||||
if (C.Op0.getOpcode() == ISD::TRUNCATE &&
|
||||
C.Op0.getOperand(0).getOpcode() == ISD::LOAD &&
|
||||
C.Op1.getOpcode() == ISD::Constant &&
|
||||
|
@ -1437,7 +1439,7 @@ static void adjustICmpTruncate(SelectionDAG &DAG, Comparison &C) {
|
|||
if ((Type == ISD::ZEXTLOAD && C.ICmpType != SystemZICMP::SignedOnly) ||
|
||||
(Type == ISD::SEXTLOAD && C.ICmpType != SystemZICMP::UnsignedOnly)) {
|
||||
C.Op0 = C.Op0.getOperand(0);
|
||||
C.Op1 = DAG.getConstant(0, C.Op0.getValueType());
|
||||
C.Op1 = DAG.getConstant(0, DL, C.Op0.getValueType());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1556,7 +1558,7 @@ static unsigned getTestUnderMaskCond(unsigned BitSize, unsigned CCMask,
|
|||
|
||||
// See whether C can be implemented as a TEST UNDER MASK instruction.
|
||||
// Update the arguments with the TM version if so.
|
||||
static void adjustForTestUnderMask(SelectionDAG &DAG, Comparison &C) {
|
||||
static void adjustForTestUnderMask(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
|
||||
// Check that we have a comparison with a constant.
|
||||
auto *ConstOp1 = dyn_cast<ConstantSDNode>(C.Op1);
|
||||
if (!ConstOp1)
|
||||
|
@ -1634,7 +1636,7 @@ static void adjustForTestUnderMask(SelectionDAG &DAG, Comparison &C) {
|
|||
if (Mask && Mask->getZExtValue() == MaskVal)
|
||||
C.Op1 = SDValue(Mask, 0);
|
||||
else
|
||||
C.Op1 = DAG.getConstant(MaskVal, C.Op0.getValueType());
|
||||
C.Op1 = DAG.getConstant(MaskVal, DL, C.Op0.getValueType());
|
||||
C.CCValid = SystemZ::CCMASK_TM;
|
||||
C.CCMask = NewCCMask;
|
||||
}
|
||||
|
@ -1677,7 +1679,7 @@ static Comparison getIntrinsicCmp(SelectionDAG &DAG, unsigned Opcode,
|
|||
|
||||
// Decide how to implement a comparison of type Cond between CmpOp0 with CmpOp1.
|
||||
static Comparison getCmp(SelectionDAG &DAG, SDValue CmpOp0, SDValue CmpOp1,
|
||||
ISD::CondCode Cond) {
|
||||
ISD::CondCode Cond, SDLoc DL) {
|
||||
if (CmpOp1.getOpcode() == ISD::Constant) {
|
||||
uint64_t Constant = cast<ConstantSDNode>(CmpOp1)->getZExtValue();
|
||||
unsigned Opcode, CCValid;
|
||||
|
@ -1709,11 +1711,11 @@ static Comparison getCmp(SelectionDAG &DAG, SDValue CmpOp0, SDValue CmpOp1,
|
|||
else
|
||||
C.ICmpType = SystemZICMP::SignedOnly;
|
||||
C.CCMask &= ~SystemZ::CCMASK_CMP_UO;
|
||||
adjustZeroCmp(DAG, C);
|
||||
adjustSubwordCmp(DAG, C);
|
||||
adjustForSubtraction(DAG, C);
|
||||
adjustZeroCmp(DAG, DL, C);
|
||||
adjustSubwordCmp(DAG, DL, C);
|
||||
adjustForSubtraction(DAG, DL, C);
|
||||
adjustForLTGFR(C);
|
||||
adjustICmpTruncate(DAG, C);
|
||||
adjustICmpTruncate(DAG, DL, C);
|
||||
}
|
||||
|
||||
if (shouldSwapCmpOperands(C)) {
|
||||
|
@ -1721,7 +1723,7 @@ static Comparison getCmp(SelectionDAG &DAG, SDValue CmpOp0, SDValue CmpOp1,
|
|||
C.CCMask = reverseCCMask(C.CCMask);
|
||||
}
|
||||
|
||||
adjustForTestUnderMask(DAG, C);
|
||||
adjustForTestUnderMask(DAG, DL, C);
|
||||
return C;
|
||||
}
|
||||
|
||||
|
@ -1740,12 +1742,12 @@ static SDValue emitCmp(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
|
|||
}
|
||||
if (C.Opcode == SystemZISD::ICMP)
|
||||
return DAG.getNode(SystemZISD::ICMP, DL, MVT::Glue, C.Op0, C.Op1,
|
||||
DAG.getConstant(C.ICmpType, MVT::i32));
|
||||
DAG.getConstant(C.ICmpType, DL, MVT::i32));
|
||||
if (C.Opcode == SystemZISD::TM) {
|
||||
bool RegisterOnly = (bool(C.CCMask & SystemZ::CCMASK_TM_MIXED_MSB_0) !=
|
||||
bool(C.CCMask & SystemZ::CCMASK_TM_MIXED_MSB_1));
|
||||
return DAG.getNode(SystemZISD::TM, DL, MVT::Glue, C.Op0, C.Op1,
|
||||
DAG.getConstant(RegisterOnly, MVT::i32));
|
||||
DAG.getConstant(RegisterOnly, DL, MVT::i32));
|
||||
}
|
||||
return DAG.getNode(C.Opcode, DL, MVT::Glue, C.Op0, C.Op1);
|
||||
}
|
||||
|
@ -1759,7 +1761,8 @@ static void lowerMUL_LOHI32(SelectionDAG &DAG, SDLoc DL,
|
|||
Op0 = DAG.getNode(Extend, DL, MVT::i64, Op0);
|
||||
Op1 = DAG.getNode(Extend, DL, MVT::i64, Op1);
|
||||
SDValue Mul = DAG.getNode(ISD::MUL, DL, MVT::i64, Op0, Op1);
|
||||
Hi = DAG.getNode(ISD::SRL, DL, MVT::i64, Mul, DAG.getConstant(32, MVT::i64));
|
||||
Hi = DAG.getNode(ISD::SRL, DL, MVT::i64, Mul,
|
||||
DAG.getConstant(32, DL, MVT::i64));
|
||||
Hi = DAG.getNode(ISD::TRUNCATE, DL, MVT::i32, Hi);
|
||||
Lo = DAG.getNode(ISD::TRUNCATE, DL, MVT::i32, Mul);
|
||||
}
|
||||
|
@ -1791,18 +1794,18 @@ static SDValue emitSETCC(SelectionDAG &DAG, SDLoc DL, SDValue Glue,
|
|||
|
||||
if (Conversion.XORValue)
|
||||
Result = DAG.getNode(ISD::XOR, DL, MVT::i32, Result,
|
||||
DAG.getConstant(Conversion.XORValue, MVT::i32));
|
||||
DAG.getConstant(Conversion.XORValue, DL, MVT::i32));
|
||||
|
||||
if (Conversion.AddValue)
|
||||
Result = DAG.getNode(ISD::ADD, DL, MVT::i32, Result,
|
||||
DAG.getConstant(Conversion.AddValue, MVT::i32));
|
||||
DAG.getConstant(Conversion.AddValue, DL, MVT::i32));
|
||||
|
||||
// The SHR/AND sequence should get optimized to an RISBG.
|
||||
Result = DAG.getNode(ISD::SRL, DL, MVT::i32, Result,
|
||||
DAG.getConstant(Conversion.Bit, MVT::i32));
|
||||
DAG.getConstant(Conversion.Bit, DL, MVT::i32));
|
||||
if (Conversion.Bit != 31)
|
||||
Result = DAG.getNode(ISD::AND, DL, MVT::i32, Result,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, DL, MVT::i32));
|
||||
return Result;
|
||||
}
|
||||
|
||||
|
@ -1813,7 +1816,7 @@ SDValue SystemZTargetLowering::lowerSETCC(SDValue Op,
|
|||
ISD::CondCode CC = cast<CondCodeSDNode>(Op.getOperand(2))->get();
|
||||
SDLoc DL(Op);
|
||||
|
||||
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC));
|
||||
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC, DL));
|
||||
SDValue Glue = emitCmp(DAG, DL, C);
|
||||
return emitSETCC(DAG, DL, Glue, C.CCValid, C.CCMask);
|
||||
}
|
||||
|
@ -1825,11 +1828,11 @@ SDValue SystemZTargetLowering::lowerBR_CC(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue Dest = Op.getOperand(4);
|
||||
SDLoc DL(Op);
|
||||
|
||||
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC));
|
||||
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC, DL));
|
||||
SDValue Glue = emitCmp(DAG, DL, C);
|
||||
return DAG.getNode(SystemZISD::BR_CCMASK, DL, Op.getValueType(),
|
||||
Op.getOperand(0), DAG.getConstant(C.CCValid, MVT::i32),
|
||||
DAG.getConstant(C.CCMask, MVT::i32), Dest, Glue);
|
||||
Op.getOperand(0), DAG.getConstant(C.CCValid, DL, MVT::i32),
|
||||
DAG.getConstant(C.CCMask, DL, MVT::i32), Dest, Glue);
|
||||
}
|
||||
|
||||
// Return true if Pos is CmpOp and Neg is the negative of CmpOp,
|
||||
|
@ -1850,7 +1853,7 @@ static SDValue getAbsolute(SelectionDAG &DAG, SDLoc DL, SDValue Op,
|
|||
Op = DAG.getNode(SystemZISD::IABS, DL, Op.getValueType(), Op);
|
||||
if (IsNegative)
|
||||
Op = DAG.getNode(ISD::SUB, DL, Op.getValueType(),
|
||||
DAG.getConstant(0, Op.getValueType()), Op);
|
||||
DAG.getConstant(0, DL, Op.getValueType()), Op);
|
||||
return Op;
|
||||
}
|
||||
|
||||
|
@ -1863,7 +1866,7 @@ SDValue SystemZTargetLowering::lowerSELECT_CC(SDValue Op,
|
|||
ISD::CondCode CC = cast<CondCodeSDNode>(Op.getOperand(4))->get();
|
||||
SDLoc DL(Op);
|
||||
|
||||
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC));
|
||||
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC, DL));
|
||||
|
||||
// Check for absolute and negative-absolute selections, including those
|
||||
// where the comparison value is sign-extended (for LPGFR and LNGFR).
|
||||
|
@ -1898,14 +1901,14 @@ SDValue SystemZTargetLowering::lowerSELECT_CC(SDValue Op,
|
|||
if (!is32Bit(VT))
|
||||
Result = DAG.getNode(ISD::ANY_EXTEND, DL, VT, Result);
|
||||
// Sign-extend from the low bit.
|
||||
SDValue ShAmt = DAG.getConstant(VT.getSizeInBits() - 1, MVT::i32);
|
||||
SDValue ShAmt = DAG.getConstant(VT.getSizeInBits() - 1, DL, MVT::i32);
|
||||
SDValue Shl = DAG.getNode(ISD::SHL, DL, VT, Result, ShAmt);
|
||||
return DAG.getNode(ISD::SRA, DL, VT, Shl, ShAmt);
|
||||
}
|
||||
}
|
||||
|
||||
SDValue Ops[] = {TrueOp, FalseOp, DAG.getConstant(C.CCValid, MVT::i32),
|
||||
DAG.getConstant(C.CCMask, MVT::i32), Glue};
|
||||
SDValue Ops[] = {TrueOp, FalseOp, DAG.getConstant(C.CCValid, DL, MVT::i32),
|
||||
DAG.getConstant(C.CCMask, DL, MVT::i32), Glue};
|
||||
|
||||
SDVTList VTs = DAG.getVTList(Op.getValueType(), MVT::Glue);
|
||||
return DAG.getNode(SystemZISD::SELECT_CCMASK, DL, VTs, Ops);
|
||||
|
@ -1945,7 +1948,7 @@ SDValue SystemZTargetLowering::lowerGlobalAddress(GlobalAddressSDNode *Node,
|
|||
// addition for it.
|
||||
if (Offset != 0)
|
||||
Result = DAG.getNode(ISD::ADD, DL, PtrVT, Result,
|
||||
DAG.getConstant(Offset, PtrVT));
|
||||
DAG.getConstant(Offset, DL, PtrVT));
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
@ -2006,17 +2009,17 @@ SDValue SystemZTargetLowering::lowerGlobalTLSAddress(GlobalAddressSDNode *Node,
|
|||
|
||||
// The high part of the thread pointer is in access register 0.
|
||||
SDValue TPHi = DAG.getNode(SystemZISD::EXTRACT_ACCESS, DL, MVT::i32,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
TPHi = DAG.getNode(ISD::ANY_EXTEND, DL, PtrVT, TPHi);
|
||||
|
||||
// The low part of the thread pointer is in access register 1.
|
||||
SDValue TPLo = DAG.getNode(SystemZISD::EXTRACT_ACCESS, DL, MVT::i32,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, DL, MVT::i32));
|
||||
TPLo = DAG.getNode(ISD::ZERO_EXTEND, DL, PtrVT, TPLo);
|
||||
|
||||
// Merge them into a single 64-bit address.
|
||||
SDValue TPHiShifted = DAG.getNode(ISD::SHL, DL, PtrVT, TPHi,
|
||||
DAG.getConstant(32, PtrVT));
|
||||
DAG.getConstant(32, DL, PtrVT));
|
||||
SDValue TP = DAG.getNode(ISD::OR, DL, PtrVT, TPHiShifted, TPLo);
|
||||
|
||||
// Get the offset of GA from the thread pointer, based on the TLS model.
|
||||
|
@ -2153,7 +2156,7 @@ SDValue SystemZTargetLowering::lowerBITCAST(SDValue Op,
|
|||
} else {
|
||||
In64 = DAG.getNode(ISD::ANY_EXTEND, DL, MVT::i64, In);
|
||||
In64 = DAG.getNode(ISD::SHL, DL, MVT::i64, In64,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, DL, MVT::i64));
|
||||
}
|
||||
SDValue Out64 = DAG.getNode(ISD::BITCAST, DL, MVT::f64, In64);
|
||||
return DAG.getTargetExtractSubreg(SystemZ::subreg_h32,
|
||||
|
@ -2168,7 +2171,7 @@ SDValue SystemZTargetLowering::lowerBITCAST(SDValue Op,
|
|||
return DAG.getTargetExtractSubreg(SystemZ::subreg_h32, DL,
|
||||
MVT::i32, Out64);
|
||||
SDValue Shift = DAG.getNode(ISD::SRL, DL, MVT::i64, Out64,
|
||||
DAG.getConstant(32, MVT::i64));
|
||||
DAG.getConstant(32, DL, MVT::i64));
|
||||
return DAG.getNode(ISD::TRUNCATE, DL, MVT::i32, Shift);
|
||||
}
|
||||
llvm_unreachable("Unexpected bitcast combination");
|
||||
|
@ -2189,8 +2192,8 @@ SDValue SystemZTargetLowering::lowerVASTART(SDValue Op,
|
|||
// The initial values of each field.
|
||||
const unsigned NumFields = 4;
|
||||
SDValue Fields[NumFields] = {
|
||||
DAG.getConstant(FuncInfo->getVarArgsFirstGPR(), PtrVT),
|
||||
DAG.getConstant(FuncInfo->getVarArgsFirstFPR(), PtrVT),
|
||||
DAG.getConstant(FuncInfo->getVarArgsFirstGPR(), DL, PtrVT),
|
||||
DAG.getConstant(FuncInfo->getVarArgsFirstFPR(), DL, PtrVT),
|
||||
DAG.getFrameIndex(FuncInfo->getVarArgsFrameIndex(), PtrVT),
|
||||
DAG.getFrameIndex(FuncInfo->getRegSaveFrameIndex(), PtrVT)
|
||||
};
|
||||
|
@ -2202,7 +2205,7 @@ SDValue SystemZTargetLowering::lowerVASTART(SDValue Op,
|
|||
SDValue FieldAddr = Addr;
|
||||
if (Offset != 0)
|
||||
FieldAddr = DAG.getNode(ISD::ADD, DL, PtrVT, FieldAddr,
|
||||
DAG.getIntPtrConstant(Offset));
|
||||
DAG.getIntPtrConstant(Offset, DL));
|
||||
MemOps[I] = DAG.getStore(Chain, DL, Fields[I], FieldAddr,
|
||||
MachinePointerInfo(SV, Offset),
|
||||
false, false, 0);
|
||||
|
@ -2220,7 +2223,7 @@ SDValue SystemZTargetLowering::lowerVACOPY(SDValue Op,
|
|||
const Value *SrcSV = cast<SrcValueSDNode>(Op.getOperand(4))->getValue();
|
||||
SDLoc DL(Op);
|
||||
|
||||
return DAG.getMemcpy(Chain, DL, DstPtr, SrcPtr, DAG.getIntPtrConstant(32),
|
||||
return DAG.getMemcpy(Chain, DL, DstPtr, SrcPtr, DAG.getIntPtrConstant(32, DL),
|
||||
/*Align*/8, /*isVolatile*/false, /*AlwaysInline*/false,
|
||||
/*isTailCall*/false,
|
||||
MachinePointerInfo(DstSV), MachinePointerInfo(SrcSV));
|
||||
|
@ -2277,7 +2280,7 @@ SDValue SystemZTargetLowering::lowerSMUL_LOHI(SDValue Op,
|
|||
// multiplication:
|
||||
//
|
||||
// (ll * rl) - (((lh & rl) + (ll & rh)) << 64)
|
||||
SDValue C63 = DAG.getConstant(63, MVT::i64);
|
||||
SDValue C63 = DAG.getConstant(63, DL, MVT::i64);
|
||||
SDValue LL = Op.getOperand(0);
|
||||
SDValue RL = Op.getOperand(1);
|
||||
SDValue LH = DAG.getNode(ISD::SRA, DL, VT, LL, C63);
|
||||
|
@ -2427,7 +2430,7 @@ SDValue SystemZTargetLowering::lowerCTPOP(SDValue Op,
|
|||
DAG.computeKnownBits(Op, KnownZero, KnownOne);
|
||||
unsigned NumSignificantBits = (~KnownZero).getActiveBits();
|
||||
if (NumSignificantBits == 0)
|
||||
return DAG.getConstant(0, VT);
|
||||
return DAG.getConstant(0, DL, VT);
|
||||
|
||||
// Skip known-zero high parts of the operand.
|
||||
int64_t BitSize = (int64_t)1 << Log2_32_Ceil(NumSignificantBits);
|
||||
|
@ -2441,16 +2444,17 @@ SDValue SystemZTargetLowering::lowerCTPOP(SDValue Op,
|
|||
// Add up per-byte counts in a binary tree. All bits of Op at
|
||||
// position larger than BitSize remain zero throughout.
|
||||
for (int64_t I = BitSize / 2; I >= 8; I = I / 2) {
|
||||
SDValue Tmp = DAG.getNode(ISD::SHL, DL, VT, Op, DAG.getConstant(I, VT));
|
||||
SDValue Tmp = DAG.getNode(ISD::SHL, DL, VT, Op, DAG.getConstant(I, DL, VT));
|
||||
if (BitSize != OrigBitSize)
|
||||
Tmp = DAG.getNode(ISD::AND, DL, VT, Tmp,
|
||||
DAG.getConstant(((uint64_t)1 << BitSize) - 1, VT));
|
||||
DAG.getConstant(((uint64_t)1 << BitSize) - 1, DL, VT));
|
||||
Op = DAG.getNode(ISD::ADD, DL, VT, Op, Tmp);
|
||||
}
|
||||
|
||||
// Extract overall result from high byte.
|
||||
if (BitSize > 8)
|
||||
Op = DAG.getNode(ISD::SRL, DL, VT, Op, DAG.getConstant(BitSize - 8, VT));
|
||||
Op = DAG.getNode(ISD::SRL, DL, VT, Op,
|
||||
DAG.getConstant(BitSize - 8, DL, VT));
|
||||
|
||||
return Op;
|
||||
}
|
||||
|
@ -2501,23 +2505,23 @@ SDValue SystemZTargetLowering::lowerATOMIC_LOAD_OP(SDValue Op,
|
|||
if (Opcode == SystemZISD::ATOMIC_LOADW_SUB)
|
||||
if (auto *Const = dyn_cast<ConstantSDNode>(Src2)) {
|
||||
Opcode = SystemZISD::ATOMIC_LOADW_ADD;
|
||||
Src2 = DAG.getConstant(-Const->getSExtValue(), Src2.getValueType());
|
||||
Src2 = DAG.getConstant(-Const->getSExtValue(), DL, Src2.getValueType());
|
||||
}
|
||||
|
||||
// Get the address of the containing word.
|
||||
SDValue AlignedAddr = DAG.getNode(ISD::AND, DL, PtrVT, Addr,
|
||||
DAG.getConstant(-4, PtrVT));
|
||||
DAG.getConstant(-4, DL, PtrVT));
|
||||
|
||||
// Get the number of bits that the word must be rotated left in order
|
||||
// to bring the field to the top bits of a GR32.
|
||||
SDValue BitShift = DAG.getNode(ISD::SHL, DL, PtrVT, Addr,
|
||||
DAG.getConstant(3, PtrVT));
|
||||
DAG.getConstant(3, DL, PtrVT));
|
||||
BitShift = DAG.getNode(ISD::TRUNCATE, DL, WideVT, BitShift);
|
||||
|
||||
// Get the complementing shift amount, for rotating a field in the top
|
||||
// bits back to its proper position.
|
||||
SDValue NegBitShift = DAG.getNode(ISD::SUB, DL, WideVT,
|
||||
DAG.getConstant(0, WideVT), BitShift);
|
||||
DAG.getConstant(0, DL, WideVT), BitShift);
|
||||
|
||||
// Extend the source operand to 32 bits and prepare it for the inner loop.
|
||||
// ATOMIC_SWAPW uses RISBG to rotate the field left, but all other
|
||||
|
@ -2526,23 +2530,23 @@ SDValue SystemZTargetLowering::lowerATOMIC_LOAD_OP(SDValue Op,
|
|||
// bits must be set, while for other opcodes they should be left clear.
|
||||
if (Opcode != SystemZISD::ATOMIC_SWAPW)
|
||||
Src2 = DAG.getNode(ISD::SHL, DL, WideVT, Src2,
|
||||
DAG.getConstant(32 - BitSize, WideVT));
|
||||
DAG.getConstant(32 - BitSize, DL, WideVT));
|
||||
if (Opcode == SystemZISD::ATOMIC_LOADW_AND ||
|
||||
Opcode == SystemZISD::ATOMIC_LOADW_NAND)
|
||||
Src2 = DAG.getNode(ISD::OR, DL, WideVT, Src2,
|
||||
DAG.getConstant(uint32_t(-1) >> BitSize, WideVT));
|
||||
DAG.getConstant(uint32_t(-1) >> BitSize, DL, WideVT));
|
||||
|
||||
// Construct the ATOMIC_LOADW_* node.
|
||||
SDVTList VTList = DAG.getVTList(WideVT, MVT::Other);
|
||||
SDValue Ops[] = { ChainIn, AlignedAddr, Src2, BitShift, NegBitShift,
|
||||
DAG.getConstant(BitSize, WideVT) };
|
||||
DAG.getConstant(BitSize, DL, WideVT) };
|
||||
SDValue AtomicOp = DAG.getMemIntrinsicNode(Opcode, DL, VTList, Ops,
|
||||
NarrowVT, MMO);
|
||||
|
||||
// Rotate the result of the final CS so that the field is in the lower
|
||||
// bits of a GR32, then truncate it.
|
||||
SDValue ResultShift = DAG.getNode(ISD::ADD, DL, WideVT, BitShift,
|
||||
DAG.getConstant(BitSize, WideVT));
|
||||
DAG.getConstant(BitSize, DL, WideVT));
|
||||
SDValue Result = DAG.getNode(ISD::ROTL, DL, WideVT, AtomicOp, ResultShift);
|
||||
|
||||
SDValue RetOps[2] = { Result, AtomicOp.getValue(1) };
|
||||
|
@ -2568,10 +2572,10 @@ SDValue SystemZTargetLowering::lowerATOMIC_LOAD_SUB(SDValue Op,
|
|||
// available or the negative value is in the range of A(G)FHI.
|
||||
int64_t Value = (-Op2->getAPIntValue()).getSExtValue();
|
||||
if (isInt<32>(Value) || Subtarget.hasInterlockedAccess1())
|
||||
NegSrc2 = DAG.getConstant(Value, MemVT);
|
||||
NegSrc2 = DAG.getConstant(Value, DL, MemVT);
|
||||
} else if (Subtarget.hasInterlockedAccess1())
|
||||
// Use LAA(G) if available.
|
||||
NegSrc2 = DAG.getNode(ISD::SUB, DL, MemVT, DAG.getConstant(0, MemVT),
|
||||
NegSrc2 = DAG.getNode(ISD::SUB, DL, MemVT, DAG.getConstant(0, DL, MemVT),
|
||||
Src2);
|
||||
|
||||
if (NegSrc2.getNode())
|
||||
|
@ -2610,23 +2614,23 @@ SDValue SystemZTargetLowering::lowerATOMIC_CMP_SWAP(SDValue Op,
|
|||
|
||||
// Get the address of the containing word.
|
||||
SDValue AlignedAddr = DAG.getNode(ISD::AND, DL, PtrVT, Addr,
|
||||
DAG.getConstant(-4, PtrVT));
|
||||
DAG.getConstant(-4, DL, PtrVT));
|
||||
|
||||
// Get the number of bits that the word must be rotated left in order
|
||||
// to bring the field to the top bits of a GR32.
|
||||
SDValue BitShift = DAG.getNode(ISD::SHL, DL, PtrVT, Addr,
|
||||
DAG.getConstant(3, PtrVT));
|
||||
DAG.getConstant(3, DL, PtrVT));
|
||||
BitShift = DAG.getNode(ISD::TRUNCATE, DL, WideVT, BitShift);
|
||||
|
||||
// Get the complementing shift amount, for rotating a field in the top
|
||||
// bits back to its proper position.
|
||||
SDValue NegBitShift = DAG.getNode(ISD::SUB, DL, WideVT,
|
||||
DAG.getConstant(0, WideVT), BitShift);
|
||||
DAG.getConstant(0, DL, WideVT), BitShift);
|
||||
|
||||
// Construct the ATOMIC_CMP_SWAPW node.
|
||||
SDVTList VTList = DAG.getVTList(WideVT, MVT::Other);
|
||||
SDValue Ops[] = { ChainIn, AlignedAddr, CmpVal, SwapVal, BitShift,
|
||||
NegBitShift, DAG.getConstant(BitSize, WideVT) };
|
||||
NegBitShift, DAG.getConstant(BitSize, DL, WideVT) };
|
||||
SDValue AtomicOp = DAG.getMemIntrinsicNode(SystemZISD::ATOMIC_CMP_SWAPW, DL,
|
||||
VTList, Ops, NarrowVT, MMO);
|
||||
return AtomicOp;
|
||||
|
@ -2655,15 +2659,16 @@ SDValue SystemZTargetLowering::lowerPREFETCH(SDValue Op,
|
|||
// Just preserve the chain.
|
||||
return Op.getOperand(0);
|
||||
|
||||
SDLoc DL(Op);
|
||||
bool IsWrite = cast<ConstantSDNode>(Op.getOperand(2))->getZExtValue();
|
||||
unsigned Code = IsWrite ? SystemZ::PFD_WRITE : SystemZ::PFD_READ;
|
||||
auto *Node = cast<MemIntrinsicSDNode>(Op.getNode());
|
||||
SDValue Ops[] = {
|
||||
Op.getOperand(0),
|
||||
DAG.getConstant(Code, MVT::i32),
|
||||
DAG.getConstant(Code, DL, MVT::i32),
|
||||
Op.getOperand(1)
|
||||
};
|
||||
return DAG.getMemIntrinsicNode(SystemZISD::PREFETCH, SDLoc(Op),
|
||||
return DAG.getMemIntrinsicNode(SystemZISD::PREFETCH, DL,
|
||||
Node->getVTList(), Ops,
|
||||
Node->getMemoryVT(), Node->getMemOperand());
|
||||
}
|
||||
|
@ -2671,10 +2676,11 @@ SDValue SystemZTargetLowering::lowerPREFETCH(SDValue Op,
|
|||
// Return an i32 that contains the value of CC immediately after After,
|
||||
// whose final operand must be MVT::Glue.
|
||||
static SDValue getCCResult(SelectionDAG &DAG, SDNode *After) {
|
||||
SDLoc DL(After);
|
||||
SDValue Glue = SDValue(After, After->getNumValues() - 1);
|
||||
SDValue IPM = DAG.getNode(SystemZISD::IPM, SDLoc(After), MVT::i32, Glue);
|
||||
return DAG.getNode(ISD::SRL, SDLoc(After), MVT::i32, IPM,
|
||||
DAG.getConstant(SystemZ::IPM_CC, MVT::i32));
|
||||
SDValue IPM = DAG.getNode(SystemZISD::IPM, DL, MVT::i32, Glue);
|
||||
return DAG.getNode(ISD::SRL, DL, MVT::i32, IPM,
|
||||
DAG.getConstant(SystemZ::IPM_CC, DL, MVT::i32));
|
||||
}
|
||||
|
||||
SDValue
|
||||
|
@ -2851,9 +2857,10 @@ SDValue SystemZTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
SDValue Ext = DAG.getNode(ISD::ANY_EXTEND, SDLoc(Inner), VT,
|
||||
Inner.getOperand(0));
|
||||
SDValue Shl = DAG.getNode(ISD::SHL, SDLoc(Inner), VT, Ext,
|
||||
DAG.getConstant(NewShlAmt, ShiftVT));
|
||||
DAG.getConstant(NewShlAmt, SDLoc(Inner),
|
||||
ShiftVT));
|
||||
return DAG.getNode(ISD::SRA, SDLoc(N0), VT, Shl,
|
||||
DAG.getConstant(NewSraAmt, ShiftVT));
|
||||
DAG.getConstant(NewSraAmt, SDLoc(N0), ShiftVT));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -134,72 +134,79 @@ class BDLMode<string type, string bitsize, string dispsize, string suffix,
|
|||
// Bits 0-15 (counting from the lsb).
|
||||
def LL16 : SDNodeXForm<imm, [{
|
||||
uint64_t Value = N->getZExtValue() & 0x000000000000FFFFULL;
|
||||
return CurDAG->getTargetConstant(Value, MVT::i64);
|
||||
return CurDAG->getTargetConstant(Value, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Bits 16-31 (counting from the lsb).
|
||||
def LH16 : SDNodeXForm<imm, [{
|
||||
uint64_t Value = (N->getZExtValue() & 0x00000000FFFF0000ULL) >> 16;
|
||||
return CurDAG->getTargetConstant(Value, MVT::i64);
|
||||
return CurDAG->getTargetConstant(Value, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Bits 32-47 (counting from the lsb).
|
||||
def HL16 : SDNodeXForm<imm, [{
|
||||
uint64_t Value = (N->getZExtValue() & 0x0000FFFF00000000ULL) >> 32;
|
||||
return CurDAG->getTargetConstant(Value, MVT::i64);
|
||||
return CurDAG->getTargetConstant(Value, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Bits 48-63 (counting from the lsb).
|
||||
def HH16 : SDNodeXForm<imm, [{
|
||||
uint64_t Value = (N->getZExtValue() & 0xFFFF000000000000ULL) >> 48;
|
||||
return CurDAG->getTargetConstant(Value, MVT::i64);
|
||||
return CurDAG->getTargetConstant(Value, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Low 32 bits.
|
||||
def LF32 : SDNodeXForm<imm, [{
|
||||
uint64_t Value = N->getZExtValue() & 0x00000000FFFFFFFFULL;
|
||||
return CurDAG->getTargetConstant(Value, MVT::i64);
|
||||
return CurDAG->getTargetConstant(Value, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// High 32 bits.
|
||||
def HF32 : SDNodeXForm<imm, [{
|
||||
uint64_t Value = N->getZExtValue() >> 32;
|
||||
return CurDAG->getTargetConstant(Value, MVT::i64);
|
||||
return CurDAG->getTargetConstant(Value, SDLoc(N), MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Truncate an immediate to a 8-bit signed quantity.
|
||||
def SIMM8 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(int8_t(N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(int8_t(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Truncate an immediate to a 8-bit unsigned quantity.
|
||||
def UIMM8 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(uint8_t(N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(uint8_t(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Truncate an immediate to a 16-bit signed quantity.
|
||||
def SIMM16 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(int16_t(N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(int16_t(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Truncate an immediate to a 16-bit unsigned quantity.
|
||||
def UIMM16 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(uint16_t(N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(uint16_t(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Truncate an immediate to a 32-bit signed quantity.
|
||||
def SIMM32 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(int32_t(N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(int32_t(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Truncate an immediate to a 32-bit unsigned quantity.
|
||||
def UIMM32 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(uint32_t(N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(uint32_t(N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
// Negate and then truncate an immediate to a 32-bit unsigned quantity.
|
||||
def NEGIMM32 : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(uint32_t(-N->getZExtValue()), MVT::i64);
|
||||
return CurDAG->getTargetConstant(uint32_t(-N->getZExtValue()), SDLoc(N),
|
||||
MVT::i64);
|
||||
}]>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
|
@ -46,10 +46,10 @@ static SDValue emitMemMem(SelectionDAG &DAG, SDLoc DL, unsigned Sequence,
|
|||
// number of straight-line MVCs as 6 * 256 - 1.
|
||||
if (Size > 6 * 256)
|
||||
return DAG.getNode(Loop, DL, MVT::Other, Chain, Dst, Src,
|
||||
DAG.getConstant(Size, PtrVT),
|
||||
DAG.getConstant(Size / 256, PtrVT));
|
||||
DAG.getConstant(Size, DL, PtrVT),
|
||||
DAG.getConstant(Size / 256, DL, PtrVT));
|
||||
return DAG.getNode(Sequence, DL, MVT::Other, Chain, Dst, Src,
|
||||
DAG.getConstant(Size, PtrVT));
|
||||
DAG.getConstant(Size, DL, PtrVT));
|
||||
}
|
||||
|
||||
SDValue SystemZSelectionDAGInfo::
|
||||
|
@ -78,7 +78,8 @@ static SDValue memsetStore(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
for (unsigned I = 1; I < Size; ++I)
|
||||
StoreVal |= ByteVal << (I * 8);
|
||||
return DAG.getStore(Chain, DL,
|
||||
DAG.getConstant(StoreVal, MVT::getIntegerVT(Size * 8)),
|
||||
DAG.getConstant(StoreVal, DL,
|
||||
MVT::getIntegerVT(Size * 8)),
|
||||
Dst, DstPtrInfo, false, false, Align);
|
||||
}
|
||||
|
||||
|
@ -112,7 +113,7 @@ EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
if (Size2 == 0)
|
||||
return Chain1;
|
||||
Dst = DAG.getNode(ISD::ADD, DL, PtrVT, Dst,
|
||||
DAG.getConstant(Size1, PtrVT));
|
||||
DAG.getConstant(Size1, DL, PtrVT));
|
||||
DstPtrInfo = DstPtrInfo.getWithOffset(Size1);
|
||||
SDValue Chain2 = memsetStore(DAG, DL, Chain, Dst, ByteVal, Size2,
|
||||
std::min(Align, Size1), DstPtrInfo);
|
||||
|
@ -126,7 +127,7 @@ EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
if (Bytes == 1)
|
||||
return Chain1;
|
||||
SDValue Dst2 = DAG.getNode(ISD::ADD, DL, PtrVT, Dst,
|
||||
DAG.getConstant(1, PtrVT));
|
||||
DAG.getConstant(1, DL, PtrVT));
|
||||
SDValue Chain2 = DAG.getStore(Chain, DL, Byte, Dst2,
|
||||
DstPtrInfo.getWithOffset(1),
|
||||
false, false, 1);
|
||||
|
@ -146,7 +147,7 @@ EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
Chain = DAG.getStore(Chain, DL, Byte, Dst, DstPtrInfo,
|
||||
false, false, Align);
|
||||
SDValue DstPlus1 = DAG.getNode(ISD::ADD, DL, PtrVT, Dst,
|
||||
DAG.getConstant(1, PtrVT));
|
||||
DAG.getConstant(1, DL, PtrVT));
|
||||
return emitMemMem(DAG, DL, SystemZISD::MVC, SystemZISD::MVC_LOOP,
|
||||
Chain, DstPlus1, Dst, Bytes - 1);
|
||||
}
|
||||
|
@ -169,10 +170,10 @@ static SDValue emitCLC(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
// needs 2 branches, whereas a straight-line sequence would need 3 or more.
|
||||
if (Size > 3 * 256)
|
||||
return DAG.getNode(SystemZISD::CLC_LOOP, DL, VTs, Chain, Src1, Src2,
|
||||
DAG.getConstant(Size, PtrVT),
|
||||
DAG.getConstant(Size / 256, PtrVT));
|
||||
DAG.getConstant(Size, DL, PtrVT),
|
||||
DAG.getConstant(Size / 256, DL, PtrVT));
|
||||
return DAG.getNode(SystemZISD::CLC, DL, VTs, Chain, Src1, Src2,
|
||||
DAG.getConstant(Size, PtrVT));
|
||||
DAG.getConstant(Size, DL, PtrVT));
|
||||
}
|
||||
|
||||
// Convert the current CC value into an integer that is 0 if CC == 0,
|
||||
|
@ -182,9 +183,9 @@ static SDValue emitCLC(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
static SDValue addIPMSequence(SDLoc DL, SDValue Glue, SelectionDAG &DAG) {
|
||||
SDValue IPM = DAG.getNode(SystemZISD::IPM, DL, MVT::i32, Glue);
|
||||
SDValue SRL = DAG.getNode(ISD::SRL, DL, MVT::i32, IPM,
|
||||
DAG.getConstant(SystemZ::IPM_CC, MVT::i32));
|
||||
DAG.getConstant(SystemZ::IPM_CC, DL, MVT::i32));
|
||||
SDValue ROTL = DAG.getNode(ISD::ROTL, DL, MVT::i32, SRL,
|
||||
DAG.getConstant(31, MVT::i32));
|
||||
DAG.getConstant(31, DL, MVT::i32));
|
||||
return ROTL;
|
||||
}
|
||||
|
||||
|
@ -213,7 +214,7 @@ EmitTargetCodeForMemchr(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
Length = DAG.getZExtOrTrunc(Length, DL, PtrVT);
|
||||
Char = DAG.getZExtOrTrunc(Char, DL, MVT::i32);
|
||||
Char = DAG.getNode(ISD::AND, DL, MVT::i32, Char,
|
||||
DAG.getConstant(255, MVT::i32));
|
||||
DAG.getConstant(255, DL, MVT::i32));
|
||||
SDValue Limit = DAG.getNode(ISD::ADD, DL, PtrVT, Src, Length);
|
||||
SDValue End = DAG.getNode(SystemZISD::SEARCH_STRING, DL, VTs, Chain,
|
||||
Limit, Src, Char);
|
||||
|
@ -222,9 +223,10 @@ EmitTargetCodeForMemchr(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
|
||||
// Now select between End and null, depending on whether the character
|
||||
// was found.
|
||||
SDValue Ops[] = {End, DAG.getConstant(0, PtrVT),
|
||||
DAG.getConstant(SystemZ::CCMASK_SRST, MVT::i32),
|
||||
DAG.getConstant(SystemZ::CCMASK_SRST_FOUND, MVT::i32), Glue};
|
||||
SDValue Ops[] = {End, DAG.getConstant(0, DL, PtrVT),
|
||||
DAG.getConstant(SystemZ::CCMASK_SRST, DL, MVT::i32),
|
||||
DAG.getConstant(SystemZ::CCMASK_SRST_FOUND, DL, MVT::i32),
|
||||
Glue};
|
||||
VTs = DAG.getVTList(PtrVT, MVT::Glue);
|
||||
End = DAG.getNode(SystemZISD::SELECT_CCMASK, DL, VTs, Ops);
|
||||
return std::make_pair(End, Chain);
|
||||
|
@ -237,7 +239,7 @@ EmitTargetCodeForStrcpy(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
MachinePointerInfo SrcPtrInfo, bool isStpcpy) const {
|
||||
SDVTList VTs = DAG.getVTList(Dest.getValueType(), MVT::Other);
|
||||
SDValue EndDest = DAG.getNode(SystemZISD::STPCPY, DL, VTs, Chain, Dest, Src,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
return std::make_pair(isStpcpy ? EndDest : Dest, EndDest.getValue(1));
|
||||
}
|
||||
|
||||
|
@ -248,7 +250,7 @@ EmitTargetCodeForStrcmp(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
|||
MachinePointerInfo Op2PtrInfo) const {
|
||||
SDVTList VTs = DAG.getVTList(Src1.getValueType(), MVT::Other, MVT::Glue);
|
||||
SDValue Unused = DAG.getNode(SystemZISD::STRCMP, DL, VTs, Chain, Src1, Src2,
|
||||
DAG.getConstant(0, MVT::i32));
|
||||
DAG.getConstant(0, DL, MVT::i32));
|
||||
Chain = Unused.getValue(1);
|
||||
SDValue Glue = Chain.getValue(2);
|
||||
return std::make_pair(addIPMSequence(DL, Glue, DAG), Chain);
|
||||
|
@ -265,7 +267,7 @@ static std::pair<SDValue, SDValue> getBoundedStrlen(SelectionDAG &DAG, SDLoc DL,
|
|||
EVT PtrVT = Src.getValueType();
|
||||
SDVTList VTs = DAG.getVTList(PtrVT, MVT::Other, MVT::Glue);
|
||||
SDValue End = DAG.getNode(SystemZISD::SEARCH_STRING, DL, VTs, Chain,
|
||||
Limit, Src, DAG.getConstant(0, MVT::i32));
|
||||
Limit, Src, DAG.getConstant(0, DL, MVT::i32));
|
||||
Chain = End.getValue(1);
|
||||
SDValue Len = DAG.getNode(ISD::SUB, DL, PtrVT, End, Src);
|
||||
return std::make_pair(Len, Chain);
|
||||
|
@ -275,7 +277,7 @@ std::pair<SDValue, SDValue> SystemZSelectionDAGInfo::
|
|||
EmitTargetCodeForStrlen(SelectionDAG &DAG, SDLoc DL, SDValue Chain,
|
||||
SDValue Src, MachinePointerInfo SrcPtrInfo) const {
|
||||
EVT PtrVT = Src.getValueType();
|
||||
return getBoundedStrlen(DAG, DL, Chain, Src, DAG.getConstant(0, PtrVT));
|
||||
return getBoundedStrlen(DAG, DL, Chain, Src, DAG.getConstant(0, DL, PtrVT));
|
||||
}
|
||||
|
||||
std::pair<SDValue, SDValue> SystemZSelectionDAGInfo::
|
||||
|
|
|
@ -233,14 +233,15 @@ namespace {
|
|||
|
||||
void EmitSpecialCodeForMain();
|
||||
|
||||
inline void getAddressOperands(X86ISelAddressMode &AM, SDValue &Base,
|
||||
SDValue &Scale, SDValue &Index,
|
||||
SDValue &Disp, SDValue &Segment) {
|
||||
inline void getAddressOperands(X86ISelAddressMode &AM, SDLoc DL,
|
||||
SDValue &Base, SDValue &Scale,
|
||||
SDValue &Index, SDValue &Disp,
|
||||
SDValue &Segment) {
|
||||
Base = (AM.BaseType == X86ISelAddressMode::FrameIndexBase)
|
||||
? CurDAG->getTargetFrameIndex(AM.Base_FrameIndex,
|
||||
TLI->getPointerTy())
|
||||
: AM.Base_Reg;
|
||||
Scale = getI8Imm(AM.Scale);
|
||||
Scale = getI8Imm(AM.Scale, DL);
|
||||
Index = AM.IndexReg;
|
||||
// These are 32-bit even in 64-bit mode since RIP relative offset
|
||||
// is 32-bit.
|
||||
|
@ -261,7 +262,7 @@ namespace {
|
|||
Disp = CurDAG->getTargetBlockAddress(AM.BlockAddr, MVT::i32, AM.Disp,
|
||||
AM.SymbolFlags);
|
||||
else
|
||||
Disp = CurDAG->getTargetConstant(AM.Disp, MVT::i32);
|
||||
Disp = CurDAG->getTargetConstant(AM.Disp, DL, MVT::i32);
|
||||
|
||||
if (AM.Segment.getNode())
|
||||
Segment = AM.Segment;
|
||||
|
@ -271,14 +272,14 @@ namespace {
|
|||
|
||||
/// getI8Imm - Return a target constant with the specified value, of type
|
||||
/// i8.
|
||||
inline SDValue getI8Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i8);
|
||||
inline SDValue getI8Imm(unsigned Imm, SDLoc DL) {
|
||||
return CurDAG->getTargetConstant(Imm, DL, MVT::i8);
|
||||
}
|
||||
|
||||
/// getI32Imm - Return a target constant with the specified value, of type
|
||||
/// i32.
|
||||
inline SDValue getI32Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
inline SDValue getI32Imm(unsigned Imm, SDLoc DL) {
|
||||
return CurDAG->getTargetConstant(Imm, DL, MVT::i32);
|
||||
}
|
||||
|
||||
/// getGlobalBaseReg - Return an SDNode that returns the value of
|
||||
|
@ -801,11 +802,11 @@ static bool FoldMaskAndShiftToExtract(SelectionDAG &DAG, SDValue N,
|
|||
|
||||
MVT VT = N.getSimpleValueType();
|
||||
SDLoc DL(N);
|
||||
SDValue Eight = DAG.getConstant(8, MVT::i8);
|
||||
SDValue NewMask = DAG.getConstant(0xff, VT);
|
||||
SDValue Eight = DAG.getConstant(8, DL, MVT::i8);
|
||||
SDValue NewMask = DAG.getConstant(0xff, DL, VT);
|
||||
SDValue Srl = DAG.getNode(ISD::SRL, DL, VT, X, Eight);
|
||||
SDValue And = DAG.getNode(ISD::AND, DL, VT, Srl, NewMask);
|
||||
SDValue ShlCount = DAG.getConstant(ScaleLog, MVT::i8);
|
||||
SDValue ShlCount = DAG.getConstant(ScaleLog, DL, MVT::i8);
|
||||
SDValue Shl = DAG.getNode(ISD::SHL, DL, VT, And, ShlCount);
|
||||
|
||||
// Insert the new nodes into the topological ordering. We must do this in
|
||||
|
@ -849,7 +850,7 @@ static bool FoldMaskedShiftToScaledMask(SelectionDAG &DAG, SDValue N,
|
|||
|
||||
MVT VT = N.getSimpleValueType();
|
||||
SDLoc DL(N);
|
||||
SDValue NewMask = DAG.getConstant(Mask >> ShiftAmt, VT);
|
||||
SDValue NewMask = DAG.getConstant(Mask >> ShiftAmt, DL, VT);
|
||||
SDValue NewAnd = DAG.getNode(ISD::AND, DL, VT, X, NewMask);
|
||||
SDValue NewShift = DAG.getNode(ISD::SHL, DL, VT, NewAnd, Shift.getOperand(1));
|
||||
|
||||
|
@ -955,9 +956,9 @@ static bool FoldMaskAndShiftToScale(SelectionDAG &DAG, SDValue N,
|
|||
X = NewX;
|
||||
}
|
||||
SDLoc DL(N);
|
||||
SDValue NewSRLAmt = DAG.getConstant(ShiftAmt + AMShiftAmt, MVT::i8);
|
||||
SDValue NewSRLAmt = DAG.getConstant(ShiftAmt + AMShiftAmt, DL, MVT::i8);
|
||||
SDValue NewSRL = DAG.getNode(ISD::SRL, DL, VT, X, NewSRLAmt);
|
||||
SDValue NewSHLAmt = DAG.getConstant(AMShiftAmt, MVT::i8);
|
||||
SDValue NewSHLAmt = DAG.getConstant(AMShiftAmt, DL, MVT::i8);
|
||||
SDValue NewSHL = DAG.getNode(ISD::SHL, DL, VT, NewSRL, NewSHLAmt);
|
||||
|
||||
// Insert the new nodes into the topological ordering. We must do this in
|
||||
|
@ -1198,7 +1199,7 @@ bool X86DAGToDAGISel::MatchAddressRecursively(SDValue N, X86ISelAddressMode &AM,
|
|||
}
|
||||
|
||||
// Ok, the transformation is legal and appears profitable. Go for it.
|
||||
SDValue Zero = CurDAG->getConstant(0, N.getValueType());
|
||||
SDValue Zero = CurDAG->getConstant(0, dl, N.getValueType());
|
||||
SDValue Neg = CurDAG->getNode(ISD::SUB, dl, N.getValueType(), Zero, RHS);
|
||||
AM.IndexReg = Neg;
|
||||
AM.Scale = 1;
|
||||
|
@ -1357,7 +1358,7 @@ bool X86DAGToDAGISel::SelectAddr(SDNode *Parent, SDValue N, SDValue &Base,
|
|||
if (!AM.IndexReg.getNode())
|
||||
AM.IndexReg = CurDAG->getRegister(0, VT);
|
||||
|
||||
getAddressOperands(AM, Base, Scale, Index, Disp, Segment);
|
||||
getAddressOperands(AM, SDLoc(N), Base, Scale, Index, Disp, Segment);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1413,7 +1414,7 @@ bool X86DAGToDAGISel::SelectMOV64Imm32(SDValue N, SDValue &Imm) {
|
|||
if ((uint32_t)ImmVal != (uint64_t)ImmVal)
|
||||
return false;
|
||||
|
||||
Imm = CurDAG->getTargetConstant(ImmVal, MVT::i64);
|
||||
Imm = CurDAG->getTargetConstant(ImmVal, SDLoc(N), MVT::i64);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1449,9 +1450,9 @@ bool X86DAGToDAGISel::SelectLEA64_32Addr(SDValue N, SDValue &Base,
|
|||
// Base could already be %rip, particularly in the x32 ABI.
|
||||
Base = SDValue(CurDAG->getMachineNode(
|
||||
TargetOpcode::SUBREG_TO_REG, DL, MVT::i64,
|
||||
CurDAG->getTargetConstant(0, MVT::i64),
|
||||
CurDAG->getTargetConstant(0, DL, MVT::i64),
|
||||
Base,
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, MVT::i32)),
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, DL, MVT::i32)),
|
||||
0);
|
||||
}
|
||||
|
||||
|
@ -1463,9 +1464,10 @@ bool X86DAGToDAGISel::SelectLEA64_32Addr(SDValue N, SDValue &Base,
|
|||
"Expect to be extending 32-bit registers for use in LEA");
|
||||
Index = SDValue(CurDAG->getMachineNode(
|
||||
TargetOpcode::SUBREG_TO_REG, DL, MVT::i64,
|
||||
CurDAG->getTargetConstant(0, MVT::i64),
|
||||
CurDAG->getTargetConstant(0, DL, MVT::i64),
|
||||
Index,
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, MVT::i32)),
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, DL,
|
||||
MVT::i32)),
|
||||
0);
|
||||
}
|
||||
|
||||
|
@ -1531,7 +1533,7 @@ bool X86DAGToDAGISel::SelectLEAAddr(SDValue N,
|
|||
if (Complexity <= 2)
|
||||
return false;
|
||||
|
||||
getAddressOperands(AM, Base, Scale, Index, Disp, Segment);
|
||||
getAddressOperands(AM, SDLoc(N), Base, Scale, Index, Disp, Segment);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1555,7 +1557,7 @@ bool X86DAGToDAGISel::SelectTLSADDRAddr(SDValue N, SDValue &Base,
|
|||
AM.IndexReg = CurDAG->getRegister(0, MVT::i64);
|
||||
}
|
||||
|
||||
getAddressOperands(AM, Base, Scale, Index, Disp, Segment);
|
||||
getAddressOperands(AM, SDLoc(N), Base, Scale, Index, Disp, Segment);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1725,7 +1727,7 @@ static SDValue getAtomicLoadArithTargetConstant(SelectionDAG *CurDAG,
|
|||
// an immediate operand to sub. However, it still fits in 32 bits for the
|
||||
// add (since it is not negated) so we can return target-constant.
|
||||
if (CNVal == INT32_MIN)
|
||||
return CurDAG->getTargetConstant(CNVal, NVT);
|
||||
return CurDAG->getTargetConstant(CNVal, dl, NVT);
|
||||
// For atomic-load-add, we could do some optimizations.
|
||||
if (Op == ADD) {
|
||||
// Translate to INC/DEC if ADD by 1 or -1.
|
||||
|
@ -1740,7 +1742,7 @@ static SDValue getAtomicLoadArithTargetConstant(SelectionDAG *CurDAG,
|
|||
CNVal = -CNVal;
|
||||
}
|
||||
}
|
||||
return CurDAG->getTargetConstant(CNVal, NVT);
|
||||
return CurDAG->getTargetConstant(CNVal, dl, NVT);
|
||||
}
|
||||
|
||||
// If the value operand is single-used, try to optimize it.
|
||||
|
@ -2053,12 +2055,14 @@ SDNode *X86DAGToDAGISel::SelectGather(SDNode *Node, unsigned Opc) {
|
|||
SDVTList VTs = CurDAG->getVTList(VSrc.getValueType(), VSrc.getValueType(),
|
||||
MVT::Other);
|
||||
|
||||
SDLoc DL(Node);
|
||||
|
||||
// Memory Operands: Base, Scale, Index, Disp, Segment
|
||||
SDValue Disp = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
SDValue Disp = CurDAG->getTargetConstant(0, DL, MVT::i32);
|
||||
SDValue Segment = CurDAG->getRegister(0, MVT::i32);
|
||||
const SDValue Ops[] = { VSrc, Base, getI8Imm(Scale->getSExtValue()), VIdx,
|
||||
const SDValue Ops[] = { VSrc, Base, getI8Imm(Scale->getSExtValue(), DL), VIdx,
|
||||
Disp, Segment, VMask, Chain};
|
||||
SDNode *ResNode = CurDAG->getMachineNode(Opc, SDLoc(Node), VTs, Ops);
|
||||
SDNode *ResNode = CurDAG->getMachineNode(Opc, DL, VTs, Ops);
|
||||
// Node has 2 outputs: VDst and MVT::Other.
|
||||
// ResNode has 3 outputs: VDst, VMask_wb, and MVT::Other.
|
||||
// We replace VDst of Node with VDst of ResNode, and Other of Node with Other
|
||||
|
@ -2232,13 +2236,13 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
}
|
||||
|
||||
// Emit the smaller op and the shift.
|
||||
SDValue NewCst = CurDAG->getTargetConstant(Val >> ShlVal, CstVT);
|
||||
SDValue NewCst = CurDAG->getTargetConstant(Val >> ShlVal, dl, CstVT);
|
||||
SDNode *New = CurDAG->getMachineNode(Op, dl, NVT, N0->getOperand(0),NewCst);
|
||||
if (ShlVal == 1)
|
||||
return CurDAG->SelectNodeTo(Node, AddOp, NVT, SDValue(New, 0),
|
||||
SDValue(New, 0));
|
||||
return CurDAG->SelectNodeTo(Node, ShlOp, NVT, SDValue(New, 0),
|
||||
getI8Imm(ShlVal));
|
||||
getI8Imm(ShlVal, dl));
|
||||
}
|
||||
case X86ISD::UMUL8:
|
||||
case X86ISD::SMUL8: {
|
||||
|
@ -2402,7 +2406,8 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
// Shift AX down 8 bits.
|
||||
Result = SDValue(CurDAG->getMachineNode(X86::SHR16ri, dl, MVT::i16,
|
||||
Result,
|
||||
CurDAG->getTargetConstant(8, MVT::i8)), 0);
|
||||
CurDAG->getTargetConstant(8, dl, MVT::i8)),
|
||||
0);
|
||||
// Then truncate it down to i8.
|
||||
ReplaceUses(SDValue(Node, 1),
|
||||
CurDAG->getTargetExtractSubreg(X86::sub_8bit, dl, MVT::i8, Result));
|
||||
|
@ -2522,7 +2527,8 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
ClrNode =
|
||||
SDValue(CurDAG->getMachineNode(
|
||||
TargetOpcode::EXTRACT_SUBREG, dl, MVT::i16, ClrNode,
|
||||
CurDAG->getTargetConstant(X86::sub_16bit, MVT::i32)),
|
||||
CurDAG->getTargetConstant(X86::sub_16bit, dl,
|
||||
MVT::i32)),
|
||||
0);
|
||||
break;
|
||||
case MVT::i32:
|
||||
|
@ -2531,8 +2537,9 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
ClrNode =
|
||||
SDValue(CurDAG->getMachineNode(
|
||||
TargetOpcode::SUBREG_TO_REG, dl, MVT::i64,
|
||||
CurDAG->getTargetConstant(0, MVT::i64), ClrNode,
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, MVT::i32)),
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i64), ClrNode,
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, dl,
|
||||
MVT::i32)),
|
||||
0);
|
||||
break;
|
||||
default:
|
||||
|
@ -2584,8 +2591,9 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
Result =
|
||||
SDValue(CurDAG->getMachineNode(
|
||||
TargetOpcode::SUBREG_TO_REG, dl, MVT::i64,
|
||||
CurDAG->getTargetConstant(0, MVT::i64), Result,
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, MVT::i32)),
|
||||
CurDAG->getTargetConstant(0, dl, MVT::i64), Result,
|
||||
CurDAG->getTargetConstant(X86::sub_32bit, dl,
|
||||
MVT::i32)),
|
||||
0);
|
||||
}
|
||||
} else {
|
||||
|
@ -2642,7 +2650,7 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
if ((C->getZExtValue() & ~UINT64_C(0xff)) == 0 &&
|
||||
(!(C->getZExtValue() & 0x80) ||
|
||||
HasNoSignedComparisonUses(Node))) {
|
||||
SDValue Imm = CurDAG->getTargetConstant(C->getZExtValue(), MVT::i8);
|
||||
SDValue Imm = CurDAG->getTargetConstant(C->getZExtValue(), dl, MVT::i8);
|
||||
SDValue Reg = N0.getNode()->getOperand(0);
|
||||
|
||||
// On x86-32, only the ABCD registers have 8-bit subregisters.
|
||||
|
@ -2653,7 +2661,7 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
case MVT::i16: TRC = &X86::GR16_ABCDRegClass; break;
|
||||
default: llvm_unreachable("Unsupported TEST operand type!");
|
||||
}
|
||||
SDValue RC = CurDAG->getTargetConstant(TRC->getID(), MVT::i32);
|
||||
SDValue RC = CurDAG->getTargetConstant(TRC->getID(), dl, MVT::i32);
|
||||
Reg = SDValue(CurDAG->getMachineNode(X86::COPY_TO_REGCLASS, dl,
|
||||
Reg.getValueType(), Reg, RC), 0);
|
||||
}
|
||||
|
@ -2678,7 +2686,7 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
HasNoSignedComparisonUses(Node))) {
|
||||
// Shift the immediate right by 8 bits.
|
||||
SDValue ShiftedImm = CurDAG->getTargetConstant(C->getZExtValue() >> 8,
|
||||
MVT::i8);
|
||||
dl, MVT::i8);
|
||||
SDValue Reg = N0.getNode()->getOperand(0);
|
||||
|
||||
// Put the value in an ABCD register.
|
||||
|
@ -2689,7 +2697,7 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
case MVT::i16: TRC = &X86::GR16_ABCDRegClass; break;
|
||||
default: llvm_unreachable("Unsupported TEST operand type!");
|
||||
}
|
||||
SDValue RC = CurDAG->getTargetConstant(TRC->getID(), MVT::i32);
|
||||
SDValue RC = CurDAG->getTargetConstant(TRC->getID(), dl, MVT::i32);
|
||||
Reg = SDValue(CurDAG->getMachineNode(X86::COPY_TO_REGCLASS, dl,
|
||||
Reg.getValueType(), Reg, RC), 0);
|
||||
|
||||
|
@ -2714,7 +2722,8 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
N0.getValueType() != MVT::i16 &&
|
||||
(!(C->getZExtValue() & 0x8000) ||
|
||||
HasNoSignedComparisonUses(Node))) {
|
||||
SDValue Imm = CurDAG->getTargetConstant(C->getZExtValue(), MVT::i16);
|
||||
SDValue Imm = CurDAG->getTargetConstant(C->getZExtValue(), dl,
|
||||
MVT::i16);
|
||||
SDValue Reg = N0.getNode()->getOperand(0);
|
||||
|
||||
// Extract the 16-bit subregister.
|
||||
|
@ -2736,7 +2745,8 @@ SDNode *X86DAGToDAGISel::Select(SDNode *Node) {
|
|||
N0.getValueType() == MVT::i64 &&
|
||||
(!(C->getZExtValue() & 0x80000000) ||
|
||||
HasNoSignedComparisonUses(Node))) {
|
||||
SDValue Imm = CurDAG->getTargetConstant(C->getZExtValue(), MVT::i32);
|
||||
SDValue Imm = CurDAG->getTargetConstant(C->getZExtValue(), dl,
|
||||
MVT::i32);
|
||||
SDValue Reg = N0.getNode()->getOperand(0);
|
||||
|
||||
// Extract the 32-bit subregister.
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -17,12 +17,12 @@
|
|||
|
||||
def GetLo32XForm : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the low 32 bits.
|
||||
return getI32Imm((unsigned)N->getZExtValue());
|
||||
return getI32Imm((unsigned)N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def GetLo8XForm : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the low 8 bits.
|
||||
return getI8Imm((uint8_t)N->getZExtValue());
|
||||
return getI8Imm((uint8_t)N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
|
||||
|
|
|
@ -566,7 +566,7 @@ def fp32imm0 : PatLeaf<(f32 fpimm), [{
|
|||
|
||||
def I8Imm : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the low 8 bits.
|
||||
return getI8Imm((uint8_t)N->getZExtValue());
|
||||
return getI8Imm((uint8_t)N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def FROUND_NO_EXC : ImmLeaf<i32, [{ return Imm == 8; }]>;
|
||||
|
@ -577,31 +577,31 @@ def FROUND_CURRENT : ImmLeaf<i32, [{
|
|||
// BYTE_imm - Transform bit immediates into byte immediates.
|
||||
def BYTE_imm : SDNodeXForm<imm, [{
|
||||
// Transformation function: imm >> 3
|
||||
return getI32Imm(N->getZExtValue() >> 3);
|
||||
return getI32Imm(N->getZExtValue() >> 3, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// EXTRACT_get_vextract128_imm xform function: convert extract_subvector index
|
||||
// to VEXTRACTF128/VEXTRACTI128 imm.
|
||||
def EXTRACT_get_vextract128_imm : SDNodeXForm<extract_subvector, [{
|
||||
return getI8Imm(X86::getExtractVEXTRACT128Immediate(N));
|
||||
return getI8Imm(X86::getExtractVEXTRACT128Immediate(N), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// INSERT_get_vinsert128_imm xform function: convert insert_subvector index to
|
||||
// VINSERTF128/VINSERTI128 imm.
|
||||
def INSERT_get_vinsert128_imm : SDNodeXForm<insert_subvector, [{
|
||||
return getI8Imm(X86::getInsertVINSERT128Immediate(N));
|
||||
return getI8Imm(X86::getInsertVINSERT128Immediate(N), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// EXTRACT_get_vextract256_imm xform function: convert extract_subvector index
|
||||
// to VEXTRACTF64x4 imm.
|
||||
def EXTRACT_get_vextract256_imm : SDNodeXForm<extract_subvector, [{
|
||||
return getI8Imm(X86::getExtractVEXTRACT256Immediate(N));
|
||||
return getI8Imm(X86::getExtractVEXTRACT256Immediate(N), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
// INSERT_get_vinsert256_imm xform function: convert insert_subvector index to
|
||||
// VINSERTF64x4 imm.
|
||||
def INSERT_get_vinsert256_imm : SDNodeXForm<insert_subvector, [{
|
||||
return getI8Imm(X86::getInsertVINSERT256Immediate(N));
|
||||
return getI8Imm(X86::getInsertVINSERT256Immediate(N), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def vextract128_extract : PatFrag<(ops node:$bigvec, node:$index),
|
||||
|
|
|
@ -2223,7 +2223,7 @@ let Predicates = [HasBMI2], Defs = [EFLAGS] in {
|
|||
|
||||
def CountTrailingOnes : SDNodeXForm<imm, [{
|
||||
// Count the trailing ones in the immediate.
|
||||
return getI8Imm(countTrailingOnes(N->getZExtValue()));
|
||||
return getI8Imm(countTrailingOnes(N->getZExtValue()), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def BZHIMask : ImmLeaf<i64, [{
|
||||
|
|
|
@ -850,12 +850,12 @@ def SHRD64mri8 : RIi8<0xAC, MRMDestMem,
|
|||
|
||||
def ROT32L2R_imm8 : SDNodeXForm<imm, [{
|
||||
// Convert a ROTL shamt to a ROTR shamt on 32-bit integer.
|
||||
return getI8Imm(32 - N->getZExtValue());
|
||||
return getI8Imm(32 - N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def ROT64L2R_imm8 : SDNodeXForm<imm, [{
|
||||
// Convert a ROTL shamt to a ROTR shamt on 64-bit integer.
|
||||
return getI8Imm(64 - N->getZExtValue());
|
||||
return getI8Imm(64 - N->getZExtValue(), SDLoc(N));
|
||||
}]>;
|
||||
|
||||
multiclass bmi_rotate<string asm, RegisterClass RC, X86MemOperand x86memop> {
|
||||
|
|
|
@ -138,22 +138,22 @@ X86SelectionDAGInfo::EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc dl,
|
|||
default: // Byte aligned
|
||||
AVT = MVT::i8;
|
||||
ValReg = X86::AL;
|
||||
Count = DAG.getIntPtrConstant(SizeVal);
|
||||
Count = DAG.getIntPtrConstant(SizeVal, dl);
|
||||
break;
|
||||
}
|
||||
|
||||
if (AVT.bitsGT(MVT::i8)) {
|
||||
unsigned UBytes = AVT.getSizeInBits() / 8;
|
||||
Count = DAG.getIntPtrConstant(SizeVal / UBytes);
|
||||
Count = DAG.getIntPtrConstant(SizeVal / UBytes, dl);
|
||||
BytesLeft = SizeVal % UBytes;
|
||||
}
|
||||
|
||||
Chain = DAG.getCopyToReg(Chain, dl, ValReg, DAG.getConstant(Val, AVT),
|
||||
Chain = DAG.getCopyToReg(Chain, dl, ValReg, DAG.getConstant(Val, dl, AVT),
|
||||
InFlag);
|
||||
InFlag = Chain.getValue(1);
|
||||
} else {
|
||||
AVT = MVT::i8;
|
||||
Count = DAG.getIntPtrConstant(SizeVal);
|
||||
Count = DAG.getIntPtrConstant(SizeVal, dl);
|
||||
Chain = DAG.getCopyToReg(Chain, dl, X86::AL, Src, InFlag);
|
||||
InFlag = Chain.getValue(1);
|
||||
}
|
||||
|
@ -174,7 +174,8 @@ X86SelectionDAGInfo::EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc dl,
|
|||
Count = Size;
|
||||
EVT CVT = Count.getValueType();
|
||||
SDValue Left = DAG.getNode(ISD::AND, dl, CVT, Count,
|
||||
DAG.getConstant((AVT == MVT::i64) ? 7 : 3, CVT));
|
||||
DAG.getConstant((AVT == MVT::i64) ? 7 : 3, dl,
|
||||
CVT));
|
||||
Chain = DAG.getCopyToReg(Chain, dl, (CVT == MVT::i64) ? X86::RCX :
|
||||
X86::ECX,
|
||||
Left, InFlag);
|
||||
|
@ -190,9 +191,9 @@ X86SelectionDAGInfo::EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc dl,
|
|||
|
||||
Chain = DAG.getMemset(Chain, dl,
|
||||
DAG.getNode(ISD::ADD, dl, AddrVT, Dst,
|
||||
DAG.getConstant(Offset, AddrVT)),
|
||||
DAG.getConstant(Offset, dl, AddrVT)),
|
||||
Src,
|
||||
DAG.getConstant(BytesLeft, SizeVT),
|
||||
DAG.getConstant(BytesLeft, dl, SizeVT),
|
||||
Align, isVolatile, false,
|
||||
DstPtrInfo.getWithOffset(Offset));
|
||||
}
|
||||
|
@ -248,7 +249,7 @@ SDValue X86SelectionDAGInfo::EmitTargetCodeForMemcpy(
|
|||
|
||||
unsigned UBytes = AVT.getSizeInBits() / 8;
|
||||
unsigned CountVal = SizeVal / UBytes;
|
||||
SDValue Count = DAG.getIntPtrConstant(CountVal);
|
||||
SDValue Count = DAG.getIntPtrConstant(CountVal, dl);
|
||||
unsigned BytesLeft = SizeVal % UBytes;
|
||||
|
||||
SDValue InFlag;
|
||||
|
@ -279,10 +280,12 @@ SDValue X86SelectionDAGInfo::EmitTargetCodeForMemcpy(
|
|||
EVT SizeVT = Size.getValueType();
|
||||
Results.push_back(DAG.getMemcpy(Chain, dl,
|
||||
DAG.getNode(ISD::ADD, dl, DstVT, Dst,
|
||||
DAG.getConstant(Offset, DstVT)),
|
||||
DAG.getConstant(Offset, dl,
|
||||
DstVT)),
|
||||
DAG.getNode(ISD::ADD, dl, SrcVT, Src,
|
||||
DAG.getConstant(Offset, SrcVT)),
|
||||
DAG.getConstant(BytesLeft, SizeVT),
|
||||
DAG.getConstant(Offset, dl,
|
||||
SrcVT)),
|
||||
DAG.getConstant(BytesLeft, dl, SizeVT),
|
||||
Align, isVolatile, AlwaysInline, false,
|
||||
DstPtrInfo.getWithOffset(Offset),
|
||||
SrcPtrInfo.getWithOffset(Offset)));
|
||||
|
|
|
@ -47,8 +47,8 @@ namespace {
|
|||
|
||||
/// getI32Imm - Return a target constant with the specified value, of type
|
||||
/// i32.
|
||||
inline SDValue getI32Imm(unsigned Imm) {
|
||||
return CurDAG->getTargetConstant(Imm, MVT::i32);
|
||||
inline SDValue getI32Imm(unsigned Imm, SDLoc dl) {
|
||||
return CurDAG->getTargetConstant(Imm, dl, MVT::i32);
|
||||
}
|
||||
|
||||
inline bool immMskBitp(SDNode *inN) const {
|
||||
|
@ -90,7 +90,7 @@ bool XCoreDAGToDAGISel::SelectADDRspii(SDValue Addr, SDValue &Base,
|
|||
FrameIndexSDNode *FIN = nullptr;
|
||||
if ((FIN = dyn_cast<FrameIndexSDNode>(Addr))) {
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(0, SDLoc(Addr), MVT::i32);
|
||||
return true;
|
||||
}
|
||||
if (Addr.getOpcode() == ISD::ADD) {
|
||||
|
@ -100,7 +100,8 @@ bool XCoreDAGToDAGISel::SelectADDRspii(SDValue Addr, SDValue &Base,
|
|||
&& (CN->getSExtValue() % 4 == 0 && CN->getSExtValue() >= 0)) {
|
||||
// Constant positive word offset from frame index
|
||||
Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(CN->getSExtValue(), MVT::i32);
|
||||
Offset = CurDAG->getTargetConstant(CN->getSExtValue(), SDLoc(Addr),
|
||||
MVT::i32);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -138,7 +139,7 @@ SDNode *XCoreDAGToDAGISel::Select(SDNode *N) {
|
|||
if (immMskBitp(N)) {
|
||||
// Transformation function: get the size of a mask
|
||||
// Look for the first non-zero bit
|
||||
SDValue MskSize = getI32Imm(32 - countLeadingZeros((uint32_t)Val));
|
||||
SDValue MskSize = getI32Imm(32 - countLeadingZeros((uint32_t)Val), dl);
|
||||
return CurDAG->getMachineNode(XCore::MKMSK_rus, dl,
|
||||
MVT::i32, MskSize);
|
||||
}
|
||||
|
@ -256,7 +257,7 @@ SDNode *XCoreDAGToDAGISel::SelectBRIND(SDNode *N) {
|
|||
// after with clrsr 1. If any resources owned by the thread are ready an event
|
||||
// will be taken. If no resource is ready we branch to the address which was
|
||||
// the operand to the checkevent intrinsic.
|
||||
SDValue constOne = getI32Imm(1);
|
||||
SDValue constOne = getI32Imm(1, dl);
|
||||
SDValue Glue =
|
||||
SDValue(CurDAG->getMachineNode(XCore::SETSR_branch_u6, dl, MVT::Glue,
|
||||
constOne, Chain), 0);
|
||||
|
|
|
@ -298,7 +298,7 @@ LowerGlobalAddress(SDValue Op, SelectionDAG &DAG) const
|
|||
GA = getGlobalAddressWrapper(GA, GV, DAG);
|
||||
// Handle the rest of the offset.
|
||||
if (Offset != FoldedOffset) {
|
||||
SDValue Remaining = DAG.getConstant(Offset - FoldedOffset, MVT::i32);
|
||||
SDValue Remaining = DAG.getConstant(Offset - FoldedOffset, DL, MVT::i32);
|
||||
GA = DAG.getNode(ISD::ADD, DL, MVT::i32, GA, Remaining);
|
||||
}
|
||||
return GA;
|
||||
|
@ -368,7 +368,7 @@ LowerBR_JT(SDValue Op, SelectionDAG &DAG) const
|
|||
}
|
||||
assert((NumEntries >> 31) == 0);
|
||||
SDValue ScaledIndex = DAG.getNode(ISD::SHL, dl, MVT::i32, Index,
|
||||
DAG.getConstant(1, MVT::i32));
|
||||
DAG.getConstant(1, dl, MVT::i32));
|
||||
return DAG.getNode(XCoreISD::BR_JT32, dl, MVT::Other, Chain, TargetJT,
|
||||
ScaledIndex);
|
||||
}
|
||||
|
@ -393,12 +393,12 @@ lowerLoadWordFromAlignedBasePlusOffset(SDLoc DL, SDValue Chain, SDValue Base,
|
|||
HighOffset);
|
||||
} else {
|
||||
LowAddr = DAG.getNode(ISD::ADD, DL, MVT::i32, Base,
|
||||
DAG.getConstant(LowOffset, MVT::i32));
|
||||
DAG.getConstant(LowOffset, DL, MVT::i32));
|
||||
HighAddr = DAG.getNode(ISD::ADD, DL, MVT::i32, Base,
|
||||
DAG.getConstant(HighOffset, MVT::i32));
|
||||
DAG.getConstant(HighOffset, DL, MVT::i32));
|
||||
}
|
||||
SDValue LowShift = DAG.getConstant((Offset - LowOffset) * 8, MVT::i32);
|
||||
SDValue HighShift = DAG.getConstant((HighOffset - Offset) * 8, MVT::i32);
|
||||
SDValue LowShift = DAG.getConstant((Offset - LowOffset) * 8, DL, MVT::i32);
|
||||
SDValue HighShift = DAG.getConstant((HighOffset - Offset) * 8, DL, MVT::i32);
|
||||
|
||||
SDValue Low = DAG.getLoad(getPointerTy(), DL, Chain,
|
||||
LowAddr, MachinePointerInfo(),
|
||||
|
@ -469,14 +469,14 @@ LowerLOAD(SDValue Op, SelectionDAG &DAG) const {
|
|||
LD->isVolatile(), LD->isNonTemporal(),
|
||||
LD->isInvariant(), 2);
|
||||
SDValue HighAddr = DAG.getNode(ISD::ADD, DL, MVT::i32, BasePtr,
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, DL, MVT::i32));
|
||||
SDValue High = DAG.getExtLoad(ISD::EXTLOAD, DL, MVT::i32, Chain,
|
||||
HighAddr,
|
||||
LD->getPointerInfo().getWithOffset(2),
|
||||
MVT::i16, LD->isVolatile(),
|
||||
LD->isNonTemporal(), LD->isInvariant(), 2);
|
||||
SDValue HighShifted = DAG.getNode(ISD::SHL, DL, MVT::i32, High,
|
||||
DAG.getConstant(16, MVT::i32));
|
||||
DAG.getConstant(16, DL, MVT::i32));
|
||||
SDValue Result = DAG.getNode(ISD::OR, DL, MVT::i32, Low, HighShifted);
|
||||
Chain = DAG.getNode(ISD::TokenFactor, DL, MVT::Other, Low.getValue(1),
|
||||
High.getValue(1));
|
||||
|
@ -529,13 +529,13 @@ LowerSTORE(SDValue Op, SelectionDAG &DAG) const
|
|||
if (ST->getAlignment() == 2) {
|
||||
SDValue Low = Value;
|
||||
SDValue High = DAG.getNode(ISD::SRL, dl, MVT::i32, Value,
|
||||
DAG.getConstant(16, MVT::i32));
|
||||
DAG.getConstant(16, dl, MVT::i32));
|
||||
SDValue StoreLow = DAG.getTruncStore(Chain, dl, Low, BasePtr,
|
||||
ST->getPointerInfo(), MVT::i16,
|
||||
ST->isVolatile(), ST->isNonTemporal(),
|
||||
2);
|
||||
SDValue HighAddr = DAG.getNode(ISD::ADD, dl, MVT::i32, BasePtr,
|
||||
DAG.getConstant(2, MVT::i32));
|
||||
DAG.getConstant(2, dl, MVT::i32));
|
||||
SDValue StoreHigh = DAG.getTruncStore(Chain, dl, High, HighAddr,
|
||||
ST->getPointerInfo().getWithOffset(2),
|
||||
MVT::i16, ST->isVolatile(),
|
||||
|
@ -573,7 +573,7 @@ LowerSMUL_LOHI(SDValue Op, SelectionDAG &DAG) const
|
|||
SDLoc dl(Op);
|
||||
SDValue LHS = Op.getOperand(0);
|
||||
SDValue RHS = Op.getOperand(1);
|
||||
SDValue Zero = DAG.getConstant(0, MVT::i32);
|
||||
SDValue Zero = DAG.getConstant(0, dl, MVT::i32);
|
||||
SDValue Hi = DAG.getNode(XCoreISD::MACCS, dl,
|
||||
DAG.getVTList(MVT::i32, MVT::i32), Zero, Zero,
|
||||
LHS, RHS);
|
||||
|
@ -590,7 +590,7 @@ LowerUMUL_LOHI(SDValue Op, SelectionDAG &DAG) const
|
|||
SDLoc dl(Op);
|
||||
SDValue LHS = Op.getOperand(0);
|
||||
SDValue RHS = Op.getOperand(1);
|
||||
SDValue Zero = DAG.getConstant(0, MVT::i32);
|
||||
SDValue Zero = DAG.getConstant(0, dl, MVT::i32);
|
||||
SDValue Hi = DAG.getNode(XCoreISD::LMUL, dl,
|
||||
DAG.getVTList(MVT::i32, MVT::i32), LHS, RHS,
|
||||
Zero, Zero);
|
||||
|
@ -675,13 +675,13 @@ TryExpandADDWithMul(SDNode *N, SelectionDAG &DAG) const
|
|||
SDLoc dl(N);
|
||||
SDValue LL, RL, AddendL, AddendH;
|
||||
LL = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Mul.getOperand(0), DAG.getConstant(0, MVT::i32));
|
||||
Mul.getOperand(0), DAG.getConstant(0, dl, MVT::i32));
|
||||
RL = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Mul.getOperand(1), DAG.getConstant(0, MVT::i32));
|
||||
Mul.getOperand(1), DAG.getConstant(0, dl, MVT::i32));
|
||||
AddendL = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Other, DAG.getConstant(0, MVT::i32));
|
||||
Other, DAG.getConstant(0, dl, MVT::i32));
|
||||
AddendH = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Other, DAG.getConstant(1, MVT::i32));
|
||||
Other, DAG.getConstant(1, dl, MVT::i32));
|
||||
APInt HighMask = APInt::getHighBitsSet(64, 32);
|
||||
unsigned LHSSB = DAG.ComputeNumSignBits(Mul.getOperand(0));
|
||||
unsigned RHSSB = DAG.ComputeNumSignBits(Mul.getOperand(1));
|
||||
|
@ -704,9 +704,9 @@ TryExpandADDWithMul(SDNode *N, SelectionDAG &DAG) const
|
|||
}
|
||||
SDValue LH, RH;
|
||||
LH = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Mul.getOperand(0), DAG.getConstant(1, MVT::i32));
|
||||
Mul.getOperand(0), DAG.getConstant(1, dl, MVT::i32));
|
||||
RH = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Mul.getOperand(1), DAG.getConstant(1, MVT::i32));
|
||||
Mul.getOperand(1), DAG.getConstant(1, dl, MVT::i32));
|
||||
SDValue Hi = DAG.getNode(XCoreISD::MACCU, dl,
|
||||
DAG.getVTList(MVT::i32, MVT::i32), AddendH,
|
||||
AddendL, LL, RL);
|
||||
|
@ -735,18 +735,22 @@ ExpandADDSUB(SDNode *N, SelectionDAG &DAG) const
|
|||
|
||||
// Extract components
|
||||
SDValue LHSL = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
N->getOperand(0), DAG.getConstant(0, MVT::i32));
|
||||
N->getOperand(0),
|
||||
DAG.getConstant(0, dl, MVT::i32));
|
||||
SDValue LHSH = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
N->getOperand(0), DAG.getConstant(1, MVT::i32));
|
||||
N->getOperand(0),
|
||||
DAG.getConstant(1, dl, MVT::i32));
|
||||
SDValue RHSL = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
N->getOperand(1), DAG.getConstant(0, MVT::i32));
|
||||
N->getOperand(1),
|
||||
DAG.getConstant(0, dl, MVT::i32));
|
||||
SDValue RHSH = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
N->getOperand(1), DAG.getConstant(1, MVT::i32));
|
||||
N->getOperand(1),
|
||||
DAG.getConstant(1, dl, MVT::i32));
|
||||
|
||||
// Expand
|
||||
unsigned Opcode = (N->getOpcode() == ISD::ADD) ? XCoreISD::LADD :
|
||||
XCoreISD::LSUB;
|
||||
SDValue Zero = DAG.getConstant(0, MVT::i32);
|
||||
SDValue Zero = DAG.getConstant(0, dl, MVT::i32);
|
||||
SDValue Lo = DAG.getNode(Opcode, dl, DAG.getVTList(MVT::i32, MVT::i32),
|
||||
LHSL, RHSL, Zero);
|
||||
SDValue Carry(Lo.getNode(), 1);
|
||||
|
@ -775,7 +779,8 @@ LowerVAARG(SDValue Op, SelectionDAG &DAG) const
|
|||
false, false, false, 0);
|
||||
// Increment the pointer, VAList, to the next vararg
|
||||
SDValue nextPtr = DAG.getNode(ISD::ADD, dl, PtrVT, VAList,
|
||||
DAG.getIntPtrConstant(VT.getSizeInBits() / 8));
|
||||
DAG.getIntPtrConstant(VT.getSizeInBits() / 8,
|
||||
dl));
|
||||
// Store the incremented VAList to the legalized pointer
|
||||
InChain = DAG.getStore(VAList.getValue(1), dl, nextPtr, VAListPtr,
|
||||
MachinePointerInfo(SV), false, false, 0);
|
||||
|
@ -910,30 +915,30 @@ LowerINIT_TRAMPOLINE(SDValue Op, SelectionDAG &DAG) const {
|
|||
SDValue Addr = Trmp;
|
||||
|
||||
SDLoc dl(Op);
|
||||
OutChains[0] = DAG.getStore(Chain, dl, DAG.getConstant(0x0a3cd805, MVT::i32),
|
||||
Addr, MachinePointerInfo(TrmpAddr), false, false,
|
||||
0);
|
||||
OutChains[0] = DAG.getStore(Chain, dl,
|
||||
DAG.getConstant(0x0a3cd805, dl, MVT::i32), Addr,
|
||||
MachinePointerInfo(TrmpAddr), false, false, 0);
|
||||
|
||||
Addr = DAG.getNode(ISD::ADD, dl, MVT::i32, Trmp,
|
||||
DAG.getConstant(4, MVT::i32));
|
||||
OutChains[1] = DAG.getStore(Chain, dl, DAG.getConstant(0xd80456c0, MVT::i32),
|
||||
Addr, MachinePointerInfo(TrmpAddr, 4), false,
|
||||
false, 0);
|
||||
DAG.getConstant(4, dl, MVT::i32));
|
||||
OutChains[1] = DAG.getStore(Chain, dl,
|
||||
DAG.getConstant(0xd80456c0, dl, MVT::i32), Addr,
|
||||
MachinePointerInfo(TrmpAddr, 4), false, false, 0);
|
||||
|
||||
Addr = DAG.getNode(ISD::ADD, dl, MVT::i32, Trmp,
|
||||
DAG.getConstant(8, MVT::i32));
|
||||
OutChains[2] = DAG.getStore(Chain, dl, DAG.getConstant(0x27fb0a3c, MVT::i32),
|
||||
Addr, MachinePointerInfo(TrmpAddr, 8), false,
|
||||
false, 0);
|
||||
DAG.getConstant(8, dl, MVT::i32));
|
||||
OutChains[2] = DAG.getStore(Chain, dl,
|
||||
DAG.getConstant(0x27fb0a3c, dl, MVT::i32), Addr,
|
||||
MachinePointerInfo(TrmpAddr, 8), false, false, 0);
|
||||
|
||||
Addr = DAG.getNode(ISD::ADD, dl, MVT::i32, Trmp,
|
||||
DAG.getConstant(12, MVT::i32));
|
||||
DAG.getConstant(12, dl, MVT::i32));
|
||||
OutChains[3] = DAG.getStore(Chain, dl, Nest, Addr,
|
||||
MachinePointerInfo(TrmpAddr, 12), false, false,
|
||||
0);
|
||||
|
||||
Addr = DAG.getNode(ISD::ADD, dl, MVT::i32, Trmp,
|
||||
DAG.getConstant(16, MVT::i32));
|
||||
DAG.getConstant(16, dl, MVT::i32));
|
||||
OutChains[4] = DAG.getStore(Chain, dl, FPtr, Addr,
|
||||
MachinePointerInfo(TrmpAddr, 16), false, false,
|
||||
0);
|
||||
|
@ -1096,7 +1101,7 @@ LowerCallResult(SDValue Chain, SDValue InFlag,
|
|||
int offset = ResultMemLocs[i].first;
|
||||
unsigned index = ResultMemLocs[i].second;
|
||||
SDVTList VTs = DAG.getVTList(MVT::i32, MVT::Other);
|
||||
SDValue Ops[] = { Chain, DAG.getConstant(offset / 4, MVT::i32) };
|
||||
SDValue Ops[] = { Chain, DAG.getConstant(offset / 4, dl, MVT::i32) };
|
||||
SDValue load = DAG.getNode(XCoreISD::LDWSP, dl, VTs, Ops);
|
||||
InVals[index] = load;
|
||||
MemOpChains.push_back(load.getValue(1));
|
||||
|
@ -1145,7 +1150,7 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
|||
// Get a count of how many bytes are to be pushed on the stack.
|
||||
unsigned NumBytes = RetCCInfo.getNextStackOffset();
|
||||
|
||||
Chain = DAG.getCALLSEQ_START(Chain,DAG.getConstant(NumBytes,
|
||||
Chain = DAG.getCALLSEQ_START(Chain,DAG.getConstant(NumBytes, dl,
|
||||
getPointerTy(), true), dl);
|
||||
|
||||
SmallVector<std::pair<unsigned, SDValue>, 4> RegsToPass;
|
||||
|
@ -1182,7 +1187,8 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
|||
|
||||
MemOpChains.push_back(DAG.getNode(XCoreISD::STWSP, dl, MVT::Other,
|
||||
Chain, Arg,
|
||||
DAG.getConstant(Offset/4, MVT::i32)));
|
||||
DAG.getConstant(Offset/4, dl,
|
||||
MVT::i32)));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1233,8 +1239,9 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
|||
|
||||
// Create the CALLSEQ_END node.
|
||||
Chain = DAG.getCALLSEQ_END(Chain,
|
||||
DAG.getConstant(NumBytes, getPointerTy(), true),
|
||||
DAG.getConstant(0, getPointerTy(), true),
|
||||
DAG.getConstant(NumBytes, dl, getPointerTy(),
|
||||
true),
|
||||
DAG.getConstant(0, dl, getPointerTy(), true),
|
||||
InFlag, dl);
|
||||
InFlag = Chain.getValue(1);
|
||||
|
||||
|
@ -1422,7 +1429,7 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,
|
|||
SDValue FIN = DAG.getFrameIndex(FI, MVT::i32);
|
||||
InVals.push_back(FIN);
|
||||
MemOps.push_back(DAG.getMemcpy(Chain, dl, FIN, ArgDI->SDV,
|
||||
DAG.getConstant(Size, MVT::i32),
|
||||
DAG.getConstant(Size, dl, MVT::i32),
|
||||
Align, false, false, false,
|
||||
MachinePointerInfo(),
|
||||
MachinePointerInfo()));
|
||||
|
@ -1487,7 +1494,7 @@ XCoreTargetLowering::LowerReturn(SDValue Chain,
|
|||
SmallVector<SDValue, 4> RetOps(1, Chain);
|
||||
|
||||
// Return on XCore is always a "retsp 0"
|
||||
RetOps.push_back(DAG.getConstant(0, MVT::i32));
|
||||
RetOps.push_back(DAG.getConstant(0, dl, MVT::i32));
|
||||
|
||||
SmallVector<SDValue, 4> MemOpChains;
|
||||
// Handle return values that must be copied to memory.
|
||||
|
@ -1671,9 +1678,9 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
|
||||
// fold (ladd 0, 0, x) -> 0, x & 1
|
||||
if (N0C && N0C->isNullValue() && N1C && N1C->isNullValue()) {
|
||||
SDValue Carry = DAG.getConstant(0, VT);
|
||||
SDValue Carry = DAG.getConstant(0, dl, VT);
|
||||
SDValue Result = DAG.getNode(ISD::AND, dl, VT, N2,
|
||||
DAG.getConstant(1, VT));
|
||||
DAG.getConstant(1, dl, VT));
|
||||
SDValue Ops[] = { Result, Carry };
|
||||
return DAG.getMergeValues(Ops, dl);
|
||||
}
|
||||
|
@ -1686,7 +1693,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
VT.getSizeInBits() - 1);
|
||||
DAG.computeKnownBits(N2, KnownZero, KnownOne);
|
||||
if ((KnownZero & Mask) == Mask) {
|
||||
SDValue Carry = DAG.getConstant(0, VT);
|
||||
SDValue Carry = DAG.getConstant(0, dl, VT);
|
||||
SDValue Result = DAG.getNode(ISD::ADD, dl, VT, N0, N2);
|
||||
SDValue Ops[] = { Result, Carry };
|
||||
return DAG.getMergeValues(Ops, dl);
|
||||
|
@ -1711,7 +1718,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
if ((KnownZero & Mask) == Mask) {
|
||||
SDValue Borrow = N2;
|
||||
SDValue Result = DAG.getNode(ISD::SUB, dl, VT,
|
||||
DAG.getConstant(0, VT), N2);
|
||||
DAG.getConstant(0, dl, VT), N2);
|
||||
SDValue Ops[] = { Result, Borrow };
|
||||
return DAG.getMergeValues(Ops, dl);
|
||||
}
|
||||
|
@ -1725,7 +1732,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
VT.getSizeInBits() - 1);
|
||||
DAG.computeKnownBits(N2, KnownZero, KnownOne);
|
||||
if ((KnownZero & Mask) == Mask) {
|
||||
SDValue Borrow = DAG.getConstant(0, VT);
|
||||
SDValue Borrow = DAG.getConstant(0, dl, VT);
|
||||
SDValue Result = DAG.getNode(ISD::SUB, dl, VT, N0, N2);
|
||||
SDValue Ops[] = { Result, Borrow };
|
||||
return DAG.getMergeValues(Ops, dl);
|
||||
|
@ -1791,13 +1798,13 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
DAG.MaskedValueIsZero(Addend0, HighMask) &&
|
||||
DAG.MaskedValueIsZero(Addend1, HighMask)) {
|
||||
SDValue Mul0L = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Mul0, DAG.getConstant(0, MVT::i32));
|
||||
Mul0, DAG.getConstant(0, dl, MVT::i32));
|
||||
SDValue Mul1L = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Mul1, DAG.getConstant(0, MVT::i32));
|
||||
Mul1, DAG.getConstant(0, dl, MVT::i32));
|
||||
SDValue Addend0L = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Addend0, DAG.getConstant(0, MVT::i32));
|
||||
Addend0, DAG.getConstant(0, dl, MVT::i32));
|
||||
SDValue Addend1L = DAG.getNode(ISD::EXTRACT_ELEMENT, dl, MVT::i32,
|
||||
Addend1, DAG.getConstant(0, MVT::i32));
|
||||
Addend1, DAG.getConstant(0, dl, MVT::i32));
|
||||
SDValue Hi = DAG.getNode(XCoreISD::LMUL, dl,
|
||||
DAG.getVTList(MVT::i32, MVT::i32), Mul0L, Mul1L,
|
||||
Addend0L, Addend1L);
|
||||
|
@ -1837,7 +1844,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,
|
|||
bool isTail = isInTailCallPosition(DAG, ST, Chain);
|
||||
return DAG.getMemmove(Chain, dl, ST->getBasePtr(),
|
||||
LD->getBasePtr(),
|
||||
DAG.getConstant(StoreBits/8, MVT::i32),
|
||||
DAG.getConstant(StoreBits/8, dl, MVT::i32),
|
||||
Alignment, false, isTail, ST->getPointerInfo(),
|
||||
LD->getPointerInfo());
|
||||
}
|
||||
|
|
|
@ -94,33 +94,34 @@ def XCoreMemBarrier : SDNode<"XCoreISD::MEMBARRIER", SDT_XCoreMEMBARRIER,
|
|||
def div4_xform : SDNodeXForm<imm, [{
|
||||
// Transformation function: imm/4
|
||||
assert(N->getZExtValue() % 4 == 0);
|
||||
return getI32Imm(N->getZExtValue()/4);
|
||||
return getI32Imm(N->getZExtValue()/4, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def msksize_xform : SDNodeXForm<imm, [{
|
||||
// Transformation function: get the size of a mask
|
||||
assert(isMask_32(N->getZExtValue()));
|
||||
// look for the first non-zero bit
|
||||
return getI32Imm(32 - countLeadingZeros((uint32_t)N->getZExtValue()));
|
||||
return getI32Imm(32 - countLeadingZeros((uint32_t)N->getZExtValue()),
|
||||
SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def neg_xform : SDNodeXForm<imm, [{
|
||||
// Transformation function: -imm
|
||||
uint32_t value = N->getZExtValue();
|
||||
return getI32Imm(-value);
|
||||
return getI32Imm(-value, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def bpwsub_xform : SDNodeXForm<imm, [{
|
||||
// Transformation function: 32-imm
|
||||
uint32_t value = N->getZExtValue();
|
||||
return getI32Imm(32-value);
|
||||
return getI32Imm(32 - value, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def div4neg_xform : SDNodeXForm<imm, [{
|
||||
// Transformation function: -imm/4
|
||||
uint32_t value = N->getZExtValue();
|
||||
assert(-value % 4 == 0);
|
||||
return getI32Imm(-value/4);
|
||||
return getI32Imm(-value/4, SDLoc(N));
|
||||
}]>;
|
||||
|
||||
def immUs4Neg : PatLeaf<(imm), [{
|
||||
|
|
|
@ -0,0 +1,37 @@
|
|||
; RUN: llc -filetype=asm %s -o - | FileCheck %s
|
||||
|
||||
target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
|
||||
target triple = "aarch64--linux-gnueabihf"
|
||||
|
||||
; int
|
||||
; main(void)
|
||||
; {
|
||||
; return -1;
|
||||
; }
|
||||
|
||||
; CHECK: test.c:4:5
|
||||
; CHECK: movn
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define i32 @main() {
|
||||
entry:
|
||||
%retval = alloca i32, align 4
|
||||
store i32 0, i32* %retval
|
||||
ret i32 -1, !dbg !11
|
||||
}
|
||||
|
||||
!llvm.dbg.cu = !{!0}
|
||||
!llvm.module.flags = !{!8, !9}
|
||||
|
||||
!0 = !MDCompileUnit(language: DW_LANG_C99, file: !1, producer: "", isOptimized: false, subprograms: !3)
|
||||
!1 = !MDFile(filename: "test.c", directory: "/home/user/clang/build")
|
||||
!2 = !{}
|
||||
!3 = !{!4}
|
||||
!4 = !MDSubprogram(name: "main", scope: !1, file: !1, line: 2, type: !5, isLocal: false, isDefinition: true, scopeLine: 3, flags: DIFlagPrototyped, isOptimized: false, function: i32 ()* @main, variables: !2)
|
||||
!5 = !MDSubroutineType(types: !6)
|
||||
!6 = !{!7}
|
||||
!7 = !MDBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
||||
!8 = !{i32 2, !"Dwarf Version", i32 4}
|
||||
!9 = !{i32 2, !"Debug Info Version", i32 3}
|
||||
!10 = !{i32 1, !"wchar_size", i32 4}
|
||||
!11 = !MDLocation(line: 4, column: 5, scope: !4)
|
|
@ -0,0 +1,37 @@
|
|||
; RUN: llc -filetype=asm %s -o - | FileCheck %s
|
||||
|
||||
target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
|
||||
target triple = "armv7--linux-gnueabihf"
|
||||
|
||||
; int
|
||||
; main(void)
|
||||
; {
|
||||
; return -1;
|
||||
; }
|
||||
|
||||
; CHECK: test.c:4:5
|
||||
; CHECK: mvn
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define i32 @main() {
|
||||
entry:
|
||||
%retval = alloca i32, align 4
|
||||
store i32 0, i32* %retval
|
||||
ret i32 -1, !dbg !11
|
||||
}
|
||||
|
||||
!llvm.dbg.cu = !{!0}
|
||||
!llvm.module.flags = !{!8, !9}
|
||||
|
||||
!0 = !MDCompileUnit(language: DW_LANG_C99, file: !1, producer: "", isOptimized: false, subprograms: !3)
|
||||
!1 = !MDFile(filename: "test.c", directory: "/home/user/clang/build")
|
||||
!2 = !{}
|
||||
!3 = !{!4}
|
||||
!4 = !MDSubprogram(name: "main", scope: !1, file: !1, line: 2, type: !5, isLocal: false, isDefinition: true, scopeLine: 3, flags: DIFlagPrototyped, isOptimized: false, function: i32 ()* @main, variables: !2)
|
||||
!5 = !MDSubroutineType(types: !6)
|
||||
!6 = !{!7}
|
||||
!7 = !MDBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
||||
!8 = !{i32 2, !"Dwarf Version", i32 4}
|
||||
!9 = !{i32 2, !"Debug Info Version", i32 3}
|
||||
!10 = !{i32 1, !"wchar_size", i32 4}
|
||||
!11 = !MDLocation(line: 4, column: 5, scope: !4)
|
|
@ -0,0 +1,25 @@
|
|||
; RUN: llc -debug < %s 2>&1 | FileCheck %s
|
||||
|
||||
; CHECK: 0x{{[0-9,a-f]+}}: i32 = Constant<-1>test.c:4:5
|
||||
|
||||
define i32 @main() {
|
||||
entry:
|
||||
%retval = alloca i32, align 4
|
||||
store i32 0, i32* %retval
|
||||
ret i32 -1, !dbg !10
|
||||
}
|
||||
|
||||
!llvm.dbg.cu = !{!0}
|
||||
!llvm.module.flags = !{!8, !9}
|
||||
|
||||
!0 = !MDCompileUnit(language: DW_LANG_C99, file: !1, producer: "", isOptimized: false, subprograms: !3)
|
||||
!1 = !MDFile(filename: "test.c", directory: "/home/user/clang-llvm/build")
|
||||
!2 = !{}
|
||||
!3 = !{!4}
|
||||
!4 = !MDSubprogram(name: "main", scope: !1, file: !1, line: 2, type: !5, isLocal: false, isDefinition: true, scopeLine: 3, flags: DIFlagPrototyped, isOptimized: false, function: i32 ()* @main, variables: !2)
|
||||
!5 = !MDSubroutineType(types: !6)
|
||||
!6 = !{!7}
|
||||
!7 = !MDBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
||||
!8 = !{i32 2, !"Dwarf Version", i32 4}
|
||||
!9 = !{i32 2, !"Debug Info Version", i32 3}
|
||||
!10 = !MDLocation(line: 4, column: 5, scope: !4)
|
Loading…
Reference in New Issue