|
LLVM 22.0.0git
|
A live range for subregisters. More...
#include "llvm/CodeGen/LiveInterval.h"
Public Member Functions | |
| SubRange (LaneBitmask LaneMask) | |
| Constructs a new SubRange object. | |
| SubRange (LaneBitmask LaneMask, const LiveRange &Other, BumpPtrAllocator &Allocator) | |
Constructs a new SubRange object by copying liveness from Other. | |
| LLVM_ABI void | print (raw_ostream &OS) const |
| LLVM_ABI void | dump () const |
| Public Member Functions inherited from llvm::LiveRange | |
| iterator | begin () |
| iterator | end () |
| const_iterator | begin () const |
| const_iterator | end () const |
| vni_iterator | vni_begin () |
| vni_iterator | vni_end () |
| const_vni_iterator | vni_begin () const |
| const_vni_iterator | vni_end () const |
| iterator_range< vni_iterator > | vnis () |
| iterator_range< const_vni_iterator > | vnis () const |
| LiveRange (bool UseSegmentSet=false) | |
| Constructs a new LiveRange object. | |
| LiveRange (const LiveRange &Other, BumpPtrAllocator &Allocator) | |
| Constructs a new LiveRange object by copying segments and valnos from another LiveRange. | |
| void | assign (const LiveRange &Other, BumpPtrAllocator &Allocator) |
Copies values numbers and live segments from Other into this range. | |
| iterator | advanceTo (iterator I, SlotIndex Pos) |
| advanceTo - Advance the specified iterator to point to the Segment containing the specified position, or end() if the position is past the end of the range. | |
| const_iterator | advanceTo (const_iterator I, SlotIndex Pos) const |
| LLVM_ABI iterator | find (SlotIndex Pos) |
| find - Return an iterator pointing to the first segment that ends after Pos, or end(). | |
| const_iterator | find (SlotIndex Pos) const |
| void | clear () |
| size_t | size () const |
| bool | hasAtLeastOneValue () const |
| bool | containsOneValue () const |
| unsigned | getNumValNums () const |
| VNInfo * | getValNumInfo (unsigned ValNo) |
| getValNumInfo - Returns pointer to the specified val#. | |
| const VNInfo * | getValNumInfo (unsigned ValNo) const |
| bool | containsValue (const VNInfo *VNI) const |
| containsValue - Returns true if VNI belongs to this range. | |
| VNInfo * | getNextValue (SlotIndex Def, VNInfo::Allocator &VNInfoAllocator) |
| getNextValue - Create a new value number and return it. | |
| LLVM_ABI VNInfo * | createDeadDef (SlotIndex Def, VNInfo::Allocator &VNIAlloc) |
| createDeadDef - Make sure the range has a value defined at Def. | |
| LLVM_ABI VNInfo * | createDeadDef (VNInfo *VNI) |
Create a def of value VNI. | |
| VNInfo * | createValueCopy (const VNInfo *orig, VNInfo::Allocator &VNInfoAllocator) |
| Create a copy of the given value. | |
| LLVM_ABI void | RenumberValues () |
| RenumberValues - Renumber all values in order of appearance and remove unused values. | |
| LLVM_ABI VNInfo * | MergeValueNumberInto (VNInfo *V1, VNInfo *V2) |
| MergeValueNumberInto - This method is called when two value numbers are found to be equivalent. | |
| LLVM_ABI void | MergeSegmentsInAsValue (const LiveRange &RHS, VNInfo *LHSValNo) |
| Merge all of the live segments of a specific val# in RHS into this live range as the specified value number. | |
| LLVM_ABI void | MergeValueInAsValue (const LiveRange &RHS, const VNInfo *RHSValNo, VNInfo *LHSValNo) |
| MergeValueInAsValue - Merge all of the segments of a specific val# in RHS into this live range as the specified value number. | |
| bool | empty () const |
| SlotIndex | beginIndex () const |
| beginIndex - Return the lowest numbered slot covered. | |
| SlotIndex | endIndex () const |
| endNumber - return the maximum point of the range of the whole, exclusive. | |
| bool | expiredAt (SlotIndex index) const |
| bool | liveAt (SlotIndex index) const |
| const Segment * | getSegmentContaining (SlotIndex Idx) const |
| Return the segment that contains the specified index, or null if there is none. | |
| Segment * | getSegmentContaining (SlotIndex Idx) |
| Return the live segment that contains the specified index, or null if there is none. | |
| VNInfo * | getVNInfoAt (SlotIndex Idx) const |
| getVNInfoAt - Return the VNInfo that is live at Idx, or NULL. | |
| VNInfo * | getVNInfoBefore (SlotIndex Idx) const |
| getVNInfoBefore - Return the VNInfo that is live up to but not necessarily including Idx, or NULL. | |
| iterator | FindSegmentContaining (SlotIndex Idx) |
| Return an iterator to the segment that contains the specified index, or end() if there is none. | |
| const_iterator | FindSegmentContaining (SlotIndex Idx) const |
| bool | overlaps (const LiveRange &other) const |
| overlaps - Return true if the intersection of the two live ranges is not empty. | |
| LLVM_ABI bool | overlaps (const LiveRange &Other, const CoalescerPair &CP, const SlotIndexes &) const |
| overlaps - Return true if the two ranges have overlapping segments that are not coalescable according to CP. | |
| LLVM_ABI bool | overlaps (SlotIndex Start, SlotIndex End) const |
| overlaps - Return true if the live range overlaps an interval specified by [Start, End). | |
| LLVM_ABI bool | overlapsFrom (const LiveRange &Other, const_iterator StartPos) const |
| overlapsFrom - Return true if the intersection of the two live ranges is not empty. | |
| LLVM_ABI bool | covers (const LiveRange &Other) const |
Returns true if all segments of the Other live range are completely covered by this live range. | |
| LLVM_ABI iterator | addSegment (Segment S) |
| Add the specified Segment to this range, merging segments as appropriate. | |
| LLVM_ABI std::pair< VNInfo *, bool > | extendInBlock (ArrayRef< SlotIndex > Undefs, SlotIndex StartIdx, SlotIndex Kill) |
Attempt to extend a value defined after StartIdx to include Use. | |
| LLVM_ABI VNInfo * | extendInBlock (SlotIndex StartIdx, SlotIndex Kill) |
| Simplified version of the above "extendInBlock", which assumes that no register lanes are undefined by <def,read-undef> operands. | |
| LLVM_ABI void | join (LiveRange &Other, const int *ValNoAssignments, const int *RHSValNoAssignments, SmallVectorImpl< VNInfo * > &NewVNInfo) |
| join - Join two live ranges (this, and other) together. | |
| bool | isLocal (SlotIndex Start, SlotIndex End) const |
| True iff this segment is a single segment that lies between the specified boundaries, exclusively. | |
| LLVM_ABI void | removeSegment (SlotIndex Start, SlotIndex End, bool RemoveDeadValNo=false) |
| Remove the specified interval from this live range. | |
| void | removeSegment (Segment S, bool RemoveDeadValNo=false) |
| LLVM_ABI iterator | removeSegment (iterator I, bool RemoveDeadValNo=false) |
Remove segment pointed to by iterator I from this range. | |
| LLVM_ABI void | removeValNoIfDead (VNInfo *ValNo) |
Mark ValNo for deletion if no segments in this range use it. | |
| LiveQueryResult | Query (SlotIndex Idx) const |
| Query Liveness at Idx. | |
| LLVM_ABI void | removeValNo (VNInfo *ValNo) |
| removeValNo - Remove all the segments defined by the specified value#. | |
| bool | isZeroLength (SlotIndexes *Indexes) const |
| Returns true if the live range is zero length, i.e. | |
| LLVM_ABI bool | isLiveAtIndexes (ArrayRef< SlotIndex > Slots) const |
| bool | operator< (const LiveRange &other) const |
| bool | isUndefIn (ArrayRef< SlotIndex > Undefs, SlotIndex Begin, SlotIndex End) const |
Returns true if there is an explicit "undef" between Begin End. | |
| LLVM_ABI void | flushSegmentSet () |
| Flush segment set into the regular segment vector. | |
| template<typename Range, typename OutputIt> | |
| bool | findIndexesLiveAt (Range &&R, OutputIt O) const |
| Stores indexes from the input index sequence R at which this LiveRange is live to the output O iterator. | |
| LLVM_ABI void | print (raw_ostream &OS) const |
| LLVM_ABI void | dump () const |
| bool | verify () const |
| Walk the range and assert if any invariants fail to hold. | |
Public Attributes | |
| SubRange * | Next = nullptr |
| LaneBitmask | LaneMask |
| Public Attributes inherited from llvm::LiveRange | |
| Segments | segments |
| VNInfoList | valnos |
| std::unique_ptr< SegmentSet > | segmentSet |
Additional Inherited Members | |
| Public Types inherited from llvm::LiveRange | |
| using | Segments = SmallVector<Segment, 2> |
| using | VNInfoList = SmallVector<VNInfo *, 2> |
| using | SegmentSet = std::set<Segment> |
| using | iterator = Segments::iterator |
| using | const_iterator = Segments::const_iterator |
| using | vni_iterator = VNInfoList::iterator |
| using | const_vni_iterator = VNInfoList::const_iterator |
| Protected Member Functions inherited from llvm::LiveRange | |
| LLVM_ABI void | append (const LiveRange::Segment S) |
| Append a segment to the list of segments. | |
A live range for subregisters.
The LaneMask specifies which parts of the super register are covered by the interval. (
Definition at line 705 of file LiveInterval.h.
|
inline |
Constructs a new SubRange object.
Definition at line 711 of file LiveInterval.h.
References LaneMask.
|
inline |
Constructs a new SubRange object by copying liveness from Other.
Definition at line 714 of file LiveInterval.h.
References Allocator, LaneMask, llvm::LiveRange::LiveRange(), and llvm::Other.
| LLVM_DUMP_METHOD void LiveInterval::SubRange::dump | ( | ) | const |
Definition at line 1054 of file LiveInterval.cpp.
References llvm::dbgs(), and LLVM_DUMP_METHOD.
| void LiveInterval::SubRange::print | ( | raw_ostream & | OS | ) | const |
Definition at line 1035 of file LiveInterval.cpp.
References LaneMask, llvm::LiveRange::LiveRange(), and llvm::PrintLaneMask().
Referenced by llvm::operator<<().
| LaneBitmask llvm::LiveInterval::SubRange::LaneMask |
Definition at line 708 of file LiveInterval.h.
Referenced by print(), llvm::LiveIntervals::shrinkToUses(), SubRange(), and SubRange().
| SubRange* llvm::LiveInterval::SubRange::Next = nullptr |
Definition at line 707 of file LiveInterval.h.
Referenced by llvm::LiveInterval::SingleLinkedListIterator< SubRange >::operator++().