summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2008-07-30 17:42:47 +0000
committerOwen Anderson <resistor@mac.com>2008-07-30 17:42:47 +0000
commit7b5f535590b8c87f1c2ffa8b497ca31c7f82d317 (patch)
tree5eb4c40b3ab1050cf1825161ec39916d6276e84b /llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
parenta950422221fc33355b9379b616ed6c35af4aa9c5 (diff)
downloadbcm5719-llvm-7b5f535590b8c87f1c2ffa8b497ca31c7f82d317.tar.gz
bcm5719-llvm-7b5f535590b8c87f1c2ffa8b497ca31c7f82d317.zip
Value numbers whose def index is a special sentinel value should not be remapped.
llvm-svn: 54218
Diffstat (limited to 'llvm/lib/CodeGen/LiveIntervalAnalysis.cpp')
-rw-r--r--llvm/lib/CodeGen/LiveIntervalAnalysis.cpp24
1 files changed, 13 insertions, 11 deletions
diff --git a/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp b/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
index b557b703ccb..fba44166662 100644
--- a/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
+++ b/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
@@ -176,19 +176,22 @@ void LiveIntervals::computeNumbering() {
// Remap the VNInfo def index, which works the same as the
// start indices above.
VNInfo* vni = LI->valno;
- index = vni->def / InstrSlots::NUM;
- offset = vni->def % InstrSlots::NUM;
- if (offset == InstrSlots::LOAD) {
- std::vector<IdxMBBPair>::const_iterator I =
+
+ // VN's with special sentinel defs don't need to be remapped.
+ if (vni->def != ~0U && vni->def != ~1U) {
+ index = vni->def / InstrSlots::NUM;
+ offset = vni->def % InstrSlots::NUM;
+ if (offset == InstrSlots::LOAD) {
+ std::vector<IdxMBBPair>::const_iterator I =
std::lower_bound(OldI2MBB.begin(), OldI2MBB.end(), vni->def);
- // Take the pair containing the index
- std::vector<IdxMBBPair>::const_iterator J =
+ // Take the pair containing the index
+ std::vector<IdxMBBPair>::const_iterator J =
(I == OldI2MBB.end() && OldI2MBB.size()>0) ? (I-1): I;
- vni->def = getMBBStartIdx(J->second);
-
- } else {
- vni->def = mi2iMap_[OldI2MI[index]] + offset;
+ vni->def = getMBBStartIdx(J->second);
+ } else {
+ vni->def = mi2iMap_[OldI2MI[index]] + offset;
+ }
}
// Remap the VNInfo kill indices, which works the same as
@@ -207,7 +210,6 @@ void LiveIntervals::computeNumbering() {
vni->kills[i] = getMBBEndIdx(I->second) + 1;
} else {
unsigned idx = index;
- while (!OldI2MI[index]) ++index;
while (index < OldI2MI.size() && !OldI2MI[index]) ++index;
if (index != OldI2MI.size())
OpenPOWER on IntegriCloud