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