mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
Remove trailing whitespace.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110944 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e1f543fbb3
commit
1b2932024f
@ -39,7 +39,7 @@ namespace llvm {
|
|||||||
/// This class holds information about a machine level values, including
|
/// This class holds information about a machine level values, including
|
||||||
/// definition and use points.
|
/// definition and use points.
|
||||||
///
|
///
|
||||||
/// Care must be taken in interpreting the def index of the value. The
|
/// Care must be taken in interpreting the def index of the value. The
|
||||||
/// following rules apply:
|
/// following rules apply:
|
||||||
///
|
///
|
||||||
/// If the isDefAccurate() method returns false then def does not contain the
|
/// If the isDefAccurate() method returns false then def does not contain the
|
||||||
@ -108,7 +108,7 @@ namespace llvm {
|
|||||||
|
|
||||||
/// For a stack interval, returns the reg which this stack interval was
|
/// For a stack interval, returns the reg which this stack interval was
|
||||||
/// defined from.
|
/// defined from.
|
||||||
/// For a register interval the behaviour of this method is undefined.
|
/// For a register interval the behaviour of this method is undefined.
|
||||||
unsigned getReg() const { return cr.reg; }
|
unsigned getReg() const { return cr.reg; }
|
||||||
/// For a stack interval, set the defining register.
|
/// For a stack interval, set the defining register.
|
||||||
/// This method should not be called on register intervals as it may lead
|
/// This method should not be called on register intervals as it may lead
|
||||||
@ -189,7 +189,7 @@ namespace llvm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// containsRange - Return true if the given range, [S, E), is covered by
|
/// containsRange - Return true if the given range, [S, E), is covered by
|
||||||
/// this range.
|
/// this range.
|
||||||
bool containsRange(SlotIndex S, SlotIndex E) const {
|
bool containsRange(SlotIndex S, SlotIndex E) const {
|
||||||
assert((S < E) && "Backwards interval?");
|
assert((S < E) && "Backwards interval?");
|
||||||
return (start <= S && S < end) && (start < E && E <= end);
|
return (start <= S && S < end) && (start < E && E <= end);
|
||||||
@ -236,7 +236,7 @@ namespace llvm {
|
|||||||
float weight; // weight of this interval
|
float weight; // weight of this interval
|
||||||
Ranges ranges; // the ranges in which this register is live
|
Ranges ranges; // the ranges in which this register is live
|
||||||
VNInfoList valnos; // value#'s
|
VNInfoList valnos; // value#'s
|
||||||
|
|
||||||
struct InstrSlots {
|
struct InstrSlots {
|
||||||
enum {
|
enum {
|
||||||
LOAD = 0,
|
LOAD = 0,
|
||||||
@ -281,7 +281,7 @@ namespace llvm {
|
|||||||
while (I->end <= Pos) ++I;
|
while (I->end <= Pos) ++I;
|
||||||
return I;
|
return I;
|
||||||
}
|
}
|
||||||
|
|
||||||
void clear() {
|
void clear() {
|
||||||
valnos.clear();
|
valnos.clear();
|
||||||
ranges.clear();
|
ranges.clear();
|
||||||
@ -305,7 +305,7 @@ namespace llvm {
|
|||||||
bool containsOneValue() const { return valnos.size() == 1; }
|
bool containsOneValue() const { return valnos.size() == 1; }
|
||||||
|
|
||||||
unsigned getNumValNums() const { return (unsigned)valnos.size(); }
|
unsigned getNumValNums() const { return (unsigned)valnos.size(); }
|
||||||
|
|
||||||
/// getValNumInfo - Returns pointer to the specified val#.
|
/// getValNumInfo - Returns pointer to the specified val#.
|
||||||
///
|
///
|
||||||
inline VNInfo *getValNumInfo(unsigned ValNo) {
|
inline VNInfo *getValNumInfo(unsigned ValNo) {
|
||||||
@ -350,7 +350,7 @@ namespace llvm {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// MergeValueNumberInto - This method is called when two value nubmers
|
/// MergeValueNumberInto - This method is called when two value nubmers
|
||||||
/// are found to be equivalent. This eliminates V1, replacing all
|
/// are found to be equivalent. This eliminates V1, replacing all
|
||||||
/// LiveRanges with the V1 value number with the V2 value number. This can
|
/// LiveRanges with the V1 value number with the V2 value number. This can
|
||||||
@ -391,7 +391,7 @@ namespace llvm {
|
|||||||
/// except for the register of the interval.
|
/// except for the register of the interval.
|
||||||
void Copy(const LiveInterval &RHS, MachineRegisterInfo *MRI,
|
void Copy(const LiveInterval &RHS, MachineRegisterInfo *MRI,
|
||||||
VNInfo::Allocator &VNInfoAllocator);
|
VNInfo::Allocator &VNInfoAllocator);
|
||||||
|
|
||||||
bool empty() const { return ranges.empty(); }
|
bool empty() const { return ranges.empty(); }
|
||||||
|
|
||||||
/// beginIndex - Return the lowest numbered slot covered by interval.
|
/// beginIndex - Return the lowest numbered slot covered by interval.
|
||||||
@ -458,14 +458,14 @@ namespace llvm {
|
|||||||
iterator FindLiveRangeContaining(SlotIndex Idx);
|
iterator FindLiveRangeContaining(SlotIndex Idx);
|
||||||
|
|
||||||
/// findDefinedVNInfo - Find the by the specified
|
/// findDefinedVNInfo - Find the by the specified
|
||||||
/// index (register interval) or defined
|
/// index (register interval) or defined
|
||||||
VNInfo *findDefinedVNInfoForRegInt(SlotIndex Idx) const;
|
VNInfo *findDefinedVNInfoForRegInt(SlotIndex Idx) const;
|
||||||
|
|
||||||
/// findDefinedVNInfo - Find the VNInfo that's defined by the specified
|
/// findDefinedVNInfo - Find the VNInfo that's defined by the specified
|
||||||
/// register (stack inteval only).
|
/// register (stack inteval only).
|
||||||
VNInfo *findDefinedVNInfoForStackInt(unsigned Reg) const;
|
VNInfo *findDefinedVNInfoForStackInt(unsigned Reg) const;
|
||||||
|
|
||||||
|
|
||||||
/// overlaps - Return true if the intersection of the two live intervals is
|
/// overlaps - Return true if the intersection of the two live intervals is
|
||||||
/// not empty.
|
/// not empty.
|
||||||
bool overlaps(const LiveInterval& other) const {
|
bool overlaps(const LiveInterval& other) const {
|
||||||
|
@ -42,7 +42,7 @@ namespace llvm {
|
|||||||
class TargetInstrInfo;
|
class TargetInstrInfo;
|
||||||
class TargetRegisterClass;
|
class TargetRegisterClass;
|
||||||
class VirtRegMap;
|
class VirtRegMap;
|
||||||
|
|
||||||
class LiveIntervals : public MachineFunctionPass {
|
class LiveIntervals : public MachineFunctionPass {
|
||||||
MachineFunction* mf_;
|
MachineFunction* mf_;
|
||||||
MachineRegisterInfo* mri_;
|
MachineRegisterInfo* mri_;
|
||||||
@ -123,7 +123,7 @@ namespace llvm {
|
|||||||
unsigned getFuncInstructionCount() {
|
unsigned getFuncInstructionCount() {
|
||||||
return indexes_->getFunctionSize();
|
return indexes_->getFunctionSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// getApproximateInstructionCount - computes an estimate of the number
|
/// getApproximateInstructionCount - computes an estimate of the number
|
||||||
/// of instructions in a given LiveInterval.
|
/// of instructions in a given LiveInterval.
|
||||||
unsigned getApproximateInstructionCount(LiveInterval& I) {
|
unsigned getApproximateInstructionCount(LiveInterval& I) {
|
||||||
@ -155,7 +155,7 @@ namespace llvm {
|
|||||||
/// dupInterval - Duplicate a live interval. The caller is responsible for
|
/// dupInterval - Duplicate a live interval. The caller is responsible for
|
||||||
/// managing the allocated memory.
|
/// managing the allocated memory.
|
||||||
LiveInterval *dupInterval(LiveInterval *li);
|
LiveInterval *dupInterval(LiveInterval *li);
|
||||||
|
|
||||||
/// addLiveRangeToEndOfBlock - Given a register and an instruction,
|
/// addLiveRangeToEndOfBlock - Given a register and an instruction,
|
||||||
/// adds a live range from that instruction to the end of its MBB.
|
/// adds a live range from that instruction to the end of its MBB.
|
||||||
LiveRange addLiveRangeToEndOfBlock(unsigned reg,
|
LiveRange addLiveRangeToEndOfBlock(unsigned reg,
|
||||||
@ -187,7 +187,7 @@ namespace llvm {
|
|||||||
SlotIndex getInstructionIndex(const MachineInstr *instr) const {
|
SlotIndex getInstructionIndex(const MachineInstr *instr) const {
|
||||||
return indexes_->getInstructionIndex(instr);
|
return indexes_->getInstructionIndex(instr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the instruction associated with the given index.
|
/// Returns the instruction associated with the given index.
|
||||||
MachineInstr* getInstructionFromIndex(SlotIndex index) const {
|
MachineInstr* getInstructionFromIndex(SlotIndex index) const {
|
||||||
return indexes_->getInstructionFromIndex(index);
|
return indexes_->getInstructionFromIndex(index);
|
||||||
@ -196,12 +196,12 @@ namespace llvm {
|
|||||||
/// Return the first index in the given basic block.
|
/// Return the first index in the given basic block.
|
||||||
SlotIndex getMBBStartIdx(const MachineBasicBlock *mbb) const {
|
SlotIndex getMBBStartIdx(const MachineBasicBlock *mbb) const {
|
||||||
return indexes_->getMBBStartIdx(mbb);
|
return indexes_->getMBBStartIdx(mbb);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return the last index in the given basic block.
|
/// Return the last index in the given basic block.
|
||||||
SlotIndex getMBBEndIdx(const MachineBasicBlock *mbb) const {
|
SlotIndex getMBBEndIdx(const MachineBasicBlock *mbb) const {
|
||||||
return indexes_->getMBBEndIdx(mbb);
|
return indexes_->getMBBEndIdx(mbb);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isLiveInToMBB(const LiveInterval &li,
|
bool isLiveInToMBB(const LiveInterval &li,
|
||||||
const MachineBasicBlock *mbb) const {
|
const MachineBasicBlock *mbb) const {
|
||||||
@ -306,7 +306,7 @@ namespace llvm {
|
|||||||
/// within a single basic block.
|
/// within a single basic block.
|
||||||
bool intervalIsInOneMBB(const LiveInterval &li) const;
|
bool intervalIsInOneMBB(const LiveInterval &li) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/// computeIntervals - Compute live intervals.
|
/// computeIntervals - Compute live intervals.
|
||||||
void computeIntervals();
|
void computeIntervals();
|
||||||
|
|
||||||
@ -320,7 +320,7 @@ namespace llvm {
|
|||||||
|
|
||||||
/// isPartialRedef - Return true if the specified def at the specific index
|
/// isPartialRedef - Return true if the specified def at the specific index
|
||||||
/// is partially re-defining the specified live interval. A common case of
|
/// is partially re-defining the specified live interval. A common case of
|
||||||
/// this is a definition of the sub-register.
|
/// this is a definition of the sub-register.
|
||||||
bool isPartialRedef(SlotIndex MIIdx, MachineOperand &MO,
|
bool isPartialRedef(SlotIndex MIIdx, MachineOperand &MO,
|
||||||
LiveInterval &interval);
|
LiveInterval &interval);
|
||||||
|
|
||||||
|
@ -309,7 +309,7 @@ LiveInterval::addRangeFrom(LiveRange LR, iterator From) {
|
|||||||
return ranges.insert(it, LR);
|
return ranges.insert(it, LR);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// isInOneLiveRange - Return true if the range specified is entirely in
|
/// isInOneLiveRange - Return true if the range specified is entirely in
|
||||||
/// a single LiveRange of the live interval.
|
/// a single LiveRange of the live interval.
|
||||||
bool LiveInterval::isInOneLiveRange(SlotIndex Start, SlotIndex End) {
|
bool LiveInterval::isInOneLiveRange(SlotIndex Start, SlotIndex End) {
|
||||||
Ranges::iterator I = std::upper_bound(ranges.begin(), ranges.end(), Start);
|
Ranges::iterator I = std::upper_bound(ranges.begin(), ranges.end(), Start);
|
||||||
@ -386,7 +386,7 @@ void LiveInterval::removeValNo(VNInfo *ValNo) {
|
|||||||
|
|
||||||
/// getLiveRangeContaining - Return the live range that contains the
|
/// getLiveRangeContaining - Return the live range that contains the
|
||||||
/// specified index, or null if there is none.
|
/// specified index, or null if there is none.
|
||||||
LiveInterval::const_iterator
|
LiveInterval::const_iterator
|
||||||
LiveInterval::FindLiveRangeContaining(SlotIndex Idx) const {
|
LiveInterval::FindLiveRangeContaining(SlotIndex Idx) const {
|
||||||
const_iterator It = std::upper_bound(begin(), end(), Idx);
|
const_iterator It = std::upper_bound(begin(), end(), Idx);
|
||||||
if (It != ranges.begin()) {
|
if (It != ranges.begin()) {
|
||||||
@ -398,7 +398,7 @@ LiveInterval::FindLiveRangeContaining(SlotIndex Idx) const {
|
|||||||
return end();
|
return end();
|
||||||
}
|
}
|
||||||
|
|
||||||
LiveInterval::iterator
|
LiveInterval::iterator
|
||||||
LiveInterval::FindLiveRangeContaining(SlotIndex Idx) {
|
LiveInterval::FindLiveRangeContaining(SlotIndex Idx) {
|
||||||
iterator It = std::upper_bound(begin(), end(), Idx);
|
iterator It = std::upper_bound(begin(), end(), Idx);
|
||||||
if (It != begin()) {
|
if (It != begin()) {
|
||||||
@ -406,7 +406,7 @@ LiveInterval::FindLiveRangeContaining(SlotIndex Idx) {
|
|||||||
if (It->contains(Idx))
|
if (It->contains(Idx))
|
||||||
return It;
|
return It;
|
||||||
}
|
}
|
||||||
|
|
||||||
return end();
|
return end();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,11 +438,11 @@ VNInfo *LiveInterval::findDefinedVNInfoForStackInt(unsigned reg) const {
|
|||||||
/// the intervals are not joinable, this aborts.
|
/// the intervals are not joinable, this aborts.
|
||||||
void LiveInterval::join(LiveInterval &Other,
|
void LiveInterval::join(LiveInterval &Other,
|
||||||
const int *LHSValNoAssignments,
|
const int *LHSValNoAssignments,
|
||||||
const int *RHSValNoAssignments,
|
const int *RHSValNoAssignments,
|
||||||
SmallVector<VNInfo*, 16> &NewVNInfo,
|
SmallVector<VNInfo*, 16> &NewVNInfo,
|
||||||
MachineRegisterInfo *MRI) {
|
MachineRegisterInfo *MRI) {
|
||||||
// Determine if any of our live range values are mapped. This is uncommon, so
|
// Determine if any of our live range values are mapped. This is uncommon, so
|
||||||
// we want to avoid the interval scan if not.
|
// we want to avoid the interval scan if not.
|
||||||
bool MustMapCurValNos = false;
|
bool MustMapCurValNos = false;
|
||||||
unsigned NumVals = getNumValNums();
|
unsigned NumVals = getNumValNums();
|
||||||
unsigned NumNewVals = NewVNInfo.size();
|
unsigned NumNewVals = NewVNInfo.size();
|
||||||
@ -462,7 +462,7 @@ void LiveInterval::join(LiveInterval &Other,
|
|||||||
++OutIt;
|
++OutIt;
|
||||||
for (iterator I = OutIt, E = end(); I != E; ++I) {
|
for (iterator I = OutIt, E = end(); I != E; ++I) {
|
||||||
OutIt->valno = NewVNInfo[LHSValNoAssignments[I->valno->id]];
|
OutIt->valno = NewVNInfo[LHSValNoAssignments[I->valno->id]];
|
||||||
|
|
||||||
// If this live range has the same value # as its immediate predecessor,
|
// If this live range has the same value # as its immediate predecessor,
|
||||||
// and if they are neighbors, remove one LiveRange. This happens when we
|
// and if they are neighbors, remove one LiveRange. This happens when we
|
||||||
// have [0,3:0)[4,7:1) and map 0/1 onto the same value #.
|
// have [0,3:0)[4,7:1) and map 0/1 onto the same value #.
|
||||||
@ -473,12 +473,12 @@ void LiveInterval::join(LiveInterval &Other,
|
|||||||
OutIt->start = I->start;
|
OutIt->start = I->start;
|
||||||
OutIt->end = I->end;
|
OutIt->end = I->end;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Didn't merge, on to the next one.
|
// Didn't merge, on to the next one.
|
||||||
++OutIt;
|
++OutIt;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If we merge some live ranges, chop off the end.
|
// If we merge some live ranges, chop off the end.
|
||||||
ranges.erase(OutIt, end());
|
ranges.erase(OutIt, end());
|
||||||
}
|
}
|
||||||
@ -496,7 +496,7 @@ void LiveInterval::join(LiveInterval &Other,
|
|||||||
if (VNI) {
|
if (VNI) {
|
||||||
if (NumValNos >= NumVals)
|
if (NumValNos >= NumVals)
|
||||||
valnos.push_back(VNI);
|
valnos.push_back(VNI);
|
||||||
else
|
else
|
||||||
valnos[NumValNos] = VNI;
|
valnos[NumValNos] = VNI;
|
||||||
VNI->id = NumValNos++; // Renumber val#.
|
VNI->id = NumValNos++; // Renumber val#.
|
||||||
}
|
}
|
||||||
@ -521,7 +521,7 @@ void LiveInterval::join(LiveInterval &Other,
|
|||||||
/// interval as the specified value number. The LiveRanges in RHS are
|
/// interval as the specified value number. The LiveRanges in RHS are
|
||||||
/// allowed to overlap with LiveRanges in the current interval, but only if
|
/// allowed to overlap with LiveRanges in the current interval, but only if
|
||||||
/// the overlapping LiveRanges have the specified value number.
|
/// the overlapping LiveRanges have the specified value number.
|
||||||
void LiveInterval::MergeRangesInAsValue(const LiveInterval &RHS,
|
void LiveInterval::MergeRangesInAsValue(const LiveInterval &RHS,
|
||||||
VNInfo *LHSValNo) {
|
VNInfo *LHSValNo) {
|
||||||
// TODO: Make this more efficient.
|
// TODO: Make this more efficient.
|
||||||
iterator InsertPos = begin();
|
iterator InsertPos = begin();
|
||||||
@ -570,7 +570,7 @@ void LiveInterval::MergeValueInAsValue(
|
|||||||
// If this trimmed away the whole range, ignore it.
|
// If this trimmed away the whole range, ignore it.
|
||||||
if (Start == End) continue;
|
if (Start == End) continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Map the valno in the other live range to the current live range.
|
// Map the valno in the other live range to the current live range.
|
||||||
IP = addRangeFrom(LiveRange(Start, End, LHSValNo), IP);
|
IP = addRangeFrom(LiveRange(Start, End, LHSValNo), IP);
|
||||||
}
|
}
|
||||||
@ -585,7 +585,7 @@ void LiveInterval::MergeValueInAsValue(
|
|||||||
if (I->valno == V1) {
|
if (I->valno == V1) {
|
||||||
isDead = false;
|
isDead = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (isDead) {
|
if (isDead) {
|
||||||
// Now that V1 is dead, remove it.
|
// Now that V1 is dead, remove it.
|
||||||
markValNoForDeletion(V1);
|
markValNoForDeletion(V1);
|
||||||
@ -602,7 +602,7 @@ void LiveInterval::MergeInClobberRanges(LiveIntervals &li_,
|
|||||||
const LiveInterval &Clobbers,
|
const LiveInterval &Clobbers,
|
||||||
VNInfo::Allocator &VNInfoAllocator) {
|
VNInfo::Allocator &VNInfoAllocator) {
|
||||||
if (Clobbers.empty()) return;
|
if (Clobbers.empty()) return;
|
||||||
|
|
||||||
DenseMap<VNInfo*, VNInfo*> ValNoMaps;
|
DenseMap<VNInfo*, VNInfo*> ValNoMaps;
|
||||||
VNInfo *UnusedValNo = 0;
|
VNInfo *UnusedValNo = 0;
|
||||||
iterator IP = begin();
|
iterator IP = begin();
|
||||||
@ -672,10 +672,10 @@ void LiveInterval::MergeInClobberRange(LiveIntervals &li_,
|
|||||||
// for unknown values, use it.
|
// for unknown values, use it.
|
||||||
VNInfo *ClobberValNo =
|
VNInfo *ClobberValNo =
|
||||||
getNextValue(li_.getInvalidIndex(), 0, false, VNInfoAllocator);
|
getNextValue(li_.getInvalidIndex(), 0, false, VNInfoAllocator);
|
||||||
|
|
||||||
iterator IP = begin();
|
iterator IP = begin();
|
||||||
IP = std::upper_bound(IP, end(), Start);
|
IP = std::upper_bound(IP, end(), Start);
|
||||||
|
|
||||||
// If the start of this range overlaps with an existing liverange, trim it.
|
// If the start of this range overlaps with an existing liverange, trim it.
|
||||||
if (IP != begin() && IP[-1].end > Start) {
|
if (IP != begin() && IP[-1].end > Start) {
|
||||||
Start = IP[-1].end;
|
Start = IP[-1].end;
|
||||||
@ -688,7 +688,7 @@ void LiveInterval::MergeInClobberRange(LiveIntervals &li_,
|
|||||||
// If this trimmed away the whole range, ignore it.
|
// If this trimmed away the whole range, ignore it.
|
||||||
if (Start == End) return;
|
if (Start == End) return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Insert the clobber interval.
|
// Insert the clobber interval.
|
||||||
addRangeFrom(LiveRange(Start, End, ClobberValNo), IP);
|
addRangeFrom(LiveRange(Start, End, ClobberValNo), IP);
|
||||||
}
|
}
|
||||||
@ -715,7 +715,7 @@ VNInfo* LiveInterval::MergeValueNumberInto(VNInfo *V1, VNInfo *V2) {
|
|||||||
for (iterator I = begin(); I != end(); ) {
|
for (iterator I = begin(); I != end(); ) {
|
||||||
iterator LR = I++;
|
iterator LR = I++;
|
||||||
if (LR->valno != V1) continue; // Not a V1 LiveRange.
|
if (LR->valno != V1) continue; // Not a V1 LiveRange.
|
||||||
|
|
||||||
// Okay, we found a V1 live range. If it had a previous, touching, V2 live
|
// Okay, we found a V1 live range. If it had a previous, touching, V2 live
|
||||||
// range, extend it.
|
// range, extend it.
|
||||||
if (LR != begin()) {
|
if (LR != begin()) {
|
||||||
@ -729,11 +729,11 @@ VNInfo* LiveInterval::MergeValueNumberInto(VNInfo *V1, VNInfo *V2) {
|
|||||||
LR = Prev;
|
LR = Prev;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Okay, now we have a V1 or V2 live range that is maximally merged forward.
|
// Okay, now we have a V1 or V2 live range that is maximally merged forward.
|
||||||
// Ensure that it is a V2 live-range.
|
// Ensure that it is a V2 live-range.
|
||||||
LR->valno = V2;
|
LR->valno = V2;
|
||||||
|
|
||||||
// If we can merge it into later V2 live ranges, do so now. We ignore any
|
// If we can merge it into later V2 live ranges, do so now. We ignore any
|
||||||
// following V1 live ranges, as they will be merged in subsequent iterations
|
// following V1 live ranges, as they will be merged in subsequent iterations
|
||||||
// of the loop.
|
// of the loop.
|
||||||
@ -745,10 +745,10 @@ VNInfo* LiveInterval::MergeValueNumberInto(VNInfo *V1, VNInfo *V2) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now that V1 is dead, remove it.
|
// Now that V1 is dead, remove it.
|
||||||
markValNoForDeletion(V1);
|
markValNoForDeletion(V1);
|
||||||
|
|
||||||
return V2;
|
return V2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@
|
|||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
// Hidden options for help debugging.
|
// Hidden options for help debugging.
|
||||||
static cl::opt<bool> DisableReMat("disable-rematerialization",
|
static cl::opt<bool> DisableReMat("disable-rematerialization",
|
||||||
cl::init(false), cl::Hidden);
|
cl::init(false), cl::Hidden);
|
||||||
|
|
||||||
STATISTIC(numIntervals , "Number of original intervals");
|
STATISTIC(numIntervals , "Number of original intervals");
|
||||||
@ -66,12 +66,12 @@ void LiveIntervals::getAnalysisUsage(AnalysisUsage &AU) const {
|
|||||||
AU.addRequired<LiveVariables>();
|
AU.addRequired<LiveVariables>();
|
||||||
AU.addPreservedID(MachineLoopInfoID);
|
AU.addPreservedID(MachineLoopInfoID);
|
||||||
AU.addPreservedID(MachineDominatorsID);
|
AU.addPreservedID(MachineDominatorsID);
|
||||||
|
|
||||||
if (!StrongPHIElim) {
|
if (!StrongPHIElim) {
|
||||||
AU.addPreservedID(PHIEliminationID);
|
AU.addPreservedID(PHIEliminationID);
|
||||||
AU.addRequiredID(PHIEliminationID);
|
AU.addRequiredID(PHIEliminationID);
|
||||||
}
|
}
|
||||||
|
|
||||||
AU.addRequiredID(TwoAddressInstructionPassID);
|
AU.addRequiredID(TwoAddressInstructionPassID);
|
||||||
AU.addPreserved<ProcessImplicitDefs>();
|
AU.addPreserved<ProcessImplicitDefs>();
|
||||||
AU.addRequired<ProcessImplicitDefs>();
|
AU.addRequired<ProcessImplicitDefs>();
|
||||||
@ -85,7 +85,7 @@ void LiveIntervals::releaseMemory() {
|
|||||||
for (DenseMap<unsigned, LiveInterval*>::iterator I = r2iMap_.begin(),
|
for (DenseMap<unsigned, LiveInterval*>::iterator I = r2iMap_.begin(),
|
||||||
E = r2iMap_.end(); I != E; ++I)
|
E = r2iMap_.end(); I != E; ++I)
|
||||||
delete I->second;
|
delete I->second;
|
||||||
|
|
||||||
r2iMap_.clear();
|
r2iMap_.clear();
|
||||||
|
|
||||||
// Release VNInfo memory regions, VNInfo objects don't need to be dtor'd.
|
// Release VNInfo memory regions, VNInfo objects don't need to be dtor'd.
|
||||||
@ -275,7 +275,7 @@ bool MultipleDefsBySameMI(const MachineInstr &MI, unsigned MOIdx) {
|
|||||||
|
|
||||||
/// isPartialRedef - Return true if the specified def at the specific index is
|
/// isPartialRedef - Return true if the specified def at the specific index is
|
||||||
/// partially re-defining the specified live interval. A common case of this is
|
/// partially re-defining the specified live interval. A common case of this is
|
||||||
/// a definition of the sub-register.
|
/// a definition of the sub-register.
|
||||||
bool LiveIntervals::isPartialRedef(SlotIndex MIIdx, MachineOperand &MO,
|
bool LiveIntervals::isPartialRedef(SlotIndex MIIdx, MachineOperand &MO,
|
||||||
LiveInterval &interval) {
|
LiveInterval &interval) {
|
||||||
if (!MO.getSubReg() || MO.isEarlyClobber())
|
if (!MO.getSubReg() || MO.isEarlyClobber())
|
||||||
@ -415,8 +415,8 @@ void LiveIntervals::handleVirtualRegisterDef(MachineBasicBlock *mbb,
|
|||||||
// def-and-use register operand.
|
// def-and-use register operand.
|
||||||
|
|
||||||
// It may also be partial redef like this:
|
// It may also be partial redef like this:
|
||||||
// 80 %reg1041:6<def> = VSHRNv4i16 %reg1034<kill>, 12, pred:14, pred:%reg0
|
// 80 %reg1041:6<def> = VSHRNv4i16 %reg1034<kill>, 12, pred:14, pred:%reg0
|
||||||
// 120 %reg1041:5<def> = VSHRNv4i16 %reg1039<kill>, 12, pred:14, pred:%reg0
|
// 120 %reg1041:5<def> = VSHRNv4i16 %reg1039<kill>, 12, pred:14, pred:%reg0
|
||||||
bool PartReDef = isPartialRedef(MIIdx, MO, interval);
|
bool PartReDef = isPartialRedef(MIIdx, MO, interval);
|
||||||
if (PartReDef || mi->isRegTiedToUseOperand(MOIdx)) {
|
if (PartReDef || mi->isRegTiedToUseOperand(MOIdx)) {
|
||||||
// If this is a two-address definition, then we have already processed
|
// If this is a two-address definition, then we have already processed
|
||||||
@ -451,7 +451,7 @@ void LiveIntervals::handleVirtualRegisterDef(MachineBasicBlock *mbb,
|
|||||||
// A re-def may be a copy. e.g. %reg1030:6<def> = VMOVD %reg1026, ...
|
// A re-def may be a copy. e.g. %reg1030:6<def> = VMOVD %reg1026, ...
|
||||||
if (PartReDef && mi->isCopyLike())
|
if (PartReDef && mi->isCopyLike())
|
||||||
OldValNo->setCopy(&*mi);
|
OldValNo->setCopy(&*mi);
|
||||||
|
|
||||||
// Add the new live interval which replaces the range for the input copy.
|
// Add the new live interval which replaces the range for the input copy.
|
||||||
LiveRange LR(DefIndex, RedefIndex, ValNo);
|
LiveRange LR(DefIndex, RedefIndex, ValNo);
|
||||||
DEBUG(dbgs() << " replace range with " << LR);
|
DEBUG(dbgs() << " replace range with " << LR);
|
||||||
@ -481,7 +481,7 @@ void LiveIntervals::handleVirtualRegisterDef(MachineBasicBlock *mbb,
|
|||||||
if (mi->isCopyLike())
|
if (mi->isCopyLike())
|
||||||
CopyMI = mi;
|
CopyMI = mi;
|
||||||
ValNo = interval.getNextValue(defIndex, CopyMI, true, VNInfoAllocator);
|
ValNo = interval.getNextValue(defIndex, CopyMI, true, VNInfoAllocator);
|
||||||
|
|
||||||
SlotIndex killIndex = getMBBEndIdx(mbb);
|
SlotIndex killIndex = getMBBEndIdx(mbb);
|
||||||
LiveRange LR(defIndex, killIndex, ValNo);
|
LiveRange LR(defIndex, killIndex, ValNo);
|
||||||
interval.addRange(LR);
|
interval.addRange(LR);
|
||||||
@ -558,10 +558,10 @@ void LiveIntervals::handlePhysicalRegisterDef(MachineBasicBlock *MBB,
|
|||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
baseIndex = baseIndex.getNextIndex();
|
baseIndex = baseIndex.getNextIndex();
|
||||||
}
|
}
|
||||||
|
|
||||||
// The only case we should have a dead physreg here without a killing or
|
// The only case we should have a dead physreg here without a killing or
|
||||||
// instruction where we know it's dead is if it is live-in to the function
|
// instruction where we know it's dead is if it is live-in to the function
|
||||||
// and never used. Another possible case is the implicit use of the
|
// and never used. Another possible case is the implicit use of the
|
||||||
@ -685,7 +685,7 @@ void LiveIntervals::handleLiveInRegister(MachineBasicBlock *MBB,
|
|||||||
/// registers. for some ordering of the machine instructions [1,N] a
|
/// registers. for some ordering of the machine instructions [1,N] a
|
||||||
/// live interval is an interval [i, j) where 1 <= i <= j < N for
|
/// live interval is an interval [i, j) where 1 <= i <= j < N for
|
||||||
/// which a variable is live
|
/// which a variable is live
|
||||||
void LiveIntervals::computeIntervals() {
|
void LiveIntervals::computeIntervals() {
|
||||||
DEBUG(dbgs() << "********** COMPUTING LIVE INTERVALS **********\n"
|
DEBUG(dbgs() << "********** COMPUTING LIVE INTERVALS **********\n"
|
||||||
<< "********** Function: "
|
<< "********** Function: "
|
||||||
<< ((Value*)mf_->getFunction())->getName() << '\n');
|
<< ((Value*)mf_->getFunction())->getName() << '\n');
|
||||||
@ -712,11 +712,11 @@ void LiveIntervals::computeIntervals() {
|
|||||||
handleLiveInRegister(MBB, MIIndex, getOrCreateInterval(*AS),
|
handleLiveInRegister(MBB, MIIndex, getOrCreateInterval(*AS),
|
||||||
true);
|
true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Skip over empty initial indices.
|
// Skip over empty initial indices.
|
||||||
if (getInstructionFromIndex(MIIndex) == 0)
|
if (getInstructionFromIndex(MIIndex) == 0)
|
||||||
MIIndex = indexes_->getNextNonNullIndex(MIIndex);
|
MIIndex = indexes_->getNextNonNullIndex(MIIndex);
|
||||||
|
|
||||||
for (MachineBasicBlock::iterator MI = MBB->begin(), miEnd = MBB->end();
|
for (MachineBasicBlock::iterator MI = MBB->begin(), miEnd = MBB->end();
|
||||||
MI != miEnd; ++MI) {
|
MI != miEnd; ++MI) {
|
||||||
DEBUG(dbgs() << MIIndex << "\t" << *MI);
|
DEBUG(dbgs() << MIIndex << "\t" << *MI);
|
||||||
@ -735,7 +735,7 @@ void LiveIntervals::computeIntervals() {
|
|||||||
else if (MO.isUndef())
|
else if (MO.isUndef())
|
||||||
UndefUses.push_back(MO.getReg());
|
UndefUses.push_back(MO.getReg());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Move to the next instr slot.
|
// Move to the next instr slot.
|
||||||
MIIndex = indexes_->getNextNonNullIndex(MIIndex);
|
MIIndex = indexes_->getNextNonNullIndex(MIIndex);
|
||||||
}
|
}
|
||||||
@ -780,7 +780,7 @@ unsigned LiveIntervals::getReMatImplicitUse(const LiveInterval &li,
|
|||||||
unsigned Reg = MO.getReg();
|
unsigned Reg = MO.getReg();
|
||||||
if (Reg == 0 || Reg == li.reg)
|
if (Reg == 0 || Reg == li.reg)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (TargetRegisterInfo::isPhysicalRegister(Reg) &&
|
if (TargetRegisterInfo::isPhysicalRegister(Reg) &&
|
||||||
!allocatableRegs_[Reg])
|
!allocatableRegs_[Reg])
|
||||||
continue;
|
continue;
|
||||||
@ -799,7 +799,7 @@ unsigned LiveIntervals::getReMatImplicitUse(const LiveInterval &li,
|
|||||||
/// which reaches the given instruction also reaches the specified use index.
|
/// which reaches the given instruction also reaches the specified use index.
|
||||||
bool LiveIntervals::isValNoAvailableAt(const LiveInterval &li, MachineInstr *MI,
|
bool LiveIntervals::isValNoAvailableAt(const LiveInterval &li, MachineInstr *MI,
|
||||||
SlotIndex UseIdx) const {
|
SlotIndex UseIdx) const {
|
||||||
SlotIndex Index = getInstructionIndex(MI);
|
SlotIndex Index = getInstructionIndex(MI);
|
||||||
VNInfo *ValNo = li.FindLiveRangeContaining(Index)->valno;
|
VNInfo *ValNo = li.FindLiveRangeContaining(Index)->valno;
|
||||||
LiveInterval::const_iterator UI = li.FindLiveRangeContaining(UseIdx);
|
LiveInterval::const_iterator UI = li.FindLiveRangeContaining(UseIdx);
|
||||||
return UI != li.end() && UI->valno == ValNo;
|
return UI != li.end() && UI->valno == ValNo;
|
||||||
@ -904,7 +904,7 @@ static bool FilterFoldedOps(MachineInstr *MI,
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// tryFoldMemoryOperand - Attempts to fold either a spill / restore from
|
/// tryFoldMemoryOperand - Attempts to fold either a spill / restore from
|
||||||
/// slot / to reg or any rematerialized load into ith operand of specified
|
/// slot / to reg or any rematerialized load into ith operand of specified
|
||||||
@ -1024,7 +1024,7 @@ void LiveIntervals::rewriteImplicitOps(const LiveInterval &li,
|
|||||||
/// for addIntervalsForSpills to rewrite uses / defs for the given live range.
|
/// for addIntervalsForSpills to rewrite uses / defs for the given live range.
|
||||||
bool LiveIntervals::
|
bool LiveIntervals::
|
||||||
rewriteInstructionForSpills(const LiveInterval &li, const VNInfo *VNI,
|
rewriteInstructionForSpills(const LiveInterval &li, const VNInfo *VNI,
|
||||||
bool TrySplit, SlotIndex index, SlotIndex end,
|
bool TrySplit, SlotIndex index, SlotIndex end,
|
||||||
MachineInstr *MI,
|
MachineInstr *MI,
|
||||||
MachineInstr *ReMatOrigDefMI, MachineInstr *ReMatDefMI,
|
MachineInstr *ReMatOrigDefMI, MachineInstr *ReMatDefMI,
|
||||||
unsigned Slot, int LdSlot,
|
unsigned Slot, int LdSlot,
|
||||||
@ -1083,7 +1083,7 @@ rewriteInstructionForSpills(const LiveInterval &li, const VNInfo *VNI,
|
|||||||
// keep the src/dst regs pinned.
|
// keep the src/dst regs pinned.
|
||||||
//
|
//
|
||||||
// Keep track of whether we replace a use and/or def so that we can
|
// Keep track of whether we replace a use and/or def so that we can
|
||||||
// create the spill interval with the appropriate range.
|
// create the spill interval with the appropriate range.
|
||||||
SmallVector<unsigned, 2> Ops;
|
SmallVector<unsigned, 2> Ops;
|
||||||
tie(HasUse, HasDef) = MI->readsWritesVirtualRegister(Reg, &Ops);
|
tie(HasUse, HasDef) = MI->readsWritesVirtualRegister(Reg, &Ops);
|
||||||
|
|
||||||
@ -1145,7 +1145,7 @@ rewriteInstructionForSpills(const LiveInterval &li, const VNInfo *VNI,
|
|||||||
if (mopj.isImplicit())
|
if (mopj.isImplicit())
|
||||||
rewriteImplicitOps(li, MI, NewVReg, vrm);
|
rewriteImplicitOps(li, MI, NewVReg, vrm);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (CreatedNewVReg) {
|
if (CreatedNewVReg) {
|
||||||
if (DefIsReMat) {
|
if (DefIsReMat) {
|
||||||
vrm.setVirtIsReMaterialized(NewVReg, ReMatDefMI);
|
vrm.setVirtIsReMaterialized(NewVReg, ReMatDefMI);
|
||||||
@ -1685,7 +1685,7 @@ addIntervalsForSpills(const LiveInterval &li,
|
|||||||
if (NeedStackSlot && vrm.getPreSplitReg(li.reg) == 0) {
|
if (NeedStackSlot && vrm.getPreSplitReg(li.reg) == 0) {
|
||||||
if (vrm.getStackSlot(li.reg) == VirtRegMap::NO_STACK_SLOT)
|
if (vrm.getStackSlot(li.reg) == VirtRegMap::NO_STACK_SLOT)
|
||||||
Slot = vrm.assignVirt2StackSlot(li.reg);
|
Slot = vrm.assignVirt2StackSlot(li.reg);
|
||||||
|
|
||||||
// This case only occurs when the prealloc splitter has already assigned
|
// This case only occurs when the prealloc splitter has already assigned
|
||||||
// a stack slot to this vreg.
|
// a stack slot to this vreg.
|
||||||
else
|
else
|
||||||
@ -1742,7 +1742,7 @@ addIntervalsForSpills(const LiveInterval &li,
|
|||||||
Ops.push_back(j);
|
Ops.push_back(j);
|
||||||
if (MO.isDef())
|
if (MO.isDef())
|
||||||
continue;
|
continue;
|
||||||
if (isReMat ||
|
if (isReMat ||
|
||||||
(!FoundUse && !alsoFoldARestore(Id, index, VReg,
|
(!FoundUse && !alsoFoldARestore(Id, index, VReg,
|
||||||
RestoreMBBs, RestoreIdxes))) {
|
RestoreMBBs, RestoreIdxes))) {
|
||||||
// MI has two-address uses of the same register. If the use
|
// MI has two-address uses of the same register. If the use
|
||||||
@ -1887,7 +1887,7 @@ bool LiveIntervals::hasAllocatableSuperReg(unsigned Reg) const {
|
|||||||
/// getRepresentativeReg - Find the largest super register of the specified
|
/// getRepresentativeReg - Find the largest super register of the specified
|
||||||
/// physical register.
|
/// physical register.
|
||||||
unsigned LiveIntervals::getRepresentativeReg(unsigned Reg) const {
|
unsigned LiveIntervals::getRepresentativeReg(unsigned Reg) const {
|
||||||
// Find the largest super-register that is allocatable.
|
// Find the largest super-register that is allocatable.
|
||||||
unsigned BestReg = Reg;
|
unsigned BestReg = Reg;
|
||||||
for (const unsigned* AS = tri_->getSuperRegisters(Reg); *AS; ++AS) {
|
for (const unsigned* AS = tri_->getSuperRegisters(Reg); *AS; ++AS) {
|
||||||
unsigned SuperReg = *AS;
|
unsigned SuperReg = *AS;
|
||||||
@ -2001,7 +2001,7 @@ LiveRange LiveIntervals::addLiveRangeToEndOfBlock(unsigned reg,
|
|||||||
SlotIndex(getInstructionIndex(startInst).getDefIndex()),
|
SlotIndex(getInstructionIndex(startInst).getDefIndex()),
|
||||||
getMBBEndIdx(startInst->getParent()), VN);
|
getMBBEndIdx(startInst->getParent()), VN);
|
||||||
Interval.addRange(LR);
|
Interval.addRange(LR);
|
||||||
|
|
||||||
return LR;
|
return LR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user