GCC and Clang have different policy for -Wunused-function; GCC does not warn unused static inline functions at all whereas Clang does if they are defined in source files instead of included headers although it has been suppressed since commitabb2ea7dfd("compiler, clang: suppress warning for unused static inline functions"). We often miss to delete unused functions where 'static inline' is used in *.c files since there is no tool to detect them. Unused code remains until somebody notices. For example, commit075ddd7568("regulator: core: remove unused rdev_get_supply()"). Let's remove __maybe_unused from the inline macro to allow Clang to start finding unused static inline functions. For now, we do this only for W=1 build since it is not a good idea to sprinkle warnings for the normal build (e.g. 35 warnings for arch/x86/configs/x86_64_defconfig). My initial attempt was to add -Wno-unused-function for no W= build (https://lore.kernel.org/patchwork/patch/1120594/) Nathan Chancellor pointed out that would weaken Clang's checks since we would no longer get -Wunused-function without W=1. It is true GCC would catch unused static non-inline functions, but it would weaken Clang as a standalone compiler, at least. Hence, here is a counter implementation. The current problem is, W=... only controls compiler flags, which are globally effective. There is no way to address only 'static inline' functions. This commit defines KBUILD_EXTRA_WARN[123] corresponding to W=[123]. When KBUILD_EXTRA_WARN1 is defined, __maybe_unused is omitted from the 'inline' macro. The new macro __inline_maybe_unused makes the code a bit uglier, so I hope we can remove it entirely after fixing most of the warnings. If you contribute to code clean-up, please run "make CC=clang W=1" and check -Wunused-function warnings. You will find lots of unused functions. Some of them are false-positives because the call-sites are disabled by #ifdef. I do not like to abuse the inline keyword for suppressing unused-function warnings because it is intended to be a hint for the compiler optimization. I prefer #ifdef around the definition, or __maybe_unused if #ifdef would make the code too ugly. Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com> Reviewed-by: Nathan Chancellor <natechancellor@gmail.com> Tested-by: Nathan Chancellor <natechancellor@gmail.com>
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| # SPDX-License-Identifier: GPL-2.0
 | |
| # ==========================================================================
 | |
| # make W=... settings
 | |
| #
 | |
| # There are three warning groups enabled by W=1, W=2, W=3.
 | |
| # They are independent, and can be combined like W=12 or W=123.
 | |
| # ==========================================================================
 | |
| 
 | |
| KBUILD_CFLAGS += $(call cc-disable-warning, packed-not-aligned)
 | |
| 
 | |
| # backward compatibility
 | |
| KBUILD_EXTRA_WARN ?= $(KBUILD_ENABLE_EXTRA_GCC_CHECKS)
 | |
| 
 | |
| ifeq ("$(origin W)", "command line")
 | |
|   KBUILD_EXTRA_WARN := $(W)
 | |
| endif
 | |
| 
 | |
| export KBUILD_EXTRA_WARN
 | |
| 
 | |
| #
 | |
| # W=1 - warnings which may be relevant and do not occur too often
 | |
| #
 | |
| ifneq ($(findstring 1, $(KBUILD_EXTRA_WARN)),)
 | |
| 
 | |
| KBUILD_CFLAGS += -Wextra -Wunused -Wno-unused-parameter
 | |
| KBUILD_CFLAGS += -Wmissing-declarations
 | |
| KBUILD_CFLAGS += -Wmissing-format-attribute
 | |
| KBUILD_CFLAGS += -Wmissing-prototypes
 | |
| KBUILD_CFLAGS += -Wold-style-definition
 | |
| KBUILD_CFLAGS += -Wmissing-include-dirs
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wunused-but-set-variable)
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wunused-const-variable)
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wpacked-not-aligned)
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wstringop-truncation)
 | |
| # The following turn off the warnings enabled by -Wextra
 | |
| KBUILD_CFLAGS += -Wno-missing-field-initializers
 | |
| KBUILD_CFLAGS += -Wno-sign-compare
 | |
| 
 | |
| KBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN1
 | |
| 
 | |
| else
 | |
| 
 | |
| # Some diagnostics enabled by default are noisy.
 | |
| # Suppress them by using -Wno... except for W=1.
 | |
| 
 | |
| ifdef CONFIG_CC_IS_CLANG
 | |
| KBUILD_CFLAGS += -Wno-initializer-overrides
 | |
| KBUILD_CFLAGS += -Wno-format
 | |
| KBUILD_CFLAGS += -Wno-sign-compare
 | |
| KBUILD_CFLAGS += -Wno-format-zero-length
 | |
| endif
 | |
| 
 | |
| endif
 | |
| 
 | |
| #
 | |
| # W=2 - warnings which occur quite often but may still be relevant
 | |
| #
 | |
| ifneq ($(findstring 2, $(KBUILD_EXTRA_WARN)),)
 | |
| 
 | |
| KBUILD_CFLAGS += -Wcast-align
 | |
| KBUILD_CFLAGS += -Wdisabled-optimization
 | |
| KBUILD_CFLAGS += -Wnested-externs
 | |
| KBUILD_CFLAGS += -Wshadow
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wlogical-op)
 | |
| KBUILD_CFLAGS += -Wmissing-field-initializers
 | |
| KBUILD_CFLAGS += -Wsign-compare
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wmaybe-uninitialized)
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wunused-macros)
 | |
| 
 | |
| KBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN2
 | |
| 
 | |
| endif
 | |
| 
 | |
| #
 | |
| # W=3 - more obscure warnings, can most likely be ignored
 | |
| #
 | |
| ifneq ($(findstring 3, $(KBUILD_EXTRA_WARN)),)
 | |
| 
 | |
| KBUILD_CFLAGS += -Wbad-function-cast
 | |
| KBUILD_CFLAGS += -Wcast-qual
 | |
| KBUILD_CFLAGS += -Wconversion
 | |
| KBUILD_CFLAGS += -Wpacked
 | |
| KBUILD_CFLAGS += -Wpadded
 | |
| KBUILD_CFLAGS += -Wpointer-arith
 | |
| KBUILD_CFLAGS += -Wredundant-decls
 | |
| KBUILD_CFLAGS += -Wswitch-default
 | |
| KBUILD_CFLAGS += $(call cc-option, -Wpacked-bitfield-compat)
 | |
| 
 | |
| KBUILD_CPPFLAGS += -DKBUILD_EXTRA_WARN3
 | |
| 
 | |
| endif
 |