Without -ffreestanding, gcc may replace calls to standard C library functions by calls to other standard C library functions and/or inline code. This may cause link errors if the replacement code calls a standard C library function that's implemented as a macro in the kernel. E.g. gcc turned strncat(name, "%d", 2); into a call to strlen() and a 16-bit store, causing a link failure, as arch/m68k/include/asm/string.h provides strlen() using a macro: ERROR: "strlen" [net/ipv4/ip_tunnel.ko] undefined! In addition, this saves ca. 64 bytes of text on a typical kernel build. Signed-off-by: Geert Uytterhoeven <geert@xxxxxxxxxxxxxx> --- http://kisskb.ellerman.id.au/kisskb/buildresult/8462108/ QUESTION: Should we re-enable -ffreestanding in the main Makefile instead? It was removed in commit 6edfba1b33c701108717f4e036320fc39abe1912 Author: Andi Kleen <ak@xxxxxxx> Date: Sat Mar 25 16:29:49 2006 +0100 [PATCH] x86_64: Don't define string functions to builtin gcc should handle this anyways, and it causes problems when sprintf is turned into strcpy by gcc behind our backs and the C fallback version of strcpy is actually defining __builtin_strcpy Then drop -ffreestanding from the main Makefile because it isn't needed anymore and implies -fno-builtin, which is wrong now. (it was only added for x86-64, so dropping it should be safe) Noticed by Roman Zippel Cc: Roman Zippel <zippel@xxxxxxxxxxxxxx> Signed-off-by: Andi Kleen <ak@xxxxxxx> Signed-off-by: Linus Torvalds <torvalds@xxxxxxxx> Subsequently, it got re-enabled for mips, sh, x86-32, um/x86, xtensa, and score. arch/m68k/Makefile | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/arch/m68k/Makefile b/arch/m68k/Makefile index 2f02acf..8e06a38 100644 --- a/arch/m68k/Makefile +++ b/arch/m68k/Makefile @@ -58,7 +58,7 @@ cpuflags-$(CONFIG_M5206e) := $(call cc-option,-mcpu=5206e,-m5200) cpuflags-$(CONFIG_M5206) := $(call cc-option,-mcpu=5206,-m5200) KBUILD_AFLAGS += $(cpuflags-y) -KBUILD_CFLAGS += $(cpuflags-y) -pipe +KBUILD_CFLAGS += $(cpuflags-y) -pipe -ffreestanding ifdef CONFIG_MMU # without -fno-strength-reduce the 53c7xx.c driver fails ;-( KBUILD_CFLAGS += -fno-strength-reduce -ffixed-a2 -- 1.7.0.4 -- To unsubscribe from this list: send the line "unsubscribe linux-kbuild" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html