Contidos dentro
Localizar Mais Documentação
Destaques de Recursos de Suporte
| Fazer download desta apostila em PDF
NAME
- fdio - floppy disk control operations
SYNOPSIS
-
#include <sys/fdio.h>
DESCRIPTION
- The Solaris floppy driver supports a set of ioctl(2) requests for getting and setting the floppy drive characteristics. Basic to these ioctl( ) requests are the definitions in <sys/fdio.h>.
IOCTLS
- The following ioctl( ) requests are available on the Solaris floppy driver.
-
-
FDDEFGEOCHAR
- x86 based systems: This ioctl( ) forces the floppy driver to restore the diskette and drive characteristics and geometry, and partition information to default values based on the device configuration.
-
-
FDGETCHANGE
- The argument is a pointer to an int. This ioctl( ) returns the status of the diskette-changed signal from the floppy interface. The following defines are provided for cohesion.
- Note that for x86 based systems, use FDGC_DETECTED (which is available only on x86 based systems) instead of FDGC_HISTORY.
-
/*
-
-
* Used by FDGETCHANGE, returned state of the sense disk change bit.
* /
#define FDGC_HISTORY 0x01 /* disk has changed since last call * /
#define FDGC_CURRENT 0x02 /* current state of disk change * /
#define FDGC_CURWPROT 0x10 /* current state of write protect * /
#define FDGC_DETECTED 0x20 /* previous state of DISK CHANGE * /
-
-
FDIOGCHAR
- The argument is a pointer to an fd_char structure (described below). This ioctl( ) gets the characteristics of the floppy diskette from the floppy controller.
-
-
FDIOSCHAR
- The argument is a pointer to an fd_char structure (described below). This ioctl( ) sets the characteristics of the floppy diskette for the floppy controller. Typical values in the fd_char structure for a high density diskette:
-
-
field value
fdc_medium 0
fdc_transfer_rate 500
fdc_ncyl 80
fdc_nhead 2
fdc_sec_size 512
fdc_secptrack 18
fdc_steps -1 { This field doesn't apply. }
-
/*
-
-
* Floppy characteristics
* /
struct fd_char {
u_char fdc_medium; /* equals 1 if medium type * /
int fdc_transfer_rate; /* transfer rate * /
int fdc_ncyl; /* number of cylinders * /
int fdc_nhead; /* number of heads * /
int fdc_sec_size; /* sector size * /
int fdc_secptrack; /* sectors per track * /
int fdc_steps; /* no. of steps per data track * /
};
-
-
FDGETDRIVECHAR
- The argument to this ioctl( ) is a pointer to an fd_drive structure (described below). This ioctl( ) gets the characteristics of the floppy drive from the floppy controller.
-
-
FDSETDRIVECHAR
x86 based systems: The argument to this ioctl( ) is a pointer to an
fd_drive structure (described below). This ioctl( ) sets the characteristics
of the floppy drive for the floppy controller. Only fdd_steprate,
fdd_headsettle, fdd_motoron, and fdd_motoroff are actually used by
- the floppy disk driver.
-
/*
-
-
* Floppy Drive characteristics
* /
struct fd_drive {
int fdd_ejectable; /* does the drive support eject? * /
int fdd_maxsearch; /* size of per-unit search table * /
int fdd_writeprecomp; /* cyl to start write precompensation * /
int fdd_writereduce; /* cyl to start recucing write current * /
int fdd_stepwidth; /* width of step pulse in 1 us units * /
int fdd_steprate; /* step rate in 100 us units * /
int fdd_headsettle; /* delay, in 100 us units * /
int fdd_headload; /* delay, in 100 us units * /
int fdd_headunload; /* delay, in 100 us units * /
int fdd_motoron; /* delay, in 100 ms units * /
int fdd_motoroff; /* delay, in 100 ms units * /
int fdd_precomplevel; /* bit shift, in nano-secs * /
int fdd_pins; /* defines meaning of pin 1, 2, 4 and 34 * /
int fdd_flags; /* TRUE READY ,Starting Sector #, & Motor On * /
};
-
FDGETSEARCH Not available.
-
FDSETSEARCH Not available.
-
-
FDEJECT
- SPARC: This ioctl( ) requests the floppy drive to eject the diskette.
-
-
FDIOCMD
- The argument is a pointer to an fd_cmd structure (described below). This ioctl( ) allows access to the floppy diskette using the floppy device driver. Only the FDCMD_WRITE, FDCMD_READ, and
-
FDCMD_FORMAT_TR commands are currently available.
-
-
struct fd_cmd {
u_short fdc_cmd; /* command to be executed * /
int fdc_flags; /* execution flags (x86 only) * /
daddr_t fdc_blkno; /* disk address for command * /
int fdc_secnt; /* sector count for command * /
caddr_t fdc_bufaddr; /* user's buffer address * /
u_int fdc_buflen; /* size of user's buffer * /
};
- Please note that the fdc_buflen field is currently unused. The fdc_secnt field is used to calculate the transfer size, and the buffer is assumed to be large enough to accommodate the transfer.
-
-
struct fd_cmd {
/*
* Floppy commands
* /
#define FDCMD_WRITE 1
#define FDCMD_READ 2
#define FDCMD_SEEK 3
#define FDCMD_REZERO 4
#define FDCMD_FORMAT_UNIT 5
#define FDCMD_FORMAT_TRACK 6
};
-
-
FDRAW
- The argument is a pointer to an fd_raw structure (described below). This ioctl( ) allows direct control of the floppy drive using the floppy controller. Refer to the appropriate floppy-controller data sheet for full details on required command bytes and returned result bytes. The following commands are supported.
-
/*
-
-
* Floppy raw commands
* /
#define FDRAW_SPECIFY 0x03
#define FDRAW_READID 0x0a (x86 only)
#define FDRAW_SENSE_DRV 0x04
#define FDRAW_REZERO 0x07
#define FDRAW_SEEK 0x0f
#define FDRAW_SENSE_INT 0x08 (x86 only)
#define FDRAW_FORMAT 0x0d
-
-
#define FDRAW_READTRACK 0x02
#define FDRAW_WRCMD 0x05
#define FDRAW_RDCMD 0x06
#define FDRAW_WRITEDEL 0x09
#define FDRAW_READDEL 0x0c
- Please note that when using FDRAW_SEEK or FDRAW_REZERO, the driver automatically issues a FDRAW_SENSE_INT command to clear the interrupt from the FDRAW_SEEK or the FDRAW_REZERO. The result bytes returned by these commands are the results from the
-
FDRAW_SENSE_INT command. Please see the floppy-controller data sheet for more details on FDRAW_SENSE_INT.
-
/*
-
-
* Used by FDRAW
* /
struct fd_raw {
char fdr_cmd[10]; /* user-supplied command bytes * /
short fdr_cnum; /* number of command bytes * /
char fdr_result[10]; /* controller-supplied result bytes * /
u_short fdr_nbytes; /* number to transfer if read/write command * /
char * fdr_addr; /* where to transfer if read/write command * /
};
SEE ALSO
-
ioctl(2), dkio(7I), fd (7D),hdio(7I)
|
|