]> asedeno.scripts.mit.edu Git - linux.git/blob - arch/sh/Kconfig
sh: add support for J-Core J2 processor
[linux.git] / arch / sh / Kconfig
1 config SUPERH
2         def_bool y
3         select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
4         select ARCH_MIGHT_HAVE_PC_PARPORT
5         select HAVE_PATA_PLATFORM
6         select CLKDEV_LOOKUP
7         select HAVE_IDE if HAS_IOPORT_MAP
8         select HAVE_MEMBLOCK
9         select HAVE_MEMBLOCK_NODE_MAP
10         select ARCH_DISCARD_MEMBLOCK
11         select HAVE_OPROFILE
12         select HAVE_GENERIC_DMA_COHERENT
13         select HAVE_ARCH_TRACEHOOK
14         select HAVE_DMA_API_DEBUG
15         select HAVE_PERF_EVENTS
16         select HAVE_DEBUG_BUGVERBOSE
17         select ARCH_HAVE_CUSTOM_GPIO_H
18         select ARCH_HAVE_NMI_SAFE_CMPXCHG if (GUSA_RB || CPU_SH4A)
19         select ARCH_HAS_GCOV_PROFILE_ALL
20         select PERF_USE_VMALLOC
21         select HAVE_DEBUG_KMEMLEAK
22         select HAVE_KERNEL_GZIP
23         select CPU_NO_EFFICIENT_FFS
24         select HAVE_KERNEL_BZIP2
25         select HAVE_KERNEL_LZMA
26         select HAVE_KERNEL_XZ
27         select HAVE_KERNEL_LZO
28         select HAVE_UID16
29         select ARCH_WANT_IPC_PARSE_VERSION
30         select HAVE_SYSCALL_TRACEPOINTS
31         select HAVE_REGS_AND_STACK_ACCESS_API
32         select MAY_HAVE_SPARSE_IRQ
33         select IRQ_FORCED_THREADING
34         select RTC_LIB
35         select GENERIC_ATOMIC64
36         select GENERIC_IRQ_SHOW
37         select GENERIC_SMP_IDLE_THREAD
38         select GENERIC_IDLE_POLL_SETUP
39         select GENERIC_CLOCKEVENTS
40         select GENERIC_CMOS_UPDATE if SH_SH03 || SH_DREAMCAST
41         select GENERIC_SCHED_CLOCK
42         select GENERIC_STRNCPY_FROM_USER
43         select GENERIC_STRNLEN_USER
44         select HAVE_MOD_ARCH_SPECIFIC if DWARF_UNWINDER
45         select MODULES_USE_ELF_RELA
46         select OLD_SIGSUSPEND
47         select OLD_SIGACTION
48         select HAVE_ARCH_AUDITSYSCALL
49         select HAVE_FUTEX_CMPXCHG if FUTEX
50         select HAVE_NMI
51         help
52           The SuperH is a RISC processor targeted for use in embedded systems
53           and consumer electronics; it was also used in the Sega Dreamcast
54           gaming console.  The SuperH port has a home page at
55           <http://www.linux-sh.org/>.
56
57 config SUPERH32
58         def_bool ARCH = "sh"
59         select HAVE_KPROBES
60         select HAVE_KRETPROBES
61         select HAVE_IOREMAP_PROT if MMU && !X2TLB
62         select HAVE_FUNCTION_TRACER
63         select HAVE_FTRACE_MCOUNT_RECORD
64         select HAVE_DYNAMIC_FTRACE
65         select HAVE_FTRACE_NMI_ENTER if DYNAMIC_FTRACE
66         select ARCH_WANT_IPC_PARSE_VERSION
67         select HAVE_FUNCTION_GRAPH_TRACER
68         select HAVE_ARCH_KGDB
69         select HAVE_HW_BREAKPOINT
70         select HAVE_MIXED_BREAKPOINTS_REGS
71         select PERF_EVENTS
72         select ARCH_HIBERNATION_POSSIBLE if MMU
73         select SPARSE_IRQ
74         select HAVE_CC_STACKPROTECTOR
75
76 config SUPERH64
77         def_bool ARCH = "sh64"
78         select HAVE_EXIT_THREAD
79         select KALLSYMS
80
81 config ARCH_DEFCONFIG
82         string
83         default "arch/sh/configs/shx3_defconfig" if SUPERH32
84         default "arch/sh/configs/cayman_defconfig" if SUPERH64
85
86 config RWSEM_GENERIC_SPINLOCK
87         def_bool y
88
89 config RWSEM_XCHGADD_ALGORITHM
90         bool
91
92 config GENERIC_BUG
93         def_bool y
94         depends on BUG && SUPERH32
95
96 config GENERIC_CSUM
97         def_bool y
98         depends on SUPERH64
99
100 config GENERIC_HWEIGHT
101         def_bool y
102
103 config GENERIC_CALIBRATE_DELAY
104         bool
105
106 config GENERIC_LOCKBREAK
107         def_bool y
108         depends on SMP && PREEMPT
109
110 config ARCH_SUSPEND_POSSIBLE
111         def_bool n
112
113 config ARCH_HIBERNATION_POSSIBLE
114         def_bool n
115
116 config SYS_SUPPORTS_APM_EMULATION
117         bool
118         select ARCH_SUSPEND_POSSIBLE
119
120 config SYS_SUPPORTS_HUGETLBFS
121         bool
122
123 config SYS_SUPPORTS_SMP
124         bool
125
126 config SYS_SUPPORTS_NUMA
127         bool
128
129 config SYS_SUPPORTS_PCI
130         bool
131
132 config STACKTRACE_SUPPORT
133         def_bool y
134
135 config LOCKDEP_SUPPORT
136         def_bool y
137
138 config ARCH_HAS_ILOG2_U32
139         def_bool n
140
141 config ARCH_HAS_ILOG2_U64
142         def_bool n
143
144 config NO_IOPORT_MAP
145         def_bool !PCI
146         depends on !SH_CAYMAN && !SH_SH4202_MICRODEV && !SH_SHMIN && \
147                    !SH_HP6XX && !SH_SOLUTION_ENGINE
148
149 config IO_TRAPPED
150         bool
151
152 config SWAP_IO_SPACE
153         bool
154
155 config DMA_COHERENT
156         bool
157
158 config DMA_NONCOHERENT
159         def_bool !DMA_COHERENT
160
161 config NEED_DMA_MAP_STATE
162         def_bool DMA_NONCOHERENT
163
164 config NEED_SG_DMA_LENGTH
165         def_bool y
166
167 config PGTABLE_LEVELS
168         default 3 if X2TLB
169         default 2
170
171 source "init/Kconfig"
172
173 source "kernel/Kconfig.freezer"
174
175 menu "System type"
176
177 #
178 # Processor families
179 #
180 config CPU_SH2
181         bool
182         select SH_INTC
183
184 config CPU_SH2A
185         bool
186         select CPU_SH2
187         select UNCACHED_MAPPING
188
189 config CPU_J2
190         bool
191         select CPU_SH2
192         select OF
193         select OF_EARLY_FLATTREE
194
195 config CPU_SH3
196         bool
197         select CPU_HAS_INTEVT
198         select CPU_HAS_SR_RB
199         select SH_INTC
200         select SYS_SUPPORTS_SH_TMU
201
202 config CPU_SH4
203         bool
204         select CPU_HAS_INTEVT
205         select CPU_HAS_SR_RB
206         select CPU_HAS_FPU if !CPU_SH4AL_DSP
207         select SH_INTC
208         select SYS_SUPPORTS_SH_TMU
209         select SYS_SUPPORTS_HUGETLBFS if MMU
210
211 config CPU_SH4A
212         bool
213         select CPU_SH4
214
215 config CPU_SH4AL_DSP
216         bool
217         select CPU_SH4A
218         select CPU_HAS_DSP
219
220 config CPU_SH5
221         bool
222         select CPU_HAS_FPU
223         select SYS_SUPPORTS_SH_TMU
224         select SYS_SUPPORTS_HUGETLBFS if MMU
225
226 config CPU_SHX2
227         bool
228
229 config CPU_SHX3
230         bool
231         select DMA_COHERENT
232         select SYS_SUPPORTS_SMP
233         select SYS_SUPPORTS_NUMA
234
235 config ARCH_SHMOBILE
236         bool
237         select ARCH_SUSPEND_POSSIBLE
238         select PM
239
240 config CPU_HAS_PMU
241        depends on CPU_SH4 || CPU_SH4A
242        default y
243        bool
244
245 if SUPERH32
246
247 choice
248         prompt "Processor sub-type selection"
249
250 #
251 # Processor subtypes
252 #
253
254 # SH-2 Processor Support
255
256 config CPU_SUBTYPE_SH7619
257         bool "Support SH7619 processor"
258         select CPU_SH2
259         select SYS_SUPPORTS_SH_CMT
260
261 config CPU_SUBTYPE_J2
262         bool "Support J2 processor"
263         select CPU_J2
264
265 # SH-2A Processor Support
266
267 config CPU_SUBTYPE_SH7201
268         bool "Support SH7201 processor"
269         select CPU_SH2A
270         select CPU_HAS_FPU
271         select SYS_SUPPORTS_SH_MTU2
272  
273 config CPU_SUBTYPE_SH7203
274         bool "Support SH7203 processor"
275         select CPU_SH2A
276         select CPU_HAS_FPU
277         select SYS_SUPPORTS_SH_CMT
278         select SYS_SUPPORTS_SH_MTU2
279         select PINCTRL
280
281 config CPU_SUBTYPE_SH7206
282         bool "Support SH7206 processor"
283         select CPU_SH2A
284         select SYS_SUPPORTS_SH_CMT
285         select SYS_SUPPORTS_SH_MTU2
286
287 config CPU_SUBTYPE_SH7263
288         bool "Support SH7263 processor"
289         select CPU_SH2A
290         select CPU_HAS_FPU
291         select SYS_SUPPORTS_SH_CMT
292         select SYS_SUPPORTS_SH_MTU2
293
294 config CPU_SUBTYPE_SH7264
295         bool "Support SH7264 processor"
296         select CPU_SH2A
297         select CPU_HAS_FPU
298         select SYS_SUPPORTS_SH_CMT
299         select SYS_SUPPORTS_SH_MTU2
300         select PINCTRL
301
302 config CPU_SUBTYPE_SH7269
303         bool "Support SH7269 processor"
304         select CPU_SH2A
305         select CPU_HAS_FPU
306         select SYS_SUPPORTS_SH_CMT
307         select SYS_SUPPORTS_SH_MTU2
308         select PINCTRL
309
310 config CPU_SUBTYPE_MXG
311         bool "Support MX-G processor"
312         select CPU_SH2A
313         select SYS_SUPPORTS_SH_MTU2
314         help
315           Select MX-G if running on an R8A03022BG part.
316
317 # SH-3 Processor Support
318
319 config CPU_SUBTYPE_SH7705
320         bool "Support SH7705 processor"
321         select CPU_SH3
322
323 config CPU_SUBTYPE_SH7706
324         bool "Support SH7706 processor"
325         select CPU_SH3
326         help
327           Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
328
329 config CPU_SUBTYPE_SH7707
330         bool "Support SH7707 processor"
331         select CPU_SH3
332         help
333           Select SH7707 if you have a  60 Mhz SH-3 HD6417707 CPU.
334
335 config CPU_SUBTYPE_SH7708
336         bool "Support SH7708 processor"
337         select CPU_SH3
338         help
339           Select SH7708 if you have a  60 Mhz SH-3 HD6417708S or
340           if you have a 100 Mhz SH-3 HD6417708R CPU.
341
342 config CPU_SUBTYPE_SH7709
343         bool "Support SH7709 processor"
344         select CPU_SH3
345         help
346           Select SH7709 if you have a  80 Mhz SH-3 HD6417709 CPU.
347
348 config CPU_SUBTYPE_SH7710
349         bool "Support SH7710 processor"
350         select CPU_SH3
351         select CPU_HAS_DSP
352         help
353           Select SH7710 if you have a SH3-DSP SH7710 CPU.
354
355 config CPU_SUBTYPE_SH7712
356         bool "Support SH7712 processor"
357         select CPU_SH3
358         select CPU_HAS_DSP
359         help
360           Select SH7712 if you have a SH3-DSP SH7712 CPU.
361
362 config CPU_SUBTYPE_SH7720
363         bool "Support SH7720 processor"
364         select CPU_SH3
365         select CPU_HAS_DSP
366         select SYS_SUPPORTS_SH_CMT
367         select USB_OHCI_SH if USB_OHCI_HCD
368         select PINCTRL
369         help
370           Select SH7720 if you have a SH3-DSP SH7720 CPU.
371
372 config CPU_SUBTYPE_SH7721
373         bool "Support SH7721 processor"
374         select CPU_SH3
375         select CPU_HAS_DSP
376         select SYS_SUPPORTS_SH_CMT
377         select USB_OHCI_SH if USB_OHCI_HCD
378         help
379           Select SH7721 if you have a SH3-DSP SH7721 CPU.
380
381 # SH-4 Processor Support
382
383 config CPU_SUBTYPE_SH7750
384         bool "Support SH7750 processor"
385         select CPU_SH4
386         help
387           Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
388
389 config CPU_SUBTYPE_SH7091
390         bool "Support SH7091 processor"
391         select CPU_SH4
392         help
393           Select SH7091 if you have an SH-4 based Sega device (such as
394           the Dreamcast, Naomi, and Naomi 2).
395
396 config CPU_SUBTYPE_SH7750R
397         bool "Support SH7750R processor"
398         select CPU_SH4
399
400 config CPU_SUBTYPE_SH7750S
401         bool "Support SH7750S processor"
402         select CPU_SH4
403
404 config CPU_SUBTYPE_SH7751
405         bool "Support SH7751 processor"
406         select CPU_SH4
407         help
408           Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
409           or if you have a HD6417751R CPU.
410
411 config CPU_SUBTYPE_SH7751R
412         bool "Support SH7751R processor"
413         select CPU_SH4
414
415 config CPU_SUBTYPE_SH7760
416         bool "Support SH7760 processor"
417         select CPU_SH4
418
419 config CPU_SUBTYPE_SH4_202
420         bool "Support SH4-202 processor"
421         select CPU_SH4
422
423 # SH-4A Processor Support
424
425 config CPU_SUBTYPE_SH7723
426         bool "Support SH7723 processor"
427         select CPU_SH4A
428         select CPU_SHX2
429         select ARCH_SHMOBILE
430         select ARCH_SPARSEMEM_ENABLE
431         select SYS_SUPPORTS_SH_CMT
432         select PINCTRL
433         help
434           Select SH7723 if you have an SH-MobileR2 CPU.
435
436 config CPU_SUBTYPE_SH7724
437         bool "Support SH7724 processor"
438         select CPU_SH4A
439         select CPU_SHX2
440         select ARCH_SHMOBILE
441         select ARCH_SPARSEMEM_ENABLE
442         select SYS_SUPPORTS_SH_CMT
443         select PINCTRL
444         help
445           Select SH7724 if you have an SH-MobileR2R CPU.
446
447 config CPU_SUBTYPE_SH7734
448         bool "Support SH7734 processor"
449         select CPU_SH4A
450         select CPU_SHX2
451         select PINCTRL
452         help
453           Select SH7734 if you have a SH4A SH7734 CPU.
454
455 config CPU_SUBTYPE_SH7757
456         bool "Support SH7757 processor"
457         select CPU_SH4A
458         select CPU_SHX2
459         select PINCTRL
460         help
461           Select SH7757 if you have a SH4A SH7757 CPU.
462
463 config CPU_SUBTYPE_SH7763
464         bool "Support SH7763 processor"
465         select CPU_SH4A
466         select USB_OHCI_SH if USB_OHCI_HCD
467         help
468           Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
469
470 config CPU_SUBTYPE_SH7770
471         bool "Support SH7770 processor"
472         select CPU_SH4A
473
474 config CPU_SUBTYPE_SH7780
475         bool "Support SH7780 processor"
476         select CPU_SH4A
477
478 config CPU_SUBTYPE_SH7785
479         bool "Support SH7785 processor"
480         select CPU_SH4A
481         select CPU_SHX2
482         select ARCH_SPARSEMEM_ENABLE
483         select SYS_SUPPORTS_NUMA
484         select PINCTRL
485
486 config CPU_SUBTYPE_SH7786
487         bool "Support SH7786 processor"
488         select CPU_SH4A
489         select CPU_SHX3
490         select CPU_HAS_PTEAEX
491         select GENERIC_CLOCKEVENTS_BROADCAST if SMP
492         select USB_OHCI_SH if USB_OHCI_HCD
493         select USB_EHCI_SH if USB_EHCI_HCD
494         select PINCTRL
495
496 config CPU_SUBTYPE_SHX3
497         bool "Support SH-X3 processor"
498         select CPU_SH4A
499         select CPU_SHX3
500         select GENERIC_CLOCKEVENTS_BROADCAST if SMP
501         select GPIOLIB
502         select PINCTRL
503
504 # SH4AL-DSP Processor Support
505
506 config CPU_SUBTYPE_SH7343
507         bool "Support SH7343 processor"
508         select CPU_SH4AL_DSP
509         select ARCH_SHMOBILE
510         select SYS_SUPPORTS_SH_CMT
511
512 config CPU_SUBTYPE_SH7722
513         bool "Support SH7722 processor"
514         select CPU_SH4AL_DSP
515         select CPU_SHX2
516         select ARCH_SHMOBILE
517         select ARCH_SPARSEMEM_ENABLE
518         select SYS_SUPPORTS_NUMA
519         select SYS_SUPPORTS_SH_CMT
520         select PINCTRL
521
522 config CPU_SUBTYPE_SH7366
523         bool "Support SH7366 processor"
524         select CPU_SH4AL_DSP
525         select CPU_SHX2
526         select ARCH_SHMOBILE
527         select ARCH_SPARSEMEM_ENABLE
528         select SYS_SUPPORTS_NUMA
529         select SYS_SUPPORTS_SH_CMT
530
531 endchoice
532
533 endif
534
535 if SUPERH64
536
537 choice
538         prompt "Processor sub-type selection"
539
540 # SH-5 Processor Support
541
542 config CPU_SUBTYPE_SH5_101
543         bool "Support SH5-101 processor"
544         select CPU_SH5
545
546 config CPU_SUBTYPE_SH5_103
547         bool "Support SH5-103 processor"
548         select CPU_SH5
549
550 endchoice
551
552 endif
553
554 source "arch/sh/mm/Kconfig"
555  
556 source "arch/sh/Kconfig.cpu"
557
558 source "arch/sh/boards/Kconfig"
559
560 menu "Timer and clock configuration"
561
562 config SH_PCLK_FREQ
563         int "Peripheral clock frequency (in Hz)"
564         depends on SH_CLK_CPG_LEGACY
565         default "31250000" if CPU_SUBTYPE_SH7619
566         default "33333333" if CPU_SUBTYPE_SH7770 || \
567                               CPU_SUBTYPE_SH7760 || \
568                               CPU_SUBTYPE_SH7705 || \
569                               CPU_SUBTYPE_SH7203 || \
570                               CPU_SUBTYPE_SH7206 || \
571                               CPU_SUBTYPE_SH7263 || \
572                               CPU_SUBTYPE_MXG
573         default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
574         default "66000000" if CPU_SUBTYPE_SH4_202
575         default "50000000"
576         help
577           This option is used to specify the peripheral clock frequency.
578           This is necessary for determining the reference clock value on
579           platforms lacking an RTC.
580
581 config SH_CLK_CPG
582         def_bool y
583
584 config SH_CLK_CPG_LEGACY
585         depends on SH_CLK_CPG
586         def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE && \
587                       !CPU_SHX3 && !CPU_SUBTYPE_SH7757 && \
588                       !CPU_SUBTYPE_SH7734 && !CPU_SUBTYPE_SH7264 && \
589                       !CPU_SUBTYPE_SH7269
590
591 endmenu
592
593 menu "CPU Frequency scaling"
594 source "drivers/cpufreq/Kconfig"
595 endmenu
596
597 source "arch/sh/drivers/Kconfig"
598
599 endmenu
600
601 menu "Kernel features"
602
603 source kernel/Kconfig.hz
604
605 config KEXEC
606         bool "kexec system call (EXPERIMENTAL)"
607         depends on SUPERH32 && MMU
608         select KEXEC_CORE
609         help
610           kexec is a system call that implements the ability to shutdown your
611           current kernel, and to start another kernel.  It is like a reboot
612           but it is independent of the system firmware.  And like a reboot
613           you can start any kernel with it, not just Linux.
614
615           The name comes from the similarity to the exec system call.
616
617           It is an ongoing process to be certain the hardware in a machine
618           is properly shutdown, so do not be surprised if this code does not
619           initially work for you.  As of this writing the exact hardware
620           interface is strongly in flux, so no good recommendation can be
621           made.
622
623 config CRASH_DUMP
624         bool "kernel crash dumps (EXPERIMENTAL)"
625         depends on SUPERH32 && BROKEN_ON_SMP
626         help
627           Generate crash dump after being started by kexec.
628           This should be normally only set in special crash dump kernels
629           which are loaded in the main kernel with kexec-tools into
630           a specially reserved region and then later executed after
631           a crash by kdump/kexec. The crash dump kernel must be compiled
632           to a memory address not used by the main kernel using
633           PHYSICAL_START.
634
635           For more details see Documentation/kdump/kdump.txt
636
637 config KEXEC_JUMP
638         bool "kexec jump (EXPERIMENTAL)"
639         depends on SUPERH32 && KEXEC && HIBERNATION
640         help
641           Jump between original kernel and kexeced kernel and invoke
642           code via KEXEC
643
644 config PHYSICAL_START
645         hex "Physical address where the kernel is loaded" if (EXPERT || CRASH_DUMP)
646         default MEMORY_START
647         ---help---
648           This gives the physical address where the kernel is loaded
649           and is ordinarily the same as MEMORY_START.
650
651           Different values are primarily used in the case of kexec on panic
652           where the fail safe kernel needs to run at a different address
653           than the panic-ed kernel.
654
655 config SECCOMP
656         bool "Enable seccomp to safely compute untrusted bytecode"
657         depends on PROC_FS
658         help
659           This kernel feature is useful for number crunching applications
660           that may need to compute untrusted bytecode during their
661           execution. By using pipes or other transports made available to
662           the process as file descriptors supporting the read/write
663           syscalls, it's possible to isolate those applications in
664           their own address space using seccomp. Once seccomp is
665           enabled via prctl, it cannot be disabled and the task is only
666           allowed to execute a few safe syscalls defined by each seccomp
667           mode.
668
669           If unsure, say N.
670
671 config SMP
672         bool "Symmetric multi-processing support"
673         depends on SYS_SUPPORTS_SMP
674         ---help---
675           This enables support for systems with more than one CPU. If you have
676           a system with only one CPU, say N. If you have a system with more
677           than one CPU, say Y.
678
679           If you say N here, the kernel will run on uni- and multiprocessor
680           machines, but will use only one CPU of a multiprocessor machine. If
681           you say Y here, the kernel will run on many, but not all,
682           uniprocessor machines. On a uniprocessor machine, the kernel
683           will run faster if you say N here.
684
685           People using multiprocessor machines who say Y here should also say
686           Y to "Enhanced Real Time Clock Support", below.
687
688           See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
689           available at <http://www.tldp.org/docs.html#howto>.
690
691           If you don't know what to do here, say N.
692
693 config NR_CPUS
694         int "Maximum number of CPUs (2-32)"
695         range 2 32
696         depends on SMP
697         default "4" if CPU_SUBTYPE_SHX3
698         default "2"
699         help
700           This allows you to specify the maximum number of CPUs which this
701           kernel will support.  The maximum supported value is 32 and the
702           minimum value which makes sense is 2.
703
704           This is purely to save memory - each supported CPU adds
705           approximately eight kilobytes to the kernel image.
706
707 config HOTPLUG_CPU
708         bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
709         depends on SMP
710         help
711           Say Y here to experiment with turning CPUs off and on.  CPUs
712           can be controlled through /sys/devices/system/cpu.
713
714 source "kernel/Kconfig.preempt"
715
716 config GUSA
717         def_bool y
718         depends on !SMP && SUPERH32
719         help
720           This enables support for gUSA (general UserSpace Atomicity).
721           This is the default implementation for both UP and non-ll/sc
722           CPUs, and is used by the libc, amongst others.
723
724           For additional information, design information can be found 
725           in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
726
727           This should only be disabled for special cases where alternate
728           atomicity implementations exist.
729
730 config GUSA_RB
731         bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
732         depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
733         help
734           Enabling this option will allow the kernel to implement some
735           atomic operations using a software implementation of load-locked/
736           store-conditional (LLSC). On machines which do not have hardware
737           LLSC, this should be more efficient than the other alternative of
738           disabling interrupts around the atomic sequence.
739
740 config HW_PERF_EVENTS
741         bool "Enable hardware performance counter support for perf events"
742         depends on PERF_EVENTS && CPU_HAS_PMU
743         default y
744         help
745           Enable hardware performance counter support for perf events. If
746           disabled, perf events will use software events only.
747
748 source "drivers/sh/Kconfig"
749
750 endmenu
751
752 menu "Boot options"
753
754 config USE_BUILTIN_DTB
755         bool "Use builtin DTB"
756         default n
757         depends on SH_DEVICE_TREE
758         help
759           Link a device tree blob for particular hardware into the kernel,
760           suppressing use of the DTB pointer provided by the bootloader.
761           This option should only be used with legacy bootloaders that are
762           not capable of providing a DTB to the kernel, or for experimental
763           hardware without stable device tree bindings.
764
765 config BUILTIN_DTB_SOURCE
766         string "Source file for builtin DTB"
767         default ""
768         depends on USE_BUILTIN_DTB
769         help
770           Base name (without suffix, relative to arch/sh/boot/dts) for the
771           a DTS file that will be used to produce the DTB linked into the
772           kernel.
773
774 config ZERO_PAGE_OFFSET
775         hex
776         default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
777                                 SH_7751_SOLUTION_ENGINE
778         default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
779         default "0x00002000" if PAGE_SIZE_8KB
780         default "0x00001000"
781         help
782           This sets the default offset of zero page.
783
784 config BOOT_LINK_OFFSET
785         hex
786         default "0x00210000" if SH_SHMIN
787         default "0x00400000" if SH_CAYMAN
788         default "0x00810000" if SH_7780_SOLUTION_ENGINE
789         default "0x009e0000" if SH_TITAN
790         default "0x01800000" if SH_SDK7780
791         default "0x02000000" if SH_EDOSK7760
792         default "0x00800000"
793         help
794           This option allows you to set the link address offset of the zImage.
795           This can be useful if you are on a board which has a small amount of
796           memory.
797
798 config ENTRY_OFFSET
799         hex
800         default "0x00001000" if PAGE_SIZE_4KB
801         default "0x00002000" if PAGE_SIZE_8KB
802         default "0x00004000" if PAGE_SIZE_16KB
803         default "0x00010000" if PAGE_SIZE_64KB
804         default "0x00000000"
805
806 config ROMIMAGE_MMCIF
807         bool "Include MMCIF loader in romImage (EXPERIMENTAL)"
808         depends on CPU_SUBTYPE_SH7724
809         help
810           Say Y here to include experimental MMCIF loading code in
811           romImage. With this enabled it is possible to write the romImage
812           kernel image to an MMC card and boot the kernel straight from
813           the reset vector. At reset the processor Mask ROM will load the
814           first part of the romImage which in turn loads the rest the kernel
815           image to RAM using the MMCIF hardware block.
816
817 choice
818         prompt "Kernel command line"
819         optional
820         default CMDLINE_OVERWRITE
821         help
822           Setting this option allows the kernel command line arguments
823           to be set.
824
825 config CMDLINE_OVERWRITE
826         bool "Overwrite bootloader kernel arguments"
827         help
828           Given string will overwrite any arguments passed in by
829           a bootloader.
830
831 config CMDLINE_EXTEND
832         bool "Extend bootloader kernel arguments"
833         help
834           Given string will be concatenated with arguments passed in
835           by a bootloader.
836
837 endchoice
838
839 config CMDLINE
840         string "Kernel command line arguments string"
841         depends on CMDLINE_OVERWRITE || CMDLINE_EXTEND
842         default "console=ttySC1,115200"
843
844 endmenu
845
846 menu "Bus options"
847
848 config SUPERHYWAY
849         tristate "SuperHyway Bus support"
850         depends on CPU_SUBTYPE_SH4_202
851
852 config MAPLE
853         bool "Maple Bus support"
854         depends on SH_DREAMCAST
855         help
856          The Maple Bus is SEGA's serial communication bus for peripherals
857          on the Dreamcast. Without this bus support you won't be able to
858          get your Dreamcast keyboard etc to work, so most users
859          probably want to say 'Y' here, unless you are only using the
860          Dreamcast with a serial line terminal or a remote network
861          connection.
862
863 config PCI
864         bool "PCI support"
865         depends on SYS_SUPPORTS_PCI
866         select PCI_DOMAINS
867         select GENERIC_PCI_IOMAP
868         select NO_GENERIC_PCI_IOPORT_MAP
869         help
870           Find out whether you have a PCI motherboard. PCI is the name of a
871           bus system, i.e. the way the CPU talks to the other stuff inside
872           your box. If you have PCI, say Y, otherwise N.
873
874 config PCI_DOMAINS
875         bool
876
877 source "drivers/pci/Kconfig"
878
879 source "drivers/pcmcia/Kconfig"
880
881 endmenu
882
883 menu "Executable file formats"
884
885 source "fs/Kconfig.binfmt"
886
887 endmenu
888
889 menu "Power management options (EXPERIMENTAL)"
890
891 source "kernel/power/Kconfig"
892
893 source "drivers/cpuidle/Kconfig"
894
895 endmenu
896
897 source "net/Kconfig"
898
899 source "drivers/Kconfig"
900
901 source "fs/Kconfig"
902
903 source "arch/sh/Kconfig.debug"
904
905 source "security/Kconfig"
906
907 source "crypto/Kconfig"
908
909 source "lib/Kconfig"