aboutsummaryrefslogtreecommitdiff
path: root/man
diff options
context:
space:
mode:
Diffstat (limited to 'man')
-rw-r--r--man/man3/disk.3177
-rw-r--r--man/man3/scsi.3188
2 files changed, 0 insertions, 365 deletions
diff --git a/man/man3/disk.3 b/man/man3/disk.3
deleted file mode 100644
index bec50f20..00000000
--- a/man/man3/disk.3
+++ /dev/null
@@ -1,177 +0,0 @@
-.TH DISK 3
-.SH NAME
-opendisk, Disk \- generic disk device interface
-.SH SYNOPSIS
-.nf
-.ft L
-#include <u.h>
-#include <libc.h>
-#include <disk.h>
-.ft
-.PP
-.ft L
-typedef struct Disk {
- char *prefix;
- char part[NAMELEN];
- int fd, wfd, ctlfd, rdonly;
- int type;
- vlong secs, secsize, size, offset;
- int c, h, s;
-} Disk;
-.ft
-.PP
-.B
-Disk* opendisk(char *file, int rdonly, int noctl)
-.SH DESCRIPTION
-These routines provide a simple way to gather
-and use information about
-disks and disk partitions,
-as well as plain files.
-.PP
-.I Opendisk
-opens
-.I file
-for reading and stores the file descriptor in
-the
-.B fd
-field of the
-.B Disk
-structure.
-If
-.I rdonly
-is not set,
-.I opendisk
-also opens
-.I file
-for writing and stores that file descriptor in
-.BR wfd .
-The two file descriptors are kept separate to
-help prevent accidents.
-.PP
-If
-.I noctl
-is not set,
-.I opendisk
-looks for a
-.B ctl
-file in the same directory as the
-disk file;
-if it finds one, it declares
-the disk to be
-an
-.I sd
-device,
-setting the
-.B type
-field in the
-.B Disk
-structure
-to
-.BR Tsd .
-If the passed
-.I file
-is named
-.BI fd n disk \fR,
-it looks for a file
-.BI fd n ctl \fR,
-and if it finds that,
-declares the disk to be
-a floppy disk, of type
-.BR Tfloppy .
-If either
-control
-file is found, it is opened for reading
-and writing, and the resulting file descriptor
-is saved as
-.BR ctlfd .
-Otherwise the returned disk
-has type
-.BR Tfile .
-.PP
-.I Opendisk
-then stats the file and stores its length in
-.BR size .
-If the disk is an
-.I sd
-partition,
-.I opendisk
-reads the sector size from the
-control
-file and stores it in
-.BR secsize ;
-otherwise the sector size is assumed to be 512,
-as is the case for floppy disks.
-.I Opendisk
-then stores the disk size measured in sectors in
-.BR secs .
-.PP
-If the disk is an
-.I sd
-partition,
-.I opendisk
-parses the
-control
-file to find the partition's offset
-within its disk;
-otherwise it sets
-.B offset
-to zero.
-If the disk is an ATA disk,
-.I opendisk
-reads
-the disk geometry (number of cylinders, heads, and sectors)
-from the
-.B geometry
-line in the
-.I sd
-control file;
-otherwise it sets these to zero as well.
-.B Name
-is initialized with the base name of
-the disk partition, and is useful for forming messages to the
-.I sd
-control file.
-.B Prefix
-is set to the passed filename without
-the
-.B name
-suffix.
-.PP
-The IBM PC BIOS interface allocates
-10 bits for the number of cylinders, 8 for
-the number of heads, and 6 for the number of sectors per track.
-Disk geometries are not quite so simple
-anymore, but to keep the interface useful,
-modern disks and BIOSes present geometries
-that still fit within these constraints.
-These numbers are still used when partitioning
-and formatting disks.
-.I Opendisk
-employs a number of heuristics to discover this
-supposed geometry and store it in the
-.BR c ,
-.BR h ,
-and
-.B s
-fields.
-Disk offsets in partition tables and
-in FAT descriptors are stored in a form
-dependent upon these numbers, so
-.I opendisk
-works hard to report numbers that
-agree with those used by other operating
-systems; the numbers bear little or no resemblance
-to reality.
-.SH SOURCE
-.B \*9/src/libdisk/disk.c
-.SH SEE ALSO
-Plan 9's
-\fIfloppy\fR(3) and \fIsd\fR(3)
-.SH BUGS
-Disks on Unix systems do not present the interface
-that
-.I opendisk
-expects, so
-.I opendisk
-will give them type
-.BR Tfile .
diff --git a/man/man3/scsi.3 b/man/man3/scsi.3
deleted file mode 100644
index d4f0d045..00000000
--- a/man/man3/scsi.3
+++ /dev/null
@@ -1,188 +0,0 @@
-.TH SCSI 3
-.SH NAME
-openscsi, scsiready, scsi, scsicmd, scsierror \- SCSI device operations
-.SH SYNOPSIS
-.nf
-.ft L
-#include <u.h>
-#include <libc.h>
-#include <disk.h>
-.ft
-.PP
-.ft L
-typedef struct Scsi {
- char *inquire;
- int rawfd;
- int nchange;
- ulong changetime;
-};
-.ft
-.PP
-.B
-Scsi* openscsi(char *devdir)
-.PP
-.B
-void closescsi(Scsi *s)
-.PP
-.B
-int scsiready(Scsi *s)
-.PP
-.B
-int scsi(Scsi *s, uchar *cmd, int ncmd,
-.br
- void *data, int ndata, int dir)
-.PP
-.B
-int scsicmd(Scsi *s, uchar *cmd, int ncmd,
-.br
- void *data, int ndata, int dir)
-.PP
-.B
-char* scsierror(int asc, int ascq)
-.PP
-.B
-int scsiverbose;
-.SH DESCRIPTION
-These routines provide an interface
-to a SCSI or ATAPI device via Plan 9's
-\fIsd\fR(3).
-.PP
-.I Openscsi
-attempts to open the file
-.IB devdir /raw
-and use it to send raw SCSI commands.
-On success, it reads the device's inquiry
-string and stores it in in returned
-.B Scsi
-structure.
-.I Closescsi
-closes the connection and frees the
-.B Scsi
-structure.
-.PP
-.I Scsiready
-sends the ``unit ready'' command up to three times,
-returning zero if the unit responds that it is ready,
-or \-1 on error.
-.PP
-.I Scsierror
-returns a textual description of the SCSI status
-denoted by the ASC and ASCQ sense codes.
-The description is found by consulting
-.BR /sys/lib/scsicodes .
-The returned string will be overwritten by
-the next call to
-.IR scsierror .
-.PP
-.I Scsi
-and
-.I scsicmd
-execute a single SCSI command on the named device.
-There should be
-.I ncmd
-bytes of
-command data in
-.IR cmd ;
-if
-.I dir
-is
-.BR Sread ,
-a successful operation
-will store up to
-.I ndata
-bytes into
-.IR data ,
-returning the number of bytes stored.
-If
-.I dir
-is
-.BR Swrite ,
-the
-.I ndata
-bytes beginning at
-.I data
-are transmitted as the data argument to
-the command, and the
-number of bytes written is returned.
-If
-.I dir
-is
-.BR Snone ,
-.I data
-and
-.I ndata
-are ignored.
-On error,
-.I scsi
-and
-.I scsicmd
-return \-1.
-.I Scsicmd
-simply issues the command and
-returns the result;
-.I scsi
-works a bit harder and
-is the more commonly used routine.
-.I Scsi
-attempts to send the command;
-if it is successful,
-.I scsi
-returns what
-.I scsicmd
-returned.
-Otherwise,
-.I scsi
-sends a request sense command to
-obtain the reason for the failure,
-sends a unit ready command in
-an attempt to bring the unit out of any
-inconsistent states, and tries again.
-If the second try fails,
-.I scsi
-sends the request
-sense and unit ready commands
-again
-and then uses
-.I scsierror
-to set
-.I errstr
-with a reason for failure.
-.PP
-The
-.B nchange
-and
-.B changetime
-fields
-in the
-.B Scsi
-structure
-record the number of times a media
-change has been detected, and the
-time when the current media was
-inserted into the drive (really the
-first time a SCSI command was issued
-after it was inserted).
-They are maintained by
-.IR scsi .
-.PP
-If
-.I scsiverbose
-is set,
-these commands will produce a fair
-amount of debugging output on file descriptor 2
-when SCSI commands fail.
-.SH FILES
-.TP
-.B /sys/lib/scsicodes
-List of textual messages corresponding to SCSI error codes;
-consulted by
-.BR scsierror .
-.SH SOURCE
-.B \*9/src/libdisk/scsi.c
-.SH SEE ALSO
-Plan 9's
-\fIsd\fR(3) and
-\fIscuzz\fR(8)
-.SH BUGS
-SCSI devices on Unix do not present the interface expected by
-these routines.