X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=Makefile.flags;h=26552222d0094545df9074c637b0092e5061fa9a;hb=6b404431aa7adea24120894d59daeebc5cbe9727;hp=9de52d89a254fac6b1a61db2fde524c95a933953;hpb=c562bb74877f68edebfa31515c17d63fc4769a60;p=oweals%2Fbusybox.git diff --git a/Makefile.flags b/Makefile.flags index 9de52d89a..26552222d 100644 --- a/Makefile.flags +++ b/Makefile.flags @@ -3,6 +3,8 @@ # ========================================================================== BB_VER = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION) +export BB_VER +SKIP_STRIP = n # -std=gnu99 needed for [U]LLONG_MAX on some systems CPPFLAGS += $(call cc-option,-std=gnu99,) @@ -16,10 +18,7 @@ CPPFLAGS += \ -D"BB_VER=KBUILD_STR($(BB_VER))" -DBB_BT=AUTOCONF_TIMESTAMP # flag checks are grouped together to speed the checks up a bit.. -CFLAGS += $(call cc-option,-Wall -Wshadow,) -ifeq ($(CONFIG_WERROR),y) -CFLAGS += $(call cc-option,-Werror,) -endif +CFLAGS += $(call cc-option,-Wall -Wshadow -Wwrite-strings,) CFLAGS += $(call cc-option,-Wundef -Wstrict-prototypes,) # If you want to add "-Wmissing-prototypes -Wmissing-declarations" above # (or anything else for that matter) make sure that it is still possible @@ -28,6 +27,12 @@ CFLAGS += $(call cc-option,-Wundef -Wstrict-prototypes,) # But still, warning-free compile is a must, or else we will drown # in warnings pretty soon. +ifeq ($(CONFIG_WERROR),y) +CFLAGS += $(call cc-option,-Werror,) +else +# for development, warn a little bit about unused results.. +CPPFLAGS += -D_FORTIFY_SOURCE=2 +endif # gcc 3.x emits bogus "old style proto" warning on find.c:alloc_action() CFLAGS += $(call cc-ifversion, -ge, 0400, -Wold-style-definition) @@ -51,7 +56,46 @@ ifeq ($(CONFIG_DEBUG),y) CFLAGS += $(call cc-option,-g) endif +ifeq ($(CONFIG_BUILD_LIBBUSYBOX),y) +# on i386: 14% smaller libbusybox.so +# (code itself is 9% bigger, we save on relocs/PLT/GOT) +CFLAGS += -fpic +# and another 4% reduction of libbusybox.so: +# (external entry points must be marked EXTERNALLY_VISIBLE) +CFLAGS += $(call cc-option,-fvisibility=hidden) +endif + ifeq ($(CONFIG_STATIC),y) LDFLAGS += -static endif + +LDLIBS += m crypt + +ifeq ($(CONFIG_PAM),y) +LDLIBS += pam pam_misc +endif + +ifeq ($(CONFIG_SELINUX),y) +LDLIBS += selinux sepol +endif + +ifeq ($(CONFIG_EFENCE),y) +LDLIBS += efence +endif + +ifeq ($(CONFIG_DMALLOC),y) +LDLIBS += dmalloc +endif + #LDFLAGS += -nostdlib + +LDFLAGS_ELF2FLT = -Wl,-elf2flt +ifneq (,$(findstring $(LDFLAGS_ELF2FLT),$(LDFLAGS))) +SKIP_STRIP = y +endif + +# Busybox is a stack-fatty so make sure we increase default size +# TODO: use "make stksizes" to find & fix big stack users +# (we stole scripts/checkstack.pl from the kernel... thanks guys!) +# Reduced from 20k to 16k in 1.9.0. +FLTFLAGS += -s 16000