| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | This file describes the floppy driver. | 
 | 2 |  | 
 | 3 | FAQ list: | 
 | 4 | ========= | 
 | 5 |  | 
 | 6 |  A FAQ list may be found in the fdutils package (see below), and also | 
| Randy Dunlap | 98766fb | 2005-11-21 21:32:31 -0800 | [diff] [blame] | 7 | at <http://fdutils.linux.lu/faq.html>. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 8 |  | 
 | 9 |  | 
 | 10 | LILO configuration options (Thinkpad users, read this) | 
 | 11 | ====================================================== | 
 | 12 |  | 
 | 13 |  The floppy driver is configured using the 'floppy=' option in | 
 | 14 | lilo. This option can be typed at the boot prompt, or entered in the | 
 | 15 | lilo configuration file. | 
 | 16 |  | 
 | 17 |  Example: If your kernel is called linux-2.6.9, type the following line | 
 | 18 | at the lilo boot prompt (if you have a thinkpad): | 
 | 19 |  | 
 | 20 |  linux-2.6.9 floppy=thinkpad | 
 | 21 |  | 
 | 22 | You may also enter the following line in /etc/lilo.conf, in the description | 
 | 23 | of linux-2.6.9: | 
 | 24 |  | 
 | 25 |  append = "floppy=thinkpad" | 
 | 26 |  | 
 | 27 |  Several floppy related options may be given, example: | 
 | 28 |  | 
 | 29 |  linux-2.6.9 floppy=daring floppy=two_fdc | 
 | 30 |  append = "floppy=daring floppy=two_fdc" | 
 | 31 |  | 
 | 32 |  If you give options both in the lilo config file and on the boot | 
 | 33 | prompt, the option strings of both places are concatenated, the boot | 
 | 34 | prompt options coming last. That's why there are also options to | 
 | 35 | restore the default behavior. | 
 | 36 |  | 
 | 37 |  | 
 | 38 | Module configuration options | 
 | 39 | ============================ | 
 | 40 |  | 
 | 41 |  If you use the floppy driver as a module, use the following syntax: | 
 | 42 | modprobe floppy <options> | 
 | 43 |  | 
 | 44 | Example: | 
 | 45 |  modprobe floppy omnibook messages | 
 | 46 |  | 
 | 47 |  If you need certain options enabled every time you load the floppy driver, | 
 | 48 | you can put: | 
 | 49 |  | 
 | 50 |  options floppy omnibook messages | 
 | 51 |  | 
 | 52 | in /etc/modprobe.conf. | 
 | 53 |  | 
 | 54 |  | 
 | 55 |  The floppy driver related options are: | 
 | 56 |  | 
 | 57 |  floppy=asus_pci | 
 | 58 | 	Sets the bit mask to allow only units 0 and 1. (default) | 
 | 59 |  | 
 | 60 |  floppy=daring | 
 | 61 | 	Tells the floppy driver that you have a well behaved floppy controller. | 
 | 62 | 	This allows more efficient and smoother operation, but may fail on | 
 | 63 | 	certain controllers. This may speed up certain operations. | 
 | 64 |  | 
 | 65 |  floppy=0,daring | 
 | 66 | 	Tells the floppy driver that your floppy controller should be used | 
 | 67 | 	with caution. | 
 | 68 |  | 
 | 69 |  floppy=one_fdc | 
 | 70 | 	Tells the floppy driver that you have only one floppy controller. | 
 | 71 | 	(default) | 
 | 72 |  | 
 | 73 |  floppy=two_fdc | 
 | 74 |  floppy=<address>,two_fdc | 
 | 75 | 	Tells the floppy driver that you have two floppy controllers. | 
 | 76 | 	The second floppy controller is assumed to be at <address>. | 
 | 77 | 	This option is not needed if the second controller is at address | 
 | 78 | 	0x370, and if you use the 'cmos' option. | 
 | 79 |  | 
 | 80 |  floppy=thinkpad | 
 | 81 | 	Tells the floppy driver that you have a Thinkpad. Thinkpads use an | 
 | 82 | 	inverted convention for the disk change line. | 
 | 83 |  | 
 | 84 |  floppy=0,thinkpad | 
 | 85 | 	Tells the floppy driver that you don't have a Thinkpad. | 
 | 86 |  | 
 | 87 |  floppy=omnibook | 
 | 88 |  floppy=nodma | 
 | 89 | 	Tells the floppy driver not to use Dma for data transfers. | 
 | 90 | 	This is needed on HP Omnibooks, which don't have a workable | 
 | 91 | 	DMA channel for the floppy driver. This option is also useful | 
 | 92 | 	if you frequently get "Unable to allocate DMA memory" messages. | 
 | 93 | 	Indeed, dma memory needs to be continuous in physical memory, | 
 | 94 | 	and is thus harder to find, whereas non-dma buffers may be | 
 | 95 | 	allocated in virtual memory. However, I advise against this if | 
 | 96 | 	you have an FDC without a FIFO (8272A or 82072). 82072A and | 
 | 97 | 	later are OK. You also need at least a 486 to use nodma. | 
 | 98 | 	If you use nodma mode, I suggest you also set the FIFO | 
 | 99 | 	threshold to 10 or lower, in order to limit the number of data | 
 | 100 | 	transfer interrupts. | 
 | 101 |  | 
 | 102 | 	If you have a FIFO-able FDC, the floppy driver automatically | 
 | 103 | 	falls back on non DMA mode if no DMA-able memory can be found. | 
 | 104 | 	If you want to avoid this, explicitly ask for 'yesdma'. | 
 | 105 |  | 
 | 106 |  floppy=yesdma | 
 | 107 | 	Tells the floppy driver that a workable DMA channel is available. | 
 | 108 | 	(default) | 
 | 109 |  | 
 | 110 |  floppy=nofifo | 
 | 111 | 	Disables the FIFO entirely. This is needed if you get "Bus | 
 | 112 | 	master arbitration error" messages from your Ethernet card (or | 
 | 113 | 	from other devices) while accessing the floppy. | 
 | 114 |  | 
 | 115 |  floppy=usefifo | 
 | 116 | 	Enables the FIFO. (default) | 
 | 117 |  | 
 | 118 |  floppy=<threshold>,fifo_depth | 
 | 119 | 	Sets the FIFO threshold. This is mostly relevant in DMA | 
 | 120 | 	mode. If this is higher, the floppy driver tolerates more | 
 | 121 | 	interrupt latency, but it triggers more interrupts (i.e. it | 
 | 122 | 	imposes more load on the rest of the system). If this is | 
 | 123 | 	lower, the interrupt latency should be lower too (faster | 
 | 124 | 	processor). The benefit of a lower threshold is less | 
 | 125 | 	interrupts. | 
 | 126 |  | 
 | 127 | 	To tune the fifo threshold, switch on over/underrun messages | 
 | 128 | 	using 'floppycontrol --messages'. Then access a floppy | 
 | 129 | 	disk. If you get a huge amount of "Over/Underrun - retrying" | 
 | 130 | 	messages, then the fifo threshold is too low. Try with a | 
 | 131 | 	higher value, until you only get an occasional Over/Underrun. | 
 | 132 | 	It is a good idea to compile the floppy driver as a module | 
 | 133 | 	when doing this tuning. Indeed, it allows to try different | 
 | 134 | 	fifo values without rebooting the machine for each test. Note | 
 | 135 | 	that you need to do 'floppycontrol --messages' every time you | 
 | 136 | 	re-insert the module. | 
 | 137 |  | 
 | 138 | 	Usually, tuning the fifo threshold should not be needed, as | 
 | 139 | 	the default (0xa) is reasonable. | 
 | 140 |  | 
 | 141 |  floppy=<drive>,<type>,cmos | 
 | 142 | 	Sets the CMOS type of <drive> to <type>. This is mandatory if | 
 | 143 | 	you have more than two floppy drives (only two can be | 
 | 144 | 	described in the physical CMOS), or if your BIOS uses | 
 | 145 | 	non-standard CMOS types. The CMOS types are: | 
 | 146 |  | 
 | 147 | 		0 - Use the value of the physical CMOS | 
 | 148 | 		1 - 5 1/4 DD | 
 | 149 | 		2 - 5 1/4 HD | 
 | 150 | 		3 - 3 1/2 DD | 
 | 151 | 		4 - 3 1/2 HD | 
 | 152 | 		5 - 3 1/2 ED | 
 | 153 | 		6 - 3 1/2 ED | 
 | 154 | 	       16 - unknown or not installed | 
 | 155 |  | 
 | 156 | 	(Note: there are two valid types for ED drives. This is because 5 was | 
 | 157 | 	initially chosen to represent floppy *tapes*, and 6 for ED drives. | 
 | 158 | 	AMI ignored this, and used 5 for ED drives. That's why the floppy | 
 | 159 | 	driver handles both.) | 
 | 160 |  | 
 | 161 |  floppy=unexpected_interrupts | 
 | 162 | 	Print a warning message when an unexpected interrupt is received. | 
 | 163 | 	(default) | 
 | 164 |  | 
 | 165 |  floppy=no_unexpected_interrupts | 
 | 166 |  floppy=L40SX | 
 | 167 | 	Don't print a message when an unexpected interrupt is received. This | 
 | 168 | 	is needed on IBM L40SX laptops in certain video modes. (There seems | 
 | 169 | 	to be an interaction between video and floppy. The unexpected | 
 | 170 | 	interrupts affect only performance, and can be safely ignored.) | 
 | 171 |  | 
 | 172 |  floppy=broken_dcl | 
 | 173 | 	Don't use the disk change line, but assume that the disk was | 
 | 174 | 	changed whenever the device node is reopened. Needed on some | 
 | 175 | 	boxes where the disk change line is broken or unsupported. | 
 | 176 | 	This should be regarded as a stopgap measure, indeed it makes | 
 | 177 | 	floppy operation less efficient due to unneeded cache | 
 | 178 | 	flushings, and slightly more unreliable. Please verify your | 
 | 179 | 	cable, connection and jumper settings if you have any DCL | 
 | 180 | 	problems. However, some older drives, and also some laptops | 
 | 181 | 	are known not to have a DCL. | 
 | 182 |  | 
 | 183 |  floppy=debug | 
 | 184 | 	Print debugging messages. | 
 | 185 |  | 
 | 186 |  floppy=messages | 
 | 187 | 	Print informational messages for some operations (disk change | 
 | 188 | 	notifications, warnings about over and underruns, and about | 
 | 189 | 	autodetection). | 
 | 190 |  | 
 | 191 |  floppy=silent_dcl_clear | 
 | 192 | 	Uses a less noisy way to clear the disk change line (which | 
 | 193 | 	doesn't involve seeks). Implied by 'daring' option. | 
 | 194 |  | 
 | 195 |  floppy=<nr>,irq | 
 | 196 | 	Sets the floppy IRQ to <nr> instead of 6. | 
 | 197 |  | 
 | 198 |  floppy=<nr>,dma | 
 | 199 | 	Sets the floppy DMA channel to <nr> instead of 2. | 
 | 200 |  | 
 | 201 |  floppy=slow | 
 | 202 | 	Use PS/2 stepping rate: | 
 | 203 | 	 " PS/2 floppies have much slower step rates than regular floppies. | 
 | 204 | 	   It's been recommended that take about 1/4 of the default speed | 
 | 205 | 	   in some more extreme cases." | 
 | 206 |  | 
 | 207 |  | 
 | 208 | Supporting utilities and additional documentation: | 
 | 209 | ================================================== | 
 | 210 |  | 
 | 211 |  Additional parameters of the floppy driver can be configured at | 
 | 212 | runtime. Utilities which do this can be found in the fdutils package. | 
 | 213 | This package also contains a new version of mtools which allows to | 
 | 214 | access high capacity disks (up to 1992K on a high density 3 1/2 disk!). | 
 | 215 | It also contains additional documentation about the floppy driver. | 
 | 216 |  | 
 | 217 | The latest version can be found at fdutils homepage: | 
 | 218 |  http://fdutils.linux.lu | 
 | 219 |  | 
| Randy Dunlap | 98766fb | 2005-11-21 21:32:31 -0800 | [diff] [blame] | 220 | The fdutils releases can be found at: | 
 | 221 |  http://fdutils.linux.lu/download.html | 
 | 222 |  http://www.tux.org/pub/knaff/fdutils/ | 
 | 223 |  ftp://metalab.unc.edu/pub/Linux/utils/disk-management/ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 224 |  | 
 | 225 | Reporting problems about the floppy driver | 
 | 226 | ========================================== | 
 | 227 |  | 
 | 228 |  If you have a question or a bug report about the floppy driver, mail | 
 | 229 | me at Alain.Knaff@poboxes.com . If you post to Usenet, preferably use | 
 | 230 | comp.os.linux.hardware. As the volume in these groups is rather high, | 
 | 231 | be sure to include the word "floppy" (or "FLOPPY") in the subject | 
 | 232 | line.  If the reported problem happens when mounting floppy disks, be | 
 | 233 | sure to mention also the type of the filesystem in the subject line. | 
 | 234 |  | 
 | 235 |  Be sure to read the FAQ before mailing/posting any bug reports! | 
 | 236 |  | 
 | 237 |  Alain | 
 | 238 |  | 
 | 239 | Changelog | 
 | 240 | ========= | 
 | 241 |  | 
 | 242 | 10-30-2004 :	Cleanup, updating, add reference to module configuration. | 
 | 243 | 		James Nelson <james4765@gmail.com> | 
 | 244 |  | 
 | 245 | 6-3-2000 :	Original Document |