Module Name:    src
Committed By:   matt
Date:           Mon Aug 19 17:02:25 UTC 2013

Modified Files:
        src/common/lib/libc/arch/arm/string: strcat_naive.S strchr_naive.S
            strlen_naive.S strrchr_naive.S

Log Message:
cbnz/cbz can not branch backwards so nuke 'em.
Use the same register usage in strlen as in strnlen


To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/common/lib/libc/arch/arm/string/strcat_naive.S
cvs rdiff -u -r1.3 -r1.4 src/common/lib/libc/arch/arm/string/strchr_naive.S \
    src/common/lib/libc/arch/arm/string/strrchr_naive.S
cvs rdiff -u -r1.7 -r1.8 src/common/lib/libc/arch/arm/string/strlen_naive.S

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/common/lib/libc/arch/arm/string/strcat_naive.S
diff -u src/common/lib/libc/arch/arm/string/strcat_naive.S:1.2 src/common/lib/libc/arch/arm/string/strcat_naive.S:1.3
--- src/common/lib/libc/arch/arm/string/strcat_naive.S:1.2	Mon Aug 19 02:54:02 2013
+++ src/common/lib/libc/arch/arm/string/strcat_naive.S	Mon Aug 19 17:02:25 2013
@@ -29,30 +29,22 @@
 
 #include <machine/asm.h>
 
-RCSID("$NetBSD: strcat_naive.S,v 1.2 2013/08/19 02:54:02 matt Exp $")
+RCSID("$NetBSD: strcat_naive.S,v 1.3 2013/08/19 17:02:25 matt Exp $")
 
 ENTRY(strcat)
 	mov	ip, r0			/* need to preserve r0 */
 #if defined(__thumb__)
 1:	ldrb	r2, [r0]		/* load next byte */
 	adds	r0, r0, #1		/* advance */
-#if defined(_ARM_ARCH_T2)
-	cbnz	r2, 1b			/* was it a NUL?  no, get next byte */
-#else
 	cmp	r2, #0			/* was it a NUL? */
 	bne	1b			/*   no, get next byte */
-#endif
 	subs	r0, r0, #1		/* back up one to the NUL */
 	subs	r1, r1, r0		/* save one increment */
 2:	ldrb	r2, [r1, r0]		/* load next byte from append */
 	strb	r2, [r0]		/* store it */
 	adds	r0, r0, #1		/* advance */
-#if defined(_ARM_ARCH_T2)
-	cbnz	r2, 1b			/* was it a NUL?  no, get next byte */
-#else
 	cmp	r2, #0			/* was it a NUL? */
 	bne	2b			/*   no, get next byte */
-#endif
 	mov	r0, ip			/* restore dst address */
 	RET				/* return */
 #else /* !__thumb__ */

Index: src/common/lib/libc/arch/arm/string/strchr_naive.S
diff -u src/common/lib/libc/arch/arm/string/strchr_naive.S:1.3 src/common/lib/libc/arch/arm/string/strchr_naive.S:1.4
--- src/common/lib/libc/arch/arm/string/strchr_naive.S:1.3	Mon Aug 19 02:22:25 2013
+++ src/common/lib/libc/arch/arm/string/strchr_naive.S	Mon Aug 19 17:02:25 2013
@@ -28,7 +28,7 @@
  */
 #include <machine/asm.h>
 
-RCSID("$NetBSD: strchr_naive.S,v 1.3 2013/08/19 02:22:25 matt Exp $")
+RCSID("$NetBSD: strchr_naive.S,v 1.4 2013/08/19 17:02:25 matt Exp $")
 
 /* LINTSTUB: char * strchr(const char *, int) */
 ENTRY(strchr)
@@ -39,12 +39,8 @@ ENTRY(strchr)
 	cmp	r3, r1		/* does it match? */
 	beq	2f		/*   yes, set return value */
 	adds	r0, r0, #1	/* advance to next byte */
