]> git.proxmox.com Git - mirror_ubuntu-disco-kernel.git/blame - arch/sh/Kconfig
License cleanup: add SPDX GPL-2.0 license identifier to files with no license
[mirror_ubuntu-disco-kernel.git] / arch / sh / Kconfig
CommitLineData
b2441318 1# SPDX-License-Identifier: GPL-2.0
1da177e4 2config SUPERH
ea0e1a9a 3 def_bool y
45624ac3 4 select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
09d8dd93 5 select ARCH_MIGHT_HAVE_PC_PARPORT
07c75d7a 6 select ARCH_NO_COHERENT_DMA_MMAP if !MMU
560b8c0e 7 select HAVE_PATA_PLATFORM
6d803ba7 8 select CLKDEV_LOOKUP
ce816fa8 9 select HAVE_IDE if HAS_IOPORT_MAP
95f72d1e 10 select HAVE_MEMBLOCK
534cfbee 11 select HAVE_MEMBLOCK_NODE_MAP
adaf7fd2 12 select ARCH_DISCARD_MEMBLOCK
42d4b839 13 select HAVE_OPROFILE
9de90ac2 14 select HAVE_GENERIC_DMA_COHERENT
d7b01f78 15 select HAVE_ARCH_TRACEHOOK
f802d969 16 select HAVE_DMA_API_DEBUG
cdd6c482 17 select HAVE_PERF_EVENTS
9b2a60c4 18 select HAVE_DEBUG_BUGVERBOSE
7563bbf8 19 select ARCH_HAVE_CUSTOM_GPIO_H
df013ffb 20 select ARCH_HAVE_NMI_SAFE_CMPXCHG if (GUSA_RB || CPU_SH4A)
957e3fac 21 select ARCH_HAS_GCOV_PROFILE_ALL
72f0c137 22 select PERF_USE_VMALLOC
b69ec42b 23 select HAVE_DEBUG_KMEMLEAK
df8ce259 24 select HAVE_KERNEL_GZIP
fff7fb0b 25 select CPU_NO_EFFICIENT_FFS
07e88e1b
PM
26 select HAVE_KERNEL_BZIP2
27 select HAVE_KERNEL_LZMA
50cfa79d 28 select HAVE_KERNEL_XZ
c7b16efb 29 select HAVE_KERNEL_LZO
af1839eb 30 select HAVE_UID16
c1d7e01d 31 select ARCH_WANT_IPC_PARSE_VERSION
a74f7e04 32 select HAVE_SYSCALL_TRACEPOINTS
eaaaeef3 33 select HAVE_REGS_AND_STACK_ACCESS_API
2ed86b16 34 select MAY_HAVE_SPARSE_IRQ
ed170924 35 select IRQ_FORCED_THREADING
6eac1af0 36 select RTC_LIB
f01789c6 37 select GENERIC_ATOMIC64
3d44ae40 38 select GENERIC_IRQ_SHOW
ea0588cb 39 select GENERIC_SMP_IDLE_THREAD
dc775dd8 40 select GENERIC_IDLE_POLL_SETUP
8cf200d8
AMG
41 select GENERIC_CLOCKEVENTS
42 select GENERIC_CMOS_UPDATE if SH_SH03 || SH_DREAMCAST
b46ed370 43 select GENERIC_SCHED_CLOCK
0e100e11 44 select GENERIC_STRNCPY_FROM_USER
cba8df4b 45 select GENERIC_STRNLEN_USER
786d35d4
DH
46 select HAVE_MOD_ARCH_SPECIFIC if DWARF_UNWINDER
47 select MODULES_USE_ELF_RELA
881e252d 48 select OLD_SIGSUSPEND
0679a858 49 select OLD_SIGACTION
7a017721 50 select HAVE_ARCH_AUDITSYSCALL
72cc564f 51 select HAVE_FUTEX_CMPXCHG if FUTEX
42a0bb3f 52 select HAVE_NMI
1da177e4
LT
53 help
54 The SuperH is a RISC processor targeted for use in embedded systems
55 and consumer electronics; it was also used in the Sega Dreamcast
56 gaming console. The SuperH port has a home page at
57 <http://www.linux-sh.org/>.
58
39d28a2d 59config SUPERH32
3cc000b5 60 def_bool ARCH = "sh"
d39f5450
CS
61 select HAVE_KPROBES
62 select HAVE_KRETPROBES
6d63e73d 63 select HAVE_IOREMAP_PROT if MMU && !X2TLB
694f94f2 64 select HAVE_FUNCTION_TRACER
fad57feb
MF
65 select HAVE_FTRACE_MCOUNT_RECORD
66 select HAVE_DYNAMIC_FTRACE
e4b053d9 67 select HAVE_FTRACE_NMI_ENTER if DYNAMIC_FTRACE
c1d7e01d 68 select ARCH_WANT_IPC_PARSE_VERSION
327933f5 69 select HAVE_FUNCTION_GRAPH_TRACER
ab6e570b 70 select HAVE_ARCH_KGDB
6fbfe8d7 71 select HAVE_HW_BREAKPOINT
0102752e 72 select HAVE_MIXED_BREAKPOINTS_REGS
e583d6b3 73 select PERF_EVENTS
8dafc346 74 select ARCH_HIBERNATION_POSSIBLE if MMU
57b81330 75 select SPARSE_IRQ
19952a92 76 select HAVE_CC_STACKPROTECTOR
ea0e1a9a
PM
77
78config SUPERH64
3cc000b5 79 def_bool ARCH = "sh64"
5f56a5df 80 select HAVE_EXIT_THREAD
3a898c0f 81 select KALLSYMS
39d28a2d 82
f42b7e3d
PM
83config ARCH_DEFCONFIG
84 string
85 default "arch/sh/configs/shx3_defconfig" if SUPERH32
86 default "arch/sh/configs/cayman_defconfig" if SUPERH64
87
1da177e4 88config RWSEM_GENERIC_SPINLOCK
d7ef4fb3 89 def_bool y
1da177e4
LT
90
91config RWSEM_XCHGADD_ALGORITHM
92 bool
93
fa691511
PM
94config GENERIC_BUG
95 def_bool y
a82d53ec 96 depends on BUG && SUPERH32
fa691511 97
3767f3f1
PM
98config GENERIC_CSUM
99 def_bool y
100 depends on SUPERH64
101
e2268c71 102config GENERIC_HWEIGHT
d7ef4fb3 103 def_bool y
e2268c71 104
1da177e4 105config GENERIC_CALIBRATE_DELAY
cf204fa7 106 bool
1da177e4 107
bdcab87b
PM
108config GENERIC_LOCKBREAK
109 def_bool y
110 depends on SMP && PREEMPT
111
af998a9a
MD
112config ARCH_SUSPEND_POSSIBLE
113 def_bool n
114
115config ARCH_HIBERNATION_POSSIBLE
116 def_bool n
357d5946 117
0a9b0db1
PM
118config SYS_SUPPORTS_APM_EMULATION
119 bool
af998a9a 120 select ARCH_SUSPEND_POSSIBLE
357d5946 121
ffb4a73d
PM
122config SYS_SUPPORTS_HUGETLBFS
123 bool
124
357d5946
PM
125config SYS_SUPPORTS_SMP
126 bool
127
128config SYS_SUPPORTS_NUMA
129 bool
130
131config SYS_SUPPORTS_PCI
132 bool
0a9b0db1 133
afbfb52e 134config STACKTRACE_SUPPORT
d7ef4fb3 135 def_bool y
afbfb52e
PM
136
137config LOCKDEP_SUPPORT
d7ef4fb3 138 def_bool y
afbfb52e 139
f0d1b0b3 140config ARCH_HAS_ILOG2_U32
d7ef4fb3 141 def_bool n
f0d1b0b3
DH
142
143config ARCH_HAS_ILOG2_U64
d7ef4fb3 144 def_bool n
f0d1b0b3 145
ce816fa8 146config NO_IOPORT_MAP
37b7a978 147 def_bool !PCI
c30b9c43
PM
148 depends on !SH_CAYMAN && !SH_SH4202_MICRODEV && !SH_SHMIN && \
149 !SH_HP6XX && !SH_SOLUTION_ENGINE
86e4dd5a 150
e7cc9a73
MD
151config IO_TRAPPED
152 bool
153
b7e68d68
PM
154config SWAP_IO_SPACE
155 bool
156
01be5d63
PM
157config DMA_COHERENT
158 bool
159
160config DMA_NONCOHERENT
161 def_bool !DMA_COHERENT
162
5cabbb62
FT
163config NEED_DMA_MAP_STATE
164 def_bool DMA_NONCOHERENT
165
18e98307
FT
166config NEED_SG_DMA_LENGTH
167 def_bool y
168
69543d63
KS
169config PGTABLE_LEVELS
170 default 3 if X2TLB
171 default 2
172
1da177e4
LT
173source "init/Kconfig"
174
dc52ddc0
MH
175source "kernel/Kconfig.freezer"
176
1da177e4
LT
177menu "System type"
178
b5f42db0
PM
179#
180# Processor families
181#
182config CPU_SH2
183 bool
049d2804 184 select SH_INTC
b5f42db0
PM
185
186config CPU_SH2A
187 bool
188 select CPU_SH2
e2fcf74f 189 select UNCACHED_MAPPING
b5f42db0 190
5a846aba
RF
191config CPU_J2
192 bool
193 select CPU_SH2
194 select OF
195 select OF_EARLY_FLATTREE
196
b5f42db0
PM
197config CPU_SH3
198 bool
199 select CPU_HAS_INTEVT
200 select CPU_HAS_SR_RB
049d2804 201 select SH_INTC
fbfa8934 202 select SYS_SUPPORTS_SH_TMU
b5f42db0
PM
203
204config CPU_SH4
205 bool
206 select CPU_HAS_INTEVT
207 select CPU_HAS_SR_RB
b5f42db0 208 select CPU_HAS_FPU if !CPU_SH4AL_DSP
049d2804 209 select SH_INTC
fbfa8934 210 select SYS_SUPPORTS_SH_TMU
ffb4a73d 211 select SYS_SUPPORTS_HUGETLBFS if MMU
b5f42db0
PM
212
213config CPU_SH4A
214 bool
215 select CPU_SH4
216
217config CPU_SH4AL_DSP
218 bool
219 select CPU_SH4A
220 select CPU_HAS_DSP
221
ea0e1a9a
PM
222config CPU_SH5
223 bool
224 select CPU_HAS_FPU
fbfa8934 225 select SYS_SUPPORTS_SH_TMU
ffb4a73d 226 select SYS_SUPPORTS_HUGETLBFS if MMU
ea0e1a9a 227
b5f42db0
PM
228config CPU_SHX2
229 bool
230
231config CPU_SHX3
232 bool
01be5d63 233 select DMA_COHERENT
4b478ee2
PM
234 select SYS_SUPPORTS_SMP
235 select SYS_SUPPORTS_NUMA
b5f42db0 236
dc65a977
PM
237config ARCH_SHMOBILE
238 bool
77594912 239 select ARCH_SUSPEND_POSSIBLE
464ed18e 240 select PM
dc65a977 241
86c8c047
MF
242config CPU_HAS_PMU
243 depends on CPU_SH4 || CPU_SH4A
244 default y
245 bool
246
3cc000b5
PM
247if SUPERH32
248
b5f42db0
PM
249choice
250 prompt "Processor sub-type selection"
251
252#
253# Processor subtypes
254#
255
256# SH-2 Processor Support
257
258config CPU_SUBTYPE_SH7619
259 bool "Support SH7619 processor"
260 select CPU_SH2
fbfa8934 261 select SYS_SUPPORTS_SH_CMT
b5f42db0 262
5a846aba
RF
263config CPU_SUBTYPE_J2
264 bool "Support J2 processor"
265 select CPU_J2
b4214e41
RF
266 select SYS_SUPPORTS_SMP
267 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
5a846aba 268
b5f42db0
PM
269# SH-2A Processor Support
270
2825999e
PG
271config CPU_SUBTYPE_SH7201
272 bool "Support SH7201 processor"
273 select CPU_SH2A
274 select CPU_HAS_FPU
fbfa8934 275 select SYS_SUPPORTS_SH_MTU2
2825999e 276
6d01f510
PM
277config CPU_SUBTYPE_SH7203
278 bool "Support SH7203 processor"
279 select CPU_SH2A
74d99a5e 280 select CPU_HAS_FPU
fbfa8934
MD
281 select SYS_SUPPORTS_SH_CMT
282 select SYS_SUPPORTS_SH_MTU2
b768ecbc 283 select PINCTRL
6d01f510 284
b5f42db0
PM
285config CPU_SUBTYPE_SH7206
286 bool "Support SH7206 processor"
287 select CPU_SH2A
fbfa8934
MD
288 select SYS_SUPPORTS_SH_CMT
289 select SYS_SUPPORTS_SH_MTU2
b5f42db0 290
a8f67f4b
PM
291config CPU_SUBTYPE_SH7263
292 bool "Support SH7263 processor"
293 select CPU_SH2A
74d99a5e 294 select CPU_HAS_FPU
fbfa8934
MD
295 select SYS_SUPPORTS_SH_CMT
296 select SYS_SUPPORTS_SH_MTU2
a8f67f4b 297
51ce3068
PE
298config CPU_SUBTYPE_SH7264
299 bool "Support SH7264 processor"
300 select CPU_SH2A
301 select CPU_HAS_FPU
fbfa8934
MD
302 select SYS_SUPPORTS_SH_CMT
303 select SYS_SUPPORTS_SH_MTU2
5946e7bb 304 select PINCTRL
51ce3068 305
0b25b7c8
PE
306config CPU_SUBTYPE_SH7269
307 bool "Support SH7269 processor"
308 select CPU_SH2A
309 select CPU_HAS_FPU
fbfa8934
MD
310 select SYS_SUPPORTS_SH_CMT
311 select SYS_SUPPORTS_SH_MTU2
fb872fcc 312 select PINCTRL
0b25b7c8 313
2ad69908
PM
314config CPU_SUBTYPE_MXG
315 bool "Support MX-G processor"
316 select CPU_SH2A
fbfa8934 317 select SYS_SUPPORTS_SH_MTU2
2ad69908
PM
318 help
319 Select MX-G if running on an R8A03022BG part.
320
b5f42db0
PM
321# SH-3 Processor Support
322
323config CPU_SUBTYPE_SH7705
324 bool "Support SH7705 processor"
325 select CPU_SH3
326
327config CPU_SUBTYPE_SH7706
328 bool "Support SH7706 processor"
329 select CPU_SH3
330 help
331 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
332
333config CPU_SUBTYPE_SH7707
334 bool "Support SH7707 processor"
335 select CPU_SH3
336 help
337 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
338
339config CPU_SUBTYPE_SH7708
340 bool "Support SH7708 processor"
341 select CPU_SH3
342 help
343 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
344 if you have a 100 Mhz SH-3 HD6417708R CPU.
345
346config CPU_SUBTYPE_SH7709
347 bool "Support SH7709 processor"
348 select CPU_SH3
349 help
350 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
351
352config CPU_SUBTYPE_SH7710
353 bool "Support SH7710 processor"
354 select CPU_SH3
355 select CPU_HAS_DSP
356 help
357 Select SH7710 if you have a SH3-DSP SH7710 CPU.
358
359config CPU_SUBTYPE_SH7712
360 bool "Support SH7712 processor"
361 select CPU_SH3
362 select CPU_HAS_DSP
363 help
364 Select SH7712 if you have a SH3-DSP SH7712 CPU.
365
366config CPU_SUBTYPE_SH7720
367 bool "Support SH7720 processor"
368 select CPU_SH3
369 select CPU_HAS_DSP
fbfa8934 370 select SYS_SUPPORTS_SH_CMT
7b61ca5d 371 select USB_OHCI_SH if USB_OHCI_HCD
85db6bff 372 select PINCTRL
b5f42db0
PM
373 help
374 Select SH7720 if you have a SH3-DSP SH7720 CPU.
375
31a49c4b
YS
376config CPU_SUBTYPE_SH7721
377 bool "Support SH7721 processor"
378 select CPU_SH3
379 select CPU_HAS_DSP
fbfa8934 380 select SYS_SUPPORTS_SH_CMT
7b61ca5d 381 select USB_OHCI_SH if USB_OHCI_HCD
31a49c4b
YS
382 help
383 Select SH7721 if you have a SH3-DSP SH7721 CPU.
384
b5f42db0
PM
385# SH-4 Processor Support
386
387config CPU_SUBTYPE_SH7750
388 bool "Support SH7750 processor"
389 select CPU_SH4
390 help
391 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
392
393config CPU_SUBTYPE_SH7091
394 bool "Support SH7091 processor"
395 select CPU_SH4
396 help
397 Select SH7091 if you have an SH-4 based Sega device (such as
398 the Dreamcast, Naomi, and Naomi 2).
399
400config CPU_SUBTYPE_SH7750R
401 bool "Support SH7750R processor"
402 select CPU_SH4
403
404config CPU_SUBTYPE_SH7750S
405 bool "Support SH7750S processor"
406 select CPU_SH4
407
408config CPU_SUBTYPE_SH7751
409 bool "Support SH7751 processor"
410 select CPU_SH4
411 help
412 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
413 or if you have a HD6417751R CPU.
414
415config CPU_SUBTYPE_SH7751R
416 bool "Support SH7751R processor"
417 select CPU_SH4
418
419config CPU_SUBTYPE_SH7760
420 bool "Support SH7760 processor"
421 select CPU_SH4
422
423config CPU_SUBTYPE_SH4_202
424 bool "Support SH4-202 processor"
425 select CPU_SH4
426
427# SH-4A Processor Support
428
178dd0cd
PM
429config CPU_SUBTYPE_SH7723
430 bool "Support SH7723 processor"
431 select CPU_SH4A
432 select CPU_SHX2
dc65a977 433 select ARCH_SHMOBILE
178dd0cd 434 select ARCH_SPARSEMEM_ENABLE
fbfa8934 435 select SYS_SUPPORTS_SH_CMT
16941a89 436 select PINCTRL
178dd0cd
PM
437 help
438 Select SH7723 if you have an SH-MobileR2 CPU.
439
0207a2ef
KM
440config CPU_SUBTYPE_SH7724
441 bool "Support SH7724 processor"
442 select CPU_SH4A
443 select CPU_SHX2
59fe700d 444 select ARCH_SHMOBILE
0207a2ef 445 select ARCH_SPARSEMEM_ENABLE
fbfa8934 446 select SYS_SUPPORTS_SH_CMT
18ebd228 447 select PINCTRL
0207a2ef
KM
448 help
449 Select SH7724 if you have an SH-MobileR2R CPU.
450
fea88a0c
NI
451config CPU_SUBTYPE_SH7734
452 bool "Support SH7734 processor"
453 select CPU_SH4A
454 select CPU_SHX2
2c172182 455 select PINCTRL
fea88a0c
NI
456 help
457 Select SH7734 if you have a SH4A SH7734 CPU.
458
c01f0f1a
YS
459config CPU_SUBTYPE_SH7757
460 bool "Support SH7757 processor"
461 select CPU_SH4A
462 select CPU_SHX2
eb61b772 463 select PINCTRL
c01f0f1a
YS
464 help
465 Select SH7757 if you have a SH4A SH7757 CPU.
466
7d740a06
YS
467config CPU_SUBTYPE_SH7763
468 bool "Support SH7763 processor"
469 select CPU_SH4A
7b61ca5d 470 select USB_OHCI_SH if USB_OHCI_HCD
7d740a06
YS
471 help
472 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
473
b5f42db0
PM
474config CPU_SUBTYPE_SH7770
475 bool "Support SH7770 processor"
476 select CPU_SH4A
477
478config CPU_SUBTYPE_SH7780
479 bool "Support SH7780 processor"
480 select CPU_SH4A
481
482config CPU_SUBTYPE_SH7785
483 bool "Support SH7785 processor"
484 select CPU_SH4A
485 select CPU_SHX2
55ba99eb
KM
486 select ARCH_SPARSEMEM_ENABLE
487 select SYS_SUPPORTS_NUMA
77bd27b2 488 select PINCTRL
55ba99eb
KM
489
490config CPU_SUBTYPE_SH7786
491 bool "Support SH7786 processor"
492 select CPU_SH4A
37042fbd 493 select CPU_SHX3
8263a67e 494 select CPU_HAS_PTEAEX
2eb2a436 495 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
7b61ca5d 496 select USB_OHCI_SH if USB_OHCI_HCD
7b61ca5d 497 select USB_EHCI_SH if USB_EHCI_HCD
c0fdbff9 498 select PINCTRL
b5f42db0
PM
499
500config CPU_SUBTYPE_SHX3
501 bool "Support SH-X3 processor"
502 select CPU_SH4A
503 select CPU_SHX3
5840263e 504 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
fdcfdfa1 505 select GPIOLIB
3e347f08 506 select PINCTRL
b5f42db0
PM
507
508# SH4AL-DSP Processor Support
509
510config CPU_SUBTYPE_SH7343
511 bool "Support SH7343 processor"
512 select CPU_SH4AL_DSP
dc65a977 513 select ARCH_SHMOBILE
fbfa8934 514 select SYS_SUPPORTS_SH_CMT
b5f42db0
PM
515
516config CPU_SUBTYPE_SH7722
517 bool "Support SH7722 processor"
518 select CPU_SH4AL_DSP
519 select CPU_SHX2
dc65a977 520 select ARCH_SHMOBILE
b5f42db0
PM
521 select ARCH_SPARSEMEM_ENABLE
522 select SYS_SUPPORTS_NUMA
fbfa8934 523 select SYS_SUPPORTS_SH_CMT
ef97c3c1 524 select PINCTRL
9109a30e
MD
525
526config CPU_SUBTYPE_SH7366
527 bool "Support SH7366 processor"
528 select CPU_SH4AL_DSP
529 select CPU_SHX2
dc65a977 530 select ARCH_SHMOBILE
9109a30e
MD
531 select ARCH_SPARSEMEM_ENABLE
532 select SYS_SUPPORTS_NUMA
fbfa8934 533 select SYS_SUPPORTS_SH_CMT
b5f42db0 534
3cc000b5
PM
535endchoice
536
537endif
538
539if SUPERH64
540
541choice
542 prompt "Processor sub-type selection"
543
ea0e1a9a
PM
544# SH-5 Processor Support
545
546config CPU_SUBTYPE_SH5_101
547 bool "Support SH5-101 processor"
548 select CPU_SH5
549
550config CPU_SUBTYPE_SH5_103
551 bool "Support SH5-103 processor"
8ef97dd7 552 select CPU_SH5
ea0e1a9a 553
b5f42db0
PM
554endchoice
555
3cc000b5
PM
556endif
557
f3d22298 558source "arch/sh/mm/Kconfig"
939a24a6 559
4690bdc7 560source "arch/sh/Kconfig.cpu"
f3d22298 561
939a24a6 562source "arch/sh/boards/Kconfig"
32351a28 563
32351a28
PM
564menu "Timer and clock configuration"
565
cad82448
PM
566config SH_PCLK_FREQ
567 int "Peripheral clock frequency (in Hz)"
8152a74b 568 depends on SH_CLK_CPG_LEGACY
9d4436a6 569 default "31250000" if CPU_SUBTYPE_SH7619
8152a74b
PM
570 default "33333333" if CPU_SUBTYPE_SH7770 || \
571 CPU_SUBTYPE_SH7760 || \
572 CPU_SUBTYPE_SH7705 || \
573 CPU_SUBTYPE_SH7203 || \
574 CPU_SUBTYPE_SH7206 || \
575 CPU_SUBTYPE_SH7263 || \
43a1839c 576 CPU_SUBTYPE_MXG
05627486 577 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
cad82448 578 default "66000000" if CPU_SUBTYPE_SH4_202
05627486 579 default "50000000"
1da177e4 580 help
cad82448
PM
581 This option is used to specify the peripheral clock frequency.
582 This is necessary for determining the reference clock value on
583 platforms lacking an RTC.
1da177e4 584
36aa1e32
PM
585config SH_CLK_CPG
586 def_bool y
587
253b0887 588config SH_CLK_CPG_LEGACY
36aa1e32 589 depends on SH_CLK_CPG
43a1839c 590 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE && \
51ce3068 591 !CPU_SHX3 && !CPU_SUBTYPE_SH7757 && \
bcb86e0a
PM
592 !CPU_SUBTYPE_SH7734 && !CPU_SUBTYPE_SH7264 && \
593 !CPU_SUBTYPE_SH7269
253b0887 594
32351a28
PM
595endmenu
596
cad82448 597menu "CPU Frequency scaling"
cad82448 598source "drivers/cpufreq/Kconfig"
cad82448
PM
599endmenu
600
9f5e8eee
PM
601source "arch/sh/drivers/Kconfig"
602
cad82448 603endmenu
1da177e4 604
cad82448
PM
605menu "Kernel features"
606
91b91d01
PM
607source kernel/Kconfig.hz
608
cad82448
PM
609config KEXEC
610 bool "kexec system call (EXPERIMENTAL)"
0d57af1e 611 depends on SUPERH32 && MMU
2965faa5 612 select KEXEC_CORE
1da177e4 613 help
cad82448
PM
614 kexec is a system call that implements the ability to shutdown your
615 current kernel, and to start another kernel. It is like a reboot
1f1332f7 616 but it is independent of the system firmware. And like a reboot
cad82448
PM
617 you can start any kernel with it, not just Linux.
618
1f1332f7 619 The name comes from the similarity to the exec system call.
cad82448
PM
620
621 It is an ongoing process to be certain the hardware in a machine
622 is properly shutdown, so do not be surprised if this code does not
bf220695
GU
623 initially work for you. As of this writing the exact hardware
624 interface is strongly in flux, so no good recommendation can be
625 made.
cad82448 626
4d5ade5b
PM
627config CRASH_DUMP
628 bool "kernel crash dumps (EXPERIMENTAL)"
0d57af1e 629 depends on SUPERH32 && BROKEN_ON_SMP
4d5ade5b
PM
630 help
631 Generate crash dump after being started by kexec.
632 This should be normally only set in special crash dump kernels
633 which are loaded in the main kernel with kexec-tools into
634 a specially reserved region and then later executed after
635 a crash by kdump/kexec. The crash dump kernel must be compiled
636 to a memory address not used by the main kernel using
e66ac3f2 637 PHYSICAL_START.
4d5ade5b
PM
638
639 For more details see Documentation/kdump/kdump.txt
640
b7cf6ddc
MD
641config KEXEC_JUMP
642 bool "kexec jump (EXPERIMENTAL)"
0d57af1e 643 depends on SUPERH32 && KEXEC && HIBERNATION
b7cf6ddc
MD
644 help
645 Jump between original kernel and kexeced kernel and invoke
646 code via KEXEC
647
e66ac3f2
SH
648config PHYSICAL_START
649 hex "Physical address where the kernel is loaded" if (EXPERT || CRASH_DUMP)
650 default MEMORY_START
651 ---help---
652 This gives the physical address where the kernel is loaded
653 and is ordinarily the same as MEMORY_START.
654
655 Different values are primarily used in the case of kexec on panic
656 where the fail safe kernel needs to run at a different address
657 than the panic-ed kernel.
658
c4637d47
PM
659config SECCOMP
660 bool "Enable seccomp to safely compute untrusted bytecode"
661 depends on PROC_FS
c4637d47
PM
662 help
663 This kernel feature is useful for number crunching applications
664 that may need to compute untrusted bytecode during their
665 execution. By using pipes or other transports made available to
666 the process as file descriptors supporting the read/write
667 syscalls, it's possible to isolate those applications in
668 their own address space using seccomp. Once seccomp is
669 enabled via prctl, it cannot be disabled and the task is only
670 allowed to execute a few safe syscalls defined by each seccomp
671 mode.
672
673 If unsure, say N.
674
1da177e4
LT
675config SMP
676 bool "Symmetric multi-processing support"
357d5946 677 depends on SYS_SUPPORTS_SMP
1da177e4
LT
678 ---help---
679 This enables support for systems with more than one CPU. If you have
4a474157
RG
680 a system with only one CPU, say N. If you have a system with more
681 than one CPU, say Y.
1da177e4 682
4a474157 683 If you say N here, the kernel will run on uni- and multiprocessor
1da177e4
LT
684 machines, but will use only one CPU of a multiprocessor machine. If
685 you say Y here, the kernel will run on many, but not all,
4a474157 686 uniprocessor machines. On a uniprocessor machine, the kernel
1da177e4
LT
687 will run faster if you say N here.
688
689 People using multiprocessor machines who say Y here should also say
690 Y to "Enhanced Real Time Clock Support", below.
691
03502faa
AB
692 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
693 available at <http://www.tldp.org/docs.html#howto>.
1da177e4
LT
694
695 If you don't know what to do here, say N.
696
697config NR_CPUS
698 int "Maximum number of CPUs (2-32)"
699 range 2 32
700 depends on SMP
2eb2a436 701 default "4" if CPU_SUBTYPE_SHX3
1da177e4
LT
702 default "2"
703 help
704 This allows you to specify the maximum number of CPUs which this
705 kernel will support. The maximum supported value is 32 and the
706 minimum value which makes sense is 2.
707
708 This is purely to save memory - each supported CPU adds
709 approximately eight kilobytes to the kernel image.
710
763142d1
PM
711config HOTPLUG_CPU
712 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
40b31360 713 depends on SMP
763142d1
PM
714 help
715 Say Y here to experiment with turning CPUs off and on. CPUs
716 can be controlled through /sys/devices/system/cpu.
717
91b91d01
PM
718source "kernel/Kconfig.preempt"
719
83662461
PM
720config GUSA
721 def_bool y
1efe4ce3 722 depends on !SMP && SUPERH32
83662461
PM
723 help
724 This enables support for gUSA (general UserSpace Atomicity).
725 This is the default implementation for both UP and non-ll/sc
726 CPUs, and is used by the libc, amongst others.
727
728 For additional information, design information can be found
729 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
730
731 This should only be disabled for special cases where alternate
732 atomicity implementations exist.
733
1efe4ce3
SM
734config GUSA_RB
735 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
736 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
737 help
738 Enabling this option will allow the kernel to implement some
692105b8 739 atomic operations using a software implementation of load-locked/
1efe4ce3
SM
740 store-conditional (LLSC). On machines which do not have hardware
741 LLSC, this should be more efficient than the other alternative of
692105b8 742 disabling interrupts around the atomic sequence.
1efe4ce3 743
86c8c047
MF
744config HW_PERF_EVENTS
745 bool "Enable hardware performance counter support for perf events"
746 depends on PERF_EVENTS && CPU_HAS_PMU
747 default y
748 help
749 Enable hardware performance counter support for perf events. If
750 disabled, perf events will use software events only.
751
43b8774d
PM
752source "drivers/sh/Kconfig"
753
cad82448 754endmenu
1da177e4 755
cad82448 756menu "Boot options"
1da177e4 757
190fe191
RF
758config USE_BUILTIN_DTB
759 bool "Use builtin DTB"
760 default n
761 depends on SH_DEVICE_TREE
762 help
763 Link a device tree blob for particular hardware into the kernel,
764 suppressing use of the DTB pointer provided by the bootloader.
765 This option should only be used with legacy bootloaders that are
766 not capable of providing a DTB to the kernel, or for experimental
767 hardware without stable device tree bindings.
768
769config BUILTIN_DTB_SOURCE
770 string "Source file for builtin DTB"
771 default ""
772 depends on USE_BUILTIN_DTB
773 help
774 Base name (without suffix, relative to arch/sh/boot/dts) for the
775 a DTS file that will be used to produce the DTB linked into the
776 kernel.
777
cad82448 778config ZERO_PAGE_OFFSET
b412a49a
PM
779 hex
780 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
781 SH_7751_SOLUTION_ENGINE
782 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
7a847f81 783 default "0x00002000" if PAGE_SIZE_8KB
cad82448 784 default "0x00001000"
1da177e4 785 help
cad82448 786 This sets the default offset of zero page.
1da177e4 787
cad82448 788config BOOT_LINK_OFFSET
b412a49a
PM
789 hex
790 default "0x00210000" if SH_SHMIN
a2e76c80 791 default "0x00400000" if SH_CAYMAN
b412a49a
PM
792 default "0x00810000" if SH_7780_SOLUTION_ENGINE
793 default "0x009e0000" if SH_TITAN
794 default "0x01800000" if SH_SDK7780
795 default "0x02000000" if SH_EDOSK7760
cad82448
PM
796 default "0x00800000"
797 help
798 This option allows you to set the link address offset of the zImage.
799 This can be useful if you are on a board which has a small amount of
800 memory.
1da177e4 801
b412a49a
PM
802config ENTRY_OFFSET
803 hex
804 default "0x00001000" if PAGE_SIZE_4KB
805 default "0x00002000" if PAGE_SIZE_8KB
806 default "0x00004000" if PAGE_SIZE_16KB
807 default "0x00010000" if PAGE_SIZE_64KB
808 default "0x00000000"
809
4705b2e8
MD
810config ROMIMAGE_MMCIF
811 bool "Include MMCIF loader in romImage (EXPERIMENTAL)"
0d57af1e 812 depends on CPU_SUBTYPE_SH7724
4705b2e8
MD
813 help
814 Say Y here to include experimental MMCIF loading code in
815 romImage. With this enabled it is possible to write the romImage
816 kernel image to an MMC card and boot the kernel straight from
817 the reset vector. At reset the processor Mask ROM will load the
818 first part of the romImage which in turn loads the rest the kernel
819 image to RAM using the MMCIF hardware block.
820
d724a9c9
PM
821choice
822 prompt "Kernel command line"
823 optional
824 default CMDLINE_OVERWRITE
825 help
826 Setting this option allows the kernel command line arguments
827 to be set.
828
829config CMDLINE_OVERWRITE
830 bool "Overwrite bootloader kernel arguments"
831 help
832 Given string will overwrite any arguments passed in by
833 a bootloader.
834
835config CMDLINE_EXTEND
836 bool "Extend bootloader kernel arguments"
837 help
838 Given string will be concatenated with arguments passed in
839 by a bootloader.
840
841endchoice
1da177e4 842
cad82448 843config CMDLINE
d724a9c9
PM
844 string "Kernel command line arguments string"
845 depends on CMDLINE_OVERWRITE || CMDLINE_EXTEND
cad82448 846 default "console=ttySC1,115200"
1da177e4
LT
847
848endmenu
849
cad82448 850menu "Bus options"
1da177e4 851
cad82448
PM
852config SUPERHYWAY
853 tristate "SuperHyway Bus support"
854 depends on CPU_SUBTYPE_SH4_202
1da177e4 855
17be2d2b 856config MAPLE
e16038ab
PM
857 bool "Maple Bus support"
858 depends on SH_DREAMCAST
859 help
860 The Maple Bus is SEGA's serial communication bus for peripherals
861 on the Dreamcast. Without this bus support you won't be able to
862 get your Dreamcast keyboard etc to work, so most users
863 probably want to say 'Y' here, unless you are only using the
864 Dreamcast with a serial line terminal or a remote network
865 connection.
17be2d2b 866
7693465d
PM
867config PCI
868 bool "PCI support"
869 depends on SYS_SUPPORTS_PCI
320e68da 870 select PCI_DOMAINS
43db595e 871 select GENERIC_PCI_IOMAP
1e05b62a 872 select NO_GENERIC_PCI_IOPORT_MAP
7693465d
PM
873 help
874 Find out whether you have a PCI motherboard. PCI is the name of a
875 bus system, i.e. the way the CPU talks to the other stuff inside
876 your box. If you have PCI, say Y, otherwise N.
1da177e4 877
320e68da
PM
878config PCI_DOMAINS
879 bool
880
1da177e4
LT
881source "drivers/pci/Kconfig"
882
883source "drivers/pcmcia/Kconfig"
884
1da177e4
LT
885endmenu
886
887menu "Executable file formats"
888
889source "fs/Kconfig.binfmt"
890
891endmenu
892
3aa770e7 893menu "Power management options (EXPERIMENTAL)"
f4cb5700 894
c6f17cb2
MD
895source "kernel/power/Kconfig"
896
897source "drivers/cpuidle/Kconfig"
3aa770e7 898
3aa770e7
AS
899endmenu
900
d5950b43
SR
901source "net/Kconfig"
902
1da177e4
LT
903source "drivers/Kconfig"
904
905source "fs/Kconfig"
906
1da177e4
LT
907source "arch/sh/Kconfig.debug"
908
909source "security/Kconfig"
910
911source "crypto/Kconfig"
912
913source "lib/Kconfig"