blob: 0ae541107f3f15e98f4da4e50f9c7b5f54eba2fd [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
Linus Torvalds1da177e2005-04-16 15:20:36 -070015 help
16 The SuperH is a RISC processor targeted for use in embedded systems
17 and consumer electronics; it was also used in the Sega Dreamcast
18 gaming console. The SuperH port has a home page at
19 <http://www.linux-sh.org/>.
20
Paul Mundt39d28a22007-11-08 18:39:33 +090021config SUPERH32
Paul Mundtea0e1a92007-11-21 15:58:01 +090022 def_bool !SUPERH64
23
24config SUPERH64
25 def_bool y if CPU_SH5
Paul Mundt39d28a22007-11-08 18:39:33 +090026
Paul Mundtf42b7e32008-07-29 20:12:51 +090027config ARCH_DEFCONFIG
28 string
29 default "arch/sh/configs/shx3_defconfig" if SUPERH32
30 default "arch/sh/configs/cayman_defconfig" if SUPERH64
31
Linus Torvalds1da177e2005-04-16 15:20:36 -070032config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090033 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
35config RWSEM_XCHGADD_ALGORITHM
36 bool
37
Paul Mundtfa691512007-03-08 19:41:21 +090038config GENERIC_BUG
39 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090040 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090041
Akinobu Mitae2268c72006-03-26 01:39:35 -080042config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090043 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080044
45config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090046 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080047
Linus Torvalds1da177e2005-04-16 15:20:36 -070048config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090049 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
51config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090052 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070053
54config GENERIC_CALIBRATE_DELAY
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090055 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070056
Paul Mundtcad82442006-01-16 22:14:19 -080057config GENERIC_IOMAP
58 bool
59
Paul Mundt45882142006-10-04 13:21:45 +090060config GENERIC_TIME
61 def_bool n
62
Paul Mundt57be2b42007-05-09 17:33:24 +090063config GENERIC_CLOCKEVENTS
64 def_bool n
65
Paul Mundt357d5942007-06-11 15:32:07 +090066config SYS_SUPPORTS_PM
67 bool
68
Paul Mundt0a9b0db2007-01-24 21:56:20 +090069config SYS_SUPPORTS_APM_EMULATION
70 bool
Paul Mundt357d5942007-06-11 15:32:07 +090071 select SYS_SUPPORTS_PM
72
73config SYS_SUPPORTS_SMP
74 bool
75
76config SYS_SUPPORTS_NUMA
77 bool
78
79config SYS_SUPPORTS_PCI
80 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +090081
Paul Mundtafbfb522006-12-04 18:17:28 +090082config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090083 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +090084
85config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090086 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +090087
David Howellsf0d1b0b2006-12-08 02:37:49 -080088config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090089 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080090
91config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090092 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080093
Paul Mundte257ad02007-07-25 11:18:00 +090094config ARCH_NO_VIRT_TO_BUS
95 def_bool y
96
David Howellsb0b933c2008-02-08 04:19:27 -080097config ARCH_SUPPORTS_AOUT
98 def_bool y
99
Magnus Damme7cc9a72008-02-07 20:18:21 +0900100config IO_TRAPPED
101 bool
102
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103source "init/Kconfig"
104
105menu "System type"
106
Paul Mundtb5f42db2007-11-08 18:38:14 +0900107#
108# Processor families
109#
110config CPU_SH2
111 bool
112
113config CPU_SH2A
114 bool
115 select CPU_SH2
116
117config CPU_SH3
118 bool
119 select CPU_HAS_INTEVT
120 select CPU_HAS_SR_RB
121
122config CPU_SH4
123 bool
124 select CPU_HAS_INTEVT
125 select CPU_HAS_SR_RB
126 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
127 select CPU_HAS_FPU if !CPU_SH4AL_DSP
128
129config CPU_SH4A
130 bool
131 select CPU_SH4
132
133config CPU_SH4AL_DSP
134 bool
135 select CPU_SH4A
136 select CPU_HAS_DSP
137
Paul Mundtea0e1a92007-11-21 15:58:01 +0900138config CPU_SH5
139 bool
140 select CPU_HAS_FPU
141
Paul Mundtb5f42db2007-11-08 18:38:14 +0900142config CPU_SHX2
143 bool
144
145config CPU_SHX3
146 bool
147
148choice
149 prompt "Processor sub-type selection"
150
151#
152# Processor subtypes
153#
154
155# SH-2 Processor Support
156
157config CPU_SUBTYPE_SH7619
158 bool "Support SH7619 processor"
159 select CPU_SH2
160
161# SH-2A Processor Support
162
Paul Mundt6d01f512007-11-26 18:17:21 +0900163config CPU_SUBTYPE_SH7203
164 bool "Support SH7203 processor"
165 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900166 select CPU_HAS_FPU
Paul Mundt6d01f512007-11-26 18:17:21 +0900167
Paul Mundtb5f42db2007-11-08 18:38:14 +0900168config CPU_SUBTYPE_SH7206
169 bool "Support SH7206 processor"
170 select CPU_SH2A
171
Paul Mundta8f67f42007-11-26 19:54:02 +0900172config CPU_SUBTYPE_SH7263
173 bool "Support SH7263 processor"
174 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900175 select CPU_HAS_FPU
Paul Mundta8f67f42007-11-26 19:54:02 +0900176
Paul Mundt2ad69902008-03-13 12:52:44 +0900177config CPU_SUBTYPE_MXG
178 bool "Support MX-G processor"
179 select CPU_SH2A
180 help
181 Select MX-G if running on an R8A03022BG part.
182
Paul Mundtb5f42db2007-11-08 18:38:14 +0900183# SH-3 Processor Support
184
185config CPU_SUBTYPE_SH7705
186 bool "Support SH7705 processor"
187 select CPU_SH3
188
189config CPU_SUBTYPE_SH7706
190 bool "Support SH7706 processor"
191 select CPU_SH3
192 help
193 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
194
195config CPU_SUBTYPE_SH7707
196 bool "Support SH7707 processor"
197 select CPU_SH3
198 help
199 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
200
201config CPU_SUBTYPE_SH7708
202 bool "Support SH7708 processor"
203 select CPU_SH3
204 help
205 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
206 if you have a 100 Mhz SH-3 HD6417708R CPU.
207
208config CPU_SUBTYPE_SH7709
209 bool "Support SH7709 processor"
210 select CPU_SH3
211 help
212 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
213
214config CPU_SUBTYPE_SH7710
215 bool "Support SH7710 processor"
216 select CPU_SH3
217 select CPU_HAS_DSP
218 help
219 Select SH7710 if you have a SH3-DSP SH7710 CPU.
220
221config CPU_SUBTYPE_SH7712
222 bool "Support SH7712 processor"
223 select CPU_SH3
224 select CPU_HAS_DSP
225 help
226 Select SH7712 if you have a SH3-DSP SH7712 CPU.
227
228config CPU_SUBTYPE_SH7720
229 bool "Support SH7720 processor"
230 select CPU_SH3
231 select CPU_HAS_DSP
232 help
233 Select SH7720 if you have a SH3-DSP SH7720 CPU.
234
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900235config CPU_SUBTYPE_SH7721
236 bool "Support SH7721 processor"
237 select CPU_SH3
238 select CPU_HAS_DSP
239 help
240 Select SH7721 if you have a SH3-DSP SH7721 CPU.
241
Paul Mundtb5f42db2007-11-08 18:38:14 +0900242# SH-4 Processor Support
243
244config CPU_SUBTYPE_SH7750
245 bool "Support SH7750 processor"
246 select CPU_SH4
247 help
248 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
249
250config CPU_SUBTYPE_SH7091
251 bool "Support SH7091 processor"
252 select CPU_SH4
253 help
254 Select SH7091 if you have an SH-4 based Sega device (such as
255 the Dreamcast, Naomi, and Naomi 2).
256
257config CPU_SUBTYPE_SH7750R
258 bool "Support SH7750R processor"
259 select CPU_SH4
260
261config CPU_SUBTYPE_SH7750S
262 bool "Support SH7750S processor"
263 select CPU_SH4
264
265config CPU_SUBTYPE_SH7751
266 bool "Support SH7751 processor"
267 select CPU_SH4
268 help
269 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
270 or if you have a HD6417751R CPU.
271
272config CPU_SUBTYPE_SH7751R
273 bool "Support SH7751R processor"
274 select CPU_SH4
275
276config CPU_SUBTYPE_SH7760
277 bool "Support SH7760 processor"
278 select CPU_SH4
279
280config CPU_SUBTYPE_SH4_202
281 bool "Support SH4-202 processor"
282 select CPU_SH4
283
284# SH-4A Processor Support
285
Paul Mundt178dd0c2008-04-09 17:56:18 +0900286config CPU_SUBTYPE_SH7723
287 bool "Support SH7723 processor"
288 select CPU_SH4A
289 select CPU_SHX2
290 select ARCH_SPARSEMEM_ENABLE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900291 help
292 Select SH7723 if you have an SH-MobileR2 CPU.
293
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900294config CPU_SUBTYPE_SH7763
295 bool "Support SH7763 processor"
296 select CPU_SH4A
297 help
298 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
299
Paul Mundtb5f42db2007-11-08 18:38:14 +0900300config CPU_SUBTYPE_SH7770
301 bool "Support SH7770 processor"
302 select CPU_SH4A
303
304config CPU_SUBTYPE_SH7780
305 bool "Support SH7780 processor"
306 select CPU_SH4A
307
308config CPU_SUBTYPE_SH7785
309 bool "Support SH7785 processor"
310 select CPU_SH4A
311 select CPU_SHX2
312 select ARCH_SPARSEMEM_ENABLE
313 select SYS_SUPPORTS_NUMA
314
315config CPU_SUBTYPE_SHX3
316 bool "Support SH-X3 processor"
317 select CPU_SH4A
318 select CPU_SHX3
319 select ARCH_SPARSEMEM_ENABLE
320 select SYS_SUPPORTS_NUMA
321 select SYS_SUPPORTS_SMP
322
323# SH4AL-DSP Processor Support
324
325config CPU_SUBTYPE_SH7343
326 bool "Support SH7343 processor"
327 select CPU_SH4AL_DSP
328
329config CPU_SUBTYPE_SH7722
330 bool "Support SH7722 processor"
331 select CPU_SH4AL_DSP
332 select CPU_SHX2
333 select ARCH_SPARSEMEM_ENABLE
334 select SYS_SUPPORTS_NUMA
335
Magnus Damm9109a302008-02-08 17:31:24 +0900336config CPU_SUBTYPE_SH7366
337 bool "Support SH7366 processor"
338 select CPU_SH4AL_DSP
339 select CPU_SHX2
340 select ARCH_SPARSEMEM_ENABLE
341 select SYS_SUPPORTS_NUMA
342
Paul Mundtea0e1a92007-11-21 15:58:01 +0900343# SH-5 Processor Support
344
345config CPU_SUBTYPE_SH5_101
346 bool "Support SH5-101 processor"
347 select CPU_SH5
348
349config CPU_SUBTYPE_SH5_103
350 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900351 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900352
Paul Mundtb5f42db2007-11-08 18:38:14 +0900353endchoice
354
Paul Mundtcad82442006-01-16 22:14:19 -0800355source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900356
Paul Mundt4690bdc2007-11-09 13:45:42 +0900357source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800358
Paul Mundt939a24a2008-07-29 21:41:37 +0900359source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900360
Paul Mundt32351a22007-03-12 14:38:59 +0900361menu "Timer and clock configuration"
362
Paul Mundtcad82442006-01-16 22:14:19 -0800363config SH_TMU
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900364 def_bool y
365 prompt "TMU timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900366 depends on CPU_SH3 || CPU_SH4
Paul Mundt57be2b42007-05-09 17:33:24 +0900367 select GENERIC_TIME
368 select GENERIC_CLOCKEVENTS
Paul Mundtcad82442006-01-16 22:14:19 -0800369 help
370 This enables the use of the TMU as the system timer.
371
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900372config SH_CMT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900373 def_bool y
374 prompt "CMT timer support"
Paul Mundt2ad69902008-03-13 12:52:44 +0900375 depends on CPU_SH2 && !CPU_SUBTYPE_MXG
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900376 help
377 This enables the use of the CMT as the system timer.
378
379config SH_MTU2
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900380 def_bool n
381 prompt "MTU2 timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900382 depends on CPU_SH2A
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900383 help
384 This enables the use of the MTU2 as the system timer.
385
Paul Mundt417528a2006-11-20 11:18:30 +0900386config SH_TIMER_IRQ
387 int
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900388 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
389 CPU_SUBTYPE_SH7763
Paul Mundt417528a2006-11-20 11:18:30 +0900390 default "86" if CPU_SUBTYPE_SH7619
391 default "140" if CPU_SUBTYPE_SH7206
Paul Mundt2b2d4e72008-03-13 19:51:06 +0900392 default "142" if CPU_SUBTYPE_SH7203
Paul Mundt2ad69902008-03-13 12:52:44 +0900393 default "238" if CPU_SUBTYPE_MXG
Paul Mundt417528a2006-11-20 11:18:30 +0900394 default "16"
395
Paul Mundtcad82442006-01-16 22:14:19 -0800396config SH_PCLK_FREQ
397 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900398 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900399 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900400 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900401 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900402 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900403 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundt2ad69902008-03-13 12:52:44 +0900404 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG
Paul Mundt05627482007-05-15 16:25:47 +0900405 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800406 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900407 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800408 help
409 This option is used to specify the peripheral clock frequency.
410 This is necessary for determining the reference clock value on
411 platforms lacking an RTC.
412
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900413config SH_CLK_MD
414 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900415 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900416 default 6 if CPU_SUBTYPE_SH7206
417 default 5 if CPU_SUBTYPE_SH7619
418 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900419 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900420 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900421
Paul Mundt57be2b42007-05-09 17:33:24 +0900422source "kernel/time/Kconfig"
423
Paul Mundt32351a22007-03-12 14:38:59 +0900424endmenu
425
Paul Mundtcad82442006-01-16 22:14:19 -0800426menu "CPU Frequency scaling"
427
428source "drivers/cpufreq/Kconfig"
429
430config SH_CPU_FREQ
431 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900432 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800433 select CPU_FREQ_TABLE
434 help
435 This adds the cpufreq driver for SuperH. At present, only
436 the SH-4 is supported.
437
438 For details, take a look at <file:Documentation/cpu-freq>.
439
440 If unsure, say N.
441
442endmenu
443
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900444source "arch/sh/drivers/Kconfig"
445
Paul Mundtcad82442006-01-16 22:14:19 -0800446endmenu
447
448config ISA_DMA_API
Adrian Bunkf5f826c2008-03-31 01:40:17 +0300449 bool
Paul Mundtcad82442006-01-16 22:14:19 -0800450
451menu "Kernel features"
452
Paul Mundt91b91d02006-09-27 18:08:33 +0900453source kernel/Kconfig.hz
454
Paul Mundtcad82442006-01-16 22:14:19 -0800455config KEXEC
456 bool "kexec system call (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900457 depends on SUPERH32 && EXPERIMENTAL
Paul Mundtcad82442006-01-16 22:14:19 -0800458 help
459 kexec is a system call that implements the ability to shutdown your
460 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400461 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800462 you can start any kernel with it, not just Linux.
463
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400464 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800465
466 It is an ongoing process to be certain the hardware in a machine
467 is properly shutdown, so do not be surprised if this code does not
468 initially work for you. It may help to enable device hotplugging
469 support. As of this writing the exact hardware interface is
470 strongly in flux, so no good recommendation can be made.
471
Paul Mundt4d5ade52007-04-27 11:25:57 +0900472config CRASH_DUMP
473 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900474 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900475 help
476 Generate crash dump after being started by kexec.
477 This should be normally only set in special crash dump kernels
478 which are loaded in the main kernel with kexec-tools into
479 a specially reserved region and then later executed after
480 a crash by kdump/kexec. The crash dump kernel must be compiled
481 to a memory address not used by the main kernel using
482 MEMORY_START.
483
484 For more details see Documentation/kdump/kdump.txt
485
Paul Mundtc4637d42008-07-30 15:30:52 +0900486config SECCOMP
487 bool "Enable seccomp to safely compute untrusted bytecode"
488 depends on PROC_FS
489 default y
490 help
491 This kernel feature is useful for number crunching applications
492 that may need to compute untrusted bytecode during their
493 execution. By using pipes or other transports made available to
494 the process as file descriptors supporting the read/write
495 syscalls, it's possible to isolate those applications in
496 their own address space using seccomp. Once seccomp is
497 enabled via prctl, it cannot be disabled and the task is only
498 allowed to execute a few safe syscalls defined by each seccomp
499 mode.
500
501 If unsure, say N.
502
Linus Torvalds1da177e2005-04-16 15:20:36 -0700503config SMP
504 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900505 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200506 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700507 ---help---
508 This enables support for systems with more than one CPU. If you have
509 a system with only one CPU, like most personal computers, say N. If
510 you have a system with more than one CPU, say Y.
511
512 If you say N here, the kernel will run on single and multiprocessor
513 machines, but will use only one CPU of a multiprocessor machine. If
514 you say Y here, the kernel will run on many, but not all,
515 singleprocessor machines. On a singleprocessor machine, the kernel
516 will run faster if you say N here.
517
518 People using multiprocessor machines who say Y here should also say
519 Y to "Enhanced Real Time Clock Support", below.
520
Adrian Bunk03502fa2008-02-03 15:50:21 +0200521 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
522 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700523
524 If you don't know what to do here, say N.
525
526config NR_CPUS
527 int "Maximum number of CPUs (2-32)"
528 range 2 32
529 depends on SMP
Paul Mundt2b1bd1a2007-06-20 18:27:10 +0900530 default "4" if CPU_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700531 default "2"
532 help
533 This allows you to specify the maximum number of CPUs which this
534 kernel will support. The maximum supported value is 32 and the
535 minimum value which makes sense is 2.
536
537 This is purely to save memory - each supported CPU adds
538 approximately eight kilobytes to the kernel image.
539
Paul Mundt91b91d02006-09-27 18:08:33 +0900540source "kernel/Kconfig.preempt"
541
Paul Mundt83662462007-09-28 16:04:49 +0900542config GUSA
543 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900544 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900545 help
546 This enables support for gUSA (general UserSpace Atomicity).
547 This is the default implementation for both UP and non-ll/sc
548 CPUs, and is used by the libc, amongst others.
549
550 For additional information, design information can be found
551 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
552
553 This should only be disabled for special cases where alternate
554 atomicity implementations exist.
555
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900556config GUSA_RB
557 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
558 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
559 help
560 Enabling this option will allow the kernel to implement some
561 atomic operations using a software implemention of load-locked/
562 store-conditional (LLSC). On machines which do not have hardware
563 LLSC, this should be more efficient than the other alternative of
564 disabling insterrupts around the atomic sequence.
565
Paul Mundtcad82442006-01-16 22:14:19 -0800566endmenu
567
568menu "Boot options"
569
570config ZERO_PAGE_OFFSET
571 hex "Zero page offset"
Adrian Bunkf5f826c2008-03-31 01:40:17 +0300572 default "0x00004000" if SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900573 default "0x00010000" if PAGE_SIZE_64KB
574 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800575 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700576 help
Paul Mundtcad82442006-01-16 22:14:19 -0800577 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700578
Paul Mundtcad82442006-01-16 22:14:19 -0800579config BOOT_LINK_OFFSET
580 hex "Link address offset for booting"
581 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700582 help
Paul Mundtcad82442006-01-16 22:14:19 -0800583 This option allows you to set the link address offset of the zImage.
584 This can be useful if you are on a board which has a small amount of
585 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700586
Paul Mundtcad82442006-01-16 22:14:19 -0800587config UBC_WAKEUP
588 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900589 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800590 help
591 Selecting this option will wakeup the User Break Controller (UBC) on
592 startup. Although the UBC is left in an awake state when the processor
593 comes up, some boot loaders misbehave by putting the UBC to sleep in a
594 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700595
596 If unsure, say N.
597
Paul Mundtcad82442006-01-16 22:14:19 -0800598config CMDLINE_BOOL
599 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700600
Paul Mundtcad82442006-01-16 22:14:19 -0800601config CMDLINE
602 string "Initial kernel command string"
603 depends on CMDLINE_BOOL
604 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700605
606endmenu
607
Paul Mundtcad82442006-01-16 22:14:19 -0800608menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700609
610# Even on SuperH devices which don't have an ISA bus,
611# this variable helps the PCMCIA modules handle
612# IRQ requesting properly -- Greg Banks.
613#
614# Though we're generally not interested in it when
615# we're not using PCMCIA, so we make it dependent on
616# PCMCIA outright. -- PFM.
617config ISA
Paul Mundt357d5942007-06-11 15:32:07 +0900618 def_bool y
619 depends on PCMCIA && HD6446X_SERIES
Linus Torvalds1da177e2005-04-16 15:20:36 -0700620 help
621 Find out whether you have ISA slots on your motherboard. ISA is the
622 name of a bus system, i.e. the way the CPU talks to the other stuff
623 inside your box. Other bus systems are PCI, EISA, MicroChannel
624 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
625 newer boards don't support it. If you have ISA, say Y, otherwise N.
626
627config EISA
628 bool
629 ---help---
630 The Extended Industry Standard Architecture (EISA) bus was
631 developed as an open alternative to the IBM MicroChannel bus.
632
633 The EISA bus provided some of the features of the IBM MicroChannel
634 bus while maintaining backward compatibility with cards made for
635 the older ISA bus. The EISA bus saw limited use between 1988 and
636 1995 when it was made obsolete by the PCI bus.
637
638 Say Y here if you are building a kernel for an EISA-based machine.
639
640 Otherwise, say N.
641
642config MCA
643 bool
644 help
645 MicroChannel Architecture is found in some IBM PS/2 machines and
646 laptops. It is a bus system similar to PCI or ISA. See
647 <file:Documentation/mca.txt> (and especially the web page given
648 there) before attempting to build an MCA bus kernel.
649
650config SBUS
651 bool
652
Paul Mundtcad82442006-01-16 22:14:19 -0800653config SUPERHYWAY
654 tristate "SuperHyway Bus support"
655 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700656
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900657config MAPLE
658 bool "Maple Bus support"
659 depends on SH_DREAMCAST
660 help
661 The Maple Bus is SEGA's serial communication bus for peripherals
662 on the Dreamcast. Without this bus support you won't be able to
663 get your Dreamcast keyboard etc to work, so most users
664 probably want to say 'Y' here, unless you are only using the
665 Dreamcast with a serial line terminal or a remote network
666 connection.
667
Paul Mundt824e55f2007-06-20 18:01:52 +0900668config CF_ENABLER
669 bool "Compact Flash Enabler support"
670 depends on SOLUTION_ENGINE || SH_SH03
671 ---help---
672 Compact Flash is a small, removable mass storage device introduced
673 in 1994 originally as a PCMCIA device. If you say `Y' here, you
674 compile in support for Compact Flash devices directly connected to
675 a SuperH processor. A Compact Flash FAQ is available at
676 <http://www.compactflash.org/faqs/faq.htm>.
677
678 If your board has "Directly Connected" CompactFlash at area 5 or 6,
679 you may want to enable this option. Then, you can use CF as
680 primary IDE drive (only tested for SanDisk).
681
682 If in doubt, select 'N'.
683
684choice
685 prompt "Compact Flash Connection Area"
686 depends on CF_ENABLER
687 default CF_AREA6
688
689config CF_AREA5
690 bool "Area5"
691 help
692 If your board has "Directly Connected" CompactFlash, You should
693 select the area where your CF is connected to.
694
695 - "Area5" if CompactFlash is connected to Area 5 (0x14000000)
696 - "Area6" if it is connected to Area 6 (0x18000000)
697
698 "Area6" will work for most boards.
699
700config CF_AREA6
701 bool "Area6"
702
703endchoice
704
705config CF_BASE_ADDR
706 hex
707 depends on CF_ENABLER
708 default "0xb8000000" if CF_AREA6
709 default "0xb4000000" if CF_AREA5
710
Linus Torvalds1da177e2005-04-16 15:20:36 -0700711source "arch/sh/drivers/pci/Kconfig"
712
713source "drivers/pci/Kconfig"
714
715source "drivers/pcmcia/Kconfig"
716
717source "drivers/pci/hotplug/Kconfig"
718
719endmenu
720
721menu "Executable file formats"
722
723source "fs/Kconfig.binfmt"
724
725endmenu
726
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900727menu "Power management options (EXPERIMENTAL)"
Paul Mundt357d5942007-06-11 15:32:07 +0900728depends on EXPERIMENTAL && SYS_SUPPORTS_PM
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900729
Johannes Bergf4cb5702007-12-08 02:14:00 +0100730config ARCH_SUSPEND_POSSIBLE
731 def_bool y
732 depends on !SMP
733
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900734source kernel/power/Kconfig
735
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900736endmenu
737
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700738source "net/Kconfig"
739
Linus Torvalds1da177e2005-04-16 15:20:36 -0700740source "drivers/Kconfig"
741
742source "fs/Kconfig"
743
Linus Torvalds1da177e2005-04-16 15:20:36 -0700744source "arch/sh/Kconfig.debug"
745
746source "security/Kconfig"
747
748source "crypto/Kconfig"
749
750source "lib/Kconfig"