|  | //===- RDFCopy.h ------------------------------------------------*- C++ -*-===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef LLVM_LIB_TARGET_HEXAGON_RDFCOPY_H | 
|  | #define LLVM_LIB_TARGET_HEXAGON_RDFCOPY_H | 
|  |  | 
|  | #include "RDFGraph.h" | 
|  | #include "RDFLiveness.h" | 
|  | #include "RDFRegisters.h" | 
|  | #include "llvm/CodeGen/MachineFunction.h" | 
|  | #include <map> | 
|  | #include <vector> | 
|  |  | 
|  | namespace llvm { | 
|  |  | 
|  | class MachineBasicBlock; | 
|  | class MachineDominatorTree; | 
|  | class MachineInstr; | 
|  |  | 
|  | namespace rdf { | 
|  |  | 
|  | struct CopyPropagation { | 
|  | CopyPropagation(DataFlowGraph &dfg) : MDT(dfg.getDT()), DFG(dfg), | 
|  | L(dfg.getMF().getRegInfo(), dfg) {} | 
|  |  | 
|  | virtual ~CopyPropagation() = default; | 
|  |  | 
|  | bool run(); | 
|  | void trace(bool On) { Trace = On; } | 
|  | bool trace() const { return Trace; } | 
|  | DataFlowGraph &getDFG() { return DFG; } | 
|  |  | 
|  | using EqualityMap = std::map<RegisterRef, RegisterRef>; | 
|  |  | 
|  | virtual bool interpretAsCopy(const MachineInstr *MI, EqualityMap &EM); | 
|  |  | 
|  | private: | 
|  | const MachineDominatorTree &MDT; | 
|  | DataFlowGraph &DFG; | 
|  | Liveness L; | 
|  | bool Trace = false; | 
|  |  | 
|  | // map: statement -> (map: dst reg -> src reg) | 
|  | std::map<NodeId, EqualityMap> CopyMap; | 
|  | std::vector<NodeId> Copies; | 
|  |  | 
|  | void recordCopy(NodeAddr<StmtNode*> SA, EqualityMap &EM); | 
|  | bool scanBlock(MachineBasicBlock *B); | 
|  | NodeId getLocalReachingDef(RegisterRef RefRR, NodeAddr<InstrNode*> IA); | 
|  | }; | 
|  |  | 
|  | } // end namespace rdf | 
|  |  | 
|  | } // end namespace llvm | 
|  |  | 
|  | #endif // LLVM_LIB_TARGET_HEXAGON_RDFCOPY_H |