29#include "llvm/Config/llvm-config.h"
42#define DEBUG_TYPE "target-reg-info"
48 cl::desc(
"A threshold of live range size which may cause "
49 "high compile time cost in global splitting."),
60 : InfoDesc(
ID), SubRegIndexStrings(SubRegIndexStrings),
61 SubRegIndexNameOffsets(SubRegIndexNameOffsets),
62 SubRegIdxRanges(SubRegIdxRanges),
63 SubRegIndexLaneMasks(SubRegIndexLaneMasks),
64 RegClassBegin(RegisterClasses.begin()),
65 RegClassEnd(RegisterClasses.end()), CoveringLanes(CoveringLanes),
66 RCInfos(RCInfos), RCVTLists(RCVTLists), HwMode(Mode) {}
75 if (
MI &&
TII->isTriviallyReMaterializable(*
MI) &&
91 for (
unsigned Reg : RegisterSet.set_bits()) {
95 if (!RegisterSet[SR] && !
is_contained(Exceptions, Reg)) {
97 <<
" of reserved register " <<
printReg(Reg,
this)
98 <<
" is not reserved.\n";
115 else if (Reg.isStack())
116 OS <<
"SS#" << Reg.stackSlotIndex();
117 else if (Reg.isVirtual()) {
122 OS <<
'%' << Reg.virtRegIndex();
125 OS <<
'$' <<
"physreg" << Reg.id();
134 OS <<
':' <<
TRI->getSubRegIndexName(SubIdx);
136 OS <<
":sub(" << SubIdx <<
')';
145 OS <<
"Unit~" <<
static_cast<unsigned>(Unit);
150 if (
static_cast<unsigned>(Unit) >=
TRI->getNumRegUnits()) {
151 OS <<
"BadUnit~" <<
static_cast<unsigned>(Unit);
158 OS <<
TRI->getName(*Roots);
159 for (++Roots; Roots.
isValid(); ++Roots)
160 OS <<
'~' <<
TRI->getName(*Roots);
179 if (RegInfo.getRegClassOrNull(Reg))
181 else if (RegInfo.getRegBankOrNull(Reg))
182 OS <<
StringRef(RegInfo.getRegBankOrNull(Reg)->getName()).
lower();
185 assert((RegInfo.def_empty(Reg) || RegInfo.getType(Reg).isValid()) &&
186 "Generic registers must have a valid type");
207template <
typename TypeT>
211 static_assert(std::is_same_v<TypeT, MVT> || std::is_same_v<TypeT, LLT>);
212 assert(
Reg.isPhysical() &&
"reg must be a physical register");
214 bool IsDefault = [&]() {
215 if constexpr (std::is_same_v<TypeT, MVT>)
216 return Ty == MVT::Other;
218 return !Ty.isValid();
225 if ((IsDefault ||
TRI->isTypeLegalForClass(*RC, Ty)) && RC->contains(
Reg) &&
230 if constexpr (std::is_same_v<TypeT, MVT>)
231 assert(BestRC &&
"Couldn't find the register class");
235template <
typename TypeT>
239 static_assert(std::is_same_v<TypeT, MVT> || std::is_same_v<TypeT, LLT>);
241 "Reg1/Reg2 must be a physical register");
243 bool IsDefault = [&]() {
244 if constexpr (std::is_same_v<TypeT, MVT>)
245 return Ty == MVT::Other;
247 return !Ty.isValid();
254 if ((IsDefault ||
TRI->isTypeLegalForClass(*RC, Ty)) &&
255 RC->contains(Reg1, Reg2) && (!BestRC || BestRC->
hasSubClass(RC)))
259 if constexpr (std::is_same_v<TypeT, MVT>)
260 assert(BestRC &&
"Couldn't find the register class");
266 return ::getMinimalPhysRegClass(
this, Reg, VT);
271 return ::getCommonMinimalPhysRegClass(
this, Reg1, Reg2, VT);
276 return ::getMinimalPhysRegClass(
this, Reg, Ty);
281 return ::getCommonMinimalPhysRegClass(
this, Reg1, Reg2, Ty);
304 if (
C->isAllocatable())
320 for (
unsigned I = 0,
E =
TRI->getNumRegClasses();
I <
E;
I += 32)
321 if (
unsigned Common = *
A++ & *
B++)
343 unsigned Idx)
const {
344 assert(
A &&
B &&
"Missing register class");
345 assert(Idx &&
"Bad sub-register index");
349 if (RCI.getSubReg() == Idx)
359 unsigned &PreA,
unsigned &PreB)
const {
360 assert(RCA && SubA && RCB && SubB &&
"Invalid arguments");
375 unsigned *BestPreA = &PreA;
376 unsigned *BestPreB = &PreB;
398 if (FinalA != FinalB)
407 *BestPreA = IA.getSubReg();
408 *BestPreB = IB.getSubReg();
425 if (DefRC == SrcRC && DefSubReg == SrcSubReg)
429 unsigned SrcIdx, DefIdx;
430 if (SrcSubReg && DefSubReg) {
461 const std::pair<unsigned, SmallVector<Register, 4>> *Hints_MRI =
462 MRI.getRegAllocationHints(VirtReg);
469 bool Skip = (Hints_MRI->first != 0);
470 for (
auto Reg : Hints_MRI->second) {
483 if (!HintedRegs.
insert(Phys).second)
488 if (
MRI.isReserved(Phys))
506 const uint32_t *callerPreservedRegs =
508 if (callerPreservedRegs) {
510 return (callerPreservedRegs[PhysReg.
id() / 32] >> PhysReg.
id() % 32) & 1;
526 for (
unsigned I = 0;
I <
N; ++
I)
527 if ((mask0[
I] & mask1[
I]) != mask0[
I])
536 if (Reg.isPhysical()) {
541 assert(RC &&
"Unable to deduce the register class");
544 LLT Ty =
MRI.getType(Reg);
546 return Ty.getSizeInBits();
549 RC =
MRI.getRegClass(Reg);
550 assert(RC &&
"Unable to deduce the register class");
558 unsigned BestIdx = 0;
559 unsigned BestCover = 0;
567 if (SubRegMask == LaneMask) {
573 if ((SubRegMask & ~LaneMask).any())
578 if (PopCount > BestCover) {
579 BestCover = PopCount;
593 while (LanesLeft.
any()) {
594 unsigned BestIdx = 0;
595 int BestCover = std::numeric_limits<int>::min();
596 for (
unsigned Idx : PossibleIndexes) {
599 if (SubRegMask == LanesLeft) {
607 if ((SubRegMask & ~LanesLeft).any())
611 const int Cover = (SubRegMask & LanesLeft).getNumLanes();
612 if (Cover > BestCover) {
631 "This is not a subregister index");
637 "This is not a subregister index");
646 if (!
MI->isCopyLike())
651 CopySrcReg =
MI->getOperand(1).getReg();
653 assert(
MI->isSubregToReg() &&
"Bad opcode for lookThruCopyLike");
654 CopySrcReg =
MI->getOperand(1).getReg();
669 if (!
MI->isCopyLike())
670 return MRI->hasOneNonDBGUse(SrcReg) ? SrcReg :
Register();
674 CopySrcReg =
MI->getOperand(1).getReg();
676 assert(
MI->isSubregToReg() &&
"Bad opcode for lookThruCopyLike");
677 CopySrcReg =
MI->getOperand(1).getReg();
682 if (!CopySrcReg.
isVirtual() || !
MRI->hasOneNonDBGUse(CopySrcReg))
691 assert(!
Offset.getScalable() &&
"Scalable offsets are not handled");
697 unsigned PrependFlags,
702 "Unsupported prepend flag");
705 OffsetExpr.
push_back(dwarf::DW_OP_deref);
708 OffsetExpr.
push_back(dwarf::DW_OP_deref);
714#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
unsigned const MachineRegisterInfo * MRI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file contains the simple types necessary to represent the attributes associated with functions a...
This file implements the BitVector class.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file contains constants used for implementing Dwarf debug support.
const HexagonInstrInfo * TII
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
Register const TargetRegisterInfo * TRI
Promote Memory to Register
This file defines the SmallSet class.
static const TargetRegisterClass * getMinimalPhysRegClass(const TargetRegisterInfo *TRI, MCRegister Reg, TypeT Ty)
static void getAllocatableSetForRC(const MachineFunction &MF, const TargetRegisterClass *RC, BitVector &R)
getAllocatableSetForRC - Toggle the bits that represent allocatable registers for the specific regist...
static const TargetRegisterClass * firstCommonClass(const uint32_t *A, const uint32_t *B, const TargetRegisterInfo *TRI)
static const TargetRegisterClass * getCommonMinimalPhysRegClass(const TargetRegisterInfo *TRI, MCRegister Reg1, MCRegister Reg2, TypeT Ty)
static cl::opt< unsigned > HugeSizeForSplit("huge-size-for-split", cl::Hidden, cl::desc("A threshold of live range size which may cause " "high compile time cost in global splitting."), cl::init(5000))
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
This class encapuslates the logic to iterate over bitmask returned by the various RegClass related AP...
bool isValid() const
Returns true if this iterator is still pointing at a valid entry.
static LLVM_ABI void appendOffset(SmallVectorImpl< uint64_t > &Ops, int64_t Offset)
Append Ops with operations to apply the Offset.
static LLVM_ABI DIExpression * prependOpcodes(const DIExpression *Expr, SmallVectorImpl< uint64_t > &Ops, bool StackValue=false, bool EntryValue=false)
Prepend DIExpr with the given opcodes and optionally turn it into a stack value.
CallingConv::ID getCallingConv() const
getCallingConv()/setCallingConv(CC) - These method get and set the calling convention of this functio...
LiveInterval - This class represents the liveness of a register, or stack slot.
MCRegUnitRootIterator enumerates the root registers of a register unit.
bool isValid() const
Check if the iterator is at the end of the list.
unsigned getNumSubRegIndices() const
Return the number of sub-register indices understood by the target.
iterator_range< MCSuperRegIterator > superregs(MCRegister Reg) const
Return an iterator range over all super-registers of Reg, excluding Reg.
iterator_range< MCSuperRegIterator > superregs_inclusive(MCRegister Reg) const
Return an iterator range over all super-registers of Reg, including Reg.
unsigned getNumRegs() const
Return the number of registers this target has (useful for sizing arrays holding per register informa...
Wrapper class representing physical registers. Should be passed by value.
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
constexpr unsigned id() const
bool shouldRealignStack() const
Return true if stack realignment is forced by function attributes or if the stack alignment.
bool isStackRealignable() const
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.
Function & getFunction()
Return the LLVM function that this machine code represents.
Representation of each machine instruction.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
Simple wrapper around std::function<void(raw_ostream&)>.
Wrapper class representing virtual and physical registers.
unsigned virtRegIndex() const
Convert a virtual register number to a 0-based index.
constexpr bool isVirtual() const
Return true if the specified register number is in the virtual register namespace.
constexpr unsigned id() const
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
std::pair< const_iterator, bool > insert(const T &V)
insert - Insert an element into the set if it isn't already there.
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.
StackOffset holds a fixed and a scalable offset in bytes.
StringRef - Represent a constant reference to a string, i.e.
LLVM_ABI std::string lower() const
bool isValid() const
Returns true if this iterator is still pointing at a valid entry.
TargetInstrInfo - Interface to description of machine instruction set.
ArrayRef< MCPhysReg > getRawAllocationOrder(const MachineFunction &MF, bool Rev=false) const
Returns the preferred order for allocating registers from this register class in MF.
bool isAllocatable() const
Return true if this register class may be used to create virtual registers.
bool hasSubClass(const TargetRegisterClass *RC) const
Return true if the specified TargetRegisterClass is a proper sub-class of this TargetRegisterClass.
const uint32_t * getSubClassMask() const
Returns a bit vector of subclasses, including this one.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
~TargetRegisterInfo() override
const TargetRegisterClass * getMinimalPhysRegClass(MCRegister Reg, MVT VT=MVT::Other) const
Returns the Register Class of a physical register of the given type, picking the most sub register cl...
iterator_range< regclass_iterator > regclasses() const
virtual bool shouldRegionSplitForVirtReg(const MachineFunction &MF, const LiveInterval &VirtReg) const
Region split has a high compile time cost especially for large live range.
virtual bool canRealignStack(const MachineFunction &MF) const
True if the stack can be realigned for the target.
bool getCoveringSubRegIndexes(const TargetRegisterClass *RC, LaneBitmask LaneMask, SmallVectorImpl< unsigned > &Indexes) const
Try to find one or more subregister indexes to cover LaneMask.
const TargetRegisterClass * getRegClass(unsigned i) const
Returns the register class associated with the enumeration value.
unsigned composeSubRegIndices(unsigned a, unsigned b) const
Return the subregister index you get from composing two subregister indices.
const TargetRegisterClass * getCommonSubClass(const TargetRegisterClass *A, const TargetRegisterClass *B) const
Find the largest common subclass of A and B.
const TargetRegisterClass * getMinimalPhysRegClassLLT(MCRegister Reg, LLT Ty=LLT()) const
Returns the Register Class of a physical register of the given type, picking the most sub register cl...
void markSuperRegs(BitVector &RegisterSet, MCRegister Reg) const
Mark a register and all its aliases as reserved in the given set.
TargetRegisterInfo(const TargetRegisterInfoDesc *ID, ArrayRef< const TargetRegisterClass * > RegisterClasses, const char *SubRegIndexStrings, ArrayRef< uint32_t > SubRegIndexNameOffsets, const SubRegCoveredBits *SubRegIdxRanges, const LaneBitmask *SubRegIndexLaneMasks, LaneBitmask CoveringLanes, const RegClassInfo *const RCInfos, const MVT::SimpleValueType *const RCVTLists, unsigned Mode=0)
virtual float getSpillWeightScaleFactor(const TargetRegisterClass *RC) const
Get the scale factor of spill weight for this register class.
bool regmaskSubsetEqual(const uint32_t *mask0, const uint32_t *mask1) const
Return true if all bits that are set in mask mask0 are also set in mask1.
TypeSize getRegSizeInBits(const TargetRegisterClass &RC) const
Return the size in bits of a register from class RC.
virtual const uint32_t * getCallPreservedMask(const MachineFunction &MF, CallingConv::ID) const
Return a mask of call-preserved registers for the given calling convention on the current function.
virtual Register lookThruSingleUseCopyChain(Register SrcReg, const MachineRegisterInfo *MRI) const
Find the original SrcReg unless it is the target of a copy-like operation, in which case we chain bac...
LaneBitmask getSubRegIndexLaneMask(unsigned SubIdx) const
Return a bitmask representing the parts of a register that are covered by SubIdx.
bool checkAllSuperRegsMarked(const BitVector &RegisterSet, ArrayRef< MCPhysReg > Exceptions=ArrayRef< MCPhysReg >()) const
Returns true if for every register in the set all super registers are part of the set as well.
const TargetRegisterClass * getAllocatableClass(const TargetRegisterClass *RC) const
Return the maximal subclass of the given register class that is allocatable or NULL.
virtual Register lookThruCopyLike(Register SrcReg, const MachineRegisterInfo *MRI) const
Returns the original SrcReg unless it is the target of a copy-like operation, in which case we chain ...
const TargetRegisterClass * getCommonSuperRegClass(const TargetRegisterClass *RCA, unsigned SubA, const TargetRegisterClass *RCB, unsigned SubB, unsigned &PreA, unsigned &PreB) const
Find a common super-register class if it exists.
unsigned getSubRegIdxSize(unsigned Idx) const
Get the size of the bit range covered by a sub-register index.
static void dumpReg(Register Reg, unsigned SubRegIndex=0, const TargetRegisterInfo *TRI=nullptr)
Debugging helper: dump register in human readable form to dbgs() stream.
virtual bool shouldRealignStack(const MachineFunction &MF) const
True if storage within the function requires the stack pointer to be aligned more than the normal cal...
DIExpression * prependOffsetExpression(const DIExpression *Expr, unsigned PrependFlags, const StackOffset &Offset) const
Prepends a DWARF expression for Offset to DIExpression Expr.
const TargetRegisterClass * findCommonRegClass(const TargetRegisterClass *DefRC, unsigned DefSubReg, const TargetRegisterClass *SrcRC, unsigned SrcSubReg) const
Find a common register class that can accomodate both the source and destination operands of a copy-l...
const TargetRegisterClass * getCommonMinimalPhysRegClass(MCRegister Reg1, MCRegister Reg2, MVT VT=MVT::Other) const
Returns the common Register Class of two physical registers of the given type, picking the most sub r...
virtual bool isCalleeSavedPhysReg(MCRegister PhysReg, const MachineFunction &MF) const
This is a wrapper around getCallPreservedMask().
unsigned getSubRegIdxOffset(unsigned Idx) const
Get the offset of the bit range covered by a sub-register index.
bool isSubRegValidForRegClass(const TargetRegisterClass *RC, unsigned Idx) const
Returns true if sub-register Idx can be used with register class RC.
virtual const TargetRegisterClass * getMatchingSuperRegClass(const TargetRegisterClass *A, const TargetRegisterClass *B, unsigned Idx) const
Return a subclass of the register class A so that each register in it has a sub-register of sub-regis...
virtual void getOffsetOpcodes(const StackOffset &Offset, SmallVectorImpl< uint64_t > &Ops) const
Gets the DWARF expression opcodes for Offset.
BitVector getAllocatableSet(const MachineFunction &MF, const TargetRegisterClass *RC=nullptr) const
Returns a bitset indexed by register number indicating if a register is allocatable or not.
virtual bool getRegAllocationHints(Register VirtReg, ArrayRef< MCPhysReg > Order, SmallVectorImpl< MCPhysReg > &Hints, const MachineFunction &MF, const VirtRegMap *VRM=nullptr, const LiveRegMatrix *Matrix=nullptr) const
Get a list of 'hint' registers that the register allocator should try first when allocating a physica...
const TargetRegisterClass * getCommonMinimalPhysRegClassLLT(MCRegister Reg1, MCRegister Reg2, LLT Ty=LLT()) const
Returns the common Register Class of two physical registers of the given type, picking the most sub r...
virtual const TargetInstrInfo * getInstrInfo() const
MCRegister getPhys(Register virtReg) const
returns the physical register mapped to the specified virtual register
Wrapper class representing a virtual register or register unit.
constexpr bool isVirtualReg() const
constexpr MCRegUnit asMCRegUnit() const
constexpr Register asVirtualReg() const
This class implements an extremely fast bulk output stream that can only output to a stream.
#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.
@ C
The default llvm calling convention, compatible with C.
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI void printLowerCase(StringRef String, raw_ostream &Out)
printLowerCase - Print each character as lowercase if it is uppercase.
LLVM_ABI Printable printRegUnit(MCRegUnit Unit, const TargetRegisterInfo *TRI)
Create Printable object to print register units on a raw_ostream.
int countr_zero(T Val)
Count number of 0's from the least significant bit to the most stopping at the first 1.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_ABI Printable printRegClassOrBank(Register Reg, const MachineRegisterInfo &RegInfo, const TargetRegisterInfo *TRI)
Create Printable object to print register classes or register banks on a raw_ostream.
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
LLVM_ABI Printable printReg(Register Reg, const TargetRegisterInfo *TRI=nullptr, unsigned SubIdx=0, const MachineRegisterInfo *MRI=nullptr)
Prints virtual and physical registers with or without a TRI instance.
LLVM_ABI Printable printVRegOrUnit(VirtRegOrUnit VRegOrUnit, const TargetRegisterInfo *TRI)
Create Printable object to print virtual registers and physical registers on a raw_ostream.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
constexpr bool any() const
unsigned getNumLanes() const
Extra information, not in MCRegisterDesc, about registers.
SubRegCoveredBits - Emitted by tablegen: bit range covered by a subreg index, -1 in any being invalid...