From c68b26369e89ead7511ef113850035775c5d183d Mon Sep 17 00:00:00 2001 From: Rich Felker Date: Sun, 3 Apr 2011 18:16:11 -0400 Subject: fix serious bug in strchr - char signedness search for bytes with high bit set was giving (potentially dangerous) wrong results. i've tested, cleaned up, and hopefully sped up this function now. --- src/string/strchr.c | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) (limited to 'src/string') diff --git a/src/string/strchr.c b/src/string/strchr.c index e606f4fe..2fe03386 100644 --- a/src/string/strchr.c +++ b/src/string/strchr.c @@ -10,14 +10,16 @@ char *strchr(const char *s, int c) { - c = (char)c; + size_t *w, k; + + c = (unsigned char)c; if (!c) return (char *)s + strlen(s); - for (; ((uintptr_t)s & ALIGN) && *s && *s != c; s++); - if (*s && *s != c) { - const size_t *w; - size_t k = ONES * c; - for (w = (const void *)s; !HASZERO(*w) && !HASZERO(*w^k); w++); - for (s = (const void *)w; *s && *s != c; s++); - } - return *s ? (char *)s : 0; + + for (; ((uintptr_t)s & ALIGN) && *s; s++) + if (*(unsigned char *)s == c) return (char *)s; + k = ONES * c; + for (w = (void *)s; !HASZERO(*w) && !HASZERO(*w^k); w++); + for (s = (void *)w; *s; s++) + if (*(unsigned char *)s == c) return (char *)s; + return 0; } -- cgit v1.2.1