diff options
author | Owen Anderson <resistor@mac.com> | 2008-06-16 07:10:49 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2008-06-16 07:10:49 +0000 |
commit | 355780128986e375c7ac2a75025ac129bb8280bf (patch) | |
tree | 512a3abd27f2b83306cb48a65393b87998c5a73e /lib | |
parent | 0ad4d9be0310b79e47561abeef39daf322d06760 (diff) | |
download | external_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.cpp | 30 |
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 + } } } |