Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Mark Rutland | 34b5560 | 2019-08-14 15:31:57 +0100 | [diff] [blame] | 2 | CFLAGS_KASAN_NOSANITIZE := -fno-builtin |
| 3 | KASAN_SHADOW_OFFSET ?= $(CONFIG_KASAN_SHADOW_OFFSET) |
Mark Rutland | 34b5560 | 2019-08-14 15:31:57 +0100 | [diff] [blame] | 4 | |
Arnd Bergmann | 5c595ac | 2021-04-16 15:45:57 -0700 | [diff] [blame] | 5 | cc-param = $(call cc-option, -mllvm -$(1), $(call cc-option, --param $(1))) |
| 6 | |
Walter Wu | 02c5877 | 2021-04-16 15:46:00 -0700 | [diff] [blame] | 7 | ifdef CONFIG_KASAN_STACK |
| 8 | stack_enable := 1 |
| 9 | else |
| 10 | stack_enable := 0 |
| 11 | endif |
| 12 | |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 13 | ifdef CONFIG_KASAN_GENERIC |
| 14 | |
Andrey Ryabinin | 0b24bec | 2015-02-13 14:39:17 -0800 | [diff] [blame] | 15 | ifdef CONFIG_KASAN_INLINE |
| 16 | call_threshold := 10000 |
| 17 | else |
| 18 | call_threshold := 0 |
| 19 | endif |
| 20 | |
| 21 | CFLAGS_KASAN_MINIMAL := -fsanitize=kernel-address |
| 22 | |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 23 | # -fasan-shadow-offset fails without -fsanitize |
| 24 | CFLAGS_KASAN_SHADOW := $(call cc-option, -fsanitize=kernel-address \ |
Andrey Ryabinin | 1a69e7c | 2018-02-06 15:36:08 -0800 | [diff] [blame] | 25 | -fasan-shadow-offset=$(KASAN_SHADOW_OFFSET), \ |
| 26 | $(call cc-option, -fsanitize=kernel-address \ |
| 27 | -mllvm -asan-mapping-offset=$(KASAN_SHADOW_OFFSET))) |
| 28 | |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 29 | ifeq ($(strip $(CFLAGS_KASAN_SHADOW)),) |
| 30 | CFLAGS_KASAN := $(CFLAGS_KASAN_MINIMAL) |
| 31 | else |
| 32 | # Now add all the compiler specific options that are valid standalone |
| 33 | CFLAGS_KASAN := $(CFLAGS_KASAN_SHADOW) \ |
| 34 | $(call cc-param,asan-globals=1) \ |
| 35 | $(call cc-param,asan-instrumentation-with-call-threshold=$(call_threshold)) \ |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 36 | $(call cc-param,asan-instrument-allocas=1) |
Andrey Ryabinin | 0b24bec | 2015-02-13 14:39:17 -0800 | [diff] [blame] | 37 | endif |
Andrey Ryabinin | c5caf21 | 2016-12-12 16:44:59 -0800 | [diff] [blame] | 38 | |
Nathan Chancellor | 1953286 | 2021-09-24 15:44:00 -0700 | [diff] [blame] | 39 | CFLAGS_KASAN += $(call cc-param,asan-stack=$(stack_enable)) |
| 40 | |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 41 | endif # CONFIG_KASAN_GENERIC |
Andrey Konovalov | 0e410e1 | 2018-02-06 15:36:00 -0800 | [diff] [blame] | 42 | |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 43 | ifdef CONFIG_KASAN_SW_TAGS |
| 44 | |
| 45 | ifdef CONFIG_KASAN_INLINE |
Arnd Bergmann | 5c595ac | 2021-04-16 15:45:57 -0700 | [diff] [blame] | 46 | instrumentation_flags := $(call cc-param,hwasan-mapping-offset=$(KASAN_SHADOW_OFFSET)) |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 47 | else |
Arnd Bergmann | 5c595ac | 2021-04-16 15:45:57 -0700 | [diff] [blame] | 48 | instrumentation_flags := $(call cc-param,hwasan-instrument-with-calls=1) |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 49 | endif |
| 50 | |
| 51 | CFLAGS_KASAN := -fsanitize=kernel-hwaddress \ |
Walter Wu | 02c5877 | 2021-04-16 15:46:00 -0700 | [diff] [blame] | 52 | $(call cc-param,hwasan-instrument-stack=$(stack_enable)) \ |
Arnd Bergmann | 5c595ac | 2021-04-16 15:45:57 -0700 | [diff] [blame] | 53 | $(call cc-param,hwasan-use-short-granules=0) \ |
Peter Collingbourne | 1cbdf60 | 2021-05-26 10:49:27 -0700 | [diff] [blame] | 54 | $(call cc-param,hwasan-inline-all-checks=0) \ |
Andrey Konovalov | 2bd926b | 2018-12-28 00:29:53 -0800 | [diff] [blame] | 55 | $(instrumentation_flags) |
| 56 | |
| 57 | endif # CONFIG_KASAN_SW_TAGS |
Masahiro Yamada | bb27321 | 2020-09-10 22:44:29 +0900 | [diff] [blame] | 58 | |
| 59 | export CFLAGS_KASAN CFLAGS_KASAN_NOSANITIZE |