[git commit] libc/string/i386/string.h: fix -O0 build failure
Denys Vlasenko
vda.linux at googlemail.com
Tue Jul 21 13:44:39 UTC 2009
commit: http://git.uclibc.org/uClibc/commit/?id=f5e2aeee574f4e8a5c1fa2340843eb3c33483daa
branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/master
Signed-off-by: Denys Vlasenko <vda.linux at googlemail.com>
---
libc/string/i386/string.h | 22 ++++++++++++++++++++++
1 files changed, 22 insertions(+), 0 deletions(-)
diff --git a/libc/string/i386/string.h b/libc/string/i386/string.h
index 3eefdeb..cf4333d 100644
--- a/libc/string/i386/string.h
+++ b/libc/string/i386/string.h
@@ -288,6 +288,7 @@ void *inlined_memchr(const void *s, int c, size_t count)
static __always_inline
void *inlined_memchr_const_c(const void *s, int c, size_t count)
{
+#if defined __OPTIMIZE__
void *edi;
int ecx, eax;
__asm__ __volatile__(
@@ -304,6 +305,27 @@ void *inlined_memchr_const_c(const void *s, int c, size_t count)
/* : no clobbers */
);
return edi;
+#else
+ /* With -O0, gcc can't figure out how to encode CONST c
+ * as an immediate operand. Generating slightly bigger code
+ * (usually "movl CONST,%eax", 3 bytes bigger than needed):
+ */
+ void *edi;
+ int ecx, eax;
+ __asm__ __volatile__(
+ " jecxz 1f\n"
+ " repne; scasb\n"
+ " leal -1(%%edi), %%edi\n"
+ " je 2f\n"
+ "1:\n"
+ " xorl %%edi, %%edi\n"
+ "2:\n"
+ : "=&D" (edi), "=&c" (ecx), "=&a" (eax)
+ : "0" (s), "2" (c), "1" (count)
+ /* : no clobbers */
+ );
+ return edi;
+#endif
}
#if 1 /* +2 bytes on shared i386 build with gcc 4.3.0 */
#define memchr(s, c, count) ( \
--
1.6.3.3
More information about the uClibc-cvs
mailing list