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.
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. Don't create
device entries for those formats to prevent their usage if
you are not sure.
Drive independent device files which automatically detect
the media format and capacity:
5.25 inch double density device files:
5.25 inch high density device files:
3.5 inch double density device files:
3.5 inch high density device files:
3.5 inch extra density device files:
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 re-enable 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 manual page for floppycontrol.
NOTES
The various formats allow to read and write many types of
disks. However, if a floppy is formatted with a too small
inter sector gap, performance may drop, up to 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.
AUTHORS
Alain Knaff (Alain.Knaff@imag.fr), David Niemi
(niemidc@clark.net), Bill Broadhurst (bbroad@netcom.com).
SEE ALSO
chown(1), floppycontrol(1), getfdprm(1), mknod(1), superformat(1), mount(8), setfdprm(8)
t
Copyright (c) 1993 Michael Haardt (michael@cantor.informatik.rwth-aachen.de)
and 1994,1995 Alain Knaff (Alain.Knaff@imag.fr)
This is free documentation; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of
the License, or (at your option) any later version.
The GNU General Public License's references to "object code"
and "executables" are to be interpreted as the output of any
document formatting or typesetting system, including
intermediate and printed output.
This manual is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public
License along with this manual; if not, write to the Free
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111,
USA.
Modified, Sun Feb 26 15:00:02 1995, faith@cs.unc.edu
|