2 # For a description of the syntax of this configuration file,
3 # see Documentation/kbuild/kconfig-language.txt.
6 mainmenu "Linux/SuperH Kernel Configuration"
14 select HAVE_GENERIC_DMA_COHERENT
15 select HAVE_IOREMAP_PROT if MMU
16 select HAVE_ARCH_TRACEHOOK
17 select HAVE_DMA_API_DEBUG
20 The SuperH is a RISC processor targeted for use in embedded systems
21 and consumer electronics; it was also used in the Sega Dreamcast
22 gaming console. The SuperH port has a home page at
23 <http://www.linux-sh.org/>.
28 select HAVE_KRETPROBES
29 select HAVE_FUNCTION_TRACER
30 select HAVE_FTRACE_MCOUNT_RECORD
31 select HAVE_DYNAMIC_FTRACE
33 select ARCH_HIBERNATION_POSSIBLE if MMU
36 def_bool ARCH = "sh64"
40 default "arch/sh/configs/shx3_defconfig" if SUPERH32
41 default "arch/sh/configs/cayman_defconfig" if SUPERH64
43 config RWSEM_GENERIC_SPINLOCK
46 config RWSEM_XCHGADD_ALGORITHM
51 depends on BUG && SUPERH32
53 config GENERIC_FIND_NEXT_BIT
56 config GENERIC_HWEIGHT
59 config GENERIC_HARDIRQS
62 config GENERIC_HARDIRQS_NO__DO_IRQ
65 config GENERIC_IRQ_PROBE
71 config GENERIC_CALIBRATE_DELAY
80 config GENERIC_CLOCKEVENTS
83 config GENERIC_CLOCKEVENTS_BROADCAST
86 config GENERIC_CMOS_UPDATE
88 depends on SH_SH03 || SH_DREAMCAST
90 config GENERIC_LOCKBREAK
92 depends on SMP && PREEMPT
94 config SYS_SUPPORTS_PM
98 config ARCH_SUSPEND_POSSIBLE
101 config ARCH_HIBERNATION_POSSIBLE
104 config SYS_SUPPORTS_APM_EMULATION
106 select ARCH_SUSPEND_POSSIBLE
108 config SYS_SUPPORTS_SMP
111 config SYS_SUPPORTS_NUMA
114 config SYS_SUPPORTS_PCI
117 config SYS_SUPPORTS_CMT
120 config SYS_SUPPORTS_MTU2
123 config SYS_SUPPORTS_TMU
126 config STACKTRACE_SUPPORT
129 config LOCKDEP_SUPPORT
132 config HAVE_LATENCYTOP_SUPPORT
136 config ARCH_HAS_ILOG2_U32
139 config ARCH_HAS_ILOG2_U64
142 config ARCH_NO_VIRT_TO_BUS
145 config ARCH_HAS_DEFAULT_IDLE
151 source "init/Kconfig"
153 source "kernel/Kconfig.freezer"
169 select CPU_HAS_INTEVT
171 select SYS_SUPPORTS_TMU
175 select CPU_HAS_INTEVT
177 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
178 select CPU_HAS_FPU if !CPU_SH4AL_DSP
179 select SYS_SUPPORTS_TMU
193 select SYS_SUPPORTS_TMU
203 select ARCH_SUSPEND_POSSIBLE
208 prompt "Processor sub-type selection"
214 # SH-2 Processor Support
216 config CPU_SUBTYPE_SH7619
217 bool "Support SH7619 processor"
219 select SYS_SUPPORTS_CMT
221 # SH-2A Processor Support
223 config CPU_SUBTYPE_SH7201
224 bool "Support SH7201 processor"
227 select SYS_SUPPORTS_MTU2
229 config CPU_SUBTYPE_SH7203
230 bool "Support SH7203 processor"
233 select SYS_SUPPORTS_CMT
234 select SYS_SUPPORTS_MTU2
236 config CPU_SUBTYPE_SH7206
237 bool "Support SH7206 processor"
239 select SYS_SUPPORTS_CMT
240 select SYS_SUPPORTS_MTU2
242 config CPU_SUBTYPE_SH7263
243 bool "Support SH7263 processor"
246 select SYS_SUPPORTS_CMT
247 select SYS_SUPPORTS_MTU2
249 config CPU_SUBTYPE_MXG
250 bool "Support MX-G processor"
252 select SYS_SUPPORTS_MTU2
254 Select MX-G if running on an R8A03022BG part.
256 # SH-3 Processor Support
258 config CPU_SUBTYPE_SH7705
259 bool "Support SH7705 processor"
262 config CPU_SUBTYPE_SH7706
263 bool "Support SH7706 processor"
266 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
268 config CPU_SUBTYPE_SH7707
269 bool "Support SH7707 processor"
272 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
274 config CPU_SUBTYPE_SH7708
275 bool "Support SH7708 processor"
278 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
279 if you have a 100 Mhz SH-3 HD6417708R CPU.
281 config CPU_SUBTYPE_SH7709
282 bool "Support SH7709 processor"
285 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
287 config CPU_SUBTYPE_SH7710
288 bool "Support SH7710 processor"
292 Select SH7710 if you have a SH3-DSP SH7710 CPU.
294 config CPU_SUBTYPE_SH7712
295 bool "Support SH7712 processor"
299 Select SH7712 if you have a SH3-DSP SH7712 CPU.
301 config CPU_SUBTYPE_SH7720
302 bool "Support SH7720 processor"
305 select SYS_SUPPORTS_CMT
307 Select SH7720 if you have a SH3-DSP SH7720 CPU.
309 config CPU_SUBTYPE_SH7721
310 bool "Support SH7721 processor"
313 select SYS_SUPPORTS_CMT
315 Select SH7721 if you have a SH3-DSP SH7721 CPU.
317 # SH-4 Processor Support
319 config CPU_SUBTYPE_SH7750
320 bool "Support SH7750 processor"
323 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
325 config CPU_SUBTYPE_SH7091
326 bool "Support SH7091 processor"
329 Select SH7091 if you have an SH-4 based Sega device (such as
330 the Dreamcast, Naomi, and Naomi 2).
332 config CPU_SUBTYPE_SH7750R
333 bool "Support SH7750R processor"
336 config CPU_SUBTYPE_SH7750S
337 bool "Support SH7750S processor"
340 config CPU_SUBTYPE_SH7751
341 bool "Support SH7751 processor"
344 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
345 or if you have a HD6417751R CPU.
347 config CPU_SUBTYPE_SH7751R
348 bool "Support SH7751R processor"
351 config CPU_SUBTYPE_SH7760
352 bool "Support SH7760 processor"
355 config CPU_SUBTYPE_SH4_202
356 bool "Support SH4-202 processor"
359 # SH-4A Processor Support
361 config CPU_SUBTYPE_SH7723
362 bool "Support SH7723 processor"
366 select ARCH_SPARSEMEM_ENABLE
367 select SYS_SUPPORTS_CMT
369 Select SH7723 if you have an SH-MobileR2 CPU.
371 config CPU_SUBTYPE_SH7724
372 bool "Support SH7724 processor"
376 select ARCH_SPARSEMEM_ENABLE
377 select SYS_SUPPORTS_CMT
379 Select SH7724 if you have an SH-MobileR2R CPU.
381 config CPU_SUBTYPE_SH7763
382 bool "Support SH7763 processor"
385 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
387 config CPU_SUBTYPE_SH7770
388 bool "Support SH7770 processor"
391 config CPU_SUBTYPE_SH7780
392 bool "Support SH7780 processor"
395 config CPU_SUBTYPE_SH7785
396 bool "Support SH7785 processor"
399 select ARCH_SPARSEMEM_ENABLE
400 select SYS_SUPPORTS_NUMA
402 config CPU_SUBTYPE_SH7786
403 bool "Support SH7786 processor"
406 select CPU_HAS_PTEAEX
407 select ARCH_SPARSEMEM_ENABLE
408 select SYS_SUPPORTS_NUMA
410 config CPU_SUBTYPE_SHX3
411 bool "Support SH-X3 processor"
414 select ARCH_SPARSEMEM_ENABLE
415 select SYS_SUPPORTS_NUMA
416 select SYS_SUPPORTS_SMP
417 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
419 # SH4AL-DSP Processor Support
421 config CPU_SUBTYPE_SH7343
422 bool "Support SH7343 processor"
425 select SYS_SUPPORTS_CMT
427 config CPU_SUBTYPE_SH7722
428 bool "Support SH7722 processor"
432 select ARCH_SPARSEMEM_ENABLE
433 select SYS_SUPPORTS_NUMA
434 select SYS_SUPPORTS_CMT
436 config CPU_SUBTYPE_SH7366
437 bool "Support SH7366 processor"
441 select ARCH_SPARSEMEM_ENABLE
442 select SYS_SUPPORTS_NUMA
443 select SYS_SUPPORTS_CMT
452 prompt "Processor sub-type selection"
454 # SH-5 Processor Support
456 config CPU_SUBTYPE_SH5_101
457 bool "Support SH5-101 processor"
460 config CPU_SUBTYPE_SH5_103
461 bool "Support SH5-103 processor"
468 source "arch/sh/mm/Kconfig"
470 source "arch/sh/Kconfig.cpu"
472 source "arch/sh/boards/Kconfig"
474 menu "Timer and clock configuration"
477 bool "TMU timer support"
478 depends on CPU_SH3 || CPU_SH4
481 This enables the use of the TMU as the system timer.
484 bool "TMU timer driver"
485 depends on !SH_TMU && SYS_SUPPORTS_TMU
488 This enables the build of the TMU timer driver.
491 bool "CMT timer driver"
492 depends on SYS_SUPPORTS_CMT
495 This enables build of the CMT timer driver.
498 bool "MTU2 timer driver"
499 depends on SYS_SUPPORTS_MTU2
502 This enables build of the MTU2 timer driver.
506 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
508 default "86" if CPU_SUBTYPE_SH7619
509 default "140" if CPU_SUBTYPE_SH7206
510 default "142" if CPU_SUBTYPE_SH7203 && SH_CMT
511 default "153" if CPU_SUBTYPE_SH7203 && SH_MTU2
512 default "238" if CPU_SUBTYPE_MXG
516 int "Peripheral clock frequency (in Hz)"
517 default "27000000" if CPU_SUBTYPE_SH7343
518 default "31250000" if CPU_SUBTYPE_SH7619
519 default "32000000" if CPU_SUBTYPE_SH7722
520 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
521 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
522 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
523 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG || \
525 default "41666666" if CPU_SUBTYPE_SH7724
526 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
527 default "66000000" if CPU_SUBTYPE_SH4_202
530 This option is used to specify the peripheral clock frequency.
531 This is necessary for determining the reference clock value on
532 platforms lacking an RTC.
535 int "CPU Mode Pin Setting"
537 default 6 if CPU_SUBTYPE_SH7206
538 default 5 if CPU_SUBTYPE_SH7619
541 MD2 - MD0 pin setting.
543 source "kernel/time/Kconfig"
547 menu "CPU Frequency scaling"
549 source "drivers/cpufreq/Kconfig"
552 tristate "SuperH CPU Frequency driver"
554 select CPU_FREQ_TABLE
556 This adds the cpufreq driver for SuperH. Any CPU that supports
557 clock rate rounding through the clock framework can use this
558 driver. While it will make the kernel slightly larger, this is
559 harmless for CPUs that don't support rate rounding. The driver
560 will also generate a notice in the boot log before disabling
561 itself if the CPU in question is not capable of rate rounding.
563 For details, take a look at <file:Documentation/cpu-freq>.
569 source "arch/sh/drivers/Kconfig"
573 menu "Kernel features"
575 source kernel/Kconfig.hz
578 bool "kexec system call (EXPERIMENTAL)"
579 depends on SUPERH32 && EXPERIMENTAL && MMU
581 kexec is a system call that implements the ability to shutdown your
582 current kernel, and to start another kernel. It is like a reboot
583 but it is independent of the system firmware. And like a reboot
584 you can start any kernel with it, not just Linux.
586 The name comes from the similarity to the exec system call.
588 It is an ongoing process to be certain the hardware in a machine
589 is properly shutdown, so do not be surprised if this code does not
590 initially work for you. It may help to enable device hotplugging
591 support. As of this writing the exact hardware interface is
592 strongly in flux, so no good recommendation can be made.
595 bool "kernel crash dumps (EXPERIMENTAL)"
596 depends on SUPERH32 && EXPERIMENTAL
598 Generate crash dump after being started by kexec.
599 This should be normally only set in special crash dump kernels
600 which are loaded in the main kernel with kexec-tools into
601 a specially reserved region and then later executed after
602 a crash by kdump/kexec. The crash dump kernel must be compiled
603 to a memory address not used by the main kernel using
606 For more details see Documentation/kdump/kdump.txt
609 bool "kexec jump (EXPERIMENTAL)"
610 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
612 Jump between original kernel and kexeced kernel and invoke
616 bool "Enable seccomp to safely compute untrusted bytecode"
619 This kernel feature is useful for number crunching applications
620 that may need to compute untrusted bytecode during their
621 execution. By using pipes or other transports made available to
622 the process as file descriptors supporting the read/write
623 syscalls, it's possible to isolate those applications in
624 their own address space using seccomp. Once seccomp is
625 enabled via prctl, it cannot be disabled and the task is only
626 allowed to execute a few safe syscalls defined by each seccomp
632 bool "Symmetric multi-processing support"
633 depends on SYS_SUPPORTS_SMP
634 select USE_GENERIC_SMP_HELPERS
636 This enables support for systems with more than one CPU. If you have
637 a system with only one CPU, like most personal computers, say N. If
638 you have a system with more than one CPU, say Y.
640 If you say N here, the kernel will run on single and multiprocessor
641 machines, but will use only one CPU of a multiprocessor machine. If
642 you say Y here, the kernel will run on many, but not all,
643 singleprocessor machines. On a singleprocessor machine, the kernel
644 will run faster if you say N here.
646 People using multiprocessor machines who say Y here should also say
647 Y to "Enhanced Real Time Clock Support", below.
649 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
650 available at <http://www.tldp.org/docs.html#howto>.
652 If you don't know what to do here, say N.
655 int "Maximum number of CPUs (2-32)"
658 default "4" if CPU_SHX3
661 This allows you to specify the maximum number of CPUs which this
662 kernel will support. The maximum supported value is 32 and the
663 minimum value which makes sense is 2.
665 This is purely to save memory - each supported CPU adds
666 approximately eight kilobytes to the kernel image.
668 source "kernel/Kconfig.preempt"
672 depends on !SMP && SUPERH32
674 This enables support for gUSA (general UserSpace Atomicity).
675 This is the default implementation for both UP and non-ll/sc
676 CPUs, and is used by the libc, amongst others.
678 For additional information, design information can be found
679 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
681 This should only be disabled for special cases where alternate
682 atomicity implementations exist.
685 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
686 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
688 Enabling this option will allow the kernel to implement some
689 atomic operations using a software implementation of load-locked/
690 store-conditional (LLSC). On machines which do not have hardware
691 LLSC, this should be more efficient than the other alternative of
692 disabling interrupts around the atomic sequence.
698 config ZERO_PAGE_OFFSET
700 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
701 SH_7751_SOLUTION_ENGINE
702 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
703 default "0x00002000" if PAGE_SIZE_8KB
706 This sets the default offset of zero page.
708 config BOOT_LINK_OFFSET
710 default "0x00210000" if SH_SHMIN
711 default "0x00400000" if SH_CAYMAN
712 default "0x00810000" if SH_7780_SOLUTION_ENGINE
713 default "0x009e0000" if SH_TITAN
714 default "0x01800000" if SH_SDK7780
715 default "0x02000000" if SH_EDOSK7760
718 This option allows you to set the link address offset of the zImage.
719 This can be useful if you are on a board which has a small amount of
724 default "0x00001000" if PAGE_SIZE_4KB
725 default "0x00002000" if PAGE_SIZE_8KB
726 default "0x00004000" if PAGE_SIZE_16KB
727 default "0x00010000" if PAGE_SIZE_64KB
731 bool "Wakeup UBC on startup"
732 depends on CPU_SH4 && !CPU_SH4A
734 Selecting this option will wakeup the User Break Controller (UBC) on
735 startup. Although the UBC is left in an awake state when the processor
736 comes up, some boot loaders misbehave by putting the UBC to sleep in a
737 power saving state, which causes issues with things like ptrace().
742 bool "Default bootloader kernel arguments"
745 string "Initial kernel command string"
746 depends on CMDLINE_BOOL
747 default "console=ttySC1,115200"
754 tristate "SuperHyway Bus support"
755 depends on CPU_SUBTYPE_SH4_202
758 bool "Maple Bus support"
759 depends on SH_DREAMCAST
761 The Maple Bus is SEGA's serial communication bus for peripherals
762 on the Dreamcast. Without this bus support you won't be able to
763 get your Dreamcast keyboard etc to work, so most users
764 probably want to say 'Y' here, unless you are only using the
765 Dreamcast with a serial line terminal or a remote network
768 source "arch/sh/drivers/pci/Kconfig"
770 source "drivers/pci/pcie/Kconfig"
772 source "drivers/pci/Kconfig"
774 source "drivers/pcmcia/Kconfig"
776 source "drivers/pci/hotplug/Kconfig"
780 menu "Executable file formats"
782 source "fs/Kconfig.binfmt"
786 menu "Power management options (EXPERIMENTAL)"
787 depends on EXPERIMENTAL
789 source "kernel/power/Kconfig"
791 source "drivers/cpuidle/Kconfig"
797 source "drivers/Kconfig"
801 source "arch/sh/Kconfig.debug"
803 source "security/Kconfig"
805 source "crypto/Kconfig"