36#define GET_INSTRINFO_CTOR_DTOR
37#include "MipsGenInstrInfo.inc"
40void MipsInstrInfo::anchor() {}
55 return op.isImm() &&
op.getImm() == 0;
78 "insertNop does not support MIPS16e mode at this time");
79 const unsigned MMOpc =
80 Subtarget.hasMips32r6() ? Mips::SLL_MMR6 : Mips::SLL_MM;
103void MipsInstrInfo::AnalyzeCondBr(
const MachineInstr *Inst,
unsigned Opc,
106 assert(getAnalyzableBrOpc(
Opc) &&
"Not an analyzable branch");
114 for (
int i = 0; i < NumOp-1; i++)
122 bool AllowModify)
const {
132 unsigned Opc =
Cond[0].getImm();
136 for (
unsigned i = 1; i <
Cond.size(); ++i) {
138 "Cannot copy operand for conditional branch!");
149 int *BytesAdded)
const {
151 assert(
TBB &&
"insertBranch must not be told to insert a fallthrough");
152 assert(!BytesAdded &&
"code size not handled");
160 "# of Mips branch conditions must be <= 3!");
179 int *BytesRemoved)
const {
180 assert(!BytesRemoved &&
"code size not handled");
183 unsigned removed = 0;
187 while (
I != REnd && removed < 2) {
189 if (
I->isDebugInstr()) {
193 if (!getAnalyzableBrOpc(
I->getOpcode()))
196 I->eraseFromParent();
209 "Invalid Mips branch condition!");
221 while (
I != REnd &&
I->isDebugInstr())
224 if (
I == REnd || !isUnpredicatedTerminator(*
I)) {
232 unsigned LastOpc = LastInst->
getOpcode();
236 if (!getAnalyzableBrOpc(LastOpc))
240 unsigned SecondLastOpc = 0;
246 while (
I != REnd &&
I->isDebugInstr())
250 SecondLastInst = &*
I;
251 SecondLastOpc = getAnalyzableBrOpc(SecondLastInst->
getOpcode());
254 if (isUnpredicatedTerminator(*SecondLastInst) && !SecondLastOpc)
259 if (!SecondLastOpc) {
267 AnalyzeCondBr(LastInst, LastOpc,
TBB,
Cond);
273 if (++
I != REnd && isUnpredicatedTerminator(*
I))
276 BranchInstrs.
insert(BranchInstrs.
begin(), SecondLastInst);
296 AnalyzeCondBr(SecondLastInst, SecondLastOpc,
TBB,
Cond);
303 int64_t BrOffset)
const {
308 case Mips::BAL_BR_MM:
313 case Mips::BEQ:
case Mips::BEQ64:
315 case Mips::BGEZ:
case Mips::BGEZ64:
319 case Mips::BGTZ:
case Mips::BGTZ64:
321 case Mips::BLEZ:
case Mips::BLEZ64:
323 case Mips::BLTZ:
case Mips::BLTZ64:
327 case Mips::BNE:
case Mips::BNE64:
337 case Mips::BGEZAL_MM:
341 case Mips::BLTZAL_MM:
351 case Mips::BEQZ16_MM:
352 case Mips::BNEZ16_MM:
364 case Mips::BEQC:
case Mips::BEQC64:
365 case Mips::BNEC:
case Mips::BNEC64:
366 case Mips::BGEC:
case Mips::BGEC64:
367 case Mips::BGEUC:
case Mips::BGEUC64:
368 case Mips::BGEZC:
case Mips::BGEZC64:
369 case Mips::BGTZC:
case Mips::BGTZC64:
370 case Mips::BLEZC:
case Mips::BLEZC64:
371 case Mips::BLTC:
case Mips::BLTC64:
372 case Mips::BLTUC:
case Mips::BLTUC64:
373 case Mips::BLTZC:
case Mips::BLTZC64:
384 case Mips::BEQZC:
case Mips::BEQZC64:
385 case Mips::BNEZC:
case Mips::BNEZC64:
389 case Mips::BC16_MMR6:
392 case Mips::BEQZC16_MMR6:
393 case Mips::BNEZC16_MMR6:
396 case Mips::BALC_MMR6:
400 case Mips::BC1EQZC_MMR6:
401 case Mips::BC1NEZC_MMR6:
402 case Mips::BC2EQZC_MMR6:
403 case Mips::BC2NEZC_MMR6:
404 case Mips::BGEZALC_MMR6:
405 case Mips::BEQZALC_MMR6:
406 case Mips::BGTZALC_MMR6:
407 case Mips::BLEZALC_MMR6:
408 case Mips::BLTZALC_MMR6:
409 case Mips::BNEZALC_MMR6:
410 case Mips::BNVC_MMR6:
411 case Mips::BOVC_MMR6:
414 case Mips::BEQC_MMR6:
415 case Mips::BNEC_MMR6:
416 case Mips::BGEC_MMR6:
417 case Mips::BGEUC_MMR6:
418 case Mips::BGEZC_MMR6:
419 case Mips::BGTZC_MMR6:
420 case Mips::BLEZC_MMR6:
421 case Mips::BLTC_MMR6:
422 case Mips::BLTUC_MMR6:
423 case Mips::BLTZC_MMR6:
426 case Mips::BEQZC_MMR6:
427 case Mips::BNEZC_MMR6:
433 case Mips::BPOSGE32_MM:
434 case Mips::BPOSGE32C_MMR3:
464 unsigned Opcode =
I->getOpcode();
465 bool canUseShortMicroMipsCTI =
false;
475 if (
I->getOperand(1).getReg() ==
Subtarget.getABI().GetZeroReg())
476 canUseShortMicroMipsCTI =
true;
481 case Mips::PseudoReturn:
482 case Mips::PseudoIndirectBranch:
483 canUseShortMicroMipsCTI =
true;
489 if (
Subtarget.hasMips32r6() && (
I->getNumOperands() > 1) &&
490 (
I->getOperand(0).isReg() &&
491 (
I->getOperand(0).getReg() == Mips::ZERO ||
492 I->getOperand(0).getReg() == Mips::ZERO_64)) &&
493 (
I->getOperand(1).isReg() &&
494 (
I->getOperand(1).getReg() == Mips::ZERO ||
495 I->getOperand(1).getReg() == Mips::ZERO_64)))
498 if (
Subtarget.hasMips32r6() || canUseShortMicroMipsCTI) {
506 if (canUseShortMicroMipsCTI)
507 return Mips::BEQZC_MM;
508 else if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
513 if (canUseShortMicroMipsCTI)
514 return Mips::BNEZC_MM;
515 else if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
519 if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
523 if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
533 if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
537 if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
543 if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
547 if (
I->getOperand(0).getReg() ==
I->getOperand(1).getReg())
551 return Mips::BGTZC64;
553 return Mips::BGEZC64;
555 return Mips::BLTZC64;
557 return Mips::BLEZC64;
561 case Mips::PseudoIndirectBranchR6:
562 case Mips::PseudoReturn:
563 case Mips::TAILCALLR6REG:
564 if (canUseShortMicroMipsCTI)
565 return Mips::JRC16_MM;
567 case Mips::JALRPseudo:
570 case Mips::PseudoIndirectBranch64R6:
571 case Mips::PseudoReturn64:
572 case Mips::TAILCALL64R6REG:
574 case Mips::JALR64Pseudo:
575 return Mips::JIALC64;
595 if (
MI.isInlineAsm())
639 return Op.isReg() && MIInSlot.readsRegister(Op.getReg(), nullptr);
657 switch (
MI.getOpcode()) {
676 switch (
MI.getOpcode()) {
691 const unsigned Opcode =
MI.getOpcode();
698 return ((
MI.getOperand(2).isImm() &&
MI.getOperand(2).getImm() == 0) ||
699 (
MI.getOperand(1).isReg() &&
700 (
MI.getOperand(1).getReg() == Mips::ZERO ||
701 MI.getOperand(1).getReg() == Mips::ZERO_64)));
703 return MI.isAsCheapAsAMove();
708 switch (
MI.getOpcode()) {
710 return MI.getDesc().getSize();
711 case TargetOpcode::INLINEASM:
712 case TargetOpcode::INLINEASM_BR: {
714 const char *AsmStr =
MI.getOperand(0).getSymbolName();
717 case Mips::CONSTPOOL_ENTRY:
720 return MI.getOperand(2).getImm();
738 int ZeroOperandPosition = -1;
739 bool BranchWithZeroOperand =
false;
740 if (
I->isBranch() && !
I->isPseudo()) {
741 auto TRI =
I->getParent()->getParent()->getSubtarget().getRegisterInfo();
742 ZeroOperandPosition =
I->findRegisterUseOperandIdx(Mips::ZERO,
TRI,
false);
743 BranchWithZeroOperand = ZeroOperandPosition != -1;
746 if (BranchWithZeroOperand) {
749 NewOpc = Mips::BEQZC;
752 NewOpc = Mips::BNEZC;
755 NewOpc = Mips::BGEZC;
758 NewOpc = Mips::BLTZC;
761 NewOpc = Mips::BEQZC64;
764 NewOpc = Mips::BNEZC64;
769 MIB =
BuildMI(*
I->getParent(),
I,
I->getDebugLoc(),
get(NewOpc));
775 if (NewOpc == Mips::JIC || NewOpc == Mips::JIALC || NewOpc == Mips::JIC64 ||
776 NewOpc == Mips::JIALC64) {
778 if (NewOpc == Mips::JIALC || NewOpc == Mips::JIALC64)
781 for (
unsigned J = 0, E =
I->getDesc().getNumOperands(); J < E; ++J) {
782 MIB.
add(
I->getOperand(J));
789 for (
unsigned J =
I->getDesc().getNumOperands(), E =
I->getNumOperands();
798 for (
unsigned J = 0, E =
I->getDesc().getNumOperands(); J < E; ++J) {
799 if (BranchWithZeroOperand && (
unsigned)ZeroOperandPosition == J)
802 MIB.
add(
I->getOperand(J));
813 unsigned &SrcOpIdx2)
const {
815 "TargetInstrInfo::findCommutedOpIndices() can't handle bundles");
818 if (!
MCID.isCommutable())
821 switch (
MI.getOpcode()) {
822 case Mips::DPADD_U_H:
823 case Mips::DPADD_U_W:
824 case Mips::DPADD_U_D:
825 case Mips::DPADD_S_H:
826 case Mips::DPADD_S_W:
827 case Mips::DPADD_S_D:
829 if (!fixCommutedOpIndices(SrcOpIdx1, SrcOpIdx2, 2, 3))
832 if (!
MI.getOperand(SrcOpIdx1).isReg() || !
MI.getOperand(SrcOpIdx2).isReg())
854 const int64_t PosLow,
const int64_t PosHigh,
855 const int64_t SizeLow,
856 const int64_t SizeHigh,
857 const int64_t BothLow,
858 const int64_t BothHigh) {
860 if (!MOPos.
isImm()) {
861 ErrInfo =
"Position is not an immediate!";
864 int64_t Pos = MOPos.
getImm();
865 if (!((PosLow <= Pos) && (Pos < PosHigh))) {
866 ErrInfo =
"Position operand is out of range!";
871 if (!MOSize.
isImm()) {
872 ErrInfo =
"Size operand is not an immediate!";
876 if (!((SizeLow <
Size) && (
Size <= SizeHigh))) {
877 ErrInfo =
"Size operand is out of range!";
881 if (!((BothLow < (Pos +
Size)) && ((Pos +
Size) <= BothHigh))) {
882 ErrInfo =
"Position + Size is out of range!";
893 switch (
MI.getOpcode()) {
919 case Mips::TAILCALLREG:
920 case Mips::PseudoIndirectBranch:
925 case Mips::JALRPseudo:
929 ErrInfo =
"invalid instruction when using jump guards!";
938std::pair<unsigned, unsigned>
940 return std::make_pair(TF, 0u);
947 static const std::pair<unsigned, const char*> Flags[] = {
948 {MO_GOT,
"mips-got"},
949 {MO_GOT_CALL,
"mips-got-call"},
950 {MO_GPREL,
"mips-gprel"},
951 {MO_ABS_HI,
"mips-abs-hi"},
952 {MO_ABS_LO,
"mips-abs-lo"},
953 {MO_TLSGD,
"mips-tlsgd"},
954 {MO_TLSLDM,
"mips-tlsldm"},
955 {MO_DTPREL_HI,
"mips-dtprel-hi"},
956 {MO_DTPREL_LO,
"mips-dtprel-lo"},
957 {MO_GOTTPREL,
"mips-gottprel"},
958 {MO_TPREL_HI,
"mips-tprel-hi"},
959 {MO_TPREL_LO,
"mips-tprel-lo"},
960 {MO_GPOFF_HI,
"mips-gpoff-hi"},
961 {MO_GPOFF_LO,
"mips-gpoff-lo"},
962 {MO_GOT_DISP,
"mips-got-disp"},
963 {MO_GOT_PAGE,
"mips-got-page"},
964 {MO_GOT_OFST,
"mips-got-ofst"},
965 {MO_HIGHER,
"mips-higher"},
966 {MO_HIGHEST,
"mips-highest"},
967 {MO_GOT_HI16,
"mips-got-hi16"},
968 {MO_GOT_LO16,
"mips-got-lo16"},
969 {MO_CALL_HI16,
"mips-call-hi16"},
970 {MO_CALL_LO16,
"mips-call-lo16"},
971 {MO_JALR,
"mips-jalr"}
976std::optional<ParamLoadedValue>
984 int64_t
Offset = RegImm->Imm;
987 if (SrcReg == Mips::ZERO || SrcReg == Mips::ZERO_64) {
992 }
else if (
auto DestSrc = isCopyInstr(
MI)) {
995 Register DestReg = DestSrc->Destination->getReg();
998 if (
TRI->isSuperRegister(Reg, DestReg) ||
TRI->isSubRegister(Reg, DestReg))
1011 return std::nullopt;
1013 switch (
MI.getOpcode()) {
1015 case Mips::DADDiu: {
1026 return std::nullopt;
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
Register const TargetRegisterInfo * TRI
static bool isReg(const MCInst &MI, unsigned OpNo)
static bool verifyInsExtInstruction(const MachineInstr &MI, StringRef &ErrInfo, const int64_t PosLow, const int64_t PosHigh, const int64_t SizeLow, const int64_t SizeHigh, const int64_t BothLow, const int64_t BothHigh)
#define IsMFLOMFHI(instr)
const SmallVectorImpl< MachineOperand > MachineBasicBlock * TBB
const SmallVectorImpl< MachineOperand > & Cond
This file defines the SmallVector class.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
static LLVM_ABI DIExpression * prepend(const DIExpression *Expr, uint8_t Flags, int64_t Offset=0)
Prepend DIExpr with a deref and offset operation and optionally turn it into a stack value or/and an ...
MCInstBuilder & addReg(MCRegister Reg)
Add a new register operand.
MCInstBuilder & addImm(int64_t Val)
Add a new integer immediate operand.
Instances of this class represent a single low-level machine instruction.
Describe properties that are true of each instruction in the target description file.
static MDTuple * get(LLVMContext &Context, ArrayRef< Metadata * > MDs)
MachineInstrBundleIterator< MachineInstr, true > reverse_iterator
MachineInstrBundleIterator< MachineInstr > iterator
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
Align getObjectAlign(int ObjectIdx) const
Return the alignment of the specified stack object.
int64_t getObjectSize(int ObjectIdx) const
Return the size of the specified object.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineMemOperand * getMachineMemOperand(MachinePointerInfo PtrInfo, MachineMemOperand::Flags f, LLT MemTy, Align base_alignment, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr, SyncScope::ID SSID=SyncScope::System, AtomicOrdering Ordering=AtomicOrdering::NotAtomic, AtomicOrdering FailureOrdering=AtomicOrdering::NotAtomic)
getMachineMemOperand - Allocate a new MachineMemOperand.
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
const MachineInstrBuilder & add(const MachineOperand &MO) const
const MachineInstrBuilder & addSym(MCSymbol *Sym, unsigned char TargetFlags=0) const
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
const MachineInstrBuilder & cloneMemRefs(const MachineInstr &OtherMI) const
const MachineInstrBuilder & copyImplicitOps(const MachineInstr &OtherMI) const
Copy all the implicit operands from OtherMI onto this one.
Representation of each machine instruction.
mop_range defs()
Returns all explicit operands that are register definitions.
unsigned getOpcode() const
Returns the opcode of this MachineInstr.
LLVM_ABI std::pair< bool, bool > readsWritesVirtualRegister(Register Reg, SmallVectorImpl< unsigned > *Ops=nullptr) const
Return a pair of bools (reads, writes) indicating if this instruction reads or writes Reg.
LLVM_ABI unsigned getNumExplicitOperands() const
Returns the number of non-implicit operands.
bool isUnconditionalBranch(QueryType Type=AnyInBundle) const
Return true if this is a branch which always transfers control flow to some other block.
LLVM_ABI void eraseFromParent()
Unlink 'this' from the containing basic block and delete it.
LLVM_ABI void removeOperand(unsigned OpNo)
Erase an operand from an instruction, leaving it with one fewer operand than it started with.
const MachineOperand & getOperand(unsigned i) const
bool isIndirectBranch(QueryType Type=AnyInBundle) const
Return true if this is an indirect branch, such as a branch through a register.
A description of a memory reference used in the backend.
Flags
Flags values. These may be or'd together.
MachineOperand class - Representation of each machine instruction operand.
bool isReg() const
isReg - Tests if this is a MO_Register operand.
MachineBasicBlock * getMBB() const
bool isImm() const
isImm - Tests if this is a MO_Immediate operand.
unsigned getTargetFlags() const
static MachineOperand CreateImm(int64_t Val)
Register getReg() const
getReg - Returns the register number.
MCSymbol * getMCSymbol() const
static MachineOperand CreateReg(Register Reg, bool isDef, bool isImp=false, bool isKill=false, bool isDead=false, bool isUndef=false, bool isEarlyClobber=false, unsigned SubReg=0, bool isDebug=false, bool isInternalRead=false, bool isRenamable=false)
MCInst getNop() const override
bool SafeAfterMflo(const MachineInstr &MI) const
ArrayRef< std::pair< unsigned, const char * > > getSerializableDirectMachineOperandTargetFlags() const override
bool SafeInForbiddenSlot(const MachineInstr &MI) const
Predicate to determine if an instruction can go in a forbidden slot.
unsigned getInstSizeInBytes(const MachineInstr &MI) const override
Return the number of bytes of code the specified instruction may be.
MachineInstrBuilder insertNop(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, DebugLoc DL) const
Insert an ISA appropriate nop.
bool isBranchOffsetInRange(unsigned BranchOpc, int64_t BrOffset) const override
Determine if the branch target is in range.
bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, MachineBasicBlock *&FBB, SmallVectorImpl< MachineOperand > &Cond, bool AllowModify) const override
Branch Analysis.
const MipsSubtarget & Subtarget
MachineMemOperand * GetMemOperand(MachineBasicBlock &MBB, int FI, MachineMemOperand::Flags Flags) const
MachineInstrBuilder genInstrWithNewOpc(unsigned NewOpc, MachineBasicBlock::iterator I) const
Create an instruction which has the same operands and memory operands as MI but has a new opcode.
bool HasForbiddenSlot(const MachineInstr &MI) const
Predicate to determine if an instruction has a forbidden slot.
bool SafeInFPUDelaySlot(const MachineInstr &MIInSlot, const MachineInstr &FPUMI) const
Predicate to determine if an instruction can go in an FPU delay slot.
bool isZeroImm(const MachineOperand &op) const
unsigned getEquivalentCompactForm(const MachineBasicBlock::iterator I) const
Determine the opcode of a non-delay slot form for a branch if one exists.
bool SafeInLoadDelaySlot(const MachineInstr &MIInSlot, const MachineInstr &LoadMI) const
Predicate to determine if an instruction can go in a load delay slot.
bool reverseBranchCondition(SmallVectorImpl< MachineOperand > &Cond) const override
reverseBranchCondition - Return the inverse opcode of the specified Branch instruction.
unsigned insertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, MachineBasicBlock *FBB, ArrayRef< MachineOperand > Cond, const DebugLoc &DL, int *BytesAdded=nullptr) const override
std::optional< RegImmPair > isAddImmediate(const MachineInstr &MI, Register Reg) const override
bool HasFPUDelaySlot(const MachineInstr &MI) const
Predicate to determine if an instruction has an FPU delay slot.
bool verifyInstruction(const MachineInstr &MI, StringRef &ErrInfo) const override
Perform target specific instruction verification.
std::pair< unsigned, unsigned > decomposeMachineOperandsTargetFlags(unsigned TF) const override
static const MipsInstrInfo * create(MipsSubtarget &STI)
bool IsMfloOrMfhi(const MachineInstr &MI) const
bool findCommutedOpIndices(const MachineInstr &MI, unsigned &SrcOpIdx1, unsigned &SrcOpIdx2) const override
std::optional< ParamLoadedValue > describeLoadedValue(const MachineInstr &MI, Register Reg) const override
MipsInstrInfo(const MipsSubtarget &STI, const MipsRegisterInfo &RI, unsigned UncondBrOpc)
virtual unsigned getOppositeBranchOpc(unsigned Opc) const =0
bool HasLoadDelaySlot(const MachineInstr &MI) const
Predicate to determine if an instruction has a load delay slot.
bool isAsCheapAsAMove(const MachineInstr &MI) const override
unsigned removeBranch(MachineBasicBlock &MBB, int *BytesRemoved=nullptr) const override
void insertNoop(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI) const override
Insert nop instruction when hazard condition is found.
bool inMips16Mode() const
Wrapper class representing virtual and physical registers.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
iterator insert(iterator I, T &&Elt)
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.
virtual bool findCommutedOpIndices(const MachineInstr &MI, unsigned &SrcOpIdx1, unsigned &SrcOpIdx2) const
Returns true iff the routine could find two commutable operands in the given machine instruction.
virtual std::optional< ParamLoadedValue > describeLoadedValue(const MachineInstr &MI, Register Reg) const
Produce the expression describing the MI loading a value into the physical register Reg.
const MCAsmInfo * getMCAsmInfo() const
Return target specific asm information.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
MipsII - This namespace holds all of the target specific flags that instruction info tracks.
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.
constexpr bool isInt(int64_t x)
Checks if an integer fits into the given bit width.
const MipsInstrInfo * createMipsSEInstrInfo(const MipsSubtarget &STI)
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
MachineInstr * getImm(const MachineOperand &MO, const MachineRegisterInfo *MRI)
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
DWARFExpression::Operation Op
ArrayRef(const T &OneElt) -> ArrayRef< T >
const MipsInstrInfo * createMips16InstrInfo(const MipsSubtarget &STI)
Create MipsInstrInfo objects.
std::pair< MachineOperand, DIExpression * > ParamLoadedValue
static LLVM_ABI MachinePointerInfo getFixedStack(MachineFunction &MF, int FI, int64_t Offset=0)
Return a MachinePointerInfo record that refers to the specified FrameIndex.
Used to describe a register and immediate addition.