sh: SHMIN board support.
[linux-2.6.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         bool
10         default y
11         help
12           The SuperH is a RISC processor targeted for use in embedded systems
13           and consumer electronics; it was also used in the Sega Dreamcast
14           gaming console.  The SuperH port has a home page at
15           <http://www.linux-sh.org/>.
16
17 config RWSEM_GENERIC_SPINLOCK
18         bool
19         default y
20
21 config RWSEM_XCHGADD_ALGORITHM
22         bool
23
24 config GENERIC_FIND_NEXT_BIT
25         bool
26         default y
27
28 config GENERIC_HWEIGHT
29         bool
30         default y
31
32 config GENERIC_HARDIRQS
33         bool
34         default y
35
36 config GENERIC_IRQ_PROBE
37         bool
38         default y
39
40 config GENERIC_CALIBRATE_DELAY
41         bool
42         default y
43
44 config GENERIC_IOMAP
45         bool
46
47 config ARCH_MAY_HAVE_PC_FDC
48         bool
49
50 source "init/Kconfig"
51
52 menu "System type"
53
54 choice
55         prompt "SuperH system type"
56         default SH_UNKNOWN
57
58 config SH_SOLUTION_ENGINE
59         bool "SolutionEngine"
60         help
61           Select SolutionEngine if configuring for a Hitachi SH7709
62           or SH7750 evaluation board.
63
64 config SH_7751_SOLUTION_ENGINE
65         bool "SolutionEngine7751"
66         select CPU_SUBTYPE_SH7751
67         help
68           Select 7751 SolutionEngine if configuring for a Hitachi SH7751
69           evaluation board.
70
71 config SH_7300_SOLUTION_ENGINE
72         bool "SolutionEngine7300"
73         select CPU_SUBTYPE_SH7300
74         help
75           Select 7300 SolutionEngine if configuring for a Hitachi SH7300(SH-Mobile V)
76           evaluation board.
77
78 config SH_73180_SOLUTION_ENGINE
79        bool "SolutionEngine73180"
80        select CPU_SUBTYPE_SH73180
81        help
82          Select 73180 SolutionEngine if configuring for a Hitachi SH73180(SH-Mobile 3)
83          evaluation board.
84
85 config SH_7751_SYSTEMH
86         bool "SystemH7751R"
87         select CPU_SUBTYPE_SH7751R
88         help
89           Select SystemH if you are configuring for a Renesas SystemH
90           7751R evaluation board.
91
92 config SH_STB1_HARP
93         bool "STB1_Harp"
94
95 config SH_STB1_OVERDRIVE
96         bool "STB1_Overdrive"
97
98 config SH_HP6XX
99         bool "HP6XX"
100         help
101           Select HP6XX if configuring for a HP jornada HP6xx.
102           More information (hardware only) at
103           <http://www.hp.com/jornada/>.
104
105 config SH_CQREEK
106         bool "CqREEK"
107         help
108           Select CqREEK if configuring for a CqREEK SH7708 or SH7750.
109           More information at
110           <http://sources.redhat.com/ecos/hardware.html#SuperH>.
111
112 config SH_DMIDA
113         bool "DMIDA"
114         help
115           Select DMIDA if configuring for a DataMyte 4000 Industrial
116           Digital Assistant. More information at <http://www.dmida.com/>.
117
118 config SH_EC3104
119         bool "EC3104"
120         help
121           Select EC3104 if configuring for a system with an Eclipse
122           International EC3104 chip, e.g. the Harris AD2000.
123
124 config SH_SATURN
125         bool "Saturn"
126         select CPU_SUBTYPE_SH7604
127         help
128           Select Saturn if configuring for a SEGA Saturn.
129
130 config SH_DREAMCAST
131         bool "Dreamcast"
132         select CPU_SUBTYPE_SH7091
133         help
134           Select Dreamcast if configuring for a SEGA Dreamcast.
135           More information at
136           <http://www.m17n.org/linux-sh/dreamcast/>.  There is a
137           Dreamcast project is at <http://linuxdc.sourceforge.net/>.
138
139 config SH_CAT68701
140         bool "CAT68701"
141
142 config SH_BIGSUR
143         bool "BigSur"
144
145 config SH_SH2000
146         bool "SH2000"
147         select CPU_SUBTYPE_SH7709
148         help
149           SH-2000 is a single-board computer based around SH7709A chip
150           intended for embedded applications.
151           It has an Ethernet interface (CS8900A), direct connected
152           Compact Flash socket, three serial ports and PC-104 bus.
153           More information at <http://sh2000.sh-linux.org>.
154
155 config SH_ADX
156         bool "ADX"
157
158 config SH_MPC1211
159         bool "Interface MPC1211"
160         help
161           CTP/PCI-SH02 is a CPU module computer that is produced
162           by Interface Corporation.
163           More information at <http://www.interface.co.jp>
164
165 config SH_SH03
166         bool "Interface CTP/PCI-SH03"
167         help
168           CTP/PCI-SH03 is a CPU module computer that is produced
169           by Interface Corporation.
170           More information at <http://www.interface.co.jp>
171
172 config SH_SECUREEDGE5410
173         bool "SecureEdge5410"
174         select CPU_SUBTYPE_SH7751R
175         help
176           Select SecureEdge5410 if configuring for a SnapGear SH board.
177           This includes both the OEM SecureEdge products as well as the
178           SME product line.
179
180 config SH_HS7751RVOIP
181         bool "HS7751RVOIP"
182         select CPU_SUBTYPE_SH7751R
183         help
184           Select HS7751RVOIP if configuring for a Renesas Technology
185           Sales VoIP board.
186
187 config SH_RTS7751R2D
188         bool "RTS7751R2D"
189         select CPU_SUBTYPE_SH7751R
190         help
191           Select RTS7751R2D if configuring for a Renesas Technology
192           Sales SH-Graphics board.
193
194 config SH_R7780RP
195         bool "R7780RP-1"
196         select CPU_SUBTYPE_SH7780
197         help
198           Select R7780RP-1 if configuring for a Renesas Solutions
199           HIGHLANDER board.
200
201 config SH_EDOSK7705
202         bool "EDOSK7705"
203         select CPU_SUBTYPE_SH7705
204
205 config SH_SH4202_MICRODEV
206         bool "SH4-202 MicroDev"
207         select CPU_SUBTYPE_SH4_202
208         help
209           Select SH4-202 MicroDev if configuring for a SuperH MicroDev board
210           with an SH4-202 CPU.
211
212 config SH_LANDISK
213         bool "LANDISK"
214         select CPU_SUBTYPE_SH7751R
215         help
216           I-O DATA DEVICE, INC. "LANDISK Series" support.
217
218 config SH_TITAN
219         bool "TITAN"
220         select CPU_SUBTYPE_SH7751R
221         help
222           Select Titan if you are configuring for a Nimble Microsystems
223           NetEngine NP51R.
224
225 config SH_SHMIN
226         bool "SHMIN"
227         select CPU_SUBTYPE_SH7706
228         help
229           Select SHMIN if configureing for the SHMIN board
230
231 config SH_UNKNOWN
232         bool "BareCPU"
233         help
234           "Bare CPU" aka "unknown" means an SH-based system which is not one
235           of the specific ones mentioned above, which means you need to enter
236           all sorts of stuff like CONFIG_MEMORY_START because the config
237           system doesn't already know what it is.  You get a machine vector
238           without any platform-specific code in it, so things like the RTC may
239           not work.
240
241           This option is for the early stages of porting to a new machine.
242
243 endchoice
244
245 source "arch/sh/mm/Kconfig"
246
247 config CF_ENABLER
248         bool "Compact Flash Enabler support"
249         depends on SH_ADX || SH_SOLUTION_ENGINE || SH_UNKNOWN || SH_CAT68701 || SH_SH03
250         ---help---
251           Compact Flash is a small, removable mass storage device introduced
252           in 1994 originally as a PCMCIA device.  If you say `Y' here, you
253           compile in support for Compact Flash devices directly connected to
254           a SuperH processor.  A Compact Flash FAQ is available at
255           <http://www.compactflash.org/faqs/faq.htm>.
256
257           If your board has "Directly Connected" CompactFlash at area 5 or 6,
258           you may want to enable this option.  Then, you can use CF as
259           primary IDE drive (only tested for SanDisk).
260
261           If in doubt, select 'N'.
262
263 choice
264         prompt "Compact Flash Connection Area"
265         depends on CF_ENABLER
266         default CF_AREA6
267
268 config CF_AREA5
269         bool "Area5"
270         help
271           If your board has "Directly Connected" CompactFlash, You should
272           select the area where your CF is connected to.
273
274           - "Area5" if CompactFlash is connected to Area 5 (0x14000000)
275           - "Area6" if it is connected to Area 6 (0x18000000)
276
277           "Area6" will work for most boards. For ADX, select "Area5".
278
279 config CF_AREA6
280         bool "Area6"
281
282 endchoice
283
284 config CF_BASE_ADDR
285         hex
286         depends on CF_ENABLER
287         default "0xb8000000" if CF_AREA6
288         default "0xb4000000" if CF_AREA5
289
290 menu "Processor features"
291
292 config CPU_LITTLE_ENDIAN
293         bool "Little Endian"
294         help
295           Some SuperH machines can be configured for either little or big
296           endian byte order. These modes require different kernels. Say Y if
297           your machine is little endian, N if it's a big endian machine.
298
299 # The SH7750 RTC module is disabled in the Dreamcast
300 config SH_RTC
301         bool
302         depends on !SH_DREAMCAST && !SH_SATURN && !SH_7300_SOLUTION_ENGINE && \
303                    !SH_73180_SOLUTION_ENGINE && !SH_LANDISK && \
304                    !SH_R7780RP && !SH_SHMIN
305         default y
306         help
307           Selecting this option will allow the Linux kernel to emulate
308           PC's RTC.
309
310           If unsure, say N.
311
312 config SH_FPU
313         bool "FPU support"
314         depends on !CPU_SH3
315         default y
316         help
317           Selecting this option will enable support for SH processors that
318           have FPU units (ie, SH77xx).
319
320           This option must be set in order to enable the FPU.
321
322 config SH_FPU_EMU
323         bool "FPU emulation support"
324         depends on !SH_FPU && EXPERIMENTAL
325         default n
326         help
327           Selecting this option will enable support for software FPU emulation.
328           Most SH-3 users will want to say Y here, whereas most SH-4 users will
329           want to say N.
330
331 config SH_DSP
332         bool "DSP support"
333         default y if SH4AL_DSP || !CPU_SH4
334         default n
335         help
336           Selecting this option will enable support for SH processors that
337           have DSP units (ie, SH2-DSP, SH3-DSP, and SH4AL-DSP).
338
339           This option must be set in order to enable the DSP.
340
341 config SH_ADC
342         bool "ADC support"
343         depends on CPU_SH3
344         default y
345         help
346           Selecting this option will allow the Linux kernel to use SH3 on-chip
347           ADC module.
348
349           If unsure, say N.
350
351 config SH_STORE_QUEUES
352         bool "Support for Store Queues"
353         depends on CPU_SH4
354         help
355           Selecting this option will enable an in-kernel API for manipulating
356           the store queues integrated in the SH-4 processors.
357
358 config CPU_HAS_INTEVT
359         bool
360
361 config CPU_HAS_PINT_IRQ
362         bool
363
364 config CPU_HAS_INTC2_IRQ
365         bool
366
367 config CPU_HAS_SR_RB
368         bool "CPU has SR.RB"
369         depends on CPU_SH3 || CPU_SH4
370         default y
371         help
372           This will enable the use of SR.RB register bank usage. Processors
373           that are lacking this bit must have another method in place for
374           accomplishing what is taken care of by the banked registers.
375
376           See <file:Documentation/sh/register-banks.txt> for further
377           information on SR.RB and register banking in the kernel in general.
378
379 endmenu
380
381 menu "Timer support"
382
383 config SH_TMU
384         bool "TMU timer support"
385         default y
386         help
387           This enables the use of the TMU as the system timer.
388
389 endmenu
390
391 source "arch/sh/boards/renesas/hs7751rvoip/Kconfig"
392
393 source "arch/sh/boards/renesas/rts7751r2d/Kconfig"
394
395 source "arch/sh/boards/renesas/r7780rp/Kconfig"
396
397 config SH_PCLK_FREQ
398         int "Peripheral clock frequency (in Hz)"
399         default "50000000" if CPU_SUBTYPE_SH7750 || CPU_SUBTYPE_SH7780
400         default "60000000" if CPU_SUBTYPE_SH7751
401         default "33333333" if CPU_SUBTYPE_SH7300 || CPU_SUBTYPE_SH7770 || \
402                               CPU_SUBTYPE_SH7760
403         default "27000000" if CPU_SUBTYPE_SH73180 || CPU_SUBTYPE_SH7343
404         default "66000000" if CPU_SUBTYPE_SH4_202
405         help
406           This option is used to specify the peripheral clock frequency.
407           This is necessary for determining the reference clock value on
408           platforms lacking an RTC.
409
410 menu "CPU Frequency scaling"
411
412 source "drivers/cpufreq/Kconfig"
413
414 config SH_CPU_FREQ
415         tristate "SuperH CPU Frequency driver"
416         depends on CPU_FREQ
417         select CPU_FREQ_TABLE
418         help
419           This adds the cpufreq driver for SuperH. At present, only
420           the SH-4 is supported.
421
422           For details, take a look at <file:Documentation/cpu-freq>.
423
424           If unsure, say N.
425
426 endmenu
427
428 source "arch/sh/drivers/dma/Kconfig"
429
430 source "arch/sh/cchips/Kconfig"
431
432 config HEARTBEAT
433         bool "Heartbeat LED"
434         depends on SH_MPC1211 || SH_SH03 || SH_CAT68701 || \
435                    SH_STB1_HARP || SH_STB1_OVERDRIVE || SH_BIGSUR || \
436                    SH_7751_SOLUTION_ENGINE || SH_7300_SOLUTION_ENGINE || \
437                    SH_73180_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || \
438                    SH_RTS7751R2D || SH_SH4202_MICRODEV || SH_LANDISK
439         help
440           Use the power-on LED on your machine as a load meter.  The exact
441           behavior is platform-dependent, but normally the flash frequency is
442           a hyperbolic function of the 5-minute load average.
443
444 endmenu
445
446 config ISA_DMA_API
447         bool
448         depends on SH_MPC1211
449         default y
450
451 menu "Kernel features"
452
453 config KEXEC
454         bool "kexec system call (EXPERIMENTAL)"
455         depends on EXPERIMENTAL
456         help
457           kexec is a system call that implements the ability to shutdown your
458           current kernel, and to start another kernel.  It is like a reboot
459           but it is independent of the system firmware.  And like a reboot
460           you can start any kernel with it, not just Linux.
461
462           The name comes from the similarity to the exec system call.
463
464           It is an ongoing process to be certain the hardware in a machine
465           is properly shutdown, so do not be surprised if this code does not
466           initially work for you.  It may help to enable device hotplugging
467           support.  As of this writing the exact hardware interface is
468           strongly in flux, so no good recommendation can be made.
469
470 config PREEMPT
471         bool "Preemptible Kernel (EXPERIMENTAL)"
472         depends on EXPERIMENTAL
473
474 config SMP
475         bool "Symmetric multi-processing support"
476         ---help---
477           This enables support for systems with more than one CPU. If you have
478           a system with only one CPU, like most personal computers, say N. If
479           you have a system with more than one CPU, say Y.
480
481           If you say N here, the kernel will run on single and multiprocessor
482           machines, but will use only one CPU of a multiprocessor machine. If
483           you say Y here, the kernel will run on many, but not all,
484           singleprocessor machines. On a singleprocessor machine, the kernel
485           will run faster if you say N here.
486
487           People using multiprocessor machines who say Y here should also say
488           Y to "Enhanced Real Time Clock Support", below.
489
490           See also the <file:Documentation/smp.txt>,
491           <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available
492           at <http://www.tldp.org/docs.html#howto>.
493
494           If you don't know what to do here, say N.
495
496 config NR_CPUS
497         int "Maximum number of CPUs (2-32)"
498         range 2 32
499         depends on SMP
500         default "2"
501         help
502           This allows you to specify the maximum number of CPUs which this
503           kernel will support.  The maximum supported value is 32 and the
504           minimum value which makes sense is 2.
505
506           This is purely to save memory - each supported CPU adds
507           approximately eight kilobytes to the kernel image.
508
509 config CPU_HAS_SR_RB
510         bool "CPU has SR.RB"
511         depends on CPU_SH3 || CPU_SH4
512         default y
513         help
514           This will enable the use of SR.RB register bank usage. Processors
515           that are lacking this bit must have another method in place for
516           accomplishing what is taken care of by the banked registers.
517
518           See <file:Documentation/sh/register-banks.txt> for further
519           information on SR.RB and register banking in the kernel in general.
520
521 config NODES_SHIFT
522         int
523         default "1"
524         depends on NEED_MULTIPLE_NODES
525
526 endmenu
527
528 menu "Boot options"
529
530 config ZERO_PAGE_OFFSET
531         hex "Zero page offset"
532         default "0x00004000" if SH_MPC1211 || SH_SH03
533         default "0x00001000"
534         help
535           This sets the default offset of zero page.
536
537 config BOOT_LINK_OFFSET
538         hex "Link address offset for booting"
539         default "0x00800000"
540         help
541           This option allows you to set the link address offset of the zImage.
542           This can be useful if you are on a board which has a small amount of
543           memory.
544
545 config UBC_WAKEUP
546         bool "Wakeup UBC on startup"
547         help
548           Selecting this option will wakeup the User Break Controller (UBC) on
549           startup. Although the UBC is left in an awake state when the processor
550           comes up, some boot loaders misbehave by putting the UBC to sleep in a
551           power saving state, which causes issues with things like ptrace().
552
553           If unsure, say N.
554
555 config CMDLINE_BOOL
556         bool "Default bootloader kernel arguments"
557
558 config CMDLINE
559         string "Initial kernel command string"
560         depends on CMDLINE_BOOL
561         default "console=ttySC1,115200"
562
563 endmenu
564
565 menu "Bus options"
566
567 # Even on SuperH devices which don't have an ISA bus,
568 # this variable helps the PCMCIA modules handle
569 # IRQ requesting properly -- Greg Banks.
570 #
571 # Though we're generally not interested in it when
572 # we're not using PCMCIA, so we make it dependent on
573 # PCMCIA outright. -- PFM.
574 config ISA
575         bool
576         default y if PCMCIA
577         help
578           Find out whether you have ISA slots on your motherboard.  ISA is the
579           name of a bus system, i.e. the way the CPU talks to the other stuff
580           inside your box.  Other bus systems are PCI, EISA, MicroChannel
581           (MCA) or VESA.  ISA is an older system, now being displaced by PCI;
582           newer boards don't support it.  If you have ISA, say Y, otherwise N.
583
584 config EISA
585         bool
586         ---help---
587           The Extended Industry Standard Architecture (EISA) bus was
588           developed as an open alternative to the IBM MicroChannel bus.
589
590           The EISA bus provided some of the features of the IBM MicroChannel
591           bus while maintaining backward compatibility with cards made for
592           the older ISA bus.  The EISA bus saw limited use between 1988 and
593           1995 when it was made obsolete by the PCI bus.
594
595           Say Y here if you are building a kernel for an EISA-based machine.
596
597           Otherwise, say N.
598
599 config MCA
600         bool
601         help
602           MicroChannel Architecture is found in some IBM PS/2 machines and
603           laptops.  It is a bus system similar to PCI or ISA. See
604           <file:Documentation/mca.txt> (and especially the web page given
605           there) before attempting to build an MCA bus kernel.
606
607 config SBUS
608         bool
609
610 config SUPERHYWAY
611         tristate "SuperHyway Bus support"
612         depends on CPU_SUBTYPE_SH4_202
613
614 source "arch/sh/drivers/pci/Kconfig"
615
616 source "drivers/pci/Kconfig"
617
618 source "drivers/pcmcia/Kconfig"
619
620 source "drivers/pci/hotplug/Kconfig"
621
622 endmenu
623
624 menu "Executable file formats"
625
626 source "fs/Kconfig.binfmt"
627
628 endmenu
629
630 menu "Power management options (EXPERIMENTAL)"
631 depends on EXPERIMENTAL
632
633 source kernel/power/Kconfig
634
635 config APM
636         bool "Advanced Power Management Emulation"
637         depends on PM
638 endmenu
639
640 source "net/Kconfig"
641
642 source "drivers/Kconfig"
643
644 source "fs/Kconfig"
645
646 source "arch/sh/oprofile/Kconfig"
647
648 source "arch/sh/Kconfig.debug"
649
650 source "security/Kconfig"
651
652 source "crypto/Kconfig"
653
654 source "lib/Kconfig"