2003-08-27 10:42:58 +08:00
|
|
|
//===- SchedGraphCommon.cpp - Scheduling Graphs Base Class- ---------------===//
|
2003-10-21 03:43:21 +08:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file was developed by the LLVM research group and is distributed under
|
|
|
|
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2003-08-27 10:42:58 +08:00
|
|
|
//
|
|
|
|
// Scheduling graph base class that contains common information for SchedGraph
|
|
|
|
// and ModuloSchedGraph scheduling graphs.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2003-08-26 06:42:20 +08:00
|
|
|
#include "llvm/CodeGen/SchedGraphCommon.h"
|
2004-09-02 06:55:40 +08:00
|
|
|
#include "llvm/ADT/STLExtras.h"
|
2004-09-28 22:42:44 +08:00
|
|
|
#include <algorithm>
|
2004-07-04 20:19:56 +08:00
|
|
|
#include <iostream>
|
2003-08-26 06:42:20 +08:00
|
|
|
|
2003-11-12 06:41:34 +08:00
|
|
|
namespace llvm {
|
|
|
|
|
2003-08-26 06:42:20 +08:00
|
|
|
class SchedGraphCommon;
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
//
|
2003-08-26 06:42:20 +08:00
|
|
|
// class SchedGraphEdge
|
|
|
|
//
|
|
|
|
SchedGraphEdge::SchedGraphEdge(SchedGraphNodeCommon* _src,
|
|
|
|
SchedGraphNodeCommon* _sink,
|
|
|
|
SchedGraphEdgeDepType _depType,
|
|
|
|
unsigned int _depOrderType,
|
|
|
|
int _minDelay)
|
2003-08-27 10:42:58 +08:00
|
|
|
: src(_src), sink(_sink), depType(_depType), depOrderType(_depOrderType),
|
|
|
|
minDelay((_minDelay >= 0)? _minDelay : _src->getLatency()), val(NULL) {
|
|
|
|
|
2003-08-26 06:42:20 +08:00
|
|
|
iteDiff=0;
|
|
|
|
assert(src != sink && "Self-loop in scheduling graph!");
|
|
|
|
src->addOutEdge(this);
|
|
|
|
sink->addInEdge(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
SchedGraphEdge::SchedGraphEdge(SchedGraphNodeCommon* _src,
|
|
|
|
SchedGraphNodeCommon* _sink,
|
|
|
|
const Value* _val,
|
|
|
|
unsigned int _depOrderType,
|
|
|
|
int _minDelay)
|
2003-08-27 10:42:58 +08:00
|
|
|
: src(_src), sink(_sink), depType(ValueDep), depOrderType(_depOrderType),
|
|
|
|
minDelay((_minDelay >= 0)? _minDelay : _src->getLatency()), val(_val) {
|
2003-08-26 06:42:20 +08:00
|
|
|
iteDiff=0;
|
|
|
|
assert(src != sink && "Self-loop in scheduling graph!");
|
|
|
|
src->addOutEdge(this);
|
|
|
|
sink->addInEdge(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
SchedGraphEdge::SchedGraphEdge(SchedGraphNodeCommon* _src,
|
|
|
|
SchedGraphNodeCommon* _sink,
|
|
|
|
unsigned int _regNum,
|
|
|
|
unsigned int _depOrderType,
|
|
|
|
int _minDelay)
|
2003-08-27 10:42:58 +08:00
|
|
|
: src(_src), sink(_sink), depType(MachineRegister),
|
2003-08-26 06:42:20 +08:00
|
|
|
depOrderType(_depOrderType),
|
|
|
|
minDelay((_minDelay >= 0)? _minDelay : _src->getLatency()),
|
2003-08-27 10:42:58 +08:00
|
|
|
machineRegNum(_regNum) {
|
2003-08-26 06:42:20 +08:00
|
|
|
iteDiff=0;
|
|
|
|
assert(src != sink && "Self-loop in scheduling graph!");
|
|
|
|
src->addOutEdge(this);
|
|
|
|
sink->addInEdge(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
SchedGraphEdge::SchedGraphEdge(SchedGraphNodeCommon* _src,
|
|
|
|
SchedGraphNodeCommon* _sink,
|
|
|
|
ResourceId _resourceId,
|
|
|
|
int _minDelay)
|
2003-08-27 10:42:58 +08:00
|
|
|
: src(_src), sink(_sink), depType(MachineResource), depOrderType(NonDataDep),
|
2003-08-26 06:42:20 +08:00
|
|
|
minDelay((_minDelay >= 0)? _minDelay : _src->getLatency()),
|
2003-08-27 10:42:58 +08:00
|
|
|
resourceId(_resourceId) {
|
2003-08-26 06:42:20 +08:00
|
|
|
iteDiff=0;
|
|
|
|
assert(src != sink && "Self-loop in scheduling graph!");
|
|
|
|
src->addOutEdge(this);
|
|
|
|
sink->addInEdge(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphEdge::dump(int indent) const {
|
|
|
|
std::cerr << std::string(indent*2, ' ') << *this;
|
2003-08-26 06:42:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*dtor*/
|
|
|
|
SchedGraphNodeCommon::~SchedGraphNodeCommon()
|
|
|
|
{
|
|
|
|
// for each node, delete its out-edges
|
|
|
|
std::for_each(beginOutEdges(), endOutEdges(),
|
|
|
|
deleter<SchedGraphEdge>);
|
|
|
|
}
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphNodeCommon::removeInEdge(const SchedGraphEdge* edge) {
|
2003-08-26 06:42:20 +08:00
|
|
|
assert(edge->getSink() == this);
|
|
|
|
|
|
|
|
for (iterator I = beginInEdges(); I != endInEdges(); ++I)
|
2003-08-27 10:42:58 +08:00
|
|
|
if ((*I) == edge) {
|
|
|
|
inEdges.erase(I);
|
|
|
|
break;
|
|
|
|
}
|
2003-08-26 06:42:20 +08:00
|
|
|
}
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphNodeCommon::removeOutEdge(const SchedGraphEdge* edge) {
|
2003-08-26 06:42:20 +08:00
|
|
|
assert(edge->getSrc() == this);
|
|
|
|
|
|
|
|
for (iterator I = beginOutEdges(); I != endOutEdges(); ++I)
|
2003-08-27 10:42:58 +08:00
|
|
|
if ((*I) == edge) {
|
|
|
|
outEdges.erase(I);
|
|
|
|
break;
|
|
|
|
}
|
2003-08-26 06:42:20 +08:00
|
|
|
}
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphNodeCommon::dump(int indent) const {
|
|
|
|
std::cerr << std::string(indent*2, ' ') << *this;
|
2003-08-26 06:42:20 +08:00
|
|
|
}
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
//class SchedGraphCommon
|
2003-08-26 06:42:20 +08:00
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
SchedGraphCommon::~SchedGraphCommon() {
|
2003-08-26 06:42:20 +08:00
|
|
|
delete graphRoot;
|
|
|
|
delete graphLeaf;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphCommon::eraseIncomingEdges(SchedGraphNodeCommon* node,
|
|
|
|
bool addDummyEdges) {
|
2003-08-26 06:42:20 +08:00
|
|
|
// Delete and disconnect all in-edges for the node
|
|
|
|
for (SchedGraphNodeCommon::iterator I = node->beginInEdges();
|
2003-08-27 10:42:58 +08:00
|
|
|
I != node->endInEdges(); ++I) {
|
|
|
|
SchedGraphNodeCommon* srcNode = (*I)->getSrc();
|
|
|
|
srcNode->removeOutEdge(*I);
|
|
|
|
delete *I;
|
|
|
|
|
|
|
|
if (addDummyEdges && srcNode != getRoot() &&
|
|
|
|
srcNode->beginOutEdges() == srcNode->endOutEdges()) {
|
2003-08-26 06:42:20 +08:00
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
// srcNode has no more out edges, so add an edge to dummy EXIT node
|
|
|
|
assert(node != getLeaf() && "Adding edge that was just removed?");
|
|
|
|
(void) new SchedGraphEdge(srcNode, getLeaf(),
|
|
|
|
SchedGraphEdge::CtrlDep,
|
|
|
|
SchedGraphEdge::NonDataDep, 0);
|
2003-08-26 06:42:20 +08:00
|
|
|
}
|
2003-08-27 10:42:58 +08:00
|
|
|
}
|
2003-08-26 06:42:20 +08:00
|
|
|
|
|
|
|
node->inEdges.clear();
|
|
|
|
}
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphCommon::eraseOutgoingEdges(SchedGraphNodeCommon* node,
|
|
|
|
bool addDummyEdges) {
|
2003-08-26 06:42:20 +08:00
|
|
|
// Delete and disconnect all out-edges for the node
|
|
|
|
for (SchedGraphNodeCommon::iterator I = node->beginOutEdges();
|
2003-08-27 10:42:58 +08:00
|
|
|
I != node->endOutEdges(); ++I) {
|
|
|
|
SchedGraphNodeCommon* sinkNode = (*I)->getSink();
|
|
|
|
sinkNode->removeInEdge(*I);
|
|
|
|
delete *I;
|
|
|
|
|
|
|
|
if (addDummyEdges &&
|
|
|
|
sinkNode != getLeaf() &&
|
|
|
|
sinkNode->beginInEdges() == sinkNode->endInEdges()) {
|
2003-08-26 06:42:20 +08:00
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
//sinkNode has no more in edges, so add an edge from dummy ENTRY node
|
|
|
|
assert(node != getRoot() && "Adding edge that was just removed?");
|
|
|
|
(void) new SchedGraphEdge(getRoot(), sinkNode,
|
|
|
|
SchedGraphEdge::CtrlDep,
|
|
|
|
SchedGraphEdge::NonDataDep, 0);
|
2003-08-26 06:42:20 +08:00
|
|
|
}
|
2003-08-27 10:42:58 +08:00
|
|
|
}
|
2003-08-26 06:42:20 +08:00
|
|
|
|
|
|
|
node->outEdges.clear();
|
|
|
|
}
|
|
|
|
|
2003-08-27 10:42:58 +08:00
|
|
|
void SchedGraphCommon::eraseIncidentEdges(SchedGraphNodeCommon* node,
|
|
|
|
bool addDummyEdges) {
|
2003-08-26 06:42:20 +08:00
|
|
|
this->eraseIncomingEdges(node, addDummyEdges);
|
|
|
|
this->eraseOutgoingEdges(node, addDummyEdges);
|
|
|
|
}
|
|
|
|
|
2003-11-12 06:41:34 +08:00
|
|
|
} // End llvm namespace
|