blob: d17570c61dfded61c509bb03dd6491ac9e01d09e [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
Paul Mundtdc65a972009-03-10 16:26:29 +0900222
Paul Mundt3cc000b2009-04-11 08:39:27 +0900223if SUPERH32
224
Paul Mundtb5f42db2007-11-08 18:38:14 +0900225choice
226 prompt "Processor sub-type selection"
227
228#
229# Processor subtypes
230#
231
232# SH-2 Processor Support
233
234config CPU_SUBTYPE_SH7619
235 bool "Support SH7619 processor"
236 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900237 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900238
239# SH-2A Processor Support
240
Peter Griffin28259992008-11-28 22:48:20 +0900241config CPU_SUBTYPE_SH7201
242 bool "Support SH7201 processor"
243 select CPU_SH2A
244 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000245 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900246
Paul Mundt6d01f512007-11-26 18:17:21 +0900247config CPU_SUBTYPE_SH7203
248 bool "Support SH7203 processor"
249 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900250 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900251 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000252 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900253
Paul Mundtb5f42db2007-11-08 18:38:14 +0900254config CPU_SUBTYPE_SH7206
255 bool "Support SH7206 processor"
256 select CPU_SH2A
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 Mundtb5f42db2007-11-08 18:38:14 +0900259
Paul Mundta8f67f42007-11-26 19:54:02 +0900260config CPU_SUBTYPE_SH7263
261 bool "Support SH7263 processor"
262 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900263 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900264 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000265 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900266
Paul Mundt2ad69902008-03-13 12:52:44 +0900267config CPU_SUBTYPE_MXG
268 bool "Support MX-G processor"
269 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000270 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900271 help
272 Select MX-G if running on an R8A03022BG part.
273
Paul Mundtb5f42db2007-11-08 18:38:14 +0900274# SH-3 Processor Support
275
276config CPU_SUBTYPE_SH7705
277 bool "Support SH7705 processor"
278 select CPU_SH3
279
280config CPU_SUBTYPE_SH7706
281 bool "Support SH7706 processor"
282 select CPU_SH3
283 help
284 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
285
286config CPU_SUBTYPE_SH7707
287 bool "Support SH7707 processor"
288 select CPU_SH3
289 help
290 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
291
292config CPU_SUBTYPE_SH7708
293 bool "Support SH7708 processor"
294 select CPU_SH3
295 help
296 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
297 if you have a 100 Mhz SH-3 HD6417708R CPU.
298
299config CPU_SUBTYPE_SH7709
300 bool "Support SH7709 processor"
301 select CPU_SH3
302 help
303 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
304
305config CPU_SUBTYPE_SH7710
306 bool "Support SH7710 processor"
307 select CPU_SH3
308 select CPU_HAS_DSP
309 help
310 Select SH7710 if you have a SH3-DSP SH7710 CPU.
311
312config CPU_SUBTYPE_SH7712
313 bool "Support SH7712 processor"
314 select CPU_SH3
315 select CPU_HAS_DSP
316 help
317 Select SH7712 if you have a SH3-DSP SH7712 CPU.
318
319config CPU_SUBTYPE_SH7720
320 bool "Support SH7720 processor"
321 select CPU_SH3
322 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000323 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900324 help
325 Select SH7720 if you have a SH3-DSP SH7720 CPU.
326
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900327config CPU_SUBTYPE_SH7721
328 bool "Support SH7721 processor"
329 select CPU_SH3
330 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000331 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900332 help
333 Select SH7721 if you have a SH3-DSP SH7721 CPU.
334
Paul Mundtb5f42db2007-11-08 18:38:14 +0900335# SH-4 Processor Support
336
337config CPU_SUBTYPE_SH7750
338 bool "Support SH7750 processor"
339 select CPU_SH4
340 help
341 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
342
343config CPU_SUBTYPE_SH7091
344 bool "Support SH7091 processor"
345 select CPU_SH4
346 help
347 Select SH7091 if you have an SH-4 based Sega device (such as
348 the Dreamcast, Naomi, and Naomi 2).
349
350config CPU_SUBTYPE_SH7750R
351 bool "Support SH7750R processor"
352 select CPU_SH4
353
354config CPU_SUBTYPE_SH7750S
355 bool "Support SH7750S processor"
356 select CPU_SH4
357
358config CPU_SUBTYPE_SH7751
359 bool "Support SH7751 processor"
360 select CPU_SH4
361 help
362 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
363 or if you have a HD6417751R CPU.
364
365config CPU_SUBTYPE_SH7751R
366 bool "Support SH7751R processor"
367 select CPU_SH4
368
369config CPU_SUBTYPE_SH7760
370 bool "Support SH7760 processor"
371 select CPU_SH4
372
373config CPU_SUBTYPE_SH4_202
374 bool "Support SH4-202 processor"
375 select CPU_SH4
376
377# SH-4A Processor Support
378
Paul Mundt178dd0c2008-04-09 17:56:18 +0900379config CPU_SUBTYPE_SH7723
380 bool "Support SH7723 processor"
381 select CPU_SH4A
382 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900383 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900384 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900385 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900386 help
387 Select SH7723 if you have an SH-MobileR2 CPU.
388
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900389config CPU_SUBTYPE_SH7724
390 bool "Support SH7724 processor"
391 select CPU_SH4A
392 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900393 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900394 select ARCH_SPARSEMEM_ENABLE
395 select SYS_SUPPORTS_CMT
396 help
397 Select SH7724 if you have an SH-MobileR2R CPU.
398
Yoshihiro Shimodac01f0f12009-08-21 16:30:28 +0900399config CPU_SUBTYPE_SH7757
400 bool "Support SH7757 processor"
401 select CPU_SH4A
402 select CPU_SHX2
403 help
404 Select SH7757 if you have a SH4A SH7757 CPU.
405
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900406config CPU_SUBTYPE_SH7763
407 bool "Support SH7763 processor"
408 select CPU_SH4A
409 help
410 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
411
Paul Mundtb5f42db2007-11-08 18:38:14 +0900412config CPU_SUBTYPE_SH7770
413 bool "Support SH7770 processor"
414 select CPU_SH4A
415
416config CPU_SUBTYPE_SH7780
417 bool "Support SH7780 processor"
418 select CPU_SH4A
419
420config CPU_SUBTYPE_SH7785
421 bool "Support SH7785 processor"
422 select CPU_SH4A
423 select CPU_SHX2
424 select ARCH_SPARSEMEM_ENABLE
425 select SYS_SUPPORTS_NUMA
426
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900427config CPU_SUBTYPE_SH7786
428 bool "Support SH7786 processor"
429 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900430 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900431 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900432 select ARCH_SPARSEMEM_ENABLE
433 select SYS_SUPPORTS_NUMA
Paul Mundt2eb2a432009-06-19 16:00:00 +0900434 select SYS_SUPPORTS_SMP
435 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900436
Paul Mundtb5f42db2007-11-08 18:38:14 +0900437config CPU_SUBTYPE_SHX3
438 bool "Support SH-X3 processor"
439 select CPU_SH4A
440 select CPU_SHX3
441 select ARCH_SPARSEMEM_ENABLE
442 select SYS_SUPPORTS_NUMA
443 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900444 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900445
446# SH4AL-DSP Processor Support
447
448config CPU_SUBTYPE_SH7343
449 bool "Support SH7343 processor"
450 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900451 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900452 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900453
454config CPU_SUBTYPE_SH7722
455 bool "Support SH7722 processor"
456 select CPU_SH4AL_DSP
457 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900458 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900459 select ARCH_SPARSEMEM_ENABLE
460 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900461 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900462
Magnus Damm9109a302008-02-08 17:31:24 +0900463config CPU_SUBTYPE_SH7366
464 bool "Support SH7366 processor"
465 select CPU_SH4AL_DSP
466 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900467 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900468 select ARCH_SPARSEMEM_ENABLE
469 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900470 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900471
Paul Mundt3cc000b2009-04-11 08:39:27 +0900472endchoice
473
474endif
475
476if SUPERH64
477
478choice
479 prompt "Processor sub-type selection"
480
Paul Mundtea0e1a92007-11-21 15:58:01 +0900481# SH-5 Processor Support
482
483config CPU_SUBTYPE_SH5_101
484 bool "Support SH5-101 processor"
485 select CPU_SH5
486
487config CPU_SUBTYPE_SH5_103
488 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900489 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900490
Paul Mundtb5f42db2007-11-08 18:38:14 +0900491endchoice
492
Paul Mundt3cc000b2009-04-11 08:39:27 +0900493endif
494
Paul Mundtcad82442006-01-16 22:14:19 -0800495source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900496
Paul Mundt4690bdc2007-11-09 13:45:42 +0900497source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800498
Paul Mundt939a24a2008-07-29 21:41:37 +0900499source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900500
Paul Mundt32351a22007-03-12 14:38:59 +0900501menu "Timer and clock configuration"
502
Magnus Damm9570ef22009-05-01 06:51:00 +0000503config SH_TIMER_TMU
504 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000505 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000506 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000507 help
508 This enables the build of the TMU timer driver.
509
Paul Mundtf5ad8812009-01-29 18:08:58 +0900510config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000511 bool "CMT timer driver"
512 depends on SYS_SUPPORTS_CMT
513 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000514 help
515 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900516
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000517config SH_TIMER_MTU2
518 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000519 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000520 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000521 help
522 This enables build of the MTU2 timer driver.
523
Paul Mundtcad82442006-01-16 22:14:19 -0800524config SH_PCLK_FREQ
525 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900526 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900527 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900528 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900529 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900530 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900531 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900532 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
Kuninori Morimoto47785412009-05-29 07:41:26 +0000533 CPU_SUBTYPE_SH7786 || CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900534 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800535 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900536 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800537 help
538 This option is used to specify the peripheral clock frequency.
539 This is necessary for determining the reference clock value on
540 platforms lacking an RTC.
541
Paul Mundt36aa1e32009-05-22 14:00:34 +0900542config SH_CLK_CPG
543 def_bool y
544
Paul Mundt253b0882009-05-13 17:38:11 +0900545config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900546 depends on SH_CLK_CPG
Magnus Damm46e93712009-06-04 07:37:59 +0000547 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE
Paul Mundt253b0882009-05-13 17:38:11 +0900548
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900549config SH_CLK_MD
550 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900551 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900552 default 6 if CPU_SUBTYPE_SH7206
553 default 5 if CPU_SUBTYPE_SH7619
554 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900555 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900556 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900557
Paul Mundt57be2b42007-05-09 17:33:24 +0900558source "kernel/time/Kconfig"
559
Paul Mundt32351a22007-03-12 14:38:59 +0900560endmenu
561
Paul Mundtcad82442006-01-16 22:14:19 -0800562menu "CPU Frequency scaling"
563
564source "drivers/cpufreq/Kconfig"
565
566config SH_CPU_FREQ
567 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900568 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800569 select CPU_FREQ_TABLE
570 help
Paul Mundt8a655052008-12-17 15:06:54 +0900571 This adds the cpufreq driver for SuperH. Any CPU that supports
572 clock rate rounding through the clock framework can use this
573 driver. While it will make the kernel slightly larger, this is
574 harmless for CPUs that don't support rate rounding. The driver
575 will also generate a notice in the boot log before disabling
576 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800577
578 For details, take a look at <file:Documentation/cpu-freq>.
579
580 If unsure, say N.
581
582endmenu
583
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900584source "arch/sh/drivers/Kconfig"
585
Paul Mundtcad82442006-01-16 22:14:19 -0800586endmenu
587
Paul Mundtcad82442006-01-16 22:14:19 -0800588menu "Kernel features"
589
Paul Mundt91b91d02006-09-27 18:08:33 +0900590source kernel/Kconfig.hz
591
Paul Mundtcad82442006-01-16 22:14:19 -0800592config KEXEC
593 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000594 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800595 help
596 kexec is a system call that implements the ability to shutdown your
597 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400598 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800599 you can start any kernel with it, not just Linux.
600
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400601 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800602
603 It is an ongoing process to be certain the hardware in a machine
604 is properly shutdown, so do not be surprised if this code does not
605 initially work for you. It may help to enable device hotplugging
606 support. As of this writing the exact hardware interface is
607 strongly in flux, so no good recommendation can be made.
608
Paul Mundt4d5ade52007-04-27 11:25:57 +0900609config CRASH_DUMP
610 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900611 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900612 help
613 Generate crash dump after being started by kexec.
614 This should be normally only set in special crash dump kernels
615 which are loaded in the main kernel with kexec-tools into
616 a specially reserved region and then later executed after
617 a crash by kdump/kexec. The crash dump kernel must be compiled
618 to a memory address not used by the main kernel using
619 MEMORY_START.
620
621 For more details see Documentation/kdump/kdump.txt
622
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000623config KEXEC_JUMP
624 bool "kexec jump (EXPERIMENTAL)"
625 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
626 help
627 Jump between original kernel and kexeced kernel and invoke
628 code via KEXEC
629
Paul Mundtc4637d42008-07-30 15:30:52 +0900630config SECCOMP
631 bool "Enable seccomp to safely compute untrusted bytecode"
632 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900633 help
634 This kernel feature is useful for number crunching applications
635 that may need to compute untrusted bytecode during their
636 execution. By using pipes or other transports made available to
637 the process as file descriptors supporting the read/write
638 syscalls, it's possible to isolate those applications in
639 their own address space using seccomp. Once seccomp is
640 enabled via prctl, it cannot be disabled and the task is only
641 allowed to execute a few safe syscalls defined by each seccomp
642 mode.
643
644 If unsure, say N.
645
Linus Torvalds1da177e2005-04-16 15:20:36 -0700646config SMP
647 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900648 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200649 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700650 ---help---
651 This enables support for systems with more than one CPU. If you have
652 a system with only one CPU, like most personal computers, say N. If
653 you have a system with more than one CPU, say Y.
654
655 If you say N here, the kernel will run on single and multiprocessor
656 machines, but will use only one CPU of a multiprocessor machine. If
657 you say Y here, the kernel will run on many, but not all,
658 singleprocessor machines. On a singleprocessor machine, the kernel
659 will run faster if you say N here.
660
661 People using multiprocessor machines who say Y here should also say
662 Y to "Enhanced Real Time Clock Support", below.
663
Adrian Bunk03502fa2008-02-03 15:50:21 +0200664 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
665 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700666
667 If you don't know what to do here, say N.
668
669config NR_CPUS
670 int "Maximum number of CPUs (2-32)"
671 range 2 32
672 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900673 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700674 default "2"
675 help
676 This allows you to specify the maximum number of CPUs which this
677 kernel will support. The maximum supported value is 32 and the
678 minimum value which makes sense is 2.
679
680 This is purely to save memory - each supported CPU adds
681 approximately eight kilobytes to the kernel image.
682
Paul Mundt91b91d02006-09-27 18:08:33 +0900683source "kernel/Kconfig.preempt"
684
Paul Mundt83662462007-09-28 16:04:49 +0900685config GUSA
686 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900687 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900688 help
689 This enables support for gUSA (general UserSpace Atomicity).
690 This is the default implementation for both UP and non-ll/sc
691 CPUs, and is used by the libc, amongst others.
692
693 For additional information, design information can be found
694 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
695
696 This should only be disabled for special cases where alternate
697 atomicity implementations exist.
698
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900699config GUSA_RB
700 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
701 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
702 help
703 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100704 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900705 store-conditional (LLSC). On machines which do not have hardware
706 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100707 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900708
Paul Mundt54ff3282009-06-11 10:33:09 +0300709config SPARSE_IRQ
710 bool "Support sparse irq numbering"
711 depends on EXPERIMENTAL
712 help
713 This enables support for sparse irqs. This is useful in general
714 as most CPUs have a fairly sparse array of IRQ vectors, which
715 the irq_desc then maps directly on to. Systems with a high
716 number of off-chip IRQs will want to treat this as
717 experimental until they have been independently verified.
718
719 If you don't know what to do here, say N.
720
Paul Mundtcad82442006-01-16 22:14:19 -0800721endmenu
722
723menu "Boot options"
724
725config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900726 hex
727 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
728 SH_7751_SOLUTION_ENGINE
729 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900730 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800731 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700732 help
Paul Mundtcad82442006-01-16 22:14:19 -0800733 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700734
Paul Mundtcad82442006-01-16 22:14:19 -0800735config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900736 hex
737 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900738 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900739 default "0x00810000" if SH_7780_SOLUTION_ENGINE
740 default "0x009e0000" if SH_TITAN
741 default "0x01800000" if SH_SDK7780
742 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800743 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700744 help
Paul Mundtcad82442006-01-16 22:14:19 -0800745 This option allows you to set the link address offset of the zImage.
746 This can be useful if you are on a board which has a small amount of
747 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700748
Paul Mundtb412a49a2009-05-10 01:23:25 +0900749config ENTRY_OFFSET
750 hex
751 default "0x00001000" if PAGE_SIZE_4KB
752 default "0x00002000" if PAGE_SIZE_8KB
753 default "0x00004000" if PAGE_SIZE_16KB
754 default "0x00010000" if PAGE_SIZE_64KB
755 default "0x00000000"
756
Paul Mundtcad82442006-01-16 22:14:19 -0800757config UBC_WAKEUP
758 bool "Wakeup UBC on startup"
Paul Mundt0e3a9aa2007-11-06 15:55:36 +0900759 depends on CPU_SH4 && !CPU_SH4A
Paul Mundtcad82442006-01-16 22:14:19 -0800760 help
761 Selecting this option will wakeup the User Break Controller (UBC) on
762 startup. Although the UBC is left in an awake state when the processor
763 comes up, some boot loaders misbehave by putting the UBC to sleep in a
764 power saving state, which causes issues with things like ptrace().
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765
766 If unsure, say N.
767
Paul Mundtcad82442006-01-16 22:14:19 -0800768config CMDLINE_BOOL
769 bool "Default bootloader kernel arguments"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700770
Paul Mundtcad82442006-01-16 22:14:19 -0800771config CMDLINE
772 string "Initial kernel command string"
773 depends on CMDLINE_BOOL
774 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700775
776endmenu
777
Paul Mundtcad82442006-01-16 22:14:19 -0800778menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700779
Paul Mundtcad82442006-01-16 22:14:19 -0800780config SUPERHYWAY
781 tristate "SuperHyway Bus support"
782 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700783
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900784config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900785 bool "Maple Bus support"
786 depends on SH_DREAMCAST
787 help
788 The Maple Bus is SEGA's serial communication bus for peripherals
789 on the Dreamcast. Without this bus support you won't be able to
790 get your Dreamcast keyboard etc to work, so most users
791 probably want to say 'Y' here, unless you are only using the
792 Dreamcast with a serial line terminal or a remote network
793 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900794
Linus Torvalds1da177e2005-04-16 15:20:36 -0700795source "arch/sh/drivers/pci/Kconfig"
796
Paul Mundte16038a2009-01-09 15:12:30 +0900797source "drivers/pci/pcie/Kconfig"
798
Linus Torvalds1da177e2005-04-16 15:20:36 -0700799source "drivers/pci/Kconfig"
800
801source "drivers/pcmcia/Kconfig"
802
803source "drivers/pci/hotplug/Kconfig"
804
805endmenu
806
807menu "Executable file formats"
808
809source "fs/Kconfig.binfmt"
810
811endmenu
812
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900813menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900814depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100815
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900816source "kernel/power/Kconfig"
817
818source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900819
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900820endmenu
821
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700822source "net/Kconfig"
823
Linus Torvalds1da177e2005-04-16 15:20:36 -0700824source "drivers/Kconfig"
825
826source "fs/Kconfig"
827
Linus Torvalds1da177e2005-04-16 15:20:36 -0700828source "arch/sh/Kconfig.debug"
829
830source "security/Kconfig"
831
832source "crypto/Kconfig"
833
834source "lib/Kconfig"