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:
Jakob Stoklund Olesen 2010-08-12 20:01:23 +00:00
parent e1f543fbb3
commit 1b2932024f
4 changed files with 65 additions and 65 deletions

View File

@ -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 {

View File

@ -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);

View File

@ -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;
} }

View File

@ -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;
} }