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 TargetOpcode::PATCHABLE_FUNCTION_ENTER:
718 case TargetOpcode::PATCHABLE_FUNCTION_EXIT:
719 case TargetOpcode::PATCHABLE_TAIL_CALL:
728 case Mips::CONSTPOOL_ENTRY:
731 return MI.getOperand(2).getImm();
749 int ZeroOperandPosition = -1;
750 bool BranchWithZeroOperand =
false;
751 if (
I->isBranch() && !
I->isPseudo()) {
752 auto TRI =
I->getParent()->getParent()->getSubtarget().getRegisterInfo();
753 ZeroOperandPosition =
I->findRegisterUseOperandIdx(Mips::ZERO,
TRI,
false);
754 BranchWithZeroOperand = ZeroOperandPosition != -1;
757 if (BranchWithZeroOperand) {
760 NewOpc = Mips::BEQZC;
763 NewOpc = Mips::BNEZC;
766 NewOpc = Mips::BGEZC;
769 NewOpc = Mips::BLTZC;
772 NewOpc = Mips::BEQZC64;
775 NewOpc = Mips::BNEZC64;
780 MIB =
BuildMI(*
I->getParent(),
I,
I->getDebugLoc(),
get(NewOpc));
786 if (NewOpc == Mips::JIC || NewOpc == Mips::JIALC || NewOpc == Mips::JIC64 ||
787 NewOpc == Mips::JIALC64) {
789 if (NewOpc == Mips::JIALC || NewOpc == Mips::JIALC64)
792 for (
unsigned J = 0, E =
I->getDesc().getNumOperands(); J < E; ++J) {
793 MIB.
add(
I->getOperand(J));
800 for (
unsigned J =
I->getDesc().getNumOperands(), E =
I->getNumOperands();
809 for (
unsigned J = 0, E =
I->getDesc().getNumOperands(); J < E; ++J) {
810 if (BranchWithZeroOperand && (
unsigned)ZeroOperandPosition == J)
813 MIB.
add(
I->getOperand(J));
824 unsigned &SrcOpIdx2)
const {
826 "TargetInstrInfo::findCommutedOpIndices() can't handle bundles");
829 if (!
MCID.isCommutable())
832 switch (
MI.getOpcode()) {
833 case Mips::DPADD_U_H:
834 case Mips::DPADD_U_W:
835 case Mips::DPADD_U_D:
836 case Mips::DPADD_S_H:
837 case Mips::DPADD_S_W:
838 case Mips::DPADD_S_D:
840 if (!fixCommutedOpIndices(SrcOpIdx1, SrcOpIdx2, 2, 3))
843 if (!
MI.getOperand(SrcOpIdx1).isReg() || !
MI.getOperand(SrcOpIdx2).isReg())
865 const int64_t PosLow,
const int64_t PosHigh,
866 const int64_t SizeLow,
867 const int64_t SizeHigh,
868 const int64_t BothLow,
869 const int64_t BothHigh) {
871 if (!MOPos.
isImm()) {
872 ErrInfo =
"Position is not an immediate!";
875 int64_t Pos = MOPos.
getImm();
876 if (!((PosLow <= Pos) && (Pos < PosHigh))) {
877 ErrInfo =
"Position operand is out of range!";
882 if (!MOSize.
isImm()) {
883 ErrInfo =
"Size operand is not an immediate!";
887 if (!((SizeLow <
Size) && (
Size <= SizeHigh))) {
888 ErrInfo =
"Size operand is out of range!";
892 if (!((BothLow < (Pos +
Size)) && ((Pos +
Size) <= BothHigh))) {
893 ErrInfo =
"Position + Size is out of range!";
904 switch (
MI.getOpcode()) {
930 case Mips::TAILCALLREG:
931 case Mips::PseudoIndirectBranch:
936 case Mips::JALRPseudo:
940 ErrInfo =
"invalid instruction when using jump guards!";
949std::pair<unsigned, unsigned>
951 return std::make_pair(TF, 0u);
958 static const std::pair<unsigned, const char*> Flags[] = {
959 {MO_GOT,
"mips-got"},
960 {MO_GOT_CALL,
"mips-got-call"},
961 {MO_GPREL,
"mips-gprel"},
962 {MO_ABS_HI,
"mips-abs-hi"},
963 {MO_ABS_LO,
"mips-abs-lo"},
964 {MO_TLSGD,
"mips-tlsgd"},
965 {MO_TLSLDM,
"mips-tlsldm"},
966 {MO_DTPREL_HI,
"mips-dtprel-hi"},
967 {MO_DTPREL_LO,
"mips-dtprel-lo"},
968 {MO_GOTTPREL,
"mips-gottprel"},
969 {MO_TPREL_HI,
"mips-tprel-hi"},
970 {MO_TPREL_LO,
"mips-tprel-lo"},
971 {MO_GPOFF_HI,
"mips-gpoff-hi"},
972 {MO_GPOFF_LO,
"mips-gpoff-lo"},
973 {MO_GOT_DISP,
"mips-got-disp"},
974 {MO_GOT_PAGE,
"mips-got-page"},
975 {MO_GOT_OFST,
"mips-got-ofst"},
976 {MO_HIGHER,
"mips-higher"},
977 {MO_HIGHEST,
"mips-highest"},
978 {MO_GOT_HI16,
"mips-got-hi16"},
979 {MO_GOT_LO16,
"mips-got-lo16"},
980 {MO_CALL_HI16,
"mips-call-hi16"},
981 {MO_CALL_LO16,
"mips-call-lo16"},
982 {MO_JALR,
"mips-jalr"}
987std::optional<ParamLoadedValue>
995 int64_t
Offset = RegImm->Imm;
998 if (SrcReg == Mips::ZERO || SrcReg == Mips::ZERO_64) {
1003 }
else if (
auto DestSrc = isCopyInstr(
MI)) {
1006 Register DestReg = DestSrc->Destination->getReg();
1009 if (
TRI->isSuperRegister(Reg, DestReg) ||
TRI->isSubRegister(Reg, DestReg))
1010 return std::nullopt;
1022 return std::nullopt;
1024 switch (
MI.getOpcode()) {
1026 case Mips::DADDiu: {
1037 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 & addReg(Register RegNo, RegState Flags={}, unsigned SubReg=0) const
Add a new virtual register operand.
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 & 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 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
LLVM_ABI MachineInstrBundleIterator< MachineInstr > eraseFromParent()
Unlink 'this' from the containing basic block and delete it.
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.