From de0ae33544adf49802814294babbabfa3df02544 Mon Sep 17 00:00:00 2001 From: Nick Clifton Date: Tue, 4 Oct 2011 16:02:25 +0000 Subject: [PATCH] * libc/machine/arm/memcpy.S: Fix unaligned access copying. --- newlib/ChangeLog | 4 ++++ newlib/libc/machine/arm/memcpy.S | 14 ++++++++++---- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/newlib/ChangeLog b/newlib/ChangeLog index 837034d73..e1cf784d4 100644 --- a/newlib/ChangeLog +++ b/newlib/ChangeLog @@ -1,3 +1,7 @@ +2011-10-04 Nick Clifton + + * libc/machine/arm/memcpy.S: Fix unaligned access copying. + 2011-09-29 Greta Yorsh * libc/machine/arm/memcpy.S: New file. Contains a hand coded diff --git a/newlib/libc/machine/arm/memcpy.S b/newlib/libc/machine/arm/memcpy.S index f86454cd1..e408ed0e0 100644 --- a/newlib/libc/machine/arm/memcpy.S +++ b/newlib/libc/machine/arm/memcpy.S @@ -364,7 +364,7 @@ src_not_word_aligned: #ifdef __ARM_FEATURE_UNALIGNED /* Copy word by word using LDR when alignment can be done in hardware, i.e., SCTLR.A is set, supporting unaligned access in LDR and STR. */ - cmp r2, #60 + subs r2, r2, #60 blt 8f 7: @@ -380,12 +380,18 @@ src_not_word_aligned: bge 7b 8: - /* Get here if there is less than 64 btyes to copy, - where the number of bytes to copy is r2 + 4. */ + /* Get here if less than 64 bytes to copy, -64 <= r2 < 0. + Check if there is more than 3 bytes to copy. */ + adds r2, r2, #60 + blt copy_less_than_4 + +9: + /* Get here if there is less than 64 but at least 4 bytes to copy, + where the number of bytes to copy is r2+4. */ ldr r3, [r1], #4 str r3, [r0], #4 subs r2, r2, #4 - bge 8b + bge 9b b copy_less_than_4