1 1.18 is /* $NetBSD: scsipi_all.h,v 1.18 2001/05/18 21:11:43 is 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.17 bouyer #define MODE_SENSE 0x1a 75 1.17 bouyer struct scsipi_mode_sense { 76 1.17 bouyer u_int8_t opcode; 77 1.17 bouyer u_int8_t byte2; 78 1.17 bouyer #define SMS_DBD 0x08 /* disable block descriptors */ 79 1.17 bouyer u_int8_t page; 80 1.17 bouyer #define SMS_PAGE_CODE 0x3F 81 1.17 bouyer #define SMS_PAGE_CTRL 0xC0 82 1.17 bouyer #define SMS_PAGE_CTRL_CURRENT 0x00 83 1.17 bouyer #define SMS_PAGE_CTRL_CHANGEABLE 0x40 84 1.17 bouyer #define SMS_PAGE_CTRL_DEFAULT 0x80 85 1.17 bouyer #define SMS_PAGE_CTRL_SAVED 0xC0 86 1.17 bouyer union { 87 1.17 bouyer struct { 88 1.17 bouyer u_int8_t unused; 89 1.17 bouyer u_int8_t length; 90 1.18 is } scsi __attribute__((packed)); 91 1.17 bouyer struct { 92 1.17 bouyer u_int8_t length[2]; 93 1.18 is } atapi __attribute__((packed)); 94 1.17 bouyer } u_len; 95 1.17 bouyer u_int8_t control; 96 1.18 is } __attribute__((packed)); 97 1.17 bouyer 98 1.17 bouyer #define MODE_SENSE_BIG 0x5A 99 1.17 bouyer struct scsipi_mode_sense_big { 100 1.17 bouyer u_int8_t opcode; 101 1.17 bouyer u_int8_t byte2; /* same bits as small version */ 102 1.17 bouyer u_int8_t page; /* same bits as small version */ 103 1.17 bouyer u_int8_t unused[4]; 104 1.17 bouyer u_int8_t length[2]; 105 1.17 bouyer u_int8_t control; 106 1.18 is } __attribute__((packed)); 107 1.17 bouyer 108 1.17 bouyer #define MODE_SELECT 0x15 109 1.17 bouyer struct scsipi_mode_select { 110 1.17 bouyer u_int8_t opcode; 111 1.17 bouyer u_int8_t byte2; 112 1.17 bouyer #define SMS_SP 0x01 /* save page */ 113 1.17 bouyer #define SMS_PF 0x10 114 1.17 bouyer u_int8_t unused[2]; 115 1.17 bouyer union { 116 1.17 bouyer struct { 117 1.17 bouyer u_int8_t unused; 118 1.17 bouyer u_int8_t length; 119 1.18 is } scsi __attribute__((packed)); 120 1.17 bouyer struct { 121 1.17 bouyer u_int8_t length[2]; 122 1.18 is } atapi __attribute__((packed)); 123 1.17 bouyer } u_len; 124 1.17 bouyer u_int8_t control; 125 1.18 is } __attribute__((packed)); 126 1.17 bouyer 127 1.17 bouyer #define MODE_SELECT_BIG 0x55 128 1.17 bouyer struct scsipi_mode_select_big { 129 1.17 bouyer u_int8_t opcode; 130 1.17 bouyer u_int8_t byte2; /* same bits as small version */ 131 1.17 bouyer u_int8_t unused[5]; 132 1.17 bouyer u_int8_t length[2]; 133 1.17 bouyer u_int8_t control; 134 1.18 is } __attribute__((packed)); 135 1.17 bouyer 136 1.3 enami #define INQUIRY 0x12 137 1.2 bouyer struct scsipi_inquiry { 138 1.2 bouyer u_int8_t opcode; 139 1.2 bouyer u_int8_t byte2; 140 1.2 bouyer u_int8_t unused[2]; 141 1.2 bouyer u_int8_t length; 142 1.2 bouyer u_int8_t control; 143 1.18 is } __attribute__((packed)); 144 1.2 bouyer 145 1.3 enami #define PREVENT_ALLOW 0x1e 146 1.2 bouyer struct scsipi_prevent { 147 1.2 bouyer u_int8_t opcode; 148 1.2 bouyer u_int8_t byte2; 149 1.2 bouyer u_int8_t unused[2]; 150 1.2 bouyer u_int8_t how; 151 1.2 bouyer u_int8_t control; 152 1.18 is } __attribute__((packed)); 153 1.2 bouyer #define PR_PREVENT 0x01 154 1.3 enami #define PR_ALLOW 0x00 155 1.2 bouyer 156 1.2 bouyer /* 157 1.2 bouyer * inquiry and sense data format 158 1.2 bouyer */ 159 1.2 bouyer 160 1.2 bouyer struct scsipi_sense_data { 161 1.3 enami /* 1*/ u_int8_t error_code; 162 1.3 enami #define SSD_ERRCODE 0x7F 163 1.3 enami #define SSD_ERRCODE_VALID 0x80 164 1.3 enami /* 2*/ u_int8_t segment; 165 1.3 enami /* 3*/ u_int8_t flags; 166 1.3 enami #define SSD_KEY 0x0F 167 1.3 enami #define SSD_ILI 0x20 168 1.3 enami #define SSD_EOM 0x40 169 1.3 enami #define SSD_FILEMARK 0x80 170 1.3 enami /* 7*/ u_int8_t info[4]; 171 1.3 enami /* 8*/ u_int8_t extra_len; 172 1.3 enami /*12*/ u_int8_t cmd_spec_info[4]; 173 1.3 enami /*13*/ u_int8_t add_sense_code; 174 1.3 enami /*14*/ u_int8_t add_sense_code_qual; 175 1.3 enami /*15*/ u_int8_t fru; 176 1.3 enami /*16*/ u_int8_t sense_key_spec_1; 177 1.3 enami #define SSD_SCS_VALID 0x80 178 1.3 enami /*17*/ u_int8_t sense_key_spec_2; 179 1.3 enami /*18*/ u_int8_t sense_key_spec_3; 180 1.3 enami /*32*/ u_int8_t extra_bytes[14]; 181 1.18 is } __attribute__((packed)); 182 1.9 mjacob 183 1.9 mjacob #define SKEY_NO_SENSE 0x00 184 1.10 mjacob #define SKEY_RECOVERED_ERROR 0x01 185 1.9 mjacob #define SKEY_NOT_READY 0x02 186 1.9 mjacob #define SKEY_MEDIUM_ERROR 0x03 187 1.9 mjacob #define SKEY_HARDWARE_ERROR 0x04 188 1.9 mjacob #define SKEY_ILLEGAL_REQUEST 0x05 189 1.9 mjacob #define SKEY_UNIT_ATTENTION 0x06 190 1.9 mjacob #define SKEY_WRITE_PROTECT 0x07 191 1.9 mjacob #define SKEY_BLANK_CHECK 0x08 192 1.9 mjacob #define SKEY_VENDOR_UNIQUE 0x09 193 1.9 mjacob #define SKEY_COPY_ABORTED 0x0A 194 1.9 mjacob #define SKEY_ABORTED_COMMAND 0x0B 195 1.9 mjacob #define SKEY_EQUAL 0x0C 196 1.9 mjacob #define SKEY_VOLUME_OVERFLOW 0x0D 197 1.9 mjacob #define SKEY_MISCOMPARE 0x0E 198 1.9 mjacob #define SKEY_RESERVED 0x0F 199 1.9 mjacob 200 1.4 mjacob /* 201 1.4 mjacob * Sense bytes described by the extra_len tag start at cmd_spec_info, 202 1.4 mjacob * and can only continue up to the end of the structure we've defined 203 1.4 mjacob * (which is too short for some cases). 204 1.4 mjacob */ 205 1.4 mjacob #define ADD_BYTES_LIM(sp) \ 206 1.12 dbj ((((int)(sp)->extra_len) < (int) sizeof(struct scsipi_sense_data) - 8)? \ 207 1.12 dbj ((sp)->extra_len) : (sizeof (struct scsipi_sense_data) - 8)) 208 1.4 mjacob 209 1.2 bouyer 210 1.2 bouyer struct scsipi_sense_data_unextended { 211 1.5 thorpej /* 1*/ u_int8_t error_code; 212 1.3 enami /* 4*/ u_int8_t block[3]; 213 1.18 is } __attribute__((packed)); 214 1.3 enami 215 1.5 thorpej #define T_REMOV 1 /* device is removable */ 216 1.5 thorpej #define T_FIXED 0 /* device is not removable */ 217 1.2 bouyer 218 1.2 bouyer /* 219 1.13 dante * According to SPC-2r16, in order to know if a U3W device support PPR, 220 1.16 bouyer * Inquiry Data structure should be at least 57 Bytes 221 1.2 bouyer */ 222 1.2 bouyer 223 1.2 bouyer struct scsipi_inquiry_data { 224 1.13 dante /* 1*/ u_int8_t device; 225 1.16 bouyer #define SID_TYPE 0x1f /* device type mask */ 226 1.16 bouyer #define SID_QUAL 0xe0 /* device qualifier mask */ 227 1.16 bouyer #define SID_QUAL_LU_PRESENT 0x00 /* logical unit present */ 228 1.16 bouyer #define SID_QUAL_LU_NOTPRESENT 0x20 /* logical unit not present */ 229 1.16 bouyer #define SID_QUAL_reserved 0x40 230 1.16 bouyer #define SID_QUAL_LU_NOT_SUPP 0x60 /* logical unit not supported */ 231 1.16 bouyer 232 1.16 bouyer #define T_DIRECT 0x00 /* direct access device */ 233 1.16 bouyer #define T_SEQUENTIAL 0x01 /* sequential access device */ 234 1.16 bouyer #define T_PRINTER 0x02 /* printer device */ 235 1.16 bouyer #define T_PROCESSOR 0x03 /* processor device */ 236 1.16 bouyer #define T_WORM 0x04 /* write once, read many device */ 237 1.16 bouyer #define T_CDROM 0x05 /* cd-rom device */ 238 1.16 bouyer #define T_SCANNER 0x06 /* scanner device */ 239 1.16 bouyer #define T_OPTICAL 0x07 /* optical memory device */ 240 1.16 bouyer #define T_CHANGER 0x08 /* medium changer device */ 241 1.16 bouyer #define T_COMM 0x09 /* communication device */ 242 1.16 bouyer #define T_IT8_1 0x0a /* Defined by ASC IT8... */ 243 1.16 bouyer #define T_IT8_2 0x0b /* ...(Graphic arts pre-press devices) */ 244 1.16 bouyer #define T_STORARRAY 0x0c /* storage array device */ 245 1.16 bouyer #define T_ENCLOSURE 0x0d /* enclosure services device */ 246 1.16 bouyer #define T_SIMPLE_DIRECT 0x0E /* Simplified direct-access device */ 247 1.16 bouyer #define T_OPTIC_CARD_RW 0x0F /* Optical card reader/writer device */ 248 1.16 bouyer #define T_OBJECT_STORED 0x11 /* Object-based Storage Device */ 249 1.16 bouyer #define T_NODEVICE 0x1f 250 1.16 bouyer 251 1.16 bouyer u_int8_t dev_qual2; 252 1.16 bouyer #define SID_QUAL2 0x7F 253 1.16 bouyer #define SID_REMOVABLE 0x80 254 1.16 bouyer 255 1.13 dante /* 3*/ u_int8_t version; 256 1.3 enami #define SID_ANSII 0x07 257 1.3 enami #define SID_ECMA 0x38 258 1.3 enami #define SID_ISO 0xC0 259 1.16 bouyer 260 1.13 dante /* 4*/ u_int8_t response_format; 261 1.13 dante #define SID_RespDataFmt 0x0F 262 1.16 bouyer #define SID_FORMAT_SCSI1 0x00 /* SCSI-1 format */ 263 1.16 bouyer #define SID_FORMAT_CCS 0x01 /* SCSI CCS format */ 264 1.16 bouyer #define SID_FORMAT_ISO 0x02 /* ISO format */ 265 1.16 bouyer 266 1.13 dante /* 5*/ u_int8_t additional_length; /* n-4 */ 267 1.13 dante /* 6*/ u_int8_t flags1; 268 1.13 dante #define SID_SCC 0x80 269 1.13 dante /* 7*/ u_int8_t flags2; 270 1.13 dante #define SID_Addr16 0x01 271 1.16 bouyer #define SID_MChngr 0x08 272 1.13 dante #define SID_MultiPort 0x10 273 1.13 dante #define SID_EncServ 0x40 274 1.13 dante #define SID_BasQue 0x80 275 1.13 dante /* 8*/ u_int8_t flags3; 276 1.2 bouyer #define SID_SftRe 0x01 277 1.2 bouyer #define SID_CmdQue 0x02 278 1.2 bouyer #define SID_Linked 0x08 279 1.2 bouyer #define SID_Sync 0x10 280 1.2 bouyer #define SID_WBus16 0x20 281 1.2 bouyer #define SID_WBus32 0x40 282 1.2 bouyer #define SID_RelAdr 0x80 283 1.16 bouyer /* 9*/ char vendor[8]; 284 1.16 bouyer /*17*/ char product[16]; 285 1.16 bouyer /*33*/ char revision[4]; 286 1.13 dante /*37*/ u_int8_t vendor_specific[20]; 287 1.13 dante /*57*/ u_int8_t flags4; 288 1.16 bouyer #define SID_IUS 0x01 289 1.16 bouyer #define SID_QAS 0x02 290 1.16 bouyer #define SID_Clocking 0x0C 291 1.16 bouyer #define SID_CLOCKING_ST_ONLY 0x00 292 1.16 bouyer #define SID_CLOCKING_DT_ONLY 0x04 293 1.16 bouyer #define SID_CLOCKING_SD_DT 0x0C 294 1.13 dante /*58*/ u_int8_t reserved; 295 1.16 bouyer /*59*/ char version_descriptor[8][2]; 296 1.18 is } __attribute__((packed)); /* 74 Bytes */ 297 1.17 bouyer 298 1.17 bouyer /* Data structures for mode select/mode sense */ 299 1.17 bouyer struct scsipi_mode_header { 300 1.17 bouyer u_int8_t data_length; /* Sense data length */ 301 1.17 bouyer u_int8_t medium_type; 302 1.17 bouyer u_int8_t dev_spec; 303 1.17 bouyer u_int8_t blk_desc_len; /* unused on ATAPI */ 304 1.18 is } __attribute__((packed)); 305 1.17 bouyer 306 1.17 bouyer struct scsipi_mode_header_big { 307 1.17 bouyer u_int8_t data_length[2]; /* Sense data length */ 308 1.17 bouyer u_int8_t medium_type; 309 1.17 bouyer u_int8_t dev_spec; 310 1.17 bouyer u_int8_t unused[2]; /* unused on ATAPI */ 311 1.17 bouyer u_int8_t blk_desc_len[2]; /* unused on ATAPI */ 312 1.18 is } __attribute__((packed)); 313 1.17 bouyer 314 1.11 thorpej 315 1.11 thorpej #endif /* _DEV_SCSIPI_SCSIPI_ALL_H_ */ 316