sh: Define ARCH_SHMOBILE for SH-Mobile CPUs.
[linux-2.6/mini2440.git] / arch / sh / Kconfig
blobadffbf4048b1f9043a160c45fcd7fad5faa5441d
2 # For a description of the syntax of this configuration file,
3 # see Documentation/kbuild/kconfig-language.txt.
6 mainmenu "Linux/SuperH Kernel Configuration"
8 config SUPERH
9         def_bool y
10         select EMBEDDED
11         select HAVE_CLK
12         select HAVE_IDE
13         select HAVE_OPROFILE
14         select HAVE_GENERIC_DMA_COHERENT
15         select HAVE_IOREMAP_PROT if MMU
16         select HAVE_ARCH_TRACEHOOK
17         help
18           The SuperH is a RISC processor targeted for use in embedded systems
19           and consumer electronics; it was also used in the Sega Dreamcast
20           gaming console.  The SuperH port has a home page at
21           <http://www.linux-sh.org/>.
23 config SUPERH32
24         def_bool !SUPERH64
25         select HAVE_KPROBES
26         select HAVE_KRETPROBES
27         select HAVE_FUNCTION_TRACER
28         select HAVE_FTRACE_MCOUNT_RECORD
29         select HAVE_DYNAMIC_FTRACE
30         select HAVE_ARCH_KGDB
32 config SUPERH64
33         def_bool y if CPU_SH5
35 config ARCH_DEFCONFIG
36         string
37         default "arch/sh/configs/shx3_defconfig" if SUPERH32
38         default "arch/sh/configs/cayman_defconfig" if SUPERH64
40 config RWSEM_GENERIC_SPINLOCK
41         def_bool y
43 config RWSEM_XCHGADD_ALGORITHM
44         bool
46 config GENERIC_BUG
47         def_bool y
48         depends on BUG && SUPERH32
50 config GENERIC_FIND_NEXT_BIT
51         def_bool y
53 config GENERIC_HWEIGHT
54         def_bool y
56 config GENERIC_HARDIRQS
57         def_bool y
59 config GENERIC_HARDIRQS_NO__DO_IRQ
60         def_bool y
62 config GENERIC_IRQ_PROBE
63         def_bool y
65 config GENERIC_GPIO
66         def_bool n
68 config GENERIC_CALIBRATE_DELAY
69         bool
71 config GENERIC_IOMAP
72         bool
74 config GENERIC_TIME
75         def_bool n
77 config GENERIC_CLOCKEVENTS
78         def_bool n
80 config GENERIC_CLOCKEVENTS_BROADCAST
81         bool
83 config GENERIC_LOCKBREAK
84         def_bool y
85         depends on SMP && PREEMPT
87 config SYS_SUPPORTS_PM
88         bool
89         depends on !SMP
91 config ARCH_SUSPEND_POSSIBLE
92         def_bool n
94 config ARCH_HIBERNATION_POSSIBLE
95         def_bool n
97 config SYS_SUPPORTS_APM_EMULATION
98         bool
99         select ARCH_SUSPEND_POSSIBLE
101 config SYS_SUPPORTS_SMP
102         bool
104 config SYS_SUPPORTS_NUMA
105         bool
107 config SYS_SUPPORTS_PCI
108         bool
110 config SYS_SUPPORTS_CMT
111         bool
113 config STACKTRACE_SUPPORT
114         def_bool y
116 config LOCKDEP_SUPPORT
117         def_bool y
119 config HAVE_LATENCYTOP_SUPPORT
120         def_bool y
121         depends on !SMP
123 config ARCH_HAS_ILOG2_U32
124         def_bool n
126 config ARCH_HAS_ILOG2_U64
127         def_bool n
129 config ARCH_NO_VIRT_TO_BUS
130         def_bool y
132 config IO_TRAPPED
133         bool
135 source "init/Kconfig"
137 source "kernel/Kconfig.freezer"
139 menu "System type"
142 # Processor families
144 config CPU_SH2
145         bool
147 config CPU_SH2A
148         bool
149         select CPU_SH2
151 config CPU_SH3
152         bool
153         select CPU_HAS_INTEVT
154         select CPU_HAS_SR_RB
156 config CPU_SH4
157         bool
158         select CPU_HAS_INTEVT
159         select CPU_HAS_SR_RB
160         select CPU_HAS_PTEA if !CPU_SH4A || CPU_SHX2
161         select CPU_HAS_FPU if !CPU_SH4AL_DSP
163 config CPU_SH4A
164         bool
165         select CPU_SH4
167 config CPU_SH4AL_DSP
168         bool
169         select CPU_SH4A
170         select CPU_HAS_DSP
172 config CPU_SH5
173         bool
174         select CPU_HAS_FPU
176 config CPU_SHX2
177         bool
179 config CPU_SHX3
180         bool
182 config ARCH_SHMOBILE
183         bool
185 choice
186         prompt "Processor sub-type selection"
189 # Processor subtypes
192 # SH-2 Processor Support
194 config CPU_SUBTYPE_SH7619
195         bool "Support SH7619 processor"
196         select CPU_SH2
197         select SYS_SUPPORTS_CMT
199 # SH-2A Processor Support
201 config CPU_SUBTYPE_SH7201
202         bool "Support SH7201 processor"
203         select CPU_SH2A
204         select CPU_HAS_FPU
206 config CPU_SUBTYPE_SH7203
207         bool "Support SH7203 processor"
208         select CPU_SH2A
209         select CPU_HAS_FPU
210         select SYS_SUPPORTS_CMT
212 config CPU_SUBTYPE_SH7206
213         bool "Support SH7206 processor"
214         select CPU_SH2A
215         select SYS_SUPPORTS_CMT
217 config CPU_SUBTYPE_SH7263
218         bool "Support SH7263 processor"
219         select CPU_SH2A
220         select CPU_HAS_FPU
221         select SYS_SUPPORTS_CMT
223 config CPU_SUBTYPE_MXG
224         bool "Support MX-G processor"
225         select CPU_SH2A
226         help
227           Select MX-G if running on an R8A03022BG part.
229 # SH-3 Processor Support
231 config CPU_SUBTYPE_SH7705
232         bool "Support SH7705 processor"
233         select CPU_SH3
235 config CPU_SUBTYPE_SH7706
236         bool "Support SH7706 processor"
237         select CPU_SH3
238         help
239           Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
241 config CPU_SUBTYPE_SH7707
242         bool "Support SH7707 processor"
243         select CPU_SH3
244         help
245           Select SH7707 if you have a  60 Mhz SH-3 HD6417707 CPU.
247 config CPU_SUBTYPE_SH7708
248         bool "Support SH7708 processor"
249         select CPU_SH3
250         help
251           Select SH7708 if you have a  60 Mhz SH-3 HD6417708S or
252           if you have a 100 Mhz SH-3 HD6417708R CPU.
254 config CPU_SUBTYPE_SH7709
255         bool "Support SH7709 processor"
256         select CPU_SH3
257         help
258           Select SH7709 if you have a  80 Mhz SH-3 HD6417709 CPU.
260 config CPU_SUBTYPE_SH7710
261         bool "Support SH7710 processor"
262         select CPU_SH3
263         select CPU_HAS_DSP
264         help
265           Select SH7710 if you have a SH3-DSP SH7710 CPU.
267 config CPU_SUBTYPE_SH7712
268         bool "Support SH7712 processor"
269         select CPU_SH3
270         select CPU_HAS_DSP
271         help
272           Select SH7712 if you have a SH3-DSP SH7712 CPU.
274 config CPU_SUBTYPE_SH7720
275         bool "Support SH7720 processor"
276         select CPU_SH3
277         select CPU_HAS_DSP
278         help
279           Select SH7720 if you have a SH3-DSP SH7720 CPU.
281 config CPU_SUBTYPE_SH7721
282         bool "Support SH7721 processor"
283         select CPU_SH3
284         select CPU_HAS_DSP
285         help
286           Select SH7721 if you have a SH3-DSP SH7721 CPU.
288 # SH-4 Processor Support
290 config CPU_SUBTYPE_SH7750
291         bool "Support SH7750 processor"
292         select CPU_SH4
293         help
294           Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
296 config CPU_SUBTYPE_SH7091
297         bool "Support SH7091 processor"
298         select CPU_SH4
299         help
300           Select SH7091 if you have an SH-4 based Sega device (such as
301           the Dreamcast, Naomi, and Naomi 2).
303 config CPU_SUBTYPE_SH7750R
304         bool "Support SH7750R processor"
305         select CPU_SH4
307 config CPU_SUBTYPE_SH7750S
308         bool "Support SH7750S processor"
309         select CPU_SH4
311 config CPU_SUBTYPE_SH7751
312         bool "Support SH7751 processor"
313         select CPU_SH4
314         help
315           Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
316           or if you have a HD6417751R CPU.
318 config CPU_SUBTYPE_SH7751R
319         bool "Support SH7751R processor"
320         select CPU_SH4
322 config CPU_SUBTYPE_SH7760
323         bool "Support SH7760 processor"
324         select CPU_SH4
326 config CPU_SUBTYPE_SH4_202
327         bool "Support SH4-202 processor"
328         select CPU_SH4
330 # SH-4A Processor Support
332 config CPU_SUBTYPE_SH7723
333         bool "Support SH7723 processor"
334         select CPU_SH4A
335         select CPU_SHX2
336         select ARCH_SHMOBILE
337         select ARCH_SPARSEMEM_ENABLE
338         select SYS_SUPPORTS_CMT
339         help
340           Select SH7723 if you have an SH-MobileR2 CPU.
342 config CPU_SUBTYPE_SH7763
343         bool "Support SH7763 processor"
344         select CPU_SH4A
345         help
346           Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
348 config CPU_SUBTYPE_SH7770
349         bool "Support SH7770 processor"
350         select CPU_SH4A
352 config CPU_SUBTYPE_SH7780
353         bool "Support SH7780 processor"
354         select CPU_SH4A
356 config CPU_SUBTYPE_SH7785
357         bool "Support SH7785 processor"
358         select CPU_SH4A
359         select CPU_SHX2
360         select ARCH_SPARSEMEM_ENABLE
361         select SYS_SUPPORTS_NUMA
363 config CPU_SUBTYPE_SH7786
364         bool "Support SH7786 processor"
365         select CPU_SH4A
366         select CPU_SHX3
367         select ARCH_SPARSEMEM_ENABLE
368         select SYS_SUPPORTS_NUMA
370 config CPU_SUBTYPE_SHX3
371         bool "Support SH-X3 processor"
372         select CPU_SH4A
373         select CPU_SHX3
374         select ARCH_SPARSEMEM_ENABLE
375         select SYS_SUPPORTS_NUMA
376         select SYS_SUPPORTS_SMP
377         select GENERIC_CLOCKEVENTS_BROADCAST if SMP
379 # SH4AL-DSP Processor Support
381 config CPU_SUBTYPE_SH7343
382         bool "Support SH7343 processor"
383         select CPU_SH4AL_DSP
384         select ARCH_SHMOBILE
385         select SYS_SUPPORTS_CMT
387 config CPU_SUBTYPE_SH7722
388         bool "Support SH7722 processor"
389         select CPU_SH4AL_DSP
390         select CPU_SHX2
391         select ARCH_SHMOBILE
392         select ARCH_SPARSEMEM_ENABLE
393         select SYS_SUPPORTS_NUMA
394         select SYS_SUPPORTS_CMT
396 config CPU_SUBTYPE_SH7366
397         bool "Support SH7366 processor"
398         select CPU_SH4AL_DSP
399         select CPU_SHX2
400         select ARCH_SHMOBILE
401         select ARCH_SPARSEMEM_ENABLE
402         select SYS_SUPPORTS_NUMA
403         select SYS_SUPPORTS_CMT
405 # SH-5 Processor Support
407 config CPU_SUBTYPE_SH5_101
408         bool "Support SH5-101 processor"
409         select CPU_SH5
411 config CPU_SUBTYPE_SH5_103
412         bool "Support SH5-103 processor"
413         select CPU_SH5
415 endchoice
417 source "arch/sh/mm/Kconfig"
419 source "arch/sh/Kconfig.cpu"
421 source "arch/sh/boards/Kconfig"
423 menu "Timer and clock configuration"
425 config SH_TMU
426         bool "TMU timer support"
427         depends on CPU_SH3 || CPU_SH4
428         default y
429         select GENERIC_TIME
430         select GENERIC_CLOCKEVENTS
431         help
432           This enables the use of the TMU as the system timer.
434 config SH_CMT
435         bool "CMT timer support"
436         depends on SYS_SUPPORTS_CMT && CPU_SH2
437         default y
438         help
439           This enables the use of the CMT as the system timer.
442 # Support for the new-style CMT driver. This will replace SH_CMT
443 # once its other dependencies are merged.
445 config SH_TIMER_CMT
446         bool "CMT clockevents driver"
447         depends on SYS_SUPPORTS_CMT && !SH_CMT
448         select GENERIC_CLOCKEVENTS
450 config SH_MTU2
451         bool "MTU2 timer support"
452         depends on CPU_SH2A
453         default y
454         help
455           This enables the use of the MTU2 as the system timer.
457 config SH_TIMER_IRQ
458         int
459         default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \
460                         CPU_SUBTYPE_SH7763
461         default "86" if CPU_SUBTYPE_SH7619
462         default "140" if CPU_SUBTYPE_SH7206
463         default "142" if CPU_SUBTYPE_SH7203 && SH_CMT
464         default "153" if CPU_SUBTYPE_SH7203 && SH_MTU2
465         default "238" if CPU_SUBTYPE_MXG
466         default "16"
468 config SH_PCLK_FREQ
469         int "Peripheral clock frequency (in Hz)"
470         default "27000000" if CPU_SUBTYPE_SH7343
471         default "31250000" if CPU_SUBTYPE_SH7619
472         default "32000000" if CPU_SUBTYPE_SH7722
473         default "33333333" if CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7723 || \
474                               CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7705 || \
475                               CPU_SUBTYPE_SH7203 || CPU_SUBTYPE_SH7206 || \
476                               CPU_SUBTYPE_SH7263 || CPU_SUBTYPE_MXG    || \
477                               CPU_SUBTYPE_SH7786
478         default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
479         default "66000000" if CPU_SUBTYPE_SH4_202
480         default "50000000"
481         help
482           This option is used to specify the peripheral clock frequency.
483           This is necessary for determining the reference clock value on
484           platforms lacking an RTC.
486 config SH_CLK_MD
487         int "CPU Mode Pin Setting"
488         depends on CPU_SH2
489         default 6 if CPU_SUBTYPE_SH7206
490         default 5 if CPU_SUBTYPE_SH7619
491         default 0
492         help
493           MD2 - MD0 pin setting.
495 source "kernel/time/Kconfig"
497 endmenu
499 menu "CPU Frequency scaling"
501 source "drivers/cpufreq/Kconfig"
503 config SH_CPU_FREQ
504         tristate "SuperH CPU Frequency driver"
505         depends on CPU_FREQ
506         select CPU_FREQ_TABLE
507         help
508           This adds the cpufreq driver for SuperH. Any CPU that supports
509           clock rate rounding through the clock framework can use this
510           driver. While it will make the kernel slightly larger, this is
511           harmless for CPUs that don't support rate rounding. The driver
512           will also generate a notice in the boot log before disabling
513           itself if the CPU in question is not capable of rate rounding.
515           For details, take a look at <file:Documentation/cpu-freq>.
517           If unsure, say N.
519 endmenu
521 source "arch/sh/drivers/Kconfig"
523 endmenu
525 menu "Kernel features"
527 source kernel/Kconfig.hz
529 config KEXEC
530         bool "kexec system call (EXPERIMENTAL)"
531         depends on SUPERH32 && EXPERIMENTAL
532         help
533           kexec is a system call that implements the ability to shutdown your
534           current kernel, and to start another kernel.  It is like a reboot
535           but it is independent of the system firmware.  And like a reboot
536           you can start any kernel with it, not just Linux.
538           The name comes from the similarity to the exec system call.
540           It is an ongoing process to be certain the hardware in a machine
541           is properly shutdown, so do not be surprised if this code does not
542           initially work for you.  It may help to enable device hotplugging
543           support.  As of this writing the exact hardware interface is
544           strongly in flux, so no good recommendation can be made.
546 config CRASH_DUMP
547         bool "kernel crash dumps (EXPERIMENTAL)"
548         depends on SUPERH32 && EXPERIMENTAL
549         help
550           Generate crash dump after being started by kexec.
551           This should be normally only set in special crash dump kernels
552           which are loaded in the main kernel with kexec-tools into
553           a specially reserved region and then later executed after
554           a crash by kdump/kexec. The crash dump kernel must be compiled
555           to a memory address not used by the main kernel using
556           MEMORY_START.
558           For more details see Documentation/kdump/kdump.txt
560 config SECCOMP
561         bool "Enable seccomp to safely compute untrusted bytecode"
562         depends on PROC_FS
563         help
564           This kernel feature is useful for number crunching applications
565           that may need to compute untrusted bytecode during their
566           execution. By using pipes or other transports made available to
567           the process as file descriptors supporting the read/write
568           syscalls, it's possible to isolate those applications in
569           their own address space using seccomp. Once seccomp is
570           enabled via prctl, it cannot be disabled and the task is only
571           allowed to execute a few safe syscalls defined by each seccomp
572           mode.
574           If unsure, say N.
576 config SMP
577         bool "Symmetric multi-processing support"
578         depends on SYS_SUPPORTS_SMP
579         select USE_GENERIC_SMP_HELPERS
580         ---help---
581           This enables support for systems with more than one CPU. If you have
582           a system with only one CPU, like most personal computers, say N. If
583           you have a system with more than one CPU, say Y.
585           If you say N here, the kernel will run on single and multiprocessor
586           machines, but will use only one CPU of a multiprocessor machine. If
587           you say Y here, the kernel will run on many, but not all,
588           singleprocessor machines. On a singleprocessor machine, the kernel
589           will run faster if you say N here.
591           People using multiprocessor machines who say Y here should also say
592           Y to "Enhanced Real Time Clock Support", below.
594           See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
595           available at <http://www.tldp.org/docs.html#howto>.
597           If you don't know what to do here, say N.
599 config NR_CPUS
600         int "Maximum number of CPUs (2-32)"
601         range 2 32
602         depends on SMP
603         default "4" if CPU_SHX3
604         default "2"
605         help
606           This allows you to specify the maximum number of CPUs which this
607           kernel will support.  The maximum supported value is 32 and the
608           minimum value which makes sense is 2.
610           This is purely to save memory - each supported CPU adds
611           approximately eight kilobytes to the kernel image.
613 source "kernel/Kconfig.preempt"
615 config GUSA
616         def_bool y
617         depends on !SMP && SUPERH32
618         help
619           This enables support for gUSA (general UserSpace Atomicity).
620           This is the default implementation for both UP and non-ll/sc
621           CPUs, and is used by the libc, amongst others.
623           For additional information, design information can be found 
624           in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
626           This should only be disabled for special cases where alternate
627           atomicity implementations exist.
629 config GUSA_RB
630         bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
631         depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
632         help
633           Enabling this option will allow the kernel to implement some
634           atomic operations using a software implemention of load-locked/
635           store-conditional (LLSC). On machines which do not have hardware
636           LLSC, this should be more efficient than the other alternative of
637           disabling insterrupts around the atomic sequence.
639 endmenu
641 menu "Boot options"
643 config ZERO_PAGE_OFFSET
644         hex "Zero page offset"
645         default "0x00004000" if SH_SH03
646         default "0x00010000" if PAGE_SIZE_64KB
647         default "0x00002000" if PAGE_SIZE_8KB
648         default "0x00001000"
649         help
650           This sets the default offset of zero page.
652 config BOOT_LINK_OFFSET
653         hex "Link address offset for booting"
654         default "0x00800000"
655         help
656           This option allows you to set the link address offset of the zImage.
657           This can be useful if you are on a board which has a small amount of
658           memory.
660 config UBC_WAKEUP
661         bool "Wakeup UBC on startup"
662         depends on CPU_SH4 && !CPU_SH4A
663         help
664           Selecting this option will wakeup the User Break Controller (UBC) on
665           startup. Although the UBC is left in an awake state when the processor
666           comes up, some boot loaders misbehave by putting the UBC to sleep in a
667           power saving state, which causes issues with things like ptrace().
669           If unsure, say N.
671 config CMDLINE_BOOL
672         bool "Default bootloader kernel arguments"
674 config CMDLINE
675         string "Initial kernel command string"
676         depends on CMDLINE_BOOL
677         default "console=ttySC1,115200"
679 endmenu
681 menu "Bus options"
683 config SUPERHYWAY
684         tristate "SuperHyway Bus support"
685         depends on CPU_SUBTYPE_SH4_202
687 config MAPLE
688         bool "Maple Bus support"
689         depends on SH_DREAMCAST
690         help
691          The Maple Bus is SEGA's serial communication bus for peripherals
692          on the Dreamcast. Without this bus support you won't be able to
693          get your Dreamcast keyboard etc to work, so most users
694          probably want to say 'Y' here, unless you are only using the
695          Dreamcast with a serial line terminal or a remote network
696          connection.
698 source "arch/sh/drivers/pci/Kconfig"
700 source "drivers/pci/pcie/Kconfig"
702 source "drivers/pci/Kconfig"
704 source "drivers/pcmcia/Kconfig"
706 source "drivers/pci/hotplug/Kconfig"
708 endmenu
710 menu "Executable file formats"
712 source "fs/Kconfig.binfmt"
714 endmenu
716 menu "Power management options (EXPERIMENTAL)"
717 depends on EXPERIMENTAL
719 source "kernel/power/Kconfig"
721 source "drivers/cpuidle/Kconfig"
723 endmenu
725 source "net/Kconfig"
727 source "drivers/Kconfig"
729 source "fs/Kconfig"
731 source "arch/sh/Kconfig.debug"
733 source "security/Kconfig"
735 source "crypto/Kconfig"
737 source "lib/Kconfig"