perf cpumap: Add new map type for aggregation
[linux-2.6-microblaze.git] / lib / Kconfig.kasan
index 8fb0970..f5fa4ba 100644 (file)
@@ -6,7 +6,10 @@ config HAVE_ARCH_KASAN
 config HAVE_ARCH_KASAN_SW_TAGS
        bool
 
-config HAVE_ARCH_KASAN_VMALLOC
+config HAVE_ARCH_KASAN_HW_TAGS
+       bool
+
+config HAVE_ARCH_KASAN_VMALLOC
        bool
 
 config CC_HAS_KASAN_GENERIC
@@ -15,15 +18,20 @@ config CC_HAS_KASAN_GENERIC
 config CC_HAS_KASAN_SW_TAGS
        def_bool $(cc-option, -fsanitize=kernel-hwaddress)
 
+# This option is only required for software KASAN modes.
+# Old GCC versions don't have proper support for no_sanitize_address.
+# See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=89124 for details.
 config CC_HAS_WORKING_NOSANITIZE_ADDRESS
        def_bool !CC_IS_GCC || GCC_VERSION >= 80300
 
 menuconfig KASAN
        bool "KASAN: runtime memory debugger"
-       depends on (HAVE_ARCH_KASAN && CC_HAS_KASAN_GENERIC) || \
-                  (HAVE_ARCH_KASAN_SW_TAGS && CC_HAS_KASAN_SW_TAGS)
+       depends on (((HAVE_ARCH_KASAN && CC_HAS_KASAN_GENERIC) || \
+                    (HAVE_ARCH_KASAN_SW_TAGS && CC_HAS_KASAN_SW_TAGS)) && \
+                   CC_HAS_WORKING_NOSANITIZE_ADDRESS) || \
+                  HAVE_ARCH_KASAN_HW_TAGS
        depends on (SLUB && SYSFS) || (SLAB && !DEBUG_SLAB)
-       depends on CC_HAS_WORKING_NOSANITIZE_ADDRESS
+       select STACKDEPOT
        help
          Enables KASAN (KernelAddressSANitizer) - runtime memory debugger,
          designed to find out-of-bounds accesses and use-after-free bugs.
@@ -35,21 +43,24 @@ choice
        prompt "KASAN mode"
        default KASAN_GENERIC
        help
-         KASAN has two modes: generic KASAN (similar to userspace ASan,
-         x86_64/arm64/xtensa, enabled with CONFIG_KASAN_GENERIC) and
-         software tag-based KASAN (a version based on software memory
-         tagging, arm64 only, similar to userspace HWASan, enabled with
-         CONFIG_KASAN_SW_TAGS).
+         KASAN has three modes:
+         1. generic KASAN (similar to userspace ASan,
+            x86_64/arm64/xtensa, enabled with CONFIG_KASAN_GENERIC),
+         2. software tag-based KASAN (arm64 only, based on software
+            memory tagging (similar to userspace HWASan), enabled with
+            CONFIG_KASAN_SW_TAGS), and
+         3. hardware tag-based KASAN (arm64 only, based on hardware
+            memory tagging, enabled with CONFIG_KASAN_HW_TAGS).
+
+         All KASAN modes are strictly debugging features.
 
-         Both generic and tag-based KASAN are strictly debugging features.
+         For better error reports enable CONFIG_STACKTRACE.
 
 config KASAN_GENERIC
        bool "Generic mode"
        depends on HAVE_ARCH_KASAN && CC_HAS_KASAN_GENERIC
-       depends on (SLUB && SYSFS) || (SLAB && !DEBUG_SLAB)
        select SLUB_DEBUG if SLUB
        select CONSTRUCTORS
-       select STACKDEPOT
        help
          Enables generic KASAN mode.
 
@@ -62,23 +73,22 @@ config KASAN_GENERIC
          and introduces an overhead of ~x1.5 for the rest of the allocations.
          The performance slowdown is ~x3.
 
-         For better error detection enable CONFIG_STACKTRACE.
-
          Currently CONFIG_KASAN_GENERIC doesn't work with CONFIG_DEBUG_SLAB
          (the resulting kernel does not boot).
 
 config KASAN_SW_TAGS
        bool "Software tag-based mode"
        depends on HAVE_ARCH_KASAN_SW_TAGS && CC_HAS_KASAN_SW_TAGS
-       depends on (SLUB && SYSFS) || (SLAB && !DEBUG_SLAB)
        select SLUB_DEBUG if SLUB
        select CONSTRUCTORS
-       select STACKDEPOT
        help
          Enables software tag-based KASAN mode.
 
-         This mode requires Top Byte Ignore support by the CPU and therefore
-         is only supported for arm64. This mode requires Clang.
+         This mode require software memory tagging support in the form of
+         HWASan-like compiler instrumentation.
+
+         Currently this mode is only implemented for arm64 CPUs and relies on
+         Top Byte Ignore. This mode requires Clang.
 
          This mode consumes about 1/16th of available memory at kernel start
          and introduces an overhead of ~20% for the rest of the allocations.
@@ -86,15 +96,27 @@ config KASAN_SW_TAGS
          casting and comparison, as it embeds tags into the top byte of each
          pointer.
 
-         For better error detection enable CONFIG_STACKTRACE.
-
          Currently CONFIG_KASAN_SW_TAGS doesn't work with CONFIG_DEBUG_SLAB
          (the resulting kernel does not boot).
 
+config KASAN_HW_TAGS
+       bool "Hardware tag-based mode"
+       depends on HAVE_ARCH_KASAN_HW_TAGS
+       depends on SLUB
+       help
+         Enables hardware tag-based KASAN mode.
+
+         This mode requires hardware memory tagging support, and can be used
+         by any architecture that provides it.
+
+         Currently this mode is only implemented for arm64 CPUs starting from
+         ARMv8.5 and relies on Memory Tagging Extension and Top Byte Ignore.
+
 endchoice
 
 choice
        prompt "Instrumentation type"
+       depends on KASAN_GENERIC || KASAN_SW_TAGS
        default KASAN_OUTLINE
 
 config KASAN_OUTLINE
@@ -118,6 +140,7 @@ endchoice
 
 config KASAN_STACK_ENABLE
        bool "Enable stack instrumentation (unsafe)" if CC_IS_CLANG && !COMPILE_TEST
+       depends on KASAN_GENERIC || KASAN_SW_TAGS
        help
          The LLVM stack address sanitizer has a know problem that
          causes excessive stack usage in a lot of functions, see
@@ -146,7 +169,7 @@ config KASAN_SW_TAGS_IDENTIFY
 
 config KASAN_VMALLOC
        bool "Back mappings in vmalloc space with real shadow memory"
-       depends on HAVE_ARCH_KASAN_VMALLOC
+       depends on KASAN_GENERIC && HAVE_ARCH_KASAN_VMALLOC
        help
          By default, the shadow region for vmalloc space is the read-only
          zero page. This means that KASAN cannot detect errors involving