blob: eff0f2352c93624b7b73b4422f50987ed2466760 [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
Paul Mundt9c93e592009-06-17 16:34:45 +090018 select HAVE_PERF_COUNTER
Paul Mundt6eac1af2009-05-08 19:48:47 +090019 select RTC_LIB
Paul Mundtf01789c2009-06-17 10:43:13 +090020 select GENERIC_ATOMIC64
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 help
22 The SuperH is a RISC processor targeted for use in embedded systems
23 and consumer electronics; it was also used in the Sega Dreamcast
24 gaming console. The SuperH port has a home page at
25 <http://www.linux-sh.org/>.
26
Paul Mundt39d28a22007-11-08 18:39:33 +090027config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090028 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090029 select HAVE_KPROBES
30 select HAVE_KRETPROBES
Paul Mundt694f94f2008-10-31 16:20:36 +090031 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090032 select HAVE_FTRACE_MCOUNT_RECORD
33 select HAVE_DYNAMIC_FTRACE
Paul Mundtab6e5702008-12-11 18:46:46 +090034 select HAVE_ARCH_KGDB
Paul Mundt8dafc342009-04-02 11:56:38 +090035 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090036
37config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090038 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090039
Paul Mundtf42b7e32008-07-29 20:12:51 +090040config ARCH_DEFCONFIG
41 string
42 default "arch/sh/configs/shx3_defconfig" if SUPERH32
43 default "arch/sh/configs/cayman_defconfig" if SUPERH64
44
Linus Torvalds1da177e2005-04-16 15:20:36 -070045config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090046 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070047
48config RWSEM_XCHGADD_ALGORITHM
49 bool
50
Paul Mundtfa691512007-03-08 19:41:21 +090051config GENERIC_BUG
52 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090053 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090054
Paul Mundt3767f3f2009-06-15 00:00:42 +090055config GENERIC_CSUM
56 def_bool y
57 depends on SUPERH64
58
Akinobu Mitae2268c72006-03-26 01:39:35 -080059config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090060 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080061
62config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090063 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080064
Linus Torvalds1da177e2005-04-16 15:20:36 -070065config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090066 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
Paul Mundt5093c9a2008-08-04 14:17:13 +090068config GENERIC_HARDIRQS_NO__DO_IRQ
69 def_bool y
70
Linus Torvalds1da177e2005-04-16 15:20:36 -070071config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090072 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070073
Paul Mundt2eb2a432009-06-19 16:00:00 +090074config IRQ_PER_CPU
75 def_bool y
76
Magnus Damm2967dab2008-10-08 20:41:43 +090077config GENERIC_GPIO
78 def_bool n
79
Linus Torvalds1da177e2005-04-16 15:20:36 -070080config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090081 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070082
Paul Mundtcad82442006-01-16 22:14:19 -080083config GENERIC_IOMAP
84 bool
85
Paul Mundt45882142006-10-04 13:21:45 +090086config GENERIC_TIME
john stultz75634312009-05-01 13:10:28 -070087 def_bool y
Paul Mundt45882142006-10-04 13:21:45 +090088
Paul Mundt57be2b42007-05-09 17:33:24 +090089config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +090090 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +090091
Paul Mundt8c245942008-08-06 18:37:07 +090092config GENERIC_CLOCKEVENTS_BROADCAST
93 bool
94
Paul Mundt6d134b92009-05-08 16:36:13 +090095config GENERIC_CMOS_UPDATE
96 def_bool y
97 depends on SH_SH03 || SH_DREAMCAST
98
Paul Mundtbdcab872008-08-04 14:09:15 +090099config GENERIC_LOCKBREAK
100 def_bool y
101 depends on SMP && PREEMPT
102
Paul Mundt357d5942007-06-11 15:32:07 +0900103config SYS_SUPPORTS_PM
104 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900105 depends on !SMP
106
107config ARCH_SUSPEND_POSSIBLE
108 def_bool n
109
110config ARCH_HIBERNATION_POSSIBLE
111 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900112
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900113config SYS_SUPPORTS_APM_EMULATION
114 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900115 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900116
117config SYS_SUPPORTS_SMP
118 bool
119
120config SYS_SUPPORTS_NUMA
121 bool
122
123config SYS_SUPPORTS_PCI
124 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900125
Paul Mundtf5ad8812009-01-29 18:08:58 +0900126config SYS_SUPPORTS_CMT
127 bool
128
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000129config SYS_SUPPORTS_MTU2
130 bool
131
Magnus Damm9570ef22009-05-01 06:51:00 +0000132config SYS_SUPPORTS_TMU
133 bool
134
Paul Mundtafbfb522006-12-04 18:17:28 +0900135config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900136 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900137
138config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900139 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900140
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900141config HAVE_LATENCYTOP_SUPPORT
142 def_bool y
143 depends on !SMP
144
David Howellsf0d1b0b2006-12-08 02:37:49 -0800145config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900146 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800147
148config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900149 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800150
Paul Mundte257ad02007-07-25 11:18:00 +0900151config ARCH_NO_VIRT_TO_BUS
152 def_bool y
153
Paul Mundte869a902009-04-02 13:08:31 +0900154config ARCH_HAS_DEFAULT_IDLE
155 def_bool y
156
Paul Mundt2e046b92009-06-19 14:40:51 +0900157config ARCH_HAS_CPU_IDLE_WAIT
158 def_bool y
159
Magnus Damme7cc9a72008-02-07 20:18:21 +0900160config IO_TRAPPED
161 bool
162
Linus Torvalds1da177e2005-04-16 15:20:36 -0700163source "init/Kconfig"
164
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700165source "kernel/Kconfig.freezer"
166
Linus Torvalds1da177e2005-04-16 15:20:36 -0700167menu "System type"
168
Paul Mundtb5f42db2007-11-08 18:38:14 +0900169#
170# Processor families
171#
172config CPU_SH2
173 bool
174
175config CPU_SH2A
176 bool
177 select CPU_SH2
178
179config CPU_SH3
180 bool
181 select CPU_HAS_INTEVT
182 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900183 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900184
185config CPU_SH4
186 bool
187 select CPU_HAS_INTEVT
188 select CPU_HAS_SR_RB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900189 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900190 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900191
192config CPU_SH4A
193 bool
194 select CPU_SH4
195
196config CPU_SH4AL_DSP
197 bool
198 select CPU_SH4A
199 select CPU_HAS_DSP
200
Paul Mundtea0e1a92007-11-21 15:58:01 +0900201config CPU_SH5
202 bool
203 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900204 select SYS_SUPPORTS_TMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900205
Paul Mundtb5f42db2007-11-08 18:38:14 +0900206config CPU_SHX2
207 bool
208
209config CPU_SHX3
210 bool
211
Paul Mundtdc65a972009-03-10 16:26:29 +0900212config ARCH_SHMOBILE
213 bool
Magnus Damm77594912009-03-13 15:23:04 +0000214 select ARCH_SUSPEND_POSSIBLE
Paul Mundtdc65a972009-03-10 16:26:29 +0900215
Paul Mundt3cc000b2009-04-11 08:39:27 +0900216if SUPERH32
217
Paul Mundtb5f42db2007-11-08 18:38:14 +0900218choice
219 prompt "Processor sub-type selection"
220
221#
222# Processor subtypes
223#
224
225# SH-2 Processor Support
226
227config CPU_SUBTYPE_SH7619
228 bool "Support SH7619 processor"
229 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900230 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900231
232# SH-2A Processor Support
233
Peter Griffin28259992008-11-28 22:48:20 +0900234config CPU_SUBTYPE_SH7201
235 bool "Support SH7201 processor"
236 select CPU_SH2A
237 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000238 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900239
Paul Mundt6d01f512007-11-26 18:17:21 +0900240config CPU_SUBTYPE_SH7203
241 bool "Support SH7203 processor"
242 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900243 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900244 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000245 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900246
Paul Mundtb5f42db2007-11-08 18:38:14 +0900247config CPU_SUBTYPE_SH7206
248 bool "Support SH7206 processor"
249 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900250 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000251 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900252
Paul Mundta8f67f42007-11-26 19:54:02 +0900253config CPU_SUBTYPE_SH7263
254 bool "Support SH7263 processor"
255 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900256 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900257 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000258 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900259
Paul Mundt2ad69902008-03-13 12:52:44 +0900260config CPU_SUBTYPE_MXG
261 bool "Support MX-G processor"
262 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000263 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900264 help
265 Select MX-G if running on an R8A03022BG part.
266
Paul Mundtb5f42db2007-11-08 18:38:14 +0900267# SH-3 Processor Support
268
269config CPU_SUBTYPE_SH7705
270 bool "Support SH7705 processor"
271 select CPU_SH3
272
273config CPU_SUBTYPE_SH7706
274 bool "Support SH7706 processor"
275 select CPU_SH3
276 help
277 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
278
279config CPU_SUBTYPE_SH7707
280 bool "Support SH7707 processor"
281 select CPU_SH3
282 help
283 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
284
285config CPU_SUBTYPE_SH7708
286 bool "Support SH7708 processor"
287 select CPU_SH3
288 help
289 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
290 if you have a 100 Mhz SH-3 HD6417708R CPU.
291
292config CPU_SUBTYPE_SH7709
293 bool "Support SH7709 processor"
294 select CPU_SH3
295 help
296 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
297
298config CPU_SUBTYPE_SH7710
299 bool "Support SH7710 processor"
300 select CPU_SH3
301 select CPU_HAS_DSP
302 help
303 Select SH7710 if you have a SH3-DSP SH7710 CPU.
304
305config CPU_SUBTYPE_SH7712
306 bool "Support SH7712 processor"
307 select CPU_SH3
308 select CPU_HAS_DSP
309 help
310 Select SH7712 if you have a SH3-DSP SH7712 CPU.
311
312config CPU_SUBTYPE_SH7720
313 bool "Support SH7720 processor"
314 select CPU_SH3
315 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000316 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900317 help
318 Select SH7720 if you have a SH3-DSP SH7720 CPU.
319
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900320config CPU_SUBTYPE_SH7721
321 bool "Support SH7721 processor"
322 select CPU_SH3
323 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000324 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900325 help
326 Select SH7721 if you have a SH3-DSP SH7721 CPU.
327
Paul Mundtb5f42db2007-11-08 18:38:14 +0900328# SH-4 Processor Support
329
330config CPU_SUBTYPE_SH7750
331 bool "Support SH7750 processor"
332 select CPU_SH4
333 help
334 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
335
336config CPU_SUBTYPE_SH7091
337 bool "Support SH7091 processor"
338 select CPU_SH4
339 help
340 Select SH7091 if you have an SH-4 based Sega device (such as
341 the Dreamcast, Naomi, and Naomi 2).
342
343config CPU_SUBTYPE_SH7750R
344 bool "Support SH7750R processor"
345 select CPU_SH4
346
347config CPU_SUBTYPE_SH7750S
348 bool "Support SH7750S processor"
349 select CPU_SH4
350
351config CPU_SUBTYPE_SH7751
352 bool "Support SH7751 processor"
353 select CPU_SH4
354 help
355 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
356 or if you have a HD6417751R CPU.
357
358config CPU_SUBTYPE_SH7751R
359 bool "Support SH7751R processor"
360 select CPU_SH4
361
362config CPU_SUBTYPE_SH7760
363 bool "Support SH7760 processor"
364 select CPU_SH4
365
366config CPU_SUBTYPE_SH4_202
367 bool "Support SH4-202 processor"
368 select CPU_SH4
369
370# SH-4A Processor Support
371
Paul Mundt178dd0c2008-04-09 17:56:18 +0900372config CPU_SUBTYPE_SH7723
373 bool "Support SH7723 processor"
374 select CPU_SH4A
375 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900376 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900377 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900378 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900379 help
380 Select SH7723 if you have an SH-MobileR2 CPU.
381
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900382config CPU_SUBTYPE_SH7724
383 bool "Support SH7724 processor"
384 select CPU_SH4A
385 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900386 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900387 select ARCH_SPARSEMEM_ENABLE
388 select SYS_SUPPORTS_CMT
389 help
390 Select SH7724 if you have an SH-MobileR2R CPU.
391
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900392config CPU_SUBTYPE_SH7763
393 bool "Support SH7763 processor"
394 select CPU_SH4A
395 help
396 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
397
Paul Mundtb5f42db2007-11-08 18:38:14 +0900398config CPU_SUBTYPE_SH7770
399 bool "Support SH7770 processor"
400 select CPU_SH4A
401
402config CPU_SUBTYPE_SH7780
403 bool "Support SH7780 processor"
404 select CPU_SH4A
405
406config CPU_SUBTYPE_SH7785
407 bool "Support SH7785 processor"
408 select CPU_SH4A
409 select CPU_SHX2
410 select ARCH_SPARSEMEM_ENABLE
411 select SYS_SUPPORTS_NUMA
412
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900413config CPU_SUBTYPE_SH7786
414 bool "Support SH7786 processor"
415 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900416 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900417 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900418 select ARCH_SPARSEMEM_ENABLE
419 select SYS_SUPPORTS_NUMA
Paul Mundt2eb2a432009-06-19 16:00:00 +0900420 select SYS_SUPPORTS_SMP
421 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900422
Paul Mundtb5f42db2007-11-08 18:38:14 +0900423config CPU_SUBTYPE_SHX3
424 bool "Support SH-X3 processor"
425 select CPU_SH4A
426 select CPU_SHX3
427 select ARCH_SPARSEMEM_ENABLE
428 select SYS_SUPPORTS_NUMA
429 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900430 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900431
432# SH4AL-DSP Processor Support
433
434config CPU_SUBTYPE_SH7343
435 bool "Support SH7343 processor"
436 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900437 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900438 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900439
440config CPU_SUBTYPE_SH7722
441 bool "Support SH7722 processor"
442 select CPU_SH4AL_DSP
443 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900444 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900445 select ARCH_SPARSEMEM_ENABLE
446 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900447 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900448
Magnus Damm9109a302008-02-08 17:31:24 +0900449config CPU_SUBTYPE_SH7366
450 bool "Support SH7366 processor"
451 select CPU_SH4AL_DSP
452 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900453 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900454 select ARCH_SPARSEMEM_ENABLE
455 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900456 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900457
Paul Mundt3cc000b2009-04-11 08:39:27 +0900458endchoice
459
460endif
461
462if SUPERH64
463
464choice
465 prompt "Processor sub-type selection"
466
Paul Mundtea0e1a92007-11-21 15:58:01 +0900467# SH-5 Processor Support
468
469config CPU_SUBTYPE_SH5_101
470 bool "Support SH5-101 processor"
471 select CPU_SH5
472
473config CPU_SUBTYPE_SH5_103
474 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900475 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900476
Paul Mundtb5f42db2007-11-08 18:38:14 +0900477endchoice
478
Paul Mundt3cc000b2009-04-11 08:39:27 +0900479endif
480
Paul Mundtcad82442006-01-16 22:14:19 -0800481source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900482
Paul Mundt4690bdc2007-11-09 13:45:42 +0900483source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800484
Paul Mundt939a24a2008-07-29 21:41:37 +0900485source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900486
Paul Mundt32351a22007-03-12 14:38:59 +0900487menu "Timer and clock configuration"
488
Magnus Damm9570ef22009-05-01 06:51:00 +0000489config SH_TIMER_TMU
490 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000491 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000492 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000493 help
494 This enables the build of the TMU timer driver.
495
Paul Mundtf5ad8812009-01-29 18:08:58 +0900496config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000497 bool "CMT timer driver"
498 depends on SYS_SUPPORTS_CMT
499 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000500 help
501 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900502
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000503config SH_TIMER_MTU2
504 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000505 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000506 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000507 help
508 This enables build of the MTU2 timer driver.
509
Paul Mundtcad82442006-01-16 22:14:19 -0800510config SH_PCLK_FREQ
511 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900512 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900513 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900514 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900515 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900516 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900517 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900518 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
Kuninori Morimoto47785412009-05-29 07:41:26 +0000519 CPU_SUBTYPE_SH7786 || CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900520 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800521 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900522 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800523 help
524 This option is used to specify the peripheral clock frequency.
525 This is necessary for determining the reference clock value on
526 platforms lacking an RTC.
527
Paul Mundt36aa1e32009-05-22 14:00:34 +0900528config SH_CLK_CPG
529 def_bool y
530
Paul Mundt253b0882009-05-13 17:38:11 +0900531config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900532 depends on SH_CLK_CPG
Magnus Damm46e93712009-06-04 07:37:59 +0000533 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE
Paul Mundt253b0882009-05-13 17:38:11 +0900534
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900535config SH_CLK_MD
536 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900537 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900538 default 6 if CPU_SUBTYPE_SH7206
539 default 5 if CPU_SUBTYPE_SH7619
540 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900541 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900542 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900543
Paul Mundt57be2b42007-05-09 17:33:24 +0900544source "kernel/time/Kconfig"
545
Paul Mundt32351a22007-03-12 14:38:59 +0900546endmenu
547
Paul Mundtcad82442006-01-16 22:14:19 -0800548menu "CPU Frequency scaling"
549
550source "drivers/cpufreq/Kconfig"
551
552config SH_CPU_FREQ
553 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900554 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800555 select CPU_FREQ_TABLE
556 help
Paul Mundt8a655052008-12-17 15:06:54 +0900557 This adds the cpufreq driver for SuperH. Any CPU that supports
558 clock rate rounding through the clock framework can use this
559 driver. While it will make the kernel slightly larger, this is
560 harmless for CPUs that don't support rate rounding. The driver
561 will also generate a notice in the boot log before disabling
562 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800563
564 For details, take a look at <file:Documentation/cpu-freq>.
565
566 If unsure, say N.
567
568endmenu
569
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900570source "arch/sh/drivers/Kconfig"
571
Paul Mundtcad82442006-01-16 22:14:19 -0800572endmenu
573
Paul Mundtcad82442006-01-16 22:14:19 -0800574menu "Kernel features"
575
Paul Mundt91b91d02006-09-27 18:08:33 +0900576source kernel/Kconfig.hz
577
Paul Mundtcad82442006-01-16 22:14:19 -0800578config KEXEC
579 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000580 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800581 help
582 kexec is a system call that implements the ability to shutdown your
583 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400584 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800585 you can start any kernel with it, not just Linux.
586
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400587 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800588
589 It is an ongoing process to be certain the hardware in a machine
590 is properly shutdown, so do not be surprised if this code does not
591 initially work for you. It may help to enable device hotplugging
592 support. As of this writing the exact hardware interface is
593 strongly in flux, so no good recommendation can be made.
594
Paul Mundt4d5ade52007-04-27 11:25:57 +0900595config CRASH_DUMP
596 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900597 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900598 help
599 Generate crash dump after being started by kexec.
600 This should be normally only set in special crash dump kernels
601 which are loaded in the main kernel with kexec-tools into
602 a specially reserved region and then later executed after
603 a crash by kdump/kexec. The crash dump kernel must be compiled
604 to a memory address not used by the main kernel using
605 MEMORY_START.
606
607 For more details see Documentation/kdump/kdump.txt
608
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000609config KEXEC_JUMP
610 bool "kexec jump (EXPERIMENTAL)"
611 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
612 help
613 Jump between original kernel and kexeced kernel and invoke
614 code via KEXEC
615
Paul Mundtc4637d42008-07-30 15:30:52 +0900616config SECCOMP
617 bool "Enable seccomp to safely compute untrusted bytecode"
618 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900619 help
620 This kernel feature is useful for number crunching applications
621 that may need to compute untrusted bytecode during their
622 execution. By using pipes or other transports made available to
623 the process as file descriptors supporting the read/write
624 syscalls, it's possible to isolate those applications in
625 their own address space using seccomp. Once seccomp is
626 enabled via prctl, it cannot be disabled and the task is only
627 allowed to execute a few safe syscalls defined by each seccomp
628 mode.
629
630 If unsure, say N.
631
Linus Torvalds1da177e2005-04-16 15:20:36 -0700632config SMP
633 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900634 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200635 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700636 ---help---
637 This enables support for systems with more than one CPU. If you have
638 a system with only one CPU, like most personal computers, say N. If
639 you have a system with more than one CPU, say Y.
640
641 If you say N here, the kernel will run on single and multiprocessor
642 machines, but will use only one CPU of a multiprocessor machine. If
643 you say Y here, the kernel will run on many, but not all,
644 singleprocessor machines. On a singleprocessor machine, the kernel
645 will run faster if you say N here.
646
647 People using multiprocessor machines who say Y here should also say
648 Y to "Enhanced Real Time Clock Support", below.
649
Adrian Bunk03502fa2008-02-03 15:50:21 +0200650 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
651 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700652
653 If you don't know what to do here, say N.
654
655config NR_CPUS
656 int "Maximum number of CPUs (2-32)"
657 range 2 32
658 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900659 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700660 default "2"
661 help
662 This allows you to specify the maximum number of CPUs which this
663 kernel will support. The maximum supported value is 32 and the
664 minimum value which makes sense is 2.
665
666 This is purely to save memory - each supported CPU adds
667 approximately eight kilobytes to the kernel image.
668
Paul Mundt91b91d02006-09-27 18:08:33 +0900669source "kernel/Kconfig.preempt"
670
Paul Mundt83662462007-09-28 16:04:49 +0900671config GUSA
672 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900673 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900674 help
675 This enables support for gUSA (general UserSpace Atomicity).
676 This is the default implementation for both UP and non-ll/sc
677 CPUs, and is used by the libc, amongst others.
678
679 For additional information, design information can be found
680 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
681
682 This should only be disabled for special cases where alternate
683 atomicity implementations exist.
684
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900685config GUSA_RB
686 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
687 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
688 help
689 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100690 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900691 store-conditional (LLSC). On machines which do not have hardware
692 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100693 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900694
Paul Mundt54ff3282009-06-11 10:33:09 +0300695config SPARSE_IRQ
696 bool "Support sparse irq numbering"
697 depends on EXPERIMENTAL
698 help
699 This enables support for sparse irqs. This is useful in general
700 as most CPUs have a fairly sparse array of IRQ vectors, which
701 the irq_desc then maps directly on to. Systems with a high
702 number of off-chip IRQs will want to treat this as
703 experimental until they have been independently verified.
704
705 If you don't know what to do here, say N.
706
Paul Mundtcad82442006-01-16 22:14:19 -0800707endmenu
708
709menu "Boot options"
710
711config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900712 hex
713 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
714 SH_7751_SOLUTION_ENGINE
715 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900716 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800717 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700718 help
Paul Mundtcad82442006-01-16 22:14:19 -0800719 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700720
Paul Mundtcad82442006-01-16 22:14:19 -0800721config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900722 hex
723 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900724 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900725 default "0x00810000" if SH_7780_SOLUTION_ENGINE
726 default "0x009e0000" if SH_TITAN
727 default "0x01800000" if SH_SDK7780
728 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800729 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700730 help
Paul Mundtcad82442006-01-16 22:14:19 -0800731 This option allows you to set the link address offset of the zImage.
732 This can be useful if you are on a board which has a small amount of
733 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700734
Paul Mundtb412a49a2009-05-10 01:23:25 +0900735config ENTRY_OFFSET
736 hex
737 default "0x00001000" if PAGE_SIZE_4KB
738 default "0x00002000" if PAGE_SIZE_8KB
739 default "0x00004000" if PAGE_SIZE_16KB
740 default "0x00010000" if PAGE_SIZE_64KB
741 default "0x00000000"
742
Paul Mundtcad82442006-01-16 22:14:19 -0800743config UBC_WAKEUP
744 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900745 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800746 help
747 Selecting this option will wakeup the User Break Controller (UBC) on
748 startup. Although the UBC is left in an awake state when the processor
749 comes up, some boot loaders misbehave by putting the UBC to sleep in a
750 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700751
752 If unsure, say N.
753
Paul Mundtcad82442006-01-16 22:14:19 -0800754config CMDLINE_BOOL
755 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700756
Paul Mundtcad82442006-01-16 22:14:19 -0800757config CMDLINE
758 string "Initial kernel command string"
759 depends on CMDLINE_BOOL
760 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700761
762endmenu
763
Paul Mundtcad82442006-01-16 22:14:19 -0800764menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765
Paul Mundtcad82442006-01-16 22:14:19 -0800766config SUPERHYWAY
767 tristate "SuperHyway Bus support"
768 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700769
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900770config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900771 bool "Maple Bus support"
772 depends on SH_DREAMCAST
773 help
774 The Maple Bus is SEGA's serial communication bus for peripherals
775 on the Dreamcast. Without this bus support you won't be able to
776 get your Dreamcast keyboard etc to work, so most users
777 probably want to say 'Y' here, unless you are only using the
778 Dreamcast with a serial line terminal or a remote network
779 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900780
Linus Torvalds1da177e2005-04-16 15:20:36 -0700781source "arch/sh/drivers/pci/Kconfig"
782
Paul Mundte16038a2009-01-09 15:12:30 +0900783source "drivers/pci/pcie/Kconfig"
784
Linus Torvalds1da177e2005-04-16 15:20:36 -0700785source "drivers/pci/Kconfig"
786
787source "drivers/pcmcia/Kconfig"
788
789source "drivers/pci/hotplug/Kconfig"
790
791endmenu
792
793menu "Executable file formats"
794
795source "fs/Kconfig.binfmt"
796
797endmenu
798
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900799menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900800depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100801
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900802source "kernel/power/Kconfig"
803
804source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900805
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900806endmenu
807
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700808source "net/Kconfig"
809
Linus Torvalds1da177e2005-04-16 15:20:36 -0700810source "drivers/Kconfig"
811
812source "fs/Kconfig"
813
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814source "arch/sh/Kconfig.debug"
815
816source "security/Kconfig"
817
818source "crypto/Kconfig"
819
820source "lib/Kconfig"