USB: ldusb: Use usb_endpoint_* functions.
[linux-2.6] / drivers / scsi / Kconfig
1 menu "SCSI device support"
2
3 config RAID_ATTRS
4         tristate "RAID Transport Class"
5         default n
6         ---help---
7           Provides RAID
8
9 config SCSI
10         tristate "SCSI device support"
11         ---help---
12           If you want to use a SCSI hard disk, SCSI tape drive, SCSI CD-ROM or
13           any other SCSI device under Linux, say Y and make sure that you know
14           the name of your SCSI host adapter (the card inside your computer
15           that "speaks" the SCSI protocol, also called SCSI controller),
16           because you will be asked for it.
17
18           You also need to say Y here if you have a device which speaks
19           the SCSI protocol.  Examples of this include the parallel port
20           version of the IOMEGA ZIP drive, USB storage devices, Fibre
21           Channel, FireWire storage and the IDE-SCSI emulation driver.
22
23           To compile this driver as a module, choose M here and read
24           <file:Documentation/scsi/scsi.txt>.
25           The module will be called scsi_mod.
26
27           However, do not compile this as a module if your root file system
28           (the one containing the directory /) is located on a SCSI device.
29
30 config SCSI_NETLINK
31         bool
32         default n
33         select NET
34
35 config SCSI_PROC_FS
36         bool "legacy /proc/scsi/ support"
37         depends on SCSI && PROC_FS
38         default y
39         ---help---
40           This option enables support for the various files in
41           /proc/scsi.  In Linux 2.6 this has been superceeded by
42           files in sysfs but many legacy applications rely on this.
43
44           If unusure say Y.
45
46 comment "SCSI support type (disk, tape, CD-ROM)"
47         depends on SCSI
48
49 config BLK_DEV_SD
50         tristate "SCSI disk support"
51         depends on SCSI
52         ---help---
53           If you want to use SCSI hard disks, Fibre Channel disks,
54           USB storage or the SCSI or parallel port version of
55           the IOMEGA ZIP drive, say Y and read the SCSI-HOWTO,
56           the Disk-HOWTO and the Multi-Disk-HOWTO, available from
57           <http://www.tldp.org/docs.html#howto>. This is NOT for SCSI
58           CD-ROMs.
59
60           To compile this driver as a module, choose M here and read
61           <file:Documentation/scsi/scsi.txt>.
62           The module will be called sd_mod.
63
64           Do not compile this driver as a module if your root file system
65           (the one containing the directory /) is located on a SCSI disk.
66           In this case, do not compile the driver for your SCSI host adapter
67           (below) as a module either.
68
69 config CHR_DEV_ST
70         tristate "SCSI tape support"
71         depends on SCSI
72         ---help---
73           If you want to use a SCSI tape drive under Linux, say Y and read the
74           SCSI-HOWTO, available from
75           <http://www.tldp.org/docs.html#howto>, and
76           <file:Documentation/scsi/st.txt> in the kernel source.  This is NOT
77           for SCSI CD-ROMs.
78
79           To compile this driver as a module, choose M here and read
80           <file:Documentation/scsi/scsi.txt>. The module will be called st.
81
82 config CHR_DEV_OSST
83         tristate "SCSI OnStream SC-x0 tape support"
84         depends on SCSI
85         ---help---
86           The OnStream SC-x0 SCSI tape drives can not be driven by the
87           standard st driver, but instead need this special osst driver and
88           use the  /dev/osstX char device nodes (major 206).  Via usb-storage
89           and ide-scsi, you may be able to drive the USB-x0 and DI-x0 drives
90           as well.  Note that there is also a second generation of OnStream
91           tape drives (ADR-x0) that supports the standard SCSI-2 commands for
92           tapes (QIC-157) and can be driven by the standard driver st.
93           For more information, you may have a look at the SCSI-HOWTO
94           <http://www.tldp.org/docs.html#howto>  and
95           <file:Documentation/scsi/osst.txt>  in the kernel source.
96           More info on the OnStream driver may be found on
97           <http://linux1.onstream.nl/test/>
98           Please also have a look at the standard st docu, as most of it
99           applies to osst as well.
100
101           To compile this driver as a module, choose M here and read
102           <file:Documentation/scsi/scsi.txt>. The module will be called osst.
103
104 config BLK_DEV_SR
105         tristate "SCSI CDROM support"
106         depends on SCSI
107         ---help---
108           If you want to use a SCSI or FireWire CD-ROM under Linux,
109           say Y and read the SCSI-HOWTO and the CDROM-HOWTO at
110           <http://www.tldp.org/docs.html#howto>. Also make sure to say
111           Y or M to "ISO 9660 CD-ROM file system support" later.
112
113           To compile this driver as a module, choose M here and read
114           <file:Documentation/scsi/scsi.txt>.
115           The module will be called sr_mod.
116
117 config BLK_DEV_SR_VENDOR
118         bool "Enable vendor-specific extensions (for SCSI CDROM)"
119         depends on BLK_DEV_SR
120         help
121           This enables the usage of vendor specific SCSI commands. This is
122           required to support multisession CDs with old NEC/TOSHIBA cdrom
123           drives (and HP Writers). If you have such a drive and get the first
124           session only, try saying Y here; everybody else says N.
125
126 config CHR_DEV_SG
127         tristate "SCSI generic support"
128         depends on SCSI
129         ---help---
130           If you want to use SCSI scanners, synthesizers or CD-writers or just
131           about anything having "SCSI" in its name other than hard disks,
132           CD-ROMs or tapes, say Y here. These won't be supported by the kernel
133           directly, so you need some additional software which knows how to
134           talk to these devices using the SCSI protocol:
135
136           For scanners, look at SANE (<http://www.mostang.com/sane/>). For CD
137           writer software look at Cdrtools
138           (<http://www.fokus.gmd.de/research/cc/glone/employees/joerg.schilling/private/cdrecord.html>)
139           and for burning a "disk at once": CDRDAO
140           (<http://cdrdao.sourceforge.net/>). Cdparanoia is a high
141           quality digital reader of audio CDs (<http://www.xiph.org/paranoia/>).
142           For other devices, it's possible that you'll have to write the
143           driver software yourself. Please read the file
144           <file:Documentation/scsi/scsi-generic.txt> for more information.
145
146           To compile this driver as a module, choose M here and read
147           <file:Documentation/scsi/scsi.txt>. The module will be called sg.
148
149           If unsure, say N.
150
151 config CHR_DEV_SCH
152         tristate "SCSI media changer support"
153         depends on SCSI
154         ---help---
155           This is a driver for SCSI media changers.  Most common devices are
156           tape libraries and MOD/CDROM jukeboxes.  *Real* jukeboxes, you
157           don't need this for those tiny 6-slot cdrom changers.  Media
158           changers are listed as "Type: Medium Changer" in /proc/scsi/scsi.
159           If you have such hardware and want to use it with linux, say Y
160           here.  Check <file:Documentation/scsi-changer.txt> for details.
161         
162           If you want to compile this as a module ( = code which can be
163           inserted in and removed from the running kernel whenever you want),
164           say M here and read <file:Documentation/modules.txt> and
165           <file:Documentation/scsi.txt>. The module will be called ch.o.
166           If unsure, say N.
167         
168
169 comment "Some SCSI devices (e.g. CD jukebox) support multiple LUNs"
170         depends on SCSI
171
172 config SCSI_MULTI_LUN
173         bool "Probe all LUNs on each SCSI device"
174         depends on SCSI
175         help
176           If you have a SCSI device that supports more than one LUN (Logical
177           Unit Number), e.g. a CD jukebox, and only one LUN is detected, you
178           can say Y here to force the SCSI driver to probe for multiple LUNs.
179           A SCSI device with multiple LUNs acts logically like multiple SCSI
180           devices. The vast majority of SCSI devices have only one LUN, and
181           so most people can say N here. The max_luns boot/module parameter 
182           allows to override this setting.
183
184 config SCSI_CONSTANTS
185         bool "Verbose SCSI error reporting (kernel size +=12K)"
186         depends on SCSI
187         help
188           The error messages regarding your SCSI hardware will be easier to
189           understand if you say Y here; it will enlarge your kernel by about
190           12 KB. If in doubt, say Y.
191
192 config SCSI_LOGGING
193         bool "SCSI logging facility"
194         depends on SCSI
195         ---help---
196           This turns on a logging facility that can be used to debug a number
197           of SCSI related problems.
198
199           If you say Y here, no logging output will appear by default, but you
200           can enable logging by saying Y to "/proc file system support" and
201           "Sysctl support" below and executing the command
202
203           echo "scsi log token [level]" > /proc/scsi/scsi
204
205           at boot time after the /proc file system has been mounted.
206
207           There are a number of things that can be used for 'token' (you can
208           find them in the source: <file:drivers/scsi/scsi.c>), and this
209           allows you to select the types of information you want, and the
210           level allows you to select the level of verbosity.
211
212           If you say N here, it may be harder to track down some types of SCSI
213           problems. If you say Y here your kernel will be somewhat larger, but
214           there should be no noticeable performance impact as long as you have
215           logging turned off.
216
217 menu "SCSI Transports"
218         depends on SCSI
219
220 config SCSI_SPI_ATTRS
221         tristate "Parallel SCSI (SPI) Transport Attributes"
222         depends on SCSI
223         help
224           If you wish to export transport-specific information about
225           each attached SCSI device to sysfs, say Y.  Otherwise, say N.
226
227 config SCSI_FC_ATTRS
228         tristate "FiberChannel Transport Attributes"
229         depends on SCSI
230         select SCSI_NETLINK
231         help
232           If you wish to export transport-specific information about
233           each attached FiberChannel device to sysfs, say Y.
234           Otherwise, say N.
235
236 config SCSI_ISCSI_ATTRS
237         tristate "iSCSI Transport Attributes"
238         depends on SCSI && NET
239         help
240           If you wish to export transport-specific information about
241           each attached iSCSI device to sysfs, say Y.
242           Otherwise, say N.
243
244 config SCSI_SAS_ATTRS
245         tristate "SAS Transport Attributes"
246         depends on SCSI
247         help
248           If you wish to export transport-specific information about
249           each attached SAS device to sysfs, say Y.
250
251 source "drivers/scsi/libsas/Kconfig"
252
253 endmenu
254
255 menu "SCSI low-level drivers"
256         depends on SCSI!=n
257
258 config ISCSI_TCP
259         tristate "iSCSI Initiator over TCP/IP"
260         depends on SCSI && INET
261         select CRYPTO
262         select CRYPTO_MD5
263         select CRYPTO_CRC32C
264         select SCSI_ISCSI_ATTRS
265         help
266          The iSCSI Driver provides a host with the ability to access storage
267          through an IP network. The driver uses the iSCSI protocol to transport
268          SCSI requests and responses over a TCP/IP network between the host
269          (the "initiator") and "targets".  Architecturally, the iSCSI driver
270          combines with the host's TCP/IP stack, network drivers, and Network
271          Interface Card (NIC) to provide the same functions as a SCSI or a
272          Fibre Channel (FC) adapter driver with a Host Bus Adapter (HBA).
273
274          To compile this driver as a module, choose M here: the
275          module will be called iscsi_tcp.
276
277          The userspace component needed to initialize the driver, documentation,
278          and sample configuration files can be found here:
279
280          http://linux-iscsi.sf.net
281
282 config SGIWD93_SCSI
283         tristate "SGI WD93C93 SCSI Driver"
284         depends on SGI_IP22 && SCSI
285         help
286           If you have a Western Digital WD93 SCSI controller on
287           an SGI MIPS system, say Y.  Otherwise, say N.
288
289 config SCSI_DECNCR
290         tristate "DEC NCR53C94 Scsi Driver"
291         depends on MACH_DECSTATION && SCSI && TC
292         help
293           Say Y here to support the NCR53C94 SCSI controller chips on IOASIC
294           based TURBOchannel DECstations and TURBOchannel PMAZ-A cards.
295
296 config SCSI_DECSII
297         tristate "DEC SII Scsi Driver"
298         depends on MACH_DECSTATION && SCSI && 32BIT
299
300 config BLK_DEV_3W_XXXX_RAID
301         tristate "3ware 5/6/7/8xxx ATA-RAID support"
302         depends on PCI && SCSI
303         help
304           3ware is the only hardware ATA-Raid product in Linux to date.
305           This card is 2,4, or 8 channel master mode support only.
306           SCSI support required!!!
307
308           <http://www.3ware.com/>
309
310           Please read the comments at the top of
311           <file:drivers/scsi/3w-xxxx.c>.
312
313 config SCSI_3W_9XXX
314         tristate "3ware 9xxx SATA-RAID support"
315         depends on PCI && SCSI
316         help
317           This driver supports the 9000 series 3ware SATA-RAID cards.
318
319           <http://www.amcc.com>
320
321           Please read the comments at the top of
322           <file:drivers/scsi/3w-9xxx.c>.
323
324 config SCSI_7000FASST
325         tristate "7000FASST SCSI support"
326         depends on ISA && SCSI && ISA_DMA_API
327         help
328           This driver supports the Western Digital 7000 SCSI host adapter
329           family.  Some information is in the source:
330           <file:drivers/scsi/wd7000.c>.
331
332           To compile this driver as a module, choose M here: the
333           module will be called wd7000.
334
335 config SCSI_ACARD
336         tristate "ACARD SCSI support"
337         depends on PCI && SCSI
338         help
339           This driver supports the ACARD SCSI host adapter.
340           Support Chip <ATP870 ATP876 ATP880 ATP885>
341           To compile this driver as a module, choose M here: the
342           module will be called atp870u.
343
344 config SCSI_AHA152X
345         tristate "Adaptec AHA152X/2825 support"
346         depends on ISA && SCSI && !64BIT
347         select SCSI_SPI_ATTRS
348         ---help---
349           This is a driver for the AHA-1510, AHA-1520, AHA-1522, and AHA-2825
350           SCSI host adapters. It also works for the AVA-1505, but the IRQ etc.
351           must be manually specified in this case.
352
353           It is explained in section 3.3 of the SCSI-HOWTO, available from
354           <http://www.tldp.org/docs.html#howto>. You might also want to
355           read the file <file:Documentation/scsi/aha152x.txt>.
356
357           To compile this driver as a module, choose M here: the
358           module will be called aha152x.
359
360 config SCSI_AHA1542
361         tristate "Adaptec AHA1542 support"
362         depends on ISA && SCSI && ISA_DMA_API
363         ---help---
364           This is support for a SCSI host adapter.  It is explained in section
365           3.4 of the SCSI-HOWTO, available from
366           <http://www.tldp.org/docs.html#howto>.  Note that Trantor was
367           purchased by Adaptec, and some former Trantor products are being
368           sold under the Adaptec name.  If it doesn't work out of the box, you
369           may have to change some settings in <file:drivers/scsi/aha1542.h>.
370
371           To compile this driver as a module, choose M here: the
372           module will be called aha1542.
373
374 config SCSI_AHA1740
375         tristate "Adaptec AHA1740 support"
376         depends on EISA && SCSI
377         ---help---
378           This is support for a SCSI host adapter.  It is explained in section
379           3.5 of the SCSI-HOWTO, available from
380           <http://www.tldp.org/docs.html#howto>.  If it doesn't work out
381           of the box, you may have to change some settings in
382           <file:drivers/scsi/aha1740.h>.
383
384           To compile this driver as a module, choose M here: the
385           module will be called aha1740.
386
387 config SCSI_AACRAID
388         tristate "Adaptec AACRAID support"
389         depends on SCSI && PCI
390         help
391           This driver supports a variety of Dell, HP, Adaptec, IBM and
392           ICP storage products. For a list of supported products, refer
393           to <file:Documentation/scsi/aacraid.txt>.
394
395           To compile this driver as a module, choose M here: the module
396           will be called aacraid.
397
398
399 source "drivers/scsi/aic7xxx/Kconfig.aic7xxx"
400
401 config SCSI_AIC7XXX_OLD
402         tristate "Adaptec AIC7xxx support (old driver)"
403         depends on (ISA || EISA || PCI ) && SCSI
404         help
405           WARNING This driver is an older aic7xxx driver and is no longer
406           under active development.  Adaptec, Inc. is writing a new driver to
407           take the place of this one, and it is recommended that whenever
408           possible, people should use the new Adaptec written driver instead
409           of this one.  This driver will eventually be phased out entirely.
410
411           This is support for the various aic7xxx based Adaptec SCSI
412           controllers. These include the 274x EISA cards; 284x VLB cards;
413           2902, 2910, 293x, 294x, 394x, 3985 and several other PCI and
414           motherboard based SCSI controllers from Adaptec. It does not support
415           the AAA-13x RAID controllers from Adaptec, nor will it likely ever
416           support them. It does not support the 2920 cards from Adaptec that
417           use the Future Domain SCSI controller chip. For those cards, you
418           need the "Future Domain 16xx SCSI support" driver.
419
420           In general, if the controller is based on an Adaptec SCSI controller
421           chip from the aic777x series or the aic78xx series, this driver
422           should work. The only exception is the 7810 which is specifically
423           not supported (that's the RAID controller chip on the AAA-13x
424           cards).
425
426           Note that the AHA2920 SCSI host adapter is *not* supported by this
427           driver; choose "Future Domain 16xx SCSI support" instead if you have
428           one of those.
429
430           Information on the configuration options for this controller can be
431           found by checking the help file for each of the available
432           configuration options. You should read
433           <file:Documentation/scsi/aic7xxx_old.txt> at a minimum before
434           contacting the maintainer with any questions.  The SCSI-HOWTO,
435           available from <http://www.tldp.org/docs.html#howto>, can also
436           be of great help.
437
438           To compile this driver as a module, choose M here: the
439           module will be called aic7xxx_old.
440
441 source "drivers/scsi/aic7xxx/Kconfig.aic79xx"
442 source "drivers/scsi/aic94xx/Kconfig"
443
444 # All the I2O code and drivers do not seem to be 64bit safe.
445 config SCSI_DPT_I2O
446         tristate "Adaptec I2O RAID support "
447         depends on !64BIT && SCSI && PCI
448         help
449           This driver supports all of Adaptec's I2O based RAID controllers as 
450           well as the DPT SmartRaid V cards.  This is an Adaptec maintained
451           driver by Deanna Bonds.  See <file:Documentation/scsi/dpti.txt>.
452
453           To compile this driver as a module, choose M here: the
454           module will be called dpt_i2o.
455
456 config SCSI_ADVANSYS
457         tristate "AdvanSys SCSI support"
458         depends on SCSI
459         depends on ISA || EISA || PCI
460         depends on BROKEN || X86_32
461         help
462           This is a driver for all SCSI host adapters manufactured by
463           AdvanSys. It is documented in the kernel source in
464           <file:drivers/scsi/advansys.c>.
465
466           To compile this driver as a module, choose M here: the
467           module will be called advansys.
468
469 config SCSI_IN2000
470         tristate "Always IN2000 SCSI support"
471         depends on ISA && SCSI
472         help
473           This is support for an ISA bus SCSI host adapter.  You'll find more
474           information in <file:Documentation/scsi/in2000.txt>. If it doesn't work
475           out of the box, you may have to change the jumpers for IRQ or
476           address selection.
477
478           To compile this driver as a module, choose M here: the
479           module will be called in2000.
480
481 config SCSI_ARCMSR
482         tristate "ARECA ARC11X0[PCI-X]/ARC12X0[PCI-EXPRESS] SATA-RAID support"
483         depends on PCI && SCSI
484         help
485           This driver supports all of ARECA's SATA RAID controller cards.
486           This is an ARECA-maintained driver by Erich Chen.
487           If you have any problems, please mail to: < erich@areca.com.tw >
488           Areca supports Linux RAID config tools.
489
490           < http://www.areca.com.tw >
491
492           To compile this driver as a module, choose M here: the
493           module will be called arcmsr (modprobe arcmsr).
494
495 source "drivers/scsi/megaraid/Kconfig.megaraid"
496
497 config SCSI_HPTIOP
498         tristate "HighPoint RocketRAID 3xxx Controller support"
499         depends on SCSI && PCI
500         help
501           This option enables support for HighPoint RocketRAID 3xxx
502           controllers.
503
504           To compile this driver as a module, choose M here; the module
505           will be called hptiop. If unsure, say N.
506
507 config SCSI_BUSLOGIC
508         tristate "BusLogic SCSI support"
509         depends on (PCI || ISA || MCA) && SCSI && ISA_DMA_API
510         ---help---
511           This is support for BusLogic MultiMaster and FlashPoint SCSI Host
512           Adapters. Consult the SCSI-HOWTO, available from
513           <http://www.tldp.org/docs.html#howto>, and the files
514           <file:Documentation/scsi/BusLogic.txt> and
515           <file:Documentation/scsi/FlashPoint.txt> for more information.
516
517           To compile this driver as a module, choose M here: the
518           module will be called BusLogic.
519
520 config SCSI_OMIT_FLASHPOINT
521         bool "Omit FlashPoint support"
522         depends on SCSI_BUSLOGIC
523         help
524           This option allows you to omit the FlashPoint support from the
525           BusLogic SCSI driver. The FlashPoint SCCB Manager code is
526           substantial, so users of MultiMaster Host Adapters may wish to omit
527           it.
528
529 config SCSI_DMX3191D
530         tristate "DMX3191D SCSI support"
531         depends on PCI && SCSI
532         select SCSI_SPI_ATTRS
533         help
534           This is support for Domex DMX3191D SCSI Host Adapters.
535
536           To compile this driver as a module, choose M here: the
537           module will be called dmx3191d.
538
539 config SCSI_DTC3280
540         tristate "DTC3180/3280 SCSI support"
541         depends on ISA && SCSI
542         select SCSI_SPI_ATTRS
543         help
544           This is support for DTC 3180/3280 SCSI Host Adapters.  Please read
545           the SCSI-HOWTO, available from
546           <http://www.tldp.org/docs.html#howto>, and the file
547           <file:Documentation/scsi/dtc3x80.txt>.
548
549           To compile this driver as a module, choose M here: the
550           module will be called dtc.
551
552 config SCSI_EATA
553         tristate "EATA ISA/EISA/PCI (DPT and generic EATA/DMA-compliant boards) support"
554         depends on (ISA || EISA || PCI) && SCSI && ISA_DMA_API
555         ---help---
556           This driver supports all EATA/DMA-compliant SCSI host adapters.  DPT
557           ISA and all EISA I/O addresses are probed looking for the "EATA"
558           signature. The addresses of all the PCI SCSI controllers reported
559           by the PCI subsystem are probed as well.
560
561           You want to read the start of <file:drivers/scsi/eata.c> and the
562           SCSI-HOWTO, available from
563           <http://www.tldp.org/docs.html#howto>.
564
565           To compile this driver as a module, choose M here: the
566           module will be called eata.
567
568 config SCSI_EATA_TAGGED_QUEUE
569         bool "enable tagged command queueing"
570         depends on SCSI_EATA
571         help
572           This is a feature of SCSI-2 which improves performance: the host
573           adapter can send several SCSI commands to a device's queue even if
574           previous commands haven't finished yet.
575           This is equivalent to the "eata=tc:y" boot option.
576
577 config SCSI_EATA_LINKED_COMMANDS
578         bool "enable elevator sorting"
579         depends on SCSI_EATA
580         help
581           This option enables elevator sorting for all probed SCSI disks and
582           CD-ROMs. It definitely reduces the average seek distance when doing
583           random seeks, but this does not necessarily result in a noticeable
584           performance improvement: your mileage may vary...
585           This is equivalent to the "eata=lc:y" boot option.
586
587 config SCSI_EATA_MAX_TAGS
588         int "maximum number of queued commands"
589         depends on SCSI_EATA
590         default "16"
591         help
592           This specifies how many SCSI commands can be maximally queued for
593           each probed SCSI device. You should reduce the default value of 16
594           only if you have disks with buggy or limited tagged command support.
595           Minimum is 2 and maximum is 62. This value is also the window size
596           used by the elevator sorting option above. The effective value used
597           by the driver for each probed SCSI device is reported at boot time.
598           This is equivalent to the "eata=mq:8" boot option.
599
600 config SCSI_EATA_PIO
601         tristate "EATA-PIO (old DPT PM2001, PM2012A) support"
602         depends on (ISA || EISA || PCI) && SCSI && BROKEN
603         ---help---
604           This driver supports all EATA-PIO protocol compliant SCSI Host
605           Adapters like the DPT PM2001 and the PM2012A.  EATA-DMA compliant
606           host adapters could also use this driver but are discouraged from
607           doing so, since this driver only supports hard disks and lacks
608           numerous features.  You might want to have a look at the SCSI-HOWTO,
609           available from <http://www.tldp.org/docs.html#howto>.
610
611           To compile this driver as a module, choose M here: the
612           module will be called eata_pio.
613
614 config SCSI_FUTURE_DOMAIN
615         tristate "Future Domain 16xx SCSI/AHA-2920A support"
616         depends on (ISA || PCI) && SCSI
617         ---help---
618           This is support for Future Domain's 16-bit SCSI host adapters
619           (TMC-1660/1680, TMC-1650/1670, TMC-3260, TMC-1610M/MER/MEX) and
620           other adapters based on the Future Domain chipsets (Quantum
621           ISA-200S, ISA-250MG; Adaptec AHA-2920A; and at least one IBM board).
622           It is explained in section 3.7 of the SCSI-HOWTO, available from
623           <http://www.tldp.org/docs.html#howto>.
624
625           NOTE: Newer Adaptec AHA-2920C boards use the Adaptec AIC-7850 chip
626           and should use the aic7xxx driver ("Adaptec AIC7xxx chipset SCSI
627           controller support"). This Future Domain driver works with the older
628           Adaptec AHA-2920A boards with a Future Domain chip on them.
629
630           To compile this driver as a module, choose M here: the
631           module will be called fdomain.
632
633 config SCSI_FD_MCS
634         tristate "Future Domain MCS-600/700 SCSI support"
635         depends on MCA_LEGACY && SCSI
636         ---help---
637           This is support for Future Domain MCS 600/700 MCA SCSI adapters.
638           Some PS/2 computers are equipped with IBM Fast SCSI Adapter/A which
639           is identical to the MCS 700 and hence also supported by this driver.
640           This driver also supports the Reply SB16/SCSI card (the SCSI part).
641           It supports multiple adapters in the same system.
642
643           To compile this driver as a module, choose M here: the
644           module will be called fd_mcs.
645
646 config SCSI_GDTH
647         tristate "Intel/ICP (former GDT SCSI Disk Array) RAID Controller support"
648         depends on (ISA || EISA || PCI) && SCSI && ISA_DMA_API
649         ---help---
650           Formerly called GDT SCSI Disk Array Controller Support.
651
652           This is a driver for RAID/SCSI Disk Array Controllers (EISA/ISA/PCI) 
653           manufactured by Intel Corporation/ICP vortex GmbH. It is documented
654           in the kernel source in <file:drivers/scsi/gdth.c> and
655           <file:drivers/scsi/gdth.h.>
656
657           To compile this driver as a module, choose M here: the
658           module will be called gdth.
659
660 config SCSI_GENERIC_NCR5380
661         tristate "Generic NCR5380/53c400 SCSI PIO support"
662         depends on ISA && SCSI
663         select SCSI_SPI_ATTRS
664         ---help---
665           This is a driver for the old NCR 53c80 series of SCSI controllers
666           on boards using PIO. Most boards such as the Trantor T130 fit this
667           category, along with a large number of ISA 8bit controllers shipped
668           for free with SCSI scanners. If you have a PAS16, T128 or DMX3191
669           you should select the specific driver for that card rather than
670           generic 5380 support.
671
672           It is explained in section 3.8 of the SCSI-HOWTO, available from
673           <http://www.tldp.org/docs.html#howto>.  If it doesn't work out
674           of the box, you may have to change some settings in
675           <file:drivers/scsi/g_NCR5380.h>.
676
677           To compile this driver as a module, choose M here: the
678           module will be called g_NCR5380.
679
680 config SCSI_GENERIC_NCR5380_MMIO
681         tristate "Generic NCR5380/53c400 SCSI MMIO support"
682         depends on ISA && SCSI
683         select SCSI_SPI_ATTRS
684         ---help---
685           This is a driver for the old NCR 53c80 series of SCSI controllers
686           on boards using memory mapped I/O. 
687           It is explained in section 3.8 of the SCSI-HOWTO, available from
688           <http://www.tldp.org/docs.html#howto>.  If it doesn't work out
689           of the box, you may have to change some settings in
690           <file:drivers/scsi/g_NCR5380.h>.
691
692           To compile this driver as a module, choose M here: the
693           module will be called g_NCR5380_mmio.
694
695 config SCSI_GENERIC_NCR53C400
696         bool "Enable NCR53c400 extensions"
697         depends on SCSI_GENERIC_NCR5380
698         help
699           This enables certain optimizations for the NCR53c400 SCSI cards.
700           You might as well try it out.  Note that this driver will only probe
701           for the Trantor T130B in its default configuration; you might have
702           to pass a command line option to the kernel at boot time if it does
703           not detect your card.  See the file
704           <file:Documentation/scsi/g_NCR5380.txt> for details.
705
706 config SCSI_IBMMCA
707         tristate "IBMMCA SCSI support"
708         depends on MCA_LEGACY && SCSI
709         ---help---
710           This is support for the IBM SCSI adapter found in many of the PS/2
711           series computers.  These machines have an MCA bus, so you need to
712           answer Y to "MCA support" as well and read
713           <file:Documentation/mca.txt>.
714
715           If the adapter isn't found during boot (a common problem for models
716           56, 57, 76, and 77) you'll need to use the 'ibmmcascsi=<pun>' kernel
717           option, where <pun> is the id of the SCSI subsystem (usually 7, but
718           if that doesn't work check your reference diskette).  Owners of
719           model 95 with a LED-matrix-display can in addition activate some
720           activity info like under OS/2, but more informative, by setting
721           'ibmmcascsi=display' as an additional kernel parameter.  Try "man
722           bootparam" or see the documentation of your boot loader about how to
723           pass options to the kernel.
724
725           To compile this driver as a module, choose M here: the
726           module will be called ibmmca.
727
728 config IBMMCA_SCSI_ORDER_STANDARD
729         bool "Standard SCSI-order"
730         depends on SCSI_IBMMCA
731         ---help---
732           In the PC-world and in most modern SCSI-BIOS-setups, SCSI-hard disks
733           are assigned to the drive letters, starting with the lowest SCSI-id
734           (physical number -- pun) to be drive C:, as seen from DOS and
735           similar operating systems. When looking into papers describing the
736           ANSI-SCSI-standard, this assignment of drives appears to be wrong.
737           The SCSI-standard follows a hardware-hierarchy which says that id 7
738           has the highest priority and id 0 the lowest. Therefore, the host
739           adapters are still today everywhere placed as SCSI-id 7 by default.
740           In the SCSI-standard, the drive letters express the priority of the
741           disk. C: should be the hard disk, or a partition on it, with the
742           highest priority. This must therefore be the disk with the highest
743           SCSI-id (e.g. 6) and not the one with the lowest! IBM-BIOS kept the
744           original definition of the SCSI-standard as also industrial- and
745           process-control-machines, like VME-CPUs running under realtime-OSes
746           (e.g. LynxOS, OS9) do.
747
748           If you like to run Linux on your MCA-machine with the same
749           assignment of hard disks as seen from e.g. DOS or OS/2 on your
750           machine, which is in addition conformant to the SCSI-standard, you
751           must say Y here. This is also necessary for MCA-Linux users who want
752           to keep downward compatibility to older releases of the
753           IBM-MCA-SCSI-driver (older than driver-release 2.00 and older than
754           June 1997).
755
756           If you like to have the lowest SCSI-id assigned as drive C:, as
757           modern SCSI-BIOSes do, which does not conform to the standard, but
758           is widespread and common in the PC-world of today, you must say N
759           here. If unsure, say Y.
760
761 config IBMMCA_SCSI_DEV_RESET
762         bool "Reset SCSI-devices at boottime"
763         depends on SCSI_IBMMCA
764         ---help---
765           By default, SCSI-devices are reset when the machine is powered on.
766           However, some devices exist, like special-control-devices,
767           SCSI-CNC-machines, SCSI-printer or scanners of older type, that do
768           not reset when switched on. If you say Y here, each device connected
769           to your SCSI-bus will be issued a reset-command after it has been
770           probed, while the kernel is booting. This may cause problems with
771           more modern devices, like hard disks, which do not appreciate these
772           reset commands, and can cause your system to hang. So say Y only if
773           you know that one of your older devices needs it; N is the safe
774           answer.
775
776 config SCSI_IPS
777         tristate "IBM ServeRAID support"
778         depends on PCI && SCSI
779         ---help---
780           This is support for the IBM ServeRAID hardware RAID controllers.
781           See <http://www.developer.ibm.com/welcome/netfinity/serveraid.html>
782           for more information.  If this driver does not work correctly
783           without modification please contact the author by email at
784           <ipslinux@adaptec.com>.
785
786           To compile this driver as a module, choose M here: the
787           module will be called ips.
788
789 config SCSI_IBMVSCSI
790         tristate "IBM Virtual SCSI support"
791         depends on PPC_PSERIES || PPC_ISERIES
792         help
793           This is the IBM POWER Virtual SCSI Client
794
795           To compile this driver as a module, choose M here: the
796           module will be called ibmvscsic.
797
798 config SCSI_INITIO
799         tristate "Initio 9100U(W) support"
800         depends on PCI && SCSI
801         help
802           This is support for the Initio 91XXU(W) SCSI host adapter.  Please
803           read the SCSI-HOWTO, available from
804           <http://www.tldp.org/docs.html#howto>.
805
806           To compile this driver as a module, choose M here: the
807           module will be called initio.
808
809 config SCSI_INIA100
810         tristate "Initio INI-A100U2W support"
811         depends on PCI && SCSI
812         help
813           This is support for the Initio INI-A100U2W SCSI host adapter.
814           Please read the SCSI-HOWTO, available from
815           <http://www.tldp.org/docs.html#howto>.
816
817           To compile this driver as a module, choose M here: the
818           module will be called a100u2w.
819
820 config SCSI_PPA
821         tristate "IOMEGA parallel port (ppa - older drives)"
822         depends on SCSI && PARPORT_PC
823         ---help---
824           This driver supports older versions of IOMEGA's parallel port ZIP
825           drive (a 100 MB removable media device).
826
827           Note that you can say N here if you have the SCSI version of the ZIP
828           drive: it will be supported automatically if you said Y to the
829           generic "SCSI disk support", above.
830
831           If you have the ZIP Plus drive or a more recent parallel port ZIP
832           drive (if the supplied cable with the drive is labeled "AutoDetect")
833           then you should say N here and Y to "IOMEGA parallel port (imm -
834           newer drives)", below.
835
836           For more information about this driver and how to use it you should
837           read the file <file:Documentation/scsi/ppa.txt>.  You should also read
838           the SCSI-HOWTO, which is available from
839           <http://www.tldp.org/docs.html#howto>.  If you use this driver,
840           you will still be able to use the parallel port for other tasks,
841           such as a printer; it is safe to compile both drivers into the
842           kernel.
843
844           To compile this driver as a module, choose M here: the
845           module will be called ppa.
846
847 config SCSI_IMM
848         tristate "IOMEGA parallel port (imm - newer drives)"
849         depends on SCSI && PARPORT_PC
850         ---help---
851           This driver supports newer versions of IOMEGA's parallel port ZIP
852           drive (a 100 MB removable media device).
853
854           Note that you can say N here if you have the SCSI version of the ZIP
855           drive: it will be supported automatically if you said Y to the
856           generic "SCSI disk support", above.
857
858           If you have the ZIP Plus drive or a more recent parallel port ZIP
859           drive (if the supplied cable with the drive is labeled "AutoDetect")
860           then you should say Y here; if you have an older ZIP drive, say N
861           here and Y to "IOMEGA Parallel Port (ppa - older drives)", above.
862
863           For more information about this driver and how to use it you should
864           read the file <file:Documentation/scsi/ppa.txt>.  You should also read
865           the SCSI-HOWTO, which is available from
866           <http://www.tldp.org/docs.html#howto>.  If you use this driver,
867           you will still be able to use the parallel port for other tasks,
868           such as a printer; it is safe to compile both drivers into the
869           kernel.
870
871           To compile this driver as a module, choose M here: the
872           module will be called imm.
873
874 config SCSI_IZIP_EPP16
875         bool "ppa/imm option - Use slow (but safe) EPP-16"
876         depends on SCSI_PPA || SCSI_IMM
877         ---help---
878           EPP (Enhanced Parallel Port) is a standard for parallel ports which
879           allows them to act as expansion buses that can handle up to 64
880           peripheral devices.
881
882           Some parallel port chipsets are slower than their motherboard, and
883           so we have to control the state of the chipset's FIFO queue every
884           now and then to avoid data loss. This will be done if you say Y
885           here.
886
887           Generally, saying Y is the safe option and slows things down a bit.
888
889 config SCSI_IZIP_SLOW_CTR
890         bool "ppa/imm option - Assume slow parport control register"
891         depends on SCSI_PPA || SCSI_IMM
892         help
893           Some parallel ports are known to have excessive delays between
894           changing the parallel port control register and good data being
895           available on the parallel port data/status register. This option
896           forces a small delay (1.0 usec to be exact) after changing the
897           control register to let things settle out. Enabling this option may
898           result in a big drop in performance but some very old parallel ports
899           (found in 386 vintage machines) will not work properly.
900
901           Generally, saying N is fine.
902
903 config SCSI_NCR53C406A
904         tristate "NCR53c406a SCSI support"
905         depends on ISA && SCSI
906         help
907           This is support for the NCR53c406a SCSI host adapter.  For user
908           configurable parameters, check out <file:drivers/scsi/NCR53c406a.c>
909           in the kernel source.  Also read the SCSI-HOWTO, available from
910           <http://www.tldp.org/docs.html#howto>.
911
912           To compile this driver as a module, choose M here: the
913           module will be called NCR53c406.
914
915 config SCSI_NCR_D700
916         tristate "NCR Dual 700 MCA SCSI support"
917         depends on MCA && SCSI
918         select SCSI_SPI_ATTRS
919         help
920           This is a driver for the MicroChannel Dual 700 card produced by
921           NCR and commonly used in 345x/35xx/4100 class machines.  It always
922           tries to negotiate sync and uses tag command queueing.
923
924           Unless you have an NCR manufactured machine, the chances are that
925           you do not have this SCSI card, so say N.
926
927 config SCSI_LASI700
928         tristate "HP Lasi SCSI support for 53c700/710"
929         depends on GSC && SCSI
930         select SCSI_SPI_ATTRS
931         help
932           This is a driver for the SCSI controller in the Lasi chip found in
933           many PA-RISC workstations & servers.  If you do not know whether you
934           have a Lasi chip, it is safe to say "Y" here.
935
936 config 53C700_LE_ON_BE
937         bool
938         depends on SCSI_LASI700
939         default y
940
941 config SCSI_STEX
942         tristate "Promise SuperTrak EX Series support"
943         depends on PCI && SCSI
944         ---help---
945           This driver supports Promise SuperTrak EX8350/8300/16350/16300
946           Storage controllers.
947
948 config SCSI_SYM53C8XX_2
949         tristate "SYM53C8XX Version 2 SCSI support"
950         depends on PCI && SCSI
951         select SCSI_SPI_ATTRS
952         ---help---
953           This driver supports the whole NCR53C8XX/SYM53C8XX family of
954           PCI-SCSI controllers.  It also supports the subset of LSI53C10XX
955           Ultra-160 controllers that are based on the SYM53C8XX SCRIPTS
956           language.  It does not support LSI53C10XX Ultra-320 PCI-X SCSI
957           controllers; you need to use the Fusion MPT driver for that.
958
959           Please read <file:Documentation/scsi/sym53c8xx_2.txt> for more
960           information.
961
962 config SCSI_SYM53C8XX_DMA_ADDRESSING_MODE
963         int "DMA addressing mode"
964         depends on SCSI_SYM53C8XX_2
965         default "1"
966         ---help---
967           This option only applies to PCI-SCSI chips that are PCI DAC
968           capable (875A, 895A, 896, 1010-33, 1010-66, 1000).
969
970           When set to 0, the driver will program the chip to only perform
971           32-bit DMA.  When set to 1, the chip will be able to perform DMA
972           to addresses up to 1TB.  When set to 2, the driver supports the
973           full 64-bit DMA address range, but can only address 16 segments
974           of 4 GB each.  This limits the total addressable range to 64 GB.
975
976           Most machines with less than 4GB of memory should use a setting
977           of 0 for best performance.  If your machine has 4GB of memory
978           or more, you should set this option to 1 (the default).
979
980           The still experimental value 2 (64 bit DMA addressing with 16
981           x 4GB segments limitation) can be used on systems that require
982           PCI address bits past bit 39 to be set for the addressing of
983           memory using PCI DAC cycles.
984
985 config SCSI_SYM53C8XX_DEFAULT_TAGS
986         int "Default tagged command queue depth"
987         depends on SCSI_SYM53C8XX_2
988         default "16"
989         help
990           This is the default value of the command queue depth the
991           driver will announce to the generic SCSI layer for devices
992           that support tagged command queueing. This value can be changed
993           from the boot command line.  This is a soft limit that cannot
994           exceed CONFIG_SCSI_SYM53C8XX_MAX_TAGS.
995
996 config SCSI_SYM53C8XX_MAX_TAGS
997         int "Maximum number of queued commands"
998         depends on SCSI_SYM53C8XX_2
999         default "64"
1000         help
1001           This option allows you to specify the maximum number of commands
1002           that can be queued to any device, when tagged command queuing is
1003           possible. The driver supports up to 256 queued commands per device.
1004           This value is used as a compiled-in hard limit.
1005
1006 config SCSI_SYM53C8XX_MMIO
1007         bool "Use memory mapped IO"
1008         depends on SCSI_SYM53C8XX_2
1009         default y
1010         help
1011           Memory mapped IO is faster than Port IO.  Most people should
1012           answer Y here, but some machines may have problems.  If you have
1013           to answer N here, please report the problem to the maintainer.
1014
1015 config SCSI_IPR
1016         tristate "IBM Power Linux RAID adapter support"
1017         depends on PCI && SCSI
1018         select FW_LOADER
1019         ---help---
1020           This driver supports the IBM Power Linux family RAID adapters.
1021           This includes IBM pSeries 5712, 5703, 5709, and 570A, as well
1022           as IBM iSeries 5702, 5703, 5709, and 570A.
1023
1024 config SCSI_IPR_TRACE
1025         bool "enable driver internal trace"
1026         depends on SCSI_IPR
1027         help
1028           If you say Y here, the driver will trace all commands issued
1029           to the adapter. Performance impact is minimal. Trace can be
1030           dumped using /sys/bus/class/scsi_host/hostXX/trace.
1031
1032 config SCSI_IPR_DUMP
1033         bool "enable adapter dump support"
1034         depends on SCSI_IPR
1035         help
1036           If you say Y here, the driver will support adapter crash dump.
1037           If you enable this support, the iprdump daemon can be used
1038           to capture adapter failure analysis information.
1039
1040 config SCSI_ZALON
1041         tristate "Zalon SCSI support"
1042         depends on GSC && SCSI
1043         select SCSI_SPI_ATTRS
1044         help
1045           The Zalon is a GSC/HSC bus interface chip that sits between the
1046           PA-RISC processor and the NCR 53c720 SCSI controller on C100,
1047           C110, J200, J210 and some D, K & R-class machines.  It's also
1048           used on the add-in Bluefish, Barracuda & Shrike SCSI cards.
1049           Say Y here if you have one of these machines or cards.
1050
1051 config SCSI_NCR_Q720
1052         tristate "NCR Quad 720 MCA SCSI support"
1053         depends on MCA && SCSI
1054         select SCSI_SPI_ATTRS
1055         help
1056           This is a driver for the MicroChannel Quad 720 card produced by
1057           NCR and commonly used in 345x/35xx/4100 class machines.  It always
1058           tries to negotiate sync and uses tag command queueing.
1059
1060           Unless you have an NCR manufactured machine, the chances are that
1061           you do not have this SCSI card, so say N.
1062
1063 config SCSI_NCR53C8XX_DEFAULT_TAGS
1064         int "default tagged command queue depth"
1065         depends on SCSI_ZALON || SCSI_NCR_Q720
1066         default "8"
1067         ---help---
1068           "Tagged command queuing" is a feature of SCSI-2 which improves
1069           performance: the host adapter can send several SCSI commands to a
1070           device's queue even if previous commands haven't finished yet.
1071           Because the device is intelligent, it can optimize its operations
1072           (like head positioning) based on its own request queue. Some SCSI
1073           devices don't implement this properly; if you want to disable this
1074           feature, enter 0 or 1 here (it doesn't matter which).
1075
1076           The default value is 8 and should be supported by most hard disks.
1077           This value can be overridden from the boot command line using the
1078           'tags' option as follows (example):
1079           'ncr53c8xx=tags:4/t2t3q16/t0u2q10' will set default queue depth to
1080           4, set queue depth to 16 for target 2 and target 3 on controller 0
1081           and set queue depth to 10 for target 0 / lun 2 on controller 1.
1082
1083           The normal answer therefore is to go with the default 8 and to use
1084           a boot command line option for devices that need to use a different
1085           command queue depth.
1086
1087           There is no safe option other than using good SCSI devices.
1088
1089 config SCSI_NCR53C8XX_MAX_TAGS
1090         int "maximum number of queued commands"
1091         depends on SCSI_ZALON || SCSI_NCR_Q720
1092         default "32"
1093         ---help---
1094           This option allows you to specify the maximum number of commands
1095           that can be queued to any device, when tagged command queuing is
1096           possible. The default value is 32. Minimum is 2, maximum is 64.
1097           Modern hard disks are able to support 64 tags and even more, but
1098           do not seem to be faster when more than 32 tags are being used.
1099
1100           So, the normal answer here is to go with the default value 32 unless
1101           you are using very large hard disks with large cache (>= 1 MB) that
1102           are able to take advantage of more than 32 tagged commands.
1103
1104           There is no safe option and the default answer is recommended.
1105
1106 config SCSI_NCR53C8XX_SYNC
1107         int "synchronous transfers frequency in MHz"
1108         depends on SCSI_ZALON || SCSI_NCR_Q720
1109         default "20"
1110         ---help---
1111           The SCSI Parallel Interface-2 Standard defines 5 classes of transfer
1112           rates: FAST-5, FAST-10, FAST-20, FAST-40 and FAST-80.  The numbers
1113           are respectively the maximum data transfer rates in mega-transfers
1114           per second for each class.  For example, a FAST-20 Wide 16 device is
1115           able to transfer data at 20 million 16 bit packets per second for a
1116           total rate of 40 MB/s.
1117
1118           You may specify 0 if you want to only use asynchronous data
1119           transfers. This is the safest and slowest option. Otherwise, specify
1120           a value between 5 and 80, depending on the capability of your SCSI
1121           controller.  The higher the number, the faster the data transfer.
1122           Note that 80 should normally be ok since the driver decreases the
1123           value automatically according to the controller's capabilities.
1124
1125           Your answer to this question is ignored for controllers with NVRAM,
1126           since the driver will get this information from the user set-up.  It
1127           also can be overridden using a boot setup option, as follows
1128           (example): 'ncr53c8xx=sync:12' will allow the driver to negotiate
1129           for FAST-20 synchronous data transfer (20 mega-transfers per
1130           second).
1131
1132           The normal answer therefore is not to go with the default but to
1133           select the maximum value 80 allowing the driver to use the maximum
1134           value supported by each controller. If this causes problems with
1135           your SCSI devices, you should come back and decrease the value.
1136
1137           There is no safe option other than using good cabling, right
1138           terminations and SCSI conformant devices.
1139
1140 config SCSI_NCR53C8XX_PROFILE
1141         bool "enable profiling"
1142         depends on SCSI_ZALON || SCSI_NCR_Q720
1143         help
1144           This option allows you to enable profiling information gathering.
1145           These statistics are not very accurate due to the low frequency
1146           of the kernel clock (100 Hz on i386) and have performance impact
1147           on systems that use very fast devices.
1148
1149           The normal answer therefore is N.
1150
1151 config SCSI_NCR53C8XX_NO_DISCONNECT
1152         bool "not allow targets to disconnect"
1153         depends on (SCSI_ZALON || SCSI_NCR_Q720) && SCSI_NCR53C8XX_DEFAULT_TAGS=0
1154         help
1155           This option is only provided for safety if you suspect some SCSI
1156           device of yours to not support properly the target-disconnect
1157           feature. In that case, you would say Y here. In general however, to
1158           not allow targets to disconnect is not reasonable if there is more
1159           than 1 device on a SCSI bus. The normal answer therefore is N.
1160
1161 config SCSI_MCA_53C9X
1162         tristate "NCR MCA 53C9x SCSI support"
1163         depends on MCA_LEGACY && SCSI && BROKEN_ON_SMP
1164         help
1165           Some MicroChannel machines, notably the NCR 35xx line, use a SCSI
1166           controller based on the NCR 53C94.  This driver will allow use of
1167           the controller on the 3550, and very possibly others.
1168
1169           To compile this driver as a module, choose M here: the
1170           module will be called mca_53c9x.
1171
1172 config SCSI_PAS16
1173         tristate "PAS16 SCSI support"
1174         depends on ISA && SCSI
1175         select SCSI_SPI_ATTRS
1176         ---help---
1177           This is support for a SCSI host adapter.  It is explained in section
1178           3.10 of the SCSI-HOWTO, available from
1179           <http://www.tldp.org/docs.html#howto>.  If it doesn't work out
1180           of the box, you may have to change some settings in
1181           <file:drivers/scsi/pas16.h>.
1182
1183           To compile this driver as a module, choose M here: the
1184           module will be called pas16.
1185
1186 config SCSI_PSI240I
1187         tristate "PSI240i support"
1188         depends on ISA && SCSI
1189         help
1190           This is support for the PSI240i EIDE interface card which acts as a
1191           SCSI host adapter.  Please read the SCSI-HOWTO, available from
1192           <http://www.tldp.org/docs.html#howto>.
1193
1194           To compile this driver as a module, choose M here: the
1195           module will be called psi240i.
1196
1197 config SCSI_QLOGIC_FAS
1198         tristate "Qlogic FAS SCSI support"
1199         depends on ISA && SCSI
1200         ---help---
1201           This is a driver for the ISA, VLB, and PCMCIA versions of the Qlogic
1202           FastSCSI! cards as well as any other card based on the FASXX chip
1203           (including the Control Concepts SCSI/IDE/SIO/PIO/FDC cards).
1204
1205           This driver does NOT support the PCI versions of these cards. The
1206           PCI versions are supported by the Qlogic ISP driver ("Qlogic ISP
1207           SCSI support"), below.
1208
1209           Information about this driver is contained in
1210           <file:Documentation/scsi/qlogicfas.txt>.  You should also read the
1211           SCSI-HOWTO, available from
1212           <http://www.tldp.org/docs.html#howto>.
1213
1214           To compile this driver as a module, choose M here: the
1215           module will be called qlogicfas.
1216
1217 config SCSI_QLOGIC_FC_FIRMWARE
1218         bool "Include loadable firmware in driver"
1219         depends on SCSI_QLOGIC_FC
1220         help
1221           Say Y to include ISP2X00 Fabric Initiator/Target Firmware, with
1222           expanded LUN addressing and FcTape (FCP-2) support, in the
1223           qlogicfc driver. This is required on some platforms.
1224
1225 config SCSI_QLOGIC_1280
1226         tristate "Qlogic QLA 1240/1x80/1x160 SCSI support"
1227         depends on PCI && SCSI
1228         help
1229           Say Y if you have a QLogic ISP1240/1x80/1x160 SCSI host adapter.
1230
1231           To compile this driver as a module, choose M here: the
1232           module will be called qla1280.
1233
1234 config SCSI_QLOGICPTI
1235         tristate "PTI Qlogic, ISP Driver"
1236         depends on SBUS && SCSI
1237         help
1238           This driver supports SBUS SCSI controllers from PTI or QLogic. These
1239           controllers are known under Solaris as qpti and in the openprom as
1240           PTI,ptisp or QLGC,isp. Note that PCI QLogic SCSI controllers are
1241           driven by a different driver.
1242
1243           To compile this driver as a module, choose M here: the
1244           module will be called qlogicpti.
1245
1246 source "drivers/scsi/qla2xxx/Kconfig"
1247
1248 config SCSI_LPFC
1249         tristate "Emulex LightPulse Fibre Channel Support"
1250         depends on PCI && SCSI
1251         select SCSI_FC_ATTRS
1252         help
1253           This lpfc driver supports the Emulex LightPulse
1254           Family of Fibre Channel PCI host adapters.
1255
1256 config SCSI_SEAGATE
1257         tristate "Seagate ST-02 and Future Domain TMC-8xx SCSI support"
1258         depends on X86 && ISA && SCSI && BROKEN
1259         ---help---
1260           These are 8-bit SCSI controllers; the ST-01 is also supported by
1261           this driver.  It is explained in section 3.9 of the SCSI-HOWTO,
1262           available from <http://www.tldp.org/docs.html#howto>.  If it
1263           doesn't work out of the box, you may have to change some settings in
1264           <file:drivers/scsi/seagate.h>.
1265
1266           To compile this driver as a module, choose M here: the
1267           module will be called seagate.
1268
1269 # definitely looks not 64bit safe:
1270 config SCSI_SIM710
1271         tristate "Simple 53c710 SCSI support (Compaq, NCR machines)"
1272         depends on (EISA || MCA) && SCSI
1273         select SCSI_SPI_ATTRS
1274         ---help---
1275           This driver for NCR53c710 based SCSI host adapters.
1276
1277           It currently supports Compaq EISA cards and NCR MCA cards
1278
1279 config 53C700_IO_MAPPED
1280         bool
1281         depends on SCSI_SIM710
1282         default y
1283
1284 config SCSI_SYM53C416
1285         tristate "Symbios 53c416 SCSI support"
1286         depends on ISA && SCSI
1287         ---help---
1288           This is support for the sym53c416 SCSI host adapter, the SCSI
1289           adapter that comes with some HP scanners. This driver requires that
1290           the sym53c416 is configured first using some sort of PnP
1291           configuration program (e.g. isapnp) or by a PnP aware BIOS. If you
1292           are using isapnp then you need to compile this driver as a module
1293           and then load it using insmod after isapnp has run. The parameters
1294           of the configured card(s) should be passed to the driver. The format
1295           is:
1296
1297           insmod sym53c416 sym53c416=<base>,<irq> [sym53c416_1=<base>,<irq>]
1298
1299           To compile this driver as a module, choose M here: the
1300           module will be called sym53c416.
1301
1302 config SCSI_DC395x
1303         tristate "Tekram DC395(U/UW/F) and DC315(U) SCSI support (EXPERIMENTAL)"
1304         depends on PCI && SCSI && EXPERIMENTAL
1305         ---help---
1306           This driver supports PCI SCSI host adapters based on the ASIC
1307           TRM-S1040 chip, e.g Tekram DC395(U/UW/F) and DC315(U) variants.
1308
1309           This driver works, but is still in experimental status. So better
1310           have a bootable disk and a backup in case of emergency.
1311
1312           Documentation can be found in <file:Documentation/scsi/dc395x.txt>.
1313
1314           To compile this driver as a module, choose M here: the
1315           module will be called dc395x.
1316
1317 config SCSI_DC390T
1318         tristate "Tekram DC390(T) and Am53/79C974 SCSI support"
1319         depends on PCI && SCSI
1320         ---help---
1321           This driver supports PCI SCSI host adapters based on the Am53C974A
1322           chip, e.g. Tekram DC390(T), DawiControl 2974 and some onboard
1323           PCscsi/PCnet (Am53/79C974) solutions.
1324
1325           Documentation can be found in <file:Documentation/scsi/tmscsim.txt>.
1326
1327           Note that this driver does NOT support Tekram DC390W/U/F, which are
1328           based on NCR/Symbios chips. Use "NCR53C8XX SCSI support" for those.
1329
1330           To compile this driver as a module, choose M here: the
1331           module will be called tmscsim.
1332
1333 config SCSI_T128
1334         tristate "Trantor T128/T128F/T228 SCSI support"
1335         depends on ISA && SCSI
1336         select SCSI_SPI_ATTRS
1337         ---help---
1338           This is support for a SCSI host adapter. It is explained in section
1339           3.11 of the SCSI-HOWTO, available from
1340           <http://www.tldp.org/docs.html#howto>.  If it doesn't work out
1341           of the box, you may have to change some settings in
1342           <file:drivers/scsi/t128.h>.  Note that Trantor was purchased by
1343           Adaptec, and some former Trantor products are being sold under the
1344           Adaptec name.
1345
1346           To compile this driver as a module, choose M here: the
1347           module will be called t128.
1348
1349 config SCSI_U14_34F
1350         tristate "UltraStor 14F/34F support"
1351         depends on ISA && SCSI && ISA_DMA_API
1352         ---help---
1353           This is support for the UltraStor 14F and 34F SCSI-2 host adapters.
1354           The source at <file:drivers/scsi/u14-34f.c> contains some
1355           information about this hardware.  If the driver doesn't work out of
1356           the box, you may have to change some settings in
1357           <file: drivers/scsi/u14-34f.c>.  Read the SCSI-HOWTO, available from
1358           <http://www.tldp.org/docs.html#howto>.  Note that there is also
1359           another driver for the same hardware: "UltraStor SCSI support",
1360           below.  You should say Y to both only if you want 24F support as
1361           well.
1362
1363           To compile this driver as a module, choose M here: the
1364           module will be called u14-34f.
1365
1366 config SCSI_U14_34F_TAGGED_QUEUE
1367         bool "enable tagged command queueing"
1368         depends on SCSI_U14_34F
1369         help
1370           This is a feature of SCSI-2 which improves performance: the host
1371           adapter can send several SCSI commands to a device's queue even if
1372           previous commands haven't finished yet.
1373           This is equivalent to the "u14-34f=tc:y" boot option.
1374
1375 config SCSI_U14_34F_LINKED_COMMANDS
1376         bool "enable elevator sorting"
1377         depends on SCSI_U14_34F
1378         help
1379           This option enables elevator sorting for all probed SCSI disks and
1380           CD-ROMs. It definitely reduces the average seek distance when doing
1381           random seeks, but this does not necessarily result in a noticeable
1382           performance improvement: your mileage may vary...
1383           This is equivalent to the "u14-34f=lc:y" boot option.
1384
1385 config SCSI_U14_34F_MAX_TAGS
1386         int "maximum number of queued commands"
1387         depends on SCSI_U14_34F
1388         default "8"
1389         help
1390           This specifies how many SCSI commands can be maximally queued for
1391           each probed SCSI device. You should reduce the default value of 8
1392           only if you have disks with buggy or limited tagged command support.
1393           Minimum is 2 and maximum is 14. This value is also the window size
1394           used by the elevator sorting option above. The effective value used
1395           by the driver for each probed SCSI device is reported at boot time.
1396           This is equivalent to the "u14-34f=mq:8" boot option.
1397
1398 config SCSI_ULTRASTOR
1399         tristate "UltraStor SCSI support"
1400         depends on X86 && ISA && SCSI
1401         ---help---
1402           This is support for the UltraStor 14F, 24F and 34F SCSI-2 host
1403           adapter family.  This driver is explained in section 3.12 of the
1404           SCSI-HOWTO, available from
1405           <http://www.tldp.org/docs.html#howto>.  If it doesn't work out
1406           of the box, you may have to change some settings in
1407           <file:drivers/scsi/ultrastor.h>.
1408
1409           Note that there is also another driver for the same hardware:
1410           "UltraStor 14F/34F support", above.
1411
1412           To compile this driver as a module, choose M here: the
1413           module will be called ultrastor.
1414
1415 config SCSI_NSP32
1416         tristate "Workbit NinjaSCSI-32Bi/UDE support"
1417         depends on PCI && SCSI && !64BIT
1418         help
1419           This is support for the Workbit NinjaSCSI-32Bi/UDE PCI/Cardbus
1420           SCSI host adapter. Please read the SCSI-HOWTO, available from
1421           <http://www.tldp.org/docs.html#howto>.
1422
1423           To compile this driver as a module, choose M here: the
1424           module will be called nsp32.
1425
1426 config SCSI_DEBUG
1427         tristate "SCSI debugging host simulator"
1428         depends on SCSI
1429         help
1430           This is a host adapter simulator that can simulate multiple hosts
1431           each with multiple dummy SCSI devices (disks). It defaults to one
1432           host adapter with one dummy SCSI disk. Each dummy disk uses kernel
1433           RAM as storage (i.e. it is a ramdisk). To save space when multiple
1434           dummy disks are simulated, they share the same kernel RAM for 
1435           their storage. See <http://www.torque.net/sg/sdebug.html> for more
1436           information. This driver is primarily of use to those testing the
1437           SCSI and block subsystems. If unsure, say N.
1438
1439 config SCSI_MESH
1440         tristate "MESH (Power Mac internal SCSI) support"
1441         depends on PPC32 && PPC_PMAC && SCSI
1442         help
1443           Many Power Macintoshes and clones have a MESH (Macintosh Enhanced
1444           SCSI Hardware) SCSI bus adaptor (the 7200 doesn't, but all of the
1445           other Power Macintoshes do). Say Y to include support for this SCSI
1446           adaptor.
1447
1448           To compile this driver as a module, choose M here: the
1449           module will be called mesh.
1450
1451 config SCSI_MESH_SYNC_RATE
1452         int "maximum synchronous transfer rate (MB/s) (0 = async)"
1453         depends on SCSI_MESH
1454         default "5"
1455         help
1456           On Power Macintoshes (and clones) where the MESH SCSI bus adaptor
1457           drives a bus which is entirely internal to the machine (such as the
1458           7500, 7600, 8500, etc.), the MESH is capable of synchronous
1459           operation at up to 10 MB/s. On machines where the SCSI bus
1460           controlled by the MESH can have external devices connected, it is
1461           usually rated at 5 MB/s. 5 is a safe value here unless you know the
1462           MESH SCSI bus is internal only; in that case you can say 10. Say 0
1463           to disable synchronous operation.
1464
1465 config SCSI_MESH_RESET_DELAY_MS
1466         int "initial bus reset delay (ms) (0 = no reset)"
1467         depends on SCSI_MESH
1468         default "4000"
1469
1470 config SCSI_MAC53C94
1471         tristate "53C94 (Power Mac external SCSI) support"
1472         depends on PPC32 && PPC_PMAC && SCSI
1473         help
1474           On Power Macintoshes (and clones) with two SCSI buses, the external
1475           SCSI bus is usually controlled by a 53C94 SCSI bus adaptor. Older
1476           machines which only have one SCSI bus, such as the 7200, also use
1477           the 53C94. Say Y to include support for the 53C94.
1478
1479           To compile this driver as a module, choose M here: the
1480           module will be called mac53c94.
1481
1482 source "drivers/scsi/arm/Kconfig"
1483
1484 config JAZZ_ESP
1485         bool "MIPS JAZZ FAS216 SCSI support"
1486         depends on MACH_JAZZ && SCSI
1487         help
1488           This is the driver for the onboard SCSI host adapter of MIPS Magnum
1489           4000, Acer PICA, Olivetti M700-10 and a few other identical OEM
1490           systems.
1491
1492 config A3000_SCSI
1493         tristate "A3000 WD33C93A support"
1494         depends on AMIGA && SCSI
1495         help
1496           If you have an Amiga 3000 and have SCSI devices connected to the
1497           built-in SCSI controller, say Y. Otherwise, say N.
1498
1499           To compile this driver as a module, choose M here: the
1500           module will be called wd33c93.
1501
1502 config A2091_SCSI
1503         tristate "A2091/A590 WD33C93A support"
1504         depends on ZORRO && SCSI
1505         help
1506           If you have a Commodore A2091 SCSI controller, say Y. Otherwise,
1507           say N.
1508
1509           To compile this driver as a module, choose M here: the
1510           module will be called wd33c93.
1511
1512 config GVP11_SCSI
1513         tristate "GVP Series II WD33C93A support"
1514         depends on ZORRO && SCSI
1515         ---help---
1516           If you have a Great Valley Products Series II SCSI controller,
1517           answer Y. Also say Y if you have a later model of GVP SCSI
1518           controller (such as the GVP A4008 or a Combo board). Otherwise,
1519           answer N. This driver does NOT work for the T-Rex series of
1520           accelerators from TekMagic and GVP-M.
1521
1522           To compile this driver as a module, choose M here: the
1523           module will be called gvp11.
1524
1525 config CYBERSTORM_SCSI
1526         tristate "CyberStorm SCSI support"
1527         depends on ZORRO && SCSI
1528         help
1529           If you have an Amiga with an original (MkI) Phase5 Cyberstorm
1530           accelerator board and the optional Cyberstorm SCSI controller,
1531           answer Y. Otherwise, say N.
1532
1533 config CYBERSTORMII_SCSI
1534         tristate "CyberStorm Mk II SCSI support"
1535         depends on ZORRO && SCSI
1536         help
1537           If you have an Amiga with a Phase5 Cyberstorm MkII accelerator board
1538           and the optional Cyberstorm SCSI controller, say Y. Otherwise,
1539           answer N.
1540
1541 config BLZ2060_SCSI
1542         tristate "Blizzard 2060 SCSI support"
1543         depends on ZORRO && SCSI
1544         help
1545           If you have an Amiga with a Phase5 Blizzard 2060 accelerator board
1546           and want to use the onboard SCSI controller, say Y. Otherwise,
1547           answer N.
1548
1549 config BLZ1230_SCSI
1550         tristate "Blizzard 1230IV/1260 SCSI support"
1551         depends on ZORRO && SCSI
1552         help
1553           If you have an Amiga 1200 with a Phase5 Blizzard 1230IV or Blizzard
1554           1260 accelerator, and the optional SCSI module, say Y. Otherwise,
1555           say N.
1556
1557 config FASTLANE_SCSI
1558         tristate "Fastlane SCSI support"
1559         depends on ZORRO && SCSI
1560         help
1561           If you have the Phase5 Fastlane Z3 SCSI controller, or plan to use
1562           one in the near future, say Y to this question. Otherwise, say N.
1563
1564 config SCSI_AMIGA7XX
1565         bool "Amiga NCR53c710 SCSI support (EXPERIMENTAL)"
1566         depends on AMIGA && SCSI && EXPERIMENTAL && BROKEN
1567         help
1568           Support for various NCR53c710-based SCSI controllers on the Amiga.
1569           This includes:
1570             - the builtin SCSI controller on the Amiga 4000T,
1571             - the Amiga 4091 Zorro III SCSI-2 controller,
1572             - the MacroSystem Development's WarpEngine Amiga SCSI-2 controller
1573               (info at
1574               <http://www.lysator.liu.se/amiga/ar/guide/ar310.guide?FEATURE5>),
1575             - the SCSI controller on the Phase5 Blizzard PowerUP 603e+
1576               accelerator card for the Amiga 1200,
1577             - the SCSI controller on the GVP Turbo 040/060 accelerator.
1578           Note that all of the above SCSI controllers, except for the builtin
1579           SCSI controller on the Amiga 4000T, reside on the Zorro expansion
1580           bus, so you also have to enable Zorro bus support if you want to use
1581           them.
1582
1583 config OKTAGON_SCSI
1584         tristate "BSC Oktagon SCSI support (EXPERIMENTAL)"
1585         depends on ZORRO && SCSI && EXPERIMENTAL
1586         help
1587           If you have the BSC Oktagon SCSI disk controller for the Amiga, say
1588           Y to this question.  If you're in doubt about whether you have one,
1589           see the picture at
1590           <http://amiga.resource.cx/exp/search.pl?product=oktagon>.
1591
1592 config ATARI_SCSI
1593         tristate "Atari native SCSI support"
1594         depends on ATARI && SCSI && BROKEN
1595         select SCSI_SPI_ATTRS
1596         ---help---
1597           If you have an Atari with built-in NCR5380 SCSI controller (TT,
1598           Falcon, ...) say Y to get it supported. Of course also, if you have
1599           a compatible SCSI controller (e.g. for Medusa).
1600
1601           To compile this driver as a module, choose M here: the
1602           module will be called atari_scsi.
1603
1604           This driver supports both styles of NCR integration into the
1605           system: the TT style (separate DMA), and the Falcon style (via
1606           ST-DMA, replacing ACSI).  It does NOT support other schemes, like
1607           in the Hades (without DMA).
1608
1609 config ATARI_SCSI_TOSHIBA_DELAY
1610         bool "Long delays for Toshiba CD-ROMs"
1611         depends on ATARI_SCSI
1612         help
1613           This option increases the delay after a SCSI arbitration to
1614           accommodate some flaky Toshiba CD-ROM drives. Say Y if you intend to
1615           use a Toshiba CD-ROM drive; otherwise, the option is not needed and
1616           would impact performance a bit, so say N.
1617
1618 config ATARI_SCSI_RESET_BOOT
1619         bool "Reset SCSI-devices at boottime"
1620         depends on ATARI_SCSI
1621         help
1622           Reset the devices on your Atari whenever it boots.  This makes the
1623           boot process fractionally longer but may assist recovery from errors
1624           that leave the devices with SCSI operations partway completed.
1625
1626 config TT_DMA_EMUL
1627         bool "Hades SCSI DMA emulator"
1628         depends on ATARI_SCSI && HADES
1629         help
1630           This option enables code which emulates the TT SCSI DMA chip on the
1631           Hades. This increases the SCSI transfer rates at least ten times
1632           compared to PIO transfers.
1633
1634 config MAC_SCSI
1635         bool "Macintosh NCR5380 SCSI"
1636         depends on MAC && SCSI=y
1637         select SCSI_SPI_ATTRS
1638         help
1639           This is the NCR 5380 SCSI controller included on most of the 68030
1640           based Macintoshes.  If you have one of these say Y and read the
1641           SCSI-HOWTO, available from
1642           <http://www.tldp.org/docs.html#howto>.
1643
1644 config SCSI_MAC_ESP
1645         tristate "Macintosh NCR53c9[46] SCSI"
1646         depends on MAC && SCSI
1647         help
1648           This is the NCR 53c9x SCSI controller found on most of the 68040
1649           based Macintoshes.  If you have one of these say Y and read the
1650           SCSI-HOWTO, available from
1651           <http://www.tldp.org/docs.html#howto>.
1652
1653           To compile this driver as a module, choose M here: the
1654           module will be called mac_esp.
1655
1656 config MVME147_SCSI
1657         bool "WD33C93 SCSI driver for MVME147"
1658         depends on MVME147 && SCSI=y
1659         select SCSI_SPI_ATTRS
1660         help
1661           Support for the on-board SCSI controller on the Motorola MVME147
1662           single-board computer.
1663
1664 config MVME16x_SCSI
1665         bool "NCR53C710 SCSI driver for MVME16x"
1666         depends on MVME16x && SCSI && BROKEN
1667         select SCSI_SPI_ATTRS
1668         help
1669           The Motorola MVME162, 166, 167, 172 and 177 boards use the NCR53C710
1670           SCSI controller chip.  Almost everyone using one of these boards
1671           will want to say Y to this question.
1672
1673 config BVME6000_SCSI
1674         bool "NCR53C710 SCSI driver for BVME6000"
1675         depends on BVME6000 && SCSI && BROKEN
1676         select SCSI_SPI_ATTRS
1677         help
1678           The BVME4000 and BVME6000 boards from BVM Ltd use the NCR53C710
1679           SCSI controller chip.  Almost everyone using one of these boards
1680           will want to say Y to this question.
1681
1682 config SCSI_NCR53C7xx_FAST
1683         bool "allow FAST-SCSI [10MHz]"
1684         depends on SCSI_AMIGA7XX || MVME16x_SCSI || BVME6000_SCSI
1685         help
1686           This will enable 10MHz FAST-SCSI transfers with your host
1687           adapter. Some systems have problems with that speed, so it's safest
1688           to say N here.
1689
1690 config SUN3_SCSI
1691         tristate "Sun3 NCR5380 SCSI"
1692         depends on SUN3 && SCSI && BROKEN
1693         select SCSI_SPI_ATTRS
1694         help
1695           This option will enable support for the OBIO (onboard io) NCR5380
1696           SCSI controller found in the Sun 3/50 and 3/60, as well as for
1697           "Sun3" type VME scsi controllers also based on the NCR5380.
1698           General Linux information on the Sun 3 series (now discontinued)
1699           is at <http://www.angelfire.com/ca2/tech68k/sun3.html>.
1700
1701 config SUN3X_ESP
1702         bool "Sun3x ESP SCSI"
1703         depends on SUN3X && SCSI=y
1704         help
1705           The ESP was an on-board SCSI controller used on Sun 3/80
1706           machines.  Say Y here to compile in support for it.
1707
1708 config SCSI_SUNESP
1709         tristate "Sparc ESP Scsi Driver"
1710         depends on SBUS && SCSI
1711         help
1712           This is the driver for the Sun ESP SCSI host adapter. The ESP
1713           chipset is present in most SPARC SBUS-based computers.
1714
1715           To compile this driver as a module, choose M here: the
1716           module will be called esp.
1717
1718 #      bool 'Cyberstorm Mk III SCSI support (EXPERIMENTAL)' CONFIG_CYBERSTORMIII_SCSI
1719
1720 config ZFCP
1721         tristate "FCP host bus adapter driver for IBM eServer zSeries"
1722         depends on S390 && QDIO && SCSI
1723         select SCSI_FC_ATTRS
1724         help
1725           If you want to access SCSI devices attached to your IBM eServer
1726           zSeries by means of Fibre Channel interfaces say Y.
1727           For details please refer to the documentation provided by IBM at
1728           <http://oss.software.ibm.com/developerworks/opensource/linux390>
1729
1730           This driver is also available as a module. This module will be
1731           called zfcp. If you want to compile it as a module, say M here
1732           and read <file:Documentation/modules.txt>.
1733
1734 endmenu
1735
1736 source "drivers/scsi/pcmcia/Kconfig"
1737
1738 endmenu