blob: e5ee3b159e50ec92b5e6b976fa1abc702b97f68c [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
Matt Flemingc601a512009-07-03 16:16:54 +090013 select HAVE_LMB
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050014 select HAVE_OPROFILE
Dmitry Baryshkov9de90ac2008-07-18 13:30:31 +040015 select HAVE_GENERIC_DMA_COHERENT
Paul Mundt21944782008-09-17 23:26:44 +090016 select HAVE_IOREMAP_PROT if MMU
Paul Mundtd7b01f72008-12-10 20:17:15 +090017 select HAVE_ARCH_TRACEHOOK
Paul Mundtf802d962009-04-09 10:36:54 -070018 select HAVE_DMA_API_DEBUG
Paul Mundt73c926b2009-10-20 12:55:56 +090019 select HAVE_DMA_ATTRS
Ingo Molnarcdd6c482009-09-21 12:02:48 +020020 select HAVE_PERF_EVENTS
Paul Mundtdf8ce252009-07-12 01:37:30 +090021 select HAVE_KERNEL_GZIP
Paul Mundt07e88e12009-07-11 13:21:19 -040022 select HAVE_KERNEL_BZIP2
23 select HAVE_KERNEL_LZMA
Paul Mundta74f7e02009-09-16 14:30:34 +090024 select HAVE_SYSCALL_TRACEPOINTS
Paul Mundt6eac1af2009-05-08 19:48:47 +090025 select RTC_LIB
Paul Mundtf01789c2009-06-17 10:43:13 +090026 select GENERIC_ATOMIC64
Linus Torvalds1da177e2005-04-16 15:20:36 -070027 help
28 The SuperH is a RISC processor targeted for use in embedded systems
29 and consumer electronics; it was also used in the Sega Dreamcast
30 gaming console. The SuperH port has a home page at
31 <http://www.linux-sh.org/>.
32
Paul Mundt39d28a22007-11-08 18:39:33 +090033config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090034 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090035 select HAVE_KPROBES
36 select HAVE_KRETPROBES
Paul Mundt694f94f2008-10-31 16:20:36 +090037 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090038 select HAVE_FTRACE_MCOUNT_RECORD
39 select HAVE_DYNAMIC_FTRACE
Matt Flemingc1340c02009-06-28 14:05:44 +010040 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Paul Mundte4b053d2009-10-13 16:52:50 +090041 select HAVE_FTRACE_NMI_ENTER if DYNAMIC_FTRACE
Matt Fleming327933f2009-07-11 00:29:03 +000042 select HAVE_FUNCTION_GRAPH_TRACER
Paul Mundtab6e5702008-12-11 18:46:46 +090043 select HAVE_ARCH_KGDB
Paul Mundt8dafc342009-04-02 11:56:38 +090044 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090045
46config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090047 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090048
Paul Mundtf42b7e32008-07-29 20:12:51 +090049config ARCH_DEFCONFIG
50 string
51 default "arch/sh/configs/shx3_defconfig" if SUPERH32
52 default "arch/sh/configs/cayman_defconfig" if SUPERH64
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090055 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070056
57config RWSEM_XCHGADD_ALGORITHM
58 bool
59
Paul Mundtfa691512007-03-08 19:41:21 +090060config GENERIC_BUG
61 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090062 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090063
Paul Mundt3767f3f2009-06-15 00:00:42 +090064config GENERIC_CSUM
65 def_bool y
66 depends on SUPERH64
67
Akinobu Mitae2268c72006-03-26 01:39:35 -080068config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090069 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080070
71config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090072 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080073
Linus Torvalds1da177e2005-04-16 15:20:36 -070074config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090075 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070076
Paul Mundt5093c9a2008-08-04 14:17:13 +090077config GENERIC_HARDIRQS_NO__DO_IRQ
78 def_bool y
79
Linus Torvalds1da177e2005-04-16 15:20:36 -070080config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090081 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070082
Paul Mundt2eb2a432009-06-19 16:00:00 +090083config IRQ_PER_CPU
84 def_bool y
85
Magnus Damm2967dab2008-10-08 20:41:43 +090086config GENERIC_GPIO
87 def_bool n
88
Linus Torvalds1da177e2005-04-16 15:20:36 -070089config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090090 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070091
Paul Mundtcad82442006-01-16 22:14:19 -080092config GENERIC_IOMAP
93 bool
94
Paul Mundt45882142006-10-04 13:21:45 +090095config GENERIC_TIME
john stultz75634312009-05-01 13:10:28 -070096 def_bool y
Paul Mundt45882142006-10-04 13:21:45 +090097
Paul Mundt57be2b42007-05-09 17:33:24 +090098config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +090099 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +0900100
Paul Mundt8c245942008-08-06 18:37:07 +0900101config GENERIC_CLOCKEVENTS_BROADCAST
102 bool
103
Paul Mundt6d134b92009-05-08 16:36:13 +0900104config GENERIC_CMOS_UPDATE
105 def_bool y
106 depends on SH_SH03 || SH_DREAMCAST
107
Paul Mundtbdcab872008-08-04 14:09:15 +0900108config GENERIC_LOCKBREAK
109 def_bool y
110 depends on SMP && PREEMPT
111
Paul Mundt357d5942007-06-11 15:32:07 +0900112config SYS_SUPPORTS_PM
113 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900114 depends on !SMP
115
116config ARCH_SUSPEND_POSSIBLE
117 def_bool n
118
119config ARCH_HIBERNATION_POSSIBLE
120 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900121
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900122config SYS_SUPPORTS_APM_EMULATION
123 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900124 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900125
126config SYS_SUPPORTS_SMP
127 bool
128
129config SYS_SUPPORTS_NUMA
130 bool
131
132config SYS_SUPPORTS_PCI
133 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900134
Paul Mundtf5ad8812009-01-29 18:08:58 +0900135config SYS_SUPPORTS_CMT
136 bool
137
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000138config SYS_SUPPORTS_MTU2
139 bool
140
Magnus Damm9570ef22009-05-01 06:51:00 +0000141config SYS_SUPPORTS_TMU
142 bool
143
Paul Mundtafbfb522006-12-04 18:17:28 +0900144config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900145 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900146
147config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900148 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900149
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900150config HAVE_LATENCYTOP_SUPPORT
151 def_bool y
152 depends on !SMP
153
David Howellsf0d1b0b2006-12-08 02:37:49 -0800154config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900155 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800156
157config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900158 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800159
Paul Mundte257ad02007-07-25 11:18:00 +0900160config ARCH_NO_VIRT_TO_BUS
161 def_bool y
162
Paul Mundte869a902009-04-02 13:08:31 +0900163config ARCH_HAS_DEFAULT_IDLE
164 def_bool y
165
Paul Mundt2e046b92009-06-19 14:40:51 +0900166config ARCH_HAS_CPU_IDLE_WAIT
167 def_bool y
168
Magnus Damme7cc9a72008-02-07 20:18:21 +0900169config IO_TRAPPED
170 bool
171
Paul Mundt01be5d62009-10-27 10:35:02 +0900172config DMA_COHERENT
173 bool
174
175config DMA_NONCOHERENT
176 def_bool !DMA_COHERENT
177
Linus Torvalds1da177e2005-04-16 15:20:36 -0700178source "init/Kconfig"
179
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700180source "kernel/Kconfig.freezer"
181
Linus Torvalds1da177e2005-04-16 15:20:36 -0700182menu "System type"
183
Paul Mundtb5f42db2007-11-08 18:38:14 +0900184#
185# Processor families
186#
187config CPU_SH2
188 bool
189
190config CPU_SH2A
191 bool
192 select CPU_SH2
193
194config CPU_SH3
195 bool
196 select CPU_HAS_INTEVT
197 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900198 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900199
200config CPU_SH4
201 bool
202 select CPU_HAS_INTEVT
203 select CPU_HAS_SR_RB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900204 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900205 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900206
207config CPU_SH4A
208 bool
209 select CPU_SH4
210
211config CPU_SH4AL_DSP
212 bool
213 select CPU_SH4A
214 select CPU_HAS_DSP
215
Paul Mundtea0e1a92007-11-21 15:58:01 +0900216config CPU_SH5
217 bool
218 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900219 select SYS_SUPPORTS_TMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900220
Paul Mundtb5f42db2007-11-08 18:38:14 +0900221config CPU_SHX2
222 bool
223
224config CPU_SHX3
225 bool
Paul Mundt01be5d62009-10-27 10:35:02 +0900226 select DMA_COHERENT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900227
Paul Mundtdc65a972009-03-10 16:26:29 +0900228config ARCH_SHMOBILE
229 bool
Magnus Damm77594912009-03-13 15:23:04 +0000230 select ARCH_SUSPEND_POSSIBLE
Magnus Dammac2c5962009-08-19 10:31:53 +0000231 select PM
232 select PM_RUNTIME
Paul Mundtdc65a972009-03-10 16:26:29 +0900233
Paul Mundt3cc000b2009-04-11 08:39:27 +0900234if SUPERH32
235
Paul Mundtb5f42db2007-11-08 18:38:14 +0900236choice
237 prompt "Processor sub-type selection"
238
239#
240# Processor subtypes
241#
242
243# SH-2 Processor Support
244
245config CPU_SUBTYPE_SH7619
246 bool "Support SH7619 processor"
247 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900248 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900249
250# SH-2A Processor Support
251
Peter Griffin28259992008-11-28 22:48:20 +0900252config CPU_SUBTYPE_SH7201
253 bool "Support SH7201 processor"
254 select CPU_SH2A
255 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000256 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900257
Paul Mundt6d01f512007-11-26 18:17:21 +0900258config CPU_SUBTYPE_SH7203
259 bool "Support SH7203 processor"
260 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900261 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900262 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000263 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900264
Paul Mundtb5f42db2007-11-08 18:38:14 +0900265config CPU_SUBTYPE_SH7206
266 bool "Support SH7206 processor"
267 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900268 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000269 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900270
Paul Mundta8f67f42007-11-26 19:54:02 +0900271config CPU_SUBTYPE_SH7263
272 bool "Support SH7263 processor"
273 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900274 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900275 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000276 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900277
Paul Mundt2ad69902008-03-13 12:52:44 +0900278config CPU_SUBTYPE_MXG
279 bool "Support MX-G processor"
280 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000281 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900282 help
283 Select MX-G if running on an R8A03022BG part.
284
Paul Mundtb5f42db2007-11-08 18:38:14 +0900285# SH-3 Processor Support
286
287config CPU_SUBTYPE_SH7705
288 bool "Support SH7705 processor"
289 select CPU_SH3
290
291config CPU_SUBTYPE_SH7706
292 bool "Support SH7706 processor"
293 select CPU_SH3
294 help
295 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
296
297config CPU_SUBTYPE_SH7707
298 bool "Support SH7707 processor"
299 select CPU_SH3
300 help
301 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
302
303config CPU_SUBTYPE_SH7708
304 bool "Support SH7708 processor"
305 select CPU_SH3
306 help
307 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
308 if you have a 100 Mhz SH-3 HD6417708R CPU.
309
310config CPU_SUBTYPE_SH7709
311 bool "Support SH7709 processor"
312 select CPU_SH3
313 help
314 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
315
316config CPU_SUBTYPE_SH7710
317 bool "Support SH7710 processor"
318 select CPU_SH3
319 select CPU_HAS_DSP
320 help
321 Select SH7710 if you have a SH3-DSP SH7710 CPU.
322
323config CPU_SUBTYPE_SH7712
324 bool "Support SH7712 processor"
325 select CPU_SH3
326 select CPU_HAS_DSP
327 help
328 Select SH7712 if you have a SH3-DSP SH7712 CPU.
329
330config CPU_SUBTYPE_SH7720
331 bool "Support SH7720 processor"
332 select CPU_SH3
333 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000334 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900335 help
336 Select SH7720 if you have a SH3-DSP SH7720 CPU.
337
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900338config CPU_SUBTYPE_SH7721
339 bool "Support SH7721 processor"
340 select CPU_SH3
341 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000342 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900343 help
344 Select SH7721 if you have a SH3-DSP SH7721 CPU.
345
Paul Mundtb5f42db2007-11-08 18:38:14 +0900346# SH-4 Processor Support
347
348config CPU_SUBTYPE_SH7750
349 bool "Support SH7750 processor"
350 select CPU_SH4
351 help
352 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
353
354config CPU_SUBTYPE_SH7091
355 bool "Support SH7091 processor"
356 select CPU_SH4
357 help
358 Select SH7091 if you have an SH-4 based Sega device (such as
359 the Dreamcast, Naomi, and Naomi 2).
360
361config CPU_SUBTYPE_SH7750R
362 bool "Support SH7750R processor"
363 select CPU_SH4
364
365config CPU_SUBTYPE_SH7750S
366 bool "Support SH7750S processor"
367 select CPU_SH4
368
369config CPU_SUBTYPE_SH7751
370 bool "Support SH7751 processor"
371 select CPU_SH4
372 help
373 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
374 or if you have a HD6417751R CPU.
375
376config CPU_SUBTYPE_SH7751R
377 bool "Support SH7751R processor"
378 select CPU_SH4
379
380config CPU_SUBTYPE_SH7760
381 bool "Support SH7760 processor"
382 select CPU_SH4
383
384config CPU_SUBTYPE_SH4_202
385 bool "Support SH4-202 processor"
386 select CPU_SH4
387
388# SH-4A Processor Support
389
Paul Mundt178dd0c2008-04-09 17:56:18 +0900390config CPU_SUBTYPE_SH7723
391 bool "Support SH7723 processor"
392 select CPU_SH4A
393 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900394 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900395 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900396 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900397 help
398 Select SH7723 if you have an SH-MobileR2 CPU.
399
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900400config CPU_SUBTYPE_SH7724
401 bool "Support SH7724 processor"
402 select CPU_SH4A
403 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900404 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900405 select ARCH_SPARSEMEM_ENABLE
406 select SYS_SUPPORTS_CMT
407 help
408 Select SH7724 if you have an SH-MobileR2R CPU.
409
Yoshihiro Shimodac01f0f12009-08-21 16:30:28 +0900410config CPU_SUBTYPE_SH7757
411 bool "Support SH7757 processor"
412 select CPU_SH4A
413 select CPU_SHX2
414 help
415 Select SH7757 if you have a SH4A SH7757 CPU.
416
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900417config CPU_SUBTYPE_SH7763
418 bool "Support SH7763 processor"
419 select CPU_SH4A
420 help
421 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
422
Paul Mundtb5f42db2007-11-08 18:38:14 +0900423config CPU_SUBTYPE_SH7770
424 bool "Support SH7770 processor"
425 select CPU_SH4A
426
427config CPU_SUBTYPE_SH7780
428 bool "Support SH7780 processor"
429 select CPU_SH4A
430
431config CPU_SUBTYPE_SH7785
432 bool "Support SH7785 processor"
433 select CPU_SH4A
434 select CPU_SHX2
435 select ARCH_SPARSEMEM_ENABLE
436 select SYS_SUPPORTS_NUMA
437
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900438config CPU_SUBTYPE_SH7786
439 bool "Support SH7786 processor"
440 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900441 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900442 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900443 select ARCH_SPARSEMEM_ENABLE
444 select SYS_SUPPORTS_NUMA
Paul Mundt2eb2a432009-06-19 16:00:00 +0900445 select SYS_SUPPORTS_SMP
446 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900447
Paul Mundtb5f42db2007-11-08 18:38:14 +0900448config CPU_SUBTYPE_SHX3
449 bool "Support SH-X3 processor"
450 select CPU_SH4A
451 select CPU_SHX3
452 select ARCH_SPARSEMEM_ENABLE
453 select SYS_SUPPORTS_NUMA
454 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900455 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900456
457# SH4AL-DSP Processor Support
458
459config CPU_SUBTYPE_SH7343
460 bool "Support SH7343 processor"
461 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900462 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900463 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900464
465config CPU_SUBTYPE_SH7722
466 bool "Support SH7722 processor"
467 select CPU_SH4AL_DSP
468 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900469 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900470 select ARCH_SPARSEMEM_ENABLE
471 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900472 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900473
Magnus Damm9109a302008-02-08 17:31:24 +0900474config CPU_SUBTYPE_SH7366
475 bool "Support SH7366 processor"
476 select CPU_SH4AL_DSP
477 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900478 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900479 select ARCH_SPARSEMEM_ENABLE
480 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900481 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900482
Paul Mundt3cc000b2009-04-11 08:39:27 +0900483endchoice
484
485endif
486
487if SUPERH64
488
489choice
490 prompt "Processor sub-type selection"
491
Paul Mundtea0e1a92007-11-21 15:58:01 +0900492# SH-5 Processor Support
493
494config CPU_SUBTYPE_SH5_101
495 bool "Support SH5-101 processor"
496 select CPU_SH5
497
498config CPU_SUBTYPE_SH5_103
499 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900500 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900501
Paul Mundtb5f42db2007-11-08 18:38:14 +0900502endchoice
503
Paul Mundt3cc000b2009-04-11 08:39:27 +0900504endif
505
Paul Mundtcad82442006-01-16 22:14:19 -0800506source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900507
Paul Mundt4690bdc2007-11-09 13:45:42 +0900508source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800509
Paul Mundt939a24a2008-07-29 21:41:37 +0900510source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900511
Paul Mundt32351a22007-03-12 14:38:59 +0900512menu "Timer and clock configuration"
513
Magnus Damm9570ef22009-05-01 06:51:00 +0000514config SH_TIMER_TMU
515 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000516 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000517 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000518 help
519 This enables the build of the TMU timer driver.
520
Paul Mundtf5ad8812009-01-29 18:08:58 +0900521config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000522 bool "CMT timer driver"
523 depends on SYS_SUPPORTS_CMT
524 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000525 help
526 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900527
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000528config SH_TIMER_MTU2
529 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000530 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000531 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000532 help
533 This enables build of the MTU2 timer driver.
534
Paul Mundtcad82442006-01-16 22:14:19 -0800535config SH_PCLK_FREQ
536 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900537 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900538 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900539 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900540 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900541 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900542 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900543 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
Kuninori Morimoto47785412009-05-29 07:41:26 +0000544 CPU_SUBTYPE_SH7786 || CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900545 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800546 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900547 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800548 help
549 This option is used to specify the peripheral clock frequency.
550 This is necessary for determining the reference clock value on
551 platforms lacking an RTC.
552
Paul Mundt36aa1e32009-05-22 14:00:34 +0900553config SH_CLK_CPG
554 def_bool y
555
Paul Mundt253b0882009-05-13 17:38:11 +0900556config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900557 depends on SH_CLK_CPG
Magnus Damm46e93712009-06-04 07:37:59 +0000558 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE
Paul Mundt253b0882009-05-13 17:38:11 +0900559
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900560config SH_CLK_MD
561 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900562 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900563 default 6 if CPU_SUBTYPE_SH7206
564 default 5 if CPU_SUBTYPE_SH7619
565 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900566 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900567 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900568
Paul Mundt57be2b42007-05-09 17:33:24 +0900569source "kernel/time/Kconfig"
570
Paul Mundt32351a22007-03-12 14:38:59 +0900571endmenu
572
Paul Mundtcad82442006-01-16 22:14:19 -0800573menu "CPU Frequency scaling"
574
575source "drivers/cpufreq/Kconfig"
576
577config SH_CPU_FREQ
578 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900579 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800580 select CPU_FREQ_TABLE
581 help
Paul Mundt8a655052008-12-17 15:06:54 +0900582 This adds the cpufreq driver for SuperH. Any CPU that supports
583 clock rate rounding through the clock framework can use this
584 driver. While it will make the kernel slightly larger, this is
585 harmless for CPUs that don't support rate rounding. The driver
586 will also generate a notice in the boot log before disabling
587 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800588
589 For details, take a look at <file:Documentation/cpu-freq>.
590
591 If unsure, say N.
592
593endmenu
594
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900595source "arch/sh/drivers/Kconfig"
596
Paul Mundtcad82442006-01-16 22:14:19 -0800597endmenu
598
Paul Mundtcad82442006-01-16 22:14:19 -0800599menu "Kernel features"
600
Paul Mundt91b91d02006-09-27 18:08:33 +0900601source kernel/Kconfig.hz
602
Paul Mundtcad82442006-01-16 22:14:19 -0800603config KEXEC
604 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000605 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800606 help
607 kexec is a system call that implements the ability to shutdown your
608 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400609 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800610 you can start any kernel with it, not just Linux.
611
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400612 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800613
614 It is an ongoing process to be certain the hardware in a machine
615 is properly shutdown, so do not be surprised if this code does not
616 initially work for you. It may help to enable device hotplugging
617 support. As of this writing the exact hardware interface is
618 strongly in flux, so no good recommendation can be made.
619
Paul Mundt4d5ade52007-04-27 11:25:57 +0900620config CRASH_DUMP
621 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900622 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900623 help
624 Generate crash dump after being started by kexec.
625 This should be normally only set in special crash dump kernels
626 which are loaded in the main kernel with kexec-tools into
627 a specially reserved region and then later executed after
628 a crash by kdump/kexec. The crash dump kernel must be compiled
629 to a memory address not used by the main kernel using
630 MEMORY_START.
631
632 For more details see Documentation/kdump/kdump.txt
633
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000634config KEXEC_JUMP
635 bool "kexec jump (EXPERIMENTAL)"
636 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
637 help
638 Jump between original kernel and kexeced kernel and invoke
639 code via KEXEC
640
Paul Mundtc4637d42008-07-30 15:30:52 +0900641config SECCOMP
642 bool "Enable seccomp to safely compute untrusted bytecode"
643 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900644 help
645 This kernel feature is useful for number crunching applications
646 that may need to compute untrusted bytecode during their
647 execution. By using pipes or other transports made available to
648 the process as file descriptors supporting the read/write
649 syscalls, it's possible to isolate those applications in
650 their own address space using seccomp. Once seccomp is
651 enabled via prctl, it cannot be disabled and the task is only
652 allowed to execute a few safe syscalls defined by each seccomp
653 mode.
654
655 If unsure, say N.
656
Linus Torvalds1da177e2005-04-16 15:20:36 -0700657config SMP
658 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900659 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200660 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700661 ---help---
662 This enables support for systems with more than one CPU. If you have
663 a system with only one CPU, like most personal computers, say N. If
664 you have a system with more than one CPU, say Y.
665
666 If you say N here, the kernel will run on single and multiprocessor
667 machines, but will use only one CPU of a multiprocessor machine. If
668 you say Y here, the kernel will run on many, but not all,
669 singleprocessor machines. On a singleprocessor machine, the kernel
670 will run faster if you say N here.
671
672 People using multiprocessor machines who say Y here should also say
673 Y to "Enhanced Real Time Clock Support", below.
674
Adrian Bunk03502fa2008-02-03 15:50:21 +0200675 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
676 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700677
678 If you don't know what to do here, say N.
679
680config NR_CPUS
681 int "Maximum number of CPUs (2-32)"
682 range 2 32
683 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900684 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700685 default "2"
686 help
687 This allows you to specify the maximum number of CPUs which this
688 kernel will support. The maximum supported value is 32 and the
689 minimum value which makes sense is 2.
690
691 This is purely to save memory - each supported CPU adds
692 approximately eight kilobytes to the kernel image.
693
Paul Mundt91b91d02006-09-27 18:08:33 +0900694source "kernel/Kconfig.preempt"
695
Paul Mundt83662462007-09-28 16:04:49 +0900696config GUSA
697 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900698 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900699 help
700 This enables support for gUSA (general UserSpace Atomicity).
701 This is the default implementation for both UP and non-ll/sc
702 CPUs, and is used by the libc, amongst others.
703
704 For additional information, design information can be found
705 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
706
707 This should only be disabled for special cases where alternate
708 atomicity implementations exist.
709
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900710config GUSA_RB
711 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
712 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
713 help
714 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100715 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900716 store-conditional (LLSC). On machines which do not have hardware
717 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100718 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900719
Paul Mundt54ff3282009-06-11 10:33:09 +0300720config SPARSE_IRQ
721 bool "Support sparse irq numbering"
722 depends on EXPERIMENTAL
723 help
724 This enables support for sparse irqs. This is useful in general
725 as most CPUs have a fairly sparse array of IRQ vectors, which
726 the irq_desc then maps directly on to. Systems with a high
727 number of off-chip IRQs will want to treat this as
728 experimental until they have been independently verified.
729
730 If you don't know what to do here, say N.
731
Paul Mundtcad82442006-01-16 22:14:19 -0800732endmenu
733
734menu "Boot options"
735
736config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900737 hex
738 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
739 SH_7751_SOLUTION_ENGINE
740 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900741 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800742 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700743 help
Paul Mundtcad82442006-01-16 22:14:19 -0800744 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700745
Paul Mundtcad82442006-01-16 22:14:19 -0800746config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900747 hex
748 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900749 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900750 default "0x00810000" if SH_7780_SOLUTION_ENGINE
751 default "0x009e0000" if SH_TITAN
752 default "0x01800000" if SH_SDK7780
753 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800754 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700755 help
Paul Mundtcad82442006-01-16 22:14:19 -0800756 This option allows you to set the link address offset of the zImage.
757 This can be useful if you are on a board which has a small amount of
758 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700759
Paul Mundtb412a49a2009-05-10 01:23:25 +0900760config ENTRY_OFFSET
761 hex
762 default "0x00001000" if PAGE_SIZE_4KB
763 default "0x00002000" if PAGE_SIZE_8KB
764 default "0x00004000" if PAGE_SIZE_16KB
765 default "0x00010000" if PAGE_SIZE_64KB
766 default "0x00000000"
767
Pawel Molld724a9c2009-08-24 16:25:38 +0900768choice
769 prompt "Kernel command line"
770 optional
771 default CMDLINE_OVERWRITE
772 help
773 Setting this option allows the kernel command line arguments
774 to be set.
775
776config CMDLINE_OVERWRITE
777 bool "Overwrite bootloader kernel arguments"
778 help
779 Given string will overwrite any arguments passed in by
780 a bootloader.
781
782config CMDLINE_EXTEND
783 bool "Extend bootloader kernel arguments"
784 help
785 Given string will be concatenated with arguments passed in
786 by a bootloader.
787
788endchoice
Linus Torvalds1da177e2005-04-16 15:20:36 -0700789
Paul Mundtcad82442006-01-16 22:14:19 -0800790config CMDLINE
Pawel Molld724a9c2009-08-24 16:25:38 +0900791 string "Kernel command line arguments string"
792 depends on CMDLINE_OVERWRITE || CMDLINE_EXTEND
Paul Mundtcad82442006-01-16 22:14:19 -0800793 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794
795endmenu
796
Paul Mundtcad82442006-01-16 22:14:19 -0800797menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700798
Paul Mundtcad82442006-01-16 22:14:19 -0800799config SUPERHYWAY
800 tristate "SuperHyway Bus support"
801 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700802
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900803config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900804 bool "Maple Bus support"
805 depends on SH_DREAMCAST
806 help
807 The Maple Bus is SEGA's serial communication bus for peripherals
808 on the Dreamcast. Without this bus support you won't be able to
809 get your Dreamcast keyboard etc to work, so most users
810 probably want to say 'Y' here, unless you are only using the
811 Dreamcast with a serial line terminal or a remote network
812 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900813
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814source "arch/sh/drivers/pci/Kconfig"
815
Paul Mundte16038a2009-01-09 15:12:30 +0900816source "drivers/pci/pcie/Kconfig"
817
Linus Torvalds1da177e2005-04-16 15:20:36 -0700818source "drivers/pci/Kconfig"
819
820source "drivers/pcmcia/Kconfig"
821
822source "drivers/pci/hotplug/Kconfig"
823
824endmenu
825
826menu "Executable file formats"
827
828source "fs/Kconfig.binfmt"
829
830endmenu
831
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900832menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900833depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100834
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900835source "kernel/power/Kconfig"
836
837source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900838
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900839endmenu
840
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700841source "net/Kconfig"
842
Linus Torvalds1da177e2005-04-16 15:20:36 -0700843source "drivers/Kconfig"
844
845source "fs/Kconfig"
846
Linus Torvalds1da177e2005-04-16 15:20:36 -0700847source "arch/sh/Kconfig.debug"
848
849source "security/Kconfig"
850
851source "crypto/Kconfig"
852
853source "lib/Kconfig"