mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-04 06:12:18 +00:00
Fixed comment for libcalls.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67373 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
91520ea585
commit
e9d81f0ad8
@ -191,18 +191,21 @@ MVT PIC16TargetLowering::getSetCCResultType(MVT ValType) const {
|
|||||||
return MVT::i8;
|
return MVT::i8;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// FIXME: These three functions below should not be here if we change
|
/// The type legalizer framework of generating legalizer can generate libcalls
|
||||||
/// the generic code to allow generting libcalls for I8 types as well.
|
/// only when the operand/result types are illegal.
|
||||||
|
/// PIC16 needs to generate libcalls even for the legal types (i8) for some ops.
|
||||||
|
/// For example an arithmetic right shift. These functions are used to lower
|
||||||
|
/// such operations that generate libcall for legal types.
|
||||||
|
|
||||||
void
|
void
|
||||||
PIC16TargetLowering::setPIC16LibcallName(PIC16ISD::PIC16Libcall Call,
|
PIC16TargetLowering::setPIC16LibcallName(PIC16ISD::PIC16Libcall Call,
|
||||||
const char *Name) {
|
const char *Name) {
|
||||||
PIC16LibcallNames[Call] = Name;
|
PIC16LibcallNames[Call] = Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
PIC16TargetLowering::getPIC16LibcallName(PIC16ISD::PIC16Libcall Call) {
|
PIC16TargetLowering::getPIC16LibcallName(PIC16ISD::PIC16Libcall Call) {
|
||||||
return PIC16LibcallNames[Call];
|
return PIC16LibcallNames[Call];
|
||||||
}
|
}
|
||||||
|
|
||||||
SDValue
|
SDValue
|
||||||
@ -211,23 +214,23 @@ PIC16TargetLowering::MakePIC16Libcall(PIC16ISD::PIC16Libcall Call,
|
|||||||
unsigned NumOps, bool isSigned,
|
unsigned NumOps, bool isSigned,
|
||||||
SelectionDAG &DAG, DebugLoc dl) {
|
SelectionDAG &DAG, DebugLoc dl) {
|
||||||
|
|
||||||
TargetLowering::ArgListTy Args;
|
TargetLowering::ArgListTy Args;
|
||||||
Args.reserve(NumOps);
|
Args.reserve(NumOps);
|
||||||
|
|
||||||
TargetLowering::ArgListEntry Entry;
|
TargetLowering::ArgListEntry Entry;
|
||||||
for (unsigned i = 0; i != NumOps; ++i) {
|
for (unsigned i = 0; i != NumOps; ++i) {
|
||||||
Entry.Node = Ops[i];
|
Entry.Node = Ops[i];
|
||||||
Entry.Ty = Entry.Node.getValueType().getTypeForMVT();
|
Entry.Ty = Entry.Node.getValueType().getTypeForMVT();
|
||||||
Entry.isSExt = isSigned;
|
Entry.isSExt = isSigned;
|
||||||
Entry.isZExt = !isSigned;
|
Entry.isZExt = !isSigned;
|
||||||
Args.push_back(Entry);
|
Args.push_back(Entry);
|
||||||
}
|
}
|
||||||
SDValue Callee = DAG.getExternalSymbol(getPIC16LibcallName(Call), MVT::i8);
|
SDValue Callee = DAG.getExternalSymbol(getPIC16LibcallName(Call), MVT::i8);
|
||||||
|
|
||||||
const Type *RetTy = RetVT.getTypeForMVT();
|
const Type *RetTy = RetVT.getTypeForMVT();
|
||||||
std::pair<SDValue,SDValue> CallInfo =
|
std::pair<SDValue,SDValue> CallInfo =
|
||||||
LowerCallTo(DAG.getEntryNode(), RetTy, isSigned, !isSigned, false,
|
LowerCallTo(DAG.getEntryNode(), RetTy, isSigned, !isSigned, false,
|
||||||
false, CallingConv::C, false, Callee, Args, DAG, dl);
|
false, CallingConv::C, false, Callee, Args, DAG, dl);
|
||||||
|
|
||||||
return CallInfo.first;
|
return CallInfo.first;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user