Hi,
On Tue, 7 Feb 2006, Andi Kleen wrote:
> If you feel the need to remove some more code: Now that gcc 2.95 isn't supported
> anymore there isn't really a need to keep the handwritten inline string functions
> in asm-i386/string.h around. Just declaring them as normal externs will cause
> gcc to use its builtin expansions, which are typically better than these old inline
> functions with inline assembly.
>
> For out of line the C versions in lib/string.c can be used (by not setting __ARCH_*)
> x86-64 did it like this forever and I guess it would be valuable cleanup for i386 too.
The only problem is that we compile with -ffreestanding which implies
-fno-builtin, so just declaring them as normal externs is not enough and
you have to something like this:
#define __HAVE_ARCH_MEMSET
extern void *memset(void *, int, __kernel_size_t);
#define memset(d, c, n) __builtin_memset(d, c, n)
(BTW you do this already in x86-64.)
Another problem here is because of -fno-builtin it's not easy to use the
generic functions as fallback. x86-64 basically does this:
#define strlen __builtin_strlen
size_t strlen(const char * s);
#ifndef __HAVE_ARCH_STRLEN
extern __kernel_size_t strlen(const char *);
#endif
This means you define a prototype for the builtin function and not for the
normal function. I'm not sure this is really intended.
bye, Roman
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]