forked from OSchip/llvm-project
Revert r121808 until I can fix the build.
llvm-svn: 121815
This commit is contained in:
parent
4fd4337b73
commit
20480d26e9
|
@ -918,15 +918,27 @@ ARMDAGToDAGISel::SelectThumbAddrModeRI(SDValue N, SDValue &Base,
|
||||||
return false; // We want to select tLDRpci instead.
|
return false; // We want to select tLDRpci instead.
|
||||||
}
|
}
|
||||||
|
|
||||||
if (N.getOpcode() != ISD::ADD)
|
if (N.getOpcode() != ISD::ADD) {
|
||||||
return false;
|
if (N.getOpcode() == ARMISD::Wrapper &&
|
||||||
|
(!Subtarget->useMovt() ||
|
||||||
|
N.getOperand(0).getOpcode() != ISD::TargetGlobalAddress))
|
||||||
|
Base = N.getOperand(0);
|
||||||
|
else
|
||||||
|
Base = N;
|
||||||
|
|
||||||
|
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// Thumb does not have [sp, r] address mode.
|
// Thumb does not have [sp, r] address mode.
|
||||||
RegisterSDNode *LHSR = dyn_cast<RegisterSDNode>(N.getOperand(0));
|
RegisterSDNode *LHSR = dyn_cast<RegisterSDNode>(N.getOperand(0));
|
||||||
RegisterSDNode *RHSR = dyn_cast<RegisterSDNode>(N.getOperand(1));
|
RegisterSDNode *RHSR = dyn_cast<RegisterSDNode>(N.getOperand(1));
|
||||||
if ((LHSR && LHSR->getReg() == ARM::SP) ||
|
if ((LHSR && LHSR->getReg() == ARM::SP) ||
|
||||||
(RHSR && RHSR->getReg() == ARM::SP))
|
(RHSR && RHSR->getReg() == ARM::SP)) {
|
||||||
return false;
|
Base = N;
|
||||||
|
Offset = CurDAG->getRegister(0, MVT::i32);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (ConstantSDNode *RHS = dyn_cast<ConstantSDNode>(N.getOperand(1))) {
|
if (ConstantSDNode *RHS = dyn_cast<ConstantSDNode>(N.getOperand(1))) {
|
||||||
int RHSC = (int)RHS->getZExtValue();
|
int RHSC = (int)RHS->getZExtValue();
|
||||||
|
@ -991,23 +1003,6 @@ ARMDAGToDAGISel::SelectThumbAddrModeImm5S(SDValue N, unsigned Scale,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
RegisterSDNode *LHSR = dyn_cast<RegisterSDNode>(N.getOperand(0));
|
|
||||||
RegisterSDNode *RHSR = dyn_cast<RegisterSDNode>(N.getOperand(1));
|
|
||||||
if ((LHSR && LHSR->getReg() == ARM::SP) ||
|
|
||||||
(RHSR && RHSR->getReg() == ARM::SP)) {
|
|
||||||
ConstantSDNode *LHS = dyn_cast<ConstantSDNode>(N.getOperand(0));
|
|
||||||
ConstantSDNode *RHS = dyn_cast<ConstantSDNode>(N.getOperand(1));
|
|
||||||
unsigned LHSC = LHS ? LHS->getZExtValue() : 0;
|
|
||||||
unsigned RHSC = RHS ? RHS->getZExtValue() : 0;
|
|
||||||
|
|
||||||
// Thumb does not have [sp, #imm5] address mode for non-zero imm5.
|
|
||||||
if (LHSC != 0 || RHSC != 0) return false;
|
|
||||||
|
|
||||||
Base = N;
|
|
||||||
OffImm = CurDAG->getTargetConstant(0, MVT::i32);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the RHS is + imm5 * scale, fold into addr mode.
|
// If the RHS is + imm5 * scale, fold into addr mode.
|
||||||
if (ConstantSDNode *RHS = dyn_cast<ConstantSDNode>(N.getOperand(1))) {
|
if (ConstantSDNode *RHS = dyn_cast<ConstantSDNode>(N.getOperand(1))) {
|
||||||
int RHSC = (int)RHS->getZExtValue();
|
int RHSC = (int)RHS->getZExtValue();
|
||||||
|
|
Loading…
Reference in New Issue