summaryrefslogtreecommitdiff
path: root/include/llvm/CodeGen/SlotIndexes.h
diff options
context:
space:
mode:
authorCameron Zwarich <zwarich@apple.com>2013-02-12 03:49:22 +0000
committerCameron Zwarich <zwarich@apple.com>2013-02-12 03:49:22 +0000
commit1fc88933e6ffbbb2b876cf67210f1a238f2af16d (patch)
tree9b50851ab0d1aa4375930237cd7ce5ca69ac808d /include/llvm/CodeGen/SlotIndexes.h
parentdd58fa4869f9bff909720aaa428487a20fab1391 (diff)
downloadllvm-1fc88933e6ffbbb2b876cf67210f1a238f2af16d.tar.gz
llvm-1fc88933e6ffbbb2b876cf67210f1a238f2af16d.tar.bz2
llvm-1fc88933e6ffbbb2b876cf67210f1a238f2af16d.tar.xz
Renumber SlotIndexes locally when a new block is inserted.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@174937 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/CodeGen/SlotIndexes.h')
-rw-r--r--include/llvm/CodeGen/SlotIndexes.h9
1 files changed, 4 insertions, 5 deletions
diff --git a/include/llvm/CodeGen/SlotIndexes.h b/include/llvm/CodeGen/SlotIndexes.h
index d4e8c20a31..76c1cea252 100644
--- a/include/llvm/CodeGen/SlotIndexes.h
+++ b/include/llvm/CodeGen/SlotIndexes.h
@@ -605,14 +605,15 @@ namespace llvm {
IndexListEntry *startEntry = 0;
IndexListEntry *endEntry = 0;
+ IndexList::iterator newItr;
if (nextMBB == mbb->getParent()->end()) {
startEntry = &indexList.back();
endEntry = createEntry(0, 0);
- indexList.insertAfter(startEntry, endEntry);
+ newItr = indexList.insertAfter(startEntry, endEntry);
} else {
startEntry = createEntry(0, 0);
endEntry = getMBBStartIdx(nextMBB).listEntry();
- indexList.insert(endEntry, startEntry);
+ newItr = indexList.insert(endEntry, startEntry);
}
SlotIndex startIdx(startEntry, SlotIndex::Slot_Block);
@@ -629,9 +630,7 @@ namespace llvm {
MBBRanges.push_back(std::make_pair(startIdx, endIdx));
idx2MBBMap.push_back(IdxMBBPair(startIdx, mbb));
- // FIXME: Renumber locally instead of renumbering the whole function every
- // time a new block is inserted.
- renumberIndexes();
+ renumberIndexes(newItr);
std::sort(idx2MBBMap.begin(), idx2MBBMap.end(), Idx2MBBCompare());
}