forked from OSchip/llvm-project
parent
af309d29b1
commit
df9ac47e5e
|
@ -2738,9 +2738,8 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
|
||||||
SDNode *PrevStore = Chain.Val;
|
SDNode *PrevStore = Chain.Val;
|
||||||
if (PrevStore->getOperand(1) == Value) // Same value multiply stored.
|
if (PrevStore->getOperand(1) == Value) // Same value multiply stored.
|
||||||
return Chain;
|
return Chain;
|
||||||
SDOperand NewStore = DAG.getNode(ISD::STORE, MVT::Other,
|
SDOperand NewStore = DAG.getStore(PrevStore->getOperand(0), Value, Ptr,
|
||||||
PrevStore->getOperand(0), Value, Ptr,
|
SrcValue);
|
||||||
SrcValue);
|
|
||||||
CombineTo(N, NewStore); // Nuke this store.
|
CombineTo(N, NewStore); // Nuke this store.
|
||||||
CombineTo(PrevStore, NewStore); // Nuke the previous store.
|
CombineTo(PrevStore, NewStore); // Nuke the previous store.
|
||||||
return SDOperand(N, 0);
|
return SDOperand(N, 0);
|
||||||
|
@ -2750,8 +2749,7 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
|
||||||
// FIXME: This needs to know that the resultant store does not need a
|
// FIXME: This needs to know that the resultant store does not need a
|
||||||
// higher alignment than the original.
|
// higher alignment than the original.
|
||||||
if (0 && Value.getOpcode() == ISD::BIT_CONVERT) {
|
if (0 && Value.getOpcode() == ISD::BIT_CONVERT) {
|
||||||
return DAG.getNode(ISD::STORE, MVT::Other, Chain, Value.getOperand(0),
|
return DAG.getStore(Chain, Value.getOperand(0), Ptr, SrcValue);
|
||||||
Ptr, SrcValue);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (CombinerAA) {
|
if (CombinerAA) {
|
||||||
|
@ -2768,9 +2766,7 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
|
||||||
// If there is a better chain.
|
// If there is a better chain.
|
||||||
if (Chain != BetterChain) {
|
if (Chain != BetterChain) {
|
||||||
// Replace the chain to avoid dependency.
|
// Replace the chain to avoid dependency.
|
||||||
SDOperand ReplStore = DAG.getNode(ISD::STORE, MVT::Other,
|
SDOperand ReplStore = DAG.getStore(BetterChain, Value, Ptr, SrcValue);
|
||||||
BetterChain, Value, Ptr,
|
|
||||||
SrcValue);
|
|
||||||
// Create token to keep both nodes around.
|
// Create token to keep both nodes around.
|
||||||
return DAG.getNode(ISD::TokenFactor, MVT::Other, Chain, ReplStore);
|
return DAG.getNode(ISD::TokenFactor, MVT::Other, Chain, ReplStore);
|
||||||
}
|
}
|
||||||
|
|
|
@ -928,8 +928,8 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
||||||
MVT::ValueType PtrVT = TLI.getPointerTy();
|
MVT::ValueType PtrVT = TLI.getPointerTy();
|
||||||
SDOperand StackPtr = CreateStackTemporary(VT);
|
SDOperand StackPtr = CreateStackTemporary(VT);
|
||||||
// Store the vector.
|
// Store the vector.
|
||||||
SDOperand Ch = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand Ch = DAG.getStore(DAG.getEntryNode(),
|
||||||
Tmp1, StackPtr, DAG.getSrcValue(NULL));
|
Tmp1, StackPtr, DAG.getSrcValue(NULL));
|
||||||
|
|
||||||
// Truncate or zero extend offset to target pointer type.
|
// Truncate or zero extend offset to target pointer type.
|
||||||
unsigned CastOpc = (IdxVT > PtrVT) ? ISD::TRUNCATE : ISD::ZERO_EXTEND;
|
unsigned CastOpc = (IdxVT > PtrVT) ? ISD::TRUNCATE : ISD::ZERO_EXTEND;
|
||||||
|
@ -939,8 +939,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
||||||
Tmp3 = DAG.getNode(ISD::MUL, IdxVT, Tmp3,DAG.getConstant(EltSize, IdxVT));
|
Tmp3 = DAG.getNode(ISD::MUL, IdxVT, Tmp3,DAG.getConstant(EltSize, IdxVT));
|
||||||
SDOperand StackPtr2 = DAG.getNode(ISD::ADD, IdxVT, Tmp3, StackPtr);
|
SDOperand StackPtr2 = DAG.getNode(ISD::ADD, IdxVT, Tmp3, StackPtr);
|
||||||
// Store the scalar value.
|
// Store the scalar value.
|
||||||
Ch = DAG.getNode(ISD::STORE, MVT::Other, Ch,
|
Ch = DAG.getStore(Ch, Tmp2, StackPtr2, DAG.getSrcValue(NULL));
|
||||||
Tmp2, StackPtr2, DAG.getSrcValue(NULL));
|
|
||||||
// Load the updated vector.
|
// Load the updated vector.
|
||||||
Result = DAG.getLoad(VT, Ch, StackPtr, DAG.getSrcValue(NULL));
|
Result = DAG.getLoad(VT, Ch, StackPtr, DAG.getSrcValue(NULL));
|
||||||
break;
|
break;
|
||||||
|
@ -1615,8 +1614,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
||||||
assert(CFP->getValueType(0) == MVT::f64 && "Unknown FP type!");
|
assert(CFP->getValueType(0) == MVT::f64 && "Unknown FP type!");
|
||||||
Tmp3 = DAG.getConstant(DoubleToBits(CFP->getValue()), MVT::i64);
|
Tmp3 = DAG.getConstant(DoubleToBits(CFP->getValue()), MVT::i64);
|
||||||
}
|
}
|
||||||
Result = DAG.getNode(ISD::STORE, MVT::Other, Tmp1, Tmp3, Tmp2,
|
Result = DAG.getStore(Tmp1, Tmp3, Tmp2, Node->getOperand(3));
|
||||||
Node->getOperand(3));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1696,16 +1694,14 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
||||||
std::swap(Lo, Hi);
|
std::swap(Lo, Hi);
|
||||||
}
|
}
|
||||||
|
|
||||||
Lo = DAG.getNode(ISD::STORE, MVT::Other, Tmp1, Lo, Tmp2,
|
Lo = DAG.getStore(Tmp1, Lo, Tmp2, Node->getOperand(3));
|
||||||
Node->getOperand(3));
|
|
||||||
Tmp2 = DAG.getNode(ISD::ADD, Tmp2.getValueType(), Tmp2,
|
Tmp2 = DAG.getNode(ISD::ADD, Tmp2.getValueType(), Tmp2,
|
||||||
getIntPtrConstant(IncrementSize));
|
getIntPtrConstant(IncrementSize));
|
||||||
assert(isTypeLegal(Tmp2.getValueType()) &&
|
assert(isTypeLegal(Tmp2.getValueType()) &&
|
||||||
"Pointers must be legal!");
|
"Pointers must be legal!");
|
||||||
// FIXME: This sets the srcvalue of both halves to be the same, which is
|
// FIXME: This sets the srcvalue of both halves to be the same, which is
|
||||||
// wrong.
|
// wrong.
|
||||||
Hi = DAG.getNode(ISD::STORE, MVT::Other, Tmp1, Hi, Tmp2,
|
Hi = DAG.getStore(Tmp1, Hi, Tmp2, Node->getOperand(3));
|
||||||
Node->getOperand(3));
|
|
||||||
Result = DAG.getNode(ISD::TokenFactor, MVT::Other, Lo, Hi);
|
Result = DAG.getNode(ISD::TokenFactor, MVT::Other, Lo, Hi);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2398,8 +2394,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
||||||
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
||||||
TLI.getPointerTy()));
|
TLI.getPointerTy()));
|
||||||
// Store the incremented VAList to the legalized pointer
|
// Store the incremented VAList to the legalized pointer
|
||||||
Tmp3 = DAG.getNode(ISD::STORE, MVT::Other, VAList.getValue(1), Tmp3, Tmp2,
|
Tmp3 = DAG.getStore(VAList.getValue(1), Tmp3, Tmp2, Node->getOperand(2));
|
||||||
Node->getOperand(2));
|
|
||||||
// Load the actual argument out of the pointer VAList
|
// Load the actual argument out of the pointer VAList
|
||||||
Result = DAG.getLoad(VT, Tmp3, VAList, DAG.getSrcValue(0));
|
Result = DAG.getLoad(VT, Tmp3, VAList, DAG.getSrcValue(0));
|
||||||
Tmp1 = LegalizeOp(Result.getValue(1));
|
Tmp1 = LegalizeOp(Result.getValue(1));
|
||||||
|
@ -2436,8 +2431,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
||||||
// This defaults to loading a pointer from the input and storing it to the
|
// This defaults to loading a pointer from the input and storing it to the
|
||||||
// output, returning the chain.
|
// output, returning the chain.
|
||||||
Tmp4 = DAG.getLoad(TLI.getPointerTy(), Tmp1, Tmp3, Node->getOperand(3));
|
Tmp4 = DAG.getLoad(TLI.getPointerTy(), Tmp1, Tmp3, Node->getOperand(3));
|
||||||
Result = DAG.getNode(ISD::STORE, MVT::Other, Tmp4.getValue(1), Tmp4, Tmp2,
|
Result = DAG.getStore(Tmp4.getValue(1), Tmp4, Tmp2, Node->getOperand(4));
|
||||||
Node->getOperand(4));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -3225,8 +3219,7 @@ SDOperand SelectionDAGLegalize::PromoteOp(SDOperand Op) {
|
||||||
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
||||||
TLI.getPointerTy()));
|
TLI.getPointerTy()));
|
||||||
// Store the incremented VAList to the legalized pointer
|
// Store the incremented VAList to the legalized pointer
|
||||||
Tmp3 = DAG.getNode(ISD::STORE, MVT::Other, VAList.getValue(1), Tmp3, Tmp2,
|
Tmp3 = DAG.getStore(VAList.getValue(1), Tmp3, Tmp2, Node->getOperand(2));
|
||||||
Node->getOperand(2));
|
|
||||||
// Load the actual argument out of the pointer VAList
|
// Load the actual argument out of the pointer VAList
|
||||||
Result = DAG.getExtLoad(ISD::EXTLOAD, NVT, Tmp3, VAList,
|
Result = DAG.getExtLoad(ISD::EXTLOAD, NVT, Tmp3, VAList,
|
||||||
DAG.getSrcValue(0), VT);
|
DAG.getSrcValue(0), VT);
|
||||||
|
@ -3368,8 +3361,8 @@ SDOperand SelectionDAGLegalize::ExpandEXTRACT_VECTOR_ELT(SDOperand Op) {
|
||||||
// If the target doesn't support this, store the value to a temporary
|
// If the target doesn't support this, store the value to a temporary
|
||||||
// stack slot, then LOAD the scalar element back out.
|
// stack slot, then LOAD the scalar element back out.
|
||||||
SDOperand StackPtr = CreateStackTemporary(Vector.getValueType());
|
SDOperand StackPtr = CreateStackTemporary(Vector.getValueType());
|
||||||
SDOperand Ch = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand Ch = DAG.getStore(DAG.getEntryNode(),
|
||||||
Vector, StackPtr, DAG.getSrcValue(NULL));
|
Vector, StackPtr, DAG.getSrcValue(NULL));
|
||||||
|
|
||||||
// Add the offset to the index.
|
// Add the offset to the index.
|
||||||
unsigned EltSize = MVT::getSizeInBits(Op.getValueType())/8;
|
unsigned EltSize = MVT::getSizeInBits(Op.getValueType())/8;
|
||||||
|
@ -3512,8 +3505,8 @@ SDOperand SelectionDAGLegalize::ExpandBIT_CONVERT(MVT::ValueType DestVT,
|
||||||
SDOperand FIPtr = CreateStackTemporary(DestVT);
|
SDOperand FIPtr = CreateStackTemporary(DestVT);
|
||||||
|
|
||||||
// Emit a store to the stack slot.
|
// Emit a store to the stack slot.
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand Store = DAG.getStore(DAG.getEntryNode(),
|
||||||
SrcOp, FIPtr, DAG.getSrcValue(NULL));
|
SrcOp, FIPtr, DAG.getSrcValue(NULL));
|
||||||
// Result is a load from the stack slot.
|
// Result is a load from the stack slot.
|
||||||
return DAG.getLoad(DestVT, Store, FIPtr, DAG.getSrcValue(0));
|
return DAG.getLoad(DestVT, Store, FIPtr, DAG.getSrcValue(0));
|
||||||
}
|
}
|
||||||
|
@ -3522,9 +3515,8 @@ SDOperand SelectionDAGLegalize::ExpandSCALAR_TO_VECTOR(SDNode *Node) {
|
||||||
// Create a vector sized/aligned stack slot, store the value to element #0,
|
// Create a vector sized/aligned stack slot, store the value to element #0,
|
||||||
// then load the whole vector back out.
|
// then load the whole vector back out.
|
||||||
SDOperand StackPtr = CreateStackTemporary(Node->getValueType(0));
|
SDOperand StackPtr = CreateStackTemporary(Node->getValueType(0));
|
||||||
SDOperand Ch = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand Ch = DAG.getStore(DAG.getEntryNode(), Node->getOperand(0), StackPtr,
|
||||||
Node->getOperand(0), StackPtr,
|
DAG.getSrcValue(NULL));
|
||||||
DAG.getSrcValue(NULL));
|
|
||||||
return DAG.getLoad(Node->getValueType(0), Ch, StackPtr,DAG.getSrcValue(NULL));
|
return DAG.getLoad(Node->getValueType(0), Ch, StackPtr,DAG.getSrcValue(NULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3673,9 +3665,8 @@ SDOperand SelectionDAGLegalize::ExpandBUILD_VECTOR(SDNode *Node) {
|
||||||
SDOperand Idx = DAG.getConstant(Offset, FIPtr.getValueType());
|
SDOperand Idx = DAG.getConstant(Offset, FIPtr.getValueType());
|
||||||
Idx = DAG.getNode(ISD::ADD, FIPtr.getValueType(), FIPtr, Idx);
|
Idx = DAG.getNode(ISD::ADD, FIPtr.getValueType(), FIPtr, Idx);
|
||||||
|
|
||||||
Stores.push_back(DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
Stores.push_back(DAG.getStore(DAG.getEntryNode(), Node->getOperand(i), Idx,
|
||||||
Node->getOperand(i), Idx,
|
DAG.getSrcValue(NULL)));
|
||||||
DAG.getSrcValue(NULL)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand StoreChain;
|
SDOperand StoreChain;
|
||||||
|
@ -4019,13 +4010,12 @@ SDOperand SelectionDAGLegalize::ExpandLegalINT_TO_FP(bool isSigned,
|
||||||
Op0Mapped = Op0;
|
Op0Mapped = Op0;
|
||||||
}
|
}
|
||||||
// store the lo of the constructed double - based on integer input
|
// store the lo of the constructed double - based on integer input
|
||||||
SDOperand Store1 = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand Store1 = DAG.getStore(DAG.getEntryNode(),
|
||||||
Op0Mapped, Lo, DAG.getSrcValue(NULL));
|
Op0Mapped, Lo, DAG.getSrcValue(NULL));
|
||||||
// initial hi portion of constructed double
|
// initial hi portion of constructed double
|
||||||
SDOperand InitialHi = DAG.getConstant(0x43300000u, MVT::i32);
|
SDOperand InitialHi = DAG.getConstant(0x43300000u, MVT::i32);
|
||||||
// store the hi of the constructed double - biased exponent
|
// store the hi of the constructed double - biased exponent
|
||||||
SDOperand Store2 = DAG.getNode(ISD::STORE, MVT::Other, Store1,
|
SDOperand Store2=DAG.getStore(Store1, InitialHi, Hi, DAG.getSrcValue(NULL));
|
||||||
InitialHi, Hi, DAG.getSrcValue(NULL));
|
|
||||||
// load the constructed double
|
// load the constructed double
|
||||||
SDOperand Load = DAG.getLoad(MVT::f64, Store2, StackSlot,
|
SDOperand Load = DAG.getLoad(MVT::f64, Store2, StackSlot,
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
|
@ -4925,8 +4915,8 @@ void SelectionDAGLegalize::SplitVectorOp(SDOperand Op, SDOperand &Lo,
|
||||||
// Lower to a store/load. FIXME: this could be improved probably.
|
// Lower to a store/load. FIXME: this could be improved probably.
|
||||||
SDOperand Ptr = CreateStackTemporary(Op.getOperand(0).getValueType());
|
SDOperand Ptr = CreateStackTemporary(Op.getOperand(0).getValueType());
|
||||||
|
|
||||||
SDOperand St = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand St = DAG.getStore(DAG.getEntryNode(),
|
||||||
Op.getOperand(0), Ptr, DAG.getSrcValue(0));
|
Op.getOperand(0), Ptr, DAG.getSrcValue(0));
|
||||||
MVT::ValueType EVT = cast<VTSDNode>(TypeNode)->getVT();
|
MVT::ValueType EVT = cast<VTSDNode>(TypeNode)->getVT();
|
||||||
St = DAG.getVecLoad(NumElements, EVT, St, Ptr, DAG.getSrcValue(0));
|
St = DAG.getVecLoad(NumElements, EVT, St, Ptr, DAG.getSrcValue(0));
|
||||||
SplitVectorOp(St, Lo, Hi);
|
SplitVectorOp(St, Lo, Hi);
|
||||||
|
|
|
@ -1393,8 +1393,8 @@ void SelectionDAGLowering::visitStore(StoreInst &I) {
|
||||||
Value *SrcV = I.getOperand(0);
|
Value *SrcV = I.getOperand(0);
|
||||||
SDOperand Src = getValue(SrcV);
|
SDOperand Src = getValue(SrcV);
|
||||||
SDOperand Ptr = getValue(I.getOperand(1));
|
SDOperand Ptr = getValue(I.getOperand(1));
|
||||||
DAG.setRoot(DAG.getNode(ISD::STORE, MVT::Other, getRoot(), Src, Ptr,
|
DAG.setRoot(DAG.getStore(getRoot(), Src, Ptr,
|
||||||
DAG.getSrcValue(I.getOperand(1))));
|
DAG.getSrcValue(I.getOperand(1))));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// IntrinsicCannotAccessMemory - Return true if the specified intrinsic cannot
|
/// IntrinsicCannotAccessMemory - Return true if the specified intrinsic cannot
|
||||||
|
@ -2285,8 +2285,7 @@ void SelectionDAGLowering::visitInlineAsm(CallInst &I) {
|
||||||
// Emit the non-flagged stores from the physregs.
|
// Emit the non-flagged stores from the physregs.
|
||||||
SmallVector<SDOperand, 8> OutChains;
|
SmallVector<SDOperand, 8> OutChains;
|
||||||
for (unsigned i = 0, e = StoresToEmit.size(); i != e; ++i)
|
for (unsigned i = 0, e = StoresToEmit.size(); i != e; ++i)
|
||||||
OutChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
OutChains.push_back(DAG.getStore(Chain, StoresToEmit[i].first,
|
||||||
StoresToEmit[i].first,
|
|
||||||
getValue(StoresToEmit[i].second),
|
getValue(StoresToEmit[i].second),
|
||||||
DAG.getSrcValue(StoresToEmit[i].second)));
|
DAG.getSrcValue(StoresToEmit[i].second)));
|
||||||
if (!OutChains.empty())
|
if (!OutChains.empty())
|
||||||
|
@ -2863,8 +2862,7 @@ void SelectionDAGLowering::visitMemIntrinsic(CallInst &I, unsigned Op) {
|
||||||
MVT::ValueType VT = MemOps[i];
|
MVT::ValueType VT = MemOps[i];
|
||||||
unsigned VTSize = getSizeInBits(VT) / 8;
|
unsigned VTSize = getSizeInBits(VT) / 8;
|
||||||
SDOperand Value = getMemsetValue(Op2, VT, DAG);
|
SDOperand Value = getMemsetValue(Op2, VT, DAG);
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, getRoot(),
|
SDOperand Store = DAG.getStore(getRoot(), Value,
|
||||||
Value,
|
|
||||||
getMemBasePlusOffset(Op1, Offset, DAG, TLI),
|
getMemBasePlusOffset(Op1, Offset, DAG, TLI),
|
||||||
DAG.getSrcValue(I.getOperand(1), Offset));
|
DAG.getSrcValue(I.getOperand(1), Offset));
|
||||||
OutChains.push_back(Store);
|
OutChains.push_back(Store);
|
||||||
|
@ -2910,18 +2908,18 @@ void SelectionDAGLowering::visitMemIntrinsic(CallInst &I, unsigned Op) {
|
||||||
Value = getMemsetStringVal(VT, DAG, TLI, Str, SrcOff);
|
Value = getMemsetStringVal(VT, DAG, TLI, Str, SrcOff);
|
||||||
Chain = getRoot();
|
Chain = getRoot();
|
||||||
Store =
|
Store =
|
||||||
DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
DAG.getStore(Chain, Value,
|
||||||
getMemBasePlusOffset(Op1, DstOff, DAG, TLI),
|
getMemBasePlusOffset(Op1, DstOff, DAG, TLI),
|
||||||
DAG.getSrcValue(I.getOperand(1), DstOff));
|
DAG.getSrcValue(I.getOperand(1), DstOff));
|
||||||
} else {
|
} else {
|
||||||
Value = DAG.getLoad(VT, getRoot(),
|
Value = DAG.getLoad(VT, getRoot(),
|
||||||
getMemBasePlusOffset(Op2, SrcOff, DAG, TLI),
|
getMemBasePlusOffset(Op2, SrcOff, DAG, TLI),
|
||||||
DAG.getSrcValue(I.getOperand(2), SrcOff));
|
DAG.getSrcValue(I.getOperand(2), SrcOff));
|
||||||
Chain = Value.getValue(1);
|
Chain = Value.getValue(1);
|
||||||
Store =
|
Store =
|
||||||
DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
DAG.getStore(Chain, Value,
|
||||||
getMemBasePlusOffset(Op1, DstOff, DAG, TLI),
|
getMemBasePlusOffset(Op1, DstOff, DAG, TLI),
|
||||||
DAG.getSrcValue(I.getOperand(1), DstOff));
|
DAG.getSrcValue(I.getOperand(1), DstOff));
|
||||||
}
|
}
|
||||||
OutChains.push_back(Store);
|
OutChains.push_back(Store);
|
||||||
SrcOff += VTSize;
|
SrcOff += VTSize;
|
||||||
|
|
|
@ -242,8 +242,8 @@ static SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG) {
|
||||||
unsigned ArgOffset = Layout.getOffset(i);
|
unsigned ArgOffset = Layout.getOffset(i);
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, StackPtr.getValueType());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, StackPtr.getValueType());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, MVT::i32, StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, MVT::i32, StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
}
|
}
|
||||||
if (!MemOpChains.empty())
|
if (!MemOpChains.empty())
|
||||||
Chain = DAG.getNode(ISD::TokenFactor, MVT::Other,
|
Chain = DAG.getNode(ISD::TokenFactor, MVT::Other,
|
||||||
|
@ -390,8 +390,7 @@ static SDOperand LowerVASTART(SDOperand Op, SelectionDAG &DAG,
|
||||||
// memory location argument.
|
// memory location argument.
|
||||||
MVT::ValueType PtrVT = DAG.getTargetLoweringInfo().getPointerTy();
|
MVT::ValueType PtrVT = DAG.getTargetLoweringInfo().getPointerTy();
|
||||||
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, PtrVT);
|
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, PtrVT);
|
||||||
return DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0), FR,
|
return DAG.getStore(Op.getOperand(0), FR, Op.getOperand(1), Op.getOperand(2));
|
||||||
Op.getOperand(1), Op.getOperand(2));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
||||||
|
@ -467,8 +466,8 @@ static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
||||||
MF.addLiveIn(REGS[RegNo], VReg);
|
MF.addLiveIn(REGS[RegNo], VReg);
|
||||||
|
|
||||||
SDOperand Val = DAG.getCopyFromReg(Root, VReg, MVT::i32);
|
SDOperand Val = DAG.getCopyFromReg(Root, VReg, MVT::i32);
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1),
|
SDOperand Store = DAG.getStore(Val.getValue(1), Val, FIN,
|
||||||
Val, FIN, DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
}
|
}
|
||||||
Root = DAG.getNode(ISD::TokenFactor, MVT::Other,&MemOps[0],MemOps.size());
|
Root = DAG.getNode(ISD::TokenFactor, MVT::Other,&MemOps[0],MemOps.size());
|
||||||
|
|
|
@ -269,16 +269,14 @@ static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
||||||
int FI = MFI->CreateFixedObject(8, -8 * (6 - i));
|
int FI = MFI->CreateFixedObject(8, -8 * (6 - i));
|
||||||
if (i == 0) VarArgsBase = FI;
|
if (i == 0) VarArgsBase = FI;
|
||||||
SDOperand SDFI = DAG.getFrameIndex(FI, MVT::i64);
|
SDOperand SDFI = DAG.getFrameIndex(FI, MVT::i64);
|
||||||
LS.push_back(DAG.getNode(ISD::STORE, MVT::Other, Root, argt,
|
LS.push_back(DAG.getStore(Root, argt, SDFI, DAG.getSrcValue(NULL)));
|
||||||
SDFI, DAG.getSrcValue(NULL)));
|
|
||||||
|
|
||||||
if (MRegisterInfo::isPhysicalRegister(args_float[i]))
|
if (MRegisterInfo::isPhysicalRegister(args_float[i]))
|
||||||
args_float[i] = AddLiveIn(MF, args_float[i], &Alpha::F8RCRegClass);
|
args_float[i] = AddLiveIn(MF, args_float[i], &Alpha::F8RCRegClass);
|
||||||
argt = DAG.getCopyFromReg(Root, args_float[i], MVT::f64);
|
argt = DAG.getCopyFromReg(Root, args_float[i], MVT::f64);
|
||||||
FI = MFI->CreateFixedObject(8, - 8 * (12 - i));
|
FI = MFI->CreateFixedObject(8, - 8 * (12 - i));
|
||||||
SDFI = DAG.getFrameIndex(FI, MVT::i64);
|
SDFI = DAG.getFrameIndex(FI, MVT::i64);
|
||||||
LS.push_back(DAG.getNode(ISD::STORE, MVT::Other, Root, argt,
|
LS.push_back(DAG.getStore(Root, argt, SDFI, DAG.getSrcValue(NULL)));
|
||||||
SDFI, DAG.getSrcValue(NULL)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Set up a token factor with all the stack traffic
|
//Set up a token factor with all the stack traffic
|
||||||
|
@ -428,8 +426,8 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
int FrameIdx =
|
int FrameIdx =
|
||||||
DAG.getMachineFunction().getFrameInfo()->CreateStackObject(8, 8);
|
DAG.getMachineFunction().getFrameInfo()->CreateStackObject(8, 8);
|
||||||
SDOperand FI = DAG.getFrameIndex(FrameIdx, MVT::i64);
|
SDOperand FI = DAG.getFrameIndex(FrameIdx, MVT::i64);
|
||||||
SDOperand ST = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand ST = DAG.getStore(DAG.getEntryNode(),
|
||||||
Op.getOperand(0), FI, DAG.getSrcValue(0));
|
Op.getOperand(0), FI, DAG.getSrcValue(0));
|
||||||
LD = DAG.getLoad(MVT::f64, ST, FI, DAG.getSrcValue(0));
|
LD = DAG.getLoad(MVT::f64, ST, FI, DAG.getSrcValue(0));
|
||||||
}
|
}
|
||||||
SDOperand FP = DAG.getNode(isDouble?AlphaISD::CVTQT_:AlphaISD::CVTQS_,
|
SDOperand FP = DAG.getNode(isDouble?AlphaISD::CVTQT_:AlphaISD::CVTQS_,
|
||||||
|
@ -451,8 +449,8 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
int FrameIdx =
|
int FrameIdx =
|
||||||
DAG.getMachineFunction().getFrameInfo()->CreateStackObject(8, 8);
|
DAG.getMachineFunction().getFrameInfo()->CreateStackObject(8, 8);
|
||||||
SDOperand FI = DAG.getFrameIndex(FrameIdx, MVT::i64);
|
SDOperand FI = DAG.getFrameIndex(FrameIdx, MVT::i64);
|
||||||
SDOperand ST = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand ST = DAG.getStore(DAG.getEntryNode(),
|
||||||
src, FI, DAG.getSrcValue(0));
|
src, FI, DAG.getSrcValue(0));
|
||||||
return DAG.getLoad(MVT::i64, ST, FI, DAG.getSrcValue(0));
|
return DAG.getLoad(MVT::i64, ST, FI, DAG.getSrcValue(0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -565,8 +563,7 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
SDOperand SrcS = Op.getOperand(4);
|
SDOperand SrcS = Op.getOperand(4);
|
||||||
|
|
||||||
SDOperand Val = DAG.getLoad(getPointerTy(), Chain, SrcP, SrcS);
|
SDOperand Val = DAG.getLoad(getPointerTy(), Chain, SrcP, SrcS);
|
||||||
SDOperand Result = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1), Val,
|
SDOperand Result = DAG.getStore(Val.getValue(1), Val, DestP, DestS);
|
||||||
DestP, DestS);
|
|
||||||
SDOperand NP = DAG.getNode(ISD::ADD, MVT::i64, SrcP,
|
SDOperand NP = DAG.getNode(ISD::ADD, MVT::i64, SrcP,
|
||||||
DAG.getConstant(8, MVT::i64));
|
DAG.getConstant(8, MVT::i64));
|
||||||
Val = DAG.getExtLoad(ISD::SEXTLOAD, MVT::i64, Result, NP,
|
Val = DAG.getExtLoad(ISD::SEXTLOAD, MVT::i64, Result, NP,
|
||||||
|
@ -583,8 +580,7 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
|
|
||||||
// vastart stores the address of the VarArgsBase and VarArgsOffset
|
// vastart stores the address of the VarArgsBase and VarArgsOffset
|
||||||
SDOperand FR = DAG.getFrameIndex(VarArgsBase, MVT::i64);
|
SDOperand FR = DAG.getFrameIndex(VarArgsBase, MVT::i64);
|
||||||
SDOperand S1 = DAG.getNode(ISD::STORE, MVT::Other, Chain, FR, VAListP,
|
SDOperand S1 = DAG.getStore(Chain, FR, VAListP, VAListS);
|
||||||
VAListS);
|
|
||||||
SDOperand SA2 = DAG.getNode(ISD::ADD, MVT::i64, VAListP,
|
SDOperand SA2 = DAG.getNode(ISD::ADD, MVT::i64, VAListP,
|
||||||
DAG.getConstant(8, MVT::i64));
|
DAG.getConstant(8, MVT::i64));
|
||||||
return DAG.getNode(ISD::TRUNCSTORE, MVT::Other, S1,
|
return DAG.getNode(ISD::TRUNCSTORE, MVT::Other, S1,
|
||||||
|
|
|
@ -387,8 +387,7 @@ IA64TargetLowering::LowerCallTo(SDOperand Chain,
|
||||||
}
|
}
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, MVT::i64, StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, MVT::i64, StackPtr, PtrOff);
|
||||||
Stores.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
Stores.push_back(DAG.getStore(Chain, ValToStore, PtrOff, NullSV));
|
||||||
ValToStore, PtrOff, NullSV));
|
|
||||||
ArgOffset += ObjSize;
|
ArgOffset += ObjSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -591,8 +590,8 @@ LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
||||||
VT));
|
VT));
|
||||||
// Store the incremented VAList to the legalized pointer
|
// Store the incremented VAList to the legalized pointer
|
||||||
VAIncr = DAG.getNode(ISD::STORE, MVT::Other, VAList.getValue(1), VAIncr,
|
VAIncr = DAG.getStore(VAList.getValue(1), VAIncr,
|
||||||
Op.getOperand(1), Op.getOperand(2));
|
Op.getOperand(1), Op.getOperand(2));
|
||||||
// Load the actual argument out of the pointer VAList
|
// Load the actual argument out of the pointer VAList
|
||||||
return DAG.getLoad(Op.getValueType(), VAIncr, VAList, DAG.getSrcValue(0));
|
return DAG.getLoad(Op.getValueType(), VAIncr, VAList, DAG.getSrcValue(0));
|
||||||
}
|
}
|
||||||
|
@ -600,8 +599,8 @@ LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
// vastart just stores the address of the VarArgsFrameIndex slot into the
|
// vastart just stores the address of the VarArgsFrameIndex slot into the
|
||||||
// memory location argument.
|
// memory location argument.
|
||||||
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, MVT::i64);
|
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, MVT::i64);
|
||||||
return DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0), FR,
|
return DAG.getStore(Op.getOperand(0), FR,
|
||||||
Op.getOperand(1), Op.getOperand(2));
|
Op.getOperand(1), Op.getOperand(2));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -743,8 +743,7 @@ static SDOperand LowerVASTART(SDOperand Op, SelectionDAG &DAG,
|
||||||
// memory location argument.
|
// memory location argument.
|
||||||
MVT::ValueType PtrVT = DAG.getTargetLoweringInfo().getPointerTy();
|
MVT::ValueType PtrVT = DAG.getTargetLoweringInfo().getPointerTy();
|
||||||
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, PtrVT);
|
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, PtrVT);
|
||||||
return DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0), FR,
|
return DAG.getStore(Op.getOperand(0), FR, Op.getOperand(1), Op.getOperand(2));
|
||||||
Op.getOperand(1), Op.getOperand(2));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
||||||
|
@ -900,8 +899,8 @@ static SDOperand LowerFORMAL_ARGUMENTS(SDOperand Op, SelectionDAG &DAG,
|
||||||
unsigned VReg = RegMap->createVirtualRegister(&PPC::GPRCRegClass);
|
unsigned VReg = RegMap->createVirtualRegister(&PPC::GPRCRegClass);
|
||||||
MF.addLiveIn(GPR[GPR_idx], VReg);
|
MF.addLiveIn(GPR[GPR_idx], VReg);
|
||||||
SDOperand Val = DAG.getCopyFromReg(Root, VReg, PtrVT);
|
SDOperand Val = DAG.getCopyFromReg(Root, VReg, PtrVT);
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1),
|
SDOperand Store = DAG.getStore(Val.getValue(1), Val, FIN,
|
||||||
Val, FIN, DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
// Increment the address by four for the next argument to store
|
// Increment the address by four for the next argument to store
|
||||||
SDOperand PtrOff = DAG.getConstant(MVT::getSizeInBits(PtrVT)/8, PtrVT);
|
SDOperand PtrOff = DAG.getConstant(MVT::getSizeInBits(PtrVT)/8, PtrVT);
|
||||||
|
@ -1035,8 +1034,8 @@ static SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG) {
|
||||||
if (GPR_idx != NumGPRs) {
|
if (GPR_idx != NumGPRs) {
|
||||||
RegsToPass.push_back(std::make_pair(GPR[GPR_idx++], Arg));
|
RegsToPass.push_back(std::make_pair(GPR[GPR_idx++], Arg));
|
||||||
} else {
|
} else {
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
}
|
}
|
||||||
ArgOffset += PtrByteSize;
|
ArgOffset += PtrByteSize;
|
||||||
break;
|
break;
|
||||||
|
@ -1046,9 +1045,8 @@ static SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG) {
|
||||||
RegsToPass.push_back(std::make_pair(FPR[FPR_idx++], Arg));
|
RegsToPass.push_back(std::make_pair(FPR[FPR_idx++], Arg));
|
||||||
|
|
||||||
if (isVarArg) {
|
if (isVarArg) {
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
SDOperand Store = DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff,
|
DAG.getSrcValue(NULL));
|
||||||
DAG.getSrcValue(NULL));
|
|
||||||
MemOpChains.push_back(Store);
|
MemOpChains.push_back(Store);
|
||||||
|
|
||||||
// Float varargs are always shadowed in available integer registers
|
// Float varargs are always shadowed in available integer registers
|
||||||
|
@ -1076,8 +1074,8 @@ static SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG) {
|
||||||
++GPR_idx;
|
++GPR_idx;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
}
|
}
|
||||||
if (isPPC64)
|
if (isPPC64)
|
||||||
ArgOffset += 8;
|
ArgOffset += 8;
|
||||||
|
@ -2123,8 +2121,8 @@ static SDOperand LowerSCALAR_TO_VECTOR(SDOperand Op, SelectionDAG &DAG) {
|
||||||
SDOperand FIdx = DAG.getFrameIndex(FrameIdx, PtrVT);
|
SDOperand FIdx = DAG.getFrameIndex(FrameIdx, PtrVT);
|
||||||
|
|
||||||
// Store the input value into Value#0 of the stack slot.
|
// Store the input value into Value#0 of the stack slot.
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, DAG.getEntryNode(),
|
SDOperand Store = DAG.getStore(DAG.getEntryNode(),
|
||||||
Op.getOperand(0), FIdx,DAG.getSrcValue(NULL));
|
Op.getOperand(0), FIdx,DAG.getSrcValue(NULL));
|
||||||
// Load it out.
|
// Load it out.
|
||||||
return DAG.getLoad(Op.getValueType(), Store, FIdx, DAG.getSrcValue(NULL));
|
return DAG.getLoad(Op.getValueType(), Store, FIdx, DAG.getSrcValue(NULL));
|
||||||
}
|
}
|
||||||
|
|
|
@ -437,8 +437,8 @@ SparcTargetLowering::LowerArguments(Function &F, SelectionDAG &DAG) {
|
||||||
int FrameIdx = MF.getFrameInfo()->CreateFixedObject(4, ArgOffset);
|
int FrameIdx = MF.getFrameInfo()->CreateFixedObject(4, ArgOffset);
|
||||||
SDOperand FIPtr = DAG.getFrameIndex(FrameIdx, MVT::i32);
|
SDOperand FIPtr = DAG.getFrameIndex(FrameIdx, MVT::i32);
|
||||||
|
|
||||||
OutChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, DAG.getRoot(),
|
OutChains.push_back(DAG.getStore(DAG.getRoot(),
|
||||||
Arg, FIPtr, DAG.getSrcValue(0)));
|
Arg, FIPtr, DAG.getSrcValue(0)));
|
||||||
ArgOffset += 4;
|
ArgOffset += 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -589,8 +589,7 @@ SparcTargetLowering::LowerCallTo(SDOperand Chain, const Type *RetTy,
|
||||||
}
|
}
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, MVT::i32, StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, MVT::i32, StackPtr, PtrOff);
|
||||||
Stores.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
Stores.push_back(DAG.getStore(Chain, ValToStore, PtrOff, NullSV));
|
||||||
ValToStore, PtrOff, NullSV));
|
|
||||||
}
|
}
|
||||||
ArgOffset += ObjSize;
|
ArgOffset += ObjSize;
|
||||||
}
|
}
|
||||||
|
@ -787,8 +786,8 @@ LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
SDOperand Offset = DAG.getNode(ISD::ADD, MVT::i32,
|
SDOperand Offset = DAG.getNode(ISD::ADD, MVT::i32,
|
||||||
DAG.getRegister(SP::I6, MVT::i32),
|
DAG.getRegister(SP::I6, MVT::i32),
|
||||||
DAG.getConstant(VarArgsFrameOffset, MVT::i32));
|
DAG.getConstant(VarArgsFrameOffset, MVT::i32));
|
||||||
return DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0), Offset,
|
return DAG.getStore(Op.getOperand(0), Offset,
|
||||||
Op.getOperand(1), Op.getOperand(2));
|
Op.getOperand(1), Op.getOperand(2));
|
||||||
}
|
}
|
||||||
case ISD::VAARG: {
|
case ISD::VAARG: {
|
||||||
SDNode *Node = Op.Val;
|
SDNode *Node = Op.Val;
|
||||||
|
@ -802,8 +801,8 @@ LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
||||||
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
DAG.getConstant(MVT::getSizeInBits(VT)/8,
|
||||||
getPointerTy()));
|
getPointerTy()));
|
||||||
// Store the incremented VAList to the legalized pointer
|
// Store the incremented VAList to the legalized pointer
|
||||||
InChain = DAG.getNode(ISD::STORE, MVT::Other, VAList.getValue(1), NextPtr,
|
InChain = DAG.getStore(VAList.getValue(1), NextPtr,
|
||||||
VAListPtr, Node->getOperand(2));
|
VAListPtr, Node->getOperand(2));
|
||||||
// Load the actual argument out of the pointer VAList, unless this is an
|
// Load the actual argument out of the pointer VAList, unless this is an
|
||||||
// f64 load.
|
// f64 load.
|
||||||
if (VT != MVT::f64) {
|
if (VT != MVT::f64) {
|
||||||
|
|
|
@ -599,8 +599,8 @@ SDOperand X86TargetLowering::LowerCCCCallTo(SDOperand Op, SelectionDAG &DAG) {
|
||||||
case MVT::f32: {
|
case MVT::f32: {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 4;
|
ArgOffset += 4;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -608,8 +608,8 @@ SDOperand X86TargetLowering::LowerCCCCallTo(SDOperand Op, SelectionDAG &DAG) {
|
||||||
case MVT::f64: {
|
case MVT::f64: {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 8;
|
ArgOffset += 8;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -627,8 +627,8 @@ SDOperand X86TargetLowering::LowerCCCCallTo(SDOperand Op, SelectionDAG &DAG) {
|
||||||
ArgOffset = ((ArgOffset + 15) / 16) * 16;
|
ArgOffset = ((ArgOffset + 15) / 16) * 16;
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 16;
|
ArgOffset += 16;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -991,8 +991,8 @@ X86TargetLowering::LowerX86_64CCCArguments(SDOperand Op, SelectionDAG &DAG) {
|
||||||
unsigned VReg = AddLiveIn(MF, GPR64ArgRegs[NumIntRegs],
|
unsigned VReg = AddLiveIn(MF, GPR64ArgRegs[NumIntRegs],
|
||||||
X86::GR64RegisterClass);
|
X86::GR64RegisterClass);
|
||||||
SDOperand Val = DAG.getCopyFromReg(Root, VReg, MVT::i64);
|
SDOperand Val = DAG.getCopyFromReg(Root, VReg, MVT::i64);
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1),
|
SDOperand Store = DAG.getStore(Val.getValue(1), Val, FIN,
|
||||||
Val, FIN, DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
||||||
DAG.getConstant(8, getPointerTy()));
|
DAG.getConstant(8, getPointerTy()));
|
||||||
|
@ -1005,8 +1005,8 @@ X86TargetLowering::LowerX86_64CCCArguments(SDOperand Op, SelectionDAG &DAG) {
|
||||||
unsigned VReg = AddLiveIn(MF, XMMArgRegs[NumXMMRegs],
|
unsigned VReg = AddLiveIn(MF, XMMArgRegs[NumXMMRegs],
|
||||||
X86::VR128RegisterClass);
|
X86::VR128RegisterClass);
|
||||||
SDOperand Val = DAG.getCopyFromReg(Root, VReg, MVT::v4f32);
|
SDOperand Val = DAG.getCopyFromReg(Root, VReg, MVT::v4f32);
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1),
|
SDOperand Store = DAG.getStore(Val.getValue(1), Val, FIN,
|
||||||
Val, FIN, DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
||||||
DAG.getConstant(16, getPointerTy()));
|
DAG.getConstant(16, getPointerTy()));
|
||||||
|
@ -1129,8 +1129,8 @@ X86TargetLowering::LowerX86_64CCCCallTo(SDOperand Op, SelectionDAG &DAG) {
|
||||||
} else {
|
} else {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 8;
|
ArgOffset += 8;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1152,8 +1152,8 @@ X86TargetLowering::LowerX86_64CCCCallTo(SDOperand Op, SelectionDAG &DAG) {
|
||||||
}
|
}
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
if (ArgVT == MVT::f32 || ArgVT == MVT::f64)
|
if (ArgVT == MVT::f32 || ArgVT == MVT::f64)
|
||||||
ArgOffset += 8;
|
ArgOffset += 8;
|
||||||
else
|
else
|
||||||
|
@ -1635,16 +1635,16 @@ SDOperand X86TargetLowering::LowerFastCCCallTo(SDOperand Op, SelectionDAG &DAG,
|
||||||
case MVT::f32: {
|
case MVT::f32: {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 4;
|
ArgOffset += 4;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case MVT::f64: {
|
case MVT::f64: {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 8;
|
ArgOffset += 8;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1665,8 +1665,8 @@ SDOperand X86TargetLowering::LowerFastCCCallTo(SDOperand Op, SelectionDAG &DAG,
|
||||||
ArgOffset = ((ArgOffset + 15) / 16) * 16;
|
ArgOffset = ((ArgOffset + 15) / 16) * 16;
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 16;
|
ArgOffset += 16;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1967,8 +1967,8 @@ SDOperand X86TargetLowering::LowerStdCallCCCallTo(SDOperand Op,
|
||||||
case MVT::f32: {
|
case MVT::f32: {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 4;
|
ArgOffset += 4;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1976,8 +1976,8 @@ SDOperand X86TargetLowering::LowerStdCallCCCallTo(SDOperand Op,
|
||||||
case MVT::f64: {
|
case MVT::f64: {
|
||||||
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
SDOperand PtrOff = DAG.getConstant(ArgOffset, getPointerTy());
|
||||||
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
PtrOff = DAG.getNode(ISD::ADD, getPointerTy(), StackPtr, PtrOff);
|
||||||
MemOpChains.push_back(DAG.getNode(ISD::STORE, MVT::Other, Chain,
|
MemOpChains.push_back(DAG.getStore(Chain, Arg, PtrOff,
|
||||||
Arg, PtrOff, DAG.getSrcValue(NULL)));
|
DAG.getSrcValue(NULL)));
|
||||||
ArgOffset += 8;
|
ArgOffset += 8;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -3994,9 +3994,8 @@ SDOperand X86TargetLowering::LowerSINT_TO_FP(SDOperand Op, SelectionDAG &DAG) {
|
||||||
MachineFunction &MF = DAG.getMachineFunction();
|
MachineFunction &MF = DAG.getMachineFunction();
|
||||||
int SSFI = MF.getFrameInfo()->CreateStackObject(Size, Size);
|
int SSFI = MF.getFrameInfo()->CreateStackObject(Size, Size);
|
||||||
SDOperand StackSlot = DAG.getFrameIndex(SSFI, getPointerTy());
|
SDOperand StackSlot = DAG.getFrameIndex(SSFI, getPointerTy());
|
||||||
SDOperand Chain = DAG.getNode(ISD::STORE, MVT::Other,
|
SDOperand Chain = DAG.getStore(DAG.getEntryNode(), Op.getOperand(0),
|
||||||
DAG.getEntryNode(), Op.getOperand(0),
|
StackSlot, DAG.getSrcValue(NULL));
|
||||||
StackSlot, DAG.getSrcValue(NULL));
|
|
||||||
|
|
||||||
// Build the FILD
|
// Build the FILD
|
||||||
std::vector<MVT::ValueType> Tys;
|
std::vector<MVT::ValueType> Tys;
|
||||||
|
@ -4058,8 +4057,7 @@ SDOperand X86TargetLowering::LowerFP_TO_SINT(SDOperand Op, SelectionDAG &DAG) {
|
||||||
SDOperand Value = Op.getOperand(0);
|
SDOperand Value = Op.getOperand(0);
|
||||||
if (X86ScalarSSE) {
|
if (X86ScalarSSE) {
|
||||||
assert(Op.getValueType() == MVT::i64 && "Invalid FP_TO_SINT to lower!");
|
assert(Op.getValueType() == MVT::i64 && "Invalid FP_TO_SINT to lower!");
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value, StackSlot,
|
Chain = DAG.getStore(Chain, Value, StackSlot, DAG.getSrcValue(0));
|
||||||
DAG.getSrcValue(0));
|
|
||||||
std::vector<MVT::ValueType> Tys;
|
std::vector<MVT::ValueType> Tys;
|
||||||
Tys.push_back(MVT::f64);
|
Tys.push_back(MVT::f64);
|
||||||
Tys.push_back(MVT::Other);
|
Tys.push_back(MVT::Other);
|
||||||
|
@ -4376,8 +4374,8 @@ SDOperand X86TargetLowering::LowerRET(SDOperand Op, SelectionDAG &DAG) {
|
||||||
MachineFunction &MF = DAG.getMachineFunction();
|
MachineFunction &MF = DAG.getMachineFunction();
|
||||||
int SSFI = MF.getFrameInfo()->CreateStackObject(Size, Size);
|
int SSFI = MF.getFrameInfo()->CreateStackObject(Size, Size);
|
||||||
MemLoc = DAG.getFrameIndex(SSFI, getPointerTy());
|
MemLoc = DAG.getFrameIndex(SSFI, getPointerTy());
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0),
|
Chain = DAG.getStore(Op.getOperand(0), Value, MemLoc,
|
||||||
Value, MemLoc, DAG.getSrcValue(0));
|
DAG.getSrcValue(0));
|
||||||
}
|
}
|
||||||
std::vector<MVT::ValueType> Tys;
|
std::vector<MVT::ValueType> Tys;
|
||||||
Tys.push_back(MVT::f64);
|
Tys.push_back(MVT::f64);
|
||||||
|
@ -4577,28 +4575,28 @@ SDOperand X86TargetLowering::LowerMEMSET(SDOperand Op, SelectionDAG &DAG) {
|
||||||
Val = (Val << 8) | Val;
|
Val = (Val << 8) | Val;
|
||||||
Val = (Val << 16) | Val;
|
Val = (Val << 16) | Val;
|
||||||
Value = DAG.getConstant(Val, MVT::i32);
|
Value = DAG.getConstant(Val, MVT::i32);
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
Chain = DAG.getStore(Chain, Value,
|
||||||
DAG.getNode(ISD::ADD, AddrVT, DstAddr,
|
DAG.getNode(ISD::ADD, AddrVT, DstAddr,
|
||||||
DAG.getConstant(Offset, AddrVT)),
|
DAG.getConstant(Offset, AddrVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
BytesLeft -= 4;
|
BytesLeft -= 4;
|
||||||
Offset += 4;
|
Offset += 4;
|
||||||
}
|
}
|
||||||
if (BytesLeft >= 2) {
|
if (BytesLeft >= 2) {
|
||||||
Value = DAG.getConstant((Val << 8) | Val, MVT::i16);
|
Value = DAG.getConstant((Val << 8) | Val, MVT::i16);
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
Chain = DAG.getStore(Chain, Value,
|
||||||
DAG.getNode(ISD::ADD, AddrVT, DstAddr,
|
DAG.getNode(ISD::ADD, AddrVT, DstAddr,
|
||||||
DAG.getConstant(Offset, AddrVT)),
|
DAG.getConstant(Offset, AddrVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
BytesLeft -= 2;
|
BytesLeft -= 2;
|
||||||
Offset += 2;
|
Offset += 2;
|
||||||
}
|
}
|
||||||
if (BytesLeft == 1) {
|
if (BytesLeft == 1) {
|
||||||
Value = DAG.getConstant(Val, MVT::i8);
|
Value = DAG.getConstant(Val, MVT::i8);
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
Chain = DAG.getStore(Chain, Value,
|
||||||
DAG.getNode(ISD::ADD, AddrVT, DstAddr,
|
DAG.getNode(ISD::ADD, AddrVT, DstAddr,
|
||||||
DAG.getConstant(Offset, AddrVT)),
|
DAG.getConstant(Offset, AddrVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4712,10 +4710,10 @@ SDOperand X86TargetLowering::LowerMEMCPY(SDOperand Op, SelectionDAG &DAG) {
|
||||||
DAG.getConstant(Offset, SrcVT)),
|
DAG.getConstant(Offset, SrcVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
Chain = Value.getValue(1);
|
Chain = Value.getValue(1);
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
Chain = DAG.getStore(Chain, Value,
|
||||||
DAG.getNode(ISD::ADD, DstVT, DstAddr,
|
DAG.getNode(ISD::ADD, DstVT, DstAddr,
|
||||||
DAG.getConstant(Offset, DstVT)),
|
DAG.getConstant(Offset, DstVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
BytesLeft -= 4;
|
BytesLeft -= 4;
|
||||||
Offset += 4;
|
Offset += 4;
|
||||||
}
|
}
|
||||||
|
@ -4725,10 +4723,10 @@ SDOperand X86TargetLowering::LowerMEMCPY(SDOperand Op, SelectionDAG &DAG) {
|
||||||
DAG.getConstant(Offset, SrcVT)),
|
DAG.getConstant(Offset, SrcVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
Chain = Value.getValue(1);
|
Chain = Value.getValue(1);
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
Chain = DAG.getStore(Chain, Value,
|
||||||
DAG.getNode(ISD::ADD, DstVT, DstAddr,
|
DAG.getNode(ISD::ADD, DstVT, DstAddr,
|
||||||
DAG.getConstant(Offset, DstVT)),
|
DAG.getConstant(Offset, DstVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
BytesLeft -= 2;
|
BytesLeft -= 2;
|
||||||
Offset += 2;
|
Offset += 2;
|
||||||
}
|
}
|
||||||
|
@ -4739,10 +4737,10 @@ SDOperand X86TargetLowering::LowerMEMCPY(SDOperand Op, SelectionDAG &DAG) {
|
||||||
DAG.getConstant(Offset, SrcVT)),
|
DAG.getConstant(Offset, SrcVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
Chain = Value.getValue(1);
|
Chain = Value.getValue(1);
|
||||||
Chain = DAG.getNode(ISD::STORE, MVT::Other, Chain, Value,
|
Chain = DAG.getStore(Chain, Value,
|
||||||
DAG.getNode(ISD::ADD, DstVT, DstAddr,
|
DAG.getNode(ISD::ADD, DstVT, DstAddr,
|
||||||
DAG.getConstant(Offset, DstVT)),
|
DAG.getConstant(Offset, DstVT)),
|
||||||
DAG.getSrcValue(NULL));
|
DAG.getSrcValue(NULL));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4772,8 +4770,7 @@ SDOperand X86TargetLowering::LowerVASTART(SDOperand Op, SelectionDAG &DAG) {
|
||||||
// vastart just stores the address of the VarArgsFrameIndex slot into the
|
// vastart just stores the address of the VarArgsFrameIndex slot into the
|
||||||
// memory location argument.
|
// memory location argument.
|
||||||
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, getPointerTy());
|
SDOperand FR = DAG.getFrameIndex(VarArgsFrameIndex, getPointerTy());
|
||||||
return DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0), FR,
|
return DAG.getStore(Op.getOperand(0), FR,Op.getOperand(1),Op.getOperand(2));
|
||||||
Op.getOperand(1), Op.getOperand(2));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// __va_list_tag:
|
// __va_list_tag:
|
||||||
|
@ -4784,33 +4781,31 @@ SDOperand X86TargetLowering::LowerVASTART(SDOperand Op, SelectionDAG &DAG) {
|
||||||
std::vector<SDOperand> MemOps;
|
std::vector<SDOperand> MemOps;
|
||||||
SDOperand FIN = Op.getOperand(1);
|
SDOperand FIN = Op.getOperand(1);
|
||||||
// Store gp_offset
|
// Store gp_offset
|
||||||
SDOperand Store = DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0),
|
SDOperand Store = DAG.getStore(Op.getOperand(0),
|
||||||
DAG.getConstant(VarArgsGPOffset, MVT::i32),
|
DAG.getConstant(VarArgsGPOffset, MVT::i32),
|
||||||
FIN, Op.getOperand(2));
|
FIN, Op.getOperand(2));
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
|
|
||||||
// Store fp_offset
|
// Store fp_offset
|
||||||
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
||||||
DAG.getConstant(4, getPointerTy()));
|
DAG.getConstant(4, getPointerTy()));
|
||||||
Store = DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0),
|
Store = DAG.getStore(Op.getOperand(0),
|
||||||
DAG.getConstant(VarArgsFPOffset, MVT::i32),
|
DAG.getConstant(VarArgsFPOffset, MVT::i32),
|
||||||
FIN, Op.getOperand(2));
|
FIN, Op.getOperand(2));
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
|
|
||||||
// Store ptr to overflow_arg_area
|
// Store ptr to overflow_arg_area
|
||||||
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
||||||
DAG.getConstant(4, getPointerTy()));
|
DAG.getConstant(4, getPointerTy()));
|
||||||
SDOperand OVFIN = DAG.getFrameIndex(VarArgsFrameIndex, getPointerTy());
|
SDOperand OVFIN = DAG.getFrameIndex(VarArgsFrameIndex, getPointerTy());
|
||||||
Store = DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0),
|
Store = DAG.getStore(Op.getOperand(0), OVFIN, FIN, Op.getOperand(2));
|
||||||
OVFIN, FIN, Op.getOperand(2));
|
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
|
|
||||||
// Store ptr to reg_save_area.
|
// Store ptr to reg_save_area.
|
||||||
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
FIN = DAG.getNode(ISD::ADD, getPointerTy(), FIN,
|
||||||
DAG.getConstant(8, getPointerTy()));
|
DAG.getConstant(8, getPointerTy()));
|
||||||
SDOperand RSFIN = DAG.getFrameIndex(RegSaveFrameIndex, getPointerTy());
|
SDOperand RSFIN = DAG.getFrameIndex(RegSaveFrameIndex, getPointerTy());
|
||||||
Store = DAG.getNode(ISD::STORE, MVT::Other, Op.getOperand(0),
|
Store = DAG.getStore(Op.getOperand(0), RSFIN, FIN, Op.getOperand(2));
|
||||||
RSFIN, FIN, Op.getOperand(2));
|
|
||||||
MemOps.push_back(Store);
|
MemOps.push_back(Store);
|
||||||
return DAG.getNode(ISD::TokenFactor, MVT::Other, &MemOps[0], MemOps.size());
|
return DAG.getNode(ISD::TokenFactor, MVT::Other, &MemOps[0], MemOps.size());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue