2005-04-16 16:20:36 -06:00
|
|
|
menu "Kernel hacking"
|
|
|
|
|
2006-07-03 01:24:43 -06:00
|
|
|
config TRACE_IRQFLAGS_SUPPORT
|
|
|
|
bool
|
|
|
|
default y
|
|
|
|
|
2005-04-16 16:20:36 -06:00
|
|
|
source "lib/Kconfig.debug"
|
|
|
|
|
|
|
|
config EARLY_PRINTK
|
|
|
|
bool "Early printk" if EMBEDDED && DEBUG_KERNEL
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
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
|
|
|
|
with klogd/syslogd or the X server. You should normally N here,
|
|
|
|
unless you want to debug such a crash.
|
|
|
|
|
|
|
|
config DEBUG_STACKOVERFLOW
|
|
|
|
bool "Check for stack overflows"
|
|
|
|
depends on DEBUG_KERNEL
|
2005-07-27 12:44:23 -06:00
|
|
|
help
|
|
|
|
This option will cause messages to be printed if free stack space
|
|
|
|
drops below a certain limit.
|
2005-04-16 16:20:36 -06:00
|
|
|
|
|
|
|
config DEBUG_STACK_USAGE
|
|
|
|
bool "Stack utilization instrumentation"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
help
|
|
|
|
Enables the display of the minimum amount of free stack which each
|
|
|
|
task has ever had available in the sysrq-T and sysrq-P debug output.
|
|
|
|
|
|
|
|
This option will slow down process creation somewhat.
|
|
|
|
|
|
|
|
comment "Page alloc debug is incompatible with Software Suspend on i386"
|
|
|
|
depends on DEBUG_KERNEL && SOFTWARE_SUSPEND
|
|
|
|
|
|
|
|
config DEBUG_PAGEALLOC
|
2006-03-25 04:07:22 -07:00
|
|
|
bool "Debug page memory allocations"
|
2006-03-25 04:06:50 -07:00
|
|
|
depends on DEBUG_KERNEL && !SOFTWARE_SUSPEND && !HUGETLBFS
|
2005-04-16 16:20:36 -06:00
|
|
|
help
|
|
|
|
Unmap pages from the kernel linear mapping after free_pages().
|
|
|
|
This results in a large slowdown, but helps to find certain types
|
|
|
|
of memory corruptions.
|
|
|
|
|
2006-01-06 01:12:02 -07:00
|
|
|
config DEBUG_RODATA
|
|
|
|
bool "Write protect kernel read-only data structures"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
help
|
|
|
|
Mark the kernel read-only data as write-protected in the pagetables,
|
|
|
|
in order to catch accidental (and incorrect) writes to such const
|
|
|
|
data. This option may have a slight performance impact because a
|
|
|
|
portion of the kernel code won't be covered by a 2MB TLB anymore.
|
|
|
|
If in doubt, say "N".
|
|
|
|
|
2005-04-16 16:20:36 -06:00
|
|
|
config 4KSTACKS
|
|
|
|
bool "Use 4Kb for kernel stacks instead of 8Kb"
|
|
|
|
depends on DEBUG_KERNEL
|
|
|
|
help
|
|
|
|
If you say Y here the kernel will use a 4Kb stacksize for the
|
|
|
|
kernel stack attached to each process/thread. This facilitates
|
|
|
|
running more threads on a system and also reduces the pressure
|
|
|
|
on the VM subsystem for higher order allocations. This option
|
|
|
|
will also use IRQ stacks to compensate for the reduced stackspace.
|
|
|
|
|
|
|
|
config X86_FIND_SMP_CONFIG
|
|
|
|
bool
|
|
|
|
depends on X86_LOCAL_APIC || X86_VOYAGER
|
|
|
|
default y
|
|
|
|
|
|
|
|
config X86_MPPARSE
|
|
|
|
bool
|
|
|
|
depends on X86_LOCAL_APIC && !X86_VISWS
|
|
|
|
default y
|
|
|
|
|
2006-04-18 04:35:22 -06:00
|
|
|
config DOUBLEFAULT
|
|
|
|
default y
|
|
|
|
bool "Enable doublefault exception handler" if EMBEDDED
|
|
|
|
help
|
|
|
|
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.
|
|
|
|
|
2006-12-06 18:14:08 -07:00
|
|
|
config DEBUG_PARAVIRT
|
|
|
|
bool "Enable some paravirtualization debugging"
|
2007-02-13 05:26:22 -07:00
|
|
|
default n
|
2006-12-06 18:14:08 -07:00
|
|
|
depends on PARAVIRT && DEBUG_KERNEL
|
|
|
|
help
|
|
|
|
Currently deliberately clobbers regs which are allowed to be
|
|
|
|
clobbered in inlined paravirt hooks, even in native mode.
|
|
|
|
If turning this off solves a problem, then DISABLE_INTERRUPTS() or
|
|
|
|
ENABLE_INTERRUPTS() is lying about what registers can be clobbered.
|
|
|
|
|
2005-04-16 16:20:36 -06:00
|
|
|
endmenu
|