summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-12-22 21:11:33 +0000
committerDan Gohman <gohman@apple.com>2008-12-22 21:11:33 +0000
commita04542b61ece411470852e5e4a2f063bd67c3371 (patch)
tree501e661d7f84fb785a4b3b995234363703cd6295 /llvm/lib/CodeGen
parenta6fbc282b217c761a5f058180127a7e05b0c5837 (diff)
downloadbcm5719-llvm-a04542b61ece411470852e5e4a2f063bd67c3371.tar.gz
bcm5719-llvm-a04542b61ece411470852e5e4a2f063bd67c3371.zip
Optimize setDepthDirty and setHeightDirty a little, as they showed
up on a profile. llvm-svn: 61344
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/ScheduleDAG.cpp26
1 files changed, 16 insertions, 10 deletions
diff --git a/llvm/lib/CodeGen/ScheduleDAG.cpp b/llvm/lib/CodeGen/ScheduleDAG.cpp
index 3ec538cf2fc..8630cfee7d7 100644
--- a/llvm/lib/CodeGen/ScheduleDAG.cpp
+++ b/llvm/lib/CodeGen/ScheduleDAG.cpp
@@ -119,29 +119,35 @@ void SUnit::removePred(const SDep &D) {
}
void SUnit::setDepthDirty() {
+ if (!isDepthCurrent) return;
SmallVector<SUnit*, 8> WorkList;
WorkList.push_back(this);
- while (!WorkList.empty()) {
+ do {
SUnit *SU = WorkList.pop_back_val();
- if (!SU->isDepthCurrent) continue;
SU->isDepthCurrent = false;
for (SUnit::const_succ_iterator I = SU->Succs.begin(),
- E = SU->Succs.end(); I != E; ++I)
- WorkList.push_back(I->getSUnit());
- }
+ E = SU->Succs.end(); I != E; ++I) {
+ SUnit *SuccSU = I->getSUnit();
+ if (SuccSU->isDepthCurrent)
+ WorkList.push_back(SuccSU);
+ }
+ } while (!WorkList.empty());
}
void SUnit::setHeightDirty() {
+ if (!isHeightCurrent) return;
SmallVector<SUnit*, 8> WorkList;
WorkList.push_back(this);
- while (!WorkList.empty()) {
+ do {
SUnit *SU = WorkList.pop_back_val();
- if (!SU->isHeightCurrent) continue;
SU->isHeightCurrent = false;
for (SUnit::const_pred_iterator I = SU->Preds.begin(),
- E = SU->Preds.end(); I != E; ++I)
- WorkList.push_back(I->getSUnit());
- }
+ E = SU->Preds.end(); I != E; ++I) {
+ SUnit *PredSU = I->getSUnit();
+ if (PredSU->isHeightCurrent)
+ WorkList.push_back(PredSU);
+ }
+ } while (!WorkList.empty());
}
/// setDepthToAtLeast - Update this node's successors to reflect the
OpenPOWER on IntegriCloud