summaryrefslogtreecommitdiff
path: root/lib/Target/ARM/ARMSelectionDAGInfo.cpp
diff options
context:
space:
mode:
authorJames Molloy <james.molloy@arm.com>2014-05-16 14:24:22 +0000
committerJames Molloy <james.molloy@arm.com>2014-05-16 14:24:22 +0000
commitb32cee560d91bb2ec4325ad348ee322a42a3a3cf (patch)
tree9f76cd48a66c8315b07a5a30a7ebe8798b4d42e3 /lib/Target/ARM/ARMSelectionDAGInfo.cpp
parent74c8558965cc021a3e320dc778e1edc497bd2491 (diff)
downloadllvm-b32cee560d91bb2ec4325ad348ee322a42a3a3cf.tar.gz
llvm-b32cee560d91bb2ec4325ad348ee322a42a3a3cf.tar.bz2
llvm-b32cee560d91bb2ec4325ad348ee322a42a3a3cf.tar.xz
Re-enable inline memcpy expansion for Thumb1.
Patch by Moritz Roth! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@208994 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMSelectionDAGInfo.cpp')
-rw-r--r--lib/Target/ARM/ARMSelectionDAGInfo.cpp7
1 files changed, 4 insertions, 3 deletions
diff --git a/lib/Target/ARM/ARMSelectionDAGInfo.cpp b/lib/Target/ARM/ARMSelectionDAGInfo.cpp
index cb5812f6d2..7ce988773c 100644
--- a/lib/Target/ARM/ARMSelectionDAGInfo.cpp
+++ b/lib/Target/ARM/ARMSelectionDAGInfo.cpp
@@ -53,9 +53,10 @@ ARMSelectionDAGInfo::EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl,
EVT VT = MVT::i32;
unsigned VTSize = 4;
unsigned i = 0;
- const unsigned MAX_LOADS_IN_LDM = 6;
- SDValue TFOps[MAX_LOADS_IN_LDM];
- SDValue Loads[MAX_LOADS_IN_LDM];
+ // Emit a maximum of 4 loads in Thumb1 since we have fewer registers
+ const unsigned MAX_LOADS_IN_LDM = Subtarget->isThumb1Only() ? 4 : 6;
+ SDValue TFOps[6];
+ SDValue Loads[6];
uint64_t SrcOff = 0, DstOff = 0;
// Emit up to MAX_LOADS_IN_LDM loads, then a TokenFactor barrier, then the