blob: 2a16014d9de37405e2355ee06fff3e10a6e9ab63 [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 Mundtbb38c222009-06-24 01:41:05 +090019 select HAVE_PERF_COUNTERS
Paul Mundtdf8ce252009-07-12 01:37:30 +090020 select HAVE_KERNEL_GZIP
Paul Mundt07e88e12009-07-11 13:21:19 -040021 select HAVE_KERNEL_BZIP2
22 select HAVE_KERNEL_LZMA
Paul Mundt6eac1af2009-05-08 19:48:47 +090023 select RTC_LIB
Paul Mundtf01789c2009-06-17 10:43:13 +090024 select GENERIC_ATOMIC64
Linus Torvalds1da177e2005-04-16 15:20:36 -070025 help
26 The SuperH is a RISC processor targeted for use in embedded systems
27 and consumer electronics; it was also used in the Sega Dreamcast
28 gaming console. The SuperH port has a home page at
29 <http://www.linux-sh.org/>.
30
Paul Mundt39d28a22007-11-08 18:39:33 +090031config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090032 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090033 select HAVE_KPROBES
34 select HAVE_KRETPROBES
Paul Mundt694f94f2008-10-31 16:20:36 +090035 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090036 select HAVE_FTRACE_MCOUNT_RECORD
37 select HAVE_DYNAMIC_FTRACE
Matt Flemingc1340c02009-06-28 14:05:44 +010038 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Matt Flemingc652d782009-07-06 20:16:33 +090039 select HAVE_FTRACE_SYSCALLS
Matt Fleming327933f2009-07-11 00:29:03 +000040 select HAVE_FUNCTION_GRAPH_TRACER
Paul Mundtab6e5702008-12-11 18:46:46 +090041 select HAVE_ARCH_KGDB
Paul Mundt8dafc342009-04-02 11:56:38 +090042 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090043
44config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090045 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090046
Paul Mundtf42b7e32008-07-29 20:12:51 +090047config ARCH_DEFCONFIG
48 string
49 default "arch/sh/configs/shx3_defconfig" if SUPERH32
50 default "arch/sh/configs/cayman_defconfig" if SUPERH64
51
Linus Torvalds1da177e2005-04-16 15:20:36 -070052config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090053 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
55config RWSEM_XCHGADD_ALGORITHM
56 bool
57
Paul Mundtfa691512007-03-08 19:41:21 +090058config GENERIC_BUG
59 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090060 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090061
Paul Mundt3767f3f2009-06-15 00:00:42 +090062config GENERIC_CSUM
63 def_bool y
64 depends on SUPERH64
65
Akinobu Mitae2268c72006-03-26 01:39:35 -080066config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090067 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080068
69config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090070 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080071
Linus Torvalds1da177e2005-04-16 15:20:36 -070072config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090073 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070074
Paul Mundt5093c9a2008-08-04 14:17:13 +090075config GENERIC_HARDIRQS_NO__DO_IRQ
76 def_bool y
77
Linus Torvalds1da177e2005-04-16 15:20:36 -070078config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090079 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070080
Paul Mundt2eb2a432009-06-19 16:00:00 +090081config IRQ_PER_CPU
82 def_bool y
83
Magnus Damm2967dab2008-10-08 20:41:43 +090084config GENERIC_GPIO
85 def_bool n
86
Linus Torvalds1da177e2005-04-16 15:20:36 -070087config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090088 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070089
Paul Mundtcad82442006-01-16 22:14:19 -080090config GENERIC_IOMAP
91 bool
92
Paul Mundt45882142006-10-04 13:21:45 +090093config GENERIC_TIME
john stultz75634312009-05-01 13:10:28 -070094 def_bool y
Paul Mundt45882142006-10-04 13:21:45 +090095
Paul Mundt57be2b42007-05-09 17:33:24 +090096config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +090097 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +090098
Paul Mundt8c245942008-08-06 18:37:07 +090099config GENERIC_CLOCKEVENTS_BROADCAST
100 bool
101
Paul Mundt6d134b92009-05-08 16:36:13 +0900102config GENERIC_CMOS_UPDATE
103 def_bool y
104 depends on SH_SH03 || SH_DREAMCAST
105
Paul Mundtbdcab872008-08-04 14:09:15 +0900106config GENERIC_LOCKBREAK
107 def_bool y
108 depends on SMP && PREEMPT
109
Paul Mundt357d5942007-06-11 15:32:07 +0900110config SYS_SUPPORTS_PM
111 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900112 depends on !SMP
113
114config ARCH_SUSPEND_POSSIBLE
115 def_bool n
116
117config ARCH_HIBERNATION_POSSIBLE
118 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900119
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900120config SYS_SUPPORTS_APM_EMULATION
121 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900122 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900123
124config SYS_SUPPORTS_SMP
125 bool
126
127config SYS_SUPPORTS_NUMA
128 bool
129
130config SYS_SUPPORTS_PCI
131 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900132
Paul Mundtf5ad8812009-01-29 18:08:58 +0900133config SYS_SUPPORTS_CMT
134 bool
135
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000136config SYS_SUPPORTS_MTU2
137 bool
138
Magnus Damm9570ef22009-05-01 06:51:00 +0000139config SYS_SUPPORTS_TMU
140 bool
141
Paul Mundtafbfb522006-12-04 18:17:28 +0900142config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900143 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900144
145config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900146 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900147
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900148config HAVE_LATENCYTOP_SUPPORT
149 def_bool y
150 depends on !SMP
151
David Howellsf0d1b0b2006-12-08 02:37:49 -0800152config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900153 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800154
155config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900156 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800157
Paul Mundte257ad02007-07-25 11:18:00 +0900158config ARCH_NO_VIRT_TO_BUS
159 def_bool y
160
Paul Mundte869a902009-04-02 13:08:31 +0900161config ARCH_HAS_DEFAULT_IDLE
162 def_bool y
163
Paul Mundt2e046b92009-06-19 14:40:51 +0900164config ARCH_HAS_CPU_IDLE_WAIT
165 def_bool y
166
Magnus Damme7cc9a72008-02-07 20:18:21 +0900167config IO_TRAPPED
168 bool
169
Linus Torvalds1da177e2005-04-16 15:20:36 -0700170source "init/Kconfig"
171
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700172source "kernel/Kconfig.freezer"
173
Linus Torvalds1da177e2005-04-16 15:20:36 -0700174menu "System type"
175
Paul Mundtb5f42db2007-11-08 18:38:14 +0900176#
177# Processor families
178#
179config CPU_SH2
180 bool
181
182config CPU_SH2A
183 bool
184 select CPU_SH2
185
186config CPU_SH3
187 bool
188 select CPU_HAS_INTEVT
189 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900190 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900191
192config CPU_SH4
193 bool
194 select CPU_HAS_INTEVT
195 select CPU_HAS_SR_RB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900196 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900197 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900198
199config CPU_SH4A
200 bool
201 select CPU_SH4
202
203config CPU_SH4AL_DSP
204 bool
205 select CPU_SH4A
206 select CPU_HAS_DSP
207
Paul Mundtea0e1a92007-11-21 15:58:01 +0900208config CPU_SH5
209 bool
210 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900211 select SYS_SUPPORTS_TMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900212
Paul Mundtb5f42db2007-11-08 18:38:14 +0900213config CPU_SHX2
214 bool
215
216config CPU_SHX3
217 bool
218
Paul Mundtdc65a972009-03-10 16:26:29 +0900219config ARCH_SHMOBILE
220 bool
Magnus Damm77594912009-03-13 15:23:04 +0000221 select ARCH_SUSPEND_POSSIBLE
Magnus Dammac2c5962009-08-19 10:31:53 +0000222 select PM
223 select PM_RUNTIME
Paul Mundtdc65a972009-03-10 16:26:29 +0900224
Paul Mundt3cc000b2009-04-11 08:39:27 +0900225if SUPERH32
226
Paul Mundtb5f42db2007-11-08 18:38:14 +0900227choice
228 prompt "Processor sub-type selection"
229
230#
231# Processor subtypes
232#
233
234# SH-2 Processor Support
235
236config CPU_SUBTYPE_SH7619
237 bool "Support SH7619 processor"
238 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900239 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900240
241# SH-2A Processor Support
242
Peter Griffin28259992008-11-28 22:48:20 +0900243config CPU_SUBTYPE_SH7201
244 bool "Support SH7201 processor"
245 select CPU_SH2A
246 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000247 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900248
Paul Mundt6d01f512007-11-26 18:17:21 +0900249config CPU_SUBTYPE_SH7203
250 bool "Support SH7203 processor"
251 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900252 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900253 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000254 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900255
Paul Mundtb5f42db2007-11-08 18:38:14 +0900256config CPU_SUBTYPE_SH7206
257 bool "Support SH7206 processor"
258 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900259 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000260 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900261
Paul Mundta8f67f42007-11-26 19:54:02 +0900262config CPU_SUBTYPE_SH7263
263 bool "Support SH7263 processor"
264 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900265 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900266 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000267 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900268
Paul Mundt2ad69902008-03-13 12:52:44 +0900269config CPU_SUBTYPE_MXG
270 bool "Support MX-G processor"
271 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000272 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900273 help
274 Select MX-G if running on an R8A03022BG part.
275
Paul Mundtb5f42db2007-11-08 18:38:14 +0900276# SH-3 Processor Support
277
278config CPU_SUBTYPE_SH7705
279 bool "Support SH7705 processor"
280 select CPU_SH3
281
282config CPU_SUBTYPE_SH7706
283 bool "Support SH7706 processor"
284 select CPU_SH3
285 help
286 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
287
288config CPU_SUBTYPE_SH7707
289 bool "Support SH7707 processor"
290 select CPU_SH3
291 help
292 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
293
294config CPU_SUBTYPE_SH7708
295 bool "Support SH7708 processor"
296 select CPU_SH3
297 help
298 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
299 if you have a 100 Mhz SH-3 HD6417708R CPU.
300
301config CPU_SUBTYPE_SH7709
302 bool "Support SH7709 processor"
303 select CPU_SH3
304 help
305 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
306
307config CPU_SUBTYPE_SH7710
308 bool "Support SH7710 processor"
309 select CPU_SH3
310 select CPU_HAS_DSP
311 help
312 Select SH7710 if you have a SH3-DSP SH7710 CPU.
313
314config CPU_SUBTYPE_SH7712
315 bool "Support SH7712 processor"
316 select CPU_SH3
317 select CPU_HAS_DSP
318 help
319 Select SH7712 if you have a SH3-DSP SH7712 CPU.
320
321config CPU_SUBTYPE_SH7720
322 bool "Support SH7720 processor"
323 select CPU_SH3
324 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000325 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900326 help
327 Select SH7720 if you have a SH3-DSP SH7720 CPU.
328
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900329config CPU_SUBTYPE_SH7721
330 bool "Support SH7721 processor"
331 select CPU_SH3
332 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000333 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900334 help
335 Select SH7721 if you have a SH3-DSP SH7721 CPU.
336
Paul Mundtb5f42db2007-11-08 18:38:14 +0900337# SH-4 Processor Support
338
339config CPU_SUBTYPE_SH7750
340 bool "Support SH7750 processor"
341 select CPU_SH4
342 help
343 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
344
345config CPU_SUBTYPE_SH7091
346 bool "Support SH7091 processor"
347 select CPU_SH4
348 help
349 Select SH7091 if you have an SH-4 based Sega device (such as
350 the Dreamcast, Naomi, and Naomi 2).
351
352config CPU_SUBTYPE_SH7750R
353 bool "Support SH7750R processor"
354 select CPU_SH4
355
356config CPU_SUBTYPE_SH7750S
357 bool "Support SH7750S processor"
358 select CPU_SH4
359
360config CPU_SUBTYPE_SH7751
361 bool "Support SH7751 processor"
362 select CPU_SH4
363 help
364 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
365 or if you have a HD6417751R CPU.
366
367config CPU_SUBTYPE_SH7751R
368 bool "Support SH7751R processor"
369 select CPU_SH4
370
371config CPU_SUBTYPE_SH7760
372 bool "Support SH7760 processor"
373 select CPU_SH4
374
375config CPU_SUBTYPE_SH4_202
376 bool "Support SH4-202 processor"
377 select CPU_SH4
378
379# SH-4A Processor Support
380
Paul Mundt178dd0c2008-04-09 17:56:18 +0900381config CPU_SUBTYPE_SH7723
382 bool "Support SH7723 processor"
383 select CPU_SH4A
384 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900385 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900386 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900387 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900388 help
389 Select SH7723 if you have an SH-MobileR2 CPU.
390
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900391config CPU_SUBTYPE_SH7724
392 bool "Support SH7724 processor"
393 select CPU_SH4A
394 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900395 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900396 select ARCH_SPARSEMEM_ENABLE
397 select SYS_SUPPORTS_CMT
398 help
399 Select SH7724 if you have an SH-MobileR2R CPU.
400
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900401config CPU_SUBTYPE_SH7763
402 bool "Support SH7763 processor"
403 select CPU_SH4A
404 help
405 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
406
Paul Mundtb5f42db2007-11-08 18:38:14 +0900407config CPU_SUBTYPE_SH7770
408 bool "Support SH7770 processor"
409 select CPU_SH4A
410
411config CPU_SUBTYPE_SH7780
412 bool "Support SH7780 processor"
413 select CPU_SH4A
414
415config CPU_SUBTYPE_SH7785
416 bool "Support SH7785 processor"
417 select CPU_SH4A
418 select CPU_SHX2
419 select ARCH_SPARSEMEM_ENABLE
420 select SYS_SUPPORTS_NUMA
421
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900422config CPU_SUBTYPE_SH7786
423 bool "Support SH7786 processor"
424 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900425 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900426 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900427 select ARCH_SPARSEMEM_ENABLE
428 select SYS_SUPPORTS_NUMA
Paul Mundt2eb2a432009-06-19 16:00:00 +0900429 select SYS_SUPPORTS_SMP
430 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900431
Paul Mundtb5f42db2007-11-08 18:38:14 +0900432config CPU_SUBTYPE_SHX3
433 bool "Support SH-X3 processor"
434 select CPU_SH4A
435 select CPU_SHX3
436 select ARCH_SPARSEMEM_ENABLE
437 select SYS_SUPPORTS_NUMA
438 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900439 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900440
441# SH4AL-DSP Processor Support
442
443config CPU_SUBTYPE_SH7343
444 bool "Support SH7343 processor"
445 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900446 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900447 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900448
449config CPU_SUBTYPE_SH7722
450 bool "Support SH7722 processor"
451 select CPU_SH4AL_DSP
452 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900453 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900454 select ARCH_SPARSEMEM_ENABLE
455 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900456 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900457
Magnus Damm9109a302008-02-08 17:31:24 +0900458config CPU_SUBTYPE_SH7366
459 bool "Support SH7366 processor"
460 select CPU_SH4AL_DSP
461 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900462 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900463 select ARCH_SPARSEMEM_ENABLE
464 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900465 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900466
Paul Mundt3cc000b2009-04-11 08:39:27 +0900467endchoice
468
469endif
470
471if SUPERH64
472
473choice
474 prompt "Processor sub-type selection"
475
Paul Mundtea0e1a92007-11-21 15:58:01 +0900476# SH-5 Processor Support
477
478config CPU_SUBTYPE_SH5_101
479 bool "Support SH5-101 processor"
480 select CPU_SH5
481
482config CPU_SUBTYPE_SH5_103
483 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900484 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900485
Paul Mundtb5f42db2007-11-08 18:38:14 +0900486endchoice
487
Paul Mundt3cc000b2009-04-11 08:39:27 +0900488endif
489
Paul Mundtcad82442006-01-16 22:14:19 -0800490source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900491
Paul Mundt4690bdc2007-11-09 13:45:42 +0900492source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800493
Paul Mundt939a24a2008-07-29 21:41:37 +0900494source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900495
Paul Mundt32351a22007-03-12 14:38:59 +0900496menu "Timer and clock configuration"
497
Magnus Damm9570ef22009-05-01 06:51:00 +0000498config SH_TIMER_TMU
499 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000500 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000501 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000502 help
503 This enables the build of the TMU timer driver.
504
Paul Mundtf5ad8812009-01-29 18:08:58 +0900505config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000506 bool "CMT timer driver"
507 depends on SYS_SUPPORTS_CMT
508 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000509 help
510 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900511
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000512config SH_TIMER_MTU2
513 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000514 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000515 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000516 help
517 This enables build of the MTU2 timer driver.
518
Paul Mundtcad82442006-01-16 22:14:19 -0800519config SH_PCLK_FREQ
520 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900521 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900522 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900523 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900524 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900525 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900526 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900527 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
Kuninori Morimoto47785412009-05-29 07:41:26 +0000528 CPU_SUBTYPE_SH7786 || CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900529 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800530 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900531 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800532 help
533 This option is used to specify the peripheral clock frequency.
534 This is necessary for determining the reference clock value on
535 platforms lacking an RTC.
536
Paul Mundt36aa1e32009-05-22 14:00:34 +0900537config SH_CLK_CPG
538 def_bool y
539
Paul Mundt253b0882009-05-13 17:38:11 +0900540config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900541 depends on SH_CLK_CPG
Magnus Damm46e93712009-06-04 07:37:59 +0000542 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE
Paul Mundt253b0882009-05-13 17:38:11 +0900543
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900544config SH_CLK_MD
545 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900546 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900547 default 6 if CPU_SUBTYPE_SH7206
548 default 5 if CPU_SUBTYPE_SH7619
549 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900550 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900551 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900552
Paul Mundt57be2b42007-05-09 17:33:24 +0900553source "kernel/time/Kconfig"
554
Paul Mundt32351a22007-03-12 14:38:59 +0900555endmenu
556
Paul Mundtcad82442006-01-16 22:14:19 -0800557menu "CPU Frequency scaling"
558
559source "drivers/cpufreq/Kconfig"
560
561config SH_CPU_FREQ
562 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900563 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800564 select CPU_FREQ_TABLE
565 help
Paul Mundt8a655052008-12-17 15:06:54 +0900566 This adds the cpufreq driver for SuperH. Any CPU that supports
567 clock rate rounding through the clock framework can use this
568 driver. While it will make the kernel slightly larger, this is
569 harmless for CPUs that don't support rate rounding. The driver
570 will also generate a notice in the boot log before disabling
571 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800572
573 For details, take a look at <file:Documentation/cpu-freq>.
574
575 If unsure, say N.
576
577endmenu
578
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900579source "arch/sh/drivers/Kconfig"
580
Paul Mundtcad82442006-01-16 22:14:19 -0800581endmenu
582
Paul Mundtcad82442006-01-16 22:14:19 -0800583menu "Kernel features"
584
Paul Mundt91b91d02006-09-27 18:08:33 +0900585source kernel/Kconfig.hz
586
Paul Mundtcad82442006-01-16 22:14:19 -0800587config KEXEC
588 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000589 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800590 help
591 kexec is a system call that implements the ability to shutdown your
592 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400593 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800594 you can start any kernel with it, not just Linux.
595
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400596 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800597
598 It is an ongoing process to be certain the hardware in a machine
599 is properly shutdown, so do not be surprised if this code does not
600 initially work for you. It may help to enable device hotplugging
601 support. As of this writing the exact hardware interface is
602 strongly in flux, so no good recommendation can be made.
603
Paul Mundt4d5ade52007-04-27 11:25:57 +0900604config CRASH_DUMP
605 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900606 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900607 help
608 Generate crash dump after being started by kexec.
609 This should be normally only set in special crash dump kernels
610 which are loaded in the main kernel with kexec-tools into
611 a specially reserved region and then later executed after
612 a crash by kdump/kexec. The crash dump kernel must be compiled
613 to a memory address not used by the main kernel using
614 MEMORY_START.
615
616 For more details see Documentation/kdump/kdump.txt
617
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000618config KEXEC_JUMP
619 bool "kexec jump (EXPERIMENTAL)"
620 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
621 help
622 Jump between original kernel and kexeced kernel and invoke
623 code via KEXEC
624
Paul Mundtc4637d42008-07-30 15:30:52 +0900625config SECCOMP
626 bool "Enable seccomp to safely compute untrusted bytecode"
627 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900628 help
629 This kernel feature is useful for number crunching applications
630 that may need to compute untrusted bytecode during their
631 execution. By using pipes or other transports made available to
632 the process as file descriptors supporting the read/write
633 syscalls, it's possible to isolate those applications in
634 their own address space using seccomp. Once seccomp is
635 enabled via prctl, it cannot be disabled and the task is only
636 allowed to execute a few safe syscalls defined by each seccomp
637 mode.
638
639 If unsure, say N.
640
Linus Torvalds1da177e2005-04-16 15:20:36 -0700641config SMP
642 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900643 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200644 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700645 ---help---
646 This enables support for systems with more than one CPU. If you have
647 a system with only one CPU, like most personal computers, say N. If
648 you have a system with more than one CPU, say Y.
649
650 If you say N here, the kernel will run on single and multiprocessor
651 machines, but will use only one CPU of a multiprocessor machine. If
652 you say Y here, the kernel will run on many, but not all,
653 singleprocessor machines. On a singleprocessor machine, the kernel
654 will run faster if you say N here.
655
656 People using multiprocessor machines who say Y here should also say
657 Y to "Enhanced Real Time Clock Support", below.
658
Adrian Bunk03502fa2008-02-03 15:50:21 +0200659 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
660 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700661
662 If you don't know what to do here, say N.
663
664config NR_CPUS
665 int "Maximum number of CPUs (2-32)"
666 range 2 32
667 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900668 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700669 default "2"
670 help
671 This allows you to specify the maximum number of CPUs which this
672 kernel will support. The maximum supported value is 32 and the
673 minimum value which makes sense is 2.
674
675 This is purely to save memory - each supported CPU adds
676 approximately eight kilobytes to the kernel image.
677
Paul Mundt91b91d02006-09-27 18:08:33 +0900678source "kernel/Kconfig.preempt"
679
Paul Mundt83662462007-09-28 16:04:49 +0900680config GUSA
681 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900682 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900683 help
684 This enables support for gUSA (general UserSpace Atomicity).
685 This is the default implementation for both UP and non-ll/sc
686 CPUs, and is used by the libc, amongst others.
687
688 For additional information, design information can be found
689 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
690
691 This should only be disabled for special cases where alternate
692 atomicity implementations exist.
693
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900694config GUSA_RB
695 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
696 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
697 help
698 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100699 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900700 store-conditional (LLSC). On machines which do not have hardware
701 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100702 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900703
Paul Mundt54ff3282009-06-11 10:33:09 +0300704config SPARSE_IRQ
705 bool "Support sparse irq numbering"
706 depends on EXPERIMENTAL
707 help
708 This enables support for sparse irqs. This is useful in general
709 as most CPUs have a fairly sparse array of IRQ vectors, which
710 the irq_desc then maps directly on to. Systems with a high
711 number of off-chip IRQs will want to treat this as
712 experimental until they have been independently verified.
713
714 If you don't know what to do here, say N.
715
Paul Mundtcad82442006-01-16 22:14:19 -0800716endmenu
717
718menu "Boot options"
719
720config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900721 hex
722 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
723 SH_7751_SOLUTION_ENGINE
724 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900725 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800726 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700727 help
Paul Mundtcad82442006-01-16 22:14:19 -0800728 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700729
Paul Mundtcad82442006-01-16 22:14:19 -0800730config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900731 hex
732 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900733 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900734 default "0x00810000" if SH_7780_SOLUTION_ENGINE
735 default "0x009e0000" if SH_TITAN
736 default "0x01800000" if SH_SDK7780
737 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800738 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700739 help
Paul Mundtcad82442006-01-16 22:14:19 -0800740 This option allows you to set the link address offset of the zImage.
741 This can be useful if you are on a board which has a small amount of
742 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700743
Paul Mundtb412a49a2009-05-10 01:23:25 +0900744config ENTRY_OFFSET
745 hex
746 default "0x00001000" if PAGE_SIZE_4KB
747 default "0x00002000" if PAGE_SIZE_8KB
748 default "0x00004000" if PAGE_SIZE_16KB
749 default "0x00010000" if PAGE_SIZE_64KB
750 default "0x00000000"
751
Paul Mundtcad82442006-01-16 22:14:19 -0800752config UBC_WAKEUP
753 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900754 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800755 help
756 Selecting this option will wakeup the User Break Controller (UBC) on
757 startup. Although the UBC is left in an awake state when the processor
758 comes up, some boot loaders misbehave by putting the UBC to sleep in a
759 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700760
761 If unsure, say N.
762
Paul Mundtcad82442006-01-16 22:14:19 -0800763config CMDLINE_BOOL
764 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765
Paul Mundtcad82442006-01-16 22:14:19 -0800766config CMDLINE
767 string "Initial kernel command string"
768 depends on CMDLINE_BOOL
769 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700770
771endmenu
772
Paul Mundtcad82442006-01-16 22:14:19 -0800773menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700774
Paul Mundtcad82442006-01-16 22:14:19 -0800775config SUPERHYWAY
776 tristate "SuperHyway Bus support"
777 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700778
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900779config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900780 bool "Maple Bus support"
781 depends on SH_DREAMCAST
782 help
783 The Maple Bus is SEGA's serial communication bus for peripherals
784 on the Dreamcast. Without this bus support you won't be able to
785 get your Dreamcast keyboard etc to work, so most users
786 probably want to say 'Y' here, unless you are only using the
787 Dreamcast with a serial line terminal or a remote network
788 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900789
Linus Torvalds1da177e2005-04-16 15:20:36 -0700790source "arch/sh/drivers/pci/Kconfig"
791
Paul Mundte16038a2009-01-09 15:12:30 +0900792source "drivers/pci/pcie/Kconfig"
793
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794source "drivers/pci/Kconfig"
795
796source "drivers/pcmcia/Kconfig"
797
798source "drivers/pci/hotplug/Kconfig"
799
800endmenu
801
802menu "Executable file formats"
803
804source "fs/Kconfig.binfmt"
805
806endmenu
807
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900808menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900809depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100810
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900811source "kernel/power/Kconfig"
812
813source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900814
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900815endmenu
816
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700817source "net/Kconfig"
818
Linus Torvalds1da177e2005-04-16 15:20:36 -0700819source "drivers/Kconfig"
820
821source "fs/Kconfig"
822
Linus Torvalds1da177e2005-04-16 15:20:36 -0700823source "arch/sh/Kconfig.debug"
824
825source "security/Kconfig"
826
827source "crypto/Kconfig"
828
829source "lib/Kconfig"