diff options
| author | Kalle Raiskila <kalle.raiskila@nokia.com> | 2010-06-01 13:34:47 +0000 |
|---|---|---|
| committer | Kalle Raiskila <kalle.raiskila@nokia.com> | 2010-06-01 13:34:47 +0000 |
| commit | 8916358f9714973fe69bd962795e391276c6e774 (patch) | |
| tree | ee929b2ee8bcda9e82800a5b91328b0822cbf981 /llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp | |
| parent | 75b960e5eed19935820b32c192d5de65a8ffda76 (diff) | |
| download | bcm5719-llvm-8916358f9714973fe69bd962795e391276c6e774.tar.gz bcm5719-llvm-8916358f9714973fe69bd962795e391276c6e774.zip | |
Fix handling of 'load' nodes.
llvm-svn: 105269
Diffstat (limited to 'llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp')
| -rw-r--r-- | llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp | 10 |
1 files changed, 2 insertions, 8 deletions
diff --git a/llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp b/llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp index 9afdb2b97f3..bfb57d36136 100644 --- a/llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp +++ b/llvm/lib/Target/CellSPU/SPUISelDAGToDAG.cpp @@ -611,13 +611,7 @@ SPUDAGToDAGISel::DFormAddressPredicate(SDNode *Op, SDValue N, SDValue &Base, if (OpOpc == ISD::STORE || OpOpc == ISD::LOAD) { // Direct load/store without getelementptr - SDValue Addr, Offs; - - // Get the register from CopyFromReg - if (Opc == ISD::CopyFromReg) - Addr = N.getOperand(1); - else - Addr = N; // Register + SDValue Offs; Offs = ((OpOpc == ISD::STORE) ? Op->getOperand(3) : Op->getOperand(2)); @@ -626,7 +620,7 @@ SPUDAGToDAGISel::DFormAddressPredicate(SDNode *Op, SDValue N, SDValue &Base, Offs = CurDAG->getTargetConstant(0, Offs.getValueType()); Base = Offs; - Index = Addr; + Index = N; return true; } } else { |

