diff options
author | Chris Lattner <sabre@nondot.org> | 2004-06-28 00:32:33 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-06-28 00:32:33 +0000 |
commit | b88fb055c45193bad7550f22f6879a1e581091de (patch) | |
tree | e55711d22627b7503cb6048ce8a12dba6f99b92e /lib/Analysis/DataStructure/DependenceGraph.cpp | |
parent | 1ffa817210bb4608b76134fc09894fa51176c0fa (diff) |
Move DependenceGraph.* to lib/Analysis/DataStructure
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14452 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/DataStructure/DependenceGraph.cpp')
-rw-r--r-- | lib/Analysis/DataStructure/DependenceGraph.cpp | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/lib/Analysis/DataStructure/DependenceGraph.cpp b/lib/Analysis/DataStructure/DependenceGraph.cpp new file mode 100644 index 0000000000..de3f45a447 --- /dev/null +++ b/lib/Analysis/DataStructure/DependenceGraph.cpp @@ -0,0 +1,87 @@ +//===- DependenceGraph.cpp - Dependence graph for a function ----*- C++ -*-===// +// +// 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. +// +//===----------------------------------------------------------------------===// +// +// This file implements an explicit representation for the dependence graph +// of a function, with one node per instruction and one edge per dependence. +// Dependences include both data and control dependences. +// +// Each dep. graph node (class DepGraphNode) keeps lists of incoming and +// outgoing dependence edges. +// +// Each dep. graph edge (class Dependence) keeps a pointer to one end-point +// of the dependence. This saves space and is important because dep. graphs +// can grow quickly. It works just fine because the standard idiom is to +// start with a known node and enumerate the dependences to or from that node. +//===----------------------------------------------------------------------===// + + +#include "DependenceGraph.h" +#include "llvm/Function.h" + +namespace llvm { + +//---------------------------------------------------------------------------- +// class Dependence: +// +// A representation of a simple (non-loop-related) dependence +//---------------------------------------------------------------------------- + +void Dependence::print(std::ostream &O) const +{ + assert(depType != NoDependence && "This dependence should never be created!"); + switch (depType) { + case TrueDependence: O << "TRUE dependence"; break; + case AntiDependence: O << "ANTI dependence"; break; + case OutputDependence: O << "OUTPUT dependence"; break; + case ControlDependence: O << "CONTROL dependence"; break; + default: assert(0 && "Invalid dependence type"); break; + } +} + + +//---------------------------------------------------------------------------- +// class DepGraphNode +//---------------------------------------------------------------------------- + +void DepGraphNode::print(std::ostream &O) const +{ + const_iterator DI = outDepBegin(), DE = outDepEnd(); + + O << "\nDeps. from instr:" << getInstr(); + + for ( ; DI != DE; ++DI) + { + O << "\t"; + DI->print(O); + O << " to instruction:"; + O << DI->getSink()->getInstr(); + } +} + +//---------------------------------------------------------------------------- +// class DependenceGraph +//---------------------------------------------------------------------------- + +DependenceGraph::~DependenceGraph() +{ + // Free all DepGraphNode objects created for this graph + for (map_iterator I = depNodeMap.begin(), E = depNodeMap.end(); I != E; ++I) + delete I->second; +} + +void DependenceGraph::print(const Function& func, std::ostream &O) const +{ + O << "DEPENDENCE GRAPH FOR FUNCTION " << func.getName() << ":\n"; + for (Function::const_iterator BB=func.begin(), FE=func.end(); BB != FE; ++BB) + for (BasicBlock::const_iterator II=BB->begin(), IE=BB->end(); II !=IE; ++II) + if (const DepGraphNode* dgNode = this->getNode(*II)) + dgNode->print(O); +} + +} // End llvm namespace |