summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2006-02-25 09:55:19 +0000
committerEvan Cheng <evan.cheng@apple.com>2006-02-25 09:55:19 +0000
commit994700101e99760132ac5d66f4c65c7cd98d4690 (patch)
tree780b20a7257434c5e6099752c2f1d1f20a6a19ed /llvm/lib
parented169db8a55114fce67e98df0164a77a5e671d0e (diff)
downloadbcm5719-llvm-994700101e99760132ac5d66f4c65c7cd98d4690.tar.gz
bcm5719-llvm-994700101e99760132ac5d66f4c65c7cd98d4690.zip
Added a common about the need for X86ISD::Wrapper.
llvm-svn: 26372
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index e2f22ae0a3e..48e049c6175 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -1829,6 +1829,13 @@ SDOperand X86TargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
return DAG.getNode(X86ISD::REP_MOVS, MVT::Other, Chain,
DAG.getValueType(AVT), InFlag);
}
+
+ // ConstantPool, GlobalAddress, and ExternalSymbol are lowered as their
+ // target countpart wrapped in the X86ISD::Wrapper node. Suppose N is
+ // one of the above mentioned nodes. It has to be wrapped because otherwise
+ // Select(N) returns N. So the raw TargetGlobalAddress nodes, etc. can only
+ // be used to form addressing mode. These wrapped nodes will be selected
+ // into MOV32ri.
case ISD::ConstantPool: {
ConstantPoolSDNode *CP = cast<ConstantPoolSDNode>(Op);
SDOperand Result = DAG.getNode(X86ISD::Wrapper, getPointerTy(),
OpenPOWER on IntegriCloud