]> git.baikalelectronics.ru Git - kernel.git/commit
kbuild: Remove '-mno-global-merge'
authorNathan Chancellor <nathan@kernel.org>
Wed, 30 Mar 2022 23:45:27 +0000 (16:45 -0700)
committerMasahiro Yamada <masahiroy@kernel.org>
Fri, 1 Apr 2022 15:05:28 +0000 (00:05 +0900)
commit7e436b7b87071e2b100551987211921b3b11fde7
treef094949a5a81b095c6073c630450f1a5e33adc12
parentd171dba237b1cc3a4258cd1dc728c2365f363d55
kbuild: Remove '-mno-global-merge'

This flag is specific to clang, where it is only used by the 32-bit and
64-bit ARM backends. In certain situations, the presence of this flag
will cause a warning, as shown by commit 970e1f26c8f2 ("um: clang: Strip
out -mno-global-merge from USER_CFLAGS").

Since commit 87b0a485064e ("kbuild: LLVMLinux: Add Kbuild support for
building kernel with Clang") that added this flag back in 2014, there
have been quite a few changes to the GlobalMerge pass in LLVM. Building
several different ARCH=arm and ARCH=arm64 configurations with LLVM 11
(minimum) and 15 (current main version) with this flag removed (i.e.,
with the default of '-mglobal-merge') reveals no modpost warnings, so it
is likely that the issue noted in the comment is no longer relevant due
to changes in LLVM or modpost, meaning this flag can be removed.

If any new warnings show up that are a result of the removal of this
flag, it can be added back under arch/arm{,64}/Makefile to avoid
warnings on other architectures.

Signed-off-by: Nathan Chancellor <nathan@kernel.org>
Tested-by: David Gow <davidgow@google.com>
Reviewed-by: Kees Cook <keescook@chromium.org>
Tested-by: Sedat Dilek <sedat.dilek@gmail.com>
Reviewed-by: Sedat Dilek <sedat.dilek@gmail.com>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Makefile