diff --git a/include/llvm/CodeGen/SelectionDAG.h b/include/llvm/CodeGen/SelectionDAG.h index d0b6ee17edb..d84924e276e 100644 --- a/include/llvm/CodeGen/SelectionDAG.h +++ b/include/llvm/CodeGen/SelectionDAG.h @@ -52,9 +52,6 @@ class SelectionDAG { // AllNodes - A linked list of nodes in the current DAG. ilist AllNodes; - // ValueNodes - track SrcValue nodes - std::map, SDNode*> ValueNodes; - public: SelectionDAG(TargetLowering &tli, MachineFunction &mf, MachineDebugInfo *di) : TLI(tli), MF(mf), DI(di) { @@ -110,14 +107,18 @@ public: void RemoveDeadNodes(); SDOperand getString(const std::string &Val); - SDOperand getConstant(uint64_t Val, MVT::ValueType VT); - SDOperand getTargetConstant(uint64_t Val, MVT::ValueType VT); + SDOperand getConstant(uint64_t Val, MVT::ValueType VT, bool isTarget = false); + SDOperand getTargetConstant(uint64_t Val, MVT::ValueType VT) { + return getConstant(Val, VT, true); + } SDOperand getConstantFP(double Val, MVT::ValueType VT); SDOperand getTargetConstantFP(double Val, MVT::ValueType VT); SDOperand getGlobalAddress(const GlobalValue *GV, MVT::ValueType VT, - int offset = 0); + int offset = 0, bool isTargetGA = false); SDOperand getTargetGlobalAddress(const GlobalValue *GV, MVT::ValueType VT, - int offset = 0); + int offset = 0) { + return getGlobalAddress(GV, VT, offset, true); + } SDOperand getFrameIndex(int FI, MVT::ValueType VT); SDOperand getTargetFrameIndex(int FI, MVT::ValueType VT); SDOperand getJumpTable(int JTI, MVT::ValueType VT); @@ -449,13 +450,8 @@ private: std::list > VTList; // Maps to auto-CSE operations. - std::map, RegisterSDNode*> RegNodes; std::vector CondCodeNodes; - std::map, SDNode*> GlobalValues; - std::map, SDNode*> TargetGlobalValues; - std::map, SDNode*> Constants; - std::map, SDNode*> TargetConstants; std::map, SDNode*> ConstantFPs; std::map, SDNode*> TargetConstantFPs; std::map FrameIndices, TargetFrameIndices, JumpTableIndices, @@ -464,7 +460,6 @@ private: std::pair >, SDNode*> ConstantPoolIndices; std::map >, SDNode*> TargetConstantPoolIndices; - std::map BBNodes; std::vector ValueTypeNodes; std::map ExternalSymbols; std::map TargetExternalSymbols; diff --git a/include/llvm/CodeGen/SelectionDAGCSEMap.h b/include/llvm/CodeGen/SelectionDAGCSEMap.h index c88e2eaad32..42007fdf688 100644 --- a/include/llvm/CodeGen/SelectionDAGCSEMap.h +++ b/include/llvm/CodeGen/SelectionDAGCSEMap.h @@ -98,12 +98,23 @@ namespace llvm { void SetOperands(const SDOperand *Ops, unsigned NumOps); void AddOperand(SDOperand Op); void AddPointer(const void *Ptr); - void AddInteger(int I) { + void AddInteger(signed I) { Bits.push_back((I >> 0) & 0xFF); Bits.push_back((I >> 8) & 0xFF); Bits.push_back((I >> 16) & 0xFF); Bits.push_back((I >> 24) & 0xFF); } + void AddInteger(unsigned I) { + AddInteger((signed)I); + } + void AddInteger(uint64_t I) { + union { + uint64_t x; + unsigned char A[8]; + }; + x = I; + Bits.append(A, A+8); + } unsigned ComputeHash() const;