IPv6: fix Routing Header Type 0 handling thinko
[linux-2.6/mini2440.git] / drivers / ide / Kconfig
blob5bdf64b779134d555508891dbe49e7a55651f904
2 # IDE ATA ATAPI Block device driver configuration
4 # Andre Hedrick <andre@linux-ide.org>
7 if BLOCK
9 menu "ATA/ATAPI/MFM/RLL support"
11 config IDE
12         tristate "ATA/ATAPI/MFM/RLL support"
13         ---help---
14           If you say Y here, your kernel will be able to manage low cost mass
15           storage units such as ATA/(E)IDE and ATAPI units. The most common
16           cases are IDE hard drives and ATAPI CD-ROM drives.
18           If your system is pure SCSI and doesn't use these interfaces, you
19           can say N here.
21           Integrated Disk Electronics (IDE aka ATA-1) is a connecting standard
22           for mass storage units such as hard disks. It was designed by
23           Western Digital and Compaq Computer in 1984. It was then named
24           ST506. Quite a number of disks use the IDE interface.
26           AT Attachment (ATA) is the superset of the IDE specifications.
27           ST506 was also called ATA-1.
29           Fast-IDE is ATA-2 (also named Fast ATA), Enhanced IDE (EIDE) is
30           ATA-3. It provides support for larger disks (up to 8.4GB by means of
31           the LBA standard), more disks (4 instead of 2) and for other mass
32           storage units such as tapes and cdrom. UDMA/33 (aka UltraDMA/33) is
33           ATA-4 and provides faster (and more CPU friendly) transfer modes
34           than previous PIO (Programmed processor Input/Output) from previous
35           ATA/IDE standards by means of fast DMA controllers.
37           ATA Packet Interface (ATAPI) is a protocol used by EIDE tape and
38           CD-ROM drives, similar in many respects to the SCSI protocol.
40           SMART IDE (Self Monitoring, Analysis and Reporting Technology) was
41           designed in order to prevent data corruption and disk crash by
42           detecting pre hardware failure conditions (heat, access time, and
43           the like...). Disks built since June 1995 may follow this standard.
44           The kernel itself doesn't manage this; however there are quite a
45           number of user programs such as smart that can query the status of
46           SMART parameters from disk drives.
48           To compile this driver as a module, choose M here: the
49           module will be called ide.
51           For further information, please read <file:Documentation/ide.txt>.
53           If unsure, say Y.
55 if IDE
57 config IDE_MAX_HWIFS
58         int "Max IDE interfaces"
59         depends on ALPHA || SUPERH || IA64 || EMBEDDED
60         range 1 10
61         default 4
62         help
63           This is the maximum number of IDE hardware interfaces that will
64           be supported by the driver. Make sure it is at least as high as
65           the number of IDE interfaces in your system.
67 config BLK_DEV_IDE
68         tristate "Enhanced IDE/MFM/RLL disk/cdrom/tape/floppy support"
69         ---help---
70           If you say Y here, you will use the full-featured IDE driver to
71           control up to ten ATA/IDE interfaces, each being able to serve a
72           "master" and a "slave" device, for a total of up to twenty ATA/IDE
73           disk/cdrom/tape/floppy drives.
75           Useful information about large (>540 MB) IDE disks, multiple
76           interfaces, what to do if ATA/IDE devices are not automatically
77           detected, sound card ATA/IDE ports, module support, and other
78           topics, is contained in <file:Documentation/ide.txt>. For detailed
79           information about hard drives, consult the Disk-HOWTO and the
80           Multi-Disk-HOWTO, available from
81           <http://www.tldp.org/docs.html#howto>.
83           To fine-tune ATA/IDE drive/interface parameters for improved
84           performance, look for the hdparm package at
85           <ftp://ibiblio.org/pub/Linux/system/hardware/>.
87           To compile this driver as a module, choose M here and read
88           <file:Documentation/ide.txt>. The module will be called ide-mod.
89           Do not compile this driver as a module if your root file system (the
90           one containing the directory /) is located on an IDE device.
92           If you have one or more IDE drives, say Y or M here. If your system
93           has no IDE drives, or if memory requirements are really tight, you
94           could say N here, and select the "Old hard disk driver" below
95           instead to save about 13 KB of memory in the kernel.
97 if BLK_DEV_IDE
99 comment "Please see Documentation/ide.txt for help/info on IDE drives"
101 config BLK_DEV_IDE_SATA
102         bool "Support for SATA (deprecated; conflicts with libata SATA driver)"
103         default n
104         ---help---
105           There are two drivers for Serial ATA controllers.
107           The main driver, "libata", uses the SCSI subsystem
108           and supports most modern SATA controllers. In order to use it
109           you may take a look at "Serial ATA (prod) and Parallel ATA
110           (experimental) drivers".
112           The IDE driver (which you are currently configuring) supports
113           a few first-generation SATA controllers.
115           In order to eliminate conflicts between the two subsystems,
116           this config option enables the IDE driver's SATA support.
117           Normally this is disabled, as it is preferred that libata
118           supports SATA controllers, and this (IDE) driver supports
119           PATA controllers.
121           If unsure, say N.
123 config BLK_DEV_HD_IDE
124         bool "Use old disk-only driver on primary interface"
125         depends on (X86 || SH_MPC1211)
126         ---help---
127           There are two drivers for MFM/RLL/IDE disks.  Most people use just
128           the new enhanced driver by itself.  This option however installs the
129           old hard disk driver to control the primary IDE/disk interface in
130           the system, leaving the new enhanced IDE driver to take care of only
131           the 2nd/3rd/4th IDE interfaces.  Doing this will prevent you from
132           having an IDE/ATAPI CD-ROM or tape drive connected to the primary
133           IDE interface.  Choosing this option may be useful for older systems
134           which have MFM/RLL/ESDI controller+drives at the primary port
135           address (0x1f0), along with IDE drives at the secondary/3rd/4th port
136           addresses.
138           Normally, just say N here; you will then use the new driver for all
139           4 interfaces.
141 config BLK_DEV_IDEDISK
142         tristate "Include IDE/ATA-2 DISK support"
143         ---help---
144           This will include enhanced support for MFM/RLL/IDE hard disks.  If
145           you have a MFM/RLL/IDE disk, and there is no special reason to use
146           the old hard disk driver instead, say Y.  If you have an SCSI-only
147           system, you can say N here.
149           To compile this driver as a module, choose M here: the
150           module will be called ide-disk.
151           Do not compile this driver as a module if your root file system
152           (the one containing the directory /) is located on the IDE disk.
154           If unsure, say Y.
156 config IDEDISK_MULTI_MODE
157         bool "Use multi-mode by default"
158         help
159           If you get this error, try to say Y here:
161           hda: set_multmode: status=0x51 { DriveReady SeekComplete Error }
162           hda: set_multmode: error=0x04 { DriveStatusError }
164           If in doubt, say N.
166 config BLK_DEV_IDECS
167         tristate "PCMCIA IDE support"
168         depends on PCMCIA
169         help
170           Support for Compact Flash cards, outboard IDE disks, tape drives,
171           and CD-ROM drives connected through a PCMCIA card.
173 config BLK_DEV_DELKIN
174         tristate "Cardbus IDE support (Delkin/ASKA/Workbit)"
175         depends on CARDBUS && PCI
176         help
177           Support for Delkin, ASKA, and Workbit Cardbus CompactFlash
178           Adapters.  This may also work for similar SD and XD adapters.
180 config BLK_DEV_IDECD
181         tristate "Include IDE/ATAPI CDROM support"
182         ---help---
183           If you have a CD-ROM drive using the ATAPI protocol, say Y. ATAPI is
184           a newer protocol used by IDE CD-ROM and TAPE drives, similar to the
185           SCSI protocol. Most new CD-ROM drives use ATAPI, including the
186           NEC-260, Mitsumi FX400, Sony 55E, and just about all non-SCSI
187           double(2X) or better speed drives.
189           If you say Y here, the CD-ROM drive will be identified at boot time
190           along with other IDE devices, as "hdb" or "hdc", or something
191           similar (check the boot messages with dmesg). If this is your only
192           CD-ROM drive, you can say N to all other CD-ROM options, but be sure
193           to say Y or M to "ISO 9660 CD-ROM file system support".
195           Note that older versions of LILO (LInux LOader) cannot properly deal
196           with IDE/ATAPI CD-ROMs, so install LILO 16 or higher, available from
197           <http://lilo.go.dyndns.org/>.
199           To compile this driver as a module, choose M here: the
200           module will be called ide-cd.
202 config BLK_DEV_IDETAPE
203         tristate "Include IDE/ATAPI TAPE support (EXPERIMENTAL)"
204         depends on EXPERIMENTAL
205         help
206           If you have an IDE tape drive using the ATAPI protocol, say Y.
207           ATAPI is a newer protocol used by IDE tape and CD-ROM drives,
208           similar to the SCSI protocol.  If you have an SCSI tape drive
209           however, you can say N here.
211           You should also say Y if you have an OnStream DI-30 tape drive; this
212           will not work with the SCSI protocol, until there is support for the
213           SC-30 and SC-50 versions.
215           If you say Y here, the tape drive will be identified at boot time
216           along with other IDE devices, as "hdb" or "hdc", or something
217           similar, and will be mapped to a character device such as "ht0"
218           (check the boot messages with dmesg).  Be sure to consult the
219           <file:drivers/ide/ide-tape.c> and <file:Documentation/ide.txt> files
220           for usage information.
222           To compile this driver as a module, choose M here: the
223           module will be called ide-tape.
225 config BLK_DEV_IDEFLOPPY
226         tristate "Include IDE/ATAPI FLOPPY support"
227         ---help---
228           If you have an IDE floppy drive which uses the ATAPI protocol,
229           answer Y.  ATAPI is a newer protocol used by IDE CD-ROM/tape/floppy
230           drives, similar to the SCSI protocol.
232           The LS-120 and the IDE/ATAPI Iomega ZIP drive are also supported by
233           this driver. For information about jumper settings and the question
234           of when a ZIP drive uses a partition table, see
235           <http://www.win.tue.nl/~aeb/linux/zip/zip-1.html>.
236           (ATAPI PD-CD/CDR drives are not supported by this driver; support
237           for PD-CD/CDR drives is available if you answer Y to
238           "SCSI emulation support", below).
240           If you say Y here, the FLOPPY drive will be identified along with
241           other IDE devices, as "hdb" or "hdc", or something similar (check
242           the boot messages with dmesg).
244           To compile this driver as a module, choose M here: the
245           module will be called ide-floppy.
247 config BLK_DEV_IDESCSI
248         tristate "SCSI emulation support"
249         depends on SCSI
250         ---help---
251           WARNING: ide-scsi is no longer needed for cd writing applications!
252           The 2.6 kernel supports direct writing to ide-cd, which eliminates
253           the need for ide-scsi + the entire scsi stack just for writing a
254           cd. The new method is more efficient in every way.
256           This will provide SCSI host adapter emulation for IDE ATAPI devices,
257           and will allow you to use a SCSI device driver instead of a native
258           ATAPI driver.
260           This is useful if you have an ATAPI device for which no native
261           driver has been written (for example, an ATAPI PD-CD drive);
262           you can then use this emulation together with an appropriate SCSI
263           device driver. In order to do this, say Y here and to "SCSI support"
264           and "SCSI generic support", below. You must then provide the kernel
265           command line "hdx=ide-scsi" (try "man bootparam" or see the
266           documentation of your boot loader (lilo or loadlin) about how to
267           pass options to the kernel at boot time) for devices if you want the
268           native EIDE sub-drivers to skip over the native support, so that
269           this SCSI emulation can be used instead.
271           Note that this option does NOT allow you to attach SCSI devices to a
272           box that doesn't have a SCSI host adapter installed.
274           If both this SCSI emulation and native ATAPI support are compiled
275           into the kernel, the native support will be used.
277 config BLK_DEV_IDEACPI
278         bool "IDE ACPI support"
279         depends on ACPI
280         ---help---
281           Implement ACPI support for generic IDE devices. On modern
282           machines ACPI support is required to properly handle ACPI S3 states.
284 config IDE_TASK_IOCTL
285         bool "IDE Taskfile Access"
286         help
287           This is a direct raw access to the media.  It is a complex but
288           elegant solution to test and validate the domain of the hardware and
289           perform below the driver data recovery if needed.  This is the most
290           basic form of media-forensics.
292           If you are unsure, say N here.
294 comment "IDE chipset support/bugfixes"
296 config IDE_GENERIC
297         tristate "generic/default IDE chipset support"
298         default y
299         help
300           If unsure, say Y.
302 config BLK_DEV_CMD640
303         bool "CMD640 chipset bugfix/support"
304         depends on X86
305         ---help---
306           The CMD-Technologies CMD640 IDE chip is used on many common 486 and
307           Pentium motherboards, usually in combination with a "Neptune" or
308           "SiS" chipset. Unfortunately, it has a number of rather nasty
309           design flaws that can cause severe data corruption under many common
310           conditions. Say Y here to include code which tries to automatically
311           detect and correct the problems under Linux. This option also
312           enables access to the secondary IDE ports in some CMD640 based
313           systems.
315           This driver will work automatically in PCI based systems (most new
316           systems have PCI slots). But if your system uses VESA local bus
317           (VLB) instead of PCI, you must also supply a kernel boot parameter
318           to enable the CMD640 bugfix/support: "ide0=cmd640_vlb". (Try "man
319           bootparam" or see the documentation of your boot loader about how to
320           pass options to the kernel.)
322           The CMD640 chip is also used on add-in cards by Acculogic, and on
323           the "CSA-6400E PCI to IDE controller" that some people have. For
324           details, read <file:Documentation/ide.txt>.
326 config BLK_DEV_CMD640_ENHANCED
327         bool "CMD640 enhanced support"
328         depends on BLK_DEV_CMD640
329         help
330           This option includes support for setting/autotuning PIO modes and
331           prefetch on CMD640 IDE interfaces.  For details, read
332           <file:Documentation/ide.txt>. If you have a CMD640 IDE interface
333           and your BIOS does not already do this for you, then say Y here.
334           Otherwise say N.
336 config BLK_DEV_IDEPNP
337         bool "PNP EIDE support"
338         depends on PNP
339         help
340           If you have a PnP (Plug and Play) compatible EIDE card and
341           would like the kernel to automatically detect and activate
342           it, say Y here.
344 config BLK_DEV_IDEPCI
345         bool "PCI IDE chipset support" if PCI
346         default BLK_DEV_IDEDMA_PMAC if PPC_PMAC && BLK_DEV_IDEDMA_PMAC
347         help
348           Say Y here for PCI systems which use IDE drive(s).
349           This option helps the IDE driver to automatically detect and
350           configure all PCI-based IDE interfaces in your system.
352 config IDEPCI_SHARE_IRQ
353         bool "Sharing PCI IDE interrupts support"
354         depends on PCI && BLK_DEV_IDEPCI
355         help
356           Some ATA/IDE chipsets have hardware support which allows for
357           sharing a single IRQ with other cards. To enable support for
358           this in the ATA/IDE driver, say Y here.
360           It is safe to say Y to this question, in most cases.
361           If unsure, say N.
363 config BLK_DEV_OFFBOARD
364         bool "Boot off-board chipsets first support"
365         depends on PCI && BLK_DEV_IDEPCI
366         help
367           Normally, IDE controllers built into the motherboard (on-board
368           controllers) are assigned to ide0 and ide1 while those on add-in PCI
369           cards (off-board controllers) are relegated to ide2 and ide3.
370           Answering Y here will allow you to reverse the situation, with
371           off-board controllers on ide0/1 and on-board controllers on ide2/3.
372           This can improve the usability of some boot managers such as lilo
373           when booting from a drive on an off-board controller.
375           If you say Y here, and you actually want to reverse the device scan
376           order as explained above, you also need to issue the kernel command
377           line option "ide=reverse". (Try "man bootparam" or see the
378           documentation of your boot loader (lilo or loadlin) about how to
379           pass options to the kernel at boot time.)
381           Note that, if you do this, the order of the hd* devices will be
382           rearranged which may require modification of fstab and other files.
384           If in doubt, say N.
386 config BLK_DEV_GENERIC
387         tristate "Generic PCI IDE Chipset Support"
388         depends on BLK_DEV_IDEPCI
389         help
390           This option provides generic support for various PCI IDE Chipsets
391           which otherwise might not be supported.
393 config BLK_DEV_OPTI621
394         tristate "OPTi 82C621 chipset enhanced support (EXPERIMENTAL)"
395         depends on PCI && BLK_DEV_IDEPCI && EXPERIMENTAL
396         help
397           This is a driver for the OPTi 82C621 EIDE controller.
398           Please read the comments at the top of <file:drivers/ide/pci/opti621.c>.
400 config BLK_DEV_RZ1000
401         tristate "RZ1000 chipset bugfix/support"
402         depends on PCI && BLK_DEV_IDEPCI && X86
403         help
404           The PC-Technologies RZ1000 IDE chip is used on many common 486 and
405           Pentium motherboards, usually along with the "Neptune" chipset.
406           Unfortunately, it has a rather nasty design flaw that can cause
407           severe data corruption under many conditions. Say Y here to include
408           code which automatically detects and corrects the problem under
409           Linux. This may slow disk throughput by a few percent, but at least
410           things will operate 100% reliably.
412 config BLK_DEV_IDEDMA_PCI
413         bool "Generic PCI bus-master DMA support"
414         depends on PCI && BLK_DEV_IDEPCI
415         ---help---
416           If your PCI system uses IDE drive(s) (as opposed to SCSI, say) and
417           is capable of bus-master DMA operation (most Pentium PCI systems),
418           you will want to say Y here to reduce CPU overhead. You can then use
419           the "hdparm" utility to enable DMA for drives for which it was not
420           enabled automatically. By default, DMA is not enabled automatically
421           for these drives, but you can change that by saying Y to the
422           following question "Use DMA by default when available". You can get
423           the latest version of the hdparm utility from
424           <ftp://ibiblio.org/pub/Linux/system/hardware/>.
426           Read the comments at the beginning of <file:drivers/ide/ide-dma.c>
427           and the file <file:Documentation/ide.txt> for more information.
429           It is safe to say Y to this question.
431 if BLK_DEV_IDEDMA_PCI
433 config BLK_DEV_IDEDMA_FORCED
434         bool "Force enable legacy 2.0.X HOSTS to use DMA"
435         help
436           This is an old piece of lost code from Linux 2.0 Kernels.
438           Generally say N here.
440 config IDEDMA_ONLYDISK
441         bool "Enable DMA only for disks "
442         help
443           This is used if you know your ATAPI Devices are going to fail DMA
444           Transfers.
446           Generally say N here.
448 config BLK_DEV_AEC62XX
449         tristate "AEC62XX chipset support"
450         help
451           This driver adds explicit support for Acard AEC62xx (Artop ATP8xx)
452           IDE controllers. This allows the kernel to change PIO, DMA and UDMA
453           speeds and to configure the chip to optimum performance.
455 config BLK_DEV_ALI15X3
456         tristate "ALI M15x3 chipset support"
457         help
458           This driver ensures (U)DMA support for ALI 1533, 1543 and 1543C
459           onboard chipsets.  It also tests for Simplex mode and enables
460           normal dual channel support.
462           If you say Y here, you also need to say Y to "Use DMA by default
463           when available", above.  Please read the comments at the top of
464           <file:drivers/ide/pci/alim15x3.c>.
466           If unsure, say N.
468 config WDC_ALI15X3
469         bool "ALI M15x3 WDC support (DANGEROUS)"
470         depends on BLK_DEV_ALI15X3
471         ---help---
472           This allows for UltraDMA support for WDC drives that ignore CRC
473           checking. You are a fool for enabling this option, but there have
474           been requests. DO NOT COMPLAIN IF YOUR DRIVE HAS FS CORRUPTION, IF
475           YOU ENABLE THIS! No one will listen, just laugh for ignoring this
476           SERIOUS WARNING.
478           Using this option can allow WDC drives to run at ATA-4/5 transfer
479           rates with only an ATA-2 support structure.
481           SAY N!
483 config BLK_DEV_AMD74XX
484         tristate "AMD and nVidia IDE support"
485         help
486           This driver adds explicit support for AMD-7xx and AMD-8111 chips
487           and also for the nVidia nForce chip.  This allows the kernel to
488           change PIO, DMA and UDMA speeds and to configure the chip to
489           optimum performance.
491 config BLK_DEV_ATIIXP
492         tristate "ATI IXP chipset IDE support"
493         depends on X86
494         help
495           This driver adds explicit support for ATI IXP chipset.
496           This allows the kernel to change PIO, DMA and UDMA speeds
497           and to configure the chip to optimum performance.
499           Say Y here if you have an ATI IXP chipset IDE controller.
501 config BLK_DEV_CMD64X
502         tristate "CMD64{3|6|8|9} chipset support"
503         help
504           Say Y here if you have an IDE controller which uses any of these
505           chipsets: CMD643, CMD646, or CMD648.
507 config BLK_DEV_TRIFLEX
508         tristate "Compaq Triflex IDE support"
509         help
510           Say Y here if you have a Compaq Triflex IDE controller, such
511           as those commonly found on Compaq Pentium-Pro systems
513 config BLK_DEV_CY82C693
514         tristate "CY82C693 chipset support"
515         help
516           This driver adds detection and support for the CY82C693 chipset
517           used on Digital's PC-Alpha 164SX boards.
519           If you say Y here, you need to say Y to "Use DMA by default
520           when available" as well.
522 config BLK_DEV_CS5520
523         tristate "Cyrix CS5510/20 MediaGX chipset support (VERY EXPERIMENTAL)"
524         depends on EXPERIMENTAL
525         help
526           Include support for PIO tuning and virtual DMA on the Cyrix MediaGX
527           5510/5520 chipset. This will automatically be detected and
528           configured if found.
530           It is safe to say Y to this question.
532 config BLK_DEV_CS5530
533         tristate "Cyrix/National Semiconductor CS5530 MediaGX chipset support"
534         help
535           Include support for UDMA on the Cyrix MediaGX 5530 chipset. This
536           will automatically be detected and configured if found.
538           It is safe to say Y to this question.
540 config BLK_DEV_CS5535
541         tristate "AMD CS5535 chipset support"
542         depends on X86 && !X86_64
543         help
544           Include support for UDMA on the NSC/AMD CS5535 companion chipset.
545           This will automatically be detected and configured if found.
547           It is safe to say Y to this question.
549 config BLK_DEV_HPT34X
550         tristate "HPT34X chipset support"
551         help
552           This driver adds up to 4 more EIDE devices sharing a single
553           interrupt. The HPT343 chipset in its current form is a non-bootable
554           controller; the HPT345/HPT363 chipset is a bootable (needs BIOS FIX)
555           PCI UDMA controllers. This driver requires dynamic tuning of the
556           chipset during the ide-probe at boot time. It is reported to support
557           DVD II drives, by the manufacturer.
559 config HPT34X_AUTODMA
560         bool "HPT34X AUTODMA support (EXPERIMENTAL)"
561         depends on BLK_DEV_HPT34X && EXPERIMENTAL
562         help
563           This is a dangerous thing to attempt currently! Please read the
564           comments at the top of <file:drivers/ide/pci/hpt34x.c>.  If you say Y
565           here, then say Y to "Use DMA by default when available" as well.
567           If unsure, say N.
569 config BLK_DEV_HPT366
570         tristate "HPT36X/37X chipset support"
571         ---help---
572           HPT366 is an Ultra DMA chipset for ATA-66.
573           HPT368 is an Ultra DMA chipset for ATA-66 RAID Based.
574           HPT370 is an Ultra DMA chipset for ATA-100.
575           HPT372 is an Ultra DMA chipset for ATA-100.
576           HPT374 is an Ultra DMA chipset for ATA-100.
578           This driver adds up to 4 more EIDE devices sharing a single
579           interrupt.
581           The HPT366 chipset in its current form is bootable. One solution
582           for this problem are special LILO commands for redirecting the
583           reference to device 0x80. The other solution is to say Y to "Boot
584           off-board chipsets first support" (CONFIG_BLK_DEV_OFFBOARD) unless
585           your mother board has the chipset natively mounted. Regardless one
586           should use the fore mentioned option and call at LILO or include
587           "ide=reverse" in LILO's append-line.
589           This driver requires dynamic tuning of the chipset during the
590           ide-probe at boot. It is reported to support DVD II drives, by the
591           manufacturer.
593 config BLK_DEV_JMICRON
594         tristate "JMicron JMB36x support"
595         help
596           Basic support for the JMicron ATA controllers. For full support
597           use the libata drivers.
599 config BLK_DEV_SC1200
600         tristate "National SCx200 chipset support"
601         help
602           This driver adds support for the built in IDE on the National
603           SCx200 series of embedded x86 "Geode" systems
605 config BLK_DEV_PIIX
606         tristate "Intel PIIXn chipsets support"
607         help
608           This driver adds explicit support for Intel PIIX and ICH chips
609           and also for the Efar Victory66 (slc90e66) chip.  This allows
610           the kernel to change PIO, DMA and UDMA speeds and to configure
611           the chip to optimum performance.
613 config BLK_DEV_IT8213
614         tristate "IT8213 IDE support"
615         help
616          This driver adds support for the ITE 8213 IDE controller.
618 config BLK_DEV_IT821X
619         tristate "IT821X IDE support"
620         help
621           This driver adds support for the ITE 8211 IDE controller and the
622           IT 8212 IDE RAID controller in both RAID and pass-through mode.
624 config BLK_DEV_NS87415
625         tristate "NS87415 chipset support"
626         help
627           This driver adds detection and support for the NS87415 chip
628           (used mainly on SPARC64 and PA-RISC machines).
630           Please read the comments at the top of <file:drivers/ide/pci/ns87415.c>.
632 config BLK_DEV_PDC202XX_OLD
633         tristate "PROMISE PDC202{46|62|65|67} support"
634         help
635           Promise Ultra33 or PDC20246
636           Promise Ultra66 or PDC20262
637           Promise Ultra100 or PDC20265/PDC20267/PDC20268
639           This driver adds up to 4 more EIDE devices sharing a single
640           interrupt. This add-on card is a bootable PCI UDMA controller. Since
641           multiple cards can be installed and there are BIOS ROM problems that
642           happen if the BIOS revisions of all installed cards (three-max) do
643           not match, the driver attempts to do dynamic tuning of the chipset
644           at boot-time for max-speed.  Ultra33 BIOS 1.25 or newer is required
645           for more than one card. This card may require that you say Y to
646           "Special UDMA Feature".
648           If you say Y here, you need to say Y to "Use DMA by default when
649           available" as well.
651           Please read the comments at the top of
652           <file:drivers/ide/pci/pdc202xx_old.c>.
654           If unsure, say N.
656 config PDC202XX_BURST
657         bool "Special UDMA Feature"
658         depends on BLK_DEV_PDC202XX_OLD
659         help
660           This option causes the pdc202xx driver to enable UDMA modes on the
661           PDC202xx even when the PDC202xx BIOS has not done so.
663           It was originally designed for the PDC20246/Ultra33, whose BIOS will
664           only setup UDMA on the first two PDC20246 cards.  It has also been
665           used successfully on a PDC20265/Ultra100, allowing use of UDMA modes
666           when the PDC20265 BIOS has been disabled (for faster boot up).
668           Please read the comments at the top of
669           <file:drivers/ide/pci/pdc202xx_old.c>.
671           If unsure, say N.
673 config BLK_DEV_PDC202XX_NEW
674         tristate "PROMISE PDC202{68|69|70|71|75|76|77} support"
676 config BLK_DEV_SVWKS
677         tristate "ServerWorks OSB4/CSB5/CSB6 chipsets support"
678         help
679           This driver adds PIO/(U)DMA support for the ServerWorks OSB4/CSB5
680           chipsets.
682 config BLK_DEV_SGIIOC4
683         tristate "Silicon Graphics IOC4 chipset ATA/ATAPI support"
684         depends on (IA64_SGI_SN2 || IA64_GENERIC) && SGI_IOC4
685         select IDEPCI_SHARE_IRQ
686         help
687           This driver adds PIO & MultiMode DMA-2 support for the SGI IOC4
688           chipset, which has one channel and can support two devices.
689           Please say Y here if you have an Altix System from SGI.
691 config BLK_DEV_SIIMAGE
692         tristate "Silicon Image chipset support"
693         help
694           This driver adds PIO/(U)DMA support for the SI CMD680 and SII
695           3112 (Serial ATA) chips.
697 config BLK_DEV_SIS5513
698         tristate "SiS5513 chipset support"
699         depends on X86
700         ---help---
701           This driver ensures (U)DMA support for SIS5513 chipset family based
702           mainboards.
704           The following chipsets are supported:
705           ATA16:  SiS5511, SiS5513
706           ATA33:  SiS5591, SiS5597, SiS5598, SiS5600
707           ATA66:  SiS530, SiS540, SiS620, SiS630, SiS640
708           ATA100: SiS635, SiS645, SiS650, SiS730, SiS735, SiS740,
709           SiS745, SiS750
711           If you say Y here, you need to say Y to "Use DMA by default when
712           available" as well.
714           Please read the comments at the top of <file:drivers/ide/pci/sis5513.c>.
716 config BLK_DEV_SL82C105
717         tristate "Winbond SL82c105 support"
718         depends on (PPC || ARM)
719         help
720           If you have a Winbond SL82c105 IDE controller, say Y here to enable
721           special configuration for this chip. This is common on various CHRP
722           motherboards, but could be used elsewhere. If in doubt, say Y.
724 config BLK_DEV_SLC90E66
725         tristate "SLC90E66 chipset support"
726         help
727           This driver ensures (U)DMA support for Victory66 SouthBridges for
728           SMsC with Intel NorthBridges.  This is an Ultra66 based chipset.
729           The nice thing about it is that you can mix Ultra/DMA/PIO devices
730           and it will handle timing cycles.  Since this is an improved
731           look-a-like to the PIIX4 it should be a nice addition.
733           If you say Y here, you need to say Y to "Use DMA by default when
734           available" as well.
736           Please read the comments at the top of
737           <file:drivers/ide/pci/slc90e66.c>.
739 config BLK_DEV_TRM290
740         tristate "Tekram TRM290 chipset support"
741         help
742           This driver adds support for bus master DMA transfers
743           using the Tekram TRM290 PCI IDE chip. Volunteers are
744           needed for further tweaking and development.
745           Please read the comments at the top of <file:drivers/ide/pci/trm290.c>.
747 config BLK_DEV_VIA82CXXX
748         tristate "VIA82CXXX chipset support"
749         help
750           This driver adds explicit support for VIA BusMastering IDE chips.
751           This allows the kernel to change PIO, DMA and UDMA speeds and to
752           configure the chip to optimum performance.
754 config BLK_DEV_TC86C001
755         tristate "Toshiba TC86C001 support"
756         help
757         This driver adds support for Toshiba TC86C001 GOKU-S chip.
759 config BLK_DEV_CELLEB
760         tristate "Toshiba's Cell Reference Set IDE support"
761         depends on PPC_CELLEB
762         help
763           This driver provides support for the built-in IDE controller on
764           Toshiba Cell Reference Board.
765           If unsure, say Y.
767 endif
769 config BLK_DEV_IDE_PMAC
770         bool "Builtin PowerMac IDE support"
771         depends on PPC_PMAC && IDE=y
772         help
773           This driver provides support for the built-in IDE controller on
774           most of the recent Apple Power Macintoshes and PowerBooks.
775           If unsure, say Y.
777 config BLK_DEV_IDE_PMAC_ATA100FIRST
778         bool "Probe internal ATA/100 (Kauai) first"
779         depends on BLK_DEV_IDE_PMAC
780         help
781           This option will cause the ATA/100 controller found in UniNorth2
782           based machines (Windtunnel PowerMac, Aluminium PowerBooks, ...)
783           to be probed before the ATA/66 and ATA/33 controllers. Without
784           these, those machine used to have the hard disk on hdc and the
785           CD-ROM on hda. This option changes this to more natural hda for
786           hard disk and hdc for CD-ROM.
788 config BLK_DEV_IDEDMA_PMAC
789         bool "PowerMac IDE DMA support"
790         depends on BLK_DEV_IDE_PMAC
791         select BLK_DEV_IDEDMA_PCI
792         help
793           This option allows the driver for the built-in IDE controller on
794           Power Macintoshes and PowerBooks to use DMA (direct memory access)
795           to transfer data to and from memory.  Saying Y is safe and improves
796           performance.
798 config BLK_DEV_IDE_SWARM
799         tristate "IDE for Sibyte evaluation boards"
800         depends on SIBYTE_SB1xxx_SOC
802 config BLK_DEV_IDE_AU1XXX
803        bool "IDE for AMD Alchemy Au1200"
804        depends on SOC_AU1200
805 choice
806        prompt "IDE Mode for AMD Alchemy Au1200"
807        default CONFIG_BLK_DEV_IDE_AU1XXX_PIO_DBDMA
808        depends on SOC_AU1200 && BLK_DEV_IDE_AU1XXX
810 config BLK_DEV_IDE_AU1XXX_PIO_DBDMA
811        bool "PIO+DbDMA IDE for AMD Alchemy Au1200"
813 config BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA
814        bool "MDMA2+DbDMA IDE for AMD Alchemy Au1200"
815        depends on SOC_AU1200 && BLK_DEV_IDE_AU1XXX
816 endchoice
818 config BLK_DEV_IDE_AU1XXX_SEQTS_PER_RQ
819        int "Maximum transfer size (KB) per request (up to 128)"
820        default "128"
821        depends on BLK_DEV_IDE_AU1XXX
823 config IDE_ARM
824         def_bool ARM && (ARCH_A5K || ARCH_CLPS7500 || ARCH_RPC || ARCH_SHARK)
826 config BLK_DEV_IDE_ICSIDE
827         tristate "ICS IDE interface support"
828         depends on ARM && ARCH_ACORN
829         help
830           On Acorn systems, say Y here if you wish to use the ICS IDE
831           interface card.  This is not required for ICS partition support.
832           If you are unsure, say N to this.
834 config BLK_DEV_IDEDMA_ICS
835         bool "ICS DMA support"
836         depends on BLK_DEV_IDE_ICSIDE
837         help
838           Say Y here if you want to add DMA (Direct Memory Access) support to
839           the ICS IDE driver.
841 config BLK_DEV_IDE_RAPIDE
842         tristate "RapIDE interface support"
843         depends on ARM && ARCH_ACORN
844         help
845           Say Y here if you want to support the Yellowstone RapIDE controller
846           manufactured for use with Acorn computers.
848 config BLK_DEV_IDE_BAST
849         tristate "Simtec BAST / Thorcom VR1000 IDE support"
850         depends on ARM && (ARCH_BAST || MACH_VR1000)
851         help
852           Say Y here if you want to support the onboard IDE channels on the
853           Simtec BAST or the Thorcom VR1000
855 config BLK_DEV_GAYLE
856         bool "Amiga Gayle IDE interface support"
857         depends on AMIGA
858         help
859           This is the IDE driver for the Amiga Gayle IDE interface. It supports
860           both the `A1200 style' and `A4000 style' of the Gayle IDE interface,
861           This includes builtin IDE interfaces on some Amiga models (A600,
862           A1200, A4000, and A4000T), and IDE interfaces on the Zorro expansion
863           bus (M-Tech E-Matrix 530 expansion card).
864           Say Y if you have an Amiga with a Gayle IDE interface and want to use
865           IDE devices (hard disks, CD-ROM drives, etc.) that are connected to
866           it.
867           Note that you also have to enable Zorro bus support if you want to
868           use Gayle IDE interfaces on the Zorro expansion bus.
870 config BLK_DEV_IDEDOUBLER
871         bool "Amiga IDE Doubler support (EXPERIMENTAL)"
872         depends on BLK_DEV_GAYLE && EXPERIMENTAL
873         ---help---
874           This driver provides support for the so-called `IDE doublers' (made
875           by various manufacturers, e.g. Eyetech) that can be connected to the
876           builtin IDE interface of some Amiga models. Using such an IDE
877           doubler, you can connect up to four instead of two IDE devices on
878           the Amiga's builtin IDE interface.
880           Note that the normal Amiga Gayle IDE driver may not work correctly
881           if you have an IDE doubler and don't enable this driver!
883           Say Y if you have an IDE doubler.  The driver is enabled at kernel
884           runtime using the "ide=doubler" kernel boot parameter.
886 config BLK_DEV_BUDDHA
887         bool "Buddha/Catweasel/X-Surf IDE interface support (EXPERIMENTAL)"
888         depends on ZORRO && EXPERIMENTAL
889         help
890           This is the IDE driver for the IDE interfaces on the Buddha, 
891           Catweasel and X-Surf expansion boards.  It supports up to two interfaces 
892           on the Buddha, three on the Catweasel and two on the X-Surf.
894           Say Y if you have a Buddha or Catweasel expansion board and want to
895           use IDE devices (hard disks, CD-ROM drives, etc.) that are connected
896           to one of its IDE interfaces.
898 config BLK_DEV_FALCON_IDE
899         bool "Falcon IDE interface support"
900         depends on ATARI
901         help
902           This is the IDE driver for the builtin IDE interface on the Atari
903           Falcon. Say Y if you have a Falcon and want to use IDE devices (hard
904           disks, CD-ROM drives, etc.) that are connected to the builtin IDE
905           interface.
907 config BLK_DEV_MAC_IDE
908         bool "Macintosh Quadra/Powerbook IDE interface support"
909         depends on MAC
910         help
911           This is the IDE driver for the builtin IDE interface on some m68k
912           Macintosh models. It supports both the `Quadra style' (used in
913           Quadra/ Centris 630 and Performa 588 models) and `Powerbook style'
914           (used in the Powerbook 150 and 190 models) IDE interface.
916           Say Y if you have such an Macintosh model and want to use IDE
917           devices (hard disks, CD-ROM drives, etc.) that are connected to the
918           builtin IDE interface.
920 config BLK_DEV_Q40IDE
921         bool "Q40/Q60 IDE interface support"
922         depends on Q40
923         help
924           Enable the on-board IDE controller in the Q40/Q60.  This should
925           normally be on; disable it only if you are running a custom hard
926           drive subsystem through an expansion card.
928 config BLK_DEV_MPC8xx_IDE
929         bool "MPC8xx IDE support"
930         depends on 8xx && IDE=y && BLK_DEV_IDE=y
931         help
932           This option provides support for IDE on Motorola MPC8xx Systems.
933           Please see 'Type of MPC8xx IDE interface' for details.
935           If unsure, say N.
937 choice
938         prompt "Type of MPC8xx IDE interface"
939         depends on BLK_DEV_MPC8xx_IDE
940         default IDE_8xx_PCCARD
942 config IDE_8xx_PCCARD
943         bool "8xx_PCCARD"
944         ---help---
945           Select how the IDE devices are connected to the MPC8xx system:
947           8xx_PCCARD uses the 8xx internal PCMCIA interface in combination
948           with a PC Card (e.g. ARGOSY portable Hard Disk Adapter),
949           ATA PC Card HDDs or ATA PC Flash Cards (example: TQM8xxL
950           systems)
952           8xx_DIRECT is used for directly connected IDE devices using the 8xx
953           internal PCMCIA interface (example: IVMS8 systems)
955           EXT_DIRECT is used for IDE devices directly connected to the 8xx
956           bus using some glue logic, but _not_ the 8xx internal
957           PCMCIA interface (example: IDIF860 systems)
959 config IDE_8xx_DIRECT
960         bool "8xx_DIRECT"
962 config IDE_EXT_DIRECT
963         bool "EXT_DIRECT"
965 endchoice
967 # no isa -> no vlb
968 config IDE_CHIPSETS
969         bool "Other IDE chipset support"
970         depends on ISA
971         ---help---
972           Say Y here if you want to include enhanced support for various IDE
973           interface chipsets used on motherboards and add-on cards. You can
974           then pick your particular IDE chip from among the following options.
975           This enhanced support may be necessary for Linux to be able to
976           access the 3rd/4th drives in some systems. It may also enable
977           setting of higher speed I/O rates to improve system performance with
978           these chipsets. Most of these also require special kernel boot
979           parameters to actually turn on the support at runtime; you can find
980           a list of these in the file <file:Documentation/ide.txt>.
982           People with SCSI-only systems can say N here.
984 if IDE_CHIPSETS
986 comment "Note: most of these also require special kernel boot parameters"
988 config BLK_DEV_4DRIVES
989         bool "Generic 4 drives/port support"
990         help
991           Certain older chipsets, including the Tekram 690CD, use a single set
992           of I/O ports at 0x1f0 to control up to four drives, instead of the
993           customary two drives per port. Support for this can be enabled at
994           runtime using the "ide0=four" kernel boot parameter if you say Y
995           here.
997 config BLK_DEV_ALI14XX
998         tristate "ALI M14xx support"
999         help
1000           This driver is enabled at runtime using the "ali14xx.probe" kernel
1001           boot parameter.  It enables support for the secondary IDE interface
1002           of the ALI M1439/1443/1445/1487/1489 chipsets, and permits faster
1003           I/O speeds to be set as well.  See the files
1004           <file:Documentation/ide.txt> and <file:drivers/ide/legacy/ali14xx.c> for
1005           more info.
1007 config BLK_DEV_DTC2278
1008         tristate "DTC-2278 support"
1009         help
1010           This driver is enabled at runtime using the "dtc2278.probe" kernel
1011           boot parameter. It enables support for the secondary IDE interface
1012           of the DTC-2278 card, and permits faster I/O speeds to be set as
1013           well. See the <file:Documentation/ide.txt> and
1014           <file:drivers/ide/legacy/dtc2278.c> files for more info.
1016 config BLK_DEV_HT6560B
1017         tristate "Holtek HT6560B support"
1018         help
1019           This driver is enabled at runtime using the "ht6560b.probe" kernel
1020           boot parameter. It enables support for the secondary IDE interface
1021           of the Holtek card, and permits faster I/O speeds to be set as well.
1022           See the <file:Documentation/ide.txt> and
1023           <file:drivers/ide/legacy/ht6560b.c> files for more info.
1025 config BLK_DEV_QD65XX
1026         tristate "QDI QD65xx support"
1027         help
1028           This driver is enabled at runtime using the "qd65xx.probe" kernel
1029           boot parameter.  It permits faster I/O speeds to be set.  See the
1030           <file:Documentation/ide.txt> and <file:drivers/ide/legacy/qd65xx.c> for
1031           more info.
1033 config BLK_DEV_UMC8672
1034         tristate "UMC-8672 support"
1035         help
1036           This driver is enabled at runtime using the "umc8672.probe" kernel
1037           boot parameter. It enables support for the secondary IDE interface
1038           of the UMC-8672, and permits faster I/O speeds to be set as well.
1039           See the files <file:Documentation/ide.txt> and
1040           <file:drivers/ide/legacy/umc8672.c> for more info.
1042 endif
1044 config BLK_DEV_IDEDMA
1045         def_bool BLK_DEV_IDEDMA_PCI || BLK_DEV_IDEDMA_PMAC || BLK_DEV_IDEDMA_ICS || BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA
1047 config IDEDMA_IVB
1048         bool "IGNORE word93 Validation BITS"
1049         depends on BLK_DEV_IDEDMA_PCI || BLK_DEV_IDEDMA_PMAC || BLK_DEV_IDEDMA_ICS
1050         ---help---
1051           There are unclear terms in ATA-4 and ATA-5 standards how certain
1052           hardware (an 80c ribbon) should be detected. Different interpretations
1053           of the standards have been released in hardware. This causes problems:
1054           for example, a host with Ultra Mode 4 (or higher) will not run
1055           in that mode with an 80c ribbon.
1057           If you are experiencing compatibility or performance problems, you
1058           MAY try to answer Y here. However, it does not necessarily solve
1059           any of your problems, it could even cause more of them.
1061           It is normally safe to answer Y; however, the default is N.
1063 endif
1065 config BLK_DEV_HD_ONLY
1066         bool "Old hard disk (MFM/RLL/IDE) driver"
1067         depends on BLK_DEV_IDE=n
1068         help
1069           There are two drivers for MFM/RLL/IDE hard disks. Most people use
1070           the newer enhanced driver, but this old one is still around for two
1071           reasons. Some older systems have strange timing problems and seem to
1072           work only with the old driver (which itself does not work with some
1073           newer systems). The other reason is that the old driver is smaller,
1074           since it lacks the enhanced functionality of the new one. This makes
1075           it a good choice for systems with very tight memory restrictions, or
1076           for systems with only older MFM/RLL/ESDI drives. Choosing the old
1077           driver can save 13 KB or so of kernel memory.
1079           If you are unsure, then just choose the Enhanced IDE/MFM/RLL driver
1080           instead of this one. For more detailed information, read the
1081           Disk-HOWTO, available from
1082           <http://www.tldp.org/docs.html#howto>.
1084 config BLK_DEV_HD
1085         def_bool BLK_DEV_HD_IDE || BLK_DEV_HD_ONLY
1087 endif
1089 endmenu
1091 endif