| //===-- SchedGraph.h - Scheduling Graph -------------------------*- 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 is a scheduling graph based on SSA graph plus extra dependence edges |
| // capturing dependences due to machine resources (machine registers, CC |
| // registers, and any others). |
| // |
| // This graph tries to leverage the SSA graph as much as possible, but captures |
| // the extra dependences through a common interface. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_CODEGEN_SCHEDGRAPH_H |
| #define LLVM_CODEGEN_SCHEDGRAPH_H |
| |
| #include "llvm/CodeGen/SchedGraphCommon.h" |
| #include "llvm/CodeGen/MachineInstr.h" |
| #include "llvm/Transforms/Scalar.h" |
| #include "llvm/ADT/hash_map" |
| #include "llvm/ADT/GraphTraits.h" |
| |
| namespace llvm { |
| |
| class RegToRefVecMap; |
| class ValueToDefVecMap; |
| class RefVec; |
| |
| class SchedGraphNode : public SchedGraphNodeCommon { |
| |
| MachineBasicBlock *MBB; |
| const MachineInstr *MI; |
| |
| |
| SchedGraphNode(unsigned nodeId, MachineBasicBlock *mbb, int indexInBB, |
| const TargetMachine& Target); |
| ~SchedGraphNode(); |
| |
| friend class SchedGraph; // give access for ctor and dtor |
| friend class SchedGraphEdge; // give access for adding edges |
| |
| public: |
| |
| // Accessor methods |
| const MachineInstr* getMachineInstr() const { return MI; } |
| const MachineOpCode getOpcode() const { return MI->getOpcode(); } |
| bool isDummyNode() const { return (MI == NULL); } |
| MachineBasicBlock &getMachineBasicBlock() const { return *MBB; } |
| |
| void print(std::ostream &os) const; |
| }; |
| |
| class SchedGraph : public SchedGraphCommon { |
| MachineBasicBlock &MBB; |
| hash_map<const MachineInstr*, SchedGraphNode*> GraphMap; |
| |
| public: |
| typedef hash_map<const MachineInstr*, SchedGraphNode*>::const_iterator iterator; |
| typedef hash_map<const MachineInstr*, SchedGraphNode*>::const_iterator const_iterator; |
| |
| MachineBasicBlock& getBasicBlock() const{return MBB;} |
| const unsigned int getNumNodes() const { return GraphMap.size()+2; } |
| SchedGraphNode* getGraphNodeForInstr(const MachineInstr* MI) const { |
| const_iterator onePair = find(MI); |
| return (onePair != end())? onePair->second : NULL; |
| } |
| |
| // Debugging support |
| void dump() const; |
| |
| protected: |
| SchedGraph(MachineBasicBlock& mbb, const TargetMachine& TM); |
| ~SchedGraph(); |
| |
| // Unordered iterators. |
| // Return values is pair<const MachineIntr*,SchedGraphNode*>. |
| // |
| hash_map<const MachineInstr*, SchedGraphNode*>::const_iterator begin() const { |
| return GraphMap.begin(); |
| } |
| hash_map<const MachineInstr*, SchedGraphNode*>::const_iterator end() const { |
| return GraphMap.end(); |
| } |
| |
| unsigned size() { return GraphMap.size(); } |
| iterator find(const MachineInstr *MI) const { return GraphMap.find(MI); } |
| |
| SchedGraphNode *&operator[](const MachineInstr *MI) { |
| return GraphMap[MI]; |
| } |
| |
| private: |
| friend class SchedGraphSet; // give access to ctor |
| |
| inline void noteGraphNodeForInstr (const MachineInstr* minstr, |
| SchedGraphNode* node) { |
| assert((*this)[minstr] == NULL); |
| (*this)[minstr] = node; |
| } |
| |
| // |
| // Graph builder |
| // |
| void buildGraph(const TargetMachine& target); |
| |
| void buildNodesForBB(const TargetMachine& target,MachineBasicBlock &MBB, |
| std::vector<SchedGraphNode*>& memNV, |
| std::vector<SchedGraphNode*>& callNV, |
| RegToRefVecMap& regToRefVecMap, |
| ValueToDefVecMap& valueToDefVecMap); |
| |
| |
| void findDefUseInfoAtInstr(const TargetMachine& target, SchedGraphNode* node, |
| std::vector<SchedGraphNode*>& memNV, |
| std::vector<SchedGraphNode*>& callNV, |
| RegToRefVecMap& regToRefVecMap, |
| ValueToDefVecMap& valueToDefVecMap); |
| |
| void addEdgesForInstruction(const MachineInstr& minstr, |
| const ValueToDefVecMap& valueToDefVecMap, |
| const TargetMachine& target); |
| |
| void addCDEdges(const TerminatorInst* term, const TargetMachine& target); |
| |
| void addMemEdges(const std::vector<SchedGraphNode*>& memNod, |
| const TargetMachine& target); |
| |
| void addCallCCEdges(const std::vector<SchedGraphNode*>& memNod, |
| MachineBasicBlock& bbMvec, |
| const TargetMachine& target); |
| |
| void addCallDepEdges(const std::vector<SchedGraphNode*>& callNV, |
| const TargetMachine& target); |
| |
| void addMachineRegEdges(RegToRefVecMap& regToRefVecMap, |
| const TargetMachine& target); |
| |
| void addEdgesForValue(SchedGraphNode* refNode, const RefVec& defVec, |
| const Value* defValue, bool refNodeIsDef, |
| bool refNodeIsDefAndUse, |
| const TargetMachine& target); |
| |
| void addDummyEdges(); |
| |
| }; |
| |
| |
| |
| class SchedGraphSet { |
| const Function* function; |
| std::vector<SchedGraph*> Graphs; |
| |
| // Graph builder |
| void buildGraphsForMethod(const Function *F, const TargetMachine& target); |
| |
| inline void addGraph(SchedGraph* graph) { |
| assert(graph != NULL); |
| Graphs.push_back(graph); |
| } |
| |
| public: |
| SchedGraphSet(const Function *function, const TargetMachine& target); |
| ~SchedGraphSet(); |
| |
| //iterators |
| typedef std::vector<SchedGraph*>::const_iterator iterator; |
| typedef std::vector<SchedGraph*>::const_iterator const_iterator; |
| |
| std::vector<SchedGraph*>::const_iterator begin() const { return Graphs.begin(); } |
| std::vector<SchedGraph*>::const_iterator end() const { return Graphs.end(); } |
| |
| // Debugging support |
| void dump() const; |
| }; |
| |
| |
| |
| |
| // |
| // sg_pred_iterator |
| // sg_pred_const_iterator |
| // |
| typedef SGPredIterator<SchedGraphNode, SchedGraphEdge, SchedGraphNode::iterator> |
| sg_pred_iterator; |
| typedef SGPredIterator<const SchedGraphNode, const SchedGraphEdge,SchedGraphNode::const_iterator> |
| sg_pred_const_iterator; |
| |
| inline sg_pred_iterator pred_begin(SchedGraphNode *N) { |
| return sg_pred_iterator(N->beginInEdges()); |
| } |
| inline sg_pred_iterator pred_end(SchedGraphNode *N) { |
| return sg_pred_iterator(N->endInEdges()); |
| } |
| inline sg_pred_const_iterator pred_begin(const SchedGraphNode *N) { |
| return sg_pred_const_iterator(N->beginInEdges()); |
| } |
| inline sg_pred_const_iterator pred_end(const SchedGraphNode *N) { |
| return sg_pred_const_iterator(N->endInEdges()); |
| } |
| |
| |
| // |
| // sg_succ_iterator |
| // sg_succ_const_iterator |
| // |
| typedef SGSuccIterator<SchedGraphNode, SchedGraphEdge, SchedGraphNode::iterator> |
| sg_succ_iterator; |
| typedef SGSuccIterator<const SchedGraphNode, const SchedGraphEdge,SchedGraphNode::const_iterator> |
| sg_succ_const_iterator; |
| |
| inline sg_succ_iterator succ_begin(SchedGraphNode *N) { |
| return sg_succ_iterator(N->beginOutEdges()); |
| } |
| inline sg_succ_iterator succ_end(SchedGraphNode *N) { |
| return sg_succ_iterator(N->endOutEdges()); |
| } |
| inline sg_succ_const_iterator succ_begin(const SchedGraphNode *N) { |
| return sg_succ_const_iterator(N->beginOutEdges()); |
| } |
| inline sg_succ_const_iterator succ_end(const SchedGraphNode *N) { |
| return sg_succ_const_iterator(N->endOutEdges()); |
| } |
| |
| // Provide specializations of GraphTraits to be able to use graph iterators on |
| // the scheduling graph! |
| // |
| template <> struct GraphTraits<SchedGraph*> { |
| typedef SchedGraphNode NodeType; |
| typedef sg_succ_iterator ChildIteratorType; |
| |
| static inline NodeType *getEntryNode(SchedGraph *SG) { return (NodeType*)SG->getRoot(); } |
| static inline ChildIteratorType child_begin(NodeType *N) { |
| return succ_begin(N); |
| } |
| static inline ChildIteratorType child_end(NodeType *N) { |
| return succ_end(N); |
| } |
| }; |
| |
| template <> struct GraphTraits<const SchedGraph*> { |
| typedef const SchedGraphNode NodeType; |
| typedef sg_succ_const_iterator ChildIteratorType; |
| |
| static inline NodeType *getEntryNode(const SchedGraph *SG) { |
| return (NodeType*)SG->getRoot(); |
| } |
| static inline ChildIteratorType child_begin(NodeType *N) { |
| return succ_begin(N); |
| } |
| static inline ChildIteratorType child_end(NodeType *N) { |
| return succ_end(N); |
| } |
| }; |
| |
| } // End llvm namespace |
| |
| #endif |