Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 2 | # ========================================================================== |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 3 | # make W=... settings |
| 4 | # |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 5 | # There are three warning groups enabled by W=1, W=2, W=3. |
| 6 | # They are independent, and can be combined like W=12 or W=123. |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 7 | # ========================================================================== |
| 8 | |
Xiongfeng Wang | 321cb03 | 2018-01-11 17:22:29 +0800 | [diff] [blame] | 9 | KBUILD_CFLAGS += $(call cc-disable-warning, packed-not-aligned) |
| 10 | |
Masahiro Yamada | e27128d | 2019-09-01 01:25:55 +0900 | [diff] [blame] | 11 | # backward compatibility |
| 12 | KBUILD_EXTRA_WARN ?= $(KBUILD_ENABLE_EXTRA_GCC_CHECKS) |
| 13 | |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 14 | ifeq ("$(origin W)", "command line") |
Masahiro Yamada | e27128d | 2019-09-01 01:25:55 +0900 | [diff] [blame] | 15 | KBUILD_EXTRA_WARN := $(W) |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 16 | endif |
| 17 | |
Masahiro Yamada | e27128d | 2019-09-01 01:25:55 +0900 | [diff] [blame] | 18 | export KBUILD_EXTRA_WARN |
| 19 | |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 20 | # |
| 21 | # W=1 - warnings which may be relevant and do not occur too often |
| 22 | # |
Masahiro Yamada | e27128d | 2019-09-01 01:25:55 +0900 | [diff] [blame] | 23 | ifneq ($(findstring 1, $(KBUILD_EXTRA_WARN)),) |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 24 | |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 25 | KBUILD_CFLAGS += -Wextra -Wunused -Wno-unused-parameter |
| 26 | KBUILD_CFLAGS += -Wmissing-declarations |
| 27 | KBUILD_CFLAGS += -Wmissing-format-attribute |
| 28 | KBUILD_CFLAGS += -Wmissing-prototypes |
| 29 | KBUILD_CFLAGS += -Wold-style-definition |
| 30 | KBUILD_CFLAGS += -Wmissing-include-dirs |
| 31 | KBUILD_CFLAGS += $(call cc-option, -Wunused-but-set-variable) |
| 32 | KBUILD_CFLAGS += $(call cc-option, -Wunused-const-variable) |
| 33 | KBUILD_CFLAGS += $(call cc-option, -Wpacked-not-aligned) |
| 34 | KBUILD_CFLAGS += $(call cc-option, -Wstringop-truncation) |
Masahiro Yamada | 4c8dd95 | 2019-05-09 15:46:35 +0900 | [diff] [blame] | 35 | # The following turn off the warnings enabled by -Wextra |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 36 | KBUILD_CFLAGS += -Wno-missing-field-initializers |
| 37 | KBUILD_CFLAGS += -Wno-sign-compare |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 38 | |
Masahiro Yamada | 6863f56 | 2019-09-07 11:52:36 +0900 | [diff] [blame] | 39 | KBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN1 |
| 40 | |
Behan Webster | 26ea6bb | 2014-07-31 21:08:25 -0700 | [diff] [blame] | 41 | else |
| 42 | |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 43 | # Some diagnostics enabled by default are noisy. |
| 44 | # Suppress them by using -Wno... except for W=1. |
| 45 | |
Masahiro Yamada | 076f421 | 2018-10-30 22:26:33 +0900 | [diff] [blame] | 46 | ifdef CONFIG_CC_IS_CLANG |
Masahiro Yamada | a149430 | 2019-05-10 23:10:09 +0900 | [diff] [blame] | 47 | KBUILD_CFLAGS += -Wno-initializer-overrides |
Masahiro Yamada | a149430 | 2019-05-10 23:10:09 +0900 | [diff] [blame] | 48 | KBUILD_CFLAGS += -Wno-format |
| 49 | KBUILD_CFLAGS += -Wno-sign-compare |
| 50 | KBUILD_CFLAGS += -Wno-format-zero-length |
Behan Webster | 26ea6bb | 2014-07-31 21:08:25 -0700 | [diff] [blame] | 51 | endif |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 52 | |
| 53 | endif |
| 54 | |
| 55 | # |
| 56 | # W=2 - warnings which occur quite often but may still be relevant |
| 57 | # |
Masahiro Yamada | e27128d | 2019-09-01 01:25:55 +0900 | [diff] [blame] | 58 | ifneq ($(findstring 2, $(KBUILD_EXTRA_WARN)),) |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 59 | |
| 60 | KBUILD_CFLAGS += -Wcast-align |
| 61 | KBUILD_CFLAGS += -Wdisabled-optimization |
| 62 | KBUILD_CFLAGS += -Wnested-externs |
| 63 | KBUILD_CFLAGS += -Wshadow |
| 64 | KBUILD_CFLAGS += $(call cc-option, -Wlogical-op) |
| 65 | KBUILD_CFLAGS += -Wmissing-field-initializers |
| 66 | KBUILD_CFLAGS += -Wsign-compare |
| 67 | KBUILD_CFLAGS += $(call cc-option, -Wmaybe-uninitialized) |
| 68 | KBUILD_CFLAGS += $(call cc-option, -Wunused-macros) |
| 69 | |
Masahiro Yamada | 6863f56 | 2019-09-07 11:52:36 +0900 | [diff] [blame] | 70 | KBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN2 |
| 71 | |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 72 | endif |
| 73 | |
| 74 | # |
| 75 | # W=3 - more obscure warnings, can most likely be ignored |
| 76 | # |
Masahiro Yamada | e27128d | 2019-09-01 01:25:55 +0900 | [diff] [blame] | 77 | ifneq ($(findstring 3, $(KBUILD_EXTRA_WARN)),) |
Masahiro Yamada | 64a9190 | 2019-09-01 01:25:54 +0900 | [diff] [blame] | 78 | |
| 79 | KBUILD_CFLAGS += -Wbad-function-cast |
| 80 | KBUILD_CFLAGS += -Wcast-qual |
| 81 | KBUILD_CFLAGS += -Wconversion |
| 82 | KBUILD_CFLAGS += -Wpacked |
| 83 | KBUILD_CFLAGS += -Wpadded |
| 84 | KBUILD_CFLAGS += -Wpointer-arith |
| 85 | KBUILD_CFLAGS += -Wredundant-decls |
| 86 | KBUILD_CFLAGS += -Wswitch-default |
| 87 | KBUILD_CFLAGS += $(call cc-option, -Wpacked-bitfield-compat) |
| 88 | |
Masahiro Yamada | 6863f56 | 2019-09-07 11:52:36 +0900 | [diff] [blame] | 89 | KBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN3 |
| 90 | |
Masahiro Yamada | a86fe35 | 2014-04-14 18:27:10 +0900 | [diff] [blame] | 91 | endif |