forked from OSchip/llvm-project
Remove the target machine from CCState. Previously it was only used
to get the subtarget and that's accessible from the MachineFunction now. This helps clear the way for smaller changes where we getting a subtarget will require passing in a MachineFunction/Function as well. llvm-svn: 214988
This commit is contained in:
parent
364d13170a
commit
b5217507c7
|
@ -174,7 +174,6 @@ private:
|
||||||
CallingConv::ID CallingConv;
|
CallingConv::ID CallingConv;
|
||||||
bool IsVarArg;
|
bool IsVarArg;
|
||||||
MachineFunction &MF;
|
MachineFunction &MF;
|
||||||
const TargetMachine &TM;
|
|
||||||
const TargetRegisterInfo &TRI;
|
const TargetRegisterInfo &TRI;
|
||||||
SmallVectorImpl<CCValAssign> &Locs;
|
SmallVectorImpl<CCValAssign> &Locs;
|
||||||
LLVMContext &Context;
|
LLVMContext &Context;
|
||||||
|
@ -238,15 +237,13 @@ protected:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF,
|
CCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF,
|
||||||
const TargetMachine &TM, SmallVectorImpl<CCValAssign> &locs,
|
SmallVectorImpl<CCValAssign> &locs, LLVMContext &C);
|
||||||
LLVMContext &C);
|
|
||||||
|
|
||||||
void addLoc(const CCValAssign &V) {
|
void addLoc(const CCValAssign &V) {
|
||||||
Locs.push_back(V);
|
Locs.push_back(V);
|
||||||
}
|
}
|
||||||
|
|
||||||
LLVMContext &getContext() const { return Context; }
|
LLVMContext &getContext() const { return Context; }
|
||||||
const TargetMachine &getTarget() const { return TM; }
|
|
||||||
MachineFunction &getMachineFunction() const { return MF; }
|
MachineFunction &getMachineFunction() const { return MF; }
|
||||||
CallingConv::ID getCallingConv() const { return CallingConv; }
|
CallingConv::ID getCallingConv() const { return CallingConv; }
|
||||||
bool isVarArg() const { return IsVarArg; }
|
bool isVarArg() const { return IsVarArg; }
|
||||||
|
|
|
@ -25,10 +25,9 @@
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
CCState::CCState(CallingConv::ID CC, bool isVarArg, MachineFunction &mf,
|
CCState::CCState(CallingConv::ID CC, bool isVarArg, MachineFunction &mf,
|
||||||
const TargetMachine &tm, SmallVectorImpl<CCValAssign> &locs,
|
SmallVectorImpl<CCValAssign> &locs, LLVMContext &C)
|
||||||
LLVMContext &C)
|
: CallingConv(CC), IsVarArg(isVarArg), MF(mf),
|
||||||
: CallingConv(CC), IsVarArg(isVarArg), MF(mf), TM(tm),
|
TRI(*MF.getSubtarget().getRegisterInfo()), Locs(locs), Context(C),
|
||||||
TRI(*TM.getSubtargetImpl()->getRegisterInfo()), Locs(locs), Context(C),
|
|
||||||
CallOrPrologue(Unknown) {
|
CallOrPrologue(Unknown) {
|
||||||
// No stack is used.
|
// No stack is used.
|
||||||
StackOffset = 0;
|
StackOffset = 0;
|
||||||
|
@ -51,7 +50,7 @@ void CCState::HandleByVal(unsigned ValNo, MVT ValVT,
|
||||||
if (MinAlign > (int)Align)
|
if (MinAlign > (int)Align)
|
||||||
Align = MinAlign;
|
Align = MinAlign;
|
||||||
MF.getFrameInfo()->ensureMaxAlignment(Align);
|
MF.getFrameInfo()->ensureMaxAlignment(Align);
|
||||||
TM.getSubtargetImpl()->getTargetLowering()->HandleByVal(this, Size, Align);
|
MF.getSubtarget().getTargetLowering()->HandleByVal(this, Size, Align);
|
||||||
Size = unsigned(RoundUpToAlignment(Size, MinAlign));
|
Size = unsigned(RoundUpToAlignment(Size, MinAlign));
|
||||||
unsigned Offset = AllocateStack(Size, Align);
|
unsigned Offset = AllocateStack(Size, Align);
|
||||||
addLoc(CCValAssign::getMem(ValNo, ValVT, Offset, LocVT, LocInfo));
|
addLoc(CCValAssign::getMem(ValNo, ValVT, Offset, LocVT, LocInfo));
|
||||||
|
|
|
@ -16,7 +16,7 @@ class CCIfAlign<string Align, CCAction A> :
|
||||||
CCIf<!strconcat("ArgFlags.getOrigAlign() == ", Align), A>;
|
CCIf<!strconcat("ArgFlags.getOrigAlign() == ", Align), A>;
|
||||||
/// CCIfBigEndian - Match only if we're in big endian mode.
|
/// CCIfBigEndian - Match only if we're in big endian mode.
|
||||||
class CCIfBigEndian<CCAction A> :
|
class CCIfBigEndian<CCAction A> :
|
||||||
CCIf<"State.getTarget().getSubtargetImpl()->getDataLayout()->isBigEndian()", A>;
|
CCIf<"State.getMachineFunction().getSubtarget().getDataLayout()->isBigEndian()", A>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// ARM AAPCS64 Calling Convention
|
// ARM AAPCS64 Calling Convention
|
||||||
|
|
|
@ -1421,7 +1421,7 @@ bool AArch64FastISel::ProcessCallArgs(CallLoweringInfo &CLI,
|
||||||
unsigned &NumBytes) {
|
unsigned &NumBytes) {
|
||||||
CallingConv::ID CC = CLI.CallConv;
|
CallingConv::ID CC = CLI.CallConv;
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CC, false, *FuncInfo.MF, TM, ArgLocs, *Context);
|
CCState CCInfo(CC, false, *FuncInfo.MF, ArgLocs, *Context);
|
||||||
CCInfo.AnalyzeCallOperands(OutVTs, CLI.OutFlags, CCAssignFnForCall(CC));
|
CCInfo.AnalyzeCallOperands(OutVTs, CLI.OutFlags, CCAssignFnForCall(CC));
|
||||||
|
|
||||||
// Get a count of how many bytes are to be pushed on the stack.
|
// Get a count of how many bytes are to be pushed on the stack.
|
||||||
|
@ -1514,7 +1514,7 @@ bool AArch64FastISel::FinishCall(CallLoweringInfo &CLI, MVT RetVT,
|
||||||
// Now the return value.
|
// Now the return value.
|
||||||
if (RetVT != MVT::isVoid) {
|
if (RetVT != MVT::isVoid) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CC, false, *FuncInfo.MF, TM, RVLocs, *Context);
|
CCState CCInfo(CC, false, *FuncInfo.MF, RVLocs, *Context);
|
||||||
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC));
|
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC));
|
||||||
|
|
||||||
// Only handle a single return value.
|
// Only handle a single return value.
|
||||||
|
@ -2068,8 +2068,7 @@ bool AArch64FastISel::SelectRet(const Instruction *I) {
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ValLocs;
|
SmallVector<CCValAssign, 16> ValLocs;
|
||||||
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, TM, ValLocs,
|
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, ValLocs, I->getContext());
|
||||||
I->getContext());
|
|
||||||
CCAssignFn *RetCC = CC == CallingConv::WebKit_JS ? RetCC_AArch64_WebKit_JS
|
CCAssignFn *RetCC = CC == CallingConv::WebKit_JS ? RetCC_AArch64_WebKit_JS
|
||||||
: RetCC_AArch64_AAPCS;
|
: RetCC_AArch64_AAPCS;
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC);
|
CCInfo.AnalyzeReturn(Outs, RetCC);
|
||||||
|
|
|
@ -1674,8 +1674,8 @@ SDValue AArch64TargetLowering::LowerFormalArguments(
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// At this point, Ins[].VT may already be promoted to i32. To correctly
|
// At this point, Ins[].VT may already be promoted to i32. To correctly
|
||||||
// handle passing i8 as i8 instead of i32 on stack, we pass in both i32 and
|
// handle passing i8 as i8 instead of i32 on stack, we pass in both i32 and
|
||||||
|
@ -1946,8 +1946,8 @@ SDValue AArch64TargetLowering::LowerCallResult(
|
||||||
: RetCC_AArch64_AAPCS;
|
: RetCC_AArch64_AAPCS;
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeCallResult(Ins, RetCC);
|
CCInfo.AnalyzeCallResult(Ins, RetCC);
|
||||||
|
|
||||||
// Copy all of the result registers out of their specified physreg.
|
// Copy all of the result registers out of their specified physreg.
|
||||||
|
@ -2033,8 +2033,8 @@ bool AArch64TargetLowering::isEligibleForTailCallOptimization(
|
||||||
// FIXME: for now we take the most conservative of these in both cases:
|
// FIXME: for now we take the most conservative of these in both cases:
|
||||||
// disallow all variadic memory operands.
|
// disallow all variadic memory operands.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
CCInfo.AnalyzeCallOperands(Outs, CCAssignFnForCall(CalleeCC, true));
|
CCInfo.AnalyzeCallOperands(Outs, CCAssignFnForCall(CalleeCC, true));
|
||||||
for (unsigned i = 0, e = ArgLocs.size(); i != e; ++i)
|
for (unsigned i = 0, e = ArgLocs.size(); i != e; ++i)
|
||||||
|
@ -2046,13 +2046,13 @@ bool AArch64TargetLowering::isEligibleForTailCallOptimization(
|
||||||
// results are returned in the same way as what the caller expects.
|
// results are returned in the same way as what the caller expects.
|
||||||
if (!CCMatch) {
|
if (!CCMatch) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs1;
|
SmallVector<CCValAssign, 16> RVLocs1;
|
||||||
CCState CCInfo1(CalleeCC, false, DAG.getMachineFunction(),
|
CCState CCInfo1(CalleeCC, false, DAG.getMachineFunction(), RVLocs1,
|
||||||
getTargetMachine(), RVLocs1, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo1.AnalyzeCallResult(Ins, CCAssignFnForCall(CalleeCC, isVarArg));
|
CCInfo1.AnalyzeCallResult(Ins, CCAssignFnForCall(CalleeCC, isVarArg));
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs2;
|
SmallVector<CCValAssign, 16> RVLocs2;
|
||||||
CCState CCInfo2(CallerCC, false, DAG.getMachineFunction(),
|
CCState CCInfo2(CallerCC, false, DAG.getMachineFunction(), RVLocs2,
|
||||||
getTargetMachine(), RVLocs2, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo2.AnalyzeCallResult(Ins, CCAssignFnForCall(CallerCC, isVarArg));
|
CCInfo2.AnalyzeCallResult(Ins, CCAssignFnForCall(CallerCC, isVarArg));
|
||||||
|
|
||||||
if (RVLocs1.size() != RVLocs2.size())
|
if (RVLocs1.size() != RVLocs2.size())
|
||||||
|
@ -2077,8 +2077,8 @@ bool AArch64TargetLowering::isEligibleForTailCallOptimization(
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
CCInfo.AnalyzeCallOperands(Outs, CCAssignFnForCall(CalleeCC, isVarArg));
|
CCInfo.AnalyzeCallOperands(Outs, CCAssignFnForCall(CalleeCC, isVarArg));
|
||||||
|
|
||||||
|
@ -2175,8 +2175,8 @@ AArch64TargetLowering::LowerCall(CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
if (IsVarArg) {
|
if (IsVarArg) {
|
||||||
// Handle fixed and variable vector arguments differently.
|
// Handle fixed and variable vector arguments differently.
|
||||||
|
@ -2500,7 +2500,7 @@ bool AArch64TargetLowering::CanLowerReturn(
|
||||||
? RetCC_AArch64_WebKit_JS
|
? RetCC_AArch64_WebKit_JS
|
||||||
: RetCC_AArch64_AAPCS;
|
: RetCC_AArch64_AAPCS;
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, getTargetMachine(), RVLocs, Context);
|
CCState CCInfo(CallConv, isVarArg, MF, RVLocs, Context);
|
||||||
return CCInfo.CheckReturn(Outs, RetCC);
|
return CCInfo.CheckReturn(Outs, RetCC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2514,8 +2514,8 @@ AArch64TargetLowering::LowerReturn(SDValue Chain, CallingConv::ID CallConv,
|
||||||
? RetCC_AArch64_WebKit_JS
|
? RetCC_AArch64_WebKit_JS
|
||||||
: RetCC_AArch64_AAPCS;
|
: RetCC_AArch64_AAPCS;
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC);
|
CCInfo.AnalyzeReturn(Outs, RetCC);
|
||||||
|
|
||||||
// Copy the result values into the output registers.
|
// Copy the result values into the output registers.
|
||||||
|
|
|
@ -1885,7 +1885,7 @@ bool ARMFastISel::ProcessCallArgs(SmallVectorImpl<Value*> &Args,
|
||||||
unsigned &NumBytes,
|
unsigned &NumBytes,
|
||||||
bool isVarArg) {
|
bool isVarArg) {
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CC, isVarArg, *FuncInfo.MF, TM, ArgLocs, *Context);
|
CCState CCInfo(CC, isVarArg, *FuncInfo.MF, ArgLocs, *Context);
|
||||||
CCInfo.AnalyzeCallOperands(ArgVTs, ArgFlags,
|
CCInfo.AnalyzeCallOperands(ArgVTs, ArgFlags,
|
||||||
CCAssignFnForCall(CC, false, isVarArg));
|
CCAssignFnForCall(CC, false, isVarArg));
|
||||||
|
|
||||||
|
@ -2034,7 +2034,7 @@ bool ARMFastISel::FinishCall(MVT RetVT, SmallVectorImpl<unsigned> &UsedRegs,
|
||||||
// Now the return value.
|
// Now the return value.
|
||||||
if (RetVT != MVT::isVoid) {
|
if (RetVT != MVT::isVoid) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CC, isVarArg, *FuncInfo.MF, TM, RVLocs, *Context);
|
CCState CCInfo(CC, isVarArg, *FuncInfo.MF, RVLocs, *Context);
|
||||||
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC, true, isVarArg));
|
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC, true, isVarArg));
|
||||||
|
|
||||||
// Copy all of the result registers out of their specified physreg.
|
// Copy all of the result registers out of their specified physreg.
|
||||||
|
@ -2095,7 +2095,7 @@ bool ARMFastISel::SelectRet(const Instruction *I) {
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ValLocs;
|
SmallVector<CCValAssign, 16> ValLocs;
|
||||||
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, TM, ValLocs,I->getContext());
|
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, ValLocs, I->getContext());
|
||||||
CCInfo.AnalyzeReturn(Outs, CCAssignFnForCall(CC, true /* is Ret */,
|
CCInfo.AnalyzeReturn(Outs, CCAssignFnForCall(CC, true /* is Ret */,
|
||||||
F.isVarArg()));
|
F.isVarArg()));
|
||||||
|
|
||||||
|
@ -2200,7 +2200,7 @@ bool ARMFastISel::ARMEmitLibcall(const Instruction *I, RTLIB::Libcall Call) {
|
||||||
// Can't handle non-double multi-reg retvals.
|
// Can't handle non-double multi-reg retvals.
|
||||||
if (RetVT != MVT::isVoid && RetVT != MVT::i32) {
|
if (RetVT != MVT::isVoid && RetVT != MVT::i32) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CC, false, *FuncInfo.MF, TM, RVLocs, *Context);
|
CCState CCInfo(CC, false, *FuncInfo.MF, RVLocs, *Context);
|
||||||
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC, true, false));
|
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC, true, false));
|
||||||
if (RVLocs.size() >= 2 && RetVT != MVT::f64)
|
if (RVLocs.size() >= 2 && RetVT != MVT::f64)
|
||||||
return false;
|
return false;
|
||||||
|
@ -2311,7 +2311,7 @@ bool ARMFastISel::SelectCall(const Instruction *I,
|
||||||
if (RetVT != MVT::isVoid && RetVT != MVT::i1 && RetVT != MVT::i8 &&
|
if (RetVT != MVT::isVoid && RetVT != MVT::i1 && RetVT != MVT::i8 &&
|
||||||
RetVT != MVT::i16 && RetVT != MVT::i32) {
|
RetVT != MVT::i16 && RetVT != MVT::i32) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CC, isVarArg, *FuncInfo.MF, TM, RVLocs, *Context);
|
CCState CCInfo(CC, isVarArg, *FuncInfo.MF, RVLocs, *Context);
|
||||||
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC, true, isVarArg));
|
CCInfo.AnalyzeCallResult(RetVT, CCAssignFnForCall(CC, true, isVarArg));
|
||||||
if (RVLocs.size() >= 2 && RetVT != MVT::f64)
|
if (RVLocs.size() >= 2 && RetVT != MVT::f64)
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -70,9 +70,9 @@ namespace {
|
||||||
class ARMCCState : public CCState {
|
class ARMCCState : public CCState {
|
||||||
public:
|
public:
|
||||||
ARMCCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF,
|
ARMCCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF,
|
||||||
const TargetMachine &TM, SmallVectorImpl<CCValAssign> &locs,
|
SmallVectorImpl<CCValAssign> &locs, LLVMContext &C,
|
||||||
LLVMContext &C, ParmContext PC)
|
ParmContext PC)
|
||||||
: CCState(CC, isVarArg, MF, TM, locs, C) {
|
: CCState(CC, isVarArg, MF, locs, C) {
|
||||||
assert(((PC == Call) || (PC == Prologue)) &&
|
assert(((PC == Call) || (PC == Prologue)) &&
|
||||||
"ARMCCState users must specify whether their context is call"
|
"ARMCCState users must specify whether their context is call"
|
||||||
"or prologue generation.");
|
"or prologue generation.");
|
||||||
|
@ -1269,8 +1269,8 @@ ARMTargetLowering::LowerCallResult(SDValue Chain, SDValue InFlag,
|
||||||
|
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext(), Call);
|
*DAG.getContext(), Call);
|
||||||
CCInfo.AnalyzeCallResult(Ins,
|
CCInfo.AnalyzeCallResult(Ins,
|
||||||
CCAssignFnForNode(CallConv, /* Return*/ true,
|
CCAssignFnForNode(CallConv, /* Return*/ true,
|
||||||
isVarArg));
|
isVarArg));
|
||||||
|
@ -1430,8 +1430,8 @@ ARMTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext(), Call);
|
*DAG.getContext(), Call);
|
||||||
CCInfo.AnalyzeCallOperands(Outs,
|
CCInfo.AnalyzeCallOperands(Outs,
|
||||||
CCAssignFnForNode(CallConv, /* Return*/ false,
|
CCAssignFnForNode(CallConv, /* Return*/ false,
|
||||||
isVarArg));
|
isVarArg));
|
||||||
|
@ -1961,13 +1961,13 @@ ARMTargetLowering::IsEligibleForTailCallOptimization(SDValue Callee,
|
||||||
// results are returned in the same way as what the caller expects.
|
// results are returned in the same way as what the caller expects.
|
||||||
if (!CCMatch) {
|
if (!CCMatch) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs1;
|
SmallVector<CCValAssign, 16> RVLocs1;
|
||||||
ARMCCState CCInfo1(CalleeCC, false, DAG.getMachineFunction(),
|
ARMCCState CCInfo1(CalleeCC, false, DAG.getMachineFunction(), RVLocs1,
|
||||||
getTargetMachine(), RVLocs1, *DAG.getContext(), Call);
|
*DAG.getContext(), Call);
|
||||||
CCInfo1.AnalyzeCallResult(Ins, CCAssignFnForNode(CalleeCC, true, isVarArg));
|
CCInfo1.AnalyzeCallResult(Ins, CCAssignFnForNode(CalleeCC, true, isVarArg));
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs2;
|
SmallVector<CCValAssign, 16> RVLocs2;
|
||||||
ARMCCState CCInfo2(CallerCC, false, DAG.getMachineFunction(),
|
ARMCCState CCInfo2(CallerCC, false, DAG.getMachineFunction(), RVLocs2,
|
||||||
getTargetMachine(), RVLocs2, *DAG.getContext(), Call);
|
*DAG.getContext(), Call);
|
||||||
CCInfo2.AnalyzeCallResult(Ins, CCAssignFnForNode(CallerCC, true, isVarArg));
|
CCInfo2.AnalyzeCallResult(Ins, CCAssignFnForNode(CallerCC, true, isVarArg));
|
||||||
|
|
||||||
if (RVLocs1.size() != RVLocs2.size())
|
if (RVLocs1.size() != RVLocs2.size())
|
||||||
|
@ -2001,8 +2001,8 @@ ARMTargetLowering::IsEligibleForTailCallOptimization(SDValue Callee,
|
||||||
// Check if stack adjustment is needed. For now, do not do this if any
|
// Check if stack adjustment is needed. For now, do not do this if any
|
||||||
// argument is passed on the stack.
|
// argument is passed on the stack.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
ARMCCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(),
|
ARMCCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext(), Call);
|
*DAG.getContext(), Call);
|
||||||
CCInfo.AnalyzeCallOperands(Outs,
|
CCInfo.AnalyzeCallOperands(Outs,
|
||||||
CCAssignFnForNode(CalleeCC, false, isVarArg));
|
CCAssignFnForNode(CalleeCC, false, isVarArg));
|
||||||
if (CCInfo.getNextStackOffset()) {
|
if (CCInfo.getNextStackOffset()) {
|
||||||
|
@ -2056,7 +2056,7 @@ ARMTargetLowering::CanLowerReturn(CallingConv::ID CallConv,
|
||||||
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
||||||
LLVMContext &Context) const {
|
LLVMContext &Context) const {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, getTargetMachine(), RVLocs, Context);
|
CCState CCInfo(CallConv, isVarArg, MF, RVLocs, Context);
|
||||||
return CCInfo.CheckReturn(Outs, CCAssignFnForNode(CallConv, /*Return=*/true,
|
return CCInfo.CheckReturn(Outs, CCAssignFnForNode(CallConv, /*Return=*/true,
|
||||||
isVarArg));
|
isVarArg));
|
||||||
}
|
}
|
||||||
|
@ -2104,8 +2104,8 @@ ARMTargetLowering::LowerReturn(SDValue Chain,
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slots.
|
// CCState - Info about the registers and stack slots.
|
||||||
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext(), Call);
|
*DAG.getContext(), Call);
|
||||||
|
|
||||||
// Analyze outgoing return values.
|
// Analyze outgoing return values.
|
||||||
CCInfo.AnalyzeReturn(Outs, CCAssignFnForNode(CallConv, /* Return */ true,
|
CCInfo.AnalyzeReturn(Outs, CCAssignFnForNode(CallConv, /* Return */ true,
|
||||||
|
@ -2941,8 +2941,8 @@ ARMTargetLowering::LowerFormalArguments(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
ARMCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext(), Prologue);
|
*DAG.getContext(), Prologue);
|
||||||
CCInfo.AnalyzeFormalArguments(Ins,
|
CCInfo.AnalyzeFormalArguments(Ins,
|
||||||
CCAssignFnForNode(CallConv, /* Return*/ false,
|
CCAssignFnForNode(CallConv, /* Return*/ false,
|
||||||
isVarArg));
|
isVarArg));
|
||||||
|
|
|
@ -51,9 +51,9 @@ class HexagonCCState : public CCState {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
HexagonCCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF,
|
HexagonCCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF,
|
||||||
const TargetMachine &TM, SmallVectorImpl<CCValAssign> &locs,
|
SmallVectorImpl<CCValAssign> &locs, LLVMContext &C,
|
||||||
LLVMContext &C, int NumNamedVarArgParams)
|
int NumNamedVarArgParams)
|
||||||
: CCState(CC, isVarArg, MF, TM, locs, C),
|
: CCState(CC, isVarArg, MF, locs, C),
|
||||||
NumNamedVarArgParams(NumNamedVarArgParams) {}
|
NumNamedVarArgParams(NumNamedVarArgParams) {}
|
||||||
|
|
||||||
int getNumNamedVarArgParams() const { return NumNamedVarArgParams; }
|
int getNumNamedVarArgParams() const { return NumNamedVarArgParams; }
|
||||||
|
@ -322,8 +322,8 @@ HexagonTargetLowering::LowerReturn(SDValue Chain,
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slot.
|
// CCState - Info about the registers and stack slot.
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Analyze return values of ISD::RET
|
// Analyze return values of ISD::RET
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_Hexagon);
|
CCInfo.AnalyzeReturn(Outs, RetCC_Hexagon);
|
||||||
|
@ -372,8 +372,8 @@ HexagonTargetLowering::LowerCallResult(SDValue Chain, SDValue InFlag,
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
|
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
CCInfo.AnalyzeCallResult(Ins, RetCC_Hexagon);
|
CCInfo.AnalyzeCallResult(Ins, RetCC_Hexagon);
|
||||||
|
|
||||||
|
@ -427,9 +427,8 @@ HexagonTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
HexagonCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
HexagonCCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext(),
|
*DAG.getContext(), NumNamedVarArgParams);
|
||||||
NumNamedVarArgParams);
|
|
||||||
|
|
||||||
if (NumNamedVarArgParams > 0)
|
if (NumNamedVarArgParams > 0)
|
||||||
CCInfo.AnalyzeCallOperands(Outs, CC_Hexagon_VarArg);
|
CCInfo.AnalyzeCallOperands(Outs, CC_Hexagon_VarArg);
|
||||||
|
@ -843,8 +842,8 @@ const {
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
CCInfo.AnalyzeFormalArguments(Ins, CC_Hexagon);
|
CCInfo.AnalyzeFormalArguments(Ins, CC_Hexagon);
|
||||||
|
|
||||||
|
|
|
@ -437,8 +437,8 @@ MSP430TargetLowering::LowerCCCArguments(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
AnalyzeArguments(CCInfo, ArgLocs, Ins);
|
AnalyzeArguments(CCInfo, ArgLocs, Ins);
|
||||||
|
|
||||||
// Create frame index for the start of the first vararg value
|
// Create frame index for the start of the first vararg value
|
||||||
|
@ -533,8 +533,8 @@ MSP430TargetLowering::LowerReturn(SDValue Chain,
|
||||||
report_fatal_error("ISRs cannot return any value");
|
report_fatal_error("ISRs cannot return any value");
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slot.
|
// CCState - Info about the registers and stack slot.
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Analize return values.
|
// Analize return values.
|
||||||
AnalyzeReturnValues(CCInfo, RVLocs, Outs);
|
AnalyzeReturnValues(CCInfo, RVLocs, Outs);
|
||||||
|
@ -583,8 +583,8 @@ MSP430TargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
||||||
SmallVectorImpl<SDValue> &InVals) const {
|
SmallVectorImpl<SDValue> &InVals) const {
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
AnalyzeArguments(CCInfo, ArgLocs, Outs);
|
AnalyzeArguments(CCInfo, ArgLocs, Outs);
|
||||||
|
|
||||||
// Get a count of how many bytes are to be pushed on the stack.
|
// Get a count of how many bytes are to be pushed on the stack.
|
||||||
|
@ -719,8 +719,8 @@ MSP430TargetLowering::LowerCallResult(SDValue Chain, SDValue InFlag,
|
||||||
|
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
AnalyzeReturnValues(CCInfo, RVLocs, Ins);
|
AnalyzeReturnValues(CCInfo, RVLocs, Ins);
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,11 @@
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
||||||
class CCIfSubtarget<string F, CCAction A>:
|
class CCIfSubtarget<string F, CCAction A>
|
||||||
CCIf<!strconcat("State.getTarget().getSubtarget<MipsSubtarget>().", F), A>;
|
: CCIf<!strconcat("static_cast<const MipsSubtarget&>"
|
||||||
|
"(State.getMachineFunction().getSubtarget()).",
|
||||||
|
F),
|
||||||
|
A>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Mips O32 Calling Convention
|
// Mips O32 Calling Convention
|
||||||
|
|
|
@ -2480,8 +2480,8 @@ MipsTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
MipsCC::SpecialCallingConvType SpecialCallingConv =
|
MipsCC::SpecialCallingConvType SpecialCallingConv =
|
||||||
getSpecialCallingConv(Callee);
|
getSpecialCallingConv(Callee);
|
||||||
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
||||||
|
@ -2684,8 +2684,8 @@ MipsTargetLowering::LowerCallResult(SDValue Chain, SDValue InFlag,
|
||||||
const Type *RetTy) const {
|
const Type *RetTy) const {
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
||||||
CCInfo);
|
CCInfo);
|
||||||
|
|
||||||
|
@ -2732,8 +2732,8 @@ MipsTargetLowering::LowerFormalArguments(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
||||||
CCInfo);
|
CCInfo);
|
||||||
Function::const_arg_iterator FuncArg =
|
Function::const_arg_iterator FuncArg =
|
||||||
|
@ -2868,8 +2868,7 @@ MipsTargetLowering::CanLowerReturn(CallingConv::ID CallConv,
|
||||||
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
||||||
LLVMContext &Context) const {
|
LLVMContext &Context) const {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, MF, getTargetMachine(),
|
CCState CCInfo(CallConv, IsVarArg, MF, RVLocs, Context);
|
||||||
RVLocs, Context);
|
|
||||||
return CCInfo.CheckReturn(Outs, RetCC_Mips);
|
return CCInfo.CheckReturn(Outs, RetCC_Mips);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2885,8 +2884,7 @@ MipsTargetLowering::LowerReturn(SDValue Chain,
|
||||||
MachineFunction &MF = DAG.getMachineFunction();
|
MachineFunction &MF = DAG.getMachineFunction();
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slot.
|
// CCState - Info about the registers and stack slot.
|
||||||
CCState CCInfo(CallConv, IsVarArg, MF, getTargetMachine(), RVLocs,
|
CCState CCInfo(CallConv, IsVarArg, MF, RVLocs, *DAG.getContext());
|
||||||
*DAG.getContext());
|
|
||||||
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
MipsCC MipsCCInfo(CallConv, Subtarget.isABI_O32(), Subtarget.isFP64bit(),
|
||||||
CCInfo);
|
CCInfo);
|
||||||
|
|
||||||
|
|
|
@ -14,9 +14,15 @@
|
||||||
|
|
||||||
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
||||||
class CCIfSubtarget<string F, CCAction A>
|
class CCIfSubtarget<string F, CCAction A>
|
||||||
: CCIf<!strconcat("State.getTarget().getSubtarget<PPCSubtarget>().", F), A>;
|
: CCIf<!strconcat("static_cast<const PPCSubtarget&>"
|
||||||
|
"(State.getMachineFunction().getSubtarget()).",
|
||||||
|
F),
|
||||||
|
A>;
|
||||||
class CCIfNotSubtarget<string F, CCAction A>
|
class CCIfNotSubtarget<string F, CCAction A>
|
||||||
: CCIf<!strconcat("!State.getTarget().getSubtarget<PPCSubtarget>().", F), A>;
|
: CCIf<!strconcat("!static_cast<const PPCSubtarget&>"
|
||||||
|
"(State.getMachineFunction().getSubtarget()).",
|
||||||
|
F),
|
||||||
|
A>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Return Value Calling Convention
|
// Return Value Calling Convention
|
||||||
|
|
|
@ -1199,7 +1199,7 @@ bool PPCFastISel::processCallArgs(SmallVectorImpl<Value*> &Args,
|
||||||
unsigned &NumBytes,
|
unsigned &NumBytes,
|
||||||
bool IsVarArg) {
|
bool IsVarArg) {
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, TM, ArgLocs, *Context);
|
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, ArgLocs, *Context);
|
||||||
|
|
||||||
// Reserve space for the linkage area on the stack.
|
// Reserve space for the linkage area on the stack.
|
||||||
bool isELFv2ABI = PPCSubTarget->isELFv2ABI();
|
bool isELFv2ABI = PPCSubTarget->isELFv2ABI();
|
||||||
|
@ -1320,7 +1320,7 @@ void PPCFastISel::finishCall(MVT RetVT, SmallVectorImpl<unsigned> &UsedRegs,
|
||||||
// any real difficulties there.
|
// any real difficulties there.
|
||||||
if (RetVT != MVT::isVoid) {
|
if (RetVT != MVT::isVoid) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, TM, RVLocs, *Context);
|
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, RVLocs, *Context);
|
||||||
CCInfo.AnalyzeCallResult(RetVT, RetCC_PPC64_ELF_FIS);
|
CCInfo.AnalyzeCallResult(RetVT, RetCC_PPC64_ELF_FIS);
|
||||||
CCValAssign &VA = RVLocs[0];
|
CCValAssign &VA = RVLocs[0];
|
||||||
assert(RVLocs.size() == 1 && "No support for multi-reg return values!");
|
assert(RVLocs.size() == 1 && "No support for multi-reg return values!");
|
||||||
|
@ -1410,7 +1410,7 @@ bool PPCFastISel::SelectCall(const Instruction *I) {
|
||||||
RetVT != MVT::i32 && RetVT != MVT::i64 && RetVT != MVT::f32 &&
|
RetVT != MVT::i32 && RetVT != MVT::i64 && RetVT != MVT::f32 &&
|
||||||
RetVT != MVT::f64) {
|
RetVT != MVT::f64) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, TM, RVLocs, *Context);
|
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, RVLocs, *Context);
|
||||||
CCInfo.AnalyzeCallResult(RetVT, RetCC_PPC64_ELF_FIS);
|
CCInfo.AnalyzeCallResult(RetVT, RetCC_PPC64_ELF_FIS);
|
||||||
if (RVLocs.size() > 1)
|
if (RVLocs.size() > 1)
|
||||||
return false;
|
return false;
|
||||||
|
@ -1537,7 +1537,7 @@ bool PPCFastISel::SelectRet(const Instruction *I) {
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ValLocs;
|
SmallVector<CCValAssign, 16> ValLocs;
|
||||||
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, TM, ValLocs, *Context);
|
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, ValLocs, *Context);
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_PPC64_ELF_FIS);
|
CCInfo.AnalyzeReturn(Outs, RetCC_PPC64_ELF_FIS);
|
||||||
const Value *RV = Ret->getOperand(0);
|
const Value *RV = Ret->getOperand(0);
|
||||||
|
|
||||||
|
|
|
@ -2386,8 +2386,8 @@ PPCTargetLowering::LowerFormalArguments_32SVR4(
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Reserve space for the linkage area on the stack.
|
// Reserve space for the linkage area on the stack.
|
||||||
unsigned LinkageSize = PPCFrameLowering::getLinkageSize(false, false, false);
|
unsigned LinkageSize = PPCFrameLowering::getLinkageSize(false, false, false);
|
||||||
|
@ -2461,7 +2461,7 @@ PPCTargetLowering::LowerFormalArguments_32SVR4(
|
||||||
// caller's stack frame, right above the parameter list area.
|
// caller's stack frame, right above the parameter list area.
|
||||||
SmallVector<CCValAssign, 16> ByValArgLocs;
|
SmallVector<CCValAssign, 16> ByValArgLocs;
|
||||||
CCState CCByValInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCByValInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
||||||
getTargetMachine(), ByValArgLocs, *DAG.getContext());
|
ByValArgLocs, *DAG.getContext());
|
||||||
|
|
||||||
// Reserve stack space for the allocations in CCInfo.
|
// Reserve stack space for the allocations in CCInfo.
|
||||||
CCByValInfo.AllocateStack(CCInfo.getNextStackOffset(), PtrByteSize);
|
CCByValInfo.AllocateStack(CCInfo.getNextStackOffset(), PtrByteSize);
|
||||||
|
@ -3743,8 +3743,8 @@ PPCTargetLowering::LowerCallResult(SDValue Chain, SDValue InFlag,
|
||||||
SmallVectorImpl<SDValue> &InVals) const {
|
SmallVectorImpl<SDValue> &InVals) const {
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCRetInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCRetInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCRetInfo.AnalyzeCallResult(Ins, RetCC_PPC);
|
CCRetInfo.AnalyzeCallResult(Ins, RetCC_PPC);
|
||||||
|
|
||||||
// Copy all of the result registers out of their specified physreg.
|
// Copy all of the result registers out of their specified physreg.
|
||||||
|
@ -3959,8 +3959,8 @@ PPCTargetLowering::LowerCall_32SVR4(SDValue Chain, SDValue Callee,
|
||||||
|
|
||||||
// Assign locations to all of the outgoing arguments.
|
// Assign locations to all of the outgoing arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Reserve space for the linkage area on the stack.
|
// Reserve space for the linkage area on the stack.
|
||||||
CCInfo.AllocateStack(PPCFrameLowering::getLinkageSize(false, false, false),
|
CCInfo.AllocateStack(PPCFrameLowering::getLinkageSize(false, false, false),
|
||||||
|
@ -4001,7 +4001,7 @@ PPCTargetLowering::LowerCall_32SVR4(SDValue Chain, SDValue Callee,
|
||||||
// Assign locations to all of the outgoing aggregate by value arguments.
|
// Assign locations to all of the outgoing aggregate by value arguments.
|
||||||
SmallVector<CCValAssign, 16> ByValArgLocs;
|
SmallVector<CCValAssign, 16> ByValArgLocs;
|
||||||
CCState CCByValInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCByValInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
||||||
getTargetMachine(), ByValArgLocs, *DAG.getContext());
|
ByValArgLocs, *DAG.getContext());
|
||||||
|
|
||||||
// Reserve stack space for the allocations in CCInfo.
|
// Reserve stack space for the allocations in CCInfo.
|
||||||
CCByValInfo.AllocateStack(CCInfo.getNextStackOffset(), PtrByteSize);
|
CCByValInfo.AllocateStack(CCInfo.getNextStackOffset(), PtrByteSize);
|
||||||
|
@ -5037,8 +5037,7 @@ PPCTargetLowering::CanLowerReturn(CallingConv::ID CallConv,
|
||||||
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
||||||
LLVMContext &Context) const {
|
LLVMContext &Context) const {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, getTargetMachine(),
|
CCState CCInfo(CallConv, isVarArg, MF, RVLocs, Context);
|
||||||
RVLocs, Context);
|
|
||||||
return CCInfo.CheckReturn(Outs, RetCC_PPC);
|
return CCInfo.CheckReturn(Outs, RetCC_PPC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5050,8 +5049,8 @@ PPCTargetLowering::LowerReturn(SDValue Chain,
|
||||||
SDLoc dl, SelectionDAG &DAG) const {
|
SDLoc dl, SelectionDAG &DAG) const {
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_PPC);
|
CCInfo.AnalyzeReturn(Outs, RetCC_PPC);
|
||||||
|
|
||||||
SDValue Flag;
|
SDValue Flag;
|
||||||
|
|
|
@ -59,16 +59,24 @@ def CC_AMDGPU_Kernel : CallingConv<[
|
||||||
]>;
|
]>;
|
||||||
|
|
||||||
def CC_AMDGPU : CallingConv<[
|
def CC_AMDGPU : CallingConv<[
|
||||||
CCIf<"State.getTarget().getSubtarget<AMDGPUSubtarget>().getGeneration() >= "
|
CCIf<"static_cast<const AMDGPUSubtarget&>"
|
||||||
"AMDGPUSubtarget::SOUTHERN_ISLANDS && "
|
"(State.getMachineFunction().getSubtarget()).getGeneration() >="
|
||||||
"State.getMachineFunction().getInfo<SIMachineFunctionInfo>()->"#
|
"AMDGPUSubtarget::SOUTHERN_ISLANDS && "
|
||||||
"getShaderType() == ShaderType::COMPUTE", CCDelegateTo<CC_AMDGPU_Kernel>>,
|
"State.getMachineFunction().getInfo<SIMachineFunctionInfo>()"
|
||||||
CCIf<"State.getTarget().getSubtarget<AMDGPUSubtarget>().getGeneration() < "
|
"->getShaderType() == ShaderType::COMPUTE",
|
||||||
"AMDGPUSubtarget::SOUTHERN_ISLANDS && "
|
CCDelegateTo<CC_AMDGPU_Kernel>>,
|
||||||
"State.getMachineFunction().getInfo<R600MachineFunctionInfo>()->"
|
CCIf<"static_cast<const AMDGPUSubtarget&>"
|
||||||
"getShaderType() == ShaderType::COMPUTE", CCDelegateTo<CC_AMDGPU_Kernel>>,
|
"(State.getMachineFunction().getSubtarget()).getGeneration() < "
|
||||||
CCIf<"State.getTarget().getSubtarget<AMDGPUSubtarget>()"#
|
"AMDGPUSubtarget::SOUTHERN_ISLANDS && "
|
||||||
".getGeneration() >= AMDGPUSubtarget::SOUTHERN_ISLANDS", CCDelegateTo<CC_SI>>,
|
"State.getMachineFunction().getInfo<R600MachineFunctionInfo>()"
|
||||||
CCIf<"State.getTarget().getSubtarget<AMDGPUSubtarget>()"#
|
"->getShaderType() == ShaderType::COMPUTE",
|
||||||
".getGeneration() < AMDGPUSubtarget::SOUTHERN_ISLANDS", CCDelegateTo<CC_R600>>
|
CCDelegateTo<CC_AMDGPU_Kernel>>,
|
||||||
|
CCIf<"static_cast<const AMDGPUSubtarget&>"
|
||||||
|
"(State.getMachineFunction().getSubtarget()).getGeneration() >= "
|
||||||
|
"AMDGPUSubtarget::SOUTHERN_ISLANDS",
|
||||||
|
CCDelegateTo<CC_SI>>,
|
||||||
|
CCIf<"static_cast<const AMDGPUSubtarget&>"
|
||||||
|
"(State.getMachineFunction().getSubtarget()).getGeneration() < "
|
||||||
|
"AMDGPUSubtarget::SOUTHERN_ISLANDS",
|
||||||
|
CCDelegateTo<CC_R600>>
|
||||||
]>;
|
]>;
|
||||||
|
|
|
@ -1692,8 +1692,8 @@ SDValue R600TargetLowering::LowerFormalArguments(
|
||||||
SDLoc DL, SelectionDAG &DAG,
|
SDLoc DL, SelectionDAG &DAG,
|
||||||
SmallVectorImpl<SDValue> &InVals) const {
|
SmallVectorImpl<SDValue> &InVals) const {
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
MachineFunction &MF = DAG.getMachineFunction();
|
MachineFunction &MF = DAG.getMachineFunction();
|
||||||
unsigned ShaderType = MF.getInfo<R600MachineFunctionInfo>()->getShaderType();
|
unsigned ShaderType = MF.getInfo<R600MachineFunctionInfo>()->getShaderType();
|
||||||
|
|
||||||
|
|
|
@ -395,8 +395,8 @@ SDValue SITargetLowering::LowerFormalArguments(
|
||||||
}
|
}
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// At least one interpolation mode must be enabled or else the GPU will hang.
|
// At least one interpolation mode must be enabled or else the GPU will hang.
|
||||||
if (Info->getShaderType() == ShaderType::PIXEL &&
|
if (Info->getShaderType() == ShaderType::PIXEL &&
|
||||||
|
|
|
@ -190,8 +190,8 @@ SparcTargetLowering::LowerReturn_32(SDValue Chain,
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slot.
|
// CCState - Info about the registers and stack slot.
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
DAG.getTarget(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Analyze return values.
|
// Analyze return values.
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_Sparc32);
|
CCInfo.AnalyzeReturn(Outs, RetCC_Sparc32);
|
||||||
|
@ -250,8 +250,8 @@ SparcTargetLowering::LowerReturn_64(SDValue Chain,
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slot.
|
// CCState - Info about the registers and stack slot.
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
DAG.getTarget(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Analyze return values.
|
// Analyze return values.
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_Sparc64);
|
CCInfo.AnalyzeReturn(Outs, RetCC_Sparc64);
|
||||||
|
@ -349,8 +349,8 @@ LowerFormalArguments_32(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeFormalArguments(Ins, CC_Sparc32);
|
CCInfo.AnalyzeFormalArguments(Ins, CC_Sparc32);
|
||||||
|
|
||||||
const unsigned StackOffset = 92;
|
const unsigned StackOffset = 92;
|
||||||
|
@ -549,8 +549,8 @@ LowerFormalArguments_64(SDValue Chain,
|
||||||
|
|
||||||
// Analyze arguments according to CC_Sparc64.
|
// Analyze arguments according to CC_Sparc64.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, IsVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeFormalArguments(Ins, CC_Sparc64);
|
CCInfo.AnalyzeFormalArguments(Ins, CC_Sparc64);
|
||||||
|
|
||||||
// The argument array begins at %fp+BIAS+128, after the register save area.
|
// The argument array begins at %fp+BIAS+128, after the register save area.
|
||||||
|
@ -698,8 +698,8 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
DAG.getTarget(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeCallOperands(Outs, CC_Sparc32);
|
CCInfo.AnalyzeCallOperands(Outs, CC_Sparc32);
|
||||||
|
|
||||||
// Get the size of the outgoing arguments stack space requirement.
|
// Get the size of the outgoing arguments stack space requirement.
|
||||||
|
@ -934,8 +934,8 @@ SparcTargetLowering::LowerCall_32(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState RVInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState RVInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
DAG.getTarget(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
RVInfo.AnalyzeCallResult(Ins, RetCC_Sparc32);
|
RVInfo.AnalyzeCallResult(Ins, RetCC_Sparc32);
|
||||||
|
|
||||||
|
@ -1061,8 +1061,8 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CLI.CallConv, CLI.IsVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CLI.CallConv, CLI.IsVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
DAG.getTarget(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeCallOperands(CLI.Outs, CC_Sparc64);
|
CCInfo.AnalyzeCallOperands(CLI.Outs, CC_Sparc64);
|
||||||
|
|
||||||
// Get the size of the outgoing arguments stack space requirement.
|
// Get the size of the outgoing arguments stack space requirement.
|
||||||
|
@ -1255,8 +1255,8 @@ SparcTargetLowering::LowerCall_64(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState RVInfo(CLI.CallConv, CLI.IsVarArg, DAG.getMachineFunction(),
|
CCState RVInfo(CLI.CallConv, CLI.IsVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
DAG.getTarget(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Set inreg flag manually for codegen generated library calls that
|
// Set inreg flag manually for codegen generated library calls that
|
||||||
// return float.
|
// return float.
|
||||||
|
|
|
@ -679,8 +679,7 @@ LowerFormalArguments(SDValue Chain, CallingConv::ID CallConv, bool IsVarArg,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, IsVarArg, MF, DAG.getTarget(), ArgLocs,
|
CCState CCInfo(CallConv, IsVarArg, MF, ArgLocs, *DAG.getContext());
|
||||||
*DAG.getContext());
|
|
||||||
CCInfo.AnalyzeFormalArguments(Ins, CC_SystemZ);
|
CCInfo.AnalyzeFormalArguments(Ins, CC_SystemZ);
|
||||||
|
|
||||||
unsigned NumFixedGPRs = 0;
|
unsigned NumFixedGPRs = 0;
|
||||||
|
@ -818,8 +817,7 @@ SystemZTargetLowering::LowerCall(CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze the operands of the call, assigning locations to each operand.
|
// Analyze the operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState ArgCCInfo(CallConv, IsVarArg, MF, DAG.getTarget(), ArgLocs,
|
CCState ArgCCInfo(CallConv, IsVarArg, MF, ArgLocs, *DAG.getContext());
|
||||||
*DAG.getContext());
|
|
||||||
ArgCCInfo.AnalyzeCallOperands(Outs, CC_SystemZ);
|
ArgCCInfo.AnalyzeCallOperands(Outs, CC_SystemZ);
|
||||||
|
|
||||||
// We don't support GuaranteedTailCallOpt, only automatically-detected
|
// We don't support GuaranteedTailCallOpt, only automatically-detected
|
||||||
|
@ -942,8 +940,7 @@ SystemZTargetLowering::LowerCall(CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RetLocs;
|
SmallVector<CCValAssign, 16> RetLocs;
|
||||||
CCState RetCCInfo(CallConv, IsVarArg, MF, DAG.getTarget(), RetLocs,
|
CCState RetCCInfo(CallConv, IsVarArg, MF, RetLocs, *DAG.getContext());
|
||||||
*DAG.getContext());
|
|
||||||
RetCCInfo.AnalyzeCallResult(Ins, RetCC_SystemZ);
|
RetCCInfo.AnalyzeCallResult(Ins, RetCC_SystemZ);
|
||||||
|
|
||||||
// Copy all of the result registers out of their specified physreg.
|
// Copy all of the result registers out of their specified physreg.
|
||||||
|
@ -974,8 +971,7 @@ SystemZTargetLowering::LowerReturn(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to each returned value.
|
// Assign locations to each returned value.
|
||||||
SmallVector<CCValAssign, 16> RetLocs;
|
SmallVector<CCValAssign, 16> RetLocs;
|
||||||
CCState RetCCInfo(CallConv, IsVarArg, MF, DAG.getTarget(), RetLocs,
|
CCState RetCCInfo(CallConv, IsVarArg, MF, RetLocs, *DAG.getContext());
|
||||||
*DAG.getContext());
|
|
||||||
RetCCInfo.AnalyzeReturn(Outs, RetCC_SystemZ);
|
RetCCInfo.AnalyzeReturn(Outs, RetCC_SystemZ);
|
||||||
|
|
||||||
// Quick exit for void returns
|
// Quick exit for void returns
|
||||||
|
|
|
@ -14,7 +14,9 @@
|
||||||
|
|
||||||
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
||||||
class CCIfSubtarget<string F, CCAction A>
|
class CCIfSubtarget<string F, CCAction A>
|
||||||
: CCIf<!strconcat("State.getTarget().getSubtarget<X86Subtarget>().", F), A>;
|
: CCIf<!strconcat("static_cast<const X86Subtarget&>"
|
||||||
|
"(State.getMachineFunction().getSubtarget()).", F),
|
||||||
|
A>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Return Value Calling Conventions
|
// Return Value Calling Conventions
|
||||||
|
|
|
@ -993,8 +993,7 @@ bool X86FastISel::X86SelectRet(const Instruction *I) {
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ValLocs;
|
SmallVector<CCValAssign, 16> ValLocs;
|
||||||
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, TM, ValLocs,
|
CCState CCInfo(CC, F.isVarArg(), *FuncInfo.MF, ValLocs, I->getContext());
|
||||||
I->getContext());
|
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_X86);
|
CCInfo.AnalyzeReturn(Outs, RetCC_X86);
|
||||||
|
|
||||||
const Value *RV = Ret->getOperand(0);
|
const Value *RV = Ret->getOperand(0);
|
||||||
|
@ -2730,8 +2729,7 @@ bool X86FastISel::FastLowerCall(CallLoweringInfo &CLI) {
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, TM, ArgLocs,
|
CCState CCInfo(CC, IsVarArg, *FuncInfo.MF, ArgLocs, CLI.RetTy->getContext());
|
||||||
CLI.RetTy->getContext());
|
|
||||||
|
|
||||||
// Allocate shadow area for Win64
|
// Allocate shadow area for Win64
|
||||||
if (IsWin64)
|
if (IsWin64)
|
||||||
|
@ -2972,7 +2970,7 @@ bool X86FastISel::FastLowerCall(CallLoweringInfo &CLI) {
|
||||||
|
|
||||||
// Now handle call return values.
|
// Now handle call return values.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCRetInfo(CC, IsVarArg, *FuncInfo.MF, TM, RVLocs,
|
CCState CCRetInfo(CC, IsVarArg, *FuncInfo.MF, RVLocs,
|
||||||
CLI.RetTy->getContext());
|
CLI.RetTy->getContext());
|
||||||
CCRetInfo.AnalyzeCallResult(Ins, RetCC_X86);
|
CCRetInfo.AnalyzeCallResult(Ins, RetCC_X86);
|
||||||
|
|
||||||
|
|
|
@ -1901,8 +1901,7 @@ X86TargetLowering::CanLowerReturn(CallingConv::ID CallConv,
|
||||||
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
||||||
LLVMContext &Context) const {
|
LLVMContext &Context) const {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, MF.getTarget(),
|
CCState CCInfo(CallConv, isVarArg, MF, RVLocs, Context);
|
||||||
RVLocs, Context);
|
|
||||||
return CCInfo.CheckReturn(Outs, RetCC_X86);
|
return CCInfo.CheckReturn(Outs, RetCC_X86);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1921,8 +1920,7 @@ X86TargetLowering::LowerReturn(SDValue Chain,
|
||||||
X86MachineFunctionInfo *FuncInfo = MF.getInfo<X86MachineFunctionInfo>();
|
X86MachineFunctionInfo *FuncInfo = MF.getInfo<X86MachineFunctionInfo>();
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, DAG.getTarget(),
|
CCState CCInfo(CallConv, isVarArg, MF, RVLocs, *DAG.getContext());
|
||||||
RVLocs, *DAG.getContext());
|
|
||||||
CCInfo.AnalyzeReturn(Outs, RetCC_X86);
|
CCInfo.AnalyzeReturn(Outs, RetCC_X86);
|
||||||
|
|
||||||
SDValue Flag;
|
SDValue Flag;
|
||||||
|
@ -2092,8 +2090,8 @@ X86TargetLowering::LowerCallResult(SDValue Chain, SDValue InFlag,
|
||||||
// Assign locations to each value returned by this call.
|
// Assign locations to each value returned by this call.
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
bool Is64Bit = Subtarget->is64Bit();
|
bool Is64Bit = Subtarget->is64Bit();
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
DAG.getTarget(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeCallResult(Ins, RetCC_X86);
|
CCInfo.AnalyzeCallResult(Ins, RetCC_X86);
|
||||||
|
|
||||||
// Copy all of the result registers out of their specified physreg.
|
// Copy all of the result registers out of their specified physreg.
|
||||||
|
@ -2289,8 +2287,7 @@ X86TargetLowering::LowerFormalArguments(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, DAG.getTarget(),
|
CCState CCInfo(CallConv, isVarArg, MF, ArgLocs, *DAG.getContext());
|
||||||
ArgLocs, *DAG.getContext());
|
|
||||||
|
|
||||||
// Allocate shadow area for Win64
|
// Allocate shadow area for Win64
|
||||||
if (IsWin64)
|
if (IsWin64)
|
||||||
|
@ -2656,8 +2653,7 @@ X86TargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, MF.getTarget(),
|
CCState CCInfo(CallConv, isVarArg, MF, ArgLocs, *DAG.getContext());
|
||||||
ArgLocs, *DAG.getContext());
|
|
||||||
|
|
||||||
// Allocate shadow area for Win64
|
// Allocate shadow area for Win64
|
||||||
if (IsWin64)
|
if (IsWin64)
|
||||||
|
@ -3253,8 +3249,8 @@ X86TargetLowering::IsEligibleForTailCallOptimization(SDValue Callee,
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
DAG.getTarget(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
CCInfo.AnalyzeCallOperands(Outs, CC_X86);
|
CCInfo.AnalyzeCallOperands(Outs, CC_X86);
|
||||||
for (unsigned i = 0, e = ArgLocs.size(); i != e; ++i)
|
for (unsigned i = 0, e = ArgLocs.size(); i != e; ++i)
|
||||||
|
@ -3274,8 +3270,8 @@ X86TargetLowering::IsEligibleForTailCallOptimization(SDValue Callee,
|
||||||
}
|
}
|
||||||
if (Unused) {
|
if (Unused) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CalleeCC, false, DAG.getMachineFunction(),
|
CCState CCInfo(CalleeCC, false, DAG.getMachineFunction(), RVLocs,
|
||||||
DAG.getTarget(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo.AnalyzeCallResult(Ins, RetCC_X86);
|
CCInfo.AnalyzeCallResult(Ins, RetCC_X86);
|
||||||
for (unsigned i = 0, e = RVLocs.size(); i != e; ++i) {
|
for (unsigned i = 0, e = RVLocs.size(); i != e; ++i) {
|
||||||
CCValAssign &VA = RVLocs[i];
|
CCValAssign &VA = RVLocs[i];
|
||||||
|
@ -3288,13 +3284,13 @@ X86TargetLowering::IsEligibleForTailCallOptimization(SDValue Callee,
|
||||||
// results are returned in the same way as what the caller expects.
|
// results are returned in the same way as what the caller expects.
|
||||||
if (!CCMatch) {
|
if (!CCMatch) {
|
||||||
SmallVector<CCValAssign, 16> RVLocs1;
|
SmallVector<CCValAssign, 16> RVLocs1;
|
||||||
CCState CCInfo1(CalleeCC, false, DAG.getMachineFunction(),
|
CCState CCInfo1(CalleeCC, false, DAG.getMachineFunction(), RVLocs1,
|
||||||
DAG.getTarget(), RVLocs1, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo1.AnalyzeCallResult(Ins, RetCC_X86);
|
CCInfo1.AnalyzeCallResult(Ins, RetCC_X86);
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs2;
|
SmallVector<CCValAssign, 16> RVLocs2;
|
||||||
CCState CCInfo2(CallerCC, false, DAG.getMachineFunction(),
|
CCState CCInfo2(CallerCC, false, DAG.getMachineFunction(), RVLocs2,
|
||||||
DAG.getTarget(), RVLocs2, *DAG.getContext());
|
*DAG.getContext());
|
||||||
CCInfo2.AnalyzeCallResult(Ins, RetCC_X86);
|
CCInfo2.AnalyzeCallResult(Ins, RetCC_X86);
|
||||||
|
|
||||||
if (RVLocs1.size() != RVLocs2.size())
|
if (RVLocs1.size() != RVLocs2.size())
|
||||||
|
@ -3320,8 +3316,8 @@ X86TargetLowering::IsEligibleForTailCallOptimization(SDValue Callee,
|
||||||
// Check if stack adjustment is needed. For now, do not do this if any
|
// Check if stack adjustment is needed. For now, do not do this if any
|
||||||
// argument is passed on the stack.
|
// argument is passed on the stack.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CalleeCC, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
DAG.getTarget(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Allocate shadow area for Win64
|
// Allocate shadow area for Win64
|
||||||
if (IsCalleeWin64)
|
if (IsCalleeWin64)
|
||||||
|
|
|
@ -1125,8 +1125,8 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
||||||
|
|
||||||
// Analyze operands of the call, assigning locations to each operand.
|
// Analyze operands of the call, assigning locations to each operand.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// The ABI dictates there should be one stack slot available to the callee
|
// The ABI dictates there should be one stack slot available to the callee
|
||||||
// on function entry (for saving lr).
|
// on function entry (for saving lr).
|
||||||
|
@ -1136,8 +1136,8 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,
|
||||||
|
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
// Analyze return values to determine the number of bytes of stack required.
|
// Analyze return values to determine the number of bytes of stack required.
|
||||||
CCState RetCCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState RetCCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
RetCCInfo.AllocateStack(CCInfo.getNextStackOffset(), 4);
|
RetCCInfo.AllocateStack(CCInfo.getNextStackOffset(), 4);
|
||||||
RetCCInfo.AnalyzeCallResult(Ins, RetCC_XCore);
|
RetCCInfo.AnalyzeCallResult(Ins, RetCC_XCore);
|
||||||
|
|
||||||
|
@ -1291,8 +1291,8 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,
|
||||||
|
|
||||||
// Assign locations to all of the incoming arguments.
|
// Assign locations to all of the incoming arguments.
|
||||||
SmallVector<CCValAssign, 16> ArgLocs;
|
SmallVector<CCValAssign, 16> ArgLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), ArgLocs,
|
||||||
getTargetMachine(), ArgLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
CCInfo.AnalyzeFormalArguments(Ins, CC_XCore);
|
CCInfo.AnalyzeFormalArguments(Ins, CC_XCore);
|
||||||
|
|
||||||
|
@ -1450,7 +1450,7 @@ CanLowerReturn(CallingConv::ID CallConv, MachineFunction &MF,
|
||||||
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
const SmallVectorImpl<ISD::OutputArg> &Outs,
|
||||||
LLVMContext &Context) const {
|
LLVMContext &Context) const {
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
CCState CCInfo(CallConv, isVarArg, MF, getTargetMachine(), RVLocs, Context);
|
CCState CCInfo(CallConv, isVarArg, MF, RVLocs, Context);
|
||||||
if (!CCInfo.CheckReturn(Outs, RetCC_XCore))
|
if (!CCInfo.CheckReturn(Outs, RetCC_XCore))
|
||||||
return false;
|
return false;
|
||||||
if (CCInfo.getNextStackOffset() != 0 && isVarArg)
|
if (CCInfo.getNextStackOffset() != 0 && isVarArg)
|
||||||
|
@ -1474,8 +1474,8 @@ XCoreTargetLowering::LowerReturn(SDValue Chain,
|
||||||
SmallVector<CCValAssign, 16> RVLocs;
|
SmallVector<CCValAssign, 16> RVLocs;
|
||||||
|
|
||||||
// CCState - Info about the registers and stack slot.
|
// CCState - Info about the registers and stack slot.
|
||||||
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(),
|
CCState CCInfo(CallConv, isVarArg, DAG.getMachineFunction(), RVLocs,
|
||||||
getTargetMachine(), RVLocs, *DAG.getContext());
|
*DAG.getContext());
|
||||||
|
|
||||||
// Analyze return values.
|
// Analyze return values.
|
||||||
if (!isVarArg)
|
if (!isVarArg)
|
||||||
|
|
|
@ -179,14 +179,14 @@ void CallingConvEmitter::EmitAction(Record *Action,
|
||||||
O << Size << ", ";
|
O << Size << ", ";
|
||||||
else
|
else
|
||||||
O << "\n" << IndentStr
|
O << "\n" << IndentStr
|
||||||
<< " State.getTarget().getSubtargetImpl()->getDataLayout()"
|
<< " State.getMachineFunction().getSubtarget().getDataLayout()"
|
||||||
"->getTypeAllocSize(EVT(LocVT).getTypeForEVT(State.getContext())),"
|
"->getTypeAllocSize(EVT(LocVT).getTypeForEVT(State.getContext())),"
|
||||||
" ";
|
" ";
|
||||||
if (Align)
|
if (Align)
|
||||||
O << Align;
|
O << Align;
|
||||||
else
|
else
|
||||||
O << "\n" << IndentStr
|
O << "\n" << IndentStr
|
||||||
<< " State.getTarget().getSubtargetImpl()->getDataLayout()"
|
<< " State.getMachineFunction().getSubtarget().getDataLayout()"
|
||||||
"->getABITypeAlignment(EVT(LocVT).getTypeForEVT(State.getContext()"
|
"->getABITypeAlignment(EVT(LocVT).getTypeForEVT(State.getContext()"
|
||||||
"))";
|
"))";
|
||||||
O << ");\n" << IndentStr
|
O << ");\n" << IndentStr
|
||||||
|
|
Loading…
Reference in New Issue