blob: f971cb74dd6255d1846c461cdbd0b65e02980c56 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# For a description of the syntax of this configuration file,
3# see Documentation/kbuild/kconfig-language.txt.
4#
5
6mainmenu "Linux/SuperH Kernel Configuration"
7
8config SUPERH
Paul Mundtea0e1a92007-11-21 15:58:01 +09009 def_bool y
Paul Mundt7a440c92006-09-27 18:18:31 +090010 select EMBEDDED
David Brownell9483a572008-07-23 21:26:48 -070011 select HAVE_CLK
Sam Ravnborgec7748b2008-02-09 10:46:40 +010012 select HAVE_IDE
Matt Flemingc601a512009-07-03 16:16:54 +090013 select HAVE_LMB
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050014 select HAVE_OPROFILE
Dmitry Baryshkov9de90ac2008-07-18 13:30:31 +040015 select HAVE_GENERIC_DMA_COHERENT
Paul Mundt21944782008-09-17 23:26:44 +090016 select HAVE_IOREMAP_PROT if MMU
Paul Mundtd7b01f72008-12-10 20:17:15 +090017 select HAVE_ARCH_TRACEHOOK
Paul Mundtf802d962009-04-09 10:36:54 -070018 select HAVE_DMA_API_DEBUG
Paul Mundt73c926b2009-10-20 12:55:56 +090019 select HAVE_DMA_ATTRS
Ingo Molnarcdd6c482009-09-21 12:02:48 +020020 select HAVE_PERF_EVENTS
Paul Mundt72f0c132009-10-27 17:08:55 +090021 select PERF_USE_VMALLOC
Paul Mundtdf8ce252009-07-12 01:37:30 +090022 select HAVE_KERNEL_GZIP
Paul Mundt07e88e12009-07-11 13:21:19 -040023 select HAVE_KERNEL_BZIP2
24 select HAVE_KERNEL_LZMA
Paul Mundta74f7e02009-09-16 14:30:34 +090025 select HAVE_SYSCALL_TRACEPOINTS
Paul Mundt6eac1af2009-05-08 19:48:47 +090026 select RTC_LIB
Paul Mundtf01789c2009-06-17 10:43:13 +090027 select GENERIC_ATOMIC64
Linus Torvalds1da177e2005-04-16 15:20:36 -070028 help
29 The SuperH is a RISC processor targeted for use in embedded systems
30 and consumer electronics; it was also used in the Sega Dreamcast
31 gaming console. The SuperH port has a home page at
32 <http://www.linux-sh.org/>.
33
Paul Mundt39d28a22007-11-08 18:39:33 +090034config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090035 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090036 select HAVE_KPROBES
37 select HAVE_KRETPROBES
Paul Mundt694f94f2008-10-31 16:20:36 +090038 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090039 select HAVE_FTRACE_MCOUNT_RECORD
40 select HAVE_DYNAMIC_FTRACE
Matt Flemingc1340c02009-06-28 14:05:44 +010041 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Paul Mundte4b053d2009-10-13 16:52:50 +090042 select HAVE_FTRACE_NMI_ENTER if DYNAMIC_FTRACE
Matt Fleming327933f2009-07-11 00:29:03 +000043 select HAVE_FUNCTION_GRAPH_TRACER
Paul Mundtab6e5702008-12-11 18:46:46 +090044 select HAVE_ARCH_KGDB
Paul Mundt6fbfe8d2010-01-06 15:46:53 +090045 select HAVE_HW_BREAKPOINT
Paul Mundt6c0ee6a2009-12-21 17:35:00 +090046 select PERF_EVENTS if HAVE_HW_BREAKPOINT
Paul Mundt8dafc342009-04-02 11:56:38 +090047 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090048
49config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090050 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090051
Paul Mundtf42b7e32008-07-29 20:12:51 +090052config ARCH_DEFCONFIG
53 string
54 default "arch/sh/configs/shx3_defconfig" if SUPERH32
55 default "arch/sh/configs/cayman_defconfig" if SUPERH64
56
Linus Torvalds1da177e2005-04-16 15:20:36 -070057config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090058 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070059
60config RWSEM_XCHGADD_ALGORITHM
61 bool
62
Paul Mundtfa691512007-03-08 19:41:21 +090063config GENERIC_BUG
64 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090065 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090066
Paul Mundt3767f3f2009-06-15 00:00:42 +090067config GENERIC_CSUM
68 def_bool y
69 depends on SUPERH64
70
Akinobu Mitae2268c72006-03-26 01:39:35 -080071config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090072 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080073
74config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090075 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080076
Linus Torvalds1da177e2005-04-16 15:20:36 -070077config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090078 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070079
Paul Mundt5093c9a2008-08-04 14:17:13 +090080config GENERIC_HARDIRQS_NO__DO_IRQ
81 def_bool y
82
Linus Torvalds1da177e2005-04-16 15:20:36 -070083config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090084 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070085
Paul Mundt2eb2a432009-06-19 16:00:00 +090086config IRQ_PER_CPU
87 def_bool y
88
Magnus Damm2967dab2008-10-08 20:41:43 +090089config GENERIC_GPIO
90 def_bool n
91
Linus Torvalds1da177e2005-04-16 15:20:36 -070092config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090093 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070094
Paul Mundtcad82442006-01-16 22:14:19 -080095config GENERIC_IOMAP
96 bool
97
Paul Mundt45882142006-10-04 13:21:45 +090098config GENERIC_TIME
john stultz75634312009-05-01 13:10:28 -070099 def_bool y
Paul Mundt45882142006-10-04 13:21:45 +0900100
Paul Mundt57be2b42007-05-09 17:33:24 +0900101config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +0900102 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +0900103
Paul Mundt8c245942008-08-06 18:37:07 +0900104config GENERIC_CLOCKEVENTS_BROADCAST
105 bool
106
Paul Mundt6d134b92009-05-08 16:36:13 +0900107config GENERIC_CMOS_UPDATE
108 def_bool y
109 depends on SH_SH03 || SH_DREAMCAST
110
Paul Mundtbdcab872008-08-04 14:09:15 +0900111config GENERIC_LOCKBREAK
112 def_bool y
113 depends on SMP && PREEMPT
114
Paul Mundt357d5942007-06-11 15:32:07 +0900115config SYS_SUPPORTS_PM
116 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900117 depends on !SMP
118
119config ARCH_SUSPEND_POSSIBLE
120 def_bool n
121
122config ARCH_HIBERNATION_POSSIBLE
123 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900124
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900125config SYS_SUPPORTS_APM_EMULATION
126 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900127 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900128
Paul Mundtffb4a732009-10-27 07:22:37 +0900129config SYS_SUPPORTS_HUGETLBFS
130 bool
131
Paul Mundt357d5942007-06-11 15:32:07 +0900132config SYS_SUPPORTS_SMP
133 bool
134
135config SYS_SUPPORTS_NUMA
136 bool
137
138config SYS_SUPPORTS_PCI
139 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900140
Paul Mundtf5ad8812009-01-29 18:08:58 +0900141config SYS_SUPPORTS_CMT
142 bool
143
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000144config SYS_SUPPORTS_MTU2
145 bool
146
Magnus Damm9570ef22009-05-01 06:51:00 +0000147config SYS_SUPPORTS_TMU
148 bool
149
Paul Mundtafbfb522006-12-04 18:17:28 +0900150config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900151 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900152
153config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900154 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900155
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900156config HAVE_LATENCYTOP_SUPPORT
157 def_bool y
158 depends on !SMP
159
David Howellsf0d1b0b2006-12-08 02:37:49 -0800160config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900161 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800162
163config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900164 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800165
Paul Mundte257ad02007-07-25 11:18:00 +0900166config ARCH_NO_VIRT_TO_BUS
167 def_bool y
168
Paul Mundte869a902009-04-02 13:08:31 +0900169config ARCH_HAS_DEFAULT_IDLE
170 def_bool y
171
Paul Mundt2e046b92009-06-19 14:40:51 +0900172config ARCH_HAS_CPU_IDLE_WAIT
173 def_bool y
174
Magnus Damme7cc9a72008-02-07 20:18:21 +0900175config IO_TRAPPED
176 bool
177
Paul Mundt01be5d62009-10-27 10:35:02 +0900178config DMA_COHERENT
179 bool
180
181config DMA_NONCOHERENT
182 def_bool !DMA_COHERENT
183
Linus Torvalds1da177e2005-04-16 15:20:36 -0700184source "init/Kconfig"
185
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700186source "kernel/Kconfig.freezer"
187
Linus Torvalds1da177e2005-04-16 15:20:36 -0700188menu "System type"
189
Paul Mundtb5f42db2007-11-08 18:38:14 +0900190#
191# Processor families
192#
193config CPU_SH2
194 bool
195
196config CPU_SH2A
197 bool
198 select CPU_SH2
199
200config CPU_SH3
201 bool
202 select CPU_HAS_INTEVT
203 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900204 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900205
206config CPU_SH4
207 bool
208 select CPU_HAS_INTEVT
209 select CPU_HAS_SR_RB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900210 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900211 select SYS_SUPPORTS_TMU
Paul Mundtffb4a732009-10-27 07:22:37 +0900212 select SYS_SUPPORTS_HUGETLBFS if MMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900213
214config CPU_SH4A
215 bool
216 select CPU_SH4
217
218config CPU_SH4AL_DSP
219 bool
220 select CPU_SH4A
221 select CPU_HAS_DSP
222
Paul Mundtea0e1a92007-11-21 15:58:01 +0900223config CPU_SH5
224 bool
225 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900226 select SYS_SUPPORTS_TMU
Paul Mundtffb4a732009-10-27 07:22:37 +0900227 select SYS_SUPPORTS_HUGETLBFS if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900228
Paul Mundtb5f42db2007-11-08 18:38:14 +0900229config CPU_SHX2
230 bool
231
232config CPU_SHX3
233 bool
Paul Mundt01be5d62009-10-27 10:35:02 +0900234 select DMA_COHERENT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900235
Paul Mundtdc65a972009-03-10 16:26:29 +0900236config ARCH_SHMOBILE
237 bool
Magnus Damm77594912009-03-13 15:23:04 +0000238 select ARCH_SUSPEND_POSSIBLE
Magnus Dammac2c5962009-08-19 10:31:53 +0000239 select PM
240 select PM_RUNTIME
Paul Mundtdc65a972009-03-10 16:26:29 +0900241
Paul Mundt3cc000b2009-04-11 08:39:27 +0900242if SUPERH32
243
Paul Mundtb5f42db2007-11-08 18:38:14 +0900244choice
245 prompt "Processor sub-type selection"
246
247#
248# Processor subtypes
249#
250
251# SH-2 Processor Support
252
253config CPU_SUBTYPE_SH7619
254 bool "Support SH7619 processor"
255 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900256 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900257
258# SH-2A Processor Support
259
Peter Griffin28259992008-11-28 22:48:20 +0900260config CPU_SUBTYPE_SH7201
261 bool "Support SH7201 processor"
262 select CPU_SH2A
263 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000264 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900265
Paul Mundt6d01f512007-11-26 18:17:21 +0900266config CPU_SUBTYPE_SH7203
267 bool "Support SH7203 processor"
268 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900269 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900270 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000271 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900272
Paul Mundtb5f42db2007-11-08 18:38:14 +0900273config CPU_SUBTYPE_SH7206
274 bool "Support SH7206 processor"
275 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900276 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000277 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900278
Paul Mundta8f67f42007-11-26 19:54:02 +0900279config CPU_SUBTYPE_SH7263
280 bool "Support SH7263 processor"
281 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900282 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900283 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000284 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900285
Paul Mundt2ad69902008-03-13 12:52:44 +0900286config CPU_SUBTYPE_MXG
287 bool "Support MX-G processor"
288 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000289 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900290 help
291 Select MX-G if running on an R8A03022BG part.
292
Paul Mundtb5f42db2007-11-08 18:38:14 +0900293# SH-3 Processor Support
294
295config CPU_SUBTYPE_SH7705
296 bool "Support SH7705 processor"
297 select CPU_SH3
298
299config CPU_SUBTYPE_SH7706
300 bool "Support SH7706 processor"
301 select CPU_SH3
302 help
303 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
304
305config CPU_SUBTYPE_SH7707
306 bool "Support SH7707 processor"
307 select CPU_SH3
308 help
309 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
310
311config CPU_SUBTYPE_SH7708
312 bool "Support SH7708 processor"
313 select CPU_SH3
314 help
315 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
316 if you have a 100 Mhz SH-3 HD6417708R CPU.
317
318config CPU_SUBTYPE_SH7709
319 bool "Support SH7709 processor"
320 select CPU_SH3
321 help
322 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
323
324config CPU_SUBTYPE_SH7710
325 bool "Support SH7710 processor"
326 select CPU_SH3
327 select CPU_HAS_DSP
328 help
329 Select SH7710 if you have a SH3-DSP SH7710 CPU.
330
331config CPU_SUBTYPE_SH7712
332 bool "Support SH7712 processor"
333 select CPU_SH3
334 select CPU_HAS_DSP
335 help
336 Select SH7712 if you have a SH3-DSP SH7712 CPU.
337
338config CPU_SUBTYPE_SH7720
339 bool "Support SH7720 processor"
340 select CPU_SH3
341 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000342 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900343 help
344 Select SH7720 if you have a SH3-DSP SH7720 CPU.
345
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900346config CPU_SUBTYPE_SH7721
347 bool "Support SH7721 processor"
348 select CPU_SH3
349 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000350 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900351 help
352 Select SH7721 if you have a SH3-DSP SH7721 CPU.
353
Paul Mundtb5f42db2007-11-08 18:38:14 +0900354# SH-4 Processor Support
355
356config CPU_SUBTYPE_SH7750
357 bool "Support SH7750 processor"
358 select CPU_SH4
359 help
360 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
361
362config CPU_SUBTYPE_SH7091
363 bool "Support SH7091 processor"
364 select CPU_SH4
365 help
366 Select SH7091 if you have an SH-4 based Sega device (such as
367 the Dreamcast, Naomi, and Naomi 2).
368
369config CPU_SUBTYPE_SH7750R
370 bool "Support SH7750R processor"
371 select CPU_SH4
372
373config CPU_SUBTYPE_SH7750S
374 bool "Support SH7750S processor"
375 select CPU_SH4
376
377config CPU_SUBTYPE_SH7751
378 bool "Support SH7751 processor"
379 select CPU_SH4
380 help
381 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
382 or if you have a HD6417751R CPU.
383
384config CPU_SUBTYPE_SH7751R
385 bool "Support SH7751R processor"
386 select CPU_SH4
387
388config CPU_SUBTYPE_SH7760
389 bool "Support SH7760 processor"
390 select CPU_SH4
391
392config CPU_SUBTYPE_SH4_202
393 bool "Support SH4-202 processor"
394 select CPU_SH4
395
396# SH-4A Processor Support
397
Paul Mundt178dd0c2008-04-09 17:56:18 +0900398config CPU_SUBTYPE_SH7723
399 bool "Support SH7723 processor"
400 select CPU_SH4A
401 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900402 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900403 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900404 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900405 help
406 Select SH7723 if you have an SH-MobileR2 CPU.
407
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900408config CPU_SUBTYPE_SH7724
409 bool "Support SH7724 processor"
410 select CPU_SH4A
411 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900412 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900413 select ARCH_SPARSEMEM_ENABLE
414 select SYS_SUPPORTS_CMT
415 help
416 Select SH7724 if you have an SH-MobileR2R CPU.
417
Yoshihiro Shimodac01f0f12009-08-21 16:30:28 +0900418config CPU_SUBTYPE_SH7757
419 bool "Support SH7757 processor"
420 select CPU_SH4A
421 select CPU_SHX2
422 help
423 Select SH7757 if you have a SH4A SH7757 CPU.
424
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900425config CPU_SUBTYPE_SH7763
426 bool "Support SH7763 processor"
427 select CPU_SH4A
428 help
429 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
430
Paul Mundtb5f42db2007-11-08 18:38:14 +0900431config CPU_SUBTYPE_SH7770
432 bool "Support SH7770 processor"
433 select CPU_SH4A
434
435config CPU_SUBTYPE_SH7780
436 bool "Support SH7780 processor"
437 select CPU_SH4A
438
439config CPU_SUBTYPE_SH7785
440 bool "Support SH7785 processor"
441 select CPU_SH4A
442 select CPU_SHX2
443 select ARCH_SPARSEMEM_ENABLE
444 select SYS_SUPPORTS_NUMA
445
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900446config CPU_SUBTYPE_SH7786
447 bool "Support SH7786 processor"
448 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900449 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900450 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900451 select ARCH_SPARSEMEM_ENABLE
452 select SYS_SUPPORTS_NUMA
Paul Mundt2eb2a432009-06-19 16:00:00 +0900453 select SYS_SUPPORTS_SMP
454 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900455
Paul Mundtb5f42db2007-11-08 18:38:14 +0900456config CPU_SUBTYPE_SHX3
457 bool "Support SH-X3 processor"
458 select CPU_SH4A
459 select CPU_SHX3
460 select ARCH_SPARSEMEM_ENABLE
461 select SYS_SUPPORTS_NUMA
462 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900463 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900464
465# SH4AL-DSP Processor Support
466
467config CPU_SUBTYPE_SH7343
468 bool "Support SH7343 processor"
469 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900470 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900471 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900472
473config CPU_SUBTYPE_SH7722
474 bool "Support SH7722 processor"
475 select CPU_SH4AL_DSP
476 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900477 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900478 select ARCH_SPARSEMEM_ENABLE
479 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900480 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900481
Magnus Damm9109a302008-02-08 17:31:24 +0900482config CPU_SUBTYPE_SH7366
483 bool "Support SH7366 processor"
484 select CPU_SH4AL_DSP
485 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900486 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900487 select ARCH_SPARSEMEM_ENABLE
488 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900489 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900490
Paul Mundt3cc000b2009-04-11 08:39:27 +0900491endchoice
492
493endif
494
495if SUPERH64
496
497choice
498 prompt "Processor sub-type selection"
499
Paul Mundtea0e1a92007-11-21 15:58:01 +0900500# SH-5 Processor Support
501
502config CPU_SUBTYPE_SH5_101
503 bool "Support SH5-101 processor"
504 select CPU_SH5
505
506config CPU_SUBTYPE_SH5_103
507 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900508 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900509
Paul Mundtb5f42db2007-11-08 18:38:14 +0900510endchoice
511
Paul Mundt3cc000b2009-04-11 08:39:27 +0900512endif
513
Paul Mundtcad82442006-01-16 22:14:19 -0800514source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900515
Paul Mundt4690bdc2007-11-09 13:45:42 +0900516source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800517
Paul Mundt939a24a2008-07-29 21:41:37 +0900518source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900519
Paul Mundt32351a22007-03-12 14:38:59 +0900520menu "Timer and clock configuration"
521
Magnus Damm9570ef22009-05-01 06:51:00 +0000522config SH_TIMER_TMU
523 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000524 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000525 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000526 help
527 This enables the build of the TMU timer driver.
528
Paul Mundtf5ad8812009-01-29 18:08:58 +0900529config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000530 bool "CMT timer driver"
531 depends on SYS_SUPPORTS_CMT
532 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000533 help
534 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900535
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000536config SH_TIMER_MTU2
537 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000538 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000539 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000540 help
541 This enables build of the MTU2 timer driver.
542
Paul Mundtcad82442006-01-16 22:14:19 -0800543config SH_PCLK_FREQ
544 int "Peripheral clock frequency (in Hz)"
Magnus Damm870e8a22007-07-25 10:49:21 +0900545 default "27000000" if CPU_SUBTYPE_SH7343
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900546 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt05627482007-05-15 16:25:47 +0900547 default "32000000" if CPU_SUBTYPE_SH7722
Paul Mundt178dd0c2008-04-09 17:56:18 +0900548 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900549 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
Paul Mundta8f67f42007-11-26 19:54:02 +0900550 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
Paul Mundta4b1fdd2009-03-05 17:52:34 +0900551 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
Kuninori Morimoto47785412009-05-29 07:41:26 +0000552 CPU_SUBTYPE_SH7786 || CPU_SUBTYPE_SH7724
Paul Mundt05627482007-05-15 16:25:47 +0900553 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800554 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900555 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800556 help
557 This option is used to specify the peripheral clock frequency.
558 This is necessary for determining the reference clock value on
559 platforms lacking an RTC.
560
Paul Mundt36aa1e32009-05-22 14:00:34 +0900561config SH_CLK_CPG
562 def_bool y
563
Paul Mundt253b0882009-05-13 17:38:11 +0900564config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900565 depends on SH_CLK_CPG
Magnus Damm46e93712009-06-04 07:37:59 +0000566 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE
Paul Mundt253b0882009-05-13 17:38:11 +0900567
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900568config SH_CLK_MD
569 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900570 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900571 default 6 if CPU_SUBTYPE_SH7206
572 default 5 if CPU_SUBTYPE_SH7619
573 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900574 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900575 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900576
Paul Mundt57be2b42007-05-09 17:33:24 +0900577source "kernel/time/Kconfig"
578
Paul Mundt32351a22007-03-12 14:38:59 +0900579endmenu
580
Paul Mundtcad82442006-01-16 22:14:19 -0800581menu "CPU Frequency scaling"
582
583source "drivers/cpufreq/Kconfig"
584
585config SH_CPU_FREQ
586 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900587 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800588 select CPU_FREQ_TABLE
589 help
Paul Mundt8a655052008-12-17 15:06:54 +0900590 This adds the cpufreq driver for SuperH. Any CPU that supports
591 clock rate rounding through the clock framework can use this
592 driver. While it will make the kernel slightly larger, this is
593 harmless for CPUs that don't support rate rounding. The driver
594 will also generate a notice in the boot log before disabling
595 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800596
597 For details, take a look at <file:Documentation/cpu-freq>.
598
599 If unsure, say N.
600
601endmenu
602
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900603source "arch/sh/drivers/Kconfig"
604
Paul Mundtcad82442006-01-16 22:14:19 -0800605endmenu
606
Paul Mundtcad82442006-01-16 22:14:19 -0800607menu "Kernel features"
608
Paul Mundt91b91d02006-09-27 18:08:33 +0900609source kernel/Kconfig.hz
610
Paul Mundtcad82442006-01-16 22:14:19 -0800611config KEXEC
612 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000613 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800614 help
615 kexec is a system call that implements the ability to shutdown your
616 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400617 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800618 you can start any kernel with it, not just Linux.
619
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400620 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800621
622 It is an ongoing process to be certain the hardware in a machine
623 is properly shutdown, so do not be surprised if this code does not
624 initially work for you. It may help to enable device hotplugging
625 support. As of this writing the exact hardware interface is
626 strongly in flux, so no good recommendation can be made.
627
Paul Mundt4d5ade52007-04-27 11:25:57 +0900628config CRASH_DUMP
629 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900630 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900631 help
632 Generate crash dump after being started by kexec.
633 This should be normally only set in special crash dump kernels
634 which are loaded in the main kernel with kexec-tools into
635 a specially reserved region and then later executed after
636 a crash by kdump/kexec. The crash dump kernel must be compiled
637 to a memory address not used by the main kernel using
638 MEMORY_START.
639
640 For more details see Documentation/kdump/kdump.txt
641
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000642config KEXEC_JUMP
643 bool "kexec jump (EXPERIMENTAL)"
644 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
645 help
646 Jump between original kernel and kexeced kernel and invoke
647 code via KEXEC
648
Paul Mundtc4637d42008-07-30 15:30:52 +0900649config SECCOMP
650 bool "Enable seccomp to safely compute untrusted bytecode"
651 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900652 help
653 This kernel feature is useful for number crunching applications
654 that may need to compute untrusted bytecode during their
655 execution. By using pipes or other transports made available to
656 the process as file descriptors supporting the read/write
657 syscalls, it's possible to isolate those applications in
658 their own address space using seccomp. Once seccomp is
659 enabled via prctl, it cannot be disabled and the task is only
660 allowed to execute a few safe syscalls defined by each seccomp
661 mode.
662
663 If unsure, say N.
664
Linus Torvalds1da177e2005-04-16 15:20:36 -0700665config SMP
666 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900667 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200668 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700669 ---help---
670 This enables support for systems with more than one CPU. If you have
671 a system with only one CPU, like most personal computers, say N. If
672 you have a system with more than one CPU, say Y.
673
674 If you say N here, the kernel will run on single and multiprocessor
675 machines, but will use only one CPU of a multiprocessor machine. If
676 you say Y here, the kernel will run on many, but not all,
677 singleprocessor machines. On a singleprocessor machine, the kernel
678 will run faster if you say N here.
679
680 People using multiprocessor machines who say Y here should also say
681 Y to "Enhanced Real Time Clock Support", below.
682
Adrian Bunk03502fa2008-02-03 15:50:21 +0200683 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
684 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700685
686 If you don't know what to do here, say N.
687
688config NR_CPUS
689 int "Maximum number of CPUs (2-32)"
690 range 2 32
691 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900692 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700693 default "2"
694 help
695 This allows you to specify the maximum number of CPUs which this
696 kernel will support. The maximum supported value is 32 and the
697 minimum value which makes sense is 2.
698
699 This is purely to save memory - each supported CPU adds
700 approximately eight kilobytes to the kernel image.
701
Paul Mundt91b91d02006-09-27 18:08:33 +0900702source "kernel/Kconfig.preempt"
703
Paul Mundt83662462007-09-28 16:04:49 +0900704config GUSA
705 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900706 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900707 help
708 This enables support for gUSA (general UserSpace Atomicity).
709 This is the default implementation for both UP and non-ll/sc
710 CPUs, and is used by the libc, amongst others.
711
712 For additional information, design information can be found
713 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
714
715 This should only be disabled for special cases where alternate
716 atomicity implementations exist.
717
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900718config GUSA_RB
719 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
720 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
721 help
722 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100723 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900724 store-conditional (LLSC). On machines which do not have hardware
725 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100726 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900727
Paul Mundt54ff3282009-06-11 10:33:09 +0300728config SPARSE_IRQ
729 bool "Support sparse irq numbering"
730 depends on EXPERIMENTAL
731 help
732 This enables support for sparse irqs. This is useful in general
733 as most CPUs have a fairly sparse array of IRQ vectors, which
734 the irq_desc then maps directly on to. Systems with a high
735 number of off-chip IRQs will want to treat this as
736 experimental until they have been independently verified.
737
738 If you don't know what to do here, say N.
739
Paul Mundtcad82442006-01-16 22:14:19 -0800740endmenu
741
742menu "Boot options"
743
744config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900745 hex
746 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
747 SH_7751_SOLUTION_ENGINE
748 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900749 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800750 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700751 help
Paul Mundtcad82442006-01-16 22:14:19 -0800752 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700753
Paul Mundtcad82442006-01-16 22:14:19 -0800754config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900755 hex
756 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900757 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900758 default "0x00810000" if SH_7780_SOLUTION_ENGINE
759 default "0x009e0000" if SH_TITAN
760 default "0x01800000" if SH_SDK7780
761 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800762 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700763 help
Paul Mundtcad82442006-01-16 22:14:19 -0800764 This option allows you to set the link address offset of the zImage.
765 This can be useful if you are on a board which has a small amount of
766 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700767
Paul Mundtb412a49a2009-05-10 01:23:25 +0900768config ENTRY_OFFSET
769 hex
770 default "0x00001000" if PAGE_SIZE_4KB
771 default "0x00002000" if PAGE_SIZE_8KB
772 default "0x00004000" if PAGE_SIZE_16KB
773 default "0x00010000" if PAGE_SIZE_64KB
774 default "0x00000000"
775
Pawel Molld724a9c2009-08-24 16:25:38 +0900776choice
777 prompt "Kernel command line"
778 optional
779 default CMDLINE_OVERWRITE
780 help
781 Setting this option allows the kernel command line arguments
782 to be set.
783
784config CMDLINE_OVERWRITE
785 bool "Overwrite bootloader kernel arguments"
786 help
787 Given string will overwrite any arguments passed in by
788 a bootloader.
789
790config CMDLINE_EXTEND
791 bool "Extend bootloader kernel arguments"
792 help
793 Given string will be concatenated with arguments passed in
794 by a bootloader.
795
796endchoice
Linus Torvalds1da177e2005-04-16 15:20:36 -0700797
Paul Mundtcad82442006-01-16 22:14:19 -0800798config CMDLINE
Pawel Molld724a9c2009-08-24 16:25:38 +0900799 string "Kernel command line arguments string"
800 depends on CMDLINE_OVERWRITE || CMDLINE_EXTEND
Paul Mundtcad82442006-01-16 22:14:19 -0800801 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700802
803endmenu
804
Paul Mundtcad82442006-01-16 22:14:19 -0800805menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700806
Paul Mundtcad82442006-01-16 22:14:19 -0800807config SUPERHYWAY
808 tristate "SuperHyway Bus support"
809 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700810
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900811config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900812 bool "Maple Bus support"
813 depends on SH_DREAMCAST
814 help
815 The Maple Bus is SEGA's serial communication bus for peripherals
816 on the Dreamcast. Without this bus support you won't be able to
817 get your Dreamcast keyboard etc to work, so most users
818 probably want to say 'Y' here, unless you are only using the
819 Dreamcast with a serial line terminal or a remote network
820 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900821
Paul Mundt76934652009-10-27 10:36:55 +0900822config PCI
823 bool "PCI support"
824 depends on SYS_SUPPORTS_PCI
825 help
826 Find out whether you have a PCI motherboard. PCI is the name of a
827 bus system, i.e. the way the CPU talks to the other stuff inside
828 your box. If you have PCI, say Y, otherwise N.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700829
Paul Mundte16038a2009-01-09 15:12:30 +0900830source "drivers/pci/pcie/Kconfig"
831
Linus Torvalds1da177e2005-04-16 15:20:36 -0700832source "drivers/pci/Kconfig"
833
834source "drivers/pcmcia/Kconfig"
835
836source "drivers/pci/hotplug/Kconfig"
837
838endmenu
839
840menu "Executable file formats"
841
842source "fs/Kconfig.binfmt"
843
844endmenu
845
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900846menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900847depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100848
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900849source "kernel/power/Kconfig"
850
851source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900852
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900853endmenu
854
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700855source "net/Kconfig"
856
Linus Torvalds1da177e2005-04-16 15:20:36 -0700857source "drivers/Kconfig"
858
859source "fs/Kconfig"
860
Linus Torvalds1da177e2005-04-16 15:20:36 -0700861source "arch/sh/Kconfig.debug"
862
863source "security/Kconfig"
864
865source "crypto/Kconfig"
866
867source "lib/Kconfig"