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