aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2008-06-16 07:10:49 +0000
committerOwen Anderson <resistor@mac.com>2008-06-16 07:10:49 +0000
commit355780128986e375c7ac2a75025ac129bb8280bf (patch)
tree512a3abd27f2b83306cb48a65393b87998c5a73e /lib
parent0ad4d9be0310b79e47561abeef39daf322d06760 (diff)
downloadexternal_llvm-355780128986e375c7ac2a75025ac129bb8280bf.zip
external_llvm-355780128986e375c7ac2a75025ac129bb8280bf.tar.gz
external_llvm-355780128986e375c7ac2a75025ac129bb8280bf.tar.bz2
Make indexing empty basic blocks an option for the moment.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52306 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/CodeGen/LiveIntervalAnalysis.cpp30
1 files changed, 21 insertions, 9 deletions
diff --git a/lib/CodeGen/LiveIntervalAnalysis.cpp b/lib/CodeGen/LiveIntervalAnalysis.cpp
index 5bb3cfa..f265e63 100644
--- a/lib/CodeGen/LiveIntervalAnalysis.cpp
+++ b/lib/CodeGen/LiveIntervalAnalysis.cpp
@@ -44,6 +44,8 @@ static cl::opt<bool> SplitAtBB("split-intervals-at-bb",
cl::init(true), cl::Hidden);
static cl::opt<int> SplitLimit("split-limit",
cl::init(-1), cl::Hidden);
+static cl::opt<bool> EmptyBBIndex("empty-bb-index",
+ cl::init(false), cl::Hidden);
STATISTIC(numIntervals, "Number of original intervals");
STATISTIC(numIntervalsAfter, "Number of intervals after coalescing");
@@ -100,15 +102,23 @@ void LiveIntervals::computeNumbering() {
i2miMap_.push_back(I);
MIIndex += InstrSlots::NUM;
}
-
- if (StartIdx == MIIndex) {
- // Empty MBB
- MIIndex += InstrSlots::NUM;
- i2miMap_.push_back(0);
- }
+
// Set the MBB2IdxMap entry for this MBB.
- MBB2IdxMap[MBB->getNumber()] = std::make_pair(StartIdx, MIIndex - 1);
- Idx2MBBMap.push_back(std::make_pair(StartIdx, MBB));
+ if (!EmptyBBIndex) {
+ MBB2IdxMap[MBB->getNumber()] = (StartIdx == MIIndex)
+ ? std::make_pair(StartIdx, StartIdx) // Empty MBB
+ : std::make_pair(StartIdx, MIIndex - 1);
+ Idx2MBBMap.push_back(std::make_pair(StartIdx, MBB));
+ } else {
+ if (StartIdx == MIIndex) {
+ // Empty MBB
+ MIIndex += InstrSlots::NUM;
+ i2miMap_.push_back(0);
+ }
+
+ MBB2IdxMap[MBB->getNumber()] = std::make_pair(StartIdx, MIIndex - 1);
+ Idx2MBBMap.push_back(std::make_pair(StartIdx, MBB));
+ }
}
std::sort(Idx2MBBMap.begin(), Idx2MBBMap.end(), Idx2MBBCompare());
@@ -665,7 +675,9 @@ void LiveIntervals::computeIntervals() {
MIIndex += InstrSlots::NUM;
}
- if (MBB->begin() == miEnd) MIIndex += InstrSlots::NUM; // Empty MBB
+ if (EmptyBBIndex) {
+ if (MBB->begin() == miEnd) MIIndex += InstrSlots::NUM; // Empty MBB
+ }
}
}