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
16 The SuperH is a RISC processor targeted for use in embedded systems
17 and consumer electronics; it was also used in the Sega Dreamcast
18 gaming console. The SuperH port has a home page at
19 <http://www.linux-sh.org/>.
24 select HAVE_KRETPROBES
28 select GENERIC_CALIBRATE_DELAY
32 default "arch/sh/configs/shx3_defconfig" if SUPERH32
33 default "arch/sh/configs/cayman_defconfig" if SUPERH64
35 config RWSEM_GENERIC_SPINLOCK
38 config RWSEM_XCHGADD_ALGORITHM
43 depends on BUG && SUPERH32
45 config GENERIC_FIND_NEXT_BIT
48 config GENERIC_HWEIGHT
51 config GENERIC_HARDIRQS
54 config GENERIC_HARDIRQS_NO__DO_IRQ
57 config GENERIC_IRQ_PROBE
60 config GENERIC_CALIBRATE_DELAY
69 config GENERIC_CLOCKEVENTS
72 config GENERIC_CLOCKEVENTS_BROADCAST
75 config GENERIC_LOCKBREAK
77 depends on SMP && PREEMPT
79 config SYS_SUPPORTS_PM
82 config SYS_SUPPORTS_APM_EMULATION
84 select SYS_SUPPORTS_PM
86 config SYS_SUPPORTS_SMP
89 config SYS_SUPPORTS_NUMA
92 config SYS_SUPPORTS_PCI
95 config STACKTRACE_SUPPORT
98 config LOCKDEP_SUPPORT
101 config ARCH_HAS_ILOG2_U32
104 config ARCH_HAS_ILOG2_U64
107 config ARCH_NO_VIRT_TO_BUS
113 source "init/Kconfig"
129 select CPU_HAS_INTEVT
134 select CPU_HAS_INTEVT
136 select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
137 select CPU_HAS_FPU if !CPU_SH4AL_DSP
159 prompt "Processor sub-type selection"
165 # SH-2 Processor Support
167 config CPU_SUBTYPE_SH7619
168 bool "Support SH7619 processor"
171 # SH-2A Processor Support
173 config CPU_SUBTYPE_SH7203
174 bool "Support SH7203 processor"
178 config CPU_SUBTYPE_SH7206
179 bool "Support SH7206 processor"
182 config CPU_SUBTYPE_SH7263
183 bool "Support SH7263 processor"
187 config CPU_SUBTYPE_MXG
188 bool "Support MX-G processor"
191 Select MX-G if running on an R8A03022BG part.
193 # SH-3 Processor Support
195 config CPU_SUBTYPE_SH7705
196 bool "Support SH7705 processor"
199 config CPU_SUBTYPE_SH7706
200 bool "Support SH7706 processor"
203 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
205 config CPU_SUBTYPE_SH7707
206 bool "Support SH7707 processor"
209 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
211 config CPU_SUBTYPE_SH7708
212 bool "Support SH7708 processor"
215 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
216 if you have a 100 Mhz SH-3 HD6417708R CPU.
218 config CPU_SUBTYPE_SH7709
219 bool "Support SH7709 processor"
222 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
224 config CPU_SUBTYPE_SH7710
225 bool "Support SH7710 processor"
229 Select SH7710 if you have a SH3-DSP SH7710 CPU.
231 config CPU_SUBTYPE_SH7712
232 bool "Support SH7712 processor"
236 Select SH7712 if you have a SH3-DSP SH7712 CPU.
238 config CPU_SUBTYPE_SH7720
239 bool "Support SH7720 processor"
243 Select SH7720 if you have a SH3-DSP SH7720 CPU.
245 config CPU_SUBTYPE_SH7721
246 bool "Support SH7721 processor"
250 Select SH7721 if you have a SH3-DSP SH7721 CPU.
252 # SH-4 Processor Support
254 config CPU_SUBTYPE_SH7750
255 bool "Support SH7750 processor"
258 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
260 config CPU_SUBTYPE_SH7091
261 bool "Support SH7091 processor"
264 Select SH7091 if you have an SH-4 based Sega device (such as
265 the Dreamcast, Naomi, and Naomi 2).
267 config CPU_SUBTYPE_SH7750R
268 bool "Support SH7750R processor"
271 config CPU_SUBTYPE_SH7750S
272 bool "Support SH7750S processor"
275 config CPU_SUBTYPE_SH7751
276 bool "Support SH7751 processor"
279 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
280 or if you have a HD6417751R CPU.
282 config CPU_SUBTYPE_SH7751R
283 bool "Support SH7751R processor"
286 config CPU_SUBTYPE_SH7760
287 bool "Support SH7760 processor"
290 config CPU_SUBTYPE_SH4_202
291 bool "Support SH4-202 processor"
294 # SH-4A Processor Support
296 config CPU_SUBTYPE_SH7723
297 bool "Support SH7723 processor"
300 select ARCH_SPARSEMEM_ENABLE
302 Select SH7723 if you have an SH-MobileR2 CPU.
304 config CPU_SUBTYPE_SH7763
305 bool "Support SH7763 processor"
308 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
310 config CPU_SUBTYPE_SH7770
311 bool "Support SH7770 processor"
314 config CPU_SUBTYPE_SH7780
315 bool "Support SH7780 processor"
318 config CPU_SUBTYPE_SH7785
319 bool "Support SH7785 processor"
322 select ARCH_SPARSEMEM_ENABLE
323 select SYS_SUPPORTS_NUMA
325 config CPU_SUBTYPE_SHX3
326 bool "Support SH-X3 processor"
329 select ARCH_SPARSEMEM_ENABLE
330 select SYS_SUPPORTS_NUMA
331 select SYS_SUPPORTS_SMP
332 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
334 # SH4AL-DSP Processor Support
336 config CPU_SUBTYPE_SH7343
337 bool "Support SH7343 processor"
340 config CPU_SUBTYPE_SH7722
341 bool "Support SH7722 processor"
344 select ARCH_SPARSEMEM_ENABLE
345 select SYS_SUPPORTS_NUMA
347 config CPU_SUBTYPE_SH7366
348 bool "Support SH7366 processor"
351 select ARCH_SPARSEMEM_ENABLE
352 select SYS_SUPPORTS_NUMA
354 # SH-5 Processor Support
356 config CPU_SUBTYPE_SH5_101
357 bool "Support SH5-101 processor"
360 config CPU_SUBTYPE_SH5_103
361 bool "Support SH5-103 processor"
366 source "arch/sh/mm/Kconfig"
368 source "arch/sh/Kconfig.cpu"
370 source "arch/sh/boards/Kconfig"
372 menu "Timer and clock configuration"
376 prompt "TMU timer support"
377 depends on CPU_SH3 || CPU_SH4
379 select GENERIC_CLOCKEVENTS
381 This enables the use of the TMU as the system timer.
385 prompt "CMT timer support"
386 depends on CPU_SH2 && !CPU_SUBTYPE_MXG
388 This enables the use of the CMT as the system timer.
392 prompt "MTU2 timer support"
395 This enables the use of the MTU2 as the system timer.
399 default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
401 default "86" if CPU_SUBTYPE_SH7619
402 default "140" if CPU_SUBTYPE_SH7206
403 default "142" if CPU_SUBTYPE_SH7203
404 default "238" if CPU_SUBTYPE_MXG
408 int "Peripheral clock frequency (in Hz)"
409 default "27000000" if CPU_SUBTYPE_SH7343
410 default "31250000" if CPU_SUBTYPE_SH7619
411 default "32000000" if CPU_SUBTYPE_SH7722
412 default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
413 CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
414 CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
415 CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG
416 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
417 default "66000000" if CPU_SUBTYPE_SH4_202
420 This option is used to specify the peripheral clock frequency.
421 This is necessary for determining the reference clock value on
422 platforms lacking an RTC.
425 int "CPU Mode Pin Setting"
427 default 6 if CPU_SUBTYPE_SH7206
428 default 5 if CPU_SUBTYPE_SH7619
431 MD2 - MD0 pin setting.
433 source "kernel/time/Kconfig"
437 menu "CPU Frequency scaling"
439 source "drivers/cpufreq/Kconfig"
442 tristate "SuperH CPU Frequency driver"
444 select CPU_FREQ_TABLE
446 This adds the cpufreq driver for SuperH. At present, only
447 the SH-4 is supported.
449 For details, take a look at <file:Documentation/cpu-freq>.
455 source "arch/sh/drivers/Kconfig"
462 menu "Kernel features"
464 source kernel/Kconfig.hz
467 bool "kexec system call (EXPERIMENTAL)"
468 depends on SUPERH32 && EXPERIMENTAL
470 kexec is a system call that implements the ability to shutdown your
471 current kernel, and to start another kernel. It is like a reboot
472 but it is independent of the system firmware. And like a reboot
473 you can start any kernel with it, not just Linux.
475 The name comes from the similarity to the exec system call.
477 It is an ongoing process to be certain the hardware in a machine
478 is properly shutdown, so do not be surprised if this code does not
479 initially work for you. It may help to enable device hotplugging
480 support. As of this writing the exact hardware interface is
481 strongly in flux, so no good recommendation can be made.
484 bool "kernel crash dumps (EXPERIMENTAL)"
485 depends on SUPERH32 && EXPERIMENTAL
487 Generate crash dump after being started by kexec.
488 This should be normally only set in special crash dump kernels
489 which are loaded in the main kernel with kexec-tools into
490 a specially reserved region and then later executed after
491 a crash by kdump/kexec. The crash dump kernel must be compiled
492 to a memory address not used by the main kernel using
495 For more details see Documentation/kdump/kdump.txt
498 bool "Enable seccomp to safely compute untrusted bytecode"
501 This kernel feature is useful for number crunching applications
502 that may need to compute untrusted bytecode during their
503 execution. By using pipes or other transports made available to
504 the process as file descriptors supporting the read/write
505 syscalls, it's possible to isolate those applications in
506 their own address space using seccomp. Once seccomp is
507 enabled via prctl, it cannot be disabled and the task is only
508 allowed to execute a few safe syscalls defined by each seccomp
514 bool "Symmetric multi-processing support"
515 depends on SYS_SUPPORTS_SMP
516 select USE_GENERIC_SMP_HELPERS
518 This enables support for systems with more than one CPU. If you have
519 a system with only one CPU, like most personal computers, say N. If
520 you have a system with more than one CPU, say Y.
522 If you say N here, the kernel will run on single and multiprocessor
523 machines, but will use only one CPU of a multiprocessor machine. If
524 you say Y here, the kernel will run on many, but not all,
525 singleprocessor machines. On a singleprocessor machine, the kernel
526 will run faster if you say N here.
528 People using multiprocessor machines who say Y here should also say
529 Y to "Enhanced Real Time Clock Support", below.
531 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
532 available at <http://www.tldp.org/docs.html#howto>.
534 If you don't know what to do here, say N.
537 int "Maximum number of CPUs (2-32)"
540 default "4" if CPU_SHX3
543 This allows you to specify the maximum number of CPUs which this
544 kernel will support. The maximum supported value is 32 and the
545 minimum value which makes sense is 2.
547 This is purely to save memory - each supported CPU adds
548 approximately eight kilobytes to the kernel image.
550 source "kernel/Kconfig.preempt"
554 depends on !SMP && SUPERH32
556 This enables support for gUSA (general UserSpace Atomicity).
557 This is the default implementation for both UP and non-ll/sc
558 CPUs, and is used by the libc, amongst others.
560 For additional information, design information can be found
561 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
563 This should only be disabled for special cases where alternate
564 atomicity implementations exist.
567 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
568 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
570 Enabling this option will allow the kernel to implement some
571 atomic operations using a software implemention of load-locked/
572 store-conditional (LLSC). On machines which do not have hardware
573 LLSC, this should be more efficient than the other alternative of
574 disabling insterrupts around the atomic sequence.
580 config ZERO_PAGE_OFFSET
581 hex "Zero page offset"
582 default "0x00004000" if SH_SH03
583 default "0x00010000" if PAGE_SIZE_64KB
584 default "0x00002000" if PAGE_SIZE_8KB
587 This sets the default offset of zero page.
589 config BOOT_LINK_OFFSET
590 hex "Link address offset for booting"
593 This option allows you to set the link address offset of the zImage.
594 This can be useful if you are on a board which has a small amount of
598 bool "Wakeup UBC on startup"
599 depends on CPU_SH4 && !CPU_SH4A
601 Selecting this option will wakeup the User Break Controller (UBC) on
602 startup. Although the UBC is left in an awake state when the processor
603 comes up, some boot loaders misbehave by putting the UBC to sleep in a
604 power saving state, which causes issues with things like ptrace().
609 bool "Default bootloader kernel arguments"
612 string "Initial kernel command string"
613 depends on CMDLINE_BOOL
614 default "console=ttySC1,115200"
620 # Even on SuperH devices which don't have an ISA bus,
621 # this variable helps the PCMCIA modules handle
622 # IRQ requesting properly -- Greg Banks.
624 # Though we're generally not interested in it when
625 # we're not using PCMCIA, so we make it dependent on
626 # PCMCIA outright. -- PFM.
629 depends on PCMCIA && HD6446X_SERIES
631 Find out whether you have ISA slots on your motherboard. ISA is the
632 name of a bus system, i.e. the way the CPU talks to the other stuff
633 inside your box. Other bus systems are PCI, EISA, MicroChannel
634 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
635 newer boards don't support it. If you have ISA, say Y, otherwise N.
640 The Extended Industry Standard Architecture (EISA) bus was
641 developed as an open alternative to the IBM MicroChannel bus.
643 The EISA bus provided some of the features of the IBM MicroChannel
644 bus while maintaining backward compatibility with cards made for
645 the older ISA bus. The EISA bus saw limited use between 1988 and
646 1995 when it was made obsolete by the PCI bus.
648 Say Y here if you are building a kernel for an EISA-based machine.
655 MicroChannel Architecture is found in some IBM PS/2 machines and
656 laptops. It is a bus system similar to PCI or ISA. See
657 <file:Documentation/mca.txt> (and especially the web page given
658 there) before attempting to build an MCA bus kernel.
664 tristate "SuperHyway Bus support"
665 depends on CPU_SUBTYPE_SH4_202
668 bool "Maple Bus support"
669 depends on SH_DREAMCAST
671 The Maple Bus is SEGA's serial communication bus for peripherals
672 on the Dreamcast. Without this bus support you won't be able to
673 get your Dreamcast keyboard etc to work, so most users
674 probably want to say 'Y' here, unless you are only using the
675 Dreamcast with a serial line terminal or a remote network
679 bool "Compact Flash Enabler support"
680 depends on SOLUTION_ENGINE || SH_SH03
682 Compact Flash is a small, removable mass storage device introduced
683 in 1994 originally as a PCMCIA device. If you say `Y' here, you
684 compile in support for Compact Flash devices directly connected to
685 a SuperH processor. A Compact Flash FAQ is available at
686 <http://www.compactflash.org/faqs/faq.htm>.
688 If your board has "Directly Connected" CompactFlash at area 5 or 6,
689 you may want to enable this option. Then, you can use CF as
690 primary IDE drive (only tested for SanDisk).
692 If in doubt, select 'N'.
695 prompt "Compact Flash Connection Area"
696 depends on CF_ENABLER
702 If your board has "Directly Connected" CompactFlash, You should
703 select the area where your CF is connected to.
705 - "Area5" if CompactFlash is connected to Area 5 (0x14000000)
706 - "Area6" if it is connected to Area 6 (0x18000000)
708 "Area6" will work for most boards.
717 depends on CF_ENABLER
718 default "0xb8000000" if CF_AREA6
719 default "0xb4000000" if CF_AREA5
721 source "arch/sh/drivers/pci/Kconfig"
723 source "drivers/pci/Kconfig"
725 source "drivers/pcmcia/Kconfig"
727 source "drivers/pci/hotplug/Kconfig"
731 menu "Executable file formats"
733 source "fs/Kconfig.binfmt"
737 menu "Power management options (EXPERIMENTAL)"
738 depends on EXPERIMENTAL && SYS_SUPPORTS_PM
740 config ARCH_SUSPEND_POSSIBLE
744 source kernel/power/Kconfig
750 source "drivers/Kconfig"
754 source "arch/sh/Kconfig.debug"
756 source "security/Kconfig"
758 source "crypto/Kconfig"