1# 2# Block device driver configuration 3# 4 5if BLOCK 6 7menu "Block devices" 8 9config BLK_DEV_FD 10 tristate "Normal floppy disk support" 11 depends on ARCH_MAY_HAVE_PC_FDC 12 ---help--- 13 If you want to use the floppy disk drive(s) of your PC under Linux, 14 say Y. Information about this driver, especially important for IBM 15 Thinkpad users, is contained in <file:Documentation/floppy.txt>. 16 That file also contains the location of the Floppy driver FAQ as 17 well as location of the fdutils package used to configure additional 18 parameters of the driver at run time. 19 20 To compile this driver as a module, choose M here: the 21 module will be called floppy. 22 23config AMIGA_FLOPPY 24 tristate "Amiga floppy support" 25 depends on AMIGA 26 27config ATARI_FLOPPY 28 tristate "Atari floppy support" 29 depends on ATARI 30 31config BLK_DEV_SWIM_IOP 32 bool "Macintosh IIfx/Quadra 900/Quadra 950 floppy support (EXPERIMENTAL)" 33 depends on MAC && EXPERIMENTAL && BROKEN 34 help 35 Say Y here to support the SWIM (Super Woz Integrated Machine) IOP 36 floppy controller on the Macintosh IIfx and Quadra 900/950. 37 38config MAC_FLOPPY 39 tristate "Support for PowerMac floppy" 40 depends on PPC_PMAC && !PPC_PMAC64 41 help 42 If you have a SWIM-3 (Super Woz Integrated Machine 3; from Apple) 43 floppy controller, say Y here. Most commonly found in PowerMacs. 44 45config BLK_DEV_PS2 46 tristate "PS/2 ESDI hard disk support" 47 depends on MCA && MCA_LEGACY && BROKEN 48 help 49 Say Y here if you have a PS/2 machine with a MCA bus and an ESDI 50 hard disk. 51 52 To compile this driver as a module, choose M here: the 53 module will be called ps2esdi. 54 55config AMIGA_Z2RAM 56 tristate "Amiga Zorro II ramdisk support" 57 depends on ZORRO 58 help 59 This enables support for using Chip RAM and Zorro II RAM as a 60 ramdisk or as a swap partition. Say Y if you want to include this 61 driver in the kernel. 62 63 To compile this driver as a module, choose M here: the 64 module will be called z2ram. 65 66config ATARI_ACSI 67 tristate "Atari ACSI support" 68 depends on ATARI && BROKEN 69 ---help--- 70 This enables support for the Atari ACSI interface. The driver 71 supports hard disks and CD-ROMs, which have 512-byte sectors, or can 72 be switched to that mode. Due to the ACSI command format, only disks 73 up to 1 GB are supported. Special support for certain ACSI to SCSI 74 adapters, which could relax that, isn't included yet. The ACSI 75 driver is also the basis for certain other drivers for devices 76 attached to the ACSI bus: Atari SLM laser printer, BioNet-100 77 Ethernet, and PAMsNet Ethernet. If you want to use one of these 78 devices, you need ACSI support, too. 79 80 To compile this driver as a module, choose M here: the 81 module will be called acsi. 82 83comment "Some devices (e.g. CD jukebox) support multiple LUNs" 84 depends on ATARI && ATARI_ACSI 85 86config ACSI_MULTI_LUN 87 bool "Probe all LUNs on each ACSI device" 88 depends on ATARI_ACSI 89 help 90 If you have a ACSI device that supports more than one LUN (Logical 91 Unit Number), e.g. a CD jukebox, you should say Y here so that all 92 will be found by the ACSI driver. An ACSI device with multiple LUNs 93 acts logically like multiple ACSI devices. The vast majority of ACSI 94 devices have only one LUN, and so most people can say N here and 95 should in fact do so, because it is safer. 96 97config ATARI_SLM 98 tristate "Atari SLM laser printer support" 99 depends on ATARI && ATARI_ACSI!=n 100 help 101 If you have an Atari SLM laser printer, say Y to include support for 102 it in the kernel. Otherwise, say N. This driver is also available as 103 a module ( = code which can be inserted in and removed from the 104 running kernel whenever you want). The module will be called 105 acsi_slm. Be warned: the driver needs much ST-RAM and can cause 106 problems due to that fact! 107 108config BLK_DEV_XD 109 tristate "XT hard disk support" 110 depends on ISA && ISA_DMA_API 111 help 112 Very old 8 bit hard disk controllers used in the IBM XT computer 113 will be supported if you say Y here. 114 115 To compile this driver as a module, choose M here: the 116 module will be called xd. 117 118 It's pretty unlikely that you have one of these: say N. 119 120config PARIDE 121 tristate "Parallel port IDE device support" 122 depends on PARPORT_PC 123 ---help--- 124 There are many external CD-ROM and disk devices that connect through 125 your computer's parallel port. Most of them are actually IDE devices 126 using a parallel port IDE adapter. This option enables the PARIDE 127 subsystem which contains drivers for many of these external drives. 128 Read <file:Documentation/paride.txt> for more information. 129 130 If you have said Y to the "Parallel-port support" configuration 131 option, you may share a single port between your printer and other 132 parallel port devices. Answer Y to build PARIDE support into your 133 kernel, or M if you would like to build it as a loadable module. If 134 your parallel port support is in a loadable module, you must build 135 PARIDE as a module. If you built PARIDE support into your kernel, 136 you may still build the individual protocol modules and high-level 137 drivers as loadable modules. If you build this support as a module, 138 it will be called paride. 139 140 To use the PARIDE support, you must say Y or M here and also to at 141 least one high-level driver (e.g. "Parallel port IDE disks", 142 "Parallel port ATAPI CD-ROMs", "Parallel port ATAPI disks" etc.) and 143 to at least one protocol driver (e.g. "ATEN EH-100 protocol", 144 "MicroSolutions backpack protocol", "DataStor Commuter protocol" 145 etc.). 146 147source "drivers/block/paride/Kconfig" 148 149config BLK_CPQ_DA 150 tristate "Compaq SMART2 support" 151 depends on PCI 152 help 153 This is the driver for Compaq Smart Array controllers. Everyone 154 using these boards should say Y here. See the file 155 <file:Documentation/cpqarray.txt> for the current list of boards 156 supported by this driver, and for further information on the use of 157 this driver. 158 159config BLK_CPQ_CISS_DA 160 tristate "Compaq Smart Array 5xxx support" 161 depends on PCI 162 help 163 This is the driver for Compaq Smart Array 5xxx controllers. 164 Everyone using these boards should say Y here. 165 See <file:Documentation/cciss.txt> for the current list of 166 boards supported by this driver, and for further information 167 on the use of this driver. 168 169config CISS_SCSI_TAPE 170 bool "SCSI tape drive support for Smart Array 5xxx" 171 depends on BLK_CPQ_CISS_DA && PROC_FS 172 depends on SCSI=y || SCSI=BLK_CPQ_CISS_DA 173 help 174 When enabled (Y), this option allows SCSI tape drives and SCSI medium 175 changers (tape robots) to be accessed via a Compaq 5xxx array 176 controller. (See <file:Documentation/cciss.txt> for more details.) 177 178 "SCSI support" and "SCSI tape support" must also be enabled for this 179 option to work. 180 181 When this option is disabled (N), the SCSI portion of the driver 182 is not compiled. 183 184config BLK_DEV_DAC960 185 tristate "Mylex DAC960/DAC1100 PCI RAID Controller support" 186 depends on PCI 187 help 188 This driver adds support for the Mylex DAC960, AcceleRAID, and 189 eXtremeRAID PCI RAID controllers. See the file 190 <file:Documentation/README.DAC960> for further information about 191 this driver. 192 193 To compile this driver as a module, choose M here: the 194 module will be called DAC960. 195 196config BLK_DEV_UMEM 197 tristate "Micro Memory MM5415 Battery Backed RAM support (EXPERIMENTAL)" 198 depends on PCI && EXPERIMENTAL 199 ---help--- 200 Saying Y here will include support for the MM5415 family of 201 battery backed (Non-volatile) RAM cards. 202 <http://www.umem.com/> 203 204 The cards appear as block devices that can be partitioned into 205 as many as 15 partitions. 206 207 To compile this driver as a module, choose M here: the 208 module will be called umem. 209 210 The umem driver has not yet been allocated a MAJOR number, so 211 one is chosen dynamically. 212 213config BLK_DEV_UBD 214 bool "Virtual block device" 215 depends on UML 216 ---help--- 217 The User-Mode Linux port includes a driver called UBD which will let 218 you access arbitrary files on the host computer as block devices. 219 Unless you know that you do not need such virtual block devices say 220 Y here. 221 222config BLK_DEV_UBD_SYNC 223 bool "Always do synchronous disk IO for UBD" 224 depends on BLK_DEV_UBD 225 ---help--- 226 Writes to the virtual block device are not immediately written to the 227 host's disk; this may cause problems if, for example, the User-Mode 228 Linux 'Virtual Machine' uses a journalling filesystem and the host 229 computer crashes. 230 231 Synchronous operation (i.e. always writing data to the host's disk 232 immediately) is configurable on a per-UBD basis by using a special 233 kernel command line option. Alternatively, you can say Y here to 234 turn on synchronous operation by default for all block devices. 235 236 If you're running a journalling file system (like reiserfs, for 237 example) in your virtual machine, you will want to say Y here. If 238 you care for the safety of the data in your virtual machine, Y is a 239 wise choice too. In all other cases (for example, if you're just 240 playing around with User-Mode Linux) you can choose N. 241 242config BLK_DEV_COW_COMMON 243 bool 244 default BLK_DEV_UBD 245 246config MMAPPER 247 tristate "Example IO memory driver (BROKEN)" 248 depends on UML && BROKEN 249 ---help--- 250 The User-Mode Linux port can provide support for IO Memory 251 emulation with this option. This allows a host file to be 252 specified as an I/O region on the kernel command line. That file 253 will be mapped into UML's kernel address space where a driver can 254 locate it and do whatever it wants with the memory, including 255 providing an interface to it for UML processes to use. 256 257 For more information, see 258 <http://user-mode-linux.sourceforge.net/iomem.html>. 259 260 If you'd like to be able to provide a simulated IO port space for 261 User-Mode Linux processes, say Y. If unsure, say N. 262 263config BLK_DEV_LOOP 264 tristate "Loopback device support" 265 ---help--- 266 Saying Y here will allow you to use a regular file as a block 267 device; you can then create a file system on that block device and 268 mount it just as you would mount other block devices such as hard 269 drive partitions, CD-ROM drives or floppy drives. The loop devices 270 are block special device files with major number 7 and typically 271 called /dev/loop0, /dev/loop1 etc. 272 273 This is useful if you want to check an ISO 9660 file system before 274 burning the CD, or if you want to use floppy images without first 275 writing them to floppy. Furthermore, some Linux distributions avoid 276 the need for a dedicated Linux partition by keeping their complete 277 root file system inside a DOS FAT file using this loop device 278 driver. 279 280 To use the loop device, you need the losetup utility, found in the 281 util-linux package, see 282 <ftp://ftp.kernel.org/pub/linux/utils/util-linux/>. 283 284 The loop device driver can also be used to "hide" a file system in 285 a disk partition, floppy, or regular file, either using encryption 286 (scrambling the data) or steganography (hiding the data in the low 287 bits of, say, a sound file). This is also safe if the file resides 288 on a remote file server. 289 290 There are several ways of encrypting disks. Some of these require 291 kernel patches. The vanilla kernel offers the cryptoloop option 292 and a Device Mapper target (which is superior, as it supports all 293 file systems). If you want to use the cryptoloop, say Y to both 294 LOOP and CRYPTOLOOP, and make sure you have a recent (version 2.12 295 or later) version of util-linux. Additionally, be aware that 296 the cryptoloop is not safe for storing journaled filesystems. 297 298 Note that this loop device has nothing to do with the loopback 299 device used for network connections from the machine to itself. 300 301 To compile this driver as a module, choose M here: the 302 module will be called loop. 303 304 Most users will answer N here. 305 306config BLK_DEV_CRYPTOLOOP 307 tristate "Cryptoloop Support" 308 select CRYPTO 309 depends on BLK_DEV_LOOP 310 ---help--- 311 Say Y here if you want to be able to use the ciphers that are 312 provided by the CryptoAPI as loop transformation. This might be 313 used as hard disk encryption. 314 315 WARNING: This device is not safe for journaled file systems like 316 ext3 or Reiserfs. Please use the Device Mapper crypto module 317 instead, which can be configured to be on-disk compatible with the 318 cryptoloop device. 319 320config BLK_DEV_NBD 321 tristate "Network block device support" 322 depends on NET 323 ---help--- 324 Saying Y here will allow your computer to be a client for network 325 block devices, i.e. it will be able to use block devices exported by 326 servers (mount file systems on them etc.). Communication between 327 client and server works over TCP/IP networking, but to the client 328 program this is hidden: it looks like a regular local file access to 329 a block device special file such as /dev/nd0. 330 331 Network block devices also allows you to run a block-device in 332 userland (making server and client physically the same computer, 333 communicating using the loopback network device). 334 335 Read <file:Documentation/nbd.txt> for more information, especially 336 about where to find the server code, which runs in user space and 337 does not need special kernel support. 338 339 Note that this has nothing to do with the network file systems NFS 340 or Coda; you can say N here even if you intend to use NFS or Coda. 341 342 To compile this driver as a module, choose M here: the 343 module will be called nbd. 344 345 If unsure, say N. 346 347config BLK_DEV_SX8 348 tristate "Promise SATA SX8 support" 349 depends on PCI 350 ---help--- 351 Saying Y or M here will enable support for the 352 Promise SATA SX8 controllers. 353 354 Use devices /dev/sx8/$N and /dev/sx8/$Np$M. 355 356config BLK_DEV_UB 357 tristate "Low Performance USB Block driver" 358 depends on USB 359 help 360 This driver supports certain USB attached storage devices 361 such as flash keys. 362 363 If you enable this driver, it is recommended to avoid conflicts 364 with usb-storage by enabling USB_LIBUSUAL. 365 366 If unsure, say N. 367 368config BLK_DEV_RAM 369 tristate "RAM disk support" 370 ---help--- 371 Saying Y here will allow you to use a portion of your RAM memory as 372 a block device, so that you can make file systems on it, read and 373 write to it and do all the other things that you can do with normal 374 block devices (such as hard drives). It is usually used to load and 375 store a copy of a minimal root file system off of a floppy into RAM 376 during the initial install of Linux. 377 378 Note that the kernel command line option "ramdisk=XX" is now 379 obsolete. For details, read <file:Documentation/ramdisk.txt>. 380 381 To compile this driver as a module, choose M here: the 382 module will be called rd. 383 384 Most normal users won't need the RAM disk functionality, and can 385 thus say N here. 386 387config BLK_DEV_RAM_COUNT 388 int "Default number of RAM disks" 389 default "16" 390 depends on BLK_DEV_RAM 391 help 392 The default value is 16 RAM disks. Change this if you know what 393 are doing. If you boot from a filesystem that needs to be extracted 394 in memory, you will need at least one RAM disk (e.g. root on cramfs). 395 396config BLK_DEV_RAM_SIZE 397 int "Default RAM disk size (kbytes)" 398 depends on BLK_DEV_RAM 399 default "4096" 400 help 401 The default value is 4096 kilobytes. Only change this if you know 402 what are you doing. If you are using IBM S/390, then set this to 403 8192. 404 405config BLK_DEV_RAM_BLOCKSIZE 406 int "Default RAM disk block size (bytes)" 407 depends on BLK_DEV_RAM 408 default "1024" 409 help 410 The default value is 1024 bytes. PAGE_SIZE is a much more 411 efficient choice however. The default is kept to ensure initrd 412 setups function - apparently needed by the rd_load_image routine 413 that supposes the filesystem in the image uses a 1024 blocksize. 414 415config BLK_DEV_INITRD 416 bool "Initial RAM filesystem and RAM disk (initramfs/initrd) support" 417 depends on BROKEN || !FRV 418 help 419 The initial RAM filesystem is a ramfs which is loaded by the 420 boot loader (loadlin or lilo) and that is mounted as root 421 before the normal boot procedure. It is typically used to 422 load modules needed to mount the "real" root file system, 423 etc. See <file:Documentation/initrd.txt> for details. 424 425 If RAM disk support (BLK_DEV_RAM) is also included, this 426 also enables initial RAM disk (initrd) support. 427 428 429config CDROM_PKTCDVD 430 tristate "Packet writing on CD/DVD media" 431 depends on !UML 432 help 433 If you have a CDROM drive that supports packet writing, say Y to 434 include preliminary support. It should work with any MMC/Mt Fuji 435 compliant ATAPI or SCSI drive, which is just about any newer CD 436 writer. 437 438 Currently only writing to CD-RW, DVD-RW and DVD+RW discs is possible. 439 DVD-RW disks must be in restricted overwrite mode. 440 441 To compile this driver as a module, choose M here: the 442 module will be called pktcdvd. 443 444config CDROM_PKTCDVD_BUFFERS 445 int "Free buffers for data gathering" 446 depends on CDROM_PKTCDVD 447 default "8" 448 help 449 This controls the maximum number of active concurrent packets. More 450 concurrent packets can increase write performance, but also require 451 more memory. Each concurrent packet will require approximately 64Kb 452 of non-swappable kernel memory, memory which will be allocated when 453 a disc is opened for writing. 454 455config CDROM_PKTCDVD_WCACHE 456 bool "Enable write caching (EXPERIMENTAL)" 457 depends on CDROM_PKTCDVD && EXPERIMENTAL 458 help 459 If enabled, write caching will be set for the CD-R/W device. For now 460 this option is dangerous unless the CD-RW media is known good, as we 461 don't do deferred write error handling yet. 462 463source "drivers/s390/block/Kconfig" 464 465config ATA_OVER_ETH 466 tristate "ATA over Ethernet support" 467 depends on NET 468 help 469 This driver provides Support for ATA over Ethernet block 470 devices like the Coraid EtherDrive (R) Storage Blade. 471 472endmenu 473 474endif 475