diff options
| author | Sam Ravnborg <sam@ravnborg.org> | 2011-04-27 16:15:27 -0400 |
|---|---|---|
| committer | Michal Marek <mmarek@suse.cz> | 2011-04-28 11:59:07 -0400 |
| commit | 28bc20dccadc610c56e27255aeef2938141a0cd3 (patch) | |
| tree | dfaf1a2b593a25cabffe8a83e5aaf34b3c2c166d /scripts | |
| parent | 40df759e2b9ec945f1a5ddc61b3fdfbb6583257e (diff) | |
kbuild: implement several W= levels
Building a kernel with "make W=1" produces far too much noise to be
useful.
Divide the warning options in three groups:
W=1 - warnings that may be relevant and does not occur too often
W=2 - warnings that occur quite often but may still be relevant
W=3 - the more obscure warnings, can most likely be ignored
When building the whole kernel, those levels produce:
W=1 - 4859 warnings
W=2 - 1394 warnings
W=3 - 86666 warnings
respectively. Warnings have been counted with Geert's script at
http://www.kernel.org/pub/linux/kernel/people/geert/linux-log/linux-log-summary.pl
Many warnings occur from .h files so fixing one file may have a nice
effect on the total number of warnings.
With these changes I am actually tempted to try W=1 now and then.
Previously there was just too much noise.
Borislav:
- make the W= levels exclusive
- move very noisy and making little sense for the kernel warnings to W=3
- drop -Woverlength-strings due to useless warning message
- copy explanatory text for the different warning levels to 'make help'
- recount warnings per level
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: Borislav Petkov <bp@alien8.de>
Cc: Dave Jones <davej@redhat.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Signed-off-by: Michal Marek <mmarek@suse.cz>
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/Makefile.build | 65 |
1 files changed, 38 insertions, 27 deletions
diff --git a/scripts/Makefile.build b/scripts/Makefile.build index e1244ef308ce..9c0c48127946 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build | |||
| @@ -51,36 +51,47 @@ ifeq ($(KBUILD_NOPEDANTIC),) | |||
| 51 | endif | 51 | endif |
| 52 | 52 | ||
| 53 | # | 53 | # |
| 54 | # make W=1 settings | 54 | # make W=... settings |
| 55 | # | 55 | # |
| 56 | # $(call cc-option... ) handles gcc -W.. options which | 56 | # W=1 - warnings that may be relevant and does not occur too often |
| 57 | # W=2 - warnings that occur quite often but may still be relevant | ||
| 58 | # W=3 - the more obscure warnings, can most likely be ignored | ||
| 59 | # | ||
| 60 | # $(call cc-option, -W...) handles gcc -W.. options which | ||
| 57 | # are not supported by all versions of the compiler | 61 | # are not supported by all versions of the compiler |
| 58 | ifdef KBUILD_ENABLE_EXTRA_GCC_CHECKS | 62 | ifdef KBUILD_ENABLE_EXTRA_GCC_CHECKS |
| 59 | KBUILD_EXTRA_WARNINGS := -Wextra | 63 | warning-1 := -Wextra -Wunused -Wno-unused-parameter |
| 60 | KBUILD_EXTRA_WARNINGS += -Wunused -Wno-unused-parameter | 64 | warning-1 += -Wmissing-declarations |
| 61 | KBUILD_EXTRA_WARNINGS += -Waggregate-return | 65 | warning-1 += -Wmissing-format-attribute |
| 62 | KBUILD_EXTRA_WARNINGS += -Wbad-function-cast | 66 | warning-1 += -Wmissing-prototypes |
| 63 | KBUILD_EXTRA_WARNINGS += -Wcast-qual | 67 | warning-1 += -Wold-style-definition |
| 64 | KBUILD_EXTRA_WARNINGS += -Wcast-align | 68 | warning-1 += $(call cc-option, -Wmissing-include-dirs) |
| 65 | KBUILD_EXTRA_WARNINGS += -Wconversion | 69 | |
| 66 | KBUILD_EXTRA_WARNINGS += -Wdisabled-optimization | 70 | warning-2 := -Waggregate-return |
| 67 | KBUILD_EXTRA_WARNINGS += -Wlogical-op | 71 | warning-2 += -Wcast-align |
| 68 | KBUILD_EXTRA_WARNINGS += -Wmissing-declarations | 72 | warning-2 += -Wdisabled-optimization |
| 69 | KBUILD_EXTRA_WARNINGS += -Wmissing-format-attribute | 73 | warning-2 += -Wnested-externs |
| 70 | KBUILD_EXTRA_WARNINGS += $(call cc-option, -Wmissing-include-dirs,) | 74 | warning-2 += -Wshadow |
| 71 | KBUILD_EXTRA_WARNINGS += -Wmissing-prototypes | 75 | warning-2 += $(call cc-option, -Wlogical-op) |
| 72 | KBUILD_EXTRA_WARNINGS += -Wnested-externs | 76 | |
| 73 | KBUILD_EXTRA_WARNINGS += -Wold-style-definition | 77 | warning-3 := -Wbad-function-cast |
| 74 | KBUILD_EXTRA_WARNINGS += $(call cc-option, -Woverlength-strings,) | 78 | warning-3 += -Wcast-qual |
| 75 | KBUILD_EXTRA_WARNINGS += -Wpacked | 79 | warning-3 += -Wconversion |
| 76 | KBUILD_EXTRA_WARNINGS += -Wpacked-bitfield-compat | 80 | warning-3 += -Wpacked |
| 77 | KBUILD_EXTRA_WARNINGS += -Wpadded | 81 | warning-3 += -Wpadded |
| 78 | KBUILD_EXTRA_WARNINGS += -Wpointer-arith | 82 | warning-3 += -Wpointer-arith |
| 79 | KBUILD_EXTRA_WARNINGS += -Wredundant-decls | 83 | warning-3 += -Wredundant-decls |
| 80 | KBUILD_EXTRA_WARNINGS += -Wshadow | 84 | warning-3 += -Wswitch-default |
| 81 | KBUILD_EXTRA_WARNINGS += -Wswitch-default | 85 | warning-3 += $(call cc-option, -Wpacked-bitfield-compat) |
| 82 | KBUILD_EXTRA_WARNINGS += $(call cc-option, -Wvla,) | 86 | warning-3 += $(call cc-option, -Wvla) |
| 83 | KBUILD_CFLAGS += $(KBUILD_EXTRA_WARNINGS) | 87 | |
| 88 | warning := $(warning-$(KBUILD_ENABLE_EXTRA_GCC_CHECKS)) | ||
| 89 | |||
| 90 | ifeq ("$(warning)","") | ||
| 91 | $(error W=$(KBUILD_ENABLE_EXTRA_GCC_CHECKS) is unknown) | ||
| 92 | endif | ||
| 93 | |||
| 94 | KBUILD_CFLAGS += $(warning) | ||
| 84 | endif | 95 | endif |
| 85 | 96 | ||
| 86 | include scripts/Makefile.lib | 97 | include scripts/Makefile.lib |
