blob: e7b6406c96b6cd65fd89193c1724bf8266ab714d [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 Mundt6eac1af2009-05-08 19:48:47 +090018 select RTC_LIB
Linus Torvalds1da177e2005-04-16 15:20:36 -070019 help
20 The SuperH is a RISC processor targeted for use in embedded systems
21 and consumer electronics; it was also used in the Sega Dreamcast
22 gaming console. The SuperH port has a home page at
23 <http://www.linux-sh.org/>.
24
Paul Mundt39d28a22007-11-08 18:39:33 +090025config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090026 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090027 select HAVE_KPROBES
28 select HAVE_KRETPROBES
Paul Mundt694f94f2008-10-31 16:20:36 +090029 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090030 select HAVE_FTRACE_MCOUNT_RECORD
31 select HAVE_DYNAMIC_FTRACE
Paul Mundtab6e5702008-12-11 18:46:46 +090032 select HAVE_ARCH_KGDB
Paul Mundt8dafc342009-04-02 11:56:38 +090033 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090034
35config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090036 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090037
Paul Mundtf42b7e32008-07-29 20:12:51 +090038config ARCH_DEFCONFIG
39 string
40 default "arch/sh/configs/shx3_defconfig" if SUPERH32
41 default "arch/sh/configs/cayman_defconfig" if SUPERH64
42
Linus Torvalds1da177e2005-04-16 15:20:36 -070043config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090044 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070045
46config RWSEM_XCHGADD_ALGORITHM
47 bool
48
Paul Mundtfa691512007-03-08 19:41:21 +090049config GENERIC_BUG
50 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090051 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090052
Akinobu Mitae2268c72006-03-26 01:39:35 -080053config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090054 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080055
56config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090057 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080058
Linus Torvalds1da177e2005-04-16 15:20:36 -070059config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090060 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
Paul Mundt5093c9a2008-08-04 14:17:13 +090062config GENERIC_HARDIRQS_NO__DO_IRQ
63 def_bool y
64
Linus Torvalds1da177e2005-04-16 15:20:36 -070065config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090066 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
Magnus Damm2967dab2008-10-08 20:41:43 +090068config GENERIC_GPIO
69 def_bool n
70
Linus Torvalds1da177e2005-04-16 15:20:36 -070071config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090072 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070073
Paul Mundtcad82442006-01-16 22:14:19 -080074config GENERIC_IOMAP
75 bool
76
Paul Mundt45882142006-10-04 13:21:45 +090077config GENERIC_TIME
john stultz75634312009-05-01 13:10:28 -070078 def_bool y
Paul Mundt45882142006-10-04 13:21:45 +090079
Paul Mundt57be2b42007-05-09 17:33:24 +090080config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +090081 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +090082
Paul Mundt8c245942008-08-06 18:37:07 +090083config GENERIC_CLOCKEVENTS_BROADCAST
84 bool
85
Paul Mundt6d134b92009-05-08 16:36:13 +090086config GENERIC_CMOS_UPDATE
87 def_bool y
88 depends on SH_SH03 || SH_DREAMCAST
89
Paul Mundtbdcab872008-08-04 14:09:15 +090090config GENERIC_LOCKBREAK
91 def_bool y
92 depends on SMP && PREEMPT
93
Paul Mundt357d5942007-06-11 15:32:07 +090094config SYS_SUPPORTS_PM
95 bool
Magnus Dammaf998a92008-12-04 22:45:12 +090096 depends on !SMP
97
98config ARCH_SUSPEND_POSSIBLE
99 def_bool n
100
101config ARCH_HIBERNATION_POSSIBLE
102 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900103
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900104config SYS_SUPPORTS_APM_EMULATION
105 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900106 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900107
108config SYS_SUPPORTS_SMP
109 bool
110
111config SYS_SUPPORTS_NUMA
112 bool
113
114config SYS_SUPPORTS_PCI
115 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900116
Paul Mundtf5ad8812009-01-29 18:08:58 +0900117config SYS_SUPPORTS_CMT
118 bool
119
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000120config SYS_SUPPORTS_MTU2
121 bool
122
Magnus Damm9570ef22009-05-01 06:51:00 +0000123config SYS_SUPPORTS_TMU
124 bool
125
Paul Mundtafbfb522006-12-04 18:17:28 +0900126config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900127 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900128
129config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900130 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900131
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900132config HAVE_LATENCYTOP_SUPPORT
133 def_bool y
134 depends on !SMP
135
David Howellsf0d1b0b2006-12-08 02:37:49 -0800136config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900137 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800138
139config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900140 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800141
Paul Mundte257ad02007-07-25 11:18:00 +0900142config ARCH_NO_VIRT_TO_BUS
143 def_bool y
144
Paul Mundte869a902009-04-02 13:08:31 +0900145config ARCH_HAS_DEFAULT_IDLE
146 def_bool y
147
Magnus Damme7cc9a72008-02-07 20:18:21 +0900148config IO_TRAPPED
149 bool
150
Linus Torvalds1da177e2005-04-16 15:20:36 -0700151source "init/Kconfig"
152
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700153source "kernel/Kconfig.freezer"
154
Linus Torvalds1da177e2005-04-16 15:20:36 -0700155menu "System type"
156
Paul Mundtb5f42db2007-11-08 18:38:14 +0900157#
158# Processor families
159#
160config CPU_SH2
161 bool
162
163config CPU_SH2A
164 bool
165 select CPU_SH2
166
167config CPU_SH3
168 bool
169 select CPU_HAS_INTEVT
170 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900171 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900172
173config CPU_SH4
174 bool
175 select CPU_HAS_INTEVT
176 select CPU_HAS_SR_RB
177 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
178 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900179 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900180
181config CPU_SH4A
182 bool
183 select CPU_SH4
184
185config CPU_SH4AL_DSP
186 bool
187 select CPU_SH4A
188 select CPU_HAS_DSP
189
Paul Mundtea0e1a92007-11-21 15:58:01 +0900190config CPU_SH5
191 bool
192 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900193 select SYS_SUPPORTS_TMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900194
Paul Mundtb5f42db2007-11-08 18:38:14 +0900195config CPU_SHX2
196 bool
197
198config CPU_SHX3
199 bool
200
Paul Mundtdc65a972009-03-10 16:26:29 +0900201config ARCH_SHMOBILE
202 bool
Magnus Damm77594912009-03-13 15:23:04 +0000203 select ARCH_SUSPEND_POSSIBLE
Paul Mundtdc65a972009-03-10 16:26:29 +0900204
Paul Mundt3cc000b2009-04-11 08:39:27 +0900205if SUPERH32
206
Paul Mundtb5f42db2007-11-08 18:38:14 +0900207choice
208 prompt "Processor sub-type selection"
209
210#
211# Processor subtypes
212#
213
214# SH-2 Processor Support
215
216config CPU_SUBTYPE_SH7619
217 bool "Support SH7619 processor"
218 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900219 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900220
221# SH-2A Processor Support
222
Peter Griffin28259992008-11-28 22:48:20 +0900223config CPU_SUBTYPE_SH7201
224 bool "Support SH7201 processor"
225 select CPU_SH2A
226 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000227 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900228
Paul Mundt6d01f512007-11-26 18:17:21 +0900229config CPU_SUBTYPE_SH7203
230 bool "Support SH7203 processor"
231 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900232 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900233 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000234 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900235
Paul Mundtb5f42db2007-11-08 18:38:14 +0900236config CPU_SUBTYPE_SH7206
237 bool "Support SH7206 processor"
238 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900239 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000240 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900241
Paul Mundta8f67f42007-11-26 19:54:02 +0900242config CPU_SUBTYPE_SH7263
243 bool "Support SH7263 processor"
244 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900245 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900246 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000247 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900248
Paul Mundt2ad69902008-03-13 12:52:44 +0900249config CPU_SUBTYPE_MXG
250 bool "Support MX-G processor"
251 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000252 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900253 help
254 Select MX-G if running on an R8A03022BG part.
255
Paul Mundtb5f42db2007-11-08 18:38:14 +0900256# SH-3 Processor Support
257
258config CPU_SUBTYPE_SH7705
259 bool "Support SH7705 processor"
260 select CPU_SH3
261
262config CPU_SUBTYPE_SH7706
263 bool "Support SH7706 processor"
264 select CPU_SH3
265 help
266 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
267
268config CPU_SUBTYPE_SH7707
269 bool "Support SH7707 processor"
270 select CPU_SH3
271 help
272 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
273
274config CPU_SUBTYPE_SH7708
275 bool "Support SH7708 processor"
276 select CPU_SH3
277 help
278 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
279 if you have a 100 Mhz SH-3 HD6417708R CPU.
280
281config CPU_SUBTYPE_SH7709
282 bool "Support SH7709 processor"
283 select CPU_SH3
284 help
285 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
286
287config CPU_SUBTYPE_SH7710
288 bool "Support SH7710 processor"
289 select CPU_SH3
290 select CPU_HAS_DSP
291 help
292 Select SH7710 if you have a SH3-DSP SH7710 CPU.
293
294config CPU_SUBTYPE_SH7712
295 bool "Support SH7712 processor"
296 select CPU_SH3
297 select CPU_HAS_DSP
298 help
299 Select SH7712 if you have a SH3-DSP SH7712 CPU.
300
301config CPU_SUBTYPE_SH7720
302 bool "Support SH7720 processor"
303 select CPU_SH3
304 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000305 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900306 help
307 Select SH7720 if you have a SH3-DSP SH7720 CPU.
308
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900309config CPU_SUBTYPE_SH7721
310 bool "Support SH7721 processor"
311 select CPU_SH3
312 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000313 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900314 help
315 Select SH7721 if you have a SH3-DSP SH7721 CPU.
316
Paul Mundtb5f42db2007-11-08 18:38:14 +0900317# SH-4 Processor Support
318
319config CPU_SUBTYPE_SH7750
320 bool "Support SH7750 processor"
321 select CPU_SH4
322 help
323 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
324
325config CPU_SUBTYPE_SH7091
326 bool "Support SH7091 processor"
327 select CPU_SH4
328 help
329 Select SH7091 if you have an SH-4 based Sega device (such as
330 the Dreamcast, Naomi, and Naomi 2).
331
332config CPU_SUBTYPE_SH7750R
333 bool "Support SH7750R processor"
334 select CPU_SH4
335
336config CPU_SUBTYPE_SH7750S
337 bool "Support SH7750S processor"
338 select CPU_SH4
339
340config CPU_SUBTYPE_SH7751
341 bool "Support SH7751 processor"
342 select CPU_SH4
343 help
344 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
345 or if you have a HD6417751R CPU.
346
347config CPU_SUBTYPE_SH7751R
348 bool "Support SH7751R processor"
349 select CPU_SH4
350
351config CPU_SUBTYPE_SH7760
352 bool "Support SH7760 processor"
353 select CPU_SH4
354
355config CPU_SUBTYPE_SH4_202
356 bool "Support SH4-202 processor"
357 select CPU_SH4
358
359# SH-4A Processor Support
360
Paul Mundt178dd0c2008-04-09 17:56:18 +0900361config CPU_SUBTYPE_SH7723
362 bool "Support SH7723 processor"
363 select CPU_SH4A
364 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900365 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900366 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900367 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900368 help
369 Select SH7723 if you have an SH-MobileR2 CPU.
370
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900371config CPU_SUBTYPE_SH7724
372 bool "Support SH7724 processor"
373 select CPU_SH4A
374 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900375 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900376 select ARCH_SPARSEMEM_ENABLE
377 select SYS_SUPPORTS_CMT
378 help
379 Select SH7724 if you have an SH-MobileR2R CPU.
380
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900381config CPU_SUBTYPE_SH7763
382 bool "Support SH7763 processor"
383 select CPU_SH4A
384 help
385 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
386
Paul Mundtb5f42db2007-11-08 18:38:14 +0900387config CPU_SUBTYPE_SH7770
388 bool "Support SH7770 processor"
389 select CPU_SH4A
390
391config CPU_SUBTYPE_SH7780
392 bool "Support SH7780 processor"
393 select CPU_SH4A
394
395config CPU_SUBTYPE_SH7785
396 bool "Support SH7785 processor"
397 select CPU_SH4A
398 select CPU_SHX2
399 select ARCH_SPARSEMEM_ENABLE
400 select SYS_SUPPORTS_NUMA
401
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900402config CPU_SUBTYPE_SH7786
403 bool "Support SH7786 processor"
404 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900405 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900406 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900407 select ARCH_SPARSEMEM_ENABLE
408 select SYS_SUPPORTS_NUMA
409
Paul Mundtb5f42db2007-11-08 18:38:14 +0900410config CPU_SUBTYPE_SHX3
411 bool "Support SH-X3 processor"
412 select CPU_SH4A
413 select CPU_SHX3
414 select ARCH_SPARSEMEM_ENABLE
415 select SYS_SUPPORTS_NUMA
416 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900417 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900418
419# SH4AL-DSP Processor Support
420
421config CPU_SUBTYPE_SH7343
422 bool "Support SH7343 processor"
423 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900424 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900425 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900426
427config CPU_SUBTYPE_SH7722
428 bool "Support SH7722 processor"
429 select CPU_SH4AL_DSP
430 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900431 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900432 select ARCH_SPARSEMEM_ENABLE
433 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900434 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900435
Magnus Damm9109a302008-02-08 17:31:24 +0900436config CPU_SUBTYPE_SH7366
437 bool "Support SH7366 processor"
438 select CPU_SH4AL_DSP
439 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900440 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900441 select ARCH_SPARSEMEM_ENABLE
442 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900443 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900444
Paul Mundt3cc000b2009-04-11 08:39:27 +0900445endchoice
446
447endif
448
449if SUPERH64
450
451choice
452 prompt "Processor sub-type selection"
453
Paul Mundtea0e1a92007-11-21 15:58:01 +0900454# SH-5 Processor Support
455
456config CPU_SUBTYPE_SH5_101
457 bool "Support SH5-101 processor"
458 select CPU_SH5
459
460config CPU_SUBTYPE_SH5_103
461 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900462 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900463
Paul Mundtb5f42db2007-11-08 18:38:14 +0900464endchoice
465
Paul Mundt3cc000b2009-04-11 08:39:27 +0900466endif
467
Paul Mundtcad82442006-01-16 22:14:19 -0800468source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900469
Paul Mundt4690bdc2007-11-09 13:45:42 +0900470source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800471
Paul Mundt939a24a2008-07-29 21:41:37 +0900472source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900473
Paul Mundt32351a22007-03-12 14:38:59 +0900474menu "Timer and clock configuration"
475
Magnus Damm9570ef22009-05-01 06:51:00 +0000476config SH_TIMER_TMU
477 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000478 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000479 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000480 help
481 This enables the build of the TMU timer driver.
482
Paul Mundtf5ad8812009-01-29 18:08:58 +0900483config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000484 bool "CMT timer driver"
485 depends on SYS_SUPPORTS_CMT
486 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000487 help
488 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900489
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000490config SH_TIMER_MTU2
491 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000492 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000493 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000494 help
495 This enables build of the MTU2 timer driver.
496
Paul Mundt417528a2006-11-20 11:18:30 +0900497config SH_TIMER_IRQ
498 int
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900499 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
500 CPU_SUBTYPE_SH7763
Paul Mundt417528a2006-11-20 11:18:30 +0900501 default "86" if CPU_SUBTYPE_SH7619
502 default "140" if CPU_SUBTYPE_SH7206
Paul Mundtd63f3a52009-01-29 18:10:13 +0900503 default "142" if CPU_SUBTYPE_SH7203 && SH_CMT
504 default "153" if CPU_SUBTYPE_SH7203 && SH_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900505 default "238" if CPU_SUBTYPE_MXG
Paul Mundt417528a2006-11-20 11:18:30 +0900506 default "16"
507
Paul Mundtcad82442006-01-16 22:14:19 -0800508config SH_PCLK_FREQ
509 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900510 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900511 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900512 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900513 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900514 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900515 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900516 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
517 CPU_SUBTYPE_SH7786
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900518 default "41666666" if CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900519 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800520 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900521 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800522 help
523 This option is used to specify the peripheral clock frequency.
524 This is necessary for determining the reference clock value on
525 platforms lacking an RTC.
526
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900527config SH_CLK_MD
528 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900529 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900530 default 6 if CPU_SUBTYPE_SH7206
531 default 5 if CPU_SUBTYPE_SH7619
532 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900533 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900534 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900535
Paul Mundt57be2b42007-05-09 17:33:24 +0900536source "kernel/time/Kconfig"
537
Paul Mundt32351a22007-03-12 14:38:59 +0900538endmenu
539
Paul Mundtcad82442006-01-16 22:14:19 -0800540menu "CPU Frequency scaling"
541
542source "drivers/cpufreq/Kconfig"
543
544config SH_CPU_FREQ
545 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900546 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800547 select CPU_FREQ_TABLE
548 help
Paul Mundt8a655052008-12-17 15:06:54 +0900549 This adds the cpufreq driver for SuperH. Any CPU that supports
550 clock rate rounding through the clock framework can use this
551 driver. While it will make the kernel slightly larger, this is
552 harmless for CPUs that don't support rate rounding. The driver
553 will also generate a notice in the boot log before disabling
554 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800555
556 For details, take a look at <file:Documentation/cpu-freq>.
557
558 If unsure, say N.
559
560endmenu
561
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900562source "arch/sh/drivers/Kconfig"
563
Paul Mundtcad82442006-01-16 22:14:19 -0800564endmenu
565
Paul Mundtcad82442006-01-16 22:14:19 -0800566menu "Kernel features"
567
Paul Mundt91b91d02006-09-27 18:08:33 +0900568source kernel/Kconfig.hz
569
Paul Mundtcad82442006-01-16 22:14:19 -0800570config KEXEC
571 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000572 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800573 help
574 kexec is a system call that implements the ability to shutdown your
575 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400576 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800577 you can start any kernel with it, not just Linux.
578
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400579 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800580
581 It is an ongoing process to be certain the hardware in a machine
582 is properly shutdown, so do not be surprised if this code does not
583 initially work for you. It may help to enable device hotplugging
584 support. As of this writing the exact hardware interface is
585 strongly in flux, so no good recommendation can be made.
586
Paul Mundt4d5ade52007-04-27 11:25:57 +0900587config CRASH_DUMP
588 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900589 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900590 help
591 Generate crash dump after being started by kexec.
592 This should be normally only set in special crash dump kernels
593 which are loaded in the main kernel with kexec-tools into
594 a specially reserved region and then later executed after
595 a crash by kdump/kexec. The crash dump kernel must be compiled
596 to a memory address not used by the main kernel using
597 MEMORY_START.
598
599 For more details see Documentation/kdump/kdump.txt
600
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000601config KEXEC_JUMP
602 bool "kexec jump (EXPERIMENTAL)"
603 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
604 help
605 Jump between original kernel and kexeced kernel and invoke
606 code via KEXEC
607
Paul Mundtc4637d42008-07-30 15:30:52 +0900608config SECCOMP
609 bool "Enable seccomp to safely compute untrusted bytecode"
610 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900611 help
612 This kernel feature is useful for number crunching applications
613 that may need to compute untrusted bytecode during their
614 execution. By using pipes or other transports made available to
615 the process as file descriptors supporting the read/write
616 syscalls, it's possible to isolate those applications in
617 their own address space using seccomp. Once seccomp is
618 enabled via prctl, it cannot be disabled and the task is only
619 allowed to execute a few safe syscalls defined by each seccomp
620 mode.
621
622 If unsure, say N.
623
Linus Torvalds1da177e2005-04-16 15:20:36 -0700624config SMP
625 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900626 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200627 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700628 ---help---
629 This enables support for systems with more than one CPU. If you have
630 a system with only one CPU, like most personal computers, say N. If
631 you have a system with more than one CPU, say Y.
632
633 If you say N here, the kernel will run on single and multiprocessor
634 machines, but will use only one CPU of a multiprocessor machine. If
635 you say Y here, the kernel will run on many, but not all,
636 singleprocessor machines. On a singleprocessor machine, the kernel
637 will run faster if you say N here.
638
639 People using multiprocessor machines who say Y here should also say
640 Y to "Enhanced Real Time Clock Support", below.
641
Adrian Bunk03502fa2008-02-03 15:50:21 +0200642 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
643 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700644
645 If you don't know what to do here, say N.
646
647config NR_CPUS
648 int "Maximum number of CPUs (2-32)"
649 range 2 32
650 depends on SMP
Paul Mundt2b1bd1a2007-06-20 18:27:10 +0900651 default "4" if CPU_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700652 default "2"
653 help
654 This allows you to specify the maximum number of CPUs which this
655 kernel will support. The maximum supported value is 32 and the
656 minimum value which makes sense is 2.
657
658 This is purely to save memory - each supported CPU adds
659 approximately eight kilobytes to the kernel image.
660
Paul Mundt91b91d02006-09-27 18:08:33 +0900661source "kernel/Kconfig.preempt"
662
Paul Mundt83662462007-09-28 16:04:49 +0900663config GUSA
664 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900665 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900666 help
667 This enables support for gUSA (general UserSpace Atomicity).
668 This is the default implementation for both UP and non-ll/sc
669 CPUs, and is used by the libc, amongst others.
670
671 For additional information, design information can be found
672 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
673
674 This should only be disabled for special cases where alternate
675 atomicity implementations exist.
676
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900677config GUSA_RB
678 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
679 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
680 help
681 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100682 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900683 store-conditional (LLSC). On machines which do not have hardware
684 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100685 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900686
Paul Mundtcad82442006-01-16 22:14:19 -0800687endmenu
688
689menu "Boot options"
690
691config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900692 hex
693 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
694 SH_7751_SOLUTION_ENGINE
695 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900696 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800697 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700698 help
Paul Mundtcad82442006-01-16 22:14:19 -0800699 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700700
Paul Mundtcad82442006-01-16 22:14:19 -0800701config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900702 hex
703 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900704 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900705 default "0x00810000" if SH_7780_SOLUTION_ENGINE
706 default "0x009e0000" if SH_TITAN
707 default "0x01800000" if SH_SDK7780
708 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800709 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700710 help
Paul Mundtcad82442006-01-16 22:14:19 -0800711 This option allows you to set the link address offset of the zImage.
712 This can be useful if you are on a board which has a small amount of
713 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700714
Paul Mundtb412a49a2009-05-10 01:23:25 +0900715config ENTRY_OFFSET
716 hex
717 default "0x00001000" if PAGE_SIZE_4KB
718 default "0x00002000" if PAGE_SIZE_8KB
719 default "0x00004000" if PAGE_SIZE_16KB
720 default "0x00010000" if PAGE_SIZE_64KB
721 default "0x00000000"
722
Paul Mundtcad82442006-01-16 22:14:19 -0800723config UBC_WAKEUP
724 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900725 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800726 help
727 Selecting this option will wakeup the User Break Controller (UBC) on
728 startup. Although the UBC is left in an awake state when the processor
729 comes up, some boot loaders misbehave by putting the UBC to sleep in a
730 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700731
732 If unsure, say N.
733
Paul Mundtcad82442006-01-16 22:14:19 -0800734config CMDLINE_BOOL
735 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700736
Paul Mundtcad82442006-01-16 22:14:19 -0800737config CMDLINE
738 string "Initial kernel command string"
739 depends on CMDLINE_BOOL
740 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700741
742endmenu
743
Paul Mundtcad82442006-01-16 22:14:19 -0800744menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700745
Paul Mundtcad82442006-01-16 22:14:19 -0800746config SUPERHYWAY
747 tristate "SuperHyway Bus support"
748 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700749
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900750config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900751 bool "Maple Bus support"
752 depends on SH_DREAMCAST
753 help
754 The Maple Bus is SEGA's serial communication bus for peripherals
755 on the Dreamcast. Without this bus support you won't be able to
756 get your Dreamcast keyboard etc to work, so most users
757 probably want to say 'Y' here, unless you are only using the
758 Dreamcast with a serial line terminal or a remote network
759 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900760
Linus Torvalds1da177e2005-04-16 15:20:36 -0700761source "arch/sh/drivers/pci/Kconfig"
762
Paul Mundte16038a2009-01-09 15:12:30 +0900763source "drivers/pci/pcie/Kconfig"
764
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765source "drivers/pci/Kconfig"
766
767source "drivers/pcmcia/Kconfig"
768
769source "drivers/pci/hotplug/Kconfig"
770
771endmenu
772
773menu "Executable file formats"
774
775source "fs/Kconfig.binfmt"
776
777endmenu
778
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900779menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900780depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100781
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900782source "kernel/power/Kconfig"
783
784source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900785
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900786endmenu
787
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700788source "net/Kconfig"
789
Linus Torvalds1da177e2005-04-16 15:20:36 -0700790source "drivers/Kconfig"
791
792source "fs/Kconfig"
793
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794source "arch/sh/Kconfig.debug"
795
796source "security/Kconfig"
797
798source "crypto/Kconfig"
799
800source "lib/Kconfig"