~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/admin-guide/blockdev/floppy.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

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

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php