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