2005-04-17 02:20:36 +04:00
|
|
|
menu "Kernel hacking"
|
|
|
|
|
2006-07-03 11:24:43 +04:00
|
|
|
config TRACE_IRQFLAGS_SUPPORT
|
2007-10-25 02:50:43 +04:00
|
|
|
def_bool y
|
2006-07-03 11:24:43 +04:00
|
|
|
|
2005-04-17 02:20:36 +04:00
|
|
|
source "lib/Kconfig.debug"
|
|
|
|
|
2017-03-21 11:01:30 +03:00
|
|
|
config EARLY_PRINTK_USB
|
|
|
|
bool
|
|
|
|
|
2008-06-18 22:04:35 +04:00
|
|
|
config X86_VERBOSE_BOOTUP
|
|
|
|
bool "Enable verbose x86 bootup info messages"
|
|
|
|
default y
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-06-18 22:04:35 +04:00
|
|
|
Enables the informational output from the decompression stage
|
|
|
|
(e.g. bzImage) of the boot. If you disable this you will still
|
|
|
|
see errors. Disable this if you want silent bootup.
|
|
|
|
|
2005-04-17 02:20:36 +04:00
|
|
|
config EARLY_PRINTK
|
2011-01-21 01:44:16 +03:00
|
|
|
bool "Early printk" if EXPERT
|
2005-04-17 02:20:36 +04:00
|
|
|
default y
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2005-04-17 02:20:36 +04:00
|
|
|
Write kernel log output directly into the VGA buffer or to a serial
|
|
|
|
port.
|
|
|
|
|
|
|
|
This is useful for kernel debugging when your machine crashes very
|
|
|
|
early before the console code is initialized. For normal operation
|
|
|
|
it is not recommended because it looks ugly and doesn't cooperate
|
2017-03-21 11:01:30 +03:00
|
|
|
with klogd/syslogd or the X server. You should normally say N here,
|
2005-04-17 02:20:36 +04:00
|
|
|
unless you want to debug such a crash.
|
|
|
|
|
2008-07-25 04:29:40 +04:00
|
|
|
config EARLY_PRINTK_DBGP
|
|
|
|
bool "Early printk via EHCI debug port"
|
2008-07-26 19:28:11 +04:00
|
|
|
depends on EARLY_PRINTK && PCI
|
2017-03-21 11:01:30 +03:00
|
|
|
select EARLY_PRINTK_USB
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-07-25 04:29:40 +04:00
|
|
|
Write kernel log output directly into the EHCI debug port.
|
|
|
|
|
|
|
|
This is useful for kernel debugging when your machine crashes very
|
|
|
|
early before the console code is initialized. For normal operation
|
|
|
|
it is not recommended because it looks ugly and doesn't cooperate
|
2017-03-21 11:01:30 +03:00
|
|
|
with klogd/syslogd or the X server. You should normally say N here,
|
2008-07-25 04:29:40 +04:00
|
|
|
unless you want to debug such a crash. You need usb debug device.
|
|
|
|
|
2013-10-04 12:36:56 +04:00
|
|
|
config EARLY_PRINTK_EFI
|
|
|
|
bool "Early printk via the EFI framebuffer"
|
|
|
|
depends on EFI && EARLY_PRINTK
|
|
|
|
select FONT_SUPPORT
|
|
|
|
---help---
|
|
|
|
Write kernel log output directly into the EFI framebuffer.
|
|
|
|
|
|
|
|
This is useful for kernel debugging when your machine crashes very
|
|
|
|
early before the console code is initialized.
|
|
|
|
|
2017-03-21 11:01:30 +03:00
|
|
|
config EARLY_PRINTK_USB_XDBC
|
|
|
|
bool "Early printk via the xHCI debug port"
|
|
|
|
depends on EARLY_PRINTK && PCI
|
|
|
|
select EARLY_PRINTK_USB
|
|
|
|
---help---
|
|
|
|
Write kernel log output directly into the xHCI debug port.
|
|
|
|
|
|
|
|
One use for this feature is kernel debugging, for example when your
|
|
|
|
machine crashes very early before the regular console code is
|
|
|
|
initialized. Other uses include simpler, lockless logging instead of
|
|
|
|
a full-blown printk console driver + klogd.
|
|
|
|
|
|
|
|
For normal production environments this is normally not recommended,
|
|
|
|
because it doesn't feed events into klogd/syslogd and doesn't try to
|
|
|
|
print anything on the screen.
|
|
|
|
|
|
|
|
You should normally say N here, unless you want to debug early
|
|
|
|
crashes or need a very simple printk logging facility.
|
|
|
|
|
2015-10-05 19:55:20 +03:00
|
|
|
config X86_PTDUMP_CORE
|
|
|
|
def_bool n
|
|
|
|
|
2008-04-17 19:40:45 +04:00
|
|
|
config X86_PTDUMP
|
2015-11-20 04:07:55 +03:00
|
|
|
tristate "Export kernel pagetable layout to userspace via debugfs"
|
2008-04-17 19:40:45 +04:00
|
|
|
depends on DEBUG_KERNEL
|
2008-04-17 19:40:45 +04:00
|
|
|
select DEBUG_FS
|
2015-10-05 19:55:20 +03:00
|
|
|
select X86_PTDUMP_CORE
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-04-17 19:40:45 +04:00
|
|
|
Say Y here if you want to show the kernel pagetable layout in a
|
|
|
|
debugfs file. This information is only useful for kernel developers
|
|
|
|
who are working in architecture specific areas of the kernel.
|
|
|
|
It is probably not a good idea to enable this feature in a production
|
|
|
|
kernel.
|
|
|
|
If in doubt, say "N"
|
|
|
|
|
2014-01-18 15:48:15 +04:00
|
|
|
config EFI_PGT_DUMP
|
|
|
|
bool "Dump the EFI pagetable"
|
2015-10-05 19:55:20 +03:00
|
|
|
depends on EFI
|
|
|
|
select X86_PTDUMP_CORE
|
2014-01-18 15:48:15 +04:00
|
|
|
---help---
|
|
|
|
Enable this if you want to dump the EFI page table before
|
|
|
|
enabling virtual mode. This can be used to debug miscellaneous
|
|
|
|
issues with the mapping of the EFI runtime regions into that
|
|
|
|
table.
|
|
|
|
|
2015-10-05 19:55:20 +03:00
|
|
|
config DEBUG_WX
|
|
|
|
bool "Warn on W+X mappings at boot"
|
|
|
|
select X86_PTDUMP_CORE
|
|
|
|
---help---
|
|
|
|
Generate a warning if any W+X mappings are found at boot.
|
|
|
|
|
|
|
|
This is useful for discovering cases where the kernel is leaving
|
|
|
|
W+X mappings after applying NX, as such mappings are a security risk.
|
|
|
|
|
|
|
|
Look for a message in dmesg output like this:
|
|
|
|
|
|
|
|
x86/mm: Checked W+X mappings: passed, no W+X pages found.
|
|
|
|
|
|
|
|
or like this, if the check failed:
|
|
|
|
|
|
|
|
x86/mm: Checked W+X mappings: FAILED, <N> W+X pages found.
|
|
|
|
|
|
|
|
Note that even if the check fails, your kernel is possibly
|
|
|
|
still fine, as W+X mappings are not a security hole in
|
|
|
|
themselves, what they do is that they make the exploitation
|
|
|
|
of other unfixed kernel bugs easier.
|
|
|
|
|
|
|
|
There is no runtime or memory usage effect of this option
|
|
|
|
once the kernel has booted up - it's a one time check.
|
|
|
|
|
|
|
|
If in doubt, say "Y".
|
|
|
|
|
2006-04-18 14:35:22 +04:00
|
|
|
config DOUBLEFAULT
|
|
|
|
default y
|
2011-01-21 01:44:16 +03:00
|
|
|
bool "Enable doublefault exception handler" if EXPERT
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2007-10-25 02:50:43 +04:00
|
|
|
This option allows trapping of rare doublefault exceptions that
|
|
|
|
would otherwise cause a system to silently reboot. Disabling this
|
|
|
|
option saves about 4k and might cause you much additional grey
|
|
|
|
hair.
|
|
|
|
|
2012-06-28 05:02:20 +04:00
|
|
|
config DEBUG_TLBFLUSH
|
|
|
|
bool "Set upper limit of TLB entries to flush one-by-one"
|
2013-03-14 15:54:37 +04:00
|
|
|
depends on DEBUG_KERNEL
|
2012-06-28 05:02:20 +04:00
|
|
|
---help---
|
|
|
|
|
|
|
|
X86-only for now.
|
|
|
|
|
|
|
|
This option allows the user to tune the amount of TLB entries the
|
|
|
|
kernel flushes one-by-one instead of doing a full TLB flush. In
|
|
|
|
certain situations, the former is cheaper. This is controlled by the
|
|
|
|
tlb_flushall_shift knob under /sys/kernel/debug/x86. If you set it
|
|
|
|
to -1, the code flushes the whole TLB unconditionally. Otherwise,
|
|
|
|
for positive values of it, the kernel will use single TLB entry
|
|
|
|
invalidating instructions according to the following formula:
|
|
|
|
|
|
|
|
flush_entries <= active_tlb_entries / 2^tlb_flushall_shift
|
|
|
|
|
|
|
|
If in doubt, say "N".
|
|
|
|
|
2007-10-25 02:50:43 +04:00
|
|
|
config IOMMU_DEBUG
|
|
|
|
bool "Enable IOMMU debugging"
|
2007-10-24 14:49:48 +04:00
|
|
|
depends on GART_IOMMU && DEBUG_KERNEL
|
2007-10-25 02:50:43 +04:00
|
|
|
depends on X86_64
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2007-10-25 02:50:43 +04:00
|
|
|
Force the IOMMU to on even when you have less than 4GB of
|
|
|
|
memory and add debugging code. On overflow always panic. And
|
|
|
|
allow to enable IOMMU leak tracing. Can be disabled at boot
|
|
|
|
time with iommu=noforce. This will also enable scatter gather
|
|
|
|
list merging. Currently not recommended for production
|
|
|
|
code. When you use it make sure you have a big enough
|
|
|
|
IOMMU/AGP aperture. Most of the options enabled by this can
|
|
|
|
be set more finegrained using the iommu= command line
|
2011-08-15 04:02:26 +04:00
|
|
|
options. See Documentation/x86/x86_64/boot-options.txt for more
|
2007-10-25 02:50:43 +04:00
|
|
|
details.
|
|
|
|
|
2009-05-22 14:15:49 +04:00
|
|
|
config IOMMU_STRESS
|
|
|
|
bool "Enable IOMMU stress-test mode"
|
|
|
|
---help---
|
|
|
|
This option disables various optimizations in IOMMU related
|
|
|
|
code to do real stress testing of the IOMMU code. This option
|
|
|
|
will cause a performance drop and should only be enabled for
|
|
|
|
testing.
|
|
|
|
|
2007-10-25 02:50:43 +04:00
|
|
|
config IOMMU_LEAK
|
|
|
|
bool "IOMMU leak tracing"
|
2009-04-14 04:43:19 +04:00
|
|
|
depends on IOMMU_DEBUG && DMA_API_DEBUG
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2007-10-25 02:50:43 +04:00
|
|
|
Add a simple leak tracer to the IOMMU code. This is useful when you
|
|
|
|
are debugging a buggy device driver that leaks IOMMU mappings.
|
|
|
|
|
2009-01-03 22:23:51 +03:00
|
|
|
config HAVE_MMIOTRACE_SUPPORT
|
|
|
|
def_bool y
|
2008-05-12 23:20:56 +04:00
|
|
|
|
2009-08-14 00:34:21 +04:00
|
|
|
config X86_DECODER_SELFTEST
|
2009-12-06 14:14:29 +03:00
|
|
|
bool "x86 instruction decoder selftest"
|
|
|
|
depends on DEBUG_KERNEL && KPROBES
|
2014-02-05 09:51:37 +04:00
|
|
|
depends on !COMPILE_TEST
|
2009-08-14 00:34:21 +04:00
|
|
|
---help---
|
|
|
|
Perform x86 instruction decoder selftests at build time.
|
|
|
|
This option is useful for checking the sanity of x86 instruction
|
|
|
|
decoder code.
|
|
|
|
If unsure, say "N".
|
|
|
|
|
2008-01-30 15:30:05 +03:00
|
|
|
#
|
|
|
|
# IO delay types:
|
|
|
|
#
|
|
|
|
|
|
|
|
config IO_DELAY_TYPE_0X80
|
|
|
|
int
|
|
|
|
default "0"
|
|
|
|
|
|
|
|
config IO_DELAY_TYPE_0XED
|
|
|
|
int
|
|
|
|
default "1"
|
|
|
|
|
|
|
|
config IO_DELAY_TYPE_UDELAY
|
|
|
|
int
|
|
|
|
default "2"
|
|
|
|
|
|
|
|
config IO_DELAY_TYPE_NONE
|
|
|
|
int
|
|
|
|
default "3"
|
|
|
|
|
|
|
|
choice
|
|
|
|
prompt "IO delay type"
|
2008-02-17 22:20:24 +03:00
|
|
|
default IO_DELAY_0X80
|
2008-01-30 15:30:05 +03:00
|
|
|
|
|
|
|
config IO_DELAY_0X80
|
|
|
|
bool "port 0x80 based port-IO delay [recommended]"
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-01-30 15:30:05 +03:00
|
|
|
This is the traditional Linux IO delay used for in/out_p.
|
|
|
|
It is the most tested hence safest selection here.
|
|
|
|
|
|
|
|
config IO_DELAY_0XED
|
|
|
|
bool "port 0xed based port-IO delay"
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-01-30 15:30:05 +03:00
|
|
|
Use port 0xed as the IO delay. This frees up port 0x80 which is
|
|
|
|
often used as a hardware-debug port.
|
|
|
|
|
|
|
|
config IO_DELAY_UDELAY
|
|
|
|
bool "udelay based port-IO delay"
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-01-30 15:30:05 +03:00
|
|
|
Use udelay(2) as the IO delay method. This provides the delay
|
|
|
|
while not having any side-effect on the IO port space.
|
|
|
|
|
|
|
|
config IO_DELAY_NONE
|
|
|
|
bool "no port-IO delay"
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-01-30 15:30:05 +03:00
|
|
|
No port-IO delay. Will break on old boxes that require port-IO
|
|
|
|
delay for certain operations. Should work on most new machines.
|
|
|
|
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
if IO_DELAY_0X80
|
|
|
|
config DEFAULT_IO_DELAY_TYPE
|
|
|
|
int
|
|
|
|
default IO_DELAY_TYPE_0X80
|
|
|
|
endif
|
|
|
|
|
|
|
|
if IO_DELAY_0XED
|
|
|
|
config DEFAULT_IO_DELAY_TYPE
|
|
|
|
int
|
|
|
|
default IO_DELAY_TYPE_0XED
|
|
|
|
endif
|
|
|
|
|
|
|
|
if IO_DELAY_UDELAY
|
|
|
|
config DEFAULT_IO_DELAY_TYPE
|
|
|
|
int
|
|
|
|
default IO_DELAY_TYPE_UDELAY
|
|
|
|
endif
|
|
|
|
|
|
|
|
if IO_DELAY_NONE
|
|
|
|
config DEFAULT_IO_DELAY_TYPE
|
|
|
|
int
|
|
|
|
default IO_DELAY_TYPE_NONE
|
|
|
|
endif
|
2008-01-30 15:30:05 +03:00
|
|
|
|
2008-01-30 15:32:51 +03:00
|
|
|
config DEBUG_BOOT_PARAMS
|
|
|
|
bool "Debug boot parameters"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
depends on DEBUG_FS
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-01-30 15:32:51 +03:00
|
|
|
This option will cause struct boot_params to be exported via debugfs.
|
|
|
|
|
2008-01-30 15:33:42 +03:00
|
|
|
config CPA_DEBUG
|
2008-02-07 00:39:45 +03:00
|
|
|
bool "CPA self-test code"
|
2008-01-30 15:34:04 +03:00
|
|
|
depends on DEBUG_KERNEL
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-02-07 00:39:45 +03:00
|
|
|
Do change_page_attr() self-tests every 30 seconds.
|
2008-01-30 15:33:42 +03:00
|
|
|
|
2008-03-03 14:38:52 +03:00
|
|
|
config OPTIMIZE_INLINING
|
|
|
|
bool "Allow gcc to uninline functions marked 'inline'"
|
2009-02-05 18:21:53 +03:00
|
|
|
---help---
|
2008-03-03 14:38:52 +03:00
|
|
|
This option determines if the kernel forces gcc to inline the functions
|
|
|
|
developers have marked 'inline'. Doing so takes away freedom from gcc to
|
|
|
|
do what it thinks is best, which is desirable for the gcc 3.x series of
|
|
|
|
compilers. The gcc 4.x series have a rewritten inlining algorithm and
|
2008-10-11 23:27:53 +04:00
|
|
|
enabling this option will generate a smaller kernel there. Hopefully
|
|
|
|
this algorithm is so good that allowing gcc 4.x and above to make the
|
|
|
|
decision will become the default in the future. Until then this option
|
|
|
|
is there to test gcc for this.
|
2008-04-30 10:48:45 +04:00
|
|
|
|
2008-07-18 18:30:05 +04:00
|
|
|
If unsure, say N.
|
|
|
|
|
2015-07-15 20:29:41 +03:00
|
|
|
config DEBUG_ENTRY
|
|
|
|
bool "Debug low-level entry code"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
---help---
|
|
|
|
This option enables sanity checks in x86's low-level entry code.
|
|
|
|
Some of these sanity checks may slow down kernel entries and
|
|
|
|
exits or otherwise impact performance.
|
|
|
|
|
|
|
|
If unsure, say N.
|
|
|
|
|
2011-10-13 23:14:26 +04:00
|
|
|
config DEBUG_NMI_SELFTEST
|
|
|
|
bool "NMI Selftest"
|
2011-12-08 01:06:30 +04:00
|
|
|
depends on DEBUG_KERNEL && X86_LOCAL_APIC
|
2011-10-13 23:14:26 +04:00
|
|
|
---help---
|
|
|
|
Enabling this option turns on a quick NMI selftest to verify
|
|
|
|
that the NMI behaves correctly.
|
|
|
|
|
|
|
|
This might help diagnose strange hangs that rely on NMI to
|
|
|
|
function properly.
|
|
|
|
|
|
|
|
If unsure, say N.
|
|
|
|
|
2015-01-30 19:29:38 +03:00
|
|
|
config DEBUG_IMR_SELFTEST
|
|
|
|
bool "Isolated Memory Region self test"
|
|
|
|
default n
|
|
|
|
depends on INTEL_IMR
|
|
|
|
---help---
|
|
|
|
This option enables automated sanity testing of the IMR code.
|
|
|
|
Some simple tests are run to verify IMR bounds checking, alignment
|
|
|
|
and overlapping. This option is really only useful if you are
|
|
|
|
debugging an IMR memory map or are modifying the IMR code and want to
|
|
|
|
test your changes.
|
|
|
|
|
|
|
|
If unsure say N here.
|
|
|
|
|
2015-05-05 12:34:49 +03:00
|
|
|
config X86_DEBUG_FPU
|
|
|
|
bool "Debug the x86 FPU code"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
default y
|
|
|
|
---help---
|
|
|
|
If this option is enabled then there will be extra sanity
|
|
|
|
checks and (boot time) debug printouts added to the kernel.
|
|
|
|
This debugging adds some small amount of runtime overhead
|
|
|
|
to the kernel.
|
|
|
|
|
|
|
|
If unsure, say N.
|
|
|
|
|
2015-05-06 22:15:54 +03:00
|
|
|
config PUNIT_ATOM_DEBUG
|
|
|
|
tristate "ATOM Punit debug driver"
|
|
|
|
select DEBUG_FS
|
|
|
|
select IOSF_MBI
|
|
|
|
---help---
|
|
|
|
This is a debug driver, which gets the power states
|
|
|
|
of all Punit North Complex devices. The power states of
|
|
|
|
each device is exposed as part of the debugfs interface.
|
|
|
|
The current power state can be read from
|
|
|
|
/sys/kernel/debug/punit_atom/dev_power_state
|
|
|
|
|
2017-07-25 02:36:57 +03:00
|
|
|
config ORC_UNWINDER
|
|
|
|
bool "ORC unwinder"
|
2017-07-25 02:36:58 +03:00
|
|
|
depends on X86_64 && !FRAME_POINTER
|
2017-07-25 02:36:57 +03:00
|
|
|
select STACK_VALIDATION
|
|
|
|
---help---
|
|
|
|
This option enables the ORC (Oops Rewind Capability) unwinder for
|
|
|
|
unwinding kernel stack traces. It uses a custom data format which is
|
|
|
|
a simplified version of the DWARF Call Frame Information standard.
|
|
|
|
|
|
|
|
This unwinder is more accurate across interrupt entry frames than the
|
2017-07-25 02:36:58 +03:00
|
|
|
frame pointer unwinder. It also enables a 5-10% performance
|
|
|
|
improvement across the entire kernel compared to frame pointers.
|
2017-07-25 02:36:57 +03:00
|
|
|
|
|
|
|
Enabling this option will increase the kernel's runtime memory usage
|
|
|
|
by roughly 2-4MB, depending on your kernel config.
|
|
|
|
|
|
|
|
config FRAME_POINTER_UNWINDER
|
|
|
|
def_bool y
|
|
|
|
depends on !ORC_UNWINDER && FRAME_POINTER
|
|
|
|
|
|
|
|
config GUESS_UNWINDER
|
|
|
|
def_bool y
|
|
|
|
depends on !ORC_UNWINDER && !FRAME_POINTER
|
|
|
|
|
2008-04-30 10:48:45 +04:00
|
|
|
endmenu
|