diff options
author | Tanya Lattner <tonic@nondot.org> | 2005-02-16 04:00:59 +0000 |
---|---|---|
committer | Tanya Lattner <tonic@nondot.org> | 2005-02-16 04:00:59 +0000 |
commit | db1680b2be5137ad6afa93354ac872cbea3c771c (patch) | |
tree | c3a715b3de277f7dfbab39ac1fdd4ae646f1f053 /lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp | |
parent | 2ee51cbeb8f83f0b04d9611535151c801bbe3d4b (diff) |
Fixed node deletion bug.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20207 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp')
-rw-r--r-- | lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp b/lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp index 376cbfdf09..9ac38b4dd3 100644 --- a/lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp +++ b/lib/Target/SparcV9/ModuloScheduling/MSchedGraph.cpp @@ -112,11 +112,12 @@ void MSchedGraph::addNode(const MachineInstr *MI, void MSchedGraph::deleteNode(MSchedGraphNode *node) { //Delete the edge to this node from all predecessors - for(MSchedGraphNode::pred_iterator P = node->pred_begin(), PE = node->pred_end(); - P != PE; ++P) { - (*P)->deleteSuccessor(node); + while(node->pred_size() > 0) { + //DEBUG(std::cerr << "Delete edge from: " << **P << " to " << *node << "\n"); + MSchedGraphNode *pred = *(node->pred_begin()); + pred->deleteSuccessor(node); } - + //Remove this node from the graph GraphMap.erase(node->getInst()); |