blob: f7e362c9d76df47d84c4754418c5ac626b1afc56 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001menu "Kernel hacking"
2
Paul Mundtafbfb522006-12-04 18:17:28 +09003config TRACE_IRQFLAGS_SUPPORT
4 bool
5 default y
6
Linus Torvalds1da177e2005-04-16 15:20:36 -07007source "lib/Kconfig.debug"
8
9config SH_STANDARD_BIOS
10 bool "Use LinuxSH standard BIOS"
11 help
12 Say Y here if your target has the gdb-sh-stub
13 package from www.m17n.org (or any conforming standard LinuxSH BIOS)
14 in FLASH or EPROM. The kernel will use standard BIOS calls during
15 boot for various housekeeping tasks (including calls to read and
16 write characters to a system console, get a MAC address from an
17 on-board Ethernet interface, and shut down the hardware). Note this
18 does not work with machines with an existing operating system in
19 mask ROM and no flash (WindowsCE machines fall in this category).
20 If unsure, say N.
21
22config EARLY_SCIF_CONSOLE
23 bool "Use early SCIF console"
Paul Mundt6fc21b82006-11-27 12:10:23 +090024 help
25 This enables an early console using a fixed SCIF port. This can
26 be used by platforms that are either not running the SH
27 standard BIOS, or do not wish to use the BIOS callbacks for the
28 serial I/O.
29
30config EARLY_SCIF_CONSOLE_PORT
Paul Mundt8d797cd2007-08-07 18:52:29 +090031 hex
Paul Mundt6fc21b82006-11-27 12:10:23 +090032 depends on EARLY_SCIF_CONSOLE
33 default "0xffe00000" if CPU_SUBTYPE_SH7780
Magnus Damm5cbc3af2007-09-10 12:05:10 +090034 default "0xffea0000" if CPU_SUBTYPE_SH7785
Paul Mundt6d01f512007-11-26 18:17:21 +090035 default "0xfffe8000" if CPU_SUBTYPE_SH7203
Yoshinori Sato11cbb702006-12-07 18:07:27 +090036 default "0xfffe9800" if CPU_SUBTYPE_SH7206
37 default "0xf8420000" if CPU_SUBTYPE_SH7619
Nobuhiro Iwamatsu2a8ff452007-04-26 11:51:00 +090038 default "0xa4400000" if CPU_SUBTYPE_SH7712 || CPU_SUBTYPE_SH7705
Markus Brunner3ea6bc32007-08-20 08:59:33 +090039 default "0xa4430000" if CPU_SUBTYPE_SH7720
Paul Mundt8d797cd2007-08-07 18:52:29 +090040 default "0xffc30000" if CPU_SUBTYPE_SHX3
Paul Mundt6fc21b82006-11-27 12:10:23 +090041 default "0xffe80000" if CPU_SH4
Paul Mundt8d797cd2007-08-07 18:52:29 +090042 default "0x00000000"
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
44config EARLY_PRINTK
45 bool "Early printk support"
46 depends on SH_STANDARD_BIOS || EARLY_SCIF_CONSOLE
47 help
48 Say Y here to redirect kernel printk messages to the serial port
49 used by the SH-IPL bootloader, starting very early in the boot
50 process and ending when the kernel's serial console is initialised.
51 This option is only useful porting the kernel to a new machine,
52 when the kernel may crash or hang before the serial console is
53 initialised. If unsure, say N.
54
Paul Mundt6fc21b82006-11-27 12:10:23 +090055 On devices that are running SH-IPL and want to keep the port
56 initialization consistent while not using the BIOS callbacks,
57 select both the EARLY_SCIF_CONSOLE and SH_STANDARD_BIOS, using
58 the kernel command line option to toggle back and forth.
59
Paul Mundt91e656a2007-06-01 14:19:22 +090060config DEBUG_BOOTMEM
61 depends on DEBUG_KERNEL
62 bool "Debug BOOTMEM initialization"
63
Paul Mundtd153ea82006-09-27 18:20:16 +090064config DEBUG_STACKOVERFLOW
65 bool "Check for stack overflows"
Paul Mundt5db141a2007-11-21 17:47:15 +090066 depends on DEBUG_KERNEL && SUPERH32
Paul Mundtd153ea82006-09-27 18:20:16 +090067 help
68 This option will cause messages to be printed if free stack space
69 drops below a certain limit.
70
71config DEBUG_STACK_USAGE
72 bool "Stack utilization instrumentation"
73 depends on DEBUG_KERNEL
74 help
75 Enables the display of the minimum amount of free stack which each
76 task has ever had available in the sysrq-T and sysrq-P debug output.
77
78 This option will slow down process creation somewhat.
79
Paul Mundta6a311392006-09-27 18:22:14 +090080config 4KSTACKS
81 bool "Use 4Kb for kernel stacks instead of 8Kb"
82 depends on DEBUG_KERNEL
83 help
84 If you say Y here the kernel will use a 4Kb stacksize for the
85 kernel stack attached to each process/thread. This facilitates
86 running more threads on a system and also reduces the pressure
87 on the VM subsystem for higher order allocations. This option
88 will also use IRQ stacks to compensate for the reduced stackspace.
89
Paul Mundt110ed282007-11-02 12:16:51 +090090config IRQSTACKS
91 bool "Use separate kernel stacks when processing interrupts"
Paul Mundt5db141a2007-11-21 17:47:15 +090092 depends on DEBUG_KERNEL && SUPERH32
Paul Mundt110ed282007-11-02 12:16:51 +090093 help
94 If you say Y here the kernel will use separate kernel stacks
95 for handling hard and soft interrupts. This can help avoid
96 overflowing the process kernel stacks.
97
Paul Mundtfa5da2f2007-03-08 17:27:37 +090098config SH_KGDB
Linus Torvalds1da177e2005-04-16 15:20:36 -070099 bool "Include KGDB kernel debugger"
Paul Mundt2549b322006-09-27 16:22:33 +0900100 select FRAME_POINTER
Paul Mundtfa5da2f2007-03-08 17:27:37 +0900101 select DEBUG_INFO
Paul Mundt357d5942007-06-11 15:32:07 +0900102 depends on CPU_SH3 || CPU_SH4
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103 help
104 Include in-kernel hooks for kgdb, the Linux kernel source level
105 debugger. See <http://kgdb.sourceforge.net/> for more information.
106 Unless you are intending to debug the kernel, say N here.
107
108menu "KGDB configuration options"
Paul Mundtfa5da2f2007-03-08 17:27:37 +0900109 depends on SH_KGDB
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110
111config MORE_COMPILE_OPTIONS
112 bool "Add any additional compile options"
113 help
114 If you want to add additional CFLAGS to the kernel build, enable this
115 option and then enter what you would like to add in the next question.
116 Note however that -g is already appended with the selection of KGDB.
117
118config COMPILE_OPTIONS
119 string "Additional compile arguments"
120 depends on MORE_COMPILE_OPTIONS
121
122config KGDB_NMI
123 bool "Enter KGDB on NMI"
124 default n
125
Linus Torvalds1da177e2005-04-16 15:20:36 -0700126config SH_KGDB_CONSOLE
127 bool "Console messages through GDB"
Paul Mundt808bde22007-11-06 17:34:33 +0900128 depends on !SERIAL_SH_SCI_CONSOLE && SERIAL_SH_SCI=y
Paul Mundtfa5da2f2007-03-08 17:27:37 +0900129 select SERIAL_CORE_CONSOLE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700130 default n
131
132config KGDB_SYSRQ
133 bool "Allow SysRq 'G' to enter KGDB"
Paul Mundt0acc7292007-11-06 17:50:07 +0900134 depends on MAGIC_SYSRQ
Linus Torvalds1da177e2005-04-16 15:20:36 -0700135 default y
136
Linus Torvalds1da177e2005-04-16 15:20:36 -0700137comment "Serial port setup"
138
139config KGDB_DEFPORT
140 int "Port number (ttySCn)"
141 default "1"
142
143config KGDB_DEFBAUD
144 int "Baud rate"
145 default "115200"
146
147choice
148 prompt "Parity"
Paul Mundtfa5da2f2007-03-08 17:27:37 +0900149 depends on SH_KGDB
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150 default KGDB_DEFPARITY_N
151
152config KGDB_DEFPARITY_N
153 bool "None"
154
155config KGDB_DEFPARITY_E
156 bool "Even"
157
158config KGDB_DEFPARITY_O
159 bool "Odd"
160
161endchoice
162
163choice
164 prompt "Data bits"
Paul Mundtfa5da2f2007-03-08 17:27:37 +0900165 depends on SH_KGDB
Linus Torvalds1da177e2005-04-16 15:20:36 -0700166 default KGDB_DEFBITS_8
167
168config KGDB_DEFBITS_8
169 bool "8"
170
171config KGDB_DEFBITS_7
172 bool "7"
173
174endchoice
175
176endmenu
177
Paul Mundt8214d522007-11-21 16:58:56 +0900178if SUPERH64
179
180config SH64_PROC_ASIDS
181 bool "Debug: report ASIDs through /proc/asids"
182 depends on PROC_FS
183
184config SH64_SR_WATCH
185 bool "Debug: set SR.WATCH to enable hardware watchpoints and trace"
186
187config POOR_MANS_STRACE
188 bool "Debug: enable rudimentary strace facility"
189 help
190 This option allows system calls to be traced to the console. It also
191 aids in detecting kernel stack underflow. It is useful for debugging
192 early-userland problems (e.g. init incurring fatal exceptions.)
193
194config SH_ALPHANUMERIC
195 bool "Enable debug outputs to on-board alphanumeric display"
196 depends on SH_CAYMAN
197
198config SH_NO_BSS_INIT
199 bool "Avoid zeroing BSS (to speed-up startup on suitable platforms)"
200
201endif
202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700203endmenu