Skip to content

Commit 8097047

Browse files
Sergei Trofimovichmichal42
authored andcommitted
Makefile: enable -Werror=implicit-int and -Werror=strict-prototypes by default
The common error found in forward-ported/backported patches is missing headers. One recent example (files and function names are mangled): void foo(){} EXPORT_SYMBOL(foo); gave only warning foo.c:12345678:5: warning: function declaration isn't a prototype [-Wstrict-prototypes] void foo(){} ^ foo.c:12345679:5: warning: data definition has no type or storage class [enabled by default] EXPORT_SYMBOL(foo); foo.c:12345679:5: warning: type defaults to 'int' in declaration of 'EXORT_SYMBOL' [-Werror=implicit-int] Now it's a fatal error. Tested on x86_64 allyesconfig. [akpm@linux-foundation.org: fix typos in comments] Signed-off-by: Sergei Trofimovich <slyfox@gentoo.org> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Michal Marek <mmarek@suse.cz>
1 parent 272b98c commit 8097047

File tree

1 file changed

+6
-0
lines changed

1 file changed

+6
-0
lines changed

Makefile

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -659,6 +659,12 @@ KBUILD_CFLAGS += $(call cc-option,-fno-strict-overflow)
659659
# conserve stack if available
660660
KBUILD_CFLAGS += $(call cc-option,-fconserve-stack)
661661

662+
# disallow errors like 'EXPORT_GPL(foo);' with missing header
663+
KBUILD_CFLAGS += $(call cc-option,-Werror=implicit-int)
664+
665+
# require functions to have arguments in prototypes, not empty 'int foo()'
666+
KBUILD_CFLAGS += $(call cc-option,-Werror=strict-prototypes)
667+
662668
# use the deterministic mode of AR if available
663669
KBUILD_ARFLAGS := $(call ar-option,D)
664670

0 commit comments

Comments
 (0)