upgrade to linux 2.6.10-1.12_FC2
[linux-2.6.git] / arch / sparc64 / Kconfig
1 # $Id: config.in,v 1.158 2002/01/24 22:14:44 davem Exp $
2 # For a description of the syntax of this configuration file,
3 # see the Configure script.
4 #
5
6 mainmenu "Linux/UltraSPARC Kernel Configuration"
7
8 config 64BIT
9         def_bool y
10
11 config MMU
12         bool
13         default y
14
15 config TIME_INTERPOLATION
16         bool
17         default y
18
19 source "init/Kconfig"
20
21 menu "General machine setup"
22
23 config BBC_I2C
24         tristate "UltraSPARC-III bootbus i2c controller driver"
25         depends on PCI
26         help
27           The BBC devices on the UltraSPARC III have two I2C controllers.  The
28           first I2C controller connects mainly to configuration PROMs (NVRAM,
29           CPU configuration, DIMM types, etc.).  The second I2C controller
30           connects to environmental control devices such as fans and
31           temperature sensors.  The second controller also connects to the
32           smartcard reader, if present.  Say Y to enable support for these.
33
34 config VT
35         bool "Virtual terminal" if EMBEDDED
36         select INPUT
37         default y
38         ---help---
39           If you say Y here, you will get support for terminal devices with
40           display and keyboard devices. These are called "virtual" because you
41           can run several virtual terminals (also called virtual consoles) on
42           one physical terminal. This is rather useful, for example one
43           virtual terminal can collect system messages and warnings, another
44           one can be used for a text-mode user session, and a third could run
45           an X session, all in parallel. Switching between virtual terminals
46           is done with certain key combinations, usually Alt-<function key>.
47
48           The setterm command ("man setterm") can be used to change the
49           properties (such as colors or beeping) of a virtual terminal. The
50           man page console_codes(4) ("man console_codes") contains the special
51           character sequences that can be used to change those properties
52           directly. The fonts used on virtual terminals can be changed with
53           the setfont ("man setfont") command and the key bindings are defined
54           with the loadkeys ("man loadkeys") command.
55
56           You need at least one virtual terminal device in order to make use
57           of your keyboard and monitor. Therefore, only people configuring an
58           embedded system would want to say N here in order to save some
59           memory; the only way to log into such a system is then via a serial
60           or network connection.
61
62           If unsure, say Y, or else you won't be able to do much with your new
63           shiny Linux system :-)
64
65 config VT_CONSOLE
66         bool "Support for console on virtual terminal" if EMBEDDED
67         depends on VT
68         default y
69         ---help---
70           The system console is the device which receives all kernel messages
71           and warnings and which allows logins in single user mode. If you
72           answer Y here, a virtual terminal (the device used to interact with
73           a physical terminal) can be used as system console. This is the most
74           common mode of operations, so you should say Y here unless you want
75           the kernel messages be output only to a serial port (in which case
76           you should say Y to "Console on serial port", below).
77
78           If you do say Y here, by default the currently visible virtual
79           terminal (/dev/tty0) will be used as system console. You can change
80           that with a kernel command line option such as "console=tty3" which
81           would use the third virtual terminal as system console. (Try "man
82           bootparam" or see the documentation of your boot loader (lilo or
83           loadlin) about how to pass options to the kernel at boot time.)
84
85           If unsure, say Y.
86
87 config HW_CONSOLE
88         bool
89         default y
90
91 config SMP
92         bool "Symmetric multi-processing support"
93         ---help---
94           This enables support for systems with more than one CPU. If you have
95           a system with only one CPU, like most personal computers, say N. If
96           you have a system with more than one CPU, say Y.
97
98           If you say N here, the kernel will run on single and multiprocessor
99           machines, but will use only one CPU of a multiprocessor machine. If
100           you say Y here, the kernel will run on many, but not all,
101           singleprocessor machines. On a singleprocessor machine, the kernel
102           will run faster if you say N here.
103
104           Note that if you say Y here and choose architecture "586" or
105           "Pentium" under "Processor family", the kernel will not work on 486
106           architectures. Similarly, multiprocessor kernels for the "PPro"
107           architecture may not work on all Pentium based boards.
108
109           People using multiprocessor machines who say Y here should also say
110           Y to "Enhanced Real Time Clock Support", below. The "Advanced Power
111           Management" code will be disabled if you say Y here.
112
113           See also the <file:Documentation/smp.txt>,
114           <file:Documentation/i386/IO-APIC.txt>,
115           <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
116           <http://www.tldp.org/docs.html#howto>.
117
118           If you don't know what to do here, say N.
119
120 config PREEMPT
121         bool "Preemptible Kernel"
122         help
123           This option reduces the latency of the kernel when reacting to
124           real-time or interactive events by allowing a low priority process to
125           be preempted even if it is in kernel mode executing a system call.
126           This allows applications to run more reliably even when the system is
127           under load.
128
129           Say Y here if you are building a kernel for a desktop, embedded
130           or real-time system.  Say N if you are unsure.
131
132 config NR_CPUS
133         int "Maximum number of CPUs (2-64)"
134         range 2 64
135         depends on SMP
136         default "32"
137
138 source "drivers/cpufreq/Kconfig"
139
140 config CPU_FREQ_TABLE
141        tristate "CPU frequency table helpers"
142        depends on CPU_FREQ
143        default y
144        help
145          Many CPUFreq drivers use these helpers, so only say N here if
146          the CPUFreq driver of your choice doesn't need these helpers.
147
148          If in doubt, say Y.
149
150 config US3_FREQ
151         tristate "UltraSPARC-III CPU Frequency driver"
152         depends on CPU_FREQ_TABLE
153         help
154           This adds the CPUFreq driver for UltraSPARC-III processors.
155
156           For details, take a look at <file:Documentation/cpu-freq>.
157
158           If in doubt, say N.
159
160 config US2E_FREQ
161         tristate "UltraSPARC-IIe CPU Frequency driver"
162         depends on CPU_FREQ_TABLE
163         help
164           This adds the CPUFreq driver for UltraSPARC-IIe processors.
165
166           For details, take a look at <file:Documentation/cpu-freq>.
167
168           If in doubt, say N.
169
170 # Identify this as a Sparc64 build
171 config SPARC64
172         bool
173         default y
174         help
175           SPARC is a family of RISC microprocessors designed and marketed by
176           Sun Microsystems, incorporated.  This port covers the newer 64-bit
177           UltraSPARC.  The UltraLinux project maintains both the SPARC32 and
178           SPARC64 ports; its web page is available at
179           <http://www.ultralinux.org/>.
180
181 # Global things across all Sun machines.
182 config RWSEM_GENERIC_SPINLOCK
183         bool
184
185 config RWSEM_XCHGADD_ALGORITHM
186         bool
187         default y
188
189 choice
190         prompt "SPARC64 Huge TLB Page Size"
191         depends on HUGETLB_PAGE
192         default HUGETLB_PAGE_SIZE_4MB
193
194 config HUGETLB_PAGE_SIZE_4MB
195         bool "4MB"
196
197 config HUGETLB_PAGE_SIZE_512K
198         bool "512K"
199
200 config HUGETLB_PAGE_SIZE_64K
201         bool "64K"
202
203 endchoice
204
205 config GENERIC_ISA_DMA
206         bool
207         default y
208
209 config ISA
210         bool
211         help
212           Find out whether you have ISA slots on your motherboard.  ISA is the
213           name of a bus system, i.e. the way the CPU talks to the other stuff
214           inside your box.  Other bus systems are PCI, EISA, MicroChannel
215           (MCA) or VESA.  ISA is an older system, now being displaced by PCI;
216           newer boards don't support it.  If you have ISA, say Y, otherwise N.
217
218 config ISAPNP
219         bool
220         help
221           Say Y here if you would like support for ISA Plug and Play devices.
222           Some information is in <file:Documentation/isapnp.txt>.
223
224           To compile this driver as a module, choose M here: the
225           module will be called isapnp.
226
227           If unsure, say Y.
228
229 config EISA
230         bool
231         ---help---
232           The Extended Industry Standard Architecture (EISA) bus was
233           developed as an open alternative to the IBM MicroChannel bus.
234
235           The EISA bus provided some of the features of the IBM MicroChannel
236           bus while maintaining backward compatibility with cards made for
237           the older ISA bus.  The EISA bus saw limited use between 1988 and
238           1995 when it was made obsolete by the PCI bus.
239
240           Say Y here if you are building a kernel for an EISA-based machine.
241
242           Otherwise, say N.
243
244 config MCA
245         bool
246         help
247           MicroChannel Architecture is found in some IBM PS/2 machines and
248           laptops.  It is a bus system similar to PCI or ISA. See
249           <file:Documentation/mca.txt> (and especially the web page given
250           there) before attempting to build an MCA bus kernel.
251
252 config PCMCIA
253         tristate
254         ---help---
255           Say Y here if you want to attach PCMCIA- or PC-cards to your Linux
256           computer.  These are credit-card size devices such as network cards,
257           modems or hard drives often used with laptops computers.  There are
258           actually two varieties of these cards: the older 16 bit PCMCIA cards
259           and the newer 32 bit CardBus cards.  If you want to use CardBus
260           cards, you need to say Y here and also to "CardBus support" below.
261
262           To use your PC-cards, you will need supporting software from David
263           Hinds' pcmcia-cs package (see the file <file:Documentation/Changes>
264           for location).  Please also read the PCMCIA-HOWTO, available from
265           <http://www.tldp.org/docs.html#howto>.
266
267           To compile this driver as modules, choose M here: the
268           modules will be called pcmcia_core and ds.
269
270 config SBUS
271         bool
272         default y
273
274 config SBUSCHAR
275         bool
276         default y
277
278 config SUN_AUXIO
279         bool
280         default y
281
282 config SUN_IO
283         bool
284         default y
285
286 config PCI
287         bool "PCI support"
288         help
289           Find out whether you have a PCI motherboard. PCI is the name of a
290           bus system, i.e. the way the CPU talks to the other stuff inside
291           your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
292           VESA. If you have PCI, say Y, otherwise N.
293
294           The PCI-HOWTO, available from
295           <http://www.tldp.org/docs.html#howto>, contains valuable
296           information about which PCI hardware does work under Linux and which
297           doesn't.
298
299 config PCI_DOMAINS
300         bool
301         default PCI
302
303 config RTC
304         tristate
305         depends on PCI
306         default y
307         ---help---
308           If you say Y here and create a character special file /dev/rtc with
309           major number 10 and minor number 135 using mknod ("man mknod"), you
310           will get access to the real time clock (or hardware clock) built
311           into your computer.
312
313           Every PC has such a clock built in. It can be used to generate
314           signals from as low as 1Hz up to 8192Hz, and can also be used
315           as a 24 hour alarm. It reports status information via the file
316           /proc/driver/rtc and its behaviour is set by various ioctls on
317           /dev/rtc.
318
319           If you run Linux on a multiprocessor machine and said Y to
320           "Symmetric Multi Processing" above, you should say Y here to read
321           and set the RTC in an SMP compatible fashion.
322
323           If you think you have a use for such a device (such as periodic data
324           sampling), then say Y here, and read <file:Documentation/rtc.txt>
325           for details.
326
327           To compile this driver as a module, choose M here: the
328           module will be called rtc.
329
330 source "drivers/pci/Kconfig"
331
332 config SUN_OPENPROMFS
333         tristate "Openprom tree appears in /proc/openprom"
334         help
335           If you say Y, the OpenPROM device tree will be available as a
336           virtual file system, which you can mount to /proc/openprom by "mount
337           -t openpromfs none /proc/openprom".
338
339           To compile the /proc/openprom support as a module, choose M here: the
340           module will be called openpromfs.  If unsure, choose M.
341
342 config SPARC32_COMPAT
343         bool "Kernel support for Linux/Sparc 32bit binary compatibility"
344         help
345           This allows you to run 32-bit binaries on your Ultra.
346           Everybody wants this; say Y.
347
348 config COMPAT
349         bool
350         depends on SPARC32_COMPAT
351         default y
352
353 config UID16
354         bool
355         depends on SPARC32_COMPAT
356         default y
357
358 config BINFMT_ELF32
359         tristate "Kernel support for 32-bit ELF binaries"
360         depends on SPARC32_COMPAT
361         help
362           This allows you to run 32-bit Linux/ELF binaries on your Ultra.
363           Everybody wants this; say Y.
364
365 config BINFMT_AOUT32
366         bool "Kernel support for 32-bit (ie. SunOS) a.out binaries"
367         depends on SPARC32_COMPAT
368         help
369           This allows you to run 32-bit a.out format binaries on your Ultra.
370           If you want to run SunOS binaries (see SunOS binary emulation below)
371           or other a.out binaries, say Y. If unsure, say N.
372
373 source "fs/Kconfig.binfmt"
374
375 config SUNOS_EMUL
376         bool "SunOS binary emulation"
377         depends on BINFMT_AOUT32
378         help
379           This allows you to run most SunOS binaries.  If you want to do this,
380           say Y here and place appropriate files in /usr/gnemul/sunos. See
381           <http://www.ultralinux.org/faq.html> for more information.  If you
382           want to run SunOS binaries on an Ultra you must also say Y to
383           "Kernel support for 32-bit a.out binaries" above.
384
385 config SOLARIS_EMUL
386         tristate "Solaris binary emulation (EXPERIMENTAL)"
387         depends on SPARC32_COMPAT && EXPERIMENTAL
388         help
389           This is experimental code which will enable you to run (many)
390           Solaris binaries on your SPARC Linux machine.
391
392           To compile this code as a module, choose M here: the
393           module will be called solaris.
394
395 source "drivers/parport/Kconfig"
396
397 config PRINTER
398         tristate "Parallel printer support"
399         depends on PARPORT
400         ---help---
401           If you intend to attach a printer to the parallel port of your Linux
402           box (as opposed to using a serial printer; if the connector at the
403           printer has 9 or 25 holes ["female"], then it's serial), say Y.
404           Also read the Printing-HOWTO, available from
405           <http://www.tldp.org/docs.html#howto>.
406
407           It is possible to share one parallel port among several devices
408           (e.g. printer and ZIP drive) and it is safe to compile the
409           corresponding drivers into the kernel.
410           To compile this driver as a module, choose M here and read
411           <file:Documentation/parport.txt>.  The module will be called lp.
412
413           If you have several parallel ports, you can specify which ports to
414           use with the "lp" kernel command line option.  (Try "man bootparam"
415           or see the documentation of your boot loader (lilo or loadlin) about
416           how to pass options to the kernel at boot time.)  The syntax of the
417           "lp" command line option can be found in <file:drivers/char/lp.c>.
418
419           If you have more than 8 printers, you need to increase the LP_NO
420           macro in lp.c and the PARPORT_MAX macro in parport.h.
421
422 config ENVCTRL
423         tristate "SUNW, envctrl support"
424         depends on PCI
425         help
426           Kernel support for temperature and fan monitoring on Sun SME
427           machines.
428
429           To compile this driver as a module, choose M here: the
430           module will be called envctrl.
431
432 config DISPLAY7SEG
433         tristate "7-Segment Display support"
434         depends on PCI
435         ---help---
436           This is the driver for the 7-segment display and LED present on
437           Sun Microsystems CompactPCI models CP1400 and CP1500.
438
439           To compile this driver as a module, choose M here: the
440           module will be called display7seg.
441
442           If you do not have a CompactPCI model CP1400 or CP1500, or
443           another UltraSPARC-IIi-cEngine boardset with a 7-segment display,
444           you should say N to this option.
445
446 config CMDLINE_BOOL
447         bool "Default bootloader kernel arguments"
448
449 config CMDLINE
450         string "Initial kernel command string"
451         depends on CMDLINE_BOOL
452         default "console=ttyS0,9600 root=/dev/sda1"
453         help
454           Say Y here if you want to be able to pass default arguments to
455           the kernel. This will be overridden by the bootloader, if you
456           use one (such as SILO). This is most useful if you want to boot
457           a kernel from TFTP, and want default options to be available
458           with having them passed on the command line.
459
460           NOTE: This option WILL override the PROM bootargs setting!
461
462 endmenu
463
464 source "drivers/base/Kconfig"
465
466 source "drivers/video/Kconfig"
467
468 source "drivers/serial/Kconfig"
469
470 source "drivers/sbus/char/Kconfig"
471
472 source "drivers/mtd/Kconfig"
473
474 source "drivers/block/Kconfig"
475
476 source "drivers/ide/Kconfig"
477
478 source "drivers/scsi/Kconfig"
479
480 source "drivers/fc4/Kconfig"
481
482 source "drivers/md/Kconfig"
483
484 if PCI
485 source "drivers/message/fusion/Kconfig"
486 endif
487
488 source "drivers/ieee1394/Kconfig"
489
490 source "net/Kconfig"
491
492 source "drivers/isdn/Kconfig"
493
494 source "drivers/telephony/Kconfig"
495
496 # This one must be before the filesystem configs. -DaveM
497
498 menu "Unix98 PTY support"
499
500 config UNIX98_PTYS
501         bool "Unix98 PTY support"
502         ---help---
503           A pseudo terminal (PTY) is a software device consisting of two
504           halves: a master and a slave. The slave device behaves identical to
505           a physical terminal; the master device is used by a process to
506           read data from and write data to the slave, thereby emulating a
507           terminal. Typical programs for the master side are telnet servers
508           and xterms.
509
510           Linux has traditionally used the BSD-like names /dev/ptyxx for
511           masters and /dev/ttyxx for slaves of pseudo terminals. This scheme
512           has a number of problems. The GNU C library glibc 2.1 and later,
513           however, supports the Unix98 naming standard: in order to acquire a
514           pseudo terminal, a process opens /dev/ptmx; the number of the pseudo
515           terminal is then made available to the process and the pseudo
516           terminal slave can be accessed as /dev/pts/<number>. What was
517           traditionally /dev/ttyp2 will then be /dev/pts/2, for example.
518
519           The entries in /dev/pts/ are created on the fly by a virtual
520           file system; therefore, if you say Y here you should say Y to
521           "/dev/pts file system for Unix98 PTYs" as well.
522
523           If you want to say Y here, you need to have the C library glibc 2.1
524           or later (equal to libc-6.1, check with "ls -l /lib/libc.so.*").
525           Read the instructions in <file:Documentation/Changes> pertaining to
526           pseudo terminals. It's safe to say N.
527
528 config UNIX98_PTY_COUNT
529         int "Maximum number of Unix98 PTYs in use (0-2048)"
530         depends on UNIX98_PTYS
531         default "256"
532         help
533           The maximum number of Unix98 PTYs that can be used at any one time.
534           The default is 256, and should be enough for desktop systems. Server
535           machines which support incoming telnet/rlogin/ssh connections and/or
536           serve several X terminals may want to increase this: every incoming
537           connection and every xterm uses up one PTY.
538
539           When not in use, each additional set of 256 PTYs occupy
540           approximately 8 KB of kernel memory on 32-bit architectures.
541
542 endmenu
543
544 menu "XFree86 DRI support"
545
546 config DRM
547         bool "Direct Rendering Manager (XFree86 DRI support)"
548         help
549           Kernel-level support for the Direct Rendering Infrastructure (DRI)
550           introduced in XFree86 4.0. If you say Y here, you need to select
551           the module that's right for your graphics card from the list below.
552           These modules provide support for synchronization, security, and
553           DMA transfers. Please see <http://dri.sourceforge.net/> for more
554           details.  You should also select and configure AGP
555           (/dev/agpgart) support.
556
557 config DRM_FFB
558         tristate "Creator/Creator3D"
559         depends on DRM
560         help
561           Choose this option if you have one of Sun's Creator3D-based graphics
562           and frame buffer cards.  Product page at
563           <http://www.sun.com/desktop/products/Graphics/creator3d.html>.
564
565 config DRM_TDFX
566         tristate "3dfx Banshee/Voodoo3+"
567         depends on DRM
568         help
569           Choose this option if you have a 3dfx Banshee or Voodoo3 (or later),
570           graphics card.  If M is selected, the module will be called tdfx.
571
572 config DRM_R128
573         tristate "ATI Rage 128"
574         depends on DRM
575         help
576           Choose this option if you have an ATI Rage 128 graphics card.  If M
577           is selected, the module will be called r128.  AGP support for
578           this card is strongly suggested (unless you have a PCI version).
579
580 endmenu
581
582 source "drivers/input/Kconfig"
583
584 source "drivers/i2c/Kconfig"
585
586 source "fs/Kconfig"
587
588 source "drivers/media/Kconfig"
589
590 source "sound/Kconfig"
591
592 source "drivers/usb/Kconfig"
593
594 source "drivers/char/watchdog/Kconfig"
595
596 source "arch/sparc64/oprofile/Kconfig"
597
598 source "arch/sparc64/Kconfig.debug"
599
600 source "kernel/vserver/Kconfig"
601
602 source "security/Kconfig"
603
604 source "crypto/Kconfig"
605
606 source "lib/Kconfig"