fd(4) — Linux manual page
fd(4) Kernel Interfaces Manual fd(4)
NAME
fd - floppy disk device
CONFIGURATION
Floppy drives are block devices with major number 2. Typically
they are owned by root:floppy (i.e., user root, group floppy) and
have either mode 0660 (access checking via group membership) or
mode 0666 (everybody has access). The minor numbers encode the
device type, drive number, and controller number. For each
device type (that is, combination of density and track count)
there is a base minor number. To this base number, add the
drive's number on its controller and 128 if the drive is on the
secondary controller. In the following device tables, n
represents the drive number.
Warning: if you use formats with more tracks than supported by
your drive, you may cause it mechanical damage. Trying once if
more tracks than the usual 40/80 are supported should not damage
it, but no warranty is given for that. If you are not sure,
don't create device entries for those formats, so as to prevent
their usage.
Drive-independent device files which automatically detect the
media format and capacity:
Name Base
minor #
───────────────
fdn 0
5.25 inch double-density device files:
Name Capacity Cyl. Sect. Heads Base
KiB minor #
───────────────────────────────────────────────────────
fdnd360 360 40 9 2 4
5.25 inch high-density device files:
Name Capacity Cyl. Sect. Heads Base
KiB minor #
───────────────────────────────────────────────────────
fdnh360 360 40 9 2 20
fdnh410 410 41 10 2 48
fdnh420 420 42 10 2 64
fdnh720 720 80 9 2 24
fdnh880 880 80 11 2 80
fdnh1200 1200 80 15 2 8
fdnh1440 1440 80 18 2 40
fdnh1476 1476 82 18 2 56
fdnh1494 1494 83 18 2 72
fdnh1600 1600 80 20 2 92
3.5 inch double-density device files:
Name Capacity Cyl. Sect. Heads Base
KiB minor #
───────────────────────────────────────────────────────
fdnu360 360 80 9 1 12
fdnu720 720 80 9 2 16
fdnu800 800 80 10 2 120
fdnu1040 1040 80 13 2 84
fdnu1120 1120 80 14 2 88
3.5 inch high-density device files:
Name Capacity Cyl. Sect. Heads Base
KiB minor #
───────────────────────────────────────────────────────
fdnu360 360 40 9 2 12
fdnu720 720 80 9 2 16
fdnu820 820 82 10 2 52
fdnu830 830 83 10 2 68
fdnu1440 1440 80 18 2 28
fdnu1600 1600 80 20 2 124
fdnu1680 1680 80 21 2 44
fdnu1722 1722 82 21 2 60
fdnu1743 1743 83 21 2 76
fdnu1760 1760 80 22 2 96
fdnu1840 1840 80 23 2 116
fdnu1920 1920 80 24 2 100
3.5 inch extra-density device files:
Name Capacity Cyl. Sect. Heads Base
KiB minor #
───────────────────────────────────────────────────────
fdnu2880 2880 80 36 2 32
fdnCompaQ 2880 80 36 2 36
fdnu3200 3200 80 40 2 104
fdnu3520 3520 80 44 2 108
fdnu3840 3840 80 48 2 112
DESCRIPTION
fd special files access the floppy disk drives in raw mode. The
following ioctl(2) calls are supported by fd devices:
FDCLRPRM
clears the media information of a drive (geometry of disk
in drive).
FDSETPRM
sets the media information of a drive. The media
information will be lost when the media is changed.
FDDEFPRM
sets the media information of a drive (geometry of disk in
drive). The media information will not be lost when the
media is changed. This will disable autodetection. In
order to reenable autodetection, you have to issue an
FDCLRPRM.
FDGETDRVTYP
returns the type of a drive (name parameter). For formats
which work in several drive types, FDGETDRVTYP returns a
name which is appropriate for the oldest drive type which
supports this format.
FDFLUSH
invalidates the buffer cache for the given drive.
FDSETMAXERRS
sets the error thresholds for reporting errors, aborting
the operation, recalibrating, resetting, and reading
sector by sector.
FDSETMAXERRS
gets the current error thresholds.
FDGETDRVTYP
gets the internal name of the drive.
FDWERRORCLR
clears the write error statistics.
FDWERRORGET
reads the write error statistics. These include the total
number of write errors, the location and disk of the first
write error, and the location and disk of the last write
error. Disks are identified by a generation number which
is incremented at (almost) each disk change.
FDTWADDLE
Switch the drive motor off for a few microseconds. This
might be needed in order to access a disk whose sectors
are too close together.
FDSETDRVPRM
sets various drive parameters.
FDGETDRVPRM
reads these parameters back.
FDGETDRVSTAT
gets the cached drive state (disk changed, write protected
et al.)
FDPOLLDRVSTAT
polls the drive and return its state.
FDGETFDCSTAT
gets the floppy controller state.
FDRESET
resets the floppy controller under certain conditions.
FDRAWCMD
sends a raw command to the floppy controller.
For more precise information, consult also the <linux/fd.h> and
<linux/fdreg.h> include files, as well as the floppycontrol(1)
manual page.
FILES
/dev/fd*
NOTES
The various formats permit reading and writing many types of
disks. However, if a floppy is formatted with an inter-sector
gap that is too small, performance may drop, to the point of
needing a few seconds to access an entire track. To prevent
this, use interleaved formats.
It is not possible to read floppies which are formatted using GCR
(group code recording), which is used by Apple II and Macintosh
computers (800k disks).
Reading floppies which are hard sectored (one hole per sector,
with the index hole being a little skewed) is not supported.
This used to be common with older 8-inch floppies.
SEE ALSO
chown(1), floppycontrol(1), getfdprm(1), mknod(1),
superformat(1), mount(8), setfdprm(8)
COLOPHON
This page is part of the man-pages (Linux kernel and C library
user-space interface documentation) project. Information about
the project can be found at
⟨https://www.kernel.org/doc/man-pages/⟩. If you have a bug report
for this manual page, see
⟨https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/tree/CONTRIBUTING⟩.
This page was obtained from the tarball man-pages-6.9.1.tar.gz
fetched from
⟨https://mirrors.edge.kernel.org/pub/linux/docs/man-pages/⟩ on
2024-06-26. If you discover any rendering problems in this HTML
version of the page, or you believe there is a better or more up-
to-date source for the page, or you have corrections or
improvements to the information in this COLOPHON (which is not
part of the original manual page), send a mail to
man-pages@man7.org