blob: 2d52b515c2418a7ca4a3993a2f6d58957b7b6755 [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
Paul Mundtd7b01f72008-12-10 20:17:15 +090016 select HAVE_ARCH_TRACEHOOK
Linus Torvalds1da177e2005-04-16 15:20:36 -070017 help
18 The SuperH is a RISC processor targeted for use in embedded systems
19 and consumer electronics; it was also used in the Sega Dreamcast
20 gaming console. The SuperH port has a home page at
21 <http://www.linux-sh.org/>.
22
Paul Mundt39d28a22007-11-08 18:39:33 +090023config SUPERH32
Paul Mundtea0e1a92007-11-21 15:58:01 +090024 def_bool !SUPERH64
Chris Smithd39f5452008-09-05 17:15:39 +090025 select HAVE_KPROBES
26 select HAVE_KRETPROBES
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 Mundtab6e5702008-12-11 18:46:46 +090030 select HAVE_ARCH_KGDB
Paul Mundtea0e1a92007-11-21 15:58:01 +090031
32config SUPERH64
33 def_bool y if CPU_SH5
Paul Mundt39d28a22007-11-08 18:39:33 +090034
Paul Mundtf42b7e32008-07-29 20:12:51 +090035config ARCH_DEFCONFIG
36 string
37 default "arch/sh/configs/shx3_defconfig" if SUPERH32
38 default "arch/sh/configs/cayman_defconfig" if SUPERH64
39
Linus Torvalds1da177e2005-04-16 15:20:36 -070040config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090041 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070042
43config RWSEM_XCHGADD_ALGORITHM
44 bool
45
Paul Mundtfa691512007-03-08 19:41:21 +090046config GENERIC_BUG
47 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090048 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090049
Akinobu Mitae2268c72006-03-26 01:39:35 -080050config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090051 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080052
53config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090054 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080055
Linus Torvalds1da177e2005-04-16 15:20:36 -070056config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090057 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070058
Paul Mundt5093c9a2008-08-04 14:17:13 +090059config GENERIC_HARDIRQS_NO__DO_IRQ
60 def_bool y
61
Linus Torvalds1da177e2005-04-16 15:20:36 -070062config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090063 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070064
Magnus Damm2967dab2008-10-08 20:41:43 +090065config GENERIC_GPIO
66 def_bool n
67
Linus Torvalds1da177e2005-04-16 15:20:36 -070068config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090069 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070070
Paul Mundtcad82442006-01-16 22:14:19 -080071config GENERIC_IOMAP
72 bool
73
Paul Mundt45882142006-10-04 13:21:45 +090074config GENERIC_TIME
75 def_bool n
76
Paul Mundt57be2b42007-05-09 17:33:24 +090077config GENERIC_CLOCKEVENTS
78 def_bool n
79
Paul Mundt8c245942008-08-06 18:37:07 +090080config GENERIC_CLOCKEVENTS_BROADCAST
81 bool
82
Paul Mundtbdcab872008-08-04 14:09:15 +090083config GENERIC_LOCKBREAK
84 def_bool y
85 depends on SMP && PREEMPT
86
Paul Mundt357d5942007-06-11 15:32:07 +090087config SYS_SUPPORTS_PM
88 bool
Magnus Dammaf998a92008-12-04 22:45:12 +090089 depends on !SMP
90
91config ARCH_SUSPEND_POSSIBLE
92 def_bool n
93
94config ARCH_HIBERNATION_POSSIBLE
95 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +090096
Paul Mundt0a9b0db2007-01-24 21:56:20 +090097config SYS_SUPPORTS_APM_EMULATION
98 bool
Magnus Dammaf998a92008-12-04 22:45:12 +090099 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900100
101config SYS_SUPPORTS_SMP
102 bool
103
104config SYS_SUPPORTS_NUMA
105 bool
106
107config SYS_SUPPORTS_PCI
108 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900109
Paul Mundtf5ad8812009-01-29 18:08:58 +0900110config SYS_SUPPORTS_CMT
111 bool
112
Paul Mundtafbfb522006-12-04 18:17:28 +0900113config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900114 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900115
116config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900117 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900118
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900119config HAVE_LATENCYTOP_SUPPORT
120 def_bool y
121 depends on !SMP
122
David Howellsf0d1b0b2006-12-08 02:37:49 -0800123config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900124 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800125
126config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900127 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800128
Paul Mundte257ad02007-07-25 11:18:00 +0900129config ARCH_NO_VIRT_TO_BUS
130 def_bool y
131
Magnus Damme7cc9a72008-02-07 20:18:21 +0900132config IO_TRAPPED
133 bool
134
Linus Torvalds1da177e2005-04-16 15:20:36 -0700135source "init/Kconfig"
136
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700137source "kernel/Kconfig.freezer"
138
Linus Torvalds1da177e2005-04-16 15:20:36 -0700139menu "System type"
140
Paul Mundtb5f42db2007-11-08 18:38:14 +0900141#
142# Processor families
143#
144config CPU_SH2
145 bool
146
147config CPU_SH2A
148 bool
149 select CPU_SH2
150
151config CPU_SH3
152 bool
153 select CPU_HAS_INTEVT
154 select CPU_HAS_SR_RB
155
156config CPU_SH4
157 bool
158 select CPU_HAS_INTEVT
159 select CPU_HAS_SR_RB
160 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
161 select CPU_HAS_FPU if !CPU_SH4AL_DSP
162
163config CPU_SH4A
164 bool
165 select CPU_SH4
166
167config CPU_SH4AL_DSP
168 bool
169 select CPU_SH4A
170 select CPU_HAS_DSP
171
Paul Mundtea0e1a92007-11-21 15:58:01 +0900172config CPU_SH5
173 bool
174 select CPU_HAS_FPU
175
Paul Mundtb5f42db2007-11-08 18:38:14 +0900176config CPU_SHX2
177 bool
178
179config CPU_SHX3
180 bool
181
Paul Mundtdc65a972009-03-10 16:26:29 +0900182config ARCH_SHMOBILE
183 bool
Magnus Damm77594912009-03-13 15:23:04 +0000184 select ARCH_SUSPEND_POSSIBLE
Paul Mundtdc65a972009-03-10 16:26:29 +0900185
Paul Mundtb5f42db2007-11-08 18:38:14 +0900186choice
187 prompt "Processor sub-type selection"
188
189#
190# Processor subtypes
191#
192
193# SH-2 Processor Support
194
195config CPU_SUBTYPE_SH7619
196 bool "Support SH7619 processor"
197 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900198 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900199
200# SH-2A Processor Support
201
Peter Griffin28259992008-11-28 22:48:20 +0900202config CPU_SUBTYPE_SH7201
203 bool "Support SH7201 processor"
204 select CPU_SH2A
205 select CPU_HAS_FPU
206
Paul Mundt6d01f512007-11-26 18:17:21 +0900207config CPU_SUBTYPE_SH7203
208 bool "Support SH7203 processor"
209 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900210 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900211 select SYS_SUPPORTS_CMT
Paul Mundt6d01f512007-11-26 18:17:21 +0900212
Paul Mundtb5f42db2007-11-08 18:38:14 +0900213config CPU_SUBTYPE_SH7206
214 bool "Support SH7206 processor"
215 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900216 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900217
Paul Mundta8f67f42007-11-26 19:54:02 +0900218config CPU_SUBTYPE_SH7263
219 bool "Support SH7263 processor"
220 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900221 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900222 select SYS_SUPPORTS_CMT
Paul Mundta8f67f42007-11-26 19:54:02 +0900223
Paul Mundt2ad69902008-03-13 12:52:44 +0900224config CPU_SUBTYPE_MXG
225 bool "Support MX-G processor"
226 select CPU_SH2A
227 help
228 Select MX-G if running on an R8A03022BG part.
229
Paul Mundtb5f42db2007-11-08 18:38:14 +0900230# SH-3 Processor Support
231
232config CPU_SUBTYPE_SH7705
233 bool "Support SH7705 processor"
234 select CPU_SH3
235
236config CPU_SUBTYPE_SH7706
237 bool "Support SH7706 processor"
238 select CPU_SH3
239 help
240 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
241
242config CPU_SUBTYPE_SH7707
243 bool "Support SH7707 processor"
244 select CPU_SH3
245 help
246 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
247
248config CPU_SUBTYPE_SH7708
249 bool "Support SH7708 processor"
250 select CPU_SH3
251 help
252 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
253 if you have a 100 Mhz SH-3 HD6417708R CPU.
254
255config CPU_SUBTYPE_SH7709
256 bool "Support SH7709 processor"
257 select CPU_SH3
258 help
259 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
260
261config CPU_SUBTYPE_SH7710
262 bool "Support SH7710 processor"
263 select CPU_SH3
264 select CPU_HAS_DSP
265 help
266 Select SH7710 if you have a SH3-DSP SH7710 CPU.
267
268config CPU_SUBTYPE_SH7712
269 bool "Support SH7712 processor"
270 select CPU_SH3
271 select CPU_HAS_DSP
272 help
273 Select SH7712 if you have a SH3-DSP SH7712 CPU.
274
275config CPU_SUBTYPE_SH7720
276 bool "Support SH7720 processor"
277 select CPU_SH3
278 select CPU_HAS_DSP
279 help
280 Select SH7720 if you have a SH3-DSP SH7720 CPU.
281
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900282config CPU_SUBTYPE_SH7721
283 bool "Support SH7721 processor"
284 select CPU_SH3
285 select CPU_HAS_DSP
286 help
287 Select SH7721 if you have a SH3-DSP SH7721 CPU.
288
Paul Mundtb5f42db2007-11-08 18:38:14 +0900289# SH-4 Processor Support
290
291config CPU_SUBTYPE_SH7750
292 bool "Support SH7750 processor"
293 select CPU_SH4
294 help
295 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
296
297config CPU_SUBTYPE_SH7091
298 bool "Support SH7091 processor"
299 select CPU_SH4
300 help
301 Select SH7091 if you have an SH-4 based Sega device (such as
302 the Dreamcast, Naomi, and Naomi 2).
303
304config CPU_SUBTYPE_SH7750R
305 bool "Support SH7750R processor"
306 select CPU_SH4
307
308config CPU_SUBTYPE_SH7750S
309 bool "Support SH7750S processor"
310 select CPU_SH4
311
312config CPU_SUBTYPE_SH7751
313 bool "Support SH7751 processor"
314 select CPU_SH4
315 help
316 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
317 or if you have a HD6417751R CPU.
318
319config CPU_SUBTYPE_SH7751R
320 bool "Support SH7751R processor"
321 select CPU_SH4
322
323config CPU_SUBTYPE_SH7760
324 bool "Support SH7760 processor"
325 select CPU_SH4
326
327config CPU_SUBTYPE_SH4_202
328 bool "Support SH4-202 processor"
329 select CPU_SH4
330
331# SH-4A Processor Support
332
Paul Mundt178dd0c2008-04-09 17:56:18 +0900333config CPU_SUBTYPE_SH7723
334 bool "Support SH7723 processor"
335 select CPU_SH4A
336 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900337 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900338 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900339 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900340 help
341 Select SH7723 if you have an SH-MobileR2 CPU.
342
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900343config CPU_SUBTYPE_SH7763
344 bool "Support SH7763 processor"
345 select CPU_SH4A
346 help
347 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
348
Paul Mundtb5f42db2007-11-08 18:38:14 +0900349config CPU_SUBTYPE_SH7770
350 bool "Support SH7770 processor"
351 select CPU_SH4A
352
353config CPU_SUBTYPE_SH7780
354 bool "Support SH7780 processor"
355 select CPU_SH4A
356
357config CPU_SUBTYPE_SH7785
358 bool "Support SH7785 processor"
359 select CPU_SH4A
360 select CPU_SHX2
361 select ARCH_SPARSEMEM_ENABLE
362 select SYS_SUPPORTS_NUMA
363
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900364config CPU_SUBTYPE_SH7786
365 bool "Support SH7786 processor"
366 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900367 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900368 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900369 select ARCH_SPARSEMEM_ENABLE
370 select SYS_SUPPORTS_NUMA
371
Paul Mundtb5f42db2007-11-08 18:38:14 +0900372config CPU_SUBTYPE_SHX3
373 bool "Support SH-X3 processor"
374 select CPU_SH4A
375 select CPU_SHX3
376 select ARCH_SPARSEMEM_ENABLE
377 select SYS_SUPPORTS_NUMA
378 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900379 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900380
381# SH4AL-DSP Processor Support
382
383config CPU_SUBTYPE_SH7343
384 bool "Support SH7343 processor"
385 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900386 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900387 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900388
389config CPU_SUBTYPE_SH7722
390 bool "Support SH7722 processor"
391 select CPU_SH4AL_DSP
392 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900393 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900394 select ARCH_SPARSEMEM_ENABLE
395 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900396 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900397
Magnus Damm9109a302008-02-08 17:31:24 +0900398config CPU_SUBTYPE_SH7366
399 bool "Support SH7366 processor"
400 select CPU_SH4AL_DSP
401 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900402 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900403 select ARCH_SPARSEMEM_ENABLE
404 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900405 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900406
Paul Mundtea0e1a92007-11-21 15:58:01 +0900407# SH-5 Processor Support
408
409config CPU_SUBTYPE_SH5_101
410 bool "Support SH5-101 processor"
411 select CPU_SH5
412
413config CPU_SUBTYPE_SH5_103
414 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900415 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900416
Paul Mundtb5f42db2007-11-08 18:38:14 +0900417endchoice
418
Paul Mundtcad82442006-01-16 22:14:19 -0800419source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900420
Paul Mundt4690bdc2007-11-09 13:45:42 +0900421source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800422
Paul Mundt939a24a2008-07-29 21:41:37 +0900423source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900424
Paul Mundt32351a22007-03-12 14:38:59 +0900425menu "Timer and clock configuration"
426
Paul Mundtcad82442006-01-16 22:14:19 -0800427config SH_TMU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900428 bool "TMU timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900429 depends on CPU_SH3 || CPU_SH4
Paul Mundtf5ad8812009-01-29 18:08:58 +0900430 default y
Paul Mundt57be2b42007-05-09 17:33:24 +0900431 select GENERIC_TIME
432 select GENERIC_CLOCKEVENTS
Paul Mundtcad82442006-01-16 22:14:19 -0800433 help
434 This enables the use of the TMU as the system timer.
435
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900436config SH_CMT
Paul Mundtf5ad8812009-01-29 18:08:58 +0900437 bool "CMT timer support"
Paul Mundt508eb2c2009-02-04 15:28:06 +0900438 depends on SYS_SUPPORTS_CMT && CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900439 default y
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900440 help
441 This enables the use of the CMT as the system timer.
442
Paul Mundtf5ad8812009-01-29 18:08:58 +0900443#
444# Support for the new-style CMT driver. This will replace SH_CMT
445# once its other dependencies are merged.
446#
447config SH_TIMER_CMT
448 bool "CMT clockevents driver"
449 depends on SYS_SUPPORTS_CMT && !SH_CMT
Paul Mundtf5ad8812009-01-29 18:08:58 +0900450 select GENERIC_CLOCKEVENTS
451
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900452config SH_MTU2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900453 bool "MTU2 timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900454 depends on CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900455 default y
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900456 help
457 This enables the use of the MTU2 as the system timer.
458
Paul Mundt417528a2006-11-20 11:18:30 +0900459config SH_TIMER_IRQ
460 int
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900461 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
462 CPU_SUBTYPE_SH7763
Paul Mundt417528a2006-11-20 11:18:30 +0900463 default "86" if CPU_SUBTYPE_SH7619
464 default "140" if CPU_SUBTYPE_SH7206
Paul Mundtd63f3a52009-01-29 18:10:13 +0900465 default "142" if CPU_SUBTYPE_SH7203 && SH_CMT
466 default "153" if CPU_SUBTYPE_SH7203 && SH_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900467 default "238" if CPU_SUBTYPE_MXG
Paul Mundt417528a2006-11-20 11:18:30 +0900468 default "16"
469
Paul Mundtcad82442006-01-16 22:14:19 -0800470config SH_PCLK_FREQ
471 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900472 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900473 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900474 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900475 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900476 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900477 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900478 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
479 CPU_SUBTYPE_SH7786
Paul Mundt05627482007-05-15 16:25:47 +0900480 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800481 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900482 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800483 help
484 This option is used to specify the peripheral clock frequency.
485 This is necessary for determining the reference clock value on
486 platforms lacking an RTC.
487
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900488config SH_CLK_MD
489 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900490 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900491 default 6 if CPU_SUBTYPE_SH7206
492 default 5 if CPU_SUBTYPE_SH7619
493 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900494 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900495 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900496
Paul Mundt57be2b42007-05-09 17:33:24 +0900497source "kernel/time/Kconfig"
498
Paul Mundt32351a22007-03-12 14:38:59 +0900499endmenu
500
Paul Mundtcad82442006-01-16 22:14:19 -0800501menu "CPU Frequency scaling"
502
503source "drivers/cpufreq/Kconfig"
504
505config SH_CPU_FREQ
506 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900507 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800508 select CPU_FREQ_TABLE
509 help
Paul Mundt8a655052008-12-17 15:06:54 +0900510 This adds the cpufreq driver for SuperH. Any CPU that supports
511 clock rate rounding through the clock framework can use this
512 driver. While it will make the kernel slightly larger, this is
513 harmless for CPUs that don't support rate rounding. The driver
514 will also generate a notice in the boot log before disabling
515 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800516
517 For details, take a look at <file:Documentation/cpu-freq>.
518
519 If unsure, say N.
520
521endmenu
522
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900523source "arch/sh/drivers/Kconfig"
524
Paul Mundtcad82442006-01-16 22:14:19 -0800525endmenu
526
Paul Mundtcad82442006-01-16 22:14:19 -0800527menu "Kernel features"
528
Paul Mundt91b91d02006-09-27 18:08:33 +0900529source kernel/Kconfig.hz
530
Paul Mundtcad82442006-01-16 22:14:19 -0800531config KEXEC
532 bool "kexec system call (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900533 depends on SUPERH32 && EXPERIMENTAL
Paul Mundtcad82442006-01-16 22:14:19 -0800534 help
535 kexec is a system call that implements the ability to shutdown your
536 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400537 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800538 you can start any kernel with it, not just Linux.
539
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400540 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800541
542 It is an ongoing process to be certain the hardware in a machine
543 is properly shutdown, so do not be surprised if this code does not
544 initially work for you. It may help to enable device hotplugging
545 support. As of this writing the exact hardware interface is
546 strongly in flux, so no good recommendation can be made.
547
Paul Mundt4d5ade52007-04-27 11:25:57 +0900548config CRASH_DUMP
549 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900550 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900551 help
552 Generate crash dump after being started by kexec.
553 This should be normally only set in special crash dump kernels
554 which are loaded in the main kernel with kexec-tools into
555 a specially reserved region and then later executed after
556 a crash by kdump/kexec. The crash dump kernel must be compiled
557 to a memory address not used by the main kernel using
558 MEMORY_START.
559
560 For more details see Documentation/kdump/kdump.txt
561
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000562config KEXEC_JUMP
563 bool "kexec jump (EXPERIMENTAL)"
564 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
565 help
566 Jump between original kernel and kexeced kernel and invoke
567 code via KEXEC
568
Paul Mundtc4637d42008-07-30 15:30:52 +0900569config SECCOMP
570 bool "Enable seccomp to safely compute untrusted bytecode"
571 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900572 help
573 This kernel feature is useful for number crunching applications
574 that may need to compute untrusted bytecode during their
575 execution. By using pipes or other transports made available to
576 the process as file descriptors supporting the read/write
577 syscalls, it's possible to isolate those applications in
578 their own address space using seccomp. Once seccomp is
579 enabled via prctl, it cannot be disabled and the task is only
580 allowed to execute a few safe syscalls defined by each seccomp
581 mode.
582
583 If unsure, say N.
584
Linus Torvalds1da177e2005-04-16 15:20:36 -0700585config SMP
586 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900587 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200588 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700589 ---help---
590 This enables support for systems with more than one CPU. If you have
591 a system with only one CPU, like most personal computers, say N. If
592 you have a system with more than one CPU, say Y.
593
594 If you say N here, the kernel will run on single and multiprocessor
595 machines, but will use only one CPU of a multiprocessor machine. If
596 you say Y here, the kernel will run on many, but not all,
597 singleprocessor machines. On a singleprocessor machine, the kernel
598 will run faster if you say N here.
599
600 People using multiprocessor machines who say Y here should also say
601 Y to "Enhanced Real Time Clock Support", below.
602
Adrian Bunk03502fa2008-02-03 15:50:21 +0200603 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
604 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700605
606 If you don't know what to do here, say N.
607
608config NR_CPUS
609 int "Maximum number of CPUs (2-32)"
610 range 2 32
611 depends on SMP
Paul Mundt2b1bd1a2007-06-20 18:27:10 +0900612 default "4" if CPU_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700613 default "2"
614 help
615 This allows you to specify the maximum number of CPUs which this
616 kernel will support. The maximum supported value is 32 and the
617 minimum value which makes sense is 2.
618
619 This is purely to save memory - each supported CPU adds
620 approximately eight kilobytes to the kernel image.
621
Paul Mundt91b91d02006-09-27 18:08:33 +0900622source "kernel/Kconfig.preempt"
623
Paul Mundt83662462007-09-28 16:04:49 +0900624config GUSA
625 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900626 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900627 help
628 This enables support for gUSA (general UserSpace Atomicity).
629 This is the default implementation for both UP and non-ll/sc
630 CPUs, and is used by the libc, amongst others.
631
632 For additional information, design information can be found
633 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
634
635 This should only be disabled for special cases where alternate
636 atomicity implementations exist.
637
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900638config GUSA_RB
639 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
640 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
641 help
642 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100643 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900644 store-conditional (LLSC). On machines which do not have hardware
645 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100646 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900647
Paul Mundtcad82442006-01-16 22:14:19 -0800648endmenu
649
650menu "Boot options"
651
652config ZERO_PAGE_OFFSET
653 hex "Zero page offset"
Adrian Bunkf5f826c2008-03-31 01:40:17 +0300654 default "0x00004000" if SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900655 default "0x00010000" if PAGE_SIZE_64KB
656 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800657 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700658 help
Paul Mundtcad82442006-01-16 22:14:19 -0800659 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700660
Paul Mundtcad82442006-01-16 22:14:19 -0800661config BOOT_LINK_OFFSET
662 hex "Link address offset for booting"
663 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700664 help
Paul Mundtcad82442006-01-16 22:14:19 -0800665 This option allows you to set the link address offset of the zImage.
666 This can be useful if you are on a board which has a small amount of
667 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700668
Paul Mundtcad82442006-01-16 22:14:19 -0800669config UBC_WAKEUP
670 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900671 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800672 help
673 Selecting this option will wakeup the User Break Controller (UBC) on
674 startup. Although the UBC is left in an awake state when the processor
675 comes up, some boot loaders misbehave by putting the UBC to sleep in a
676 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700677
678 If unsure, say N.
679
Paul Mundtcad82442006-01-16 22:14:19 -0800680config CMDLINE_BOOL
681 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700682
Paul Mundtcad82442006-01-16 22:14:19 -0800683config CMDLINE
684 string "Initial kernel command string"
685 depends on CMDLINE_BOOL
686 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700687
688endmenu
689
Paul Mundtcad82442006-01-16 22:14:19 -0800690menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700691
Paul Mundtcad82442006-01-16 22:14:19 -0800692config SUPERHYWAY
693 tristate "SuperHyway Bus support"
694 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700695
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900696config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900697 bool "Maple Bus support"
698 depends on SH_DREAMCAST
699 help
700 The Maple Bus is SEGA's serial communication bus for peripherals
701 on the Dreamcast. Without this bus support you won't be able to
702 get your Dreamcast keyboard etc to work, so most users
703 probably want to say 'Y' here, unless you are only using the
704 Dreamcast with a serial line terminal or a remote network
705 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900706
Linus Torvalds1da177e2005-04-16 15:20:36 -0700707source "arch/sh/drivers/pci/Kconfig"
708
Paul Mundte16038a2009-01-09 15:12:30 +0900709source "drivers/pci/pcie/Kconfig"
710
Linus Torvalds1da177e2005-04-16 15:20:36 -0700711source "drivers/pci/Kconfig"
712
713source "drivers/pcmcia/Kconfig"
714
715source "drivers/pci/hotplug/Kconfig"
716
717endmenu
718
719menu "Executable file formats"
720
721source "fs/Kconfig.binfmt"
722
723endmenu
724
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900725menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900726depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100727
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900728source "kernel/power/Kconfig"
729
730source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900731
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900732endmenu
733
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700734source "net/Kconfig"
735
Linus Torvalds1da177e2005-04-16 15:20:36 -0700736source "drivers/Kconfig"
737
738source "fs/Kconfig"
739
Linus Torvalds1da177e2005-04-16 15:20:36 -0700740source "arch/sh/Kconfig.debug"
741
742source "security/Kconfig"
743
744source "crypto/Kconfig"
745
746source "lib/Kconfig"