OSDN Git Service

Merge tag 'cxl-for-5.18' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl
[uclinux-h8/linux.git] / lib / Kconfig.debug
index 7dea203..075cd25 100644 (file)
@@ -208,20 +208,87 @@ config DEBUG_BUGVERBOSE
 
 endmenu # "printk and dmesg options"
 
+config DEBUG_KERNEL
+       bool "Kernel debugging"
+       help
+         Say Y here if you are developing drivers or trying to debug and
+         identify kernel problems.
+
+config DEBUG_MISC
+       bool "Miscellaneous debug code"
+       default DEBUG_KERNEL
+       depends on DEBUG_KERNEL
+       help
+         Say Y here if you need to enable miscellaneous debug code that should
+         be under a more specific debug option but isn't.
+
 menu "Compile-time checks and compiler options"
 
 config DEBUG_INFO
-       bool "Compile the kernel with debug info"
-       depends on DEBUG_KERNEL && !COMPILE_TEST
+       bool
+       help
+         A kernel debug info option other than "None" has been selected
+         in the "Debug information" choice below, indicating that debug
+         information will be generated for build targets.
+
+choice
+       prompt "Debug information"
+       depends on DEBUG_KERNEL
        help
-         If you say Y here the resulting kernel image will include
-         debugging info resulting in a larger kernel image.
+         Selecting something other than "None" results in a kernel image
+         that will include debugging info resulting in a larger kernel image.
          This adds debug symbols to the kernel and modules (gcc -g), and
          is needed if you intend to use kernel crashdump or binary object
          tools like crash, kgdb, LKCD, gdb, etc on the kernel.
-         Say Y here only if you plan to debug the kernel.
 
-         If unsure, say N.
+         Choose which version of DWARF debug info to emit. If unsure,
+         select "Toolchain default".
+
+config DEBUG_INFO_NONE
+       bool "Disable debug information"
+       help
+         Do not build the kernel with debugging information, which will
+         result in a faster and smaller build.
+
+config DEBUG_INFO_DWARF_TOOLCHAIN_DEFAULT
+       bool "Rely on the toolchain's implicit default DWARF version"
+       select DEBUG_INFO
+       help
+         The implicit default version of DWARF debug info produced by a
+         toolchain changes over time.
+
+         This can break consumers of the debug info that haven't upgraded to
+         support newer revisions, and prevent testing newer versions, but
+         those should be less common scenarios.
+
+config DEBUG_INFO_DWARF4
+       bool "Generate DWARF Version 4 debuginfo"
+       select DEBUG_INFO
+       help
+         Generate DWARF v4 debug info. This requires gcc 4.5+ and gdb 7.0+.
+
+         If you have consumers of DWARF debug info that are not ready for
+         newer revisions of DWARF, you may wish to choose this or have your
+         config select this.
+
+config DEBUG_INFO_DWARF5
+       bool "Generate DWARF Version 5 debuginfo"
+       select DEBUG_INFO
+       depends on !CC_IS_CLANG || (CC_IS_CLANG && (AS_IS_LLVM || (AS_IS_GNU && AS_VERSION >= 23502)))
+       help
+         Generate DWARF v5 debug info. Requires binutils 2.35.2, gcc 5.0+ (gcc
+         5.0+ accepts the -gdwarf-5 flag but only had partial support for some
+         draft features until 7.0), and gdb 8.0+.
+
+         Changes to the structure of debug info in Version 5 allow for around
+         15-18% savings in resulting image and debug info section sizes as
+         compared to DWARF Version 4. DWARF Version 5 standardizes previous
+         extensions such as accelerators for symbol indexing and the format
+         for fission (.dwo/.dwp) files. Users may not want to select this
+         config if they rely on tooling that has not yet been updated to
+         support DWARF Version 5.
+
+endchoice # "Debug information"
 
 if DEBUG_INFO
 
@@ -267,63 +334,27 @@ config DEBUG_INFO_SPLIT
          to know about the .dwo files and include them.
          Incompatible with older versions of ccache.
 
