diff options
author | Chris Lattner <sabre@nondot.org> | 2005-08-25 05:04:11 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-08-25 05:04:11 +0000 |
commit | 34e17052a77e1a52cae58b2f6d203c663af97ece (patch) | |
tree | 6725cea51584b1bdc4d71d56e1a94ad5f1ae6b53 /lib/Target/PowerPC/PPCISelDAGToDAG.cpp | |
parent | 4025a9c2cc4ac3b9efa465a2f64be50fdaba9da9 (diff) |
Implement support for taking the address of constant pool indices, which
is used by the int -> FP code among other things. This gets
2005-05-12-Int64ToFP past that failure, to dying on lack of support for add_parts
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23042 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/PowerPC/PPCISelDAGToDAG.cpp')
-rw-r--r-- | lib/Target/PowerPC/PPCISelDAGToDAG.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/Target/PowerPC/PPCISelDAGToDAG.cpp b/lib/Target/PowerPC/PPCISelDAGToDAG.cpp index 62fe16537e..0ed454033b 100644 --- a/lib/Target/PowerPC/PPCISelDAGToDAG.cpp +++ b/lib/Target/PowerPC/PPCISelDAGToDAG.cpp @@ -557,6 +557,16 @@ SDOperand PPC32DAGToDAGISel::Select(SDOperand Op) { getI32Imm(0)); break; } + case ISD::ConstantPool: { + unsigned CPIIdx = cast<ConstantPoolSDNode>(N)->getIndex(); + SDOperand Tmp, CPI = CurDAG->getTargetConstantPool(CPIIdx, MVT::i32); + if (PICEnabled) + Tmp = CurDAG->getTargetNode(PPC::ADDIS, MVT::i32, getGlobalBaseReg(),CPI); + else + Tmp = CurDAG->getTargetNode(PPC::LIS, MVT::i32, CPI); + CurDAG->SelectNodeTo(N, MVT::i32, PPC::LA, Tmp, CPI); + break; + } case ISD::GlobalAddress: { GlobalValue *GV = cast<GlobalAddressSDNode>(N)->getGlobal(); SDOperand Tmp; |