diff options
author | Bob Wilson <bob.wilson@apple.com> | 2011-02-25 06:42:42 +0000 |
---|---|---|
committer | Bob Wilson <bob.wilson@apple.com> | 2011-02-25 06:42:42 +0000 |
commit | e3ecd5fb9b239b150f4f1cc3ca1ed97825284dde (patch) | |
tree | fe04fa8f01f00b994c1ea0d009254c9def298484 /llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp | |
parent | 6a4e8e38f255ac5af053b7531eb2f5a0585e6f20 (diff) | |
download | bcm5719-llvm-e3ecd5fb9b239b150f4f1cc3ca1ed97825284dde.tar.gz bcm5719-llvm-e3ecd5fb9b239b150f4f1cc3ca1ed97825284dde.zip |
Add patterns to use post-increment addressing for Neon VST1-lane instructions.
llvm-svn: 126477
Diffstat (limited to 'llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp index a506cffdba3..f0d5a7d7c2e 100644 --- a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp +++ b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp @@ -126,6 +126,7 @@ public: bool SelectAddrMode5(SDValue N, SDValue &Base, SDValue &Offset); bool SelectAddrMode6(SDNode *Parent, SDValue N, SDValue &Addr,SDValue &Align); + bool SelectAddrMode6Offset(SDNode *Op, SDValue N, SDValue &Offset); bool SelectAddrModePC(SDValue N, SDValue &Offset, SDValue &Label); @@ -886,6 +887,20 @@ bool ARMDAGToDAGISel::SelectAddrMode6(SDNode *Parent, SDValue N, SDValue &Addr, return true; } +bool ARMDAGToDAGISel::SelectAddrMode6Offset(SDNode *Op, SDValue N, + SDValue &Offset) { + LSBaseSDNode *LdSt = cast<LSBaseSDNode>(Op); + ISD::MemIndexedMode AM = LdSt->getAddressingMode(); + if (AM != ISD::POST_INC) + return false; + Offset = N; + if (ConstantSDNode *NC = dyn_cast<ConstantSDNode>(N)) { + if (NC->getZExtValue() * 8 == LdSt->getMemoryVT().getSizeInBits()) + Offset = CurDAG->getRegister(0, MVT::i32); + } + return true; +} + bool ARMDAGToDAGISel::SelectAddrModePC(SDValue N, SDValue &Offset, SDValue &Label) { if (N.getOpcode() == ARMISD::PIC_ADD && N.hasOneUse()) { |