aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2005-11-30 02:49:21 +0000
committerEvan Cheng <evan.cheng@apple.com>2005-11-30 02:49:21 +0000
commit14229bb6369c110644c11bc7906b0c1167d3a87a (patch)
tree545d73d900ae6b41a790148c4d42030c81bf8d96 /lib/CodeGen/SelectionDAG/SelectionDAG.cpp
parent61ca74bc3a29b2af2be7e4bd612289da8aae85b5 (diff)
Fixed a bug introduced by my last commit: TargetGlobalValues should key on
GlobalValue * and index pair. Update getGlobalAddress() for symmetry. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24524 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAG.cpp')
-rw-r--r--lib/CodeGen/SelectionDAG/SelectionDAG.cpp20
1 files changed, 13 insertions, 7 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
index 606ed5234b..8aa2bc660a 100644
--- a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
+++ b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
@@ -283,12 +283,18 @@ void SelectionDAG::RemoveNodeFromCSEMaps(SDNode *N) {
Erased = CondCodeNodes[cast<CondCodeSDNode>(N)->get()] != 0;
CondCodeNodes[cast<CondCodeSDNode>(N)->get()] = 0;
break;
- case ISD::GlobalAddress:
- Erased = GlobalValues.erase(cast<GlobalAddressSDNode>(N)->getGlobal());
+ case ISD::GlobalAddress: {
+ GlobalAddressSDNode *GN = cast<GlobalAddressSDNode>(N);
+ Erased = GlobalValues.erase(std::make_pair(GN->getGlobal(),
+ GN->getOffset()));
break;
- case ISD::TargetGlobalAddress:
- Erased =TargetGlobalValues.erase(cast<GlobalAddressSDNode>(N)->getGlobal());
+ }
+ case ISD::TargetGlobalAddress: {
+ GlobalAddressSDNode *GN = cast<GlobalAddressSDNode>(N);
+ Erased =TargetGlobalValues.erase(std::make_pair(GN->getGlobal(),
+ GN->getOffset()));
break;
+ }
case ISD::FrameIndex:
Erased = FrameIndices.erase(cast<FrameIndexSDNode>(N)->getIndex());
break;
@@ -491,8 +497,8 @@ SDOperand SelectionDAG::getConstantFP(double Val, MVT::ValueType VT) {
SDOperand SelectionDAG::getGlobalAddress(const GlobalValue *GV,
- MVT::ValueType VT) {
- SDNode *&N = GlobalValues[GV];
+ MVT::ValueType VT, int offset) {
+ SDNode *&N = GlobalValues[std::make_pair(GV, offset)];
if (N) return SDOperand(N, 0);
N = new GlobalAddressSDNode(false, GV, VT);
AllNodes.push_back(N);
@@ -501,7 +507,7 @@ SDOperand SelectionDAG::getGlobalAddress(const GlobalValue *GV,
SDOperand SelectionDAG::getTargetGlobalAddress(const GlobalValue *GV,
MVT::ValueType VT, int offset) {
- SDNode *&N = TargetGlobalValues[GV];
+ SDNode *&N = TargetGlobalValues[std::make_pair(GV, offset)];
if (N) return SDOperand(N, 0);
N = new GlobalAddressSDNode(true, GV, VT, offset);
AllNodes.push_back(N);