aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichal Marek <mmarek@suse.cz>2011-05-02 06:51:15 -0400
committerMichal Marek <mmarek@suse.cz>2011-05-03 04:50:54 -0400
commit8417da6f2128008c431c7d130af6cd3d9079922e (patch)
tree79bfdaadfc1548826651b9b0378e70e60cdc7720
parentbffd2020a972a188750e5cf4b9566950dfdf25a2 (diff)
kbuild: Fix passing -Wno-* options to gcc 4.4+
Starting with 4.4, gcc will happily accept -Wno-<anything> in the cc-option test and complain later when compiling a file that has some other warning. This rather unexpected behavior is intentional as per http://gcc.gnu.org/PR28322, so work around it by testing for support of the opposite option (without the no-). Introduce a new Makefile function cc-disable-warning that does this and update two uses of cc-option in the toplevel Makefile. Reported-and-tested-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Michal Marek <mmarek@suse.cz>
-rw-r--r--Documentation/kbuild/makefiles.txt12
-rw-r--r--Makefile4
-rw-r--r--scripts/Kbuild.include5
3 files changed, 19 insertions, 2 deletions
diff --git a/Documentation/kbuild/makefiles.txt b/Documentation/kbuild/makefiles.txt
index 835b64acf0b4..47435e56c5da 100644
--- a/Documentation/kbuild/makefiles.txt
+++ b/Documentation/kbuild/makefiles.txt
@@ -501,6 +501,18 @@ more details, with real examples.
501 gcc >= 3.00. For gcc < 3.00, -malign-functions=4 is used. 501 gcc >= 3.00. For gcc < 3.00, -malign-functions=4 is used.
502 Note: cc-option-align uses KBUILD_CFLAGS for $(CC) options 502 Note: cc-option-align uses KBUILD_CFLAGS for $(CC) options
503 503
504 cc-disable-warning
505 cc-disable-warning checks if gcc supports a given warning and returns
506 the commandline switch to disable it. This special function is needed,
507 because gcc 4.4 and later accept any unknown -Wno-* option and only
508 warn about it if there is another warning in the source file.
509
510 Example:
511 KBUILD_CFLAGS += $(call cc-disable-warning, unused-but-set-variable)
512
513 In the above example, -Wno-unused-but-set-variable will be added to
514 KBUILD_CFLAGS only if gcc really accepts it.
515
504 cc-version 516 cc-version
505 cc-version returns a numerical version of the $(CC) compiler version. 517 cc-version returns a numerical version of the $(CC) compiler version.
506 The format is <major><minor> where both are two digits. So for example 518 The format is <major><minor> where both are two digits. So for example
diff --git a/Makefile b/Makefile
index bc9eae424af8..5cf4eb03fb3e 100644
--- a/Makefile
+++ b/Makefile
@@ -569,7 +569,7 @@ endif
569 569
570# This warning generated too much noise in a regular build. 570# This warning generated too much noise in a regular build.
571# Use make W=1 to enable this warning (see scripts/Makefile.build) 571# Use make W=1 to enable this warning (see scripts/Makefile.build)
572KBUILD_CFLAGS += $(call cc-option, -Wno-unused-but-set-variable) 572KBUILD_CFLAGS += $(call cc-disable-warning, unused-but-set-variable)
573 573
574ifdef CONFIG_FRAME_POINTER 574ifdef CONFIG_FRAME_POINTER
575KBUILD_CFLAGS += -fno-omit-frame-pointer -fno-optimize-sibling-calls 575KBUILD_CFLAGS += -fno-omit-frame-pointer -fno-optimize-sibling-calls
@@ -616,7 +616,7 @@ CHECKFLAGS += $(NOSTDINC_FLAGS)
616KBUILD_CFLAGS += $(call cc-option,-Wdeclaration-after-statement,) 616KBUILD_CFLAGS += $(call cc-option,-Wdeclaration-after-statement,)
617 617
618# disable pointer signed / unsigned warnings in gcc 4.0 618# disable pointer signed / unsigned warnings in gcc 4.0
619KBUILD_CFLAGS += $(call cc-option,-Wno-pointer-sign,) 619KBUILD_CFLAGS += $(call cc-disable-warning, pointer-sign)
620 620
621# disable invalid "can't wrap" optimizations for signed / pointers 621# disable invalid "can't wrap" optimizations for signed / pointers
622KBUILD_CFLAGS += $(call cc-option,-fno-strict-overflow) 622KBUILD_CFLAGS += $(call cc-option,-fno-strict-overflow)
diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include
index fae2d8d8cb09..c034dd7161a6 100644
--- a/scripts/Kbuild.include
+++ b/scripts/Kbuild.include
@@ -118,6 +118,11 @@ cc-option-yn = $(call try-run,\
118cc-option-align = $(subst -functions=0,,\ 118cc-option-align = $(subst -functions=0,,\
119 $(call cc-option,-falign-functions=0,-malign-functions=0)) 119 $(call cc-option,-falign-functions=0,-malign-functions=0))
120 120
121# cc-disable-warning
122# Usage: cflags-y += $(call cc-disable-warning,unused-but-set-variable)
123cc-disable-warning = $(call try-run,\
124 $(CC) $(KBUILD_CPPFLAGS) $(KBUILD_CFLAGS) -W$(strip $(1)) -c -xc /dev/null -o "$$TMP",-Wno-$(strip $(1)))
125
121# cc-version 126# cc-version
122# Usage gcc-ver := $(call cc-version) 127# Usage gcc-ver := $(call cc-version)
123cc-version = $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-version.sh $(CC)) 128cc-version = $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-version.sh $(CC))