1*41488Smckusick /* 2*41488Smckusick * Copyright (c) 1982, 1986, 1990 The Regents of the University of California. 3*41488Smckusick * All rights reserved. 4*41488Smckusick * 5*41488Smckusick * %sccs.include.redist.c% 6*41488Smckusick * 7*41488Smckusick * @(#)saio.h 7.1 (Berkeley) 05/08/90 8*41488Smckusick */ 9*41488Smckusick 10*41488Smckusick /* 11*41488Smckusick * Header file for standalone package 12*41488Smckusick */ 13*41488Smckusick 14*41488Smckusick #include "../h/types.h" 15*41488Smckusick #include "../h/param.h" 16*41488Smckusick #include "../ufs/dinode.h" 17*41488Smckusick #include "../ufs/fs.h" 18*41488Smckusick 19*41488Smckusick /* 20*41488Smckusick * Io block: includes a 21*41488Smckusick * dinode, cells for the use of seek, etc, 22*41488Smckusick * and a buffer. 23*41488Smckusick */ 24*41488Smckusick struct iob { 25*41488Smckusick int i_flgs; /* see F_ below */ 26*41488Smckusick struct dinode i_ino; /* dinode, if file */ 27*41488Smckusick int i_unit; /* pseudo device unit */ 28*41488Smckusick daddr_t i_boff; /* block offset on device */ 29*41488Smckusick daddr_t i_cyloff; /* cylinder offset on device */ 30*41488Smckusick off_t i_offset; /* seek offset in file */ 31*41488Smckusick daddr_t i_bn; /* 1st block # of next read */ 32*41488Smckusick char *i_ma; /* memory address of i/o buffer */ 33*41488Smckusick int i_cc; /* character count of transfer */ 34*41488Smckusick int i_error; /* error # return */ 35*41488Smckusick int i_errcnt; /* error count for driver retries */ 36*41488Smckusick int i_errblk; /* block # in error for error reporting */ 37*41488Smckusick char i_buf[MAXBSIZE];/* i/o buffer */ 38*41488Smckusick union { 39*41488Smckusick struct fs ui_fs; /* file system super block info */ 40*41488Smckusick char dummy[SBSIZE]; 41*41488Smckusick } i_un; 42*41488Smckusick }; 43*41488Smckusick #define i_fs i_un.ui_fs 44*41488Smckusick #define NULL 0 45*41488Smckusick 46*41488Smckusick #define F_READ 0x1 /* file opened for reading */ 47*41488Smckusick #define F_WRITE 0x2 /* file opened for writing */ 48*41488Smckusick #define F_ALLOC 0x4 /* buffer allocated */ 49*41488Smckusick #define F_FILE 0x8 /* file instead of device */ 50*41488Smckusick #define F_NBSF 0x10 /* no bad sector forwarding */ 51*41488Smckusick #define F_SSI 0x40 /* set skip sector inhibit */ 52*41488Smckusick /* io types */ 53*41488Smckusick #define F_RDDATA 0x0100 /* read data */ 54*41488Smckusick #define F_WRDATA 0x0200 /* write data */ 55*41488Smckusick #define F_HDR 0x0400 /* include header on next i/o */ 56*41488Smckusick #define F_CHECK 0x0800 /* perform check of data read/write */ 57*41488Smckusick #define F_HCHECK 0x1000 /* perform check of header and data */ 58*41488Smckusick 59*41488Smckusick #define F_TYPEMASK 0xff00 60*41488Smckusick 61*41488Smckusick /* 62*41488Smckusick * Device switch. 63*41488Smckusick */ 64*41488Smckusick struct devsw { 65*41488Smckusick char *dv_name; 66*41488Smckusick int (*dv_strategy)(); 67*41488Smckusick int (*dv_open)(); 68*41488Smckusick int (*dv_close)(); 69*41488Smckusick int (*dv_ioctl)(); 70*41488Smckusick }; 71*41488Smckusick 72*41488Smckusick struct devsw devsw[]; 73*41488Smckusick 74*41488Smckusick /* 75*41488Smckusick * Drive description table. 76*41488Smckusick * Returned from SAIODEVDATA call. 77*41488Smckusick */ 78*41488Smckusick struct st { 79*41488Smckusick short nsect; /* # sectors/track */ 80*41488Smckusick short ntrak; /* # tracks/surfaces/heads */ 81*41488Smckusick short nspc; /* # sectors/cylinder */ 82*41488Smckusick short ncyl; /* # cylinders */ 83*41488Smckusick short *off; /* partition offset table (cylinders) */ 84*41488Smckusick }; 85*41488Smckusick 86*41488Smckusick /* 87*41488Smckusick * Request codes. Must be the same a F_XXX above 88*41488Smckusick */ 89*41488Smckusick #define READ 1 90*41488Smckusick #define WRITE 2 91*41488Smckusick 92*41488Smckusick #define NBUFS 4 93*41488Smckusick 94*41488Smckusick char b[NBUFS][MAXBSIZE]; 95*41488Smckusick daddr_t blknos[NBUFS]; 96*41488Smckusick 97*41488Smckusick #define NFILES 4 98*41488Smckusick struct iob iob[NFILES]; 99*41488Smckusick 100*41488Smckusick extern int errno; /* just like unix */ 101*41488Smckusick 102*41488Smckusick /* error codes */ 103*41488Smckusick #define EBADF 1 /* bad file descriptor */ 104*41488Smckusick #define EOFFSET 2 /* relative seek not supported */ 105*41488Smckusick #define EDEV 3 /* improper device specification on open */ 106*41488Smckusick #define ENXIO 4 /* unknown device specified */ 107*41488Smckusick #define EUNIT 5 /* improper unit specification */ 108*41488Smckusick #define ESRCH 6 /* directory search for file failed */ 109*41488Smckusick #define EIO 7 /* generic error */ 110*41488Smckusick #define ECMD 10 /* undefined driver command */ 111*41488Smckusick #define EBSE 11 /* bad sector error */ 112*41488Smckusick #define EWCK 12 /* write check error */ 113*41488Smckusick #define EECC 13 /* uncorrectable ecc error */ 114*41488Smckusick #define EHER 14 /* hard error */ 115*41488Smckusick 116*41488Smckusick /* ioctl's -- for disks just now */ 117*41488Smckusick #define SAIOHDR (('d'<<8)|1) /* next i/o includes header */ 118*41488Smckusick #define SAIOCHECK (('d'<<8)|2) /* next i/o checks data */ 119*41488Smckusick #define SAIOHCHECK (('d'<<8)|3) /* next i/o checks header & data */ 120*41488Smckusick #define SAIONOBAD (('d'<<8)|4) /* inhibit bad sector forwarding */ 121*41488Smckusick #define SAIODOBAD (('d'<<8)|5) /* enable bad sector forwarding */ 122*41488Smckusick #define SAIOECCLIM (('d'<<8)|6) /* set limit to ecc correction, bits */ 123*41488Smckusick #define SAIORETRIES (('d'<<8)|7) /* set retry count for unit */ 124*41488Smckusick #define SAIODEVDATA (('d'<<8)|8) /* get device data */ 125*41488Smckusick #define SAIOSSI (('d'<<8)|9) /* set skip sector inhibit */ 126*41488Smckusick #define SAIONOSSI (('d'<<8)|10) /* inhibit skip sector handling */ 127*41488Smckusick #define SAIOSSDEV (('d'<<8)|11) /* is device skip sector type? */ 128*41488Smckusick #define SAIODEBUG (('d'<<8)|12) /* enable/disable debugging */ 129*41488Smckusick #define SAIOGBADINFO (('d'<<8)|13) /* get bad-sector table */ 130