-#ifdef _ARM_ARCH_T2
-	cbnz	r3, 1b		/* was it a NUL?  no, get next byte */
-#else
 	cmp	r3, #0		/* was it a NUL? */
 	bne	1b		/*   no, get next byte */
-#endif
 	movs	r0, #0		/* set return to NULL */
 2:	RET			/* return */
 #else
Index: src/common/lib/libc/arch/arm/string/strrchr_naive.S
diff -u src/common/lib/libc/arch/arm/string/strrchr_naive.S:1.3 src/common/lib/libc/arch/arm/string/strrchr_naive.S:1.4
--- src/common/lib/libc/arch/arm/string/strrchr_naive.S:1.3	Mon Aug 19 02:36:27 2013
+++ src/common/lib/libc/arch/arm/string/strrchr_naive.S	Mon Aug 19 17:02:25 2013
@@ -28,7 +28,7 @@
  */
 #include <machine/asm.h>
 
-RCSID("$NetBSD: strrchr_naive.S,v 1.3 2013/08/19 02:36:27 matt Exp $")
+RCSID("$NetBSD: strrchr_naive.S,v 1.4 2013/08/19 17:02:25 matt Exp $")
 
 /* LINTSTUB: char * strrchr(const char *, int) */
 ENTRY(strrchr)
@@ -42,12 +42,8 @@ ENTRY(strrchr)
 	bne	2f		/*   no, go and advance */
 	mov	r0, r2		/*   yes, set return value to point to it */
 2:	adds	r2, r2, #1	/* advance to next byte */
-#ifdef _ARM_ARCH_T2
-	cbnz	r3, 1b		/* was it a NUL?  no, get next byte */
-#else
 	cmp	r3, #0		/* was it a NUL? */
 	bne	1b		/*   no, get next byte */
-#endif
 #else
 	and	r1, r1, #0xff	/* restrict to a byte value */
 1:	ldrb	r3, [r2], #1	/* read a byte */

Index: src/common/lib/libc/arch/arm/string/strlen_naive.S
diff -u src/common/lib/libc/arch/arm/string/strlen_naive.S:1.7 src/common/lib/libc/arch/arm/string/strlen_naive.S:1.8
--- src/common/lib/libc/arch/arm/string/strlen_naive.S:1.7	Mon Aug 19 02:13:13 2013
+++ src/common/lib/libc/arch/arm/string/strlen_naive.S	Mon Aug 19 17:02:25 2013
@@ -28,7 +28,7 @@
  */
 #include <machine/asm.h>
 
-RCSID("$NetBSD: strlen_naive.S,v 1.7 2013/08/19 02:13:13 matt Exp $")
+RCSID("$NetBSD: strlen_naive.S,v 1.8 2013/08/19 17:02:25 matt Exp $")
 
 #ifdef STRNLEN
 /* LINTSTUB: size_t strnlen(const char *, size_t) */
@@ -58,17 +58,17 @@ END(strnlen)
 #else /* STRNLEN */
 /* LINTSTUB: size_t strlen(const char *) */
 ENTRY(strlen)
-	adds	r2, r0, #1	/* start of src + NUL */
+	adds	r3, r0, #1	/* start of src + NUL */
 1:
 #ifdef __thumb__
-	ldrb	r3, [r0]	/* read a byte */
+	ldrb	r2, [r0]	/* read a byte */
 	adds	r0, r0, #1
 #else
-	ldrb	r3, [r0], #1	/* read a byte */
+	ldrb	r2, [r0], #1	/* read a byte */
 #endif
-	cmp	r3, #0		/* is it a NUL? */
+	cmp	r2, #0		/* is it a NUL? */
 	bne	1b		/*   no, get next byte */
-	subs	r0, r0, r2	/* return difference between start and end */
+	subs	r0, r0, r3	/* return difference between start and end */
 	RET
 END(strlen)
 #endif /* !STRNLEN */

Reply via email to