X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=Makefile.flags;h=60bb888d8db53d8dfdaaeee01abb4f3f500bd49c;hb=0e81e488fdec7d6b1d96439407b8a50737d35929;hp=ad8d5e1f9b5764759fc218abbed01649b79685f6;hpb=f6107c7e885da0f952569252798b7fc6b4d46411;p=oweals%2Fbusybox.git diff --git a/Makefile.flags b/Makefile.flags index ad8d5e1f9..60bb888d8 100644 --- a/Makefile.flags +++ b/Makefile.flags @@ -23,6 +23,7 @@ CFLAGS += $(call cc-option,-Wwrite-strings,) CFLAGS += $(call cc-option,-Wundef,) CFLAGS += $(call cc-option,-Wstrict-prototypes,) CFLAGS += $(call cc-option,-Wunused -Wunused-parameter,) +CFLAGS += $(call cc-option,-Wunused-function -Wunused-value,) CFLAGS += $(call cc-option,-Wmissing-prototypes -Wmissing-declarations,) # warn about C99 declaration after statement CFLAGS += $(call cc-option,-Wdeclaration-after-statement,) @@ -31,6 +32,16 @@ CFLAGS += $(call cc-option,-Wdeclaration-after-statement,) ifeq ($(CONFIG_WERROR),y) CFLAGS += $(call cc-option,-Werror,) +## TODO: +## gcc version 4.4.0 20090506 (Red Hat 4.4.0-4) (GCC) is a PITA: +## const char *ptr; ... off_t v = *(off_t*)ptr; -> BOOM +## and no easy way to convince it to shut the hell up. +## We have a lot of such things all over the place. +## Classic *(off_t*)(void*)ptr does not work, +## and I am unwilling to do crazy gcc specific ({ void *ppp = ...; }) +## stuff in macros. This would obfuscate the code too much. +## Maybe try __attribute__((__may_alias__))? +#CFLAGS += $(call cc-ifversion, -eq, 0404, -fno-strict-aliasing) endif # gcc 3.x emits bogus "old style proto" warning on find.c:alloc_action() CFLAGS += $(call cc-ifversion, -ge, 0400, -Wold-style-definition) @@ -104,12 +115,12 @@ ifeq ($(CONFIG_DMALLOC),y) LDLIBS += dmalloc endif -# If a flat binary should be built, CFLAGS_busybox="-Wl,-elf2flt" +# If a flat binary should be built, CFLAGS_busybox="-elf2flt" # env var should be set for make invocation. # Here we check whether CFLAGS_busybox indeed contains that flag. # (For historical reasons, we also check LDFLAGS, which doesn't -# seem to be entirely correct variable to put "-Wl,-elf2flt" into). -W_ELF2FLT = -Wl,-elf2flt +# seem to be entirely correct variable to put "-elf2flt" into). +W_ELF2FLT = -elf2flt ifneq (,$(findstring $(W_ELF2FLT),$(LDFLAGS) $(CFLAGS_busybox))) SKIP_STRIP = y endif