xref: /linux/scripts/Makefile.extrawarn (revision 5e88c48cb4bcbd0ea683373a106268933bb4edd2)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
2a86fe353SMasahiro Yamada# ==========================================================================
3a86fe353SMasahiro Yamada# make W=... settings
4a86fe353SMasahiro Yamada#
5c77d06e7SYann Droneaud# There are four warning groups enabled by W=1, W=2, W=3, and W=e
6c77d06e7SYann Droneaud# They are independent, and can be combined like W=12 or W=123e.
7a86fe353SMasahiro Yamada# ==========================================================================
8a86fe353SMasahiro Yamada
9e88ca243SArnd Bergmann# Default set of warnings, always enabled
10e88ca243SArnd BergmannKBUILD_CFLAGS += -Wall
11e88ca243SArnd BergmannKBUILD_CFLAGS += -Wundef
12e88ca243SArnd BergmannKBUILD_CFLAGS += -Werror=implicit-function-declaration
13e88ca243SArnd BergmannKBUILD_CFLAGS += -Werror=implicit-int
14e88ca243SArnd BergmannKBUILD_CFLAGS += -Werror=return-type
15e88ca243SArnd BergmannKBUILD_CFLAGS += -Werror=strict-prototypes
16e88ca243SArnd BergmannKBUILD_CFLAGS += -Wno-format-security
17e88ca243SArnd BergmannKBUILD_CFLAGS += -Wno-trigraphs
18a79be02bSLinus TorvaldsKBUILD_CFLAGS += $(call cc-disable-warning, frame-address)
19e88ca243SArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, address-of-packed-member)
200fcb7085SArnd BergmannKBUILD_CFLAGS += -Wmissing-declarations
210fcb7085SArnd BergmannKBUILD_CFLAGS += -Wmissing-prototypes
22e88ca243SArnd Bergmann
23e88ca243SArnd Bergmannifneq ($(CONFIG_FRAME_WARN),0)
24e88ca243SArnd BergmannKBUILD_CFLAGS += -Wframe-larger-than=$(CONFIG_FRAME_WARN)
25e88ca243SArnd Bergmannendif
26e88ca243SArnd Bergmann
27e88ca243SArnd BergmannKBUILD_CPPFLAGS-$(CONFIG_WERROR) += -Werror
28e88ca243SArnd BergmannKBUILD_CPPFLAGS += $(KBUILD_CPPFLAGS-y)
29e88ca243SArnd BergmannKBUILD_CFLAGS-$(CONFIG_CC_NO_ARRAY_BOUNDS) += -Wno-array-bounds
30e88ca243SArnd Bergmann
31e88ca243SArnd Bergmannifdef CONFIG_CC_IS_CLANG
32e88ca243SArnd Bergmann# The kernel builds with '-std=gnu11' so use of GNU extensions is acceptable.
33e88ca243SArnd BergmannKBUILD_CFLAGS += -Wno-gnu
34738fc998SNathan Chancellor
35738fc998SNathan Chancellor# Clang checks for overflow/truncation with '%p', while GCC does not:
36738fc998SNathan Chancellor# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=111219
37738fc998SNathan ChancellorKBUILD_CFLAGS += $(call cc-disable-warning, format-overflow-non-kprintf)
38738fc998SNathan ChancellorKBUILD_CFLAGS += $(call cc-disable-warning, format-truncation-non-kprintf)
39e88ca243SArnd Bergmannelse
40e88ca243SArnd Bergmann
41e88ca243SArnd Bergmann# gcc inanely warns about local variables called 'main'
42e88ca243SArnd BergmannKBUILD_CFLAGS += -Wno-main
43e88ca243SArnd Bergmannendif
44e88ca243SArnd Bergmann
45e88ca243SArnd Bergmann# These result in bogus false positives
46e88ca243SArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, dangling-pointer)
47e88ca243SArnd Bergmann
48*5e88c48cSKees Cook# Stack Variable Length Arrays (VLAs) must not be used in the kernel.
49*5e88c48cSKees Cook# Function array parameters should, however, be usable, but -Wvla will
50*5e88c48cSKees Cook# warn for those. Clang has no way yet to distinguish between the VLA
51*5e88c48cSKees Cook# types, so depend on GCC for now to keep stack VLAs out of the tree.
52*5e88c48cSKees Cook# https://github.com/llvm/llvm-project/issues/57098
53*5e88c48cSKees Cook# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=98217
54*5e88c48cSKees CookKBUILD_CFLAGS += $(call cc-option,-Wvla-larger-than=1)
55e88ca243SArnd Bergmann
56e88ca243SArnd Bergmann# disable pointer signed / unsigned warnings in gcc 4.0
57e88ca243SArnd BergmannKBUILD_CFLAGS += -Wno-pointer-sign
58e88ca243SArnd Bergmann
59e88ca243SArnd Bergmann# In order to make sure new function cast mismatches are not introduced
60e88ca243SArnd Bergmann# in the kernel (to avoid tripping CFI checking), the kernel should be
61e88ca243SArnd Bergmann# globally built with -Wcast-function-type.
62e88ca243SArnd BergmannKBUILD_CFLAGS += $(call cc-option, -Wcast-function-type)
63e88ca243SArnd Bergmann
64e88ca243SArnd Bergmann# The allocators already balk at large sizes, so silence the compiler
65e88ca243SArnd Bergmann# warnings for bounds checks involving those possible values. While
66e88ca243SArnd Bergmann# -Wno-alloc-size-larger-than would normally be used here, earlier versions
67e88ca243SArnd Bergmann# of gcc (<9.1) weirdly don't handle the option correctly when _other_
68e88ca243SArnd Bergmann# warnings are produced (?!). Using -Walloc-size-larger-than=SIZE_MAX
69e88ca243SArnd Bergmann# doesn't work (as it is documented to), silently resolving to "0" prior to
70e88ca243SArnd Bergmann# version 9.1 (and producing an error more recently). Numeric values larger
71e88ca243SArnd Bergmann# than PTRDIFF_MAX also don't work prior to version 9.1, which are silently
72e88ca243SArnd Bergmann# ignored, continuing to default to PTRDIFF_MAX. So, left with no other
73e88ca243SArnd Bergmann# choice, we must perform a versioned check to disable this warning.
74e88ca243SArnd Bergmann# https://lore.kernel.org/lkml/20210824115859.187f272f@canb.auug.org.au
75e88ca243SArnd BergmannKBUILD_CFLAGS-$(call gcc-min-version, 90100) += -Wno-alloc-size-larger-than
76e88ca243SArnd BergmannKBUILD_CFLAGS += $(KBUILD_CFLAGS-y) $(CONFIG_CC_IMPLICIT_FALLTHROUGH)
77e88ca243SArnd Bergmann
78e88ca243SArnd Bergmann# Prohibit date/time macros, which would make the build non-deterministic
79e88ca243SArnd BergmannKBUILD_CFLAGS += -Werror=date-time
80e88ca243SArnd Bergmann
81e88ca243SArnd Bergmann# enforce correct pointer usage
82e88ca243SArnd BergmannKBUILD_CFLAGS += $(call cc-option,-Werror=incompatible-pointer-types)
83e88ca243SArnd Bergmann
84e88ca243SArnd Bergmann# Require designated initializers for all marked structures
85e88ca243SArnd BergmannKBUILD_CFLAGS += $(call cc-option,-Werror=designated-init)
86e88ca243SArnd Bergmann
87e88ca243SArnd Bergmann# Warn if there is an enum types mismatch
88e88ca243SArnd BergmannKBUILD_CFLAGS += $(call cc-option,-Wenum-conversion)
89e88ca243SArnd Bergmann
90f5982cceSArnd BergmannKBUILD_CFLAGS += -Wextra
91f5982cceSArnd BergmannKBUILD_CFLAGS += -Wunused
92f5982cceSArnd Bergmann
9364a91907SMasahiro Yamada#
9464a91907SMasahiro Yamada# W=1 - warnings which may be relevant and do not occur too often
9564a91907SMasahiro Yamada#
96e27128dbSMasahiro Yamadaifneq ($(findstring 1, $(KBUILD_EXTRA_WARN)),)
97a86fe353SMasahiro Yamada
9864a91907SMasahiro YamadaKBUILD_CFLAGS += -Wmissing-format-attribute
9964a91907SMasahiro YamadaKBUILD_CFLAGS += -Wmissing-include-dirs
10064a91907SMasahiro YamadaKBUILD_CFLAGS += $(call cc-option, -Wunused-const-variable)
101a86fe353SMasahiro Yamada
10280b6093bSMasahiro YamadaKBUILD_CPPFLAGS += -Wundef
1036863f564SMasahiro YamadaKBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN1
1046863f564SMasahiro Yamada
10526ea6bb1SBehan Websterelse
10626ea6bb1SBehan Webster
10764a91907SMasahiro Yamada# Some diagnostics enabled by default are noisy.
10864a91907SMasahiro Yamada# Suppress them by using -Wno... except for W=1.
1092cd3271bSArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, unused-but-set-variable)
1102cd3271bSArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, unused-const-variable)
1112cd3271bSArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, packed-not-aligned)
1126d4ab2e9SArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, format-overflow)
113908dd508SArnd Bergmannifdef CONFIG_CC_IS_GCC
1146d4ab2e9SArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, format-truncation)
115908dd508SArnd Bergmannendif
1162cd3271bSArnd BergmannKBUILD_CFLAGS += $(call cc-disable-warning, stringop-truncation)
11764a91907SMasahiro Yamada
118c40845e3SArnd BergmannKBUILD_CFLAGS += -Wno-override-init # alias for -Wno-initializer-overrides in clang
119c40845e3SArnd Bergmann
120076f421dSMasahiro Yamadaifdef CONFIG_CC_IS_CLANG
121b0839b28SNick Desaulniers# Clang before clang-16 would warn on default argument promotions.
12288b61e3bSNick Desaulniersifneq ($(call clang-min-version, 160000),y)
123b0839b28SNick Desaulniers# Disable -Wformat
12421f9c8a1SLinus TorvaldsKBUILD_CFLAGS += -Wno-format
125b0839b28SNick Desaulniers# Then re-enable flags that were part of the -Wformat group that aren't
126b0839b28SNick Desaulniers# problematic.
127b0839b28SNick DesaulniersKBUILD_CFLAGS += -Wformat-extra-args -Wformat-invalid-specifier
128b0839b28SNick DesaulniersKBUILD_CFLAGS += -Wformat-zero-length -Wnonnull
129b0839b28SNick Desaulniers# Requires clang-12+.
13088b61e3bSNick Desaulniersifeq ($(call clang-min-version, 120000),y)
131b0839b28SNick DesaulniersKBUILD_CFLAGS += -Wformat-insufficient-args
132b0839b28SNick Desaulniersendif
133b0839b28SNick Desaulniersendif
13482f2bc2fSNathan ChancellorKBUILD_CFLAGS += $(call cc-disable-warning, pointer-to-enum-cast)
135afe956c5SNathan ChancellorKBUILD_CFLAGS += -Wno-tautological-constant-out-of-range-compare
1361cf5f151SNathan ChancellorKBUILD_CFLAGS += $(call cc-disable-warning, unaligned-access)
13775b5ab13SNathan ChancellorKBUILD_CFLAGS += -Wno-enum-compare-conditional
13826ea6bb1SBehan Websterendif
13964a91907SMasahiro Yamada
14064a91907SMasahiro Yamadaendif
14164a91907SMasahiro Yamada
14264a91907SMasahiro Yamada#
14364a91907SMasahiro Yamada# W=2 - warnings which occur quite often but may still be relevant
14464a91907SMasahiro Yamada#
145e27128dbSMasahiro Yamadaifneq ($(findstring 2, $(KBUILD_EXTRA_WARN)),)
14664a91907SMasahiro Yamada
14764a91907SMasahiro YamadaKBUILD_CFLAGS += -Wdisabled-optimization
14864a91907SMasahiro YamadaKBUILD_CFLAGS += -Wshadow
14964a91907SMasahiro YamadaKBUILD_CFLAGS += $(call cc-option, -Wlogical-op)
15064a91907SMasahiro YamadaKBUILD_CFLAGS += $(call cc-option, -Wunused-macros)
15164a91907SMasahiro Yamada
1526863f564SMasahiro YamadaKBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN2
1536863f564SMasahiro Yamada
1542cd3271bSArnd Bergmannelse
1552cd3271bSArnd Bergmann
1562cd3271bSArnd Bergmann# The following turn off the warnings enabled by -Wextra
1572cd3271bSArnd BergmannKBUILD_CFLAGS += -Wno-missing-field-initializers
1582cd3271bSArnd BergmannKBUILD_CFLAGS += -Wno-type-limits
1592cd3271bSArnd BergmannKBUILD_CFLAGS += -Wno-shift-negative-value
1602cd3271bSArnd Bergmann
1618f6629c0SNathan Chancellorifdef CONFIG_CC_IS_CLANG
1628f6629c0SNathan ChancellorKBUILD_CFLAGS += -Wno-enum-enum-conversion
1638f6629c0SNathan Chancellorendif
1648f6629c0SNathan Chancellor
165c40845e3SArnd Bergmannifdef CONFIG_CC_IS_GCC
1662cd3271bSArnd BergmannKBUILD_CFLAGS += -Wno-maybe-uninitialized
1672cd3271bSArnd Bergmannendif
1682cd3271bSArnd Bergmann
16964a91907SMasahiro Yamadaendif
17064a91907SMasahiro Yamada
17164a91907SMasahiro Yamada#
17264a91907SMasahiro Yamada# W=3 - more obscure warnings, can most likely be ignored
17364a91907SMasahiro Yamada#
174e27128dbSMasahiro Yamadaifneq ($(findstring 3, $(KBUILD_EXTRA_WARN)),)
17564a91907SMasahiro Yamada
17664a91907SMasahiro YamadaKBUILD_CFLAGS += -Wbad-function-cast
177095fbca0SArnd BergmannKBUILD_CFLAGS += -Wcast-align
17864a91907SMasahiro YamadaKBUILD_CFLAGS += -Wcast-qual
17964a91907SMasahiro YamadaKBUILD_CFLAGS += -Wconversion
18064a91907SMasahiro YamadaKBUILD_CFLAGS += -Wpacked
18164a91907SMasahiro YamadaKBUILD_CFLAGS += -Wpadded
18264a91907SMasahiro YamadaKBUILD_CFLAGS += -Wpointer-arith
18364a91907SMasahiro YamadaKBUILD_CFLAGS += -Wredundant-decls
184a97ea93eSJoe PerchesKBUILD_CFLAGS += -Wsign-compare
18564a91907SMasahiro YamadaKBUILD_CFLAGS += -Wswitch-default
18664a91907SMasahiro Yamada
1876863f564SMasahiro YamadaKBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN3
1886863f564SMasahiro Yamada
1892cd3271bSArnd Bergmannelse
1902cd3271bSArnd Bergmann
1912cd3271bSArnd Bergmann# The following turn off the warnings enabled by -Wextra
1922cd3271bSArnd BergmannKBUILD_CFLAGS += -Wno-sign-compare
193f5982cceSArnd BergmannKBUILD_CFLAGS += -Wno-unused-parameter
1942cd3271bSArnd Bergmann
195a86fe353SMasahiro Yamadaendif
196c77d06e7SYann Droneaud
197c77d06e7SYann Droneaud#
198c77d06e7SYann Droneaud# W=e - error out on warnings
199c77d06e7SYann Droneaud#
200c77d06e7SYann Droneaudifneq ($(findstring e, $(KBUILD_EXTRA_WARN)),)
201c77d06e7SYann Droneaud
202c77d06e7SYann DroneaudKBUILD_CFLAGS += -Werror
203c77d06e7SYann Droneaud
204c77d06e7SYann Droneaudendif
205