-choice
-       prompt "DWARF version"
-       help
-         Which version of DWARF debug info to emit.
-
-config DEBUG_INFO_DWARF_TOOLCHAIN_DEFAULT
-       bool "Rely on the toolchain's implicit default DWARF version"
-       help
-         The implicit default version of DWARF debug info produced by a
-         toolchain changes over time.
-
-         This can break consumers of the debug info that haven't upgraded to
-         support newer revisions, and prevent testing newer versions, but
-         those should be less common scenarios.
-
-         If unsure, say Y.
-
-config DEBUG_INFO_DWARF4
-       bool "Generate DWARF Version 4 debuginfo"
-       help
-         Generate DWARF v4 debug info. This requires gcc 4.5+ and gdb 7.0+.
-
-         If you have consumers of DWARF debug info that are not ready for
-         newer revisions of DWARF, you may wish to choose this or have your
-         config select this.
-
-config DEBUG_INFO_DWARF5
-       bool "Generate DWARF Version 5 debuginfo"
-       depends on !CC_IS_CLANG || (CC_IS_CLANG && (AS_IS_LLVM || (AS_IS_GNU && AS_VERSION >= 23502)))
-       depends on !DEBUG_INFO_BTF
-       help
-         Generate DWARF v5 debug info. Requires binutils 2.35.2, gcc 5.0+ (gcc
-         5.0+ accepts the -gdwarf-5 flag but only had partial support for some
-         draft features until 7.0), and gdb 8.0+.
-
-         Changes to the structure of debug info in Version 5 allow for around
-         15-18% savings in resulting image and debug info section sizes as
-         compared to DWARF Version 4. DWARF Version 5 standardizes previous
-         extensions such as accelerators for symbol indexing and the format
-         for fission (.dwo/.dwp) files. Users may not want to select this
-         config if they rely on tooling that has not yet been updated to
-         support DWARF Version 5.
-
-endchoice # "DWARF version"
-
 config DEBUG_INFO_BTF
        bool "Generate BTF typeinfo"
        depends on !DEBUG_INFO_SPLIT && !DEBUG_INFO_REDUCED
        depends on !GCC_PLUGIN_RANDSTRUCT || COMPILE_TEST
        depends on BPF_SYSCALL
+       depends on !DEBUG_INFO_DWARF5 || PAHOLE_VERSION >= 121
        help
          Generate deduplicated BTF type information from DWARF debug info.
          Turning this on expects presence of pahole tool, which will convert
          DWARF type info into equivalent deduplicated BTF type info.
 
 config PAHOLE_HAS_SPLIT_BTF
-       def_bool $(success, test `$(PAHOLE) --version | sed -E 's/v([0-9]+)\.([0-9]+)/\1\2/'` -ge "119")
+       def_bool PAHOLE_VERSION >= 119
+
+config PAHOLE_HAS_BTF_TAG
+       def_bool PAHOLE_VERSION >= 123
+       depends on CC_IS_CLANG
+       help
+         Decide whether pahole emits btf_tag attributes (btf_type_tag and
+         btf_decl_tag) or not. Currently only clang compiler implements
+         these attributes, so make the config depend on CC_IS_CLANG.
 
 config DEBUG_INFO_BTF_MODULES
        def_bool y
@@ -331,6 +362,16 @@ config DEBUG_INFO_BTF_MODULES
        help
          Generate compact split BTF type information for kernel modules.
 
+config MODULE_ALLOW_BTF_MISMATCH
+       bool "Allow loading modules with non-matching BTF type info"
+       depends on DEBUG_INFO_BTF_MODULES
+       help
+         For modules whose split BTF does not match vmlinux, load without
+         BTF rather than refusing to load. The default behavior with
+         module BTF enabled is to reject modules with such mismatches;
+         this option will still load module BTF where possible but ignore
+         it when a mismatch is found.
+
 config GDB_SCRIPTS
        bool "Provide GDB scripts for kernel debugging"
        help
@@ -416,7 +457,8 @@ config SECTION_MISMATCH_WARN_ONLY
          If unsure, say Y.
 
 config DEBUG_FORCE_FUNCTION_ALIGN_64B
-       bool "Force all function address 64B aligned" if EXPERT
+       bool "Force all function address 64B aligned"
+       depends on EXPERT && (X86_64 || ARM64 || PPC32 || PPC64 || ARC)
        help
          There are cases that a commit from one domain changes the function
          address alignment of other domains, and cause magic performance
@@ -585,20 +627,6 @@ source "lib/Kconfig.kcsan"
 
 endmenu
 
-config DEBUG_KERNEL
-       bool "Kernel debugging"
-       help
-         Say Y here if you are developing drivers or trying to debug and
-         identify kernel problems.
-
-config DEBUG_MISC
-       bool "Miscellaneous debug code"
-       default DEBUG_KERNEL
-       depends on DEBUG_KERNEL
-       help
-         Say Y here if you need to enable miscellaneous debug code that should
-         be under a more specific debug option but isn't.
-
 menu "Networking Debugging"
 
 source "net/Kconfig.debug"
@@ -2123,6 +2151,18 @@ config KPROBES_SANITY_TEST
 
          Say N if you are unsure.
 
+config FPROBE_SANITY_TEST
+       bool "Self test for fprobe"
+       depends on DEBUG_KERNEL
+       depends on FPROBE
+       depends on KUNIT=y
+       help
+         This option will enable testing the fprobe when the system boot.
+         A series of tests are made to verify that the fprobe is functioning
+         properly.
+
+         Say N if you are unsure.
+
 config BACKTRACE_SELF_TEST
        tristate "Self test for the backtrace code"
        depends on DEBUG_KERNEL
@@ -2237,9 +2277,6 @@ config TEST_UUID
 config TEST_XARRAY
        tristate "Test the XArray code at runtime"
 
-config TEST_OVERFLOW
-       tristate "Test check_*_overflow() functions at runtime"
-
 config TEST_RHASHTABLE
        tristate "Perform selftest on resizable hash table"
        help
@@ -2524,6 +2561,30 @@ config MEMCPY_KUNIT_TEST
 
          If unsure, say N.
 
+config OVERFLOW_KUNIT_TEST
+       tristate "Test check_*_overflow() functions at runtime" if !KUNIT_ALL_TESTS
+       depends on KUNIT
+       default KUNIT_ALL_TESTS
+       help
+         Builds unit tests for the check_*_overflow(), size_*(), allocation, and
+         related functions.
+
+         For more information on KUnit and unit tests in general please refer
+         to the KUnit documentation in Documentation/dev-tools/kunit/.
+
+         If unsure, say N.
+
+config STACKINIT_KUNIT_TEST
+       tristate "Test level of stack variable initialization" if !KUNIT_ALL_TESTS
+       depends on KUNIT
+       default KUNIT_ALL_TESTS
+       help
+         Test if the kernel is zero-initializing stack variables and
+         padding. Coverage is controlled by compiler flags,
+         CONFIG_INIT_STACK_ALL_PATTERN, CONFIG_INIT_STACK_ALL_ZERO,
+         CONFIG_GCC_PLUGIN_STRUCTLEAK, CONFIG_GCC_PLUGIN_STRUCTLEAK_BYREF,
+         or CONFIG_GCC_PLUGIN_STRUCTLEAK_BYREF_ALL.
+
 config TEST_UDELAY
        tristate "udelay test driver"
        help
@@ -2615,17 +2676,6 @@ config TEST_OBJAGG
          Enable this option to test object aggregation manager on boot
          (or module load).
 
-
-config TEST_STACKINIT
-       tristate "Test level of stack variable initialization"
-       help
-         Test if the kernel is zero-initializing stack variables and
-         padding. Coverage is controlled by compiler flags,
-         CONFIG_GCC_PLUGIN_STRUCTLEAK, CONFIG_GCC_PLUGIN_STRUCTLEAK_BYREF,
-         or CONFIG_GCC_PLUGIN_STRUCTLEAK_BYREF_ALL.
-
-         If unsure, say N.
-
 config TEST_MEMINIT
        tristate "Test heap/page initialization"
        help