blob: 164748945f953ea833b7703f51f2302a49aa3055 [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
Paul Mundtf802d962009-04-09 10:36:54 -070017 select HAVE_DMA_API_DEBUG
Linus Torvalds1da177e2005-04-16 15:20:36 -070018 help
19 The SuperH is a RISC processor targeted for use in embedded systems
20 and consumer electronics; it was also used in the Sega Dreamcast
21 gaming console. The SuperH port has a home page at
22 <http://www.linux-sh.org/>.
23
Paul Mundt39d28a22007-11-08 18:39:33 +090024config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090025 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090026 select HAVE_KPROBES
27 select HAVE_KRETPROBES
Paul Mundt694f94f2008-10-31 16:20:36 +090028 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090029 select HAVE_FTRACE_MCOUNT_RECORD
30 select HAVE_DYNAMIC_FTRACE
Paul Mundtab6e5702008-12-11 18:46:46 +090031 select HAVE_ARCH_KGDB
Paul Mundt8dafc342009-04-02 11:56:38 +090032 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090033
34config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090035 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090036
Paul Mundtf42b7e32008-07-29 20:12:51 +090037config ARCH_DEFCONFIG
38 string
39 default "arch/sh/configs/shx3_defconfig" if SUPERH32
40 default "arch/sh/configs/cayman_defconfig" if SUPERH64
41
Linus Torvalds1da177e2005-04-16 15:20:36 -070042config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090043 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
45config RWSEM_XCHGADD_ALGORITHM
46 bool
47
Paul Mundtfa691512007-03-08 19:41:21 +090048config GENERIC_BUG
49 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090050 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090051
Akinobu Mitae2268c72006-03-26 01:39:35 -080052config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090053 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080054
55config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090056 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080057
Linus Torvalds1da177e2005-04-16 15:20:36 -070058config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090059 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
Paul Mundt5093c9a2008-08-04 14:17:13 +090061config GENERIC_HARDIRQS_NO__DO_IRQ
62 def_bool y
63
Linus Torvalds1da177e2005-04-16 15:20:36 -070064config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090065 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070066
Magnus Damm2967dab2008-10-08 20:41:43 +090067config GENERIC_GPIO
68 def_bool n
69
Linus Torvalds1da177e2005-04-16 15:20:36 -070070config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090071 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070072
Paul Mundtcad82442006-01-16 22:14:19 -080073config GENERIC_IOMAP
74 bool
75
Paul Mundt45882142006-10-04 13:21:45 +090076config GENERIC_TIME
77 def_bool n
78
Paul Mundt57be2b42007-05-09 17:33:24 +090079config GENERIC_CLOCKEVENTS
80 def_bool n
81
Paul Mundt8c245942008-08-06 18:37:07 +090082config GENERIC_CLOCKEVENTS_BROADCAST
83 bool
84
Paul Mundtbdcab872008-08-04 14:09:15 +090085config GENERIC_LOCKBREAK
86 def_bool y
87 depends on SMP && PREEMPT
88
Paul Mundt357d5942007-06-11 15:32:07 +090089config SYS_SUPPORTS_PM
90 bool
Magnus Dammaf998a92008-12-04 22:45:12 +090091 depends on !SMP
92
93config ARCH_SUSPEND_POSSIBLE
94 def_bool n
95
96config ARCH_HIBERNATION_POSSIBLE
97 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +090098
Paul Mundt0a9b0db2007-01-24 21:56:20 +090099config SYS_SUPPORTS_APM_EMULATION
100 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900101 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900102
103config SYS_SUPPORTS_SMP
104 bool
105
106config SYS_SUPPORTS_NUMA
107 bool
108
109config SYS_SUPPORTS_PCI
110 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900111
Paul Mundtf5ad8812009-01-29 18:08:58 +0900112config SYS_SUPPORTS_CMT
113 bool
114
Paul Mundtafbfb522006-12-04 18:17:28 +0900115config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900116 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900117
118config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900119 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900120
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900121config HAVE_LATENCYTOP_SUPPORT
122 def_bool y
123 depends on !SMP
124
David Howellsf0d1b0b2006-12-08 02:37:49 -0800125config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900126 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800127
128config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900129 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800130
Paul Mundte257ad02007-07-25 11:18:00 +0900131config ARCH_NO_VIRT_TO_BUS
132 def_bool y
133
Paul Mundte869a902009-04-02 13:08:31 +0900134config ARCH_HAS_DEFAULT_IDLE
135 def_bool y
136
Magnus Damme7cc9a72008-02-07 20:18:21 +0900137config IO_TRAPPED
138 bool
139
Linus Torvalds1da177e2005-04-16 15:20:36 -0700140source "init/Kconfig"
141
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700142source "kernel/Kconfig.freezer"
143
Linus Torvalds1da177e2005-04-16 15:20:36 -0700144menu "System type"
145
Paul Mundtb5f42db2007-11-08 18:38:14 +0900146#
147# Processor families
148#
149config CPU_SH2
150 bool
151
152config CPU_SH2A
153 bool
154 select CPU_SH2
155
156config CPU_SH3
157 bool
158 select CPU_HAS_INTEVT
159 select CPU_HAS_SR_RB
160
161config CPU_SH4
162 bool
163 select CPU_HAS_INTEVT
164 select CPU_HAS_SR_RB
165 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
166 select CPU_HAS_FPU if !CPU_SH4AL_DSP
167
168config CPU_SH4A
169 bool
170 select CPU_SH4
171
172config CPU_SH4AL_DSP
173 bool
174 select CPU_SH4A
175 select CPU_HAS_DSP
176
Paul Mundtea0e1a92007-11-21 15:58:01 +0900177config CPU_SH5
178 bool
179 select CPU_HAS_FPU
180
Paul Mundtb5f42db2007-11-08 18:38:14 +0900181config CPU_SHX2
182 bool
183
184config CPU_SHX3
185 bool
186
Paul Mundtdc65a972009-03-10 16:26:29 +0900187config ARCH_SHMOBILE
188 bool
Magnus Damm77594912009-03-13 15:23:04 +0000189 select ARCH_SUSPEND_POSSIBLE
Paul Mundtdc65a972009-03-10 16:26:29 +0900190
Paul Mundt3cc000b2009-04-11 08:39:27 +0900191if SUPERH32
192
Paul Mundtb5f42db2007-11-08 18:38:14 +0900193choice
194 prompt "Processor sub-type selection"
195
196#
197# Processor subtypes
198#
199
200# SH-2 Processor Support
201
202config CPU_SUBTYPE_SH7619
203 bool "Support SH7619 processor"
204 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900205 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900206
207# SH-2A Processor Support
208
Peter Griffin28259992008-11-28 22:48:20 +0900209config CPU_SUBTYPE_SH7201
210 bool "Support SH7201 processor"
211 select CPU_SH2A
212 select CPU_HAS_FPU
213
Paul Mundt6d01f512007-11-26 18:17:21 +0900214config CPU_SUBTYPE_SH7203
215 bool "Support SH7203 processor"
216 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900217 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900218 select SYS_SUPPORTS_CMT
Paul Mundt6d01f512007-11-26 18:17:21 +0900219
Paul Mundtb5f42db2007-11-08 18:38:14 +0900220config CPU_SUBTYPE_SH7206
221 bool "Support SH7206 processor"
222 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900223 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900224
Paul Mundta8f67f42007-11-26 19:54:02 +0900225config CPU_SUBTYPE_SH7263
226 bool "Support SH7263 processor"
227 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900228 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900229 select SYS_SUPPORTS_CMT
Paul Mundta8f67f42007-11-26 19:54:02 +0900230
Paul Mundt2ad69902008-03-13 12:52:44 +0900231config CPU_SUBTYPE_MXG
232 bool "Support MX-G processor"
233 select CPU_SH2A
234 help
235 Select MX-G if running on an R8A03022BG part.
236
Paul Mundtb5f42db2007-11-08 18:38:14 +0900237# SH-3 Processor Support
238
239config CPU_SUBTYPE_SH7705
240 bool "Support SH7705 processor"
241 select CPU_SH3
242
243config CPU_SUBTYPE_SH7706
244 bool "Support SH7706 processor"
245 select CPU_SH3
246 help
247 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
248
249config CPU_SUBTYPE_SH7707
250 bool "Support SH7707 processor"
251 select CPU_SH3
252 help
253 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
254
255config CPU_SUBTYPE_SH7708
256 bool "Support SH7708 processor"
257 select CPU_SH3
258 help
259 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
260 if you have a 100 Mhz SH-3 HD6417708R CPU.
261
262config CPU_SUBTYPE_SH7709
263 bool "Support SH7709 processor"
264 select CPU_SH3
265 help
266 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
267
268config CPU_SUBTYPE_SH7710
269 bool "Support SH7710 processor"
270 select CPU_SH3
271 select CPU_HAS_DSP
272 help
273 Select SH7710 if you have a SH3-DSP SH7710 CPU.
274
275config CPU_SUBTYPE_SH7712
276 bool "Support SH7712 processor"
277 select CPU_SH3
278 select CPU_HAS_DSP
279 help
280 Select SH7712 if you have a SH3-DSP SH7712 CPU.
281
282config CPU_SUBTYPE_SH7720
283 bool "Support SH7720 processor"
284 select CPU_SH3
285 select CPU_HAS_DSP
286 help
287 Select SH7720 if you have a SH3-DSP SH7720 CPU.
288
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900289config CPU_SUBTYPE_SH7721
290 bool "Support SH7721 processor"
291 select CPU_SH3
292 select CPU_HAS_DSP
293 help
294 Select SH7721 if you have a SH3-DSP SH7721 CPU.
295
Paul Mundtb5f42db2007-11-08 18:38:14 +0900296# SH-4 Processor Support
297
298config CPU_SUBTYPE_SH7750
299 bool "Support SH7750 processor"
300 select CPU_SH4
301 help
302 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
303
304config CPU_SUBTYPE_SH7091
305 bool "Support SH7091 processor"
306 select CPU_SH4
307 help
308 Select SH7091 if you have an SH-4 based Sega device (such as
309 the Dreamcast, Naomi, and Naomi 2).
310
311config CPU_SUBTYPE_SH7750R
312 bool "Support SH7750R processor"
313 select CPU_SH4
314
315config CPU_SUBTYPE_SH7750S
316 bool "Support SH7750S processor"
317 select CPU_SH4
318
319config CPU_SUBTYPE_SH7751
320 bool "Support SH7751 processor"
321 select CPU_SH4
322 help
323 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
324 or if you have a HD6417751R CPU.
325
326config CPU_SUBTYPE_SH7751R
327 bool "Support SH7751R processor"
328 select CPU_SH4
329
330config CPU_SUBTYPE_SH7760
331 bool "Support SH7760 processor"
332 select CPU_SH4
333
334config CPU_SUBTYPE_SH4_202
335 bool "Support SH4-202 processor"
336 select CPU_SH4
337
338# SH-4A Processor Support
339
Paul Mundt178dd0c2008-04-09 17:56:18 +0900340config CPU_SUBTYPE_SH7723
341 bool "Support SH7723 processor"
342 select CPU_SH4A
343 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900344 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900345 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900346 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900347 help
348 Select SH7723 if you have an SH-MobileR2 CPU.
349
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900350config CPU_SUBTYPE_SH7724
351 bool "Support SH7724 processor"
352 select CPU_SH4A
353 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900354 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900355 select ARCH_SPARSEMEM_ENABLE
356 select SYS_SUPPORTS_CMT
357 help
358 Select SH7724 if you have an SH-MobileR2R CPU.
359
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900360config CPU_SUBTYPE_SH7763
361 bool "Support SH7763 processor"
362 select CPU_SH4A
363 help
364 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
365
Paul Mundtb5f42db2007-11-08 18:38:14 +0900366config CPU_SUBTYPE_SH7770
367 bool "Support SH7770 processor"
368 select CPU_SH4A
369
370config CPU_SUBTYPE_SH7780
371 bool "Support SH7780 processor"
372 select CPU_SH4A
373
374config CPU_SUBTYPE_SH7785
375 bool "Support SH7785 processor"
376 select CPU_SH4A
377 select CPU_SHX2
378 select ARCH_SPARSEMEM_ENABLE
379 select SYS_SUPPORTS_NUMA
380
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900381config CPU_SUBTYPE_SH7786
382 bool "Support SH7786 processor"
383 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900384 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900385 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900386 select ARCH_SPARSEMEM_ENABLE
387 select SYS_SUPPORTS_NUMA
388
Paul Mundtb5f42db2007-11-08 18:38:14 +0900389config CPU_SUBTYPE_SHX3
390 bool "Support SH-X3 processor"
391 select CPU_SH4A
392 select CPU_SHX3
393 select ARCH_SPARSEMEM_ENABLE
394 select SYS_SUPPORTS_NUMA
395 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900396 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900397
398# SH4AL-DSP Processor Support
399
400config CPU_SUBTYPE_SH7343
401 bool "Support SH7343 processor"
402 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900403 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900404 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900405
406config CPU_SUBTYPE_SH7722
407 bool "Support SH7722 processor"
408 select CPU_SH4AL_DSP
409 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900410 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900411 select ARCH_SPARSEMEM_ENABLE
412 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900413 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900414
Magnus Damm9109a302008-02-08 17:31:24 +0900415config CPU_SUBTYPE_SH7366
416 bool "Support SH7366 processor"
417 select CPU_SH4AL_DSP
418 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900419 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900420 select ARCH_SPARSEMEM_ENABLE
421 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900422 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900423
Paul Mundt3cc000b2009-04-11 08:39:27 +0900424endchoice
425
426endif
427
428if SUPERH64
429
430choice
431 prompt "Processor sub-type selection"
432
Paul Mundtea0e1a92007-11-21 15:58:01 +0900433# SH-5 Processor Support
434
435config CPU_SUBTYPE_SH5_101
436 bool "Support SH5-101 processor"
437 select CPU_SH5
438
439config CPU_SUBTYPE_SH5_103
440 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900441 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900442
Paul Mundtb5f42db2007-11-08 18:38:14 +0900443endchoice
444
Paul Mundt3cc000b2009-04-11 08:39:27 +0900445endif
446
Paul Mundtcad82442006-01-16 22:14:19 -0800447source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900448
Paul Mundt4690bdc2007-11-09 13:45:42 +0900449source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800450
Paul Mundt939a24a2008-07-29 21:41:37 +0900451source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900452
Paul Mundt32351a22007-03-12 14:38:59 +0900453menu "Timer and clock configuration"
454
Paul Mundtcad82442006-01-16 22:14:19 -0800455config SH_TMU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900456 bool "TMU timer support"
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900457 depends on CPU_SH3 || CPU_SH4
Paul Mundtf5ad8812009-01-29 18:08:58 +0900458 default y
Paul Mundt57be2b42007-05-09 17:33:24 +0900459 select GENERIC_TIME
460 select GENERIC_CLOCKEVENTS
Paul Mundtcad82442006-01-16 22:14:19 -0800461 help
462 This enables the use of the TMU as the system timer.
463
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900464config SH_CMT
Paul Mundtf5ad8812009-01-29 18:08:58 +0900465 bool "CMT timer support"
Paul Mundt508eb2c2009-02-04 15:28:06 +0900466 depends on SYS_SUPPORTS_CMT && CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900467 default y
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900468 help
469 This enables the use of the CMT as the system timer.
470
Paul Mundtf5ad8812009-01-29 18:08:58 +0900471#
472# Support for the new-style CMT driver. This will replace SH_CMT
473# once its other dependencies are merged.
474#
475config SH_TIMER_CMT
476 bool "CMT clockevents driver"
477 depends on SYS_SUPPORTS_CMT && !SH_CMT
Paul Mundtf5ad8812009-01-29 18:08:58 +0900478 select GENERIC_CLOCKEVENTS
Paul Mundt5be7c0a2009-04-27 14:40:47 +0900479 select GENERIC_TIME
Paul Mundtf5ad8812009-01-29 18:08:58 +0900480
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900481config SH_MTU2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900482 bool "MTU2 timer support"
Paul Mundt5be7c0a2009-04-27 14:40:47 +0900483 depends on CPU_SH2A && !GENERIC_TIME
Paul Mundtf5ad8812009-01-29 18:08:58 +0900484 default y
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900485 help
486 This enables the use of the MTU2 as the system timer.
487
Paul Mundt417528a2006-11-20 11:18:30 +0900488config SH_TIMER_IRQ
489 int
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900490 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
491 CPU_SUBTYPE_SH7763
Paul Mundt417528a2006-11-20 11:18:30 +0900492 default "86" if CPU_SUBTYPE_SH7619
493 default "140" if CPU_SUBTYPE_SH7206
Paul Mundtd63f3a52009-01-29 18:10:13 +0900494 default "142" if CPU_SUBTYPE_SH7203 && SH_CMT
495 default "153" if CPU_SUBTYPE_SH7203 && SH_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900496 default "238" if CPU_SUBTYPE_MXG
Paul Mundt417528a2006-11-20 11:18:30 +0900497 default "16"
498
Paul Mundtcad82442006-01-16 22:14:19 -0800499config SH_PCLK_FREQ
500 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900501 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900502 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900503 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900504 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900505 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900506 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900507 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
508 CPU_SUBTYPE_SH7786
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900509 default "41666666" if CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900510 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800511 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900512 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800513 help
514 This option is used to specify the peripheral clock frequency.
515 This is necessary for determining the reference clock value on
516 platforms lacking an RTC.
517
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900518config SH_CLK_MD
519 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900520 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900521 default 6 if CPU_SUBTYPE_SH7206
522 default 5 if CPU_SUBTYPE_SH7619
523 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900524 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900525 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900526
Paul Mundt57be2b42007-05-09 17:33:24 +0900527source "kernel/time/Kconfig"
528
Paul Mundt32351a22007-03-12 14:38:59 +0900529endmenu
530
Paul Mundtcad82442006-01-16 22:14:19 -0800531menu "CPU Frequency scaling"
532
533source "drivers/cpufreq/Kconfig"
534
535config SH_CPU_FREQ
536 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900537 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800538 select CPU_FREQ_TABLE
539 help
Paul Mundt8a655052008-12-17 15:06:54 +0900540 This adds the cpufreq driver for SuperH. Any CPU that supports
541 clock rate rounding through the clock framework can use this
542 driver. While it will make the kernel slightly larger, this is
543 harmless for CPUs that don't support rate rounding. The driver
544 will also generate a notice in the boot log before disabling
545 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800546
547 For details, take a look at <file:Documentation/cpu-freq>.
548
549 If unsure, say N.
550
551endmenu
552
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900553source "arch/sh/drivers/Kconfig"
554
Paul Mundtcad82442006-01-16 22:14:19 -0800555endmenu
556
Paul Mundtcad82442006-01-16 22:14:19 -0800557menu "Kernel features"
558
Paul Mundt91b91d02006-09-27 18:08:33 +0900559source kernel/Kconfig.hz
560
Paul Mundtcad82442006-01-16 22:14:19 -0800561config KEXEC
562 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000563 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800564 help
565 kexec is a system call that implements the ability to shutdown your
566 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400567 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800568 you can start any kernel with it, not just Linux.
569
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400570 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800571
572 It is an ongoing process to be certain the hardware in a machine
573 is properly shutdown, so do not be surprised if this code does not
574 initially work for you. It may help to enable device hotplugging
575 support. As of this writing the exact hardware interface is
576 strongly in flux, so no good recommendation can be made.
577
Paul Mundt4d5ade52007-04-27 11:25:57 +0900578config CRASH_DUMP
579 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900580 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900581 help
582 Generate crash dump after being started by kexec.
583 This should be normally only set in special crash dump kernels
584 which are loaded in the main kernel with kexec-tools into
585 a specially reserved region and then later executed after
586 a crash by kdump/kexec. The crash dump kernel must be compiled
587 to a memory address not used by the main kernel using
588 MEMORY_START.
589
590 For more details see Documentation/kdump/kdump.txt
591
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000592config KEXEC_JUMP
593 bool "kexec jump (EXPERIMENTAL)"
594 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
595 help
596 Jump between original kernel and kexeced kernel and invoke
597 code via KEXEC
598
Paul Mundtc4637d42008-07-30 15:30:52 +0900599config SECCOMP
600 bool "Enable seccomp to safely compute untrusted bytecode"
601 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900602 help
603 This kernel feature is useful for number crunching applications
604 that may need to compute untrusted bytecode during their
605 execution. By using pipes or other transports made available to
606 the process as file descriptors supporting the read/write
607 syscalls, it's possible to isolate those applications in
608 their own address space using seccomp. Once seccomp is
609 enabled via prctl, it cannot be disabled and the task is only
610 allowed to execute a few safe syscalls defined by each seccomp
611 mode.
612
613 If unsure, say N.
614
Linus Torvalds1da177e2005-04-16 15:20:36 -0700615config SMP
616 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900617 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200618 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700619 ---help---
620 This enables support for systems with more than one CPU. If you have
621 a system with only one CPU, like most personal computers, say N. If
622 you have a system with more than one CPU, say Y.
623
624 If you say N here, the kernel will run on single and multiprocessor
625 machines, but will use only one CPU of a multiprocessor machine. If
626 you say Y here, the kernel will run on many, but not all,
627 singleprocessor machines. On a singleprocessor machine, the kernel
628 will run faster if you say N here.
629
630 People using multiprocessor machines who say Y here should also say
631 Y to "Enhanced Real Time Clock Support", below.
632
Adrian Bunk03502fa2008-02-03 15:50:21 +0200633 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
634 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700635
636 If you don't know what to do here, say N.
637
638config NR_CPUS
639 int "Maximum number of CPUs (2-32)"
640 range 2 32
641 depends on SMP
Paul Mundt2b1bd1a2007-06-20 18:27:10 +0900642 default "4" if CPU_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700643 default "2"
644 help
645 This allows you to specify the maximum number of CPUs which this
646 kernel will support. The maximum supported value is 32 and the
647 minimum value which makes sense is 2.
648
649 This is purely to save memory - each supported CPU adds
650 approximately eight kilobytes to the kernel image.
651
Paul Mundt91b91d02006-09-27 18:08:33 +0900652source "kernel/Kconfig.preempt"
653
Paul Mundt83662462007-09-28 16:04:49 +0900654config GUSA
655 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900656 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900657 help
658 This enables support for gUSA (general UserSpace Atomicity).
659 This is the default implementation for both UP and non-ll/sc
660 CPUs, and is used by the libc, amongst others.
661
662 For additional information, design information can be found
663 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
664
665 This should only be disabled for special cases where alternate
666 atomicity implementations exist.
667
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900668config GUSA_RB
669 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
670 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
671 help
672 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100673 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900674 store-conditional (LLSC). On machines which do not have hardware
675 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100676 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900677
Paul Mundtcad82442006-01-16 22:14:19 -0800678endmenu
679
680menu "Boot options"
681
682config ZERO_PAGE_OFFSET
683 hex "Zero page offset"
Adrian Bunkf5f826c2008-03-31 01:40:17 +0300684 default "0x00004000" if SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900685 default "0x00010000" if PAGE_SIZE_64KB
686 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800687 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700688 help
Paul Mundtcad82442006-01-16 22:14:19 -0800689 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700690
Paul Mundtcad82442006-01-16 22:14:19 -0800691config BOOT_LINK_OFFSET
692 hex "Link address offset for booting"
693 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700694 help
Paul Mundtcad82442006-01-16 22:14:19 -0800695 This option allows you to set the link address offset of the zImage.
696 This can be useful if you are on a board which has a small amount of
697 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700698
Paul Mundtcad82442006-01-16 22:14:19 -0800699config UBC_WAKEUP
700 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900701 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800702 help
703 Selecting this option will wakeup the User Break Controller (UBC) on
704 startup. Although the UBC is left in an awake state when the processor
705 comes up, some boot loaders misbehave by putting the UBC to sleep in a
706 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700707
708 If unsure, say N.
709
Paul Mundtcad82442006-01-16 22:14:19 -0800710config CMDLINE_BOOL
711 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700712
Paul Mundtcad82442006-01-16 22:14:19 -0800713config CMDLINE
714 string "Initial kernel command string"
715 depends on CMDLINE_BOOL
716 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700717
718endmenu
719
Paul Mundtcad82442006-01-16 22:14:19 -0800720menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700721
Paul Mundtcad82442006-01-16 22:14:19 -0800722config SUPERHYWAY
723 tristate "SuperHyway Bus support"
724 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700725
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900726config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900727 bool "Maple Bus support"
728 depends on SH_DREAMCAST
729 help
730 The Maple Bus is SEGA's serial communication bus for peripherals
731 on the Dreamcast. Without this bus support you won't be able to
732 get your Dreamcast keyboard etc to work, so most users
733 probably want to say 'Y' here, unless you are only using the
734 Dreamcast with a serial line terminal or a remote network
735 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900736
Linus Torvalds1da177e2005-04-16 15:20:36 -0700737source "arch/sh/drivers/pci/Kconfig"
738
Paul Mundte16038a2009-01-09 15:12:30 +0900739source "drivers/pci/pcie/Kconfig"
740
Linus Torvalds1da177e2005-04-16 15:20:36 -0700741source "drivers/pci/Kconfig"
742
743source "drivers/pcmcia/Kconfig"
744
745source "drivers/pci/hotplug/Kconfig"
746
747endmenu
748
749menu "Executable file formats"
750
751source "fs/Kconfig.binfmt"
752
753endmenu
754
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900755menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900756depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100757
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900758source "kernel/power/Kconfig"
759
760source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900761
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900762endmenu
763
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700764source "net/Kconfig"
765
Linus Torvalds1da177e2005-04-16 15:20:36 -0700766source "drivers/Kconfig"
767
768source "fs/Kconfig"
769
Linus Torvalds1da177e2005-04-16 15:20:36 -0700770source "arch/sh/Kconfig.debug"
771
772source "security/Kconfig"
773
774source "crypto/Kconfig"
775
776source "lib/Kconfig"