diff options
author | Cameron Zwarich <zwarich@apple.com> | 2013-02-20 22:10:00 +0000 |
---|---|---|
committer | Cameron Zwarich <zwarich@apple.com> | 2013-02-20 22:10:00 +0000 |
commit | caad7e10c1edbd0bff9d54351f174a497998232e (patch) | |
tree | 97a9b200db78b3a1c6dfb142bc56c1da2b5404f9 /llvm/lib/CodeGen/SlotIndexes.cpp | |
parent | 8e7dc068c9237822867fb60f96da1494999de75e (diff) | |
download | llvm-caad7e10c1edbd0bff9d54351f174a497998232e.zip llvm-caad7e10c1edbd0bff9d54351f174a497998232e.tar.gz llvm-caad7e10c1edbd0bff9d54351f174a497998232e.tar.bz2 |
Find anchoring end points for repairIntervalsInRange and repairIndexesInRange
automatically.
llvm-svn: 175673
Diffstat (limited to 'llvm/lib/CodeGen/SlotIndexes.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SlotIndexes.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SlotIndexes.cpp b/llvm/lib/CodeGen/SlotIndexes.cpp index b4e562e..f293794 100644 --- a/llvm/lib/CodeGen/SlotIndexes.cpp +++ b/llvm/lib/CodeGen/SlotIndexes.cpp @@ -146,6 +146,15 @@ void SlotIndexes::renumberIndexes(IndexList::iterator curItr) { void SlotIndexes::repairIndexesInRange(MachineBasicBlock *MBB, MachineBasicBlock::iterator Begin, MachineBasicBlock::iterator End) { + // FIXME: Is this really necessary? The only caller repairIntervalsForRange() + // does the same thing. + // Find anchor points, which are at the beginning/end of blocks or at + // instructions that already have indexes. + while (Begin != MBB->begin() && !hasIndex(Begin)) + --Begin; + while (End != MBB->end() && !hasIndex(End)) + ++End; + bool includeStart = (Begin == MBB->begin()); SlotIndex startIdx; if (includeStart) |