Home | History | Annotate | Line # | Download | only in scsipi
scsipi_all.h revision 1.13
      1  1.13    dante /*	$NetBSD: scsipi_all.h,v 1.13 2000/05/14 18:20:11 dante Exp $	*/
      2   1.2   bouyer 
      3   1.2   bouyer /*
      4   1.2   bouyer  * SCSI and SCSI-like general interface description
      5   1.2   bouyer  */
      6   1.2   bouyer 
      7   1.2   bouyer /*
      8   1.2   bouyer  * Largely written by Julian Elischer (julian (at) tfs.com)
      9   1.2   bouyer  * for TRW Financial Systems.
     10   1.2   bouyer  *
     11   1.2   bouyer  * TRW Financial Systems, in accordance with their agreement with Carnegie
     12   1.2   bouyer  * Mellon University, makes this software available to CMU to distribute
     13   1.3    enami  * or use in any manner that they see fit as long as this message is kept with
     14   1.2   bouyer  * the software. For this reason TFS also grants any other persons or
     15   1.2   bouyer  * organisations permission to use or modify this software.
     16   1.2   bouyer  *
     17   1.2   bouyer  * TFS supplies this software to be publicly redistributed
     18   1.2   bouyer  * on the understanding that TFS is not responsible for the correct
     19   1.2   bouyer  * functioning of this software in any circumstances.
     20   1.2   bouyer  *
     21   1.2   bouyer  * Ported to run under 386BSD by Julian Elischer (julian (at) tfs.com) Sept 1992
     22   1.2   bouyer  */
     23   1.2   bouyer 
     24  1.11  thorpej #ifndef _DEV_SCSIPI_SCSIPI_ALL_H_
     25  1.11  thorpej #define	_DEV_SCSIPI_SCSIPI_ALL_H_
     26  1.11  thorpej 
     27   1.2   bouyer /*
     28   1.2   bouyer  * SCSI-like command format and opcode
     29   1.2   bouyer  */
     30   1.2   bouyer 
     31   1.8   mjacob /*
     32   1.8   mjacob  * Some basic, common SCSI command group definitions.
     33   1.8   mjacob  */
     34   1.8   mjacob 
     35   1.8   mjacob #define	CDB_GROUPID(cmd)        ((cmd >> 5) & 0x7)
     36   1.8   mjacob #define	CDB_GROUPID_0	0
     37   1.8   mjacob #define	CDB_GROUPID_1	1
     38   1.8   mjacob #define	CDB_GROUPID_2	2
     39   1.8   mjacob #define	CDB_GROUPID_3	3
     40   1.8   mjacob #define	CDB_GROUPID_4	4
     41   1.8   mjacob #define	CDB_GROUPID_5	5
     42   1.8   mjacob #define	CDB_GROUPID_6	6
     43   1.8   mjacob #define	CDB_GROUPID_7	7
     44   1.8   mjacob 
     45   1.8   mjacob #define	CDB_GROUP0	6       /*  6-byte cdb's */
     46   1.8   mjacob #define	CDB_GROUP1	10      /* 10-byte cdb's */
     47   1.8   mjacob #define	CDB_GROUP2	10      /* 10-byte cdb's */
     48   1.8   mjacob #define	CDB_GROUP3	0       /* reserved */
     49   1.8   mjacob #define	CDB_GROUP4	16      /* 16-byte cdb's */
     50   1.8   mjacob #define	CDB_GROUP5	12      /* 12-byte cdb's */
     51   1.8   mjacob #define	CDB_GROUP6	0       /* vendor specific */
     52   1.8   mjacob #define	CDB_GROUP7	0       /* vendor specific */
     53   1.8   mjacob 
     54   1.8   mjacob /*
     55   1.8   mjacob  * Some basic, common SCSI commands
     56   1.8   mjacob  */
     57   1.2   bouyer #define	TEST_UNIT_READY		0x00
     58   1.2   bouyer struct scsipi_test_unit_ready {
     59   1.2   bouyer 	u_int8_t opcode;
     60   1.2   bouyer 	u_int8_t byte2;
     61   1.2   bouyer 	u_int8_t unused[3];
     62   1.2   bouyer 	u_int8_t control;
     63   1.2   bouyer };
     64   1.2   bouyer 
     65   1.3    enami #define	REQUEST_SENSE		0x03
     66   1.2   bouyer struct scsipi_sense {
     67   1.2   bouyer 	u_int8_t opcode;
     68   1.2   bouyer 	u_int8_t byte2;
     69   1.2   bouyer 	u_int8_t unused[2];
     70   1.2   bouyer 	u_int8_t length;
     71   1.2   bouyer 	u_int8_t control;
     72   1.2   bouyer };
     73   1.2   bouyer 
     74   1.3    enami #define	INQUIRY			0x12
     75   1.2   bouyer struct scsipi_inquiry {
     76   1.2   bouyer 	u_int8_t opcode;
     77   1.2   bouyer 	u_int8_t byte2;
     78   1.2   bouyer 	u_int8_t unused[2];
     79   1.2   bouyer 	u_int8_t length;
     80   1.2   bouyer 	u_int8_t control;
     81   1.2   bouyer };
     82   1.2   bouyer 
     83   1.3    enami #define	PREVENT_ALLOW		0x1e
     84   1.2   bouyer struct scsipi_prevent {
     85   1.2   bouyer 	u_int8_t opcode;
     86   1.2   bouyer 	u_int8_t byte2;
     87   1.2   bouyer 	u_int8_t unused[2];
     88   1.2   bouyer 	u_int8_t how;
     89   1.2   bouyer 	u_int8_t control;
     90   1.2   bouyer };
     91   1.2   bouyer #define	PR_PREVENT 0x01
     92   1.3    enami #define	PR_ALLOW   0x00
     93   1.2   bouyer 
     94   1.2   bouyer /*
     95   1.2   bouyer  * inquiry and sense data format
     96   1.2   bouyer  */
     97   1.2   bouyer 
     98   1.2   bouyer struct scsipi_sense_data {
     99   1.3    enami /* 1*/	u_int8_t error_code;
    100   1.3    enami #define	SSD_ERRCODE	0x7F
    101   1.3    enami #define	SSD_ERRCODE_VALID 0x80
    102   1.3    enami /* 2*/	u_int8_t segment;
    103   1.3    enami /* 3*/	u_int8_t flags;
    104   1.3    enami #define	SSD_KEY		0x0F
    105   1.3    enami #define	SSD_ILI		0x20
    106   1.3    enami #define	SSD_EOM		0x40
    107   1.3    enami #define	SSD_FILEMARK	0x80
    108   1.3    enami /* 7*/	u_int8_t info[4];
    109   1.3    enami /* 8*/	u_int8_t extra_len;
    110   1.3    enami /*12*/	u_int8_t cmd_spec_info[4];
    111   1.3    enami /*13*/	u_int8_t add_sense_code;
    112   1.3    enami /*14*/	u_int8_t add_sense_code_qual;
    113   1.3    enami /*15*/	u_int8_t fru;
    114   1.3    enami /*16*/	u_int8_t sense_key_spec_1;
    115   1.3    enami #define	SSD_SCS_VALID	0x80
    116   1.3    enami /*17*/	u_int8_t sense_key_spec_2;
    117   1.3    enami /*18*/	u_int8_t sense_key_spec_3;
    118   1.3    enami /*32*/	u_int8_t extra_bytes[14];
    119   1.2   bouyer };
    120   1.9   mjacob 
    121   1.9   mjacob #define	SKEY_NO_SENSE		0x00
    122  1.10   mjacob #define	SKEY_RECOVERED_ERROR	0x01
    123   1.9   mjacob #define	SKEY_NOT_READY		0x02
    124   1.9   mjacob #define	SKEY_MEDIUM_ERROR	0x03
    125   1.9   mjacob #define	SKEY_HARDWARE_ERROR	0x04
    126   1.9   mjacob #define	SKEY_ILLEGAL_REQUEST	0x05
    127   1.9   mjacob #define	SKEY_UNIT_ATTENTION	0x06
    128   1.9   mjacob #define	SKEY_WRITE_PROTECT	0x07
    129   1.9   mjacob #define	SKEY_BLANK_CHECK	0x08
    130   1.9   mjacob #define	SKEY_VENDOR_UNIQUE	0x09
    131   1.9   mjacob #define	SKEY_COPY_ABORTED	0x0A
    132   1.9   mjacob #define	SKEY_ABORTED_COMMAND	0x0B
    133   1.9   mjacob #define	SKEY_EQUAL		0x0C
    134   1.9   mjacob #define	SKEY_VOLUME_OVERFLOW	0x0D
    135   1.9   mjacob #define	SKEY_MISCOMPARE		0x0E
    136   1.9   mjacob #define	SKEY_RESERVED		0x0F
    137   1.9   mjacob 
    138   1.4   mjacob /*
    139   1.4   mjacob  * Sense bytes described by the extra_len tag start at cmd_spec_info,
    140   1.4   mjacob  * and can only continue up to the end of the structure we've defined
    141   1.4   mjacob  * (which is too short for some cases).
    142   1.4   mjacob  */
    143   1.4   mjacob #define	ADD_BYTES_LIM(sp)	\
    144  1.12      dbj 	((((int)(sp)->extra_len) < (int) sizeof(struct scsipi_sense_data) - 8)? \
    145  1.12      dbj 	((sp)->extra_len) : (sizeof (struct scsipi_sense_data) - 8))
    146   1.4   mjacob 
    147   1.2   bouyer 
    148   1.2   bouyer struct scsipi_sense_data_unextended {
    149   1.5  thorpej /* 1*/	u_int8_t error_code;
    150   1.3    enami /* 4*/	u_int8_t block[3];
    151   1.5  thorpej };
    152   1.3    enami 
    153   1.5  thorpej #define	T_DIRECT	0x00	/* direct access device */
    154   1.5  thorpej #define	T_SEQUENTIAL	0x01	/* sequential access device */
    155   1.5  thorpej #define	T_PRINTER	0x02	/* printer device */
    156   1.5  thorpej #define	T_PROCESSOR	0x03	/* processor device */
    157   1.5  thorpej #define	T_WORM		0x04	/* write once, read many device */
    158   1.5  thorpej #define	T_CDROM		0x05	/* cd-rom device */
    159   1.5  thorpej #define	T_SCANNER 	0x06	/* scanner device */
    160   1.5  thorpej #define	T_OPTICAL 	0x07	/* optical memory device */
    161   1.5  thorpej #define	T_CHANGER	0x08	/* medium changer device */
    162   1.5  thorpej #define	T_COMM		0x09	/* communication device */
    163   1.5  thorpej #define	T_IT8_1		0x0a	/* ??? */
    164   1.5  thorpej #define	T_IT8_2		0x0b	/* ??? */
    165   1.5  thorpej #define	T_STORARRAY	0x0c	/* storage array device */
    166   1.5  thorpej #define	T_ENCLOSURE	0x0d	/* enclosure services device */
    167   1.3    enami #define	T_NODEVICE	0x1F
    168   1.2   bouyer 
    169   1.5  thorpej #define	T_REMOV		1	/* device is removable */
    170   1.5  thorpej #define	T_FIXED		0	/* device is not removable */
    171   1.2   bouyer 
    172   1.2   bouyer /*
    173  1.13    dante  * According to SPC-2r16, in order to know if a U3W device support PPR,
    174  1.13    dante  * Inquiry Data structure should be at least 58 Bytes.
    175   1.2   bouyer  */
    176   1.2   bouyer 
    177   1.2   bouyer struct scsipi_inquiry_data {
    178  1.13    dante /* 1*/	u_int8_t device;
    179   1.2   bouyer #define	SID_TYPE	0x1F
    180   1.2   bouyer #define	SID_QUAL	0xE0
    181   1.2   bouyer #define	SID_QUAL_LU_OK	0x00
    182   1.2   bouyer #define	SID_QUAL_LU_OFFLINE	0x20
    183   1.2   bouyer #define	SID_QUAL_RSVD	0x40
    184   1.2   bouyer #define	SID_QUAL_BAD_LU	0x60
    185  1.13    dante /* 2*/	u_int8_t dev_qual2;
    186   1.2   bouyer #define	SID_QUAL2	0x7F
    187   1.2   bouyer #define	SID_REMOVABLE	0x80
    188  1.13    dante /* 3*/	u_int8_t version;
    189   1.3    enami #define	SID_ANSII	0x07
    190   1.3    enami #define	SID_ECMA	0x38
    191   1.3    enami #define	SID_ISO		0xC0
    192  1.13    dante /* 4*/	u_int8_t response_format;
    193  1.13    dante #define	SID_RespDataFmt	0x0F
    194  1.13    dante /* 5*/	u_int8_t additional_length;	/* n-4 */
    195  1.13    dante /* 6*/	u_int8_t flags1;
    196  1.13    dante #define	SID_SCC		0x80
    197  1.13    dante /* 7*/	u_int8_t flags2;
    198  1.13    dante #define	SID_Addr16	0x01
    199  1.13    dante #define	SID_MChngr	0x08
    200  1.13    dante #define	SID_MultiPort	0x10
    201  1.13    dante #define	SID_EncServ	0x40
    202  1.13    dante #define	SID_BasQue	0x80
    203  1.13    dante /* 8*/	u_int8_t flags3;
    204   1.2   bouyer #define	SID_SftRe	0x01
    205   1.2   bouyer #define	SID_CmdQue	0x02
    206   1.2   bouyer #define	SID_Linked	0x08
    207   1.2   bouyer #define	SID_Sync	0x10
    208   1.2   bouyer #define	SID_WBus16	0x20
    209   1.2   bouyer #define	SID_WBus32	0x40
    210   1.2   bouyer #define	SID_RelAdr	0x80
    211  1.13    dante /* 9*/	char	vendor[8];
    212  1.13    dante /*17*/	char	product[16];
    213  1.13    dante /*33*/	char	revision[4];
    214  1.13    dante /*37*/	u_int8_t vendor_specific[20];
    215  1.13    dante /*57*/	u_int8_t flags4;
    216  1.13    dante #define	SID_IUS		0x01
    217  1.13    dante #define	SID_QAS		0x02
    218  1.13    dante #define	SID_Cloacking	0x0C
    219  1.13    dante #define  SIDV_CLOCKING_ST_ONLY	0x00
    220  1.13    dante #define  SIDV_CLOCKING_DT_ONLY	0x04
    221  1.13    dante #define  SIDV_CLOCKING_SD_DT	0x0C
    222  1.13    dante /*58*/	u_int8_t reserved;
    223  1.13    dante /*59*/	char	version_descriptor[8][2];
    224  1.13    dante }; /* 74 Bytes */
    225  1.11  thorpej 
    226  1.11  thorpej #endif /* _DEV_SCSIPI_SCSIPI_ALL_H_ */
    227