diff options
Diffstat (limited to 'contrib/llvm/lib/Target/Hexagon/RDFCopy.h')
-rw-r--r-- | contrib/llvm/lib/Target/Hexagon/RDFCopy.h | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/contrib/llvm/lib/Target/Hexagon/RDFCopy.h b/contrib/llvm/lib/Target/Hexagon/RDFCopy.h index 5ece11bd5ce4..bbd625c5f5f6 100644 --- a/contrib/llvm/lib/Target/Hexagon/RDFCopy.h +++ b/contrib/llvm/lib/Target/Hexagon/RDFCopy.h @@ -11,6 +11,9 @@ #define LLVM_LIB_TARGET_HEXAGON_RDFCOPY_H #include "RDFGraph.h" +#include "RDFLiveness.h" +#include "llvm/CodeGen/MachineFunction.h" + #include <map> #include <vector> @@ -24,7 +27,7 @@ namespace rdf { struct CopyPropagation { CopyPropagation(DataFlowGraph &dfg) : MDT(dfg.getDT()), DFG(dfg), - Trace(false) {} + L(dfg.getMF().getRegInfo(), dfg), Trace(false) {} virtual ~CopyPropagation() = default; @@ -39,18 +42,16 @@ namespace rdf { private: const MachineDominatorTree &MDT; DataFlowGraph &DFG; - DataFlowGraph::DefStackMap DefM; + Liveness L; bool Trace; - // map: register -> (map: stmt -> reaching def) - std::map<RegisterRef,std::map<NodeId,NodeId>> RDefMap; // map: statement -> (map: dst reg -> src reg) std::map<NodeId, EqualityMap> CopyMap; std::vector<NodeId> Copies; void recordCopy(NodeAddr<StmtNode*> SA, EqualityMap &EM); - void updateMap(NodeAddr<InstrNode*> IA); bool scanBlock(MachineBasicBlock *B); + NodeId getLocalReachingDef(RegisterRef RefRR, NodeAddr<InstrNode*> IA); }; } // end namespace rdf |