OLD | NEW |
---|---|
1 //===- subzero/src/IceOperand.cpp - High-level operand implementation -----===// | 1 //===- subzero/src/IceOperand.cpp - High-level operand implementation -----===// |
2 // | 2 // |
3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
4 // | 4 // |
5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
7 // | 7 // |
8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
9 // | 9 // |
10 // This file implements the Operand class and its target-independent | 10 // This file implements the Operand class and its target-independent |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
115 if (I2->second <= I1->first) { | 115 if (I2->second <= I1->first) { |
116 ++I2; | 116 ++I2; |
117 continue; | 117 continue; |
118 } | 118 } |
119 return true; | 119 return true; |
120 } | 120 } |
121 return false; | 121 return false; |
122 } | 122 } |
123 | 123 |
124 bool LiveRange::overlaps(InstNumberT OtherBegin) const { | 124 bool LiveRange::overlaps(InstNumberT OtherBegin) const { |
125 for (RangeType::const_iterator I = Range.begin(), E = Range.end(); I != E; | |
126 ++I) { | |
127 if (OtherBegin >= I->second) | |
jvoung (off chromium)
2014/09/30 23:38:44
So the issue was that the ranges are sorted the ot
Jim Stichnoth
2014/09/30 23:49:16
No, the segments of the live range must be sorted,
| |
128 return false; | |
129 if (I->first <= OtherBegin) | |
130 return true; | |
131 } | |
132 return false; | |
133 #if 0 // An equivalent but less inefficient implementation: | |
125 LiveRange Temp; | 134 LiveRange Temp; |
126 Temp.addSegment(OtherBegin, OtherBegin + 1); | 135 Temp.addSegment(OtherBegin, OtherBegin + 1); |
127 return overlaps(Temp); | 136 return overlaps(Temp); |
137 #endif | |
128 } | 138 } |
129 | 139 |
130 // Returns true if the live range contains the given instruction | 140 // Returns true if the live range contains the given instruction |
131 // number. This is only used for validating the live range | 141 // number. This is only used for validating the live range |
132 // calculation. | 142 // calculation. |
133 bool LiveRange::containsValue(InstNumberT Value) const { | 143 bool LiveRange::containsValue(InstNumberT Value) const { |
134 for (RangeType::const_iterator I = Range.begin(), E = Range.end(); I != E; | 144 for (RangeType::const_iterator I = Range.begin(), E = Range.end(); I != E; |
135 ++I) { | 145 ++I) { |
136 if (I->first <= Value && Value <= I->second) | 146 if (I->first <= Value && Value <= I->second) |
137 return true; | 147 return true; |
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
252 case MDS_MultiDefMultiBlock: | 262 case MDS_MultiDefMultiBlock: |
253 case MDS_MultiDefSingleBlock: | 263 case MDS_MultiDefSingleBlock: |
254 return NULL; | 264 return NULL; |
255 case MDS_SingleDef: | 265 case MDS_SingleDef: |
256 assert(!Definitions.empty()); | 266 assert(!Definitions.empty()); |
257 return Definitions[0]; | 267 return Definitions[0]; |
258 } | 268 } |
259 } | 269 } |
260 | 270 |
261 void VariablesMetadata::init() { | 271 void VariablesMetadata::init() { |
272 static TimerIdT IDvmetadata = GlobalContext::getTimerID("vmetadata"); | |
273 TimerMarker T(IDvmetadata, Func->getContext()); | |
262 Metadata.clear(); | 274 Metadata.clear(); |
263 Metadata.resize(Func->getNumVariables()); | 275 Metadata.resize(Func->getNumVariables()); |
264 | 276 |
265 // Mark implicit args as being used in the entry node. | 277 // Mark implicit args as being used in the entry node. |
266 const VarList &ImplicitArgList = Func->getImplicitArgs(); | 278 const VarList &ImplicitArgList = Func->getImplicitArgs(); |
267 for (VarList::const_iterator I = ImplicitArgList.begin(), | 279 for (VarList::const_iterator I = ImplicitArgList.begin(), |
268 E = ImplicitArgList.end(); | 280 E = ImplicitArgList.end(); |
269 I != E; ++I) { | 281 I != E; ++I) { |
270 const Variable *Var = *I; | 282 const Variable *Var = *I; |
271 const Inst *NoInst = NULL; | 283 const Inst *NoInst = NULL; |
(...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
436 | 448 |
437 Ostream &operator<<(Ostream &Str, const RegWeight &W) { | 449 Ostream &operator<<(Ostream &Str, const RegWeight &W) { |
438 if (W.getWeight() == RegWeight::Inf) | 450 if (W.getWeight() == RegWeight::Inf) |
439 Str << "Inf"; | 451 Str << "Inf"; |
440 else | 452 else |
441 Str << W.getWeight(); | 453 Str << W.getWeight(); |
442 return Str; | 454 return Str; |
443 } | 455 } |
444 | 456 |
445 } // end of namespace Ice | 457 } // end of namespace Ice |
OLD | NEW |