aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcus Shawcroft <marcus.shawcroft@arm.com>2015-11-10 15:12:30 +0000
committerMarcus Shawcroft <marcus.shawcroft@arm.com>2015-11-13 11:54:28 +0000
commit99590589326b5537d549cdd41ca4177ce7051d4a (patch)
tree103fec7e2a1e14a71b853d94fd3ec7f563f069f6
parentbcd5e8e3f9a46d151ed8ca69d7c250e11dff67ce (diff)
downloadnewlib-99590589326b5537d549cdd41ca4177ce7051d4a.zip
newlib-99590589326b5537d549cdd41ca4177ce7051d4a.tar.gz
newlib-99590589326b5537d549cdd41ca4177ce7051d4a.tar.bz2
[ARM] Factor out the thumb1 -Os implementation.cygwin-2_3_1-releasecygwin-2_3_1-relase
The patch moves the inline ASM thumb1 -O2 implementation out into its own .S file. Tested by building newlib and comparing libc.a binaries before and after for all permutations of: Architectures: armv4 armv4t armv5 armv5t armv5te armv6 armv6j armv6k armv6z armv6kz armv6t2 armv6-m armv6s-m armv7 armv7-a armv7ve armv7-r armv7-m armv7e-m armv8-a iwmmxt iwmmxt2 ISAs: thumb arm Optimization Levels: Os O2 Excluding: armv6s-m -mthumb armv6-m -mthumb armv6zk -mthumb armv6z -mthumb armv6k -mthumb armv6j -mthumb
-rw-r--r--newlib/ChangeLog6
-rw-r--r--newlib/libc/machine/arm/strlen-stub.c15
-rw-r--r--newlib/libc/machine/arm/strlen-thumb1-Os.S50
-rw-r--r--newlib/libc/machine/arm/strlen.S2
4 files changed, 58 insertions, 15 deletions
diff --git a/newlib/ChangeLog b/newlib/ChangeLog
index 44dfdcd..f2a30a1 100644
--- a/newlib/ChangeLog
+++ b/newlib/ChangeLog
@@ -1,5 +1,11 @@
2015-11-13 Marcus Shawcroft <marcus.shawcroft@arm.com>
+ * libc/machine/arm/strlen-stub.c: Move T1 -O2 implementation to...
+ * libc/machine/arm/strlen-thumb1-Os.S: New file.
+ * libc/machine/arm/strlen.S: Include strlen-thumb1-Os.S.
+
+2015-11-13 Marcus Shawcroft <marcus.shawcroft@arm.com>
+
* libc/machine/arm/Makefile.am: Adding strlen.S.
* libc/machine/arm/Makefile.in: Regenerate.
* libc/machine/arm/strlen.S: New.
diff --git a/newlib/libc/machine/arm/strlen-stub.c b/newlib/libc/machine/arm/strlen-stub.c
index f75ee48..d77c7fc 100644
--- a/newlib/libc/machine/arm/strlen-stub.c
+++ b/newlib/libc/machine/arm/strlen-stub.c
@@ -33,20 +33,7 @@
#if defined __OPTIMIZE_SIZE__ || defined PREFER_SIZE_OVER_SPEED
#if defined __thumb__ && !defined __thumb2__
-size_t
-strlen (const char* str)
-{
- int scratch;
- size_t len;
- asm ("mov %0, #0\n"
- "1:\n\t"
- "ldrb %1, [%2, %0]\n\t"
- "add %0, %0, #1\n\t"
- "cmp %1, #0\n\t"
- "bne 1b"
- : "=&r" (len), "=&r" (scratch) : "r" (str) : "memory", "cc");
- return len - 1;
-}
+/* Implemented in strlen.S. */
#else
size_t
diff --git a/newlib/libc/machine/arm/strlen-thumb1-Os.S b/newlib/libc/machine/arm/strlen-thumb1-Os.S
new file mode 100644
index 0000000..4b50430
--- /dev/null
+++ b/newlib/libc/machine/arm/strlen-thumb1-Os.S
@@ -0,0 +1,50 @@
+/* Copyright (c) 2015 ARM Ltd.
+ All rights reserved.
+
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions are met:
+ * Redistributions of source code must retain the above copyright
+ notice, this list of conditions and the following disclaimer.
+ * Redistributions in binary form must reproduce the above copyright
+ notice, this list of conditions and the following disclaimer in the
+ documentation and/or other materials provided with the distribution.
+ * Neither the name of the Linaro nor the
+ names of its contributors may be used to endorse or promote products
+ derived from this software without specific prior written permission.
+
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
+
+ .macro def_fn f p2align=0
+ .text
+ .p2align \p2align
+ .global \f
+ .type \f, %function
+\f:
+ .endm
+
+ .arch armv4t
+ .eabi_attribute Tag_also_compatible_with, "\006\013" /* ARMv6-M. */
+ .eabi_attribute Tag_ARM_ISA_use, 0
+ .thumb
+ .syntax unified
+
+def_fn strlen p2align=1
+ movs r3, #0
+1:
+ ldrb r2, [r0, r3]
+ adds r3, r3, #1
+ cmp r2, #0
+ bne 1b
+ subs r0, r3, #1
+ bx lr
+ .size strlen, . - strlen
diff --git a/newlib/libc/machine/arm/strlen.S b/newlib/libc/machine/arm/strlen.S
index b9fb861..ec61ae2 100644
--- a/newlib/libc/machine/arm/strlen.S
+++ b/newlib/libc/machine/arm/strlen.S
@@ -28,7 +28,7 @@
#if defined __OPTIMIZE_SIZE__ || defined PREFER_SIZE_OVER_SPEED
#if defined __thumb__ && !defined __thumb2__
- /* Implemented in strlen-stub.c. */
+#include "strlen-thumb1-Os.S"
#else
/* Implemented in strlen-stub.c. */