blob: fd2c02d614ba7b559bc09029b0c6f4728357c27a [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# For a description of the syntax of this configuration file,
3# see Documentation/kbuild/kconfig-language.txt.
4#
5
6mainmenu "Linux/SuperH Kernel Configuration"
7
8config SUPERH
Paul Mundtea0e1a92007-11-21 15:58:01 +09009 def_bool y
Paul Mundt7a440c92006-09-27 18:18:31 +090010 select EMBEDDED
David Brownell9483a572008-07-23 21:26:48 -070011 select HAVE_CLK
Sam Ravnborgec7748b2008-02-09 10:46:40 +010012 select HAVE_IDE
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050013 select HAVE_OPROFILE
Dmitry Baryshkov9de90ac2008-07-18 13:30:31 +040014 select HAVE_GENERIC_DMA_COHERENT
Paul Mundt21944782008-09-17 23:26:44 +090015 select HAVE_IOREMAP_PROT if MMU
Linus Torvalds1da177e2005-04-16 15:20:36 -070016 help
17 The SuperH is a RISC processor targeted for use in embedded systems
18 and consumer electronics; it was also used in the Sega Dreamcast
19 gaming console. The SuperH port has a home page at
20 <http://www.linux-sh.org/>.
21
Paul Mundt39d28a22007-11-08 18:39:33 +090022config SUPERH32
Paul Mundtea0e1a92007-11-21 15:58:01 +090023 def_bool !SUPERH64
Chris Smithd39f5452008-09-05 17:15:39 +090024 select HAVE_KPROBES
25 select HAVE_KRETPROBES
Paul Mundte7ab3cd2008-09-21 19:04:55 +090026 select HAVE_ARCH_TRACEHOOK
Paul Mundt694f94f2008-10-31 16:20:36 +090027 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090028 select HAVE_FTRACE_MCOUNT_RECORD
29 select HAVE_DYNAMIC_FTRACE
Paul Mundtea0e1a92007-11-21 15:58:01 +090030
31config SUPERH64
32 def_bool y if CPU_SH5
Paul Mundt39d28a22007-11-08 18:39:33 +090033
Paul Mundtf42b7e32008-07-29 20:12:51 +090034config ARCH_DEFCONFIG
35 string
36 default "arch/sh/configs/shx3_defconfig" if SUPERH32
37 default "arch/sh/configs/cayman_defconfig" if SUPERH64
38
Linus Torvalds1da177e2005-04-16 15:20:36 -070039config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090040 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
42config RWSEM_XCHGADD_ALGORITHM
43 bool
44
Paul Mundtfa691512007-03-08 19:41:21 +090045config GENERIC_BUG
46 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090047 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090048
Akinobu Mitae2268c72006-03-26 01:39:35 -080049config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090050 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080051
52config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090053 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080054
Linus Torvalds1da177e2005-04-16 15:20:36 -070055config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090056 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070057
Paul Mundt5093c9a2008-08-04 14:17:13 +090058config GENERIC_HARDIRQS_NO__DO_IRQ
59 def_bool y
Paul Mundtf9d62c02008-12-08 11:45:37 +090060 depends on SUPERH32 && (!SH_DREAMCAST && !SH_SH4202_MICRODEV && \
61 !SH_7751_SYSTEMH && !HD64461)
Paul Mundt5093c9a2008-08-04 14:17:13 +090062
Linus Torvalds1da177e2005-04-16 15:20:36 -070063config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090064 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
Magnus Damm2967dab2008-10-08 20:41:43 +090066config GENERIC_GPIO
67 def_bool n
68
Linus Torvalds1da177e2005-04-16 15:20:36 -070069config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090070 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070071
Paul Mundtcad82442006-01-16 22:14:19 -080072config GENERIC_IOMAP
73 bool
74
Paul Mundt45882142006-10-04 13:21:45 +090075config GENERIC_TIME
76 def_bool n
77
Paul Mundt57be2b42007-05-09 17:33:24 +090078config GENERIC_CLOCKEVENTS
79 def_bool n
80
Paul Mundt8c245942008-08-06 18:37:07 +090081config GENERIC_CLOCKEVENTS_BROADCAST
82 bool
83
Paul Mundtbdcab872008-08-04 14:09:15 +090084config GENERIC_LOCKBREAK
85 def_bool y
86 depends on SMP && PREEMPT
87
Paul Mundt357d5942007-06-11 15:32:07 +090088config SYS_SUPPORTS_PM
89 bool
90
Paul Mundt0a9b0db2007-01-24 21:56:20 +090091config SYS_SUPPORTS_APM_EMULATION
92 bool
Paul Mundt357d5942007-06-11 15:32:07 +090093 select SYS_SUPPORTS_PM
94
95config SYS_SUPPORTS_SMP
96 bool
97
98config SYS_SUPPORTS_NUMA
99 bool
100
101config SYS_SUPPORTS_PCI
102 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900103
Paul Mundtafbfb522006-12-04 18:17:28 +0900104config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900105 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900106
107config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900108 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900109
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900110config HAVE_LATENCYTOP_SUPPORT
111 def_bool y
112 depends on !SMP
113
David Howellsf0d1b0b2006-12-08 02:37:49 -0800114config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900115 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800116
117config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900118 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800119
Paul Mundte257ad02007-07-25 11:18:00 +0900120config ARCH_NO_VIRT_TO_BUS
121 def_bool y
122
Magnus Damme7cc9a72008-02-07 20:18:21 +0900123config IO_TRAPPED
124 bool
125
Linus Torvalds1da177e2005-04-16 15:20:36 -0700126source "init/Kconfig"
127
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700128source "kernel/Kconfig.freezer"
129
Linus Torvalds1da177e2005-04-16 15:20:36 -0700130menu "System type"
131
Paul Mundtb5f42db2007-11-08 18:38:14 +0900132#
133# Processor families
134#
135config CPU_SH2
136 bool
137
138config CPU_SH2A
139 bool
140 select CPU_SH2
141
142config CPU_SH3
143 bool
144 select CPU_HAS_INTEVT
145 select CPU_HAS_SR_RB
146
147config CPU_SH4
148 bool
149 select CPU_HAS_INTEVT
150 select CPU_HAS_SR_RB
151 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
152 select CPU_HAS_FPU if !CPU_SH4AL_DSP
153
154config CPU_SH4A
155 bool
156 select CPU_SH4
157
158config CPU_SH4AL_DSP
159 bool
160 select CPU_SH4A
161 select CPU_HAS_DSP
162
Paul Mundtea0e1a92007-11-21 15:58:01 +0900163config CPU_SH5
164 bool
165 select CPU_HAS_FPU
166
Paul Mundtb5f42db2007-11-08 18:38:14 +0900167config CPU_SHX2
168 bool
169
170config CPU_SHX3
171 bool
172
173choice
174 prompt "Processor sub-type selection"
175
176#
177# Processor subtypes
178#
179
180# SH-2 Processor Support
181
182config CPU_SUBTYPE_SH7619
183 bool "Support SH7619 processor"
184 select CPU_SH2
185
186# SH-2A Processor Support
187
Paul Mundt6d01f512007-11-26 18:17:21 +0900188config CPU_SUBTYPE_SH7203
189 bool "Support SH7203 processor"
190 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900191 select CPU_HAS_FPU
Paul Mundt6d01f512007-11-26 18:17:21 +0900192
Paul Mundtb5f42db2007-11-08 18:38:14 +0900193config CPU_SUBTYPE_SH7206
194 bool "Support SH7206 processor"
195 select CPU_SH2A
196
Paul Mundta8f67f42007-11-26 19:54:02 +0900197config CPU_SUBTYPE_SH7263
198 bool "Support SH7263 processor"
199 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900200 select CPU_HAS_FPU
Paul Mundta8f67f42007-11-26 19:54:02 +0900201
Paul Mundt2ad69902008-03-13 12:52:44 +0900202config CPU_SUBTYPE_MXG
203 bool "Support MX-G processor"
204 select CPU_SH2A
205 help
206 Select MX-G if running on an R8A03022BG part.
207
Paul Mundtb5f42db2007-11-08 18:38:14 +0900208# SH-3 Processor Support
209
210config CPU_SUBTYPE_SH7705
211 bool "Support SH7705 processor"
212 select CPU_SH3
213
214config CPU_SUBTYPE_SH7706
215 bool "Support SH7706 processor"
216 select CPU_SH3
217 help
218 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
219
220config CPU_SUBTYPE_SH7707
221 bool "Support SH7707 processor"
222 select CPU_SH3
223 help
224 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
225
226config CPU_SUBTYPE_SH7708
227 bool "Support SH7708 processor"
228 select CPU_SH3
229 help
230 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
231 if you have a 100 Mhz SH-3 HD6417708R CPU.
232
233config CPU_SUBTYPE_SH7709
234 bool "Support SH7709 processor"
235 select CPU_SH3
236 help
237 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
238
239config CPU_SUBTYPE_SH7710
240 bool "Support SH7710 processor"
241 select CPU_SH3
242 select CPU_HAS_DSP
243 help
244 Select SH7710 if you have a SH3-DSP SH7710 CPU.
245
246config CPU_SUBTYPE_SH7712
247 bool "Support SH7712 processor"
248 select CPU_SH3
249 select CPU_HAS_DSP
250 help
251 Select SH7712 if you have a SH3-DSP SH7712 CPU.
252
253config CPU_SUBTYPE_SH7720
254 bool "Support SH7720 processor"
255 select CPU_SH3
256 select CPU_HAS_DSP
257 help
258 Select SH7720 if you have a SH3-DSP SH7720 CPU.
259
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900260config CPU_SUBTYPE_SH7721
261 bool "Support SH7721 processor"
262 select CPU_SH3
263 select CPU_HAS_DSP
264 help
265 Select SH7721 if you have a SH3-DSP SH7721 CPU.
266
Paul Mundtb5f42db2007-11-08 18:38:14 +0900267# SH-4 Processor Support
268
269config CPU_SUBTYPE_SH7750
270 bool "Support SH7750 processor"
271 select CPU_SH4
272 help
273 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
274
275config CPU_SUBTYPE_SH7091
276 bool "Support SH7091 processor"
277 select CPU_SH4
278 help
279 Select SH7091 if you have an SH-4 based Sega device (such as
280 the Dreamcast, Naomi, and Naomi 2).
281
282config CPU_SUBTYPE_SH7750R
283 bool "Support SH7750R processor"
284 select CPU_SH4
285
286config CPU_SUBTYPE_SH7750S
287 bool "Support SH7750S processor"
288 select CPU_SH4
289
290config CPU_SUBTYPE_SH7751
291 bool "Support SH7751 processor"
292 select CPU_SH4
293 help
294 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
295 or if you have a HD6417751R CPU.
296
297config CPU_SUBTYPE_SH7751R
298 bool "Support SH7751R processor"
299 select CPU_SH4
300
301config CPU_SUBTYPE_SH7760
302 bool "Support SH7760 processor"
303 select CPU_SH4
304
305config CPU_SUBTYPE_SH4_202
306 bool "Support SH4-202 processor"
307 select CPU_SH4
308
309# SH-4A Processor Support
310
Paul Mundt178dd0c2008-04-09 17:56:18 +0900311config CPU_SUBTYPE_SH7723
312 bool "Support SH7723 processor"
313 select CPU_SH4A
314 select CPU_SHX2
315 select ARCH_SPARSEMEM_ENABLE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900316 help
317 Select SH7723 if you have an SH-MobileR2 CPU.
318
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900319config CPU_SUBTYPE_SH7763
320 bool "Support SH7763 processor"
321 select CPU_SH4A
322 help
323 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
324
Paul Mundtb5f42db2007-11-08 18:38:14 +0900325config CPU_SUBTYPE_SH7770
326 bool "Support SH7770 processor"
327 select CPU_SH4A
328
329config CPU_SUBTYPE_SH7780
330 bool "Support SH7780 processor"
331 select CPU_SH4A
332
333config CPU_SUBTYPE_SH7785
334 bool "Support SH7785 processor"
335 select CPU_SH4A
336 select CPU_SHX2
337 select ARCH_SPARSEMEM_ENABLE
338 select SYS_SUPPORTS_NUMA
339
340config CPU_SUBTYPE_SHX3
341 bool "Support SH-X3 processor"
342 select CPU_SH4A
343 select CPU_SHX3
344 select ARCH_SPARSEMEM_ENABLE
345 select SYS_SUPPORTS_NUMA
346 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900347 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900348
349# SH4AL-DSP Processor Support
350
351config CPU_SUBTYPE_SH7343
352 bool "Support SH7343 processor"
353 select CPU_SH4AL_DSP
354
355config CPU_SUBTYPE_SH7722
356 bool "Support SH7722 processor"
357 select CPU_SH4AL_DSP
358 select CPU_SHX2
359 select ARCH_SPARSEMEM_ENABLE
360 select SYS_SUPPORTS_NUMA
361
Magnus Damm9109a302008-02-08 17:31:24 +0900362config CPU_SUBTYPE_SH7366
363 bool "Support SH7366 processor"
364 select CPU_SH4AL_DSP
365 select CPU_SHX2
366 select ARCH_SPARSEMEM_ENABLE
367 select SYS_SUPPORTS_NUMA
368
Paul Mundtea0e1a92007-11-21 15:58:01 +0900369# SH-5 Processor Support
370
371config CPU_SUBTYPE_SH5_101
372 bool "Support SH5-101 processor"
373 select CPU_SH5
374
375config CPU_SUBTYPE_SH5_103
376 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900377 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900378
Paul Mundtb5f42db2007-11-08 18:38:14 +0900379endchoice
380
Paul Mundtcad82442006-01-16 22:14:19 -0800381source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900382
Paul Mundt4690bdc2007-11-09 13:45:42 +0900383source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800384
Paul Mundt939a24a2008-07-29 21:41:37 +0900385source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900386
Paul Mundt32351a22007-03-12 14:38:59 +0900387menu "Timer and clock configuration"
388
Paul Mundtcad82442006-01-16 22:14:19 -0800389config SH_TMU
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900390 def_bool y
391 prompt "TMU timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900392 depends on CPU_SH3 || CPU_SH4
Paul Mundt57be2b42007-05-09 17:33:24 +0900393 select GENERIC_TIME
394 select GENERIC_CLOCKEVENTS
Paul Mundtcad82442006-01-16 22:14:19 -0800395 help
396 This enables the use of the TMU as the system timer.
397
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900398config SH_CMT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900399 def_bool y
400 prompt "CMT timer support"
Paul Mundt2ad69902008-03-13 12:52:44 +0900401 depends on CPU_SH2 && !CPU_SUBTYPE_MXG
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900402 help
403 This enables the use of the CMT as the system timer.
404
405config SH_MTU2
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900406 def_bool n
407 prompt "MTU2 timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900408 depends on CPU_SH2A
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900409 help
410 This enables the use of the MTU2 as the system timer.
411
Paul Mundt417528a2006-11-20 11:18:30 +0900412config SH_TIMER_IRQ
413 int
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900414 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
415 CPU_SUBTYPE_SH7763
Paul Mundt417528a2006-11-20 11:18:30 +0900416 default "86" if CPU_SUBTYPE_SH7619
417 default "140" if CPU_SUBTYPE_SH7206
Paul Mundt2b2d4e72008-03-13 19:51:06 +0900418 default "142" if CPU_SUBTYPE_SH7203
Paul Mundt2ad69902008-03-13 12:52:44 +0900419 default "238" if CPU_SUBTYPE_MXG
Paul Mundt417528a2006-11-20 11:18:30 +0900420 default "16"
421
Paul Mundtcad82442006-01-16 22:14:19 -0800422config SH_PCLK_FREQ
423 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900424 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900425 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900426 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900427 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900428 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900429 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundt2ad69902008-03-13 12:52:44 +0900430 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG
Paul Mundt05627482007-05-15 16:25:47 +0900431 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800432 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900433 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800434 help
435 This option is used to specify the peripheral clock frequency.
436 This is necessary for determining the reference clock value on
437 platforms lacking an RTC.
438
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900439config SH_CLK_MD
440 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900441 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900442 default 6 if CPU_SUBTYPE_SH7206
443 default 5 if CPU_SUBTYPE_SH7619
444 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900445 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900446 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900447
Paul Mundt57be2b42007-05-09 17:33:24 +0900448source "kernel/time/Kconfig"
449
Paul Mundt32351a22007-03-12 14:38:59 +0900450endmenu
451
Paul Mundtcad82442006-01-16 22:14:19 -0800452menu "CPU Frequency scaling"
453
454source "drivers/cpufreq/Kconfig"
455
456config SH_CPU_FREQ
457 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900458 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800459 select CPU_FREQ_TABLE
460 help
461 This adds the cpufreq driver for SuperH. At present, only
462 the SH-4 is supported.
463
464 For details, take a look at <file:Documentation/cpu-freq>.
465
466 If unsure, say N.
467
468endmenu
469
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900470source "arch/sh/drivers/Kconfig"
471
Paul Mundtcad82442006-01-16 22:14:19 -0800472endmenu
473
474config ISA_DMA_API
Adrian Bunkf5f826c2008-03-31 01:40:17 +0300475 bool
Paul Mundtcad82442006-01-16 22:14:19 -0800476
477menu "Kernel features"
478
Paul Mundt91b91d02006-09-27 18:08:33 +0900479source kernel/Kconfig.hz
480
Paul Mundtcad82442006-01-16 22:14:19 -0800481config KEXEC
482 bool "kexec system call (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900483 depends on SUPERH32 && EXPERIMENTAL
Paul Mundtcad82442006-01-16 22:14:19 -0800484 help
485 kexec is a system call that implements the ability to shutdown your
486 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400487 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800488 you can start any kernel with it, not just Linux.
489
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400490 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800491
492 It is an ongoing process to be certain the hardware in a machine
493 is properly shutdown, so do not be surprised if this code does not
494 initially work for you. It may help to enable device hotplugging
495 support. As of this writing the exact hardware interface is
496 strongly in flux, so no good recommendation can be made.
497
Paul Mundt4d5ade52007-04-27 11:25:57 +0900498config CRASH_DUMP
499 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900500 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900501 help
502 Generate crash dump after being started by kexec.
503 This should be normally only set in special crash dump kernels
504 which are loaded in the main kernel with kexec-tools into
505 a specially reserved region and then later executed after
506 a crash by kdump/kexec. The crash dump kernel must be compiled
507 to a memory address not used by the main kernel using
508 MEMORY_START.
509
510 For more details see Documentation/kdump/kdump.txt
511
Paul Mundtc4637d42008-07-30 15:30:52 +0900512config SECCOMP
513 bool "Enable seccomp to safely compute untrusted bytecode"
514 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900515 help
516 This kernel feature is useful for number crunching applications
517 that may need to compute untrusted bytecode during their
518 execution. By using pipes or other transports made available to
519 the process as file descriptors supporting the read/write
520 syscalls, it's possible to isolate those applications in
521 their own address space using seccomp. Once seccomp is
522 enabled via prctl, it cannot be disabled and the task is only
523 allowed to execute a few safe syscalls defined by each seccomp
524 mode.
525
526 If unsure, say N.
527
Linus Torvalds1da177e2005-04-16 15:20:36 -0700528config SMP
529 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900530 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200531 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700532 ---help---
533 This enables support for systems with more than one CPU. If you have
534 a system with only one CPU, like most personal computers, say N. If
535 you have a system with more than one CPU, say Y.
536
537 If you say N here, the kernel will run on single and multiprocessor
538 machines, but will use only one CPU of a multiprocessor machine. If
539 you say Y here, the kernel will run on many, but not all,
540 singleprocessor machines. On a singleprocessor machine, the kernel
541 will run faster if you say N here.
542
543 People using multiprocessor machines who say Y here should also say
544 Y to "Enhanced Real Time Clock Support", below.
545
Adrian Bunk03502fa2008-02-03 15:50:21 +0200546 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
547 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700548
549 If you don't know what to do here, say N.
550
551config NR_CPUS
552 int "Maximum number of CPUs (2-32)"
553 range 2 32
554 depends on SMP
Paul Mundt2b1bd1a2007-06-20 18:27:10 +0900555 default "4" if CPU_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700556 default "2"
557 help
558 This allows you to specify the maximum number of CPUs which this
559 kernel will support. The maximum supported value is 32 and the
560 minimum value which makes sense is 2.
561
562 This is purely to save memory - each supported CPU adds
563 approximately eight kilobytes to the kernel image.
564
Paul Mundt91b91d02006-09-27 18:08:33 +0900565source "kernel/Kconfig.preempt"
566
Paul Mundt83662462007-09-28 16:04:49 +0900567config GUSA
568 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900569 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900570 help
571 This enables support for gUSA (general UserSpace Atomicity).
572 This is the default implementation for both UP and non-ll/sc
573 CPUs, and is used by the libc, amongst others.
574
575 For additional information, design information can be found
576 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
577
578 This should only be disabled for special cases where alternate
579 atomicity implementations exist.
580
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900581config GUSA_RB
582 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
583 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
584 help
585 Enabling this option will allow the kernel to implement some
586 atomic operations using a software implemention of load-locked/
587 store-conditional (LLSC). On machines which do not have hardware
588 LLSC, this should be more efficient than the other alternative of
589 disabling insterrupts around the atomic sequence.
590
Paul Mundtcad82442006-01-16 22:14:19 -0800591endmenu
592
593menu "Boot options"
594
595config ZERO_PAGE_OFFSET
596 hex "Zero page offset"
Adrian Bunkf5f826c2008-03-31 01:40:17 +0300597 default "0x00004000" if SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900598 default "0x00010000" if PAGE_SIZE_64KB
599 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800600 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700601 help
Paul Mundtcad82442006-01-16 22:14:19 -0800602 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700603
Paul Mundtcad82442006-01-16 22:14:19 -0800604config BOOT_LINK_OFFSET
605 hex "Link address offset for booting"
606 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700607 help
Paul Mundtcad82442006-01-16 22:14:19 -0800608 This option allows you to set the link address offset of the zImage.
609 This can be useful if you are on a board which has a small amount of
610 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700611
Paul Mundtcad82442006-01-16 22:14:19 -0800612config UBC_WAKEUP
613 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900614 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800615 help
616 Selecting this option will wakeup the User Break Controller (UBC) on
617 startup. Although the UBC is left in an awake state when the processor
618 comes up, some boot loaders misbehave by putting the UBC to sleep in a
619 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700620
621 If unsure, say N.
622
Paul Mundtcad82442006-01-16 22:14:19 -0800623config CMDLINE_BOOL
624 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700625
Paul Mundtcad82442006-01-16 22:14:19 -0800626config CMDLINE
627 string "Initial kernel command string"
628 depends on CMDLINE_BOOL
629 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700630
631endmenu
632
Paul Mundtcad82442006-01-16 22:14:19 -0800633menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700634
635# Even on SuperH devices which don't have an ISA bus,
636# this variable helps the PCMCIA modules handle
637# IRQ requesting properly -- Greg Banks.
638#
639# Though we're generally not interested in it when
640# we're not using PCMCIA, so we make it dependent on
641# PCMCIA outright. -- PFM.
642config ISA
Paul Mundt357d5942007-06-11 15:32:07 +0900643 def_bool y
644 depends on PCMCIA && HD6446X_SERIES
Linus Torvalds1da177e2005-04-16 15:20:36 -0700645 help
646 Find out whether you have ISA slots on your motherboard. ISA is the
647 name of a bus system, i.e. the way the CPU talks to the other stuff
648 inside your box. Other bus systems are PCI, EISA, MicroChannel
649 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
650 newer boards don't support it. If you have ISA, say Y, otherwise N.
651
652config EISA
653 bool
654 ---help---
655 The Extended Industry Standard Architecture (EISA) bus was
656 developed as an open alternative to the IBM MicroChannel bus.
657
658 The EISA bus provided some of the features of the IBM MicroChannel
659 bus while maintaining backward compatibility with cards made for
660 the older ISA bus. The EISA bus saw limited use between 1988 and
661 1995 when it was made obsolete by the PCI bus.
662
663 Say Y here if you are building a kernel for an EISA-based machine.
664
665 Otherwise, say N.
666
667config MCA
668 bool
669 help
670 MicroChannel Architecture is found in some IBM PS/2 machines and
671 laptops. It is a bus system similar to PCI or ISA. See
672 <file:Documentation/mca.txt> (and especially the web page given
673 there) before attempting to build an MCA bus kernel.
674
675config SBUS
676 bool
677
Paul Mundtcad82442006-01-16 22:14:19 -0800678config SUPERHYWAY
679 tristate "SuperHyway Bus support"
680 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700681
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900682config MAPLE
683 bool "Maple Bus support"
684 depends on SH_DREAMCAST
685 help
686 The Maple Bus is SEGA's serial communication bus for peripherals
687 on the Dreamcast. Without this bus support you won't be able to
688 get your Dreamcast keyboard etc to work, so most users
689 probably want to say 'Y' here, unless you are only using the
690 Dreamcast with a serial line terminal or a remote network
691 connection.
692
Paul Mundt824e55f2007-06-20 18:01:52 +0900693config CF_ENABLER
694 bool "Compact Flash Enabler support"
695 depends on SOLUTION_ENGINE || SH_SH03
696 ---help---
697 Compact Flash is a small, removable mass storage device introduced
698 in 1994 originally as a PCMCIA device. If you say `Y' here, you
699 compile in support for Compact Flash devices directly connected to
700 a SuperH processor. A Compact Flash FAQ is available at
701 <http://www.compactflash.org/faqs/faq.htm>.
702
703 If your board has "Directly Connected" CompactFlash at area 5 or 6,
704 you may want to enable this option. Then, you can use CF as
705 primary IDE drive (only tested for SanDisk).
706
707 If in doubt, select 'N'.
708
709choice
710 prompt "Compact Flash Connection Area"
711 depends on CF_ENABLER
712 default CF_AREA6
713
714config CF_AREA5
715 bool "Area5"
716 help
717 If your board has "Directly Connected" CompactFlash, You should
718 select the area where your CF is connected to.
719
720 - "Area5" if CompactFlash is connected to Area 5 (0x14000000)
721 - "Area6" if it is connected to Area 6 (0x18000000)
722
723 "Area6" will work for most boards.
724
725config CF_AREA6
726 bool "Area6"
727
728endchoice
729
730config CF_BASE_ADDR
731 hex
732 depends on CF_ENABLER
733 default "0xb8000000" if CF_AREA6
734 default "0xb4000000" if CF_AREA5
735
Linus Torvalds1da177e2005-04-16 15:20:36 -0700736source "arch/sh/drivers/pci/Kconfig"
737
738source "drivers/pci/Kconfig"
739
740source "drivers/pcmcia/Kconfig"
741
742source "drivers/pci/hotplug/Kconfig"
743
744endmenu
745
746menu "Executable file formats"
747
748source "fs/Kconfig.binfmt"
749
750endmenu
751
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900752menu "Power management options (EXPERIMENTAL)"
Paul Mundt357d5942007-06-11 15:32:07 +0900753depends on EXPERIMENTAL && SYS_SUPPORTS_PM
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900754
Johannes Bergf4cb5702007-12-08 02:14:00 +0100755config ARCH_SUSPEND_POSSIBLE
756 def_bool y
757 depends on !SMP
758
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900759source kernel/power/Kconfig
760
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900761endmenu
762
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700763source "net/Kconfig"
764
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765source "drivers/Kconfig"
766
767source "fs/Kconfig"
768
Linus Torvalds1da177e2005-04-16 15:20:36 -0700769source "arch/sh/Kconfig.debug"
770
771source "security/Kconfig"
772
773source "crypto/Kconfig"
774
775source "lib/Kconfig"