aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2006-11-06 08:14:30 +0000
committerEvan Cheng <evan.cheng@apple.com>2006-11-06 08:14:30 +0000
commit3ef554d2b12af4ed0a25161fa02222d8f14026e5 (patch)
tree6a9c1ffdbfcba0c2d7123890927f65ff3b0463f5 /lib/CodeGen/SelectionDAG/DAGCombiner.cpp
parent5fa39df5ba542280deb743546ae7df68149a72ff (diff)
Add comment.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31473 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/DAGCombiner.cpp')
-rw-r--r--lib/CodeGen/SelectionDAG/DAGCombiner.cpp14
1 files changed, 10 insertions, 4 deletions
diff --git a/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
index 03abac2450..eee7a8fe8b 100644
--- a/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+++ b/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
@@ -174,7 +174,13 @@ namespace {
return true;
}
- bool CombineToIndexedLoadStore(SDNode *N) {
+ /// CombineToPreIndexedLoadStore - Try turning a load / store into a
+ /// pre-indexed load store when the base pointer is a add or subtract
+ /// and it has other uses besides the load / store. When the
+ /// transformation is done, the new indexed load / store effectively
+ /// folded the add / subtract in and all of its other uses are redirected
+ /// to the new load / store.
+ bool CombineToPreIndexedLoadStore(SDNode *N) {
bool isLoad = true;
SDOperand Ptr;
if (LoadSDNode *LD = dyn_cast<LoadSDNode>(N)) {
@@ -811,7 +817,7 @@ SDOperand DAGCombiner::visitADD(SDNode *N) {
return DAG.getNode(ISD::OR, VT, N0, N1);
}
}
-
+
return SDOperand();
}
@@ -2871,7 +2877,7 @@ SDOperand DAGCombiner::visitLOAD(SDNode *N) {
}
// Try transforming N to an indexed load.
- if (CombineToIndexedLoadStore(N))
+ if (CombineToPreIndexedLoadStore(N))
return SDOperand(N, 0);
return SDOperand();
@@ -2917,7 +2923,7 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
}
// Try transforming N to an indexed store.
- if (CombineToIndexedLoadStore(N))
+ if (CombineToPreIndexedLoadStore(N))
return SDOperand(N, 0);
return SDOperand();