Kconfig.debug 5.7 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4
menu "Kernel hacking"

source "lib/Kconfig.debug"

5 6 7 8 9 10 11 12 13 14 15 16 17 18
config STRICT_DEVMEM
	bool "Filter access to /dev/mem"
	depends on MMU
	---help---
	  If this option is disabled, you allow userspace (root) access to all
	  of memory, including kernel and userspace memory. Accidental
	  access to this is obviously disastrous, but specific access can
	  be used by people debugging the kernel.

	  If this option is switched on, the /dev/mem file only allows
	  userspace access to memory mapped peripherals.

          If in doubt, say Y.

19
# RMK wants arm kernels compiled with frame pointers or stack unwinding.
L
Linus Torvalds 已提交
20 21 22 23 24
# If you know what you are doing and are willing to live without stack
# traces, you can get a slightly smaller kernel by setting this option to
# n, but then RMK will have to kill you ;).
config FRAME_POINTER
	bool
25
	depends on !THUMB2_KERNEL
26
	default y if !ARM_UNWIND || FUNCTION_GRAPH_TRACER
L
Linus Torvalds 已提交
27 28
	help
	  If you say N here, the resulting kernel will be slightly smaller and
29 30 31 32 33
	  faster. However, if neither FRAME_POINTER nor ARM_UNWIND are enabled,
	  when a problem occurs with the kernel, the information that is
	  reported is severely limited.

config ARM_UNWIND
34
	bool "Enable stack unwinding support (EXPERIMENTAL)"
35 36 37 38 39 40 41 42
	depends on AEABI && EXPERIMENTAL
	default y
	help
	  This option enables stack unwinding support in the kernel
	  using the information automatically generated by the
	  compiler. The resulting kernel image is slightly bigger but
	  the performance is not affected. Currently, this feature
	  only works with EABI compilers. If unsure say Y.
L
Linus Torvalds 已提交
43

44 45 46 47 48
config OLD_MCOUNT
	bool
	depends on FUNCTION_TRACER && FRAME_POINTER
	default y

L
Linus Torvalds 已提交
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
config DEBUG_USER
	bool "Verbose user fault messages"
	help
	  When a user program crashes due to an exception, the kernel can
	  print a brief message explaining what the problem was. This is
	  sometimes helpful for debugging but serves no purpose on a
	  production system. Most people should say N here.

	  In addition, you need to pass user_debug=N on the kernel command
	  line to enable this feature.  N consists of the sum of:

	      1 - undefined instruction events
	      2 - system calls
	      4 - invalid data aborts
	      8 - SIGSEGV faults
	     16 - SIGBUS faults

# These options are only for real kernel hackers who want to get their hands dirty.
config DEBUG_LL
68
	bool "Kernel low-level debugging functions (read help!)"
L
Linus Torvalds 已提交
69 70
	depends on DEBUG_KERNEL
	help
71
	  Say Y here to include definitions of printascii, printch, printhex
L
Linus Torvalds 已提交
72 73 74
	  in the kernel.  This is helpful if you are debugging code that
	  executes before the console is initialized.

75 76 77 78 79
	  Note that selecting this option will limit the kernel to a single
	  UART definition, as specified below. Attempting to boot the kernel
	  image on a different platform *will not work*, so this option should
	  not be enabled for kernels that are intended to be portable.

80 81 82 83
choice
	prompt "Kernel low-level debugging port"
	depends on DEBUG_LL

84 85 86 87 88 89 90 91
	config DEBUG_LL_UART_NONE
		bool "No low-level debugging UART"
		help
		  Say Y here if your platform doesn't provide a UART option
		  below. This relies on your platform choosing the right UART
		  definition internally in order for low-level debugging to
		  work.

92 93 94 95 96 97 98 99
	config DEBUG_ICEDCC
		bool "Kernel low-level debugging via EmbeddedICE DCC channel"
		help
		  Say Y here if you want the debug print routines to direct
		  their output to the EmbeddedICE macrocell's DCC channel using
		  co-processor 14. This is known to work on the ARM9 style ICE
		  channel and on the XScale with the PEEDI.

100 101
		  Note that the system will appear to hang during boot if there
		  is nothing connected to read from the DCC.
102 103 104 105 106 107 108 109

	config DEBUG_FOOTBRIDGE_COM1
		bool "Kernel low-level debugging messages via footbridge 8250 at PCI COM1"
		depends on FOOTBRIDGE
		help
		  Say Y here if you want the debug print routines to direct
		  their output to the 8250 at PCI COM1.

110 111 112 113 114 115
	config DEBUG_DC21285_PORT
		bool "Kernel low-level debugging messages via footbridge serial port"
		depends on FOOTBRIDGE
		help
		  Say Y here if you want the debug print routines to direct
		  their output to the serial port in the DC21285 (Footbridge).
116 117 118 119 120 121 122

	config DEBUG_CLPS711X_UART1
		bool "Kernel low-level debugging messages via UART1"
		depends on ARCH_CLPS711X
		help
		  Say Y here if you want the debug print routines to direct
		  their output to the first serial port on these devices.
123 124 125 126 127 128 129 130

	config DEBUG_CLPS711X_UART2
		bool "Kernel low-level debugging messages via UART2"
		depends on ARCH_CLPS711X
		help
		  Say Y here if you want the debug print routines to direct
		  their output to the second serial port on these devices.

131 132 133 134 135 136 137
	config DEBUG_HIGHBANK_UART
		bool "Kernel low-level debugging messages via Highbank UART"
		depends on ARCH_HIGHBANK
		help
		  Say Y here if you want the debug print routines to direct
		  their output to the UART on Highbank based devices.

138 139
endchoice

140 141 142 143 144 145 146 147
config EARLY_PRINTK
	bool "Early printk"
	depends on DEBUG_LL
	help
	  Say Y here if you want to have an early console using the
	  kernel low-level debugging functions. Add earlyprintk to your
	  kernel parameters to enable this console.

148 149 150 151 152 153 154 155
config OC_ETM
	bool "On-chip ETM and ETB"
	select ARM_AMBA
	help
	  Enables the on-chip embedded trace macrocell and embedded trace
	  buffer driver that will allow you to collect traces of the
	  kernel code.

156
config DEBUG_S3C_UART
157
	depends on PLAT_SAMSUNG
158
	int "S3C UART to use for low-level debug"
L
Linus Torvalds 已提交
159 160
	default "0"
	help
161
	  Choice for UART for kernel low-level using S3C UARTS,
L
Linus Torvalds 已提交
162
	  should be between zero and two. The port must have been
E
Egry Gabor 已提交
163
	  initialised by the boot-loader before use.
L
Linus Torvalds 已提交
164 165

	  The uncompressor code port configuration is now handled
166
	  by CONFIG_S3C_LOWLEVEL_UART_PORT.
L
Linus Torvalds 已提交
167

168 169 170 171 172 173
config ARM_KPROBES_TEST
	tristate "Kprobes test module"
	depends on KPROBES && MODULES
	help
	  Perform tests of kprobes API and instruction set simulation.

L
Linus Torvalds 已提交
174
endmenu