CellSPU: Relax constraints on when to generate a X-form address, evidently

they were too tight according to bug 3126.

Fix bug 3126.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@60006 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Scott Michel 2008-11-25 04:03:47 +00:00
parent 97d0a603e6
commit 50843c0741

View File

@ -591,6 +591,7 @@ SPUDAGToDAGISel::SelectXFormAddr(SDValue Op, SDValue N, SDValue &Base,
SDValue &Index) { SDValue &Index) {
if (!SelectAFormAddr(Op, N, Base, Index) if (!SelectAFormAddr(Op, N, Base, Index)
&& !SelectDFormAddr(Op, N, Base, Index)) { && !SelectDFormAddr(Op, N, Base, Index)) {
#if 0
// Default form of a X-form address is r(r) in operands 0 and 1: // Default form of a X-form address is r(r) in operands 0 and 1:
SDValue Op0 = N.getOperand(0); SDValue Op0 = N.getOperand(0);
SDValue Op1 = N.getOperand(1); SDValue Op1 = N.getOperand(1);
@ -611,6 +612,12 @@ SPUDAGToDAGISel::SelectXFormAddr(SDValue Op, SDValue N, SDValue &Base,
return true; return true;
} }
#else
// All else fails, punt and use an X-form address:
Base = N.getOperand(0);
Index = N.getOperand(1);
return true;
#endif
} }
return false; return false;