Home | History | Annotate | Line # | Download | only in scsipi
      1  1.35  jakllsch /*	$NetBSD: scsipi_all.h,v 1.35 2025/02/10 14:42:33 jakllsch 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.17    bouyer 
     58   1.3     enami #define	INQUIRY			0x12
     59   1.2    bouyer struct scsipi_inquiry {
     60  1.27   reinoud 	u_int8_t opcode;
     61  1.27   reinoud 	u_int8_t byte2;
     62  1.34   mlelstv #define SINQ_EVPD		0x01
     63  1.34   mlelstv 	u_int8_t pagecode;
     64  1.34   mlelstv 	u_int8_t length_hi;	/* upper byte of length */
     65  1.27   reinoud 	u_int8_t length;
     66  1.27   reinoud 	u_int8_t control;
     67  1.33     perry } __packed;
     68  1.22     soren 
     69  1.22     soren #define START_STOP		0x1b
     70  1.22     soren struct scsipi_start_stop {
     71  1.27   reinoud 	u_int8_t opcode;
     72  1.27   reinoud 	u_int8_t byte2;
     73  1.27   reinoud 	u_int8_t unused[2];
     74  1.27   reinoud 	u_int8_t how;
     75  1.22     soren #define SSS_STOP		0x00
     76  1.22     soren #define SSS_START		0x01
     77  1.22     soren #define SSS_LOEJ		0x02
     78  1.27   reinoud 	u_int8_t control;
     79  1.31    martin };
     80   1.2    bouyer 
     81   1.2    bouyer /*
     82  1.28   thorpej  * inquiry data format
     83   1.2    bouyer  */
     84   1.2    bouyer 
     85   1.5   thorpej #define	T_REMOV		1	/* device is removable */
     86   1.5   thorpej #define	T_FIXED		0	/* device is not removable */
     87   1.2    bouyer 
     88   1.2    bouyer /*
     89  1.13     dante  * According to SPC-2r16, in order to know if a U3W device support PPR,
     90  1.16    bouyer  * Inquiry Data structure should be at least 57 Bytes
     91   1.2    bouyer  */
     92   1.2    bouyer 
     93   1.2    bouyer struct scsipi_inquiry_data {
     94  1.27   reinoud /* 1*/	u_int8_t device;
     95  1.16    bouyer #define	SID_TYPE		0x1f	/* device type mask */
     96  1.16    bouyer #define	SID_QUAL		0xe0	/* device qualifier mask */
     97  1.16    bouyer #define	SID_QUAL_LU_PRESENT	0x00	/* logical unit present */
     98  1.16    bouyer #define	SID_QUAL_LU_NOTPRESENT	0x20	/* logical unit not present */
     99  1.16    bouyer #define	SID_QUAL_reserved	0x40
    100  1.16    bouyer #define	SID_QUAL_LU_NOT_SUPP	0x60	/* logical unit not supported */
    101  1.16    bouyer 
    102  1.16    bouyer #define	T_DIRECT		0x00	/* direct access device */
    103  1.16    bouyer #define	T_SEQUENTIAL		0x01	/* sequential access device */
    104  1.16    bouyer #define	T_PRINTER		0x02	/* printer device */
    105  1.16    bouyer #define	T_PROCESSOR		0x03	/* processor device */
    106  1.16    bouyer #define	T_WORM			0x04	/* write once, read many device */
    107  1.16    bouyer #define	T_CDROM			0x05	/* cd-rom device */
    108  1.16    bouyer #define	T_SCANNER 		0x06	/* scanner device */
    109  1.16    bouyer #define	T_OPTICAL 		0x07	/* optical memory device */
    110  1.16    bouyer #define	T_CHANGER		0x08	/* medium changer device */
    111  1.16    bouyer #define	T_COMM			0x09	/* communication device */
    112  1.16    bouyer #define	T_IT8_1			0x0a	/* Defined by ASC IT8... */
    113  1.16    bouyer #define	T_IT8_2			0x0b	/* ...(Graphic arts pre-press devices) */
    114  1.16    bouyer #define	T_STORARRAY		0x0c	/* storage array device */
    115  1.16    bouyer #define	T_ENCLOSURE		0x0d	/* enclosure services device */
    116  1.16    bouyer #define	T_SIMPLE_DIRECT		0x0E	/* Simplified direct-access device */
    117  1.16    bouyer #define	T_OPTIC_CARD_RW		0x0F	/* Optical card reader/writer device */
    118  1.16    bouyer #define	T_OBJECT_STORED		0x11	/* Object-based Storage Device */
    119  1.16    bouyer #define	T_NODEVICE		0x1f
    120  1.16    bouyer 
    121  1.27   reinoud 	u_int8_t dev_qual2;
    122  1.16    bouyer #define	SID_QUAL2		0x7F
    123  1.16    bouyer #define	SID_REMOVABLE		0x80
    124  1.16    bouyer 
    125  1.27   reinoud /* 3*/	u_int8_t version;
    126   1.3     enami #define	SID_ANSII	0x07
    127   1.3     enami #define	SID_ECMA	0x38
    128   1.3     enami #define	SID_ISO		0xC0
    129  1.16    bouyer 
    130  1.27   reinoud /* 4*/	u_int8_t response_format;
    131  1.13     dante #define	SID_RespDataFmt	0x0F
    132  1.16    bouyer #define	SID_FORMAT_SCSI1	0x00	/* SCSI-1 format */
    133  1.16    bouyer #define	SID_FORMAT_CCS		0x01	/* SCSI CCS format */
    134  1.16    bouyer #define	SID_FORMAT_ISO		0x02	/* ISO format */
    135  1.16    bouyer 
    136  1.27   reinoud /* 5*/	u_int8_t additional_length;	/* n-4 */
    137  1.27   reinoud /* 6*/	u_int8_t flags1;
    138  1.13     dante #define	SID_SCC		0x80
    139  1.27   reinoud /* 7*/	u_int8_t flags2;
    140  1.13     dante #define	SID_Addr16	0x01
    141  1.16    bouyer #define SID_MChngr	0x08
    142  1.13     dante #define	SID_MultiPort	0x10
    143  1.13     dante #define	SID_EncServ	0x40
    144  1.13     dante #define	SID_BasQue	0x80
    145  1.27   reinoud /* 8*/	u_int8_t flags3;
    146   1.2    bouyer #define	SID_SftRe	0x01
    147   1.2    bouyer #define	SID_CmdQue	0x02
    148   1.2    bouyer #define	SID_Linked	0x08
    149   1.2    bouyer #define	SID_Sync	0x10
    150   1.2    bouyer #define	SID_WBus16	0x20
    151   1.2    bouyer #define	SID_WBus32	0x40
    152   1.2    bouyer #define	SID_RelAdr	0x80
    153  1.16    bouyer /* 9*/	char    vendor[8];
    154  1.16    bouyer /*17*/	char    product[16];
    155  1.16    bouyer /*33*/	char    revision[4];
    156  1.25   mycroft #define	SCSIPI_INQUIRY_LENGTH_SCSI2	36
    157  1.27   reinoud /*37*/	u_int8_t vendor_specific[20];
    158  1.27   reinoud /*57*/	u_int8_t flags4;
    159  1.16    bouyer #define        SID_IUS         0x01
    160  1.16    bouyer #define        SID_QAS         0x02
    161  1.16    bouyer #define        SID_Clocking    0x0C
    162  1.16    bouyer #define	SID_CLOCKING_ST_ONLY  0x00
    163  1.16    bouyer #define	SID_CLOCKING_DT_ONLY  0x04
    164  1.16    bouyer #define	SID_CLOCKING_SD_DT    0x0C
    165  1.27   reinoud /*58*/	u_int8_t reserved;
    166  1.16    bouyer /*59*/	char    version_descriptor[8][2];
    167  1.25   mycroft #define	SCSIPI_INQUIRY_LENGTH_SCSI3	74
    168  1.33     perry } __packed; /* 74 Bytes */
    169  1.17    bouyer 
    170  1.34   mlelstv /* Vital product data when SINQ_EVPD is set */
    171  1.34   mlelstv 
    172  1.34   mlelstv struct scsipi_inquiry_evpd_header {
    173  1.34   mlelstv /* 1*/	u_int8_t device;
    174  1.34   mlelstv /* 2*/	u_int8_t pagecode;
    175  1.34   mlelstv /* 3*/	u_int8_t length[2];
    176  1.34   mlelstv };
    177  1.34   mlelstv 
    178  1.34   mlelstv #define SINQ_VPD_PAGES		0x00
    179  1.34   mlelstv #define SINQ_VPD_UNIT_SERIAL	0x80
    180  1.34   mlelstv #define SINQ_VPD_DEVICE_ID	0x83
    181  1.34   mlelstv #define SINQ_VPD_SOFTWARE_ID	0x84
    182  1.34   mlelstv #define SINQ_VPD_MN_ADDRESS	0x85
    183  1.34   mlelstv #define SINQ_VPD_INQUIRY	0x86
    184  1.34   mlelstv #define SINQ_VPD_MP_POLICY	0x87
    185  1.34   mlelstv #define SINQ_VPD_PORTS		0x88
    186  1.34   mlelstv #define SINQ_VPD_POWER_COND	0x8a
    187  1.34   mlelstv #define SINQ_VPD_CONSTITUENTS	0x8b
    188  1.34   mlelstv #define SINQ_VPD_CFA_PROFILE	0x8c
    189  1.34   mlelstv #define SINQ_VPD_CONSUMPTION	0x8d
    190  1.34   mlelstv #define SINQ_VPD_BLOCK_LIMITS	0xb0
    191  1.34   mlelstv #define SINQ_VPD_BLOCK_CHARS	0xb1
    192  1.34   mlelstv #define SINQ_VPD_LOGICAL_PROV	0xb2
    193  1.35  jakllsch #define SINQ_VPD_REFERRALS	0xb3
    194  1.34   mlelstv #define SINQ_VPD_SUPPORTED	0xb4
    195  1.34   mlelstv #define SINQ_VPD_BLOCK_CHARSX	0xb5
    196  1.34   mlelstv #define SINQ_VPD_BLOCK_ZONED	0xb6
    197  1.34   mlelstv #define SINQ_VPD_BLOCK_LIMITSX	0xb7
    198  1.34   mlelstv #define SINQ_VPD_FIRMWARE_NUM	0xc0
    199  1.34   mlelstv #define SINQ_VPD_JUMPERS	0xc2
    200  1.34   mlelstv #define SINQ_VPD_BEHAVIOUR	0xc3
    201  1.34   mlelstv 
    202  1.34   mlelstv #define SINQ_VPD_DATE_CODE	0xc1
    203  1.34   mlelstv struct scsipi_inquiry_evpd_date_code {
    204  1.34   mlelstv /* 1*/	u_int8_t etf_log_date[8]; /* MMDDYYYY */
    205  1.34   mlelstv /* 9*/	u_int8_t compile_date[8]; /* MMDDYYYY */
    206  1.34   mlelstv /*17*/	u_int8_t spindown_count[2];
    207  1.34   mlelstv /*19*/	u_int8_t spindown_time[6]; /* HHMMSS */
    208  1.34   mlelstv } __packed;
    209  1.34   mlelstv 
    210  1.34   mlelstv #define SINQ_VPD_SERIAL		0x80
    211  1.34   mlelstv struct scsipi_inquiry_evpd_serial {
    212  1.34   mlelstv /* 1*/	u_int8_t serial_number[251];
    213  1.34   mlelstv } __packed;
    214  1.34   mlelstv 
    215  1.34   mlelstv #define SINQ_VPD_DEVICE_ID	0x83
    216  1.34   mlelstv struct scsipi_inquiry_evpd_device_id {
    217  1.34   mlelstv /* 1*/	u_int8_t pc;
    218  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL			0xf0
    219  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL_FC		0x00
    220  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL_SSA		0x20
    221  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL_IEEE1394	0x30
    222  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL_RDMA		0x40
    223  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL_ISCSI		0x50
    224  1.34   mlelstv #define SINQ_DEVICE_ID_PROTOCOL_SAS		0x60
    225  1.34   mlelstv #define SINQ_DEVICE_ID_CODESET			0x0f
    226  1.34   mlelstv #define SINQ_DEVICE_ID_CODESET_BINARY		0x01
    227  1.34   mlelstv #define SINQ_DEVICE_ID_CODESET_ASCII		0x02
    228  1.34   mlelstv #define SINQ_DEVICE_ID_CODESET_UTF8		0x03
    229  1.34   mlelstv /* 2*/	u_int8_t flags;
    230  1.34   mlelstv #define SINQ_DEVICE_ID_PIV			0x80
    231  1.34   mlelstv #define SINQ_DEVICE_ID_ASSOCIATION		0x30
    232  1.34   mlelstv #define SINQ_DEVICE_ID_ASSOCIATION_DEVICE	0x00
    233  1.34   mlelstv #define SINQ_DEVICE_ID_ASSOCIATION_PORT		0x10
    234  1.34   mlelstv #define SINQ_DEVICE_ID_ASSOCIATION_TARGET	0x20
    235  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE			0x0f
    236  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_UNASSIGNED		0x00
    237  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_VENDOR		0x01
    238  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_EUI64		0x02
    239  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_FC			0x03
    240  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_PORTNUMBER1		0x04
    241  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_PORTNUMBER2		0x05
    242  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_PORTNUMBER3		0x06
    243  1.34   mlelstv #define SINQ_DEVICE_ID_TYPE_MD5			0x07
    244  1.34   mlelstv /* 3*/	u_int8_t reserved;
    245  1.34   mlelstv /* 4*/	u_int8_t designator_length;
    246  1.34   mlelstv /* 5*/	u_int8_t designator[1];
    247  1.34   mlelstv } __packed;
    248  1.34   mlelstv 
    249  1.11   thorpej #endif /* _DEV_SCSIPI_SCSIPI_ALL_H_ */
    250