mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-04 04:04:19 +00:00
kbuild: move CFLAGS_{KASAN,UBSAN,KCSAN} exports to relevant Makefiles
Move CFLAGS_KASAN*, CFLAGS_UBSAN, CFLAGS_KCSAN to Makefile.kasan, Makefile.ubsan, Makefile.kcsan, respectively. This commit also avoids the same -fsanitize=* flags being added to CFLAGS_UBSAN multiple times. Prior to this commit, the ubsan flags were appended by the '+=' operator, without any initialization. Some build targets such as 'make bindeb-pkg' recurses to the top Makefile, and ended up with adding the same flags to CFLAGS_UBSAN twice. Clear CFLAGS_UBSAN with ':=' to make it a simply expanded variable. This is better than a recursively expanded variable, which evaluates $(call cc-option, ...) multiple times before Kbuild starts descending to subdirectories. Signed-off-by: Masahiro Yamada <masahiroy@kernel.org> Acked-by: Marco Elver <elver@google.com>
This commit is contained in:
parent
9909b76812
commit
bb2732112b
1
Makefile
1
Makefile
@ -516,7 +516,6 @@ export KBUILD_HOSTCXXFLAGS KBUILD_HOSTLDFLAGS KBUILD_HOSTLDLIBS LDFLAGS_MODULE
|
|||||||
|
|
||||||
export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINCLUDE OBJCOPYFLAGS KBUILD_LDFLAGS
|
export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINCLUDE OBJCOPYFLAGS KBUILD_LDFLAGS
|
||||||
export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE
|
export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE
|
||||||
export CFLAGS_KASAN CFLAGS_KASAN_NOSANITIZE CFLAGS_UBSAN CFLAGS_KCSAN
|
|
||||||
export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE
|
export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE
|
||||||
export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE
|
export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE
|
||||||
export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
|
export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
|
||||||
|
@ -47,3 +47,5 @@ CFLAGS_KASAN := -fsanitize=kernel-hwaddress \
|
|||||||
$(instrumentation_flags)
|
$(instrumentation_flags)
|
||||||
|
|
||||||
endif # CONFIG_KASAN_SW_TAGS
|
endif # CONFIG_KASAN_SW_TAGS
|
||||||
|
|
||||||
|
export CFLAGS_KASAN CFLAGS_KASAN_NOSANITIZE
|
||||||
|
@ -9,7 +9,7 @@ endif
|
|||||||
|
|
||||||
# Keep most options here optional, to allow enabling more compilers if absence
|
# Keep most options here optional, to allow enabling more compilers if absence
|
||||||
# of some options does not break KCSAN nor causes false positive reports.
|
# of some options does not break KCSAN nor causes false positive reports.
|
||||||
CFLAGS_KCSAN := -fsanitize=thread \
|
export CFLAGS_KCSAN := -fsanitize=thread \
|
||||||
$(call cc-option,$(call cc-param,tsan-instrument-func-entry-exit=0) -fno-optimize-sibling-calls) \
|
$(call cc-option,$(call cc-param,tsan-instrument-func-entry-exit=0) -fno-optimize-sibling-calls) \
|
||||||
$(call cc-option,$(call cc-param,tsan-instrument-read-before-write=1)) \
|
$(call cc-option,$(call cc-param,tsan-instrument-read-before-write=1)) \
|
||||||
$(call cc-param,tsan-distinguish-volatile=1)
|
$(call cc-param,tsan-distinguish-volatile=1)
|
||||||
|
@ -1,4 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
export CFLAGS_UBSAN :=
|
||||||
|
|
||||||
ifdef CONFIG_UBSAN_ALIGNMENT
|
ifdef CONFIG_UBSAN_ALIGNMENT
|
||||||
CFLAGS_UBSAN += $(call cc-option, -fsanitize=alignment)
|
CFLAGS_UBSAN += $(call cc-option, -fsanitize=alignment)
|
||||||
endif
|
endif
|
||||||
|
Loading…
Reference in New Issue
Block a user