36#define DEBUG_TYPE "msp430-lower"
40 cl::desc(
"Enable non legal immediates (for testing purposes only)"),
153 const RTLIB::Libcall
Op;
154 const RTLIB::LibcallImpl Impl;
157 {RTLIB::MUL_I16, RTLIB::__mspabi_mpyi_hw},
158 {RTLIB::MUL_I32, RTLIB::__mspabi_mpyl_hw},
159 {RTLIB::MUL_I64, RTLIB::__mspabi_mpyll_hw},
163 for (
const auto &LC : LibraryCalls) {
168 const RTLIB::Libcall
Op;
169 const RTLIB::LibcallImpl Impl;
172 {RTLIB::MUL_I16, RTLIB::__mspabi_mpyi_hw},
173 {RTLIB::MUL_I32, RTLIB::__mspabi_mpyl_hw32},
174 {RTLIB::MUL_I64, RTLIB::__mspabi_mpyll_hw32},
178 for (
const auto &LC : LibraryCalls) {
183 const RTLIB::Libcall
Op;
184 const RTLIB::LibcallImpl Impl;
187 {RTLIB::MUL_I16, RTLIB::__mspabi_mpyi_f5hw},
188 {RTLIB::MUL_I32, RTLIB::__mspabi_mpyl_f5hw},
189 {RTLIB::MUL_I64, RTLIB::__mspabi_mpyll_f5hw},
193 for (
const auto &LC : LibraryCalls) {
198 const RTLIB::Libcall
Op;
199 const RTLIB::LibcallImpl Impl;
202 {RTLIB::MUL_I16, RTLIB::__mspabi_mpyi},
203 {RTLIB::MUL_I32, RTLIB::__mspabi_mpyl},
204 {RTLIB::MUL_I64, RTLIB::__mspabi_mpyll},
208 for (
const auto &LC : LibraryCalls) {
220 switch (
Op.getOpcode()) {
242 unsigned Amount)
const {
243 return !(Amount == 8 || Amount == 9 || Amount<=2);
250 return Immed >= -32 && Immed < 32;
262 if (Constraint.
size() == 1) {
263 switch (Constraint[0]) {
273std::pair<unsigned, const TargetRegisterClass *>
276 if (Constraint.
size() == 1) {
278 switch (Constraint[0]) {
282 return std::make_pair(0U, &MSP430::GR8RegClass);
284 return std::make_pair(0U, &MSP430::GR16RegClass);
295#include "MSP430GenCallingConv.inc"
299template<
typename ArgT>
302 unsigned CurrentArgIndex;
307 CurrentArgIndex = Args[0].OrigArgIndex;
310 for (
auto &Arg : Args) {
311 if (CurrentArgIndex == Arg.OrigArgIndex) {
315 CurrentArgIndex = Arg.OrigArgIndex;
334template<
typename ArgT>
339 MSP430::R12, MSP430::R13, MSP430::R14, MSP430::R15
341 static const unsigned CNbRegs = std::size(CRegList);
342 static const MCPhysReg BuiltinRegList[] = {
343 MSP430::R8, MSP430::R9, MSP430::R10, MSP430::R11,
344 MSP430::R12, MSP430::R13, MSP430::R14, MSP430::R15
346 static const unsigned BuiltinNbRegs = std::size(BuiltinRegList);
353 RegList = BuiltinRegList;
354 NbRegs = BuiltinNbRegs;
370 "Builtin calling convention requires two arguments");
373 unsigned RegsLeft = NbRegs;
374 bool UsedStack =
false;
377 for (
unsigned i = 0, e = ArgsParts.
size(); i != e; i++) {
378 MVT ArgVT = Args[ValNo].VT;
380 Type *OrigTy = Args[ValNo].OrigTy;
385 if (LocVT == MVT::i8) {
389 else if (ArgFlags.
isZExt())
401 unsigned Parts = ArgsParts[i];
405 "Builtin calling convention requires 64-bit arguments");
408 if (!UsedStack && Parts == 2 && RegsLeft == 1) {
415 CC_MSP430_AssignStack(ValNo++, ArgVT, LocVT, LocInfo, ArgFlags, OrigTy,
417 }
else if (Parts <= RegsLeft) {
418 for (
unsigned j = 0; j < Parts; j++) {
425 for (
unsigned j = 0; j < Parts; j++)
426 CC_MSP430_AssignStack(ValNo++, ArgVT, LocVT, LocInfo, ArgFlags, OrigTy,
442template<
typename ArgT>
449SDValue MSP430TargetLowering::LowerFormalArguments(
459 return LowerCCCArguments(Chain, CallConv, isVarArg, Ins, dl, DAG, InVals);
490 return LowerCCCCallTo(Chain, Callee, CallConv, isVarArg, isTailCall,
491 Outs, OutVals, Ins, dl, DAG, InVals);
500SDValue MSP430TargetLowering::LowerCCCArguments(
517 unsigned Offset = CCInfo.getStackSize();
521 for (
unsigned i = 0, e = ArgLocs.size(); i != e; ++i) {
530 errs() <<
"LowerFormalArguments Unhandled argument type: "
562 if (
Flags.isByVal()) {
571 errs() <<
"LowerFormalArguments Unhandled argument type: "
589 for (
unsigned i = 0, e = ArgLocs.size(); i != e; ++i) {
590 if (Ins[i].
Flags.isSRet()) {
613 CCState CCInfo(CallConv, IsVarArg, MF, RVLocs, Context);
614 return CCInfo.CheckReturn(Outs, RetCC_MSP430);
644 for (
unsigned i = 0; i != RVLocs.
size(); ++i) {
667 unsigned R12 = MSP430::R12;
675 MSP430ISD::RETI_GLUE : MSP430ISD::RET_GLUE);
681 RetOps.push_back(Glue);
683 return DAG.
getNode(
Opc, dl, MVT::Other, RetOps);
688SDValue MSP430TargetLowering::LowerCCCCallTo(
701 unsigned NumBytes = CCInfo.getStackSize();
711 for (
unsigned i = 0, e = ArgLocs.
size(); i != e; ++i) {
748 if (
Flags.isByVal()) {
751 Flags.getNonZeroByValAlign(),
754 nullptr, std::nullopt,
766 if (!MemOpChains.
empty())
773 for (
const auto &[Reg,
N] : RegsToPass) {
794 for (
const auto &[Reg,
N] : RegsToPass)
800 Chain = DAG.
getNode(MSP430ISD::CALL, dl, NodeTys, Ops);
809 return LowerCallResult(Chain, InGlue, CallConv, isVarArg, Ins, dl,
816SDValue MSP430TargetLowering::LowerCallResult(
829 for (
unsigned i = 0; i != RVLocs.
size(); ++i) {
831 RVLocs[i].getValVT(), InGlue).
getValue(1);
841 unsigned Opc =
Op.getOpcode();
843 EVT VT =
Op.getValueType();
847 if (!isa<ConstantSDNode>(
N->getOperand(1)))
850 uint64_t ShiftAmount =
N->getConstantOperandVal(1);
855 if (ShiftAmount >= 8) {
856 assert(VT == MVT::i16 &&
"Can not shift i8 by 8 and more");
881 Victim = DAG.
getNode(MSP430ISD::RRCL, dl, VT, Victim);
885 while (ShiftAmount--)
894 const GlobalValue *GV = cast<GlobalAddressSDNode>(
Op)->getGlobal();
895 int64_t
Offset = cast<GlobalAddressSDNode>(
Op)->getOffset();
896 EVT PtrVT =
Op.getValueType();
906 const char *
Sym = cast<ExternalSymbolSDNode>(
Op)->getSymbol();
907 EVT PtrVT =
Op.getValueType();
910 return DAG.
getNode(MSP430ISD::Wrapper, dl, PtrVT, Result);
916 const BlockAddress *BA = cast<BlockAddressSDNode>(
Op)->getBlockAddress();
917 EVT PtrVT =
Op.getValueType();
920 return DAG.
getNode(MSP430ISD::Wrapper, dl, PtrVT, Result);
926 assert(!
LHS.getValueType().isFloatingPoint() &&
"We don't handle FP yet");
1005 return DAG.
getNode(MSP430ISD::CMP, dl, MVT::Glue,
LHS,
RHS);
1020 return DAG.
getNode(MSP430ISD::BR_CC, dl,
Op.getValueType(),
1021 Chain, Dest, TargetCC, Flag);
1046 bool Invert =
false;
1048 bool Convert =
true;
1075 EVT VT =
Op.getValueType();
1089 SDValue Ops[] = {One, Zero, TargetCC, Flag};
1090 return DAG.
getNode(MSP430ISD::SELECT_CC, dl,
Op.getValueType(), Ops);
1106 SDValue Ops[] = {TrueV, FalseV, TargetCC, Flag};
1108 return DAG.
getNode(MSP430ISD::SELECT_CC, dl,
Op.getValueType(), Ops);
1114 EVT VT =
Op.getValueType();
1117 assert(VT == MVT::i16 &&
"Only support i16 for now!");
1128 int ReturnAddrIndex = FuncInfo->
getRAIndex();
1131 if (ReturnAddrIndex == 0) {
1147 unsigned Depth =
Op.getConstantOperandVal(0);
1149 EVT PtrVT =
Op.getValueType();
1171 EVT VT =
Op.getValueType();
1173 unsigned Depth =
Op.getConstantOperandVal(0);
1188 EVT PtrVT =
Ptr.getValueType();
1193 const Value *SV = cast<SrcValueSDNode>(
Op.getOperand(2))->getValue();
1203 EVT PtrVT =
Op.getValueType();
1205 return DAG.
getNode(MSP430ISD::Wrapper,
SDLoc(JT), PtrVT, Result);
1211bool MSP430TargetLowering::getPostIndexedAddressParts(
SDNode *
N,
SDNode *
Op,
1221 EVT VT = LD->getMemoryVT();
1222 if (VT != MVT::i8 && VT != MVT::i16)
1230 if ((VT == MVT::i16 && RHSC != 2) ||
1231 (VT == MVT::i8 && RHSC != 1))
1234 Base =
Op->getOperand(0);
1266 return false && VT1 == MVT::i8 && VT2 == MVT::i16;
1282 bool ClearCarry =
false;
1284 switch (
MI.getOpcode()) {
1287 Opc = MSP430::ADD8rr;
1288 RC = &MSP430::GR8RegClass;
1291 Opc = MSP430::ADD16rr;
1292 RC = &MSP430::GR16RegClass;
1295 Opc = MSP430::RRA8r;
1296 RC = &MSP430::GR8RegClass;
1299 Opc = MSP430::RRA16r;
1300 RC = &MSP430::GR16RegClass;
1304 Opc = MSP430::RRC8r;
1305 RC = &MSP430::GR8RegClass;
1309 Opc = MSP430::RRC16r;
1310 RC = &MSP430::GR16RegClass;
1313 case MSP430::Rrcl16: {
1314 BuildMI(*BB,
MI, dl,
TII.get(MSP430::BIC16rc), MSP430::SR)
1318 unsigned RrcOpc =
MI.getOpcode() == MSP430::Rrcl16
1319 ? MSP430::RRC16r : MSP430::RRC8r;
1322 MI.eraseFromParent();
1334 F->insert(
I, LoopBB);
1335 F->insert(
I, RemBB);
1353 Register ShiftAmtSrcReg =
MI.getOperand(2).getReg();
1371 BuildMI(LoopBB, dl,
TII.get(MSP430::PHI), ShiftReg)
1374 BuildMI(LoopBB, dl,
TII.get(MSP430::PHI), ShiftAmtReg)
1378 BuildMI(LoopBB, dl,
TII.get(MSP430::BIC16rc), MSP430::SR)
1380 if (
Opc == MSP430::ADD8rr ||
Opc == MSP430::ADD16rr)
1387 BuildMI(LoopBB, dl,
TII.get(MSP430::SUB8ri), ShiftAmtReg2)
1399 MI.eraseFromParent();
1406 unsigned Opc =
MI.getOpcode();
1408 if (
Opc == MSP430::Shl8 ||
Opc == MSP430::Shl16 ||
1409 Opc == MSP430::Sra8 ||
Opc == MSP430::Sra16 ||
1410 Opc == MSP430::Srl8 ||
Opc == MSP430::Srl16 ||
1411 Opc == MSP430::Rrcl8 ||
Opc == MSP430::Rrcl16)
1417 assert((
Opc == MSP430::Select16 ||
Opc == MSP430::Select8) &&
1418 "Unexpected instr type to insert");
1437 F->insert(
I, copy0MBB);
1438 F->insert(
I, copy1MBB);
1450 .
addImm(
MI.getOperand(3).getImm());
1470 MI.eraseFromParent();
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
const HexagonInstrInfo * TII
static void AnalyzeReturnValues(CCState &State, SmallVectorImpl< CCValAssign > &RVLocs, const SmallVectorImpl< ArgT > &Args)
static void AnalyzeVarArgs(CCState &State, const SmallVectorImpl< ISD::OutputArg > &Outs)
static void AnalyzeRetResult(CCState &State, const SmallVectorImpl< ISD::InputArg > &Ins)
static cl::opt< bool > MSP430NoLegalImmediate("msp430-no-legal-immediate", cl::Hidden, cl::desc("Enable non legal immediates (for testing purposes only)"), cl::init(false))
static void ParseFunctionArgs(const SmallVectorImpl< ArgT > &Args, SmallVectorImpl< unsigned > &Out)
For each argument in a function store the number of pieces it is composed of.
static void AnalyzeArguments(CCState &State, SmallVectorImpl< CCValAssign > &ArgLocs, const SmallVectorImpl< ArgT > &Args)
Analyze incoming and outgoing function arguments.
static SDValue EmitCMP(SDValue &LHS, SDValue &RHS, SDValue &TargetCC, ISD::CondCode CC, const SDLoc &dl, SelectionDAG &DAG)
Register const TargetRegisterInfo * TRI
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
LLVM Basic Block Representation.
The address of a basic block.
CCState - This class holds information needed while lowering arguments and return values.
LLVM_ABI void HandleByVal(unsigned ValNo, MVT ValVT, MVT LocVT, CCValAssign::LocInfo LocInfo, int MinSize, Align MinAlign, ISD::ArgFlagsTy ArgFlags)
Allocate space on the stack large enough to pass an argument by value.
LLVM_ABI void AnalyzeCallResult(const SmallVectorImpl< ISD::InputArg > &Ins, CCAssignFn Fn)
AnalyzeCallResult - Analyze the return values of a call, incorporating info about the passed values i...
CallingConv::ID getCallingConv() const
MCRegister AllocateReg(MCPhysReg Reg)
AllocateReg - Attempt to allocate one register.
LLVM_ABI void AnalyzeReturn(const SmallVectorImpl< ISD::OutputArg > &Outs, CCAssignFn Fn)
AnalyzeReturn - Analyze the returned values of a return, incorporating info about the result values i...
LLVM_ABI void AnalyzeCallOperands(const SmallVectorImpl< ISD::OutputArg > &Outs, CCAssignFn Fn)
AnalyzeCallOperands - Analyze the outgoing arguments to a call, incorporating info about the passed v...
LLVM_ABI void AnalyzeFormalArguments(const SmallVectorImpl< ISD::InputArg > &Ins, CCAssignFn Fn)
AnalyzeFormalArguments - Analyze an array of argument values, incorporating info about the formals in...
void addLoc(const CCValAssign &V)
CCValAssign - Represent assignment of one arg/retval to a location.
Register getLocReg() const
LocInfo getLocInfo() const
static CCValAssign getReg(unsigned ValNo, MVT ValVT, MCRegister Reg, MVT LocVT, LocInfo HTP, bool IsCustom=false)
int64_t getLocMemOffset() const
This class represents an Operation in the Expression.
bool hasStructRetAttr() const
Determine if the function returns a structure through first or second pointer argument.
This is an important class for using LLVM in a threaded context.
This class is used to represent ISD::LOAD nodes.
Wrapper class representing physical registers. Should be passed by value.
MSP430MachineFunctionInfo - This class is derived from MachineFunction and contains private MSP430 ta...
void setVarArgsFrameIndex(int Index)
Register getSRetReturnReg() const
void setRAIndex(int Index)
void setSRetReturnReg(Register Reg)
int getVarArgsFrameIndex() const
const MSP430RegisterInfo * getRegisterInfo() const override
SDValue getReturnAddressFrameIndex(SelectionDAG &DAG) const
MSP430TargetLowering(const TargetMachine &TM, const MSP430Subtarget &STI)
std::pair< unsigned, const TargetRegisterClass * > getRegForInlineAsmConstraint(const TargetRegisterInfo *TRI, StringRef Constraint, MVT VT) const override
Given a physical register constraint (e.g.
SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override
LowerOperation - Provide custom lowering hooks for some operations.
MachineBasicBlock * EmitShiftInstr(MachineInstr &MI, MachineBasicBlock *BB) const
SDValue LowerJumpTable(SDValue Op, SelectionDAG &DAG) const
SDValue LowerSELECT_CC(SDValue Op, SelectionDAG &DAG) const
SDValue LowerExternalSymbol(SDValue Op, SelectionDAG &DAG) const
bool isTruncateFree(Type *Ty1, Type *Ty2) const override
isTruncateFree - Return true if it's free to truncate a value of type Ty1 to type Ty2.
SDValue LowerBlockAddress(SDValue Op, SelectionDAG &DAG) const
SDValue LowerShifts(SDValue Op, SelectionDAG &DAG) const
SDValue LowerFRAMEADDR(SDValue Op, SelectionDAG &DAG) const
SDValue LowerGlobalAddress(SDValue Op, SelectionDAG &DAG) const
SDValue LowerSIGN_EXTEND(SDValue Op, SelectionDAG &DAG) const
MachineBasicBlock * EmitInstrWithCustomInserter(MachineInstr &MI, MachineBasicBlock *BB) const override
This method should be implemented by targets that mark instructions with the 'usesCustomInserter' fla...
SDValue LowerRETURNADDR(SDValue Op, SelectionDAG &DAG) const
SDValue LowerVASTART(SDValue Op, SelectionDAG &DAG) const
SDValue LowerSETCC(SDValue Op, SelectionDAG &DAG) const
SDValue LowerBR_CC(SDValue Op, SelectionDAG &DAG) const
bool shouldAvoidTransformToShift(EVT VT, unsigned Amount) const override
Return true if creating a shift of the type by the given amount is not profitable.
bool isZExtFree(Type *Ty1, Type *Ty2) const override
isZExtFree - Return true if any actual instruction that defines a value of type Ty1 implicit zero-ext...
TargetLowering::ConstraintType getConstraintType(StringRef Constraint) const override
getConstraintType - Given a constraint letter, return the type of constraint it is for this target.
bool isLegalICmpImmediate(int64_t) const override
Return true if the specified immediate is legal icmp immediate, that is the target has icmp instructi...
static auto integer_valuetypes()
TypeSize getSizeInBits() const
Returns the size of the specified MVT in bits.
TypeSize getStoreSize() const
Return the number of bytes overwritten by a store of the specified value type.
LLVM_ABI void transferSuccessorsAndUpdatePHIs(MachineBasicBlock *FromMBB)
Transfers all the successors, as in transferSuccessors, and update PHI operands in the successor bloc...
const BasicBlock * getBasicBlock() const
Return the LLVM basic block that this instance corresponded to originally.
LLVM_ABI void addSuccessor(MachineBasicBlock *Succ, BranchProbability Prob=BranchProbability::getUnknown())
Add Succ as a successor of this MachineBasicBlock.
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
void splice(iterator Where, MachineBasicBlock *Other, iterator From)
Take an instruction from MBB 'Other' at the position From, and insert it into this MBB right before '...
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
LLVM_ABI int CreateFixedObject(uint64_t Size, int64_t SPOffset, bool IsImmutable, bool isAliased=false)
Create a new object at a fixed location on the stack.
void setFrameAddressIsTaken(bool T)
void setReturnAddressIsTaken(bool s)
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
const DataLayout & getDataLayout() const
Return the DataLayout attached to the Module associated to this MF.
Function & getFunction()
Return the LLVM function that this machine code represents.
Ty * getInfo()
getInfo - Keep track of various per-function pieces of information for backends that would like to do...
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
const MachineInstrBuilder & addReg(Register RegNo, unsigned flags=0, unsigned SubReg=0) const
Add a new virtual register operand.
const MachineInstrBuilder & addMBB(MachineBasicBlock *MBB, unsigned TargetFlags=0) const
Representation of each machine instruction.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
LLVM_ABI Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
Wrapper class representing virtual and physical registers.
Wrapper class for IR location info (IR ordering and DebugLoc) to be passed into SDNode creation funct...
Represents one node in the SelectionDAG.
uint64_t getAsZExtVal() const
Helper method returns the zero-extended integer value of a ConstantSDNode.
Unlike LLVM values, Selection DAG nodes may return multiple values as the result of a computation.
SDNode * getNode() const
get the SDNode which holds the desired result
SDValue getValue(unsigned R) const
EVT getValueType() const
Return the ValueType of the referenced return value.
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
SDValue getTargetGlobalAddress(const GlobalValue *GV, const SDLoc &DL, EVT VT, int64_t offset=0, unsigned TargetFlags=0)
SDValue getCopyToReg(SDValue Chain, const SDLoc &dl, Register Reg, SDValue N)
LLVM_ABI SDVTList getVTList(EVT VT)
Return an SDVTList that represents the list of values specified.
LLVM_ABI SDValue getRegister(Register Reg, EVT VT)
LLVM_ABI SDValue getLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, MachinePointerInfo PtrInfo, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr)
Loads are not normal binary operators: their result type is not determined by their operands,...
LLVM_ABI SDValue getMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVol, bool AlwaysInline, const CallInst *CI, std::optional< bool > OverrideTailCall, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo, const AAMDNodes &AAInfo=AAMDNodes(), BatchAAResults *BatchAA=nullptr)
SDValue getTargetJumpTable(int JTI, EVT VT, unsigned TargetFlags=0)
SDValue getCALLSEQ_END(SDValue Chain, SDValue Op1, SDValue Op2, SDValue InGlue, const SDLoc &DL)
Return a new CALLSEQ_END node, which always must have a glue result (to ensure it's not CSE'd).
SDValue getCopyFromReg(SDValue Chain, const SDLoc &dl, Register Reg, EVT VT)
LLVM_ABI SDValue getZeroExtendInReg(SDValue Op, const SDLoc &DL, EVT VT)
Return the expression required to zero extend the Op value assuming it was the smaller SrcTy value.
const DataLayout & getDataLayout() const
LLVM_ABI SDValue getConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isTarget=false, bool isOpaque=false)
Create a ConstantSDNode wrapping a constant value.
LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, Align Alignment, MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
Helper function to build ISD::STORE nodes.
SDValue getCALLSEQ_START(SDValue Chain, uint64_t InSize, uint64_t OutSize, const SDLoc &DL)
Return a new CALLSEQ_START node, that starts new call frame, in which InSize bytes are set up inside ...
LLVM_ABI SDValue getIntPtrConstant(uint64_t Val, const SDLoc &DL, bool isTarget=false)
LLVM_ABI SDValue getValueType(EVT)
LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDUse > Ops)
Gets or creates the specified node.
SDValue getTargetBlockAddress(const BlockAddress *BA, EVT VT, int64_t Offset=0, unsigned TargetFlags=0)
MachineFunction & getMachineFunction() const
LLVM_ABI SDValue getFrameIndex(int FI, EVT VT, bool isTarget=false)
LLVMContext * getContext() const
LLVM_ABI SDValue getTargetExternalSymbol(const char *Sym, EVT VT, unsigned TargetFlags=0)
SDValue getEntryNode() const
Return the token chain corresponding to the entry of the function.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
constexpr size_t size() const
size - Get the string size.
TargetInstrInfo - Interface to description of machine instruction set.
void setBooleanVectorContents(BooleanContent Ty)
Specify how the target extends the result of a vector boolean value from a vector of i1 to a wider ty...
void setOperationAction(unsigned Op, MVT VT, LegalizeAction Action)
Indicate that the specified operation does not work with the specified type and indicate what to do a...
virtual bool isLegalICmpImmediate(int64_t) const
Return true if the specified immediate is legal icmp immediate, that is the target has icmp instructi...
virtual const TargetRegisterClass * getRegClassFor(MVT VT, bool isDivergent=false) const
Return the register class that should be used for the specified value type.
void setIndexedLoadAction(ArrayRef< unsigned > IdxModes, MVT VT, LegalizeAction Action)
Indicate that the specified indexed load does or does not work with the specified type and indicate w...
void setMaxAtomicSizeInBitsSupported(unsigned SizeInBits)
Set the maximum atomic operation size supported by the backend.
void setMinFunctionAlignment(Align Alignment)
Set the target's minimum function alignment.
void setBooleanContents(BooleanContent Ty)
Specify how the target extends the result of integer and floating point boolean values from i1 to a w...
void computeRegisterProperties(const TargetRegisterInfo *TRI)
Once all of the register classes are added, this allows us to compute derived properties we expose.
void addRegisterClass(MVT VT, const TargetRegisterClass *RC)
Add the specified register class as an available regclass for the specified value type.
void setPrefFunctionAlignment(Align Alignment)
Set the target's preferred function alignment.
void setTruncStoreAction(MVT ValVT, MVT MemVT, LegalizeAction Action)
Indicate that the specified truncating store does not work with the specified type and indicate what ...
@ ZeroOrOneBooleanContent
void setStackPointerRegisterToSaveRestore(Register R)
If set to a physical register, this specifies the register that llvm.savestack/llvm....
void setLoadExtAction(unsigned ExtType, MVT ValVT, MVT MemVT, LegalizeAction Action)
Indicate that the specified load with extension does not work with the specified type and indicate wh...
void setLibcallImpl(RTLIB::Libcall Call, RTLIB::LibcallImpl Impl)
MVT getFrameIndexTy(const DataLayout &DL) const
Return the type for frame index, which is determined by the alloca address space specified through th...
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
virtual ConstraintType getConstraintType(StringRef Constraint) const
Given a constraint, return the type of constraint it is for this target.
virtual std::pair< unsigned, const TargetRegisterClass * > getRegForInlineAsmConstraint(const TargetRegisterInfo *TRI, StringRef Constraint, MVT VT) const
Given a physical register constraint (e.g.
Primary interface to the complete machine description for the target machine.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetInstrInfo * getInstrInfo() const
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI TypeSize getPrimitiveSizeInBits() const LLVM_READONLY
Return the basic size of this type if it is a primitive type.
bool isIntegerTy() const
True if this is an instance of IntegerType.
LLVM Value Representation.
bool hasOneUse() const
Return true if there is exactly one use of this value.
constexpr ScalarTy getFixedValue() const
self_iterator getIterator()
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ MSP430_BUILTIN
Used for special MSP430 rtlib functions which have an "optimized" convention using additional registe...
@ Fast
Attempts to make calls as fast as possible (e.g.
@ MSP430_INTR
Used for MSP430 interrupt routines.
@ C
The default llvm calling convention, compatible with C.
@ SETCC
SetCC operator - This evaluates to a true value iff the condition is true.
@ STACKRESTORE
STACKRESTORE has two operands, an input chain and a pointer to restore to it returns an output chain.
@ STACKSAVE
STACKSAVE - STACKSAVE has one operand, an input chain.
@ SMUL_LOHI
SMUL_LOHI/UMUL_LOHI - Multiply two integers of type iN, producing a signed/unsigned value of type i[2...
@ BSWAP
Byte Swap and Counting operators.
@ VAEND
VAEND, VASTART - VAEND and VASTART have three operands: an input chain, pointer, and a SRCVALUE.
@ ADD
Simple integer binary arithmetic operators.
@ ANY_EXTEND
ANY_EXTEND - Used for integer types. The high bits are undefined.
@ SDIVREM
SDIVREM/UDIVREM - Divide two integers and produce both a quotient and remainder result.
@ SIGN_EXTEND
Conversion operators.
@ BR_CC
BR_CC - Conditional branch.
@ BR_JT
BR_JT - Jumptable branch.
@ SELECT
Select(COND, TRUEVAL, FALSEVAL).
@ VACOPY
VACOPY - VACOPY has 5 operands: an input chain, a destination pointer, a source pointer,...
@ MULHU
MULHU/MULHS - Multiply high - Multiply two integers of type iN, producing an unsigned/signed value of...
@ SHL
Shift and rotation operations.
@ ZERO_EXTEND
ZERO_EXTEND - Used for integer types, zeroing the new bits.
@ SELECT_CC
Select with condition operator - This selects between a true value and a false value (ops #2 and #3) ...
@ DYNAMIC_STACKALLOC
DYNAMIC_STACKALLOC - Allocate some number of bytes on the stack aligned to a specified boundary.
@ SIGN_EXTEND_INREG
SIGN_EXTEND_INREG - This operator atomically performs a SHL/SRA pair to sign extend a small value in ...
@ FRAMEADDR
FRAMEADDR, RETURNADDR - These nodes represent llvm.frameaddress and llvm.returnaddress on the DAG.
@ AND
Bitwise operators - logical and, logical or, logical xor.
@ TokenFactor
TokenFactor - This node takes multiple tokens as input and produces a single token result.
@ TRUNCATE
TRUNCATE - Completely drop the high bits.
@ VAARG
VAARG - VAARG has four operands: an input chain, a pointer, a SRCVALUE, and the alignment.
@ BRCOND
BRCOND - Conditional branch.
@ SHL_PARTS
SHL_PARTS/SRA_PARTS/SRL_PARTS - These operators are used for expanded integer shift operations.
@ AssertSext
AssertSext, AssertZext - These nodes record if a register contains a value that has already been zero...
MemIndexedMode
MemIndexedMode enum - This enum defines the load / store indexed addressing modes.
CondCode
ISD::CondCode enum - These are ordered carefully to make the bitfields below work out,...
Reg
All possible values of the reg field in the ModR/M byte.
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
LLVM_ABI bool isNullConstant(SDValue V)
Returns true if V is a constant integer zero.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
DWARFExpression::Operation Op
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
This struct is a compact representation of a valid (non-zero power of two) alignment.
TypeSize getStoreSize() const
Return the number of bytes overwritten by a store of the specified value type.
MVT getSimpleVT() const
Return the SimpleValueType held in the specified simple EVT.
uint64_t getFixedSizeInBits() const
Return the size of the specified fixed width value type in bits.
bool isInteger() const
Return true if this is an integer or a vector integer type.
This class contains a discriminated union of information about pointers in memory operands,...
static LLVM_ABI MachinePointerInfo getFixedStack(MachineFunction &MF, int FI, int64_t Offset=0)
Return a MachinePointerInfo record that refers to the specified FrameIndex.
This represents a list of ValueType's that has been intern'd by a SelectionDAG.
This structure contains all information that is necessary for lowering calls.
SmallVector< ISD::InputArg, 32 > Ins
SmallVector< ISD::OutputArg, 32 > Outs
SmallVector< SDValue, 32 > OutVals