blob: 0f023bb62f99239790128cff444ac569ec0db2a6 [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 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 Mundt73c926b2009-10-20 12:55:56 +090018 select HAVE_DMA_ATTRS
Ingo Molnarcdd6c482009-09-21 12:02:48 +020019 select HAVE_PERF_EVENTS
Paul Mundt72f0c132009-10-27 17:08:55 +090020 select PERF_USE_VMALLOC
Paul Mundtdf8ce252009-07-12 01:37:30 +090021 select HAVE_KERNEL_GZIP
Paul Mundt07e88e12009-07-11 13:21:19 -040022 select HAVE_KERNEL_BZIP2
23 select HAVE_KERNEL_LZMA
Paul Mundtc7b16ef2010-01-13 13:29:19 +090024 select HAVE_KERNEL_LZO
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 Mundt6d63e732010-01-19 14:00:14 +090038 select HAVE_IOREMAP_PROT if MMU && !X2TLB
Paul Mundt694f94f2008-10-31 16:20:36 +090039 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090040 select HAVE_FTRACE_MCOUNT_RECORD
41 select HAVE_DYNAMIC_FTRACE
Matt Flemingc1340c02009-06-28 14:05:44 +010042 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Paul Mundte4b053d2009-10-13 16:52:50 +090043 select HAVE_FTRACE_NMI_ENTER if DYNAMIC_FTRACE
Matt Fleming327933f2009-07-11 00:29:03 +000044 select HAVE_FUNCTION_GRAPH_TRACER
Paul Mundtab6e5702008-12-11 18:46:46 +090045 select HAVE_ARCH_KGDB
Paul Mundt6fbfe8d2010-01-06 15:46:53 +090046 select HAVE_HW_BREAKPOINT
Paul Mundt6c0ee6a2009-12-21 17:35:00 +090047 select PERF_EVENTS if HAVE_HW_BREAKPOINT
Paul Mundt8dafc342009-04-02 11:56:38 +090048 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +090049
50config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090051 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090052
Paul Mundtf42b7e32008-07-29 20:12:51 +090053config ARCH_DEFCONFIG
54 string
55 default "arch/sh/configs/shx3_defconfig" if SUPERH32
56 default "arch/sh/configs/cayman_defconfig" if SUPERH64
57
Linus Torvalds1da177e2005-04-16 15:20:36 -070058config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090059 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
61config RWSEM_XCHGADD_ALGORITHM
62 bool
63
Paul Mundtfa691512007-03-08 19:41:21 +090064config GENERIC_BUG
65 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090066 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090067
Paul Mundt3767f3f2009-06-15 00:00:42 +090068config GENERIC_CSUM
69 def_bool y
70 depends on SUPERH64
71
Akinobu Mitae2268c72006-03-26 01:39:35 -080072config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090073 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080074
75config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090076 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080077
Linus Torvalds1da177e2005-04-16 15:20:36 -070078config GENERIC_HARDIRQS
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090079 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070080
Paul Mundt5093c9a2008-08-04 14:17:13 +090081config GENERIC_HARDIRQS_NO__DO_IRQ
82 def_bool y
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084config GENERIC_IRQ_PROBE
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090085 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070086
Paul Mundt2eb2a432009-06-19 16:00:00 +090087config IRQ_PER_CPU
88 def_bool y
89
Magnus Damm2967dab2008-10-08 20:41:43 +090090config GENERIC_GPIO
91 def_bool n
92
Linus Torvalds1da177e2005-04-16 15:20:36 -070093config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090094 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
Paul Mundtcad82442006-01-16 22:14:19 -080096config GENERIC_IOMAP
97 bool
98
Paul Mundt45882142006-10-04 13:21:45 +090099config GENERIC_TIME
john stultz75634312009-05-01 13:10:28 -0700100 def_bool y
Paul Mundt45882142006-10-04 13:21:45 +0900101
Paul Mundt57be2b42007-05-09 17:33:24 +0900102config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +0900103 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +0900104
Paul Mundt8c245942008-08-06 18:37:07 +0900105config GENERIC_CLOCKEVENTS_BROADCAST
106 bool
107
Paul Mundt6d134b92009-05-08 16:36:13 +0900108config GENERIC_CMOS_UPDATE
109 def_bool y
110 depends on SH_SH03 || SH_DREAMCAST
111
Paul Mundtbdcab872008-08-04 14:09:15 +0900112config GENERIC_LOCKBREAK
113 def_bool y
114 depends on SMP && PREEMPT
115
Paul Mundt357d5942007-06-11 15:32:07 +0900116config SYS_SUPPORTS_PM
117 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900118 depends on !SMP
119
120config ARCH_SUSPEND_POSSIBLE
121 def_bool n
122
123config ARCH_HIBERNATION_POSSIBLE
124 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900125
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900126config SYS_SUPPORTS_APM_EMULATION
127 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900128 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900129
Paul Mundtffb4a732009-10-27 07:22:37 +0900130config SYS_SUPPORTS_HUGETLBFS
131 bool
132
Paul Mundt357d5942007-06-11 15:32:07 +0900133config SYS_SUPPORTS_SMP
134 bool
135
136config SYS_SUPPORTS_NUMA
137 bool
138
139config SYS_SUPPORTS_PCI
140 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900141
Paul Mundtf5ad8812009-01-29 18:08:58 +0900142config SYS_SUPPORTS_CMT
143 bool
144
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000145config SYS_SUPPORTS_MTU2
146 bool
147
Magnus Damm9570ef22009-05-01 06:51:00 +0000148config SYS_SUPPORTS_TMU
149 bool
150
Paul Mundtafbfb522006-12-04 18:17:28 +0900151config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900152 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900153
154config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900155 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900156
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900157config HAVE_LATENCYTOP_SUPPORT
158 def_bool y
159 depends on !SMP
160
David Howellsf0d1b0b2006-12-08 02:37:49 -0800161config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900162 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800163
164config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900165 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800166
Paul Mundte257ad02007-07-25 11:18:00 +0900167config ARCH_NO_VIRT_TO_BUS
168 def_bool y
169
Paul Mundte869a902009-04-02 13:08:31 +0900170config ARCH_HAS_DEFAULT_IDLE
171 def_bool y
172
Paul Mundt2e046b92009-06-19 14:40:51 +0900173config ARCH_HAS_CPU_IDLE_WAIT
174 def_bool y
175
Magnus Damme7cc9a72008-02-07 20:18:21 +0900176config IO_TRAPPED
177 bool
178
Paul Mundt01be5d62009-10-27 10:35:02 +0900179config DMA_COHERENT
180 bool
181
182config DMA_NONCOHERENT
183 def_bool !DMA_COHERENT
184
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185source "init/Kconfig"
186
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700187source "kernel/Kconfig.freezer"
188
Linus Torvalds1da177e2005-04-16 15:20:36 -0700189menu "System type"
190
Paul Mundtb5f42db2007-11-08 18:38:14 +0900191#
192# Processor families
193#
194config CPU_SH2
195 bool
196
197config CPU_SH2A
198 bool
199 select CPU_SH2
200
201config CPU_SH3
202 bool
203 select CPU_HAS_INTEVT
204 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900205 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900206
207config CPU_SH4
208 bool
209 select CPU_HAS_INTEVT
210 select CPU_HAS_SR_RB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900211 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900212 select SYS_SUPPORTS_TMU
Paul Mundtffb4a732009-10-27 07:22:37 +0900213 select SYS_SUPPORTS_HUGETLBFS if MMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900214
215config CPU_SH4A
216 bool
217 select CPU_SH4
218
219config CPU_SH4AL_DSP
220 bool
221 select CPU_SH4A
222 select CPU_HAS_DSP
223
Paul Mundtea0e1a92007-11-21 15:58:01 +0900224config CPU_SH5
225 bool
226 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900227 select SYS_SUPPORTS_TMU
Paul Mundtffb4a732009-10-27 07:22:37 +0900228 select SYS_SUPPORTS_HUGETLBFS if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900229
Paul Mundtb5f42db2007-11-08 18:38:14 +0900230config CPU_SHX2
231 bool
232
233config CPU_SHX3
234 bool
Paul Mundt01be5d62009-10-27 10:35:02 +0900235 select DMA_COHERENT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900236
Paul Mundtdc65a972009-03-10 16:26:29 +0900237config ARCH_SHMOBILE
238 bool
Magnus Damm77594912009-03-13 15:23:04 +0000239 select ARCH_SUSPEND_POSSIBLE
Magnus Dammac2c5962009-08-19 10:31:53 +0000240 select PM
241 select PM_RUNTIME
Paul Mundtdc65a972009-03-10 16:26:29 +0900242
Paul Mundt3cc000b2009-04-11 08:39:27 +0900243if SUPERH32
244
Paul Mundtb5f42db2007-11-08 18:38:14 +0900245choice
246 prompt "Processor sub-type selection"
247
248#
249# Processor subtypes
250#
251
252# SH-2 Processor Support
253
254config CPU_SUBTYPE_SH7619
255 bool "Support SH7619 processor"
256 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900257 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900258
259# SH-2A Processor Support
260
Peter Griffin28259992008-11-28 22:48:20 +0900261config CPU_SUBTYPE_SH7201
262 bool "Support SH7201 processor"
263 select CPU_SH2A
264 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000265 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900266
Paul Mundt6d01f512007-11-26 18:17:21 +0900267config CPU_SUBTYPE_SH7203
268 bool "Support SH7203 processor"
269 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900270 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900271 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000272 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900273
Paul Mundtb5f42db2007-11-08 18:38:14 +0900274config CPU_SUBTYPE_SH7206
275 bool "Support SH7206 processor"
276 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900277 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000278 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900279
Paul Mundta8f67f42007-11-26 19:54:02 +0900280config CPU_SUBTYPE_SH7263
281 bool "Support SH7263 processor"
282 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900283 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900284 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000285 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900286
Paul Mundt2ad69902008-03-13 12:52:44 +0900287config CPU_SUBTYPE_MXG
288 bool "Support MX-G processor"
289 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000290 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900291 help
292 Select MX-G if running on an R8A03022BG part.
293
Paul Mundtb5f42db2007-11-08 18:38:14 +0900294# SH-3 Processor Support
295
296config CPU_SUBTYPE_SH7705
297 bool "Support SH7705 processor"
298 select CPU_SH3
299
300config CPU_SUBTYPE_SH7706
301 bool "Support SH7706 processor"
302 select CPU_SH3
303 help
304 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
305
306config CPU_SUBTYPE_SH7707
307 bool "Support SH7707 processor"
308 select CPU_SH3
309 help
310 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
311
312config CPU_SUBTYPE_SH7708
313 bool "Support SH7708 processor"
314 select CPU_SH3
315 help
316 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
317 if you have a 100 Mhz SH-3 HD6417708R CPU.
318
319config CPU_SUBTYPE_SH7709
320 bool "Support SH7709 processor"
321 select CPU_SH3
322 help
323 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
324
325config CPU_SUBTYPE_SH7710
326 bool "Support SH7710 processor"
327 select CPU_SH3
328 select CPU_HAS_DSP
329 help
330 Select SH7710 if you have a SH3-DSP SH7710 CPU.
331
332config CPU_SUBTYPE_SH7712
333 bool "Support SH7712 processor"
334 select CPU_SH3
335 select CPU_HAS_DSP
336 help
337 Select SH7712 if you have a SH3-DSP SH7712 CPU.
338
339config CPU_SUBTYPE_SH7720
340 bool "Support SH7720 processor"
341 select CPU_SH3
342 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000343 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900344 help
345 Select SH7720 if you have a SH3-DSP SH7720 CPU.
346
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900347config CPU_SUBTYPE_SH7721
348 bool "Support SH7721 processor"
349 select CPU_SH3
350 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000351 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900352 help
353 Select SH7721 if you have a SH3-DSP SH7721 CPU.
354
Paul Mundtb5f42db2007-11-08 18:38:14 +0900355# SH-4 Processor Support
356
357config CPU_SUBTYPE_SH7750
358 bool "Support SH7750 processor"
359 select CPU_SH4
360 help
361 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
362
363config CPU_SUBTYPE_SH7091
364 bool "Support SH7091 processor"
365 select CPU_SH4
366 help
367 Select SH7091 if you have an SH-4 based Sega device (such as
368 the Dreamcast, Naomi, and Naomi 2).
369
370config CPU_SUBTYPE_SH7750R
371 bool "Support SH7750R processor"
372 select CPU_SH4
373
374config CPU_SUBTYPE_SH7750S
375 bool "Support SH7750S processor"
376 select CPU_SH4
377
378config CPU_SUBTYPE_SH7751
379 bool "Support SH7751 processor"
380 select CPU_SH4
381 help
382 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
383 or if you have a HD6417751R CPU.
384
385config CPU_SUBTYPE_SH7751R
386 bool "Support SH7751R processor"
387 select CPU_SH4
388
389config CPU_SUBTYPE_SH7760
390 bool "Support SH7760 processor"
391 select CPU_SH4
392
393config CPU_SUBTYPE_SH4_202
394 bool "Support SH4-202 processor"
395 select CPU_SH4
396
397# SH-4A Processor Support
398
Paul Mundt178dd0c2008-04-09 17:56:18 +0900399config CPU_SUBTYPE_SH7723
400 bool "Support SH7723 processor"
401 select CPU_SH4A
402 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900403 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900404 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900405 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900406 help
407 Select SH7723 if you have an SH-MobileR2 CPU.
408
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900409config CPU_SUBTYPE_SH7724
410 bool "Support SH7724 processor"
411 select CPU_SH4A
412 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900413 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900414 select ARCH_SPARSEMEM_ENABLE
415 select SYS_SUPPORTS_CMT
416 help
417 Select SH7724 if you have an SH-MobileR2R CPU.
418
Yoshihiro Shimodac01f0f12009-08-21 16:30:28 +0900419config CPU_SUBTYPE_SH7757
420 bool "Support SH7757 processor"
421 select CPU_SH4A
422 select CPU_SHX2
423 help
424 Select SH7757 if you have a SH4A SH7757 CPU.
425
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900426config CPU_SUBTYPE_SH7763
427 bool "Support SH7763 processor"
428 select CPU_SH4A
429 help
430 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
431
Paul Mundtb5f42db2007-11-08 18:38:14 +0900432config CPU_SUBTYPE_SH7770
433 bool "Support SH7770 processor"
434 select CPU_SH4A
435
436config CPU_SUBTYPE_SH7780
437 bool "Support SH7780 processor"
438 select CPU_SH4A
439
440config CPU_SUBTYPE_SH7785
441 bool "Support SH7785 processor"
442 select CPU_SH4A
443 select CPU_SHX2
444 select ARCH_SPARSEMEM_ENABLE
445 select SYS_SUPPORTS_NUMA
446
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900447config CPU_SUBTYPE_SH7786
448 bool "Support SH7786 processor"
449 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900450 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900451 select CPU_HAS_PTEAEX
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900452 select ARCH_SPARSEMEM_ENABLE
453 select SYS_SUPPORTS_NUMA
Paul Mundt2eb2a432009-06-19 16:00:00 +0900454 select SYS_SUPPORTS_SMP
455 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900456
Paul Mundtb5f42db2007-11-08 18:38:14 +0900457config CPU_SUBTYPE_SHX3
458 bool "Support SH-X3 processor"
459 select CPU_SH4A
460 select CPU_SHX3
461 select ARCH_SPARSEMEM_ENABLE
462 select SYS_SUPPORTS_NUMA
463 select SYS_SUPPORTS_SMP
Paul Mundt58402632008-09-05 15:36:39 +0900464 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundtb5f42db2007-11-08 18:38:14 +0900465
466# SH4AL-DSP Processor Support
467
468config CPU_SUBTYPE_SH7343
469 bool "Support SH7343 processor"
470 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900471 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900472 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900473
474config CPU_SUBTYPE_SH7722
475 bool "Support SH7722 processor"
476 select CPU_SH4AL_DSP
477 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900478 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900479 select ARCH_SPARSEMEM_ENABLE
480 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900481 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900482
Magnus Damm9109a302008-02-08 17:31:24 +0900483config CPU_SUBTYPE_SH7366
484 bool "Support SH7366 processor"
485 select CPU_SH4AL_DSP
486 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900487 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900488 select ARCH_SPARSEMEM_ENABLE
489 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900490 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900491
Paul Mundt3cc000b2009-04-11 08:39:27 +0900492endchoice
493
494endif
495
496if SUPERH64
497
498choice
499 prompt "Processor sub-type selection"
500
Paul Mundtea0e1a92007-11-21 15:58:01 +0900501# SH-5 Processor Support
502
503config CPU_SUBTYPE_SH5_101
504 bool "Support SH5-101 processor"
505 select CPU_SH5
506
507config CPU_SUBTYPE_SH5_103
508 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900509 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900510
Paul Mundtb5f42db2007-11-08 18:38:14 +0900511endchoice
512
Paul Mundt3cc000b2009-04-11 08:39:27 +0900513endif
514
Paul Mundtcad82442006-01-16 22:14:19 -0800515source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900516
Paul Mundt4690bdc2007-11-09 13:45:42 +0900517source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800518
Paul Mundt939a24a2008-07-29 21:41:37 +0900519source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900520
Paul Mundt32351a22007-03-12 14:38:59 +0900521menu "Timer and clock configuration"
522
Magnus Damm9570ef22009-05-01 06:51:00 +0000523config SH_TIMER_TMU
524 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000525 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000526 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000527 help
528 This enables the build of the TMU timer driver.
529
Paul Mundtf5ad8812009-01-29 18:08:58 +0900530config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000531 bool "CMT timer driver"
532 depends on SYS_SUPPORTS_CMT
533 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000534 help
535 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900536
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000537config SH_TIMER_MTU2
538 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000539 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000540 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000541 help
542 This enables build of the MTU2 timer driver.
543
Paul Mundtcad82442006-01-16 22:14:19 -0800544config SH_PCLK_FREQ
545 int "Peripheral clock frequency (in Hz)"
Paul Mundt8152a742009-12-29 11:09:30 +0900546 depends on SH_CLK_CPG_LEGACY
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900547 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt8152a742009-12-29 11:09:30 +0900548 default "33333333" if CPU_SUBTYPE_SH7770 || \
549 CPU_SUBTYPE_SH7760 || \
550 CPU_SUBTYPE_SH7705 || \
551 CPU_SUBTYPE_SH7203 || \
552 CPU_SUBTYPE_SH7206 || \
553 CPU_SUBTYPE_SH7263 || \
Paul Mundt43a18392010-01-19 19:37:14 +0900554 CPU_SUBTYPE_MXG
Paul Mundt05627482007-05-15 16:25:47 +0900555 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800556 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900557 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800558 help
559 This option is used to specify the peripheral clock frequency.
560 This is necessary for determining the reference clock value on
561 platforms lacking an RTC.
562
Paul Mundt36aa1e32009-05-22 14:00:34 +0900563config SH_CLK_CPG
564 def_bool y
565
Paul Mundt253b0882009-05-13 17:38:11 +0900566config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900567 depends on SH_CLK_CPG
Paul Mundt43a18392010-01-19 19:37:14 +0900568 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE && \
569 !CPU_SUBTYPE_SH7786
Paul Mundt253b0882009-05-13 17:38:11 +0900570
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900571config SH_CLK_MD
572 int "CPU Mode Pin Setting"
Paul Mundt6d01f512007-11-26 18:17:21 +0900573 depends on CPU_SH2
Paul Mundt357d5942007-06-11 15:32:07 +0900574 default 6 if CPU_SUBTYPE_SH7206
575 default 5 if CPU_SUBTYPE_SH7619
576 default 0
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900577 help
Yoshinori Sato11cbb702006-12-07 18:07:27 +0900578 MD2 - MD0 pin setting.
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900579
Paul Mundt57be2b42007-05-09 17:33:24 +0900580source "kernel/time/Kconfig"
581
Paul Mundt32351a22007-03-12 14:38:59 +0900582endmenu
583
Paul Mundtcad82442006-01-16 22:14:19 -0800584menu "CPU Frequency scaling"
585
586source "drivers/cpufreq/Kconfig"
587
588config SH_CPU_FREQ
589 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900590 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800591 select CPU_FREQ_TABLE
592 help
Paul Mundt8a655052008-12-17 15:06:54 +0900593 This adds the cpufreq driver for SuperH. Any CPU that supports
594 clock rate rounding through the clock framework can use this
595 driver. While it will make the kernel slightly larger, this is
596 harmless for CPUs that don't support rate rounding. The driver
597 will also generate a notice in the boot log before disabling
598 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800599
600 For details, take a look at <file:Documentation/cpu-freq>.
601
602 If unsure, say N.
603
604endmenu
605
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900606source "arch/sh/drivers/Kconfig"
607
Paul Mundtcad82442006-01-16 22:14:19 -0800608endmenu
609
Paul Mundtcad82442006-01-16 22:14:19 -0800610menu "Kernel features"
611
Paul Mundt91b91d02006-09-27 18:08:33 +0900612source kernel/Kconfig.hz
613
Paul Mundtcad82442006-01-16 22:14:19 -0800614config KEXEC
615 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000616 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800617 help
618 kexec is a system call that implements the ability to shutdown your
619 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400620 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800621 you can start any kernel with it, not just Linux.
622
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400623 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800624
625 It is an ongoing process to be certain the hardware in a machine
626 is properly shutdown, so do not be surprised if this code does not
627 initially work for you. It may help to enable device hotplugging
628 support. As of this writing the exact hardware interface is
629 strongly in flux, so no good recommendation can be made.
630
Paul Mundt4d5ade52007-04-27 11:25:57 +0900631config CRASH_DUMP
632 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundt640f7482008-04-25 13:04:56 +0900633 depends on SUPERH32 && EXPERIMENTAL
Paul Mundt4d5ade52007-04-27 11:25:57 +0900634 help
635 Generate crash dump after being started by kexec.
636 This should be normally only set in special crash dump kernels
637 which are loaded in the main kernel with kexec-tools into
638 a specially reserved region and then later executed after
639 a crash by kdump/kexec. The crash dump kernel must be compiled
640 to a memory address not used by the main kernel using
641 MEMORY_START.
642
643 For more details see Documentation/kdump/kdump.txt
644
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000645config KEXEC_JUMP
646 bool "kexec jump (EXPERIMENTAL)"
647 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
648 help
649 Jump between original kernel and kexeced kernel and invoke
650 code via KEXEC
651
Paul Mundtc4637d42008-07-30 15:30:52 +0900652config SECCOMP
653 bool "Enable seccomp to safely compute untrusted bytecode"
654 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900655 help
656 This kernel feature is useful for number crunching applications
657 that may need to compute untrusted bytecode during their
658 execution. By using pipes or other transports made available to
659 the process as file descriptors supporting the read/write
660 syscalls, it's possible to isolate those applications in
661 their own address space using seccomp. Once seccomp is
662 enabled via prctl, it cannot be disabled and the task is only
663 allowed to execute a few safe syscalls defined by each seccomp
664 mode.
665
666 If unsure, say N.
667
Linus Torvalds1da177e2005-04-16 15:20:36 -0700668config SMP
669 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900670 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200671 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700672 ---help---
673 This enables support for systems with more than one CPU. If you have
674 a system with only one CPU, like most personal computers, say N. If
675 you have a system with more than one CPU, say Y.
676
677 If you say N here, the kernel will run on single and multiprocessor
678 machines, but will use only one CPU of a multiprocessor machine. If
679 you say Y here, the kernel will run on many, but not all,
680 singleprocessor machines. On a singleprocessor machine, the kernel
681 will run faster if you say N here.
682
683 People using multiprocessor machines who say Y here should also say
684 Y to "Enhanced Real Time Clock Support", below.
685
Adrian Bunk03502fa2008-02-03 15:50:21 +0200686 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
687 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700688
689 If you don't know what to do here, say N.
690
691config NR_CPUS
692 int "Maximum number of CPUs (2-32)"
693 range 2 32
694 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900695 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700696 default "2"
697 help
698 This allows you to specify the maximum number of CPUs which this
699 kernel will support. The maximum supported value is 32 and the
700 minimum value which makes sense is 2.
701
702 This is purely to save memory - each supported CPU adds
703 approximately eight kilobytes to the kernel image.
704
Paul Mundt91b91d02006-09-27 18:08:33 +0900705source "kernel/Kconfig.preempt"
706
Paul Mundt83662462007-09-28 16:04:49 +0900707config GUSA
708 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900709 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900710 help
711 This enables support for gUSA (general UserSpace Atomicity).
712 This is the default implementation for both UP and non-ll/sc
713 CPUs, and is used by the libc, amongst others.
714
715 For additional information, design information can be found
716 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
717
718 This should only be disabled for special cases where alternate
719 atomicity implementations exist.
720
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900721config GUSA_RB
722 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
723 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
724 help
725 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100726 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900727 store-conditional (LLSC). On machines which do not have hardware
728 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100729 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900730
Paul Mundt54ff3282009-06-11 10:33:09 +0300731config SPARSE_IRQ
Paul Mundtee2760e2010-01-12 13:48:27 +0900732 def_bool y
733 depends on SUPERH32 && !SH_DREAMCAST && !SH_HIGHLANDER && \
Paul Mundtc7a96722010-02-02 17:38:04 +0900734 !SH_RTS7751R2D && !HD64461
Paul Mundt54ff3282009-06-11 10:33:09 +0300735 help
736 This enables support for sparse irqs. This is useful in general
737 as most CPUs have a fairly sparse array of IRQ vectors, which
738 the irq_desc then maps directly on to. Systems with a high
739 number of off-chip IRQs will want to treat this as
740 experimental until they have been independently verified.
741
742 If you don't know what to do here, say N.
743
Paul Mundtcad82442006-01-16 22:14:19 -0800744endmenu
745
746menu "Boot options"
747
748config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900749 hex
750 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
751 SH_7751_SOLUTION_ENGINE
752 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900753 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800754 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700755 help
Paul Mundtcad82442006-01-16 22:14:19 -0800756 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700757
Paul Mundtcad82442006-01-16 22:14:19 -0800758config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900759 hex
760 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900761 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900762 default "0x00810000" if SH_7780_SOLUTION_ENGINE
763 default "0x009e0000" if SH_TITAN
764 default "0x01800000" if SH_SDK7780
765 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800766 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700767 help
Paul Mundtcad82442006-01-16 22:14:19 -0800768 This option allows you to set the link address offset of the zImage.
769 This can be useful if you are on a board which has a small amount of
770 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700771
Paul Mundtb412a49a2009-05-10 01:23:25 +0900772config ENTRY_OFFSET
773 hex
774 default "0x00001000" if PAGE_SIZE_4KB
775 default "0x00002000" if PAGE_SIZE_8KB
776 default "0x00004000" if PAGE_SIZE_16KB
777 default "0x00010000" if PAGE_SIZE_64KB
778 default "0x00000000"
779
Pawel Molld724a9c2009-08-24 16:25:38 +0900780choice
781 prompt "Kernel command line"
782 optional
783 default CMDLINE_OVERWRITE
784 help
785 Setting this option allows the kernel command line arguments
786 to be set.
787
788config CMDLINE_OVERWRITE
789 bool "Overwrite bootloader kernel arguments"
790 help
791 Given string will overwrite any arguments passed in by
792 a bootloader.
793
794config CMDLINE_EXTEND
795 bool "Extend bootloader kernel arguments"
796 help
797 Given string will be concatenated with arguments passed in
798 by a bootloader.
799
800endchoice
Linus Torvalds1da177e2005-04-16 15:20:36 -0700801
Paul Mundtcad82442006-01-16 22:14:19 -0800802config CMDLINE
Pawel Molld724a9c2009-08-24 16:25:38 +0900803 string "Kernel command line arguments string"
804 depends on CMDLINE_OVERWRITE || CMDLINE_EXTEND
Paul Mundtcad82442006-01-16 22:14:19 -0800805 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700806
807endmenu
808
Paul Mundtcad82442006-01-16 22:14:19 -0800809menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700810
Paul Mundtcad82442006-01-16 22:14:19 -0800811config SUPERHYWAY
812 tristate "SuperHyway Bus support"
813 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900815config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900816 bool "Maple Bus support"
817 depends on SH_DREAMCAST
818 help
819 The Maple Bus is SEGA's serial communication bus for peripherals
820 on the Dreamcast. Without this bus support you won't be able to
821 get your Dreamcast keyboard etc to work, so most users
822 probably want to say 'Y' here, unless you are only using the
823 Dreamcast with a serial line terminal or a remote network
824 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900825
Paul Mundt76934652009-10-27 10:36:55 +0900826config PCI
827 bool "PCI support"
828 depends on SYS_SUPPORTS_PCI
Paul Mundt320e68d2010-01-29 22:38:13 +0900829 select PCI_DOMAINS
Paul Mundt76934652009-10-27 10:36:55 +0900830 help
831 Find out whether you have a PCI motherboard. PCI is the name of a
832 bus system, i.e. the way the CPU talks to the other stuff inside
833 your box. If you have PCI, say Y, otherwise N.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700834
Paul Mundt320e68d2010-01-29 22:38:13 +0900835config PCI_DOMAINS
836 bool
837
Paul Mundte16038a2009-01-09 15:12:30 +0900838source "drivers/pci/pcie/Kconfig"
839
Linus Torvalds1da177e2005-04-16 15:20:36 -0700840source "drivers/pci/Kconfig"
841
842source "drivers/pcmcia/Kconfig"
843
844source "drivers/pci/hotplug/Kconfig"
845
846endmenu
847
848menu "Executable file formats"
849
850source "fs/Kconfig.binfmt"
851
852endmenu
853
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900854menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900855depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100856
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900857source "kernel/power/Kconfig"
858
859source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900860
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900861endmenu
862
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700863source "net/Kconfig"
864
Linus Torvalds1da177e2005-04-16 15:20:36 -0700865source "drivers/Kconfig"
866
867source "fs/Kconfig"
868
Linus Torvalds1da177e2005-04-16 15:20:36 -0700869source "arch/sh/Kconfig.debug"
870
871source "security/Kconfig"
872
873source "crypto/Kconfig"
874
875source "lib/Kconfig"