36#define DEBUG_TYPE "msp430-lower"
40 cl::desc(
"Enable non legal immediates (for testing purposes only)"),
158 switch (
Op.getOpcode()) {
180 unsigned Amount)
const {
181 return !(Amount == 8 || Amount == 9 || Amount<=2);
188 return Immed >= -32 && Immed < 32;
200 if (Constraint.
size() == 1) {
201 switch (Constraint[0]) {
211std::pair<unsigned, const TargetRegisterClass *>
214 if (Constraint.
size() == 1) {
216 switch (Constraint[0]) {
220 return std::make_pair(0U, &MSP430::GR8RegClass);
222 return std::make_pair(0U, &MSP430::GR16RegClass);
233#include "MSP430GenCallingConv.inc"
237template<
typename ArgT>
240 unsigned CurrentArgIndex;
245 CurrentArgIndex = Args[0].OrigArgIndex;
248 for (
auto &Arg : Args) {
249 if (CurrentArgIndex == Arg.OrigArgIndex) {
253 CurrentArgIndex = Arg.OrigArgIndex;
260 State.AnalyzeCallOperands(Outs, CC_MSP430_AssignStack);
265 State.AnalyzeFormalArguments(Ins, CC_MSP430_AssignStack);
272template<
typename ArgT>
277 MSP430::R12, MSP430::R13, MSP430::R14, MSP430::R15
279 static const unsigned CNbRegs = std::size(CRegList);
280 static const MCPhysReg BuiltinRegList[] = {
281 MSP430::R8, MSP430::R9, MSP430::R10, MSP430::R11,
282 MSP430::R12, MSP430::R13, MSP430::R14, MSP430::R15
284 static const unsigned BuiltinNbRegs = std::size(BuiltinRegList);
291 RegList = BuiltinRegList;
292 NbRegs = BuiltinNbRegs;
298 if (State.isVarArg()) {
308 "Builtin calling convention requires two arguments");
311 unsigned RegsLeft = NbRegs;
312 bool UsedStack =
false;
315 for (
unsigned i = 0, e = ArgsParts.
size(); i != e; i++) {
316 MVT ArgVT = Args[ValNo].VT;
318 Type *OrigTy = Args[ValNo].OrigTy;
323 if (LocVT == MVT::i8) {
327 else if (ArgFlags.
isZExt())
335 State.HandleByVal(ValNo++, ArgVT, LocVT, LocInfo, 2,
Align(2), ArgFlags);
339 unsigned Parts = ArgsParts[i];
343 "Builtin calling convention requires 64-bit arguments");
346 if (!UsedStack && Parts == 2 && RegsLeft == 1) {
353 CC_MSP430_AssignStack(ValNo++, ArgVT, LocVT, LocInfo, ArgFlags, OrigTy,
355 }
else if (Parts <= RegsLeft) {
356 for (
unsigned j = 0; j < Parts; j++) {
363 for (
unsigned j = 0; j < Parts; j++)
364 CC_MSP430_AssignStack(ValNo++, ArgVT, LocVT, LocInfo, ArgFlags, OrigTy,
372 State.AnalyzeCallResult(Ins, RetCC_MSP430);
377 State.AnalyzeReturn(Outs, RetCC_MSP430);
380template<
typename ArgT>
387SDValue MSP430TargetLowering::LowerFormalArguments(
397 return LowerCCCArguments(Chain, CallConv, isVarArg, Ins, dl, DAG, InVals);
408 SelectionDAG &DAG = CLI.
DAG;
410 SmallVectorImpl<ISD::OutputArg> &Outs = CLI.
Outs;
411 SmallVectorImpl<SDValue> &OutVals = CLI.
OutVals;
412 SmallVectorImpl<ISD::InputArg> &
Ins = CLI.
Ins;
428 return LowerCCCCallTo(Chain, Callee, CallConv, isVarArg, isTailCall,
429 Outs, OutVals, Ins, dl, DAG, InVals);
438SDValue MSP430TargetLowering::LowerCCCArguments(
444 MachineRegisterInfo &RegInfo = MF.
getRegInfo();
445 MSP430MachineFunctionInfo *FuncInfo = MF.
getInfo<MSP430MachineFunctionInfo>();
455 unsigned Offset = CCInfo.getStackSize();
459 for (
unsigned i = 0, e = ArgLocs.size(); i != e; ++i) {
460 CCValAssign &VA = ArgLocs[i];
468 errs() <<
"LowerFormalArguments Unhandled argument type: "
498 ISD::ArgFlagsTy
Flags =
Ins[i].Flags;
500 if (
Flags.isByVal()) {
509 errs() <<
"LowerFormalArguments Unhandled argument type: "
527 for (
unsigned i = 0, e = ArgLocs.size(); i != e; ++i) {
528 if (Ins[i].
Flags.isSRet()) {
549 const Type *RetTy)
const {
551 CCState CCInfo(CallConv, IsVarArg, MF, RVLocs,
Context);
552 return CCInfo.CheckReturn(Outs, RetCC_MSP430);
582 for (
unsigned i = 0; i != RVLocs.
size(); ++i) {
583 CCValAssign &VA = RVLocs[i];
596 MSP430MachineFunctionInfo *FuncInfo = MF.
getInfo<MSP430MachineFunctionInfo>();
605 unsigned R12 = MSP430::R12;
613 MSP430ISD::RETI_GLUE : MSP430ISD::RET_GLUE);
619 RetOps.push_back(Glue);
621 return DAG.
getNode(
Opc, dl, MVT::Other, RetOps);
626SDValue MSP430TargetLowering::LowerCCCCallTo(
639 unsigned NumBytes = CCInfo.getStackSize();
649 for (
unsigned i = 0, e = ArgLocs.
size(); i != e; ++i) {
650 CCValAssign &VA = ArgLocs[i];
684 ISD::ArgFlagsTy
Flags = Outs[i].Flags;
686 if (
Flags.isByVal()) {
688 MemOp = DAG.
getMemcpy(Chain, dl, PtrOff, Arg, SizeNode,
689 Flags.getNonZeroByValAlign(),
692 nullptr, std::nullopt,
693 MachinePointerInfo(), MachinePointerInfo());
695 MemOp = DAG.
getStore(Chain, dl, Arg, PtrOff, MachinePointerInfo());
704 if (!MemOpChains.
empty())
711 for (
const auto &[
Reg,
N] : RegsToPass) {
725 SDVTList NodeTys = DAG.
getVTList(MVT::Other, MVT::Glue);
727 Ops.push_back(Chain);
728 Ops.push_back(Callee);
732 for (
const auto &[
Reg,
N] : RegsToPass)
736 Ops.push_back(InGlue);
738 Chain = DAG.
getNode(MSP430ISD::CALL, dl, NodeTys,
Ops);
747 return LowerCallResult(Chain, InGlue, CallConv, isVarArg, Ins, dl,
754SDValue MSP430TargetLowering::LowerCallResult(
767 for (
unsigned i = 0; i != RVLocs.
size(); ++i) {
769 RVLocs[i].getValVT(), InGlue).
getValue(1);
779 unsigned Opc =
Op.getOpcode();
781 EVT VT =
Op.getValueType();
788 uint64_t ShiftAmount =
N->getConstantOperandVal(1);
793 if (ShiftAmount >= 8) {
794 assert(VT == MVT::i16 &&
"Can not shift i8 by 8 and more");
819 Victim = DAG.
getNode(MSP430ISD::RRCL, dl, VT, Victim);
823 while (ShiftAmount--)
834 EVT PtrVT =
Op.getValueType();
845 EVT PtrVT =
Op.getValueType();
848 return DAG.
getNode(MSP430ISD::Wrapper, dl, PtrVT, Result);
855 EVT PtrVT =
Op.getValueType();
858 return DAG.
getNode(MSP430ISD::Wrapper, dl, PtrVT, Result);
864 assert(!
LHS.getValueType().isFloatingPoint() &&
"We don't handle FP yet");
958 return DAG.
getNode(MSP430ISD::BR_CC, dl,
Op.getValueType(),
959 Chain, Dest, TargetCC, Flag);
975 LHS.getOperand(0).getOpcode() ==
ISD::AND));
1013 EVT VT =
Op.getValueType();
1028 return DAG.
getNode(MSP430ISD::SELECT_CC, dl,
Op.getValueType(),
Ops);
1044 SDValue Ops[] = {TrueV, FalseV, TargetCC, Flag};
1046 return DAG.
getNode(MSP430ISD::SELECT_CC, dl,
Op.getValueType(),
Ops);
1052 EVT VT =
Op.getValueType();
1055 assert(VT == MVT::i16 &&
"Only support i16 for now!");
1066 int ReturnAddrIndex = FuncInfo->
getRAIndex();
1069 if (ReturnAddrIndex == 0) {
1085 unsigned Depth =
Op.getConstantOperandVal(0);
1087 EVT PtrVT =
Op.getValueType();
1109 EVT VT =
Op.getValueType();
1111 unsigned Depth =
Op.getConstantOperandVal(0);
1126 EVT PtrVT = Ptr.getValueType();
1141 EVT PtrVT =
Op.getValueType();
1143 return DAG.
getNode(MSP430ISD::Wrapper,
SDLoc(JT), PtrVT, Result);
1149bool MSP430TargetLowering::getPostIndexedAddressParts(
SDNode *
N,
SDNode *
Op,
1159 EVT VT = LD->getMemoryVT();
1160 if (VT != MVT::i8 && VT != MVT::i16)
1167 uint64_t RHSC = RHS->getZExtValue();
1168 if ((VT == MVT::i16 && RHSC != 2) ||
1169 (VT == MVT::i8 && RHSC != 1))
1172 Base =
Op->getOperand(0);
1204 return false && VT1 == MVT::i8 && VT2 == MVT::i16;
1220 bool ClearCarry =
false;
1222 switch (
MI.getOpcode()) {
1225 Opc = MSP430::ADD8rr;
1226 RC = &MSP430::GR8RegClass;
1229 Opc = MSP430::ADD16rr;
1230 RC = &MSP430::GR16RegClass;
1233 Opc = MSP430::RRA8r;
1234 RC = &MSP430::GR8RegClass;
1237 Opc = MSP430::RRA16r;
1238 RC = &MSP430::GR16RegClass;
1242 Opc = MSP430::RRC8r;
1243 RC = &MSP430::GR8RegClass;
1247 Opc = MSP430::RRC16r;
1248 RC = &MSP430::GR16RegClass;
1251 case MSP430::Rrcl16: {
1252 BuildMI(*BB,
MI, dl,
TII.get(MSP430::BIC16rc), MSP430::SR)
1256 unsigned RrcOpc =
MI.getOpcode() == MSP430::Rrcl16
1257 ? MSP430::RRC16r : MSP430::RRC8r;
1260 MI.eraseFromParent();
1272 F->insert(
I, LoopBB);
1273 F->insert(
I, RemBB);
1291 Register ShiftAmtSrcReg =
MI.getOperand(2).getReg();
1309 BuildMI(LoopBB, dl,
TII.get(MSP430::PHI), ShiftReg)
1312 BuildMI(LoopBB, dl,
TII.get(MSP430::PHI), ShiftAmtReg)
1316 BuildMI(LoopBB, dl,
TII.get(MSP430::BIC16rc), MSP430::SR)
1318 if (
Opc == MSP430::ADD8rr ||
Opc == MSP430::ADD16rr)
1325 BuildMI(LoopBB, dl,
TII.get(MSP430::SUB8ri), ShiftAmtReg2)
1337 MI.eraseFromParent();
1344 unsigned Opc =
MI.getOpcode();
1346 if (
Opc == MSP430::Shl8 ||
Opc == MSP430::Shl16 ||
1347 Opc == MSP430::Sra8 ||
Opc == MSP430::Sra16 ||
1348 Opc == MSP430::Srl8 ||
Opc == MSP430::Srl16 ||
1349 Opc == MSP430::Rrcl8 ||
Opc == MSP430::Rrcl16)
1355 assert((
Opc == MSP430::Select16 ||
Opc == MSP430::Select8) &&
1356 "Unexpected instr type to insert");
1375 F->insert(
I, copy0MBB);
1376 F->insert(
I, copy1MBB);
1388 .
addImm(
MI.getOperand(3).getImm());
1408 MI.eraseFromParent();
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
const HexagonInstrInfo * TII
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
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
Promote Memory to Register
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.
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
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 '...
MachineInstrBundleIterator< MachineInstr > iterator
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.
BasicBlockListType::iterator iterator
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...
void addLiveIn(MCRegister Reg, Register vreg=Register())
addLiveIn - Add the specified register as a live-in.
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...
MVT getFrameIndexTy(const DataLayout &DL) const
Return the type for frame index, which is determined by the alloca address space specified through th...
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.
TargetLowering(const TargetLowering &)=delete
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.
constexpr ScalarTy getFixedValue() const
self_iterator getIterator()
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ 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.
@ 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.
@ 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.
@ SELECT
Select(COND, TRUEVAL, FALSEVAL).
@ 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) ...
@ 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.
@ 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,...
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.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
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 structure contains all information that is necessary for lowering calls.
SmallVector< ISD::InputArg, 32 > Ins
SmallVector< ISD::OutputArg, 32 > Outs
SmallVector< SDValue, 32 > OutVals