On Mon, Aug 20, 2007 at 12:40:07PM -0500, Scott Wood wrote:
> strncmp() will be needed for PlanetCore firmware support.
> 
> Signed-off-by: Scott Wood <[EMAIL PROTECTED]>

Hmm.  They should be moved, but if we are, I'm inclined to implement
them in string.S with the rest of the string functions, rather than as
inlines.  Below is a patch I've had in my queue for some time which
does exactly that for strchr().

Move bootwrapper's strchr() from .h to string.S

Currently the bootwrapper has an implementation of strchr(), but it's
done as an inline in flatdevtree_env.h, rather than implemented in
string.S with the rest of the string functions.  This patch moves it
to string.S, matching the other string functions.

Signed-off-by: David Gibson <[EMAIL PROTECTED]>

Index: working-2.6/arch/powerpc/boot/string.S
===================================================================
--- working-2.6.orig/arch/powerpc/boot/string.S 2007-06-28 14:30:16.000000000 
+1000
+++ working-2.6/arch/powerpc/boot/string.S      2007-06-28 14:38:01.000000000 
+1000
@@ -49,6 +49,17 @@
        bne     1b
        blr
 
+       .globl  strchr
+strchr:
+       addi    r3,r3,-1
+1:     lbzu    r0,1(r3)
+       cmpw    0,r0,r4
+       beqlr
+       cmpwi   0,r0,0
+       bne     1b
+       li      r3,0
+       blr
+
        .globl  strcmp
 strcmp:
        addi    r5,r3,-1
Index: working-2.6/arch/powerpc/boot/string.h
===================================================================
--- working-2.6.orig/arch/powerpc/boot/string.h 2007-06-28 14:38:52.000000000 
+1000
+++ working-2.6/arch/powerpc/boot/string.h      2007-06-28 14:39:14.000000000 
+1000
@@ -5,6 +5,7 @@
 extern char *strcpy(char *dest, const char *src);
 extern char *strncpy(char *dest, const char *src, size_t n);
 extern char *strcat(char *dest, const char *src);
+extern char *strchr(const char *s, int c);
 extern int strcmp(const char *s1, const char *s2);
 extern size_t strlen(const char *s);
 extern size_t strnlen(const char *s, size_t count);
Index: working-2.6/arch/powerpc/boot/flatdevtree_env.h
===================================================================
--- working-2.6.orig/arch/powerpc/boot/flatdevtree_env.h        2007-06-28 
14:39:55.000000000 +1000
+++ working-2.6/arch/powerpc/boot/flatdevtree_env.h     2007-06-28 
14:40:00.000000000 +1000
@@ -36,12 +36,4 @@
        return __res;
 }
 
-static inline char *strchr(const char *s, int c)
-{
-       for (; *s != (char)c; ++s)
-               if (*s == '\0')
-                       return NULL;
-       return (char *)s;
-}
-
 #endif /* _PPC_BOOT_FLATDEVTREE_ENV_H_ */


-- 
David Gibson                    | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au  | minimalist, thank you.  NOT _the_ _other_
                                | _way_ _around_!
http://www.ozlabs.org/~dgibson
_______________________________________________
Linuxppc-dev mailing list
[email protected]
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to