1 1.30 christos /* $NetBSD: scsipi_all.h,v 1.31 2006/12/01 21:11:26 martin 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.27 reinoud u_int8_t unused[2]; 63 1.27 reinoud u_int8_t length; 64 1.27 reinoud u_int8_t control; 65 1.31 martin } __attribute__((packed)); 66 1.22 soren 67 1.22 soren #define START_STOP 0x1b 68 1.22 soren struct scsipi_start_stop { 69 1.27 reinoud u_int8_t opcode; 70 1.27 reinoud u_int8_t byte2; 71 1.27 reinoud u_int8_t unused[2]; 72 1.27 reinoud u_int8_t how; 73 1.22 soren #define SSS_STOP 0x00 74 1.22 soren #define SSS_START 0x01 75 1.22 soren #define SSS_LOEJ 0x02 76 1.27 reinoud u_int8_t control; 77 1.31 martin }; 78 1.2 bouyer 79 1.2 bouyer /* 80 1.28 thorpej * inquiry data format 81 1.2 bouyer */ 82 1.2 bouyer 83 1.5 thorpej #define T_REMOV 1 /* device is removable */ 84 1.5 thorpej #define T_FIXED 0 /* device is not removable */ 85 1.2 bouyer 86 1.2 bouyer /* 87 1.13 dante * According to SPC-2r16, in order to know if a U3W device support PPR, 88 1.16 bouyer * Inquiry Data structure should be at least 57 Bytes 89 1.2 bouyer */ 90 1.2 bouyer 91 1.2 bouyer struct scsipi_inquiry_data { 92 1.27 reinoud /* 1*/ u_int8_t device; 93 1.16 bouyer #define SID_TYPE 0x1f /* device type mask */ 94 1.16 bouyer #define SID_QUAL 0xe0 /* device qualifier mask */ 95 1.16 bouyer #define SID_QUAL_LU_PRESENT 0x00 /* logical unit present */ 96 1.16 bouyer #define SID_QUAL_LU_NOTPRESENT 0x20 /* logical unit not present */ 97 1.16 bouyer #define SID_QUAL_reserved 0x40 98 1.16 bouyer #define SID_QUAL_LU_NOT_SUPP 0x60 /* logical unit not supported */ 99 1.16 bouyer 100 1.16 bouyer #define T_DIRECT 0x00 /* direct access device */ 101 1.16 bouyer #define T_SEQUENTIAL 0x01 /* sequential access device */ 102 1.16 bouyer #define T_PRINTER 0x02 /* printer device */ 103 1.16 bouyer #define T_PROCESSOR 0x03 /* processor device */ 104 1.16 bouyer #define T_WORM 0x04 /* write once, read many device */ 105 1.16 bouyer #define T_CDROM 0x05 /* cd-rom device */ 106 1.16 bouyer #define T_SCANNER 0x06 /* scanner device */ 107 1.16 bouyer #define T_OPTICAL 0x07 /* optical memory device */ 108 1.16 bouyer #define T_CHANGER 0x08 /* medium changer device */ 109 1.16 bouyer #define T_COMM 0x09 /* communication device */ 110 1.16 bouyer #define T_IT8_1 0x0a /* Defined by ASC IT8... */ 111 1.16 bouyer #define T_IT8_2 0x0b /* ...(Graphic arts pre-press devices) */ 112 1.16 bouyer #define T_STORARRAY 0x0c /* storage array device */ 113 1.16 bouyer #define T_ENCLOSURE 0x0d /* enclosure services device */ 114 1.16 bouyer #define T_SIMPLE_DIRECT 0x0E /* Simplified direct-access device */ 115 1.16 bouyer #define T_OPTIC_CARD_RW 0x0F /* Optical card reader/writer device */ 116 1.16 bouyer #define T_OBJECT_STORED 0x11 /* Object-based Storage Device */ 117 1.16 bouyer #define T_NODEVICE 0x1f 118 1.16 bouyer 119 1.27 reinoud u_int8_t dev_qual2; 120 1.16 bouyer #define SID_QUAL2 0x7F 121 1.16 bouyer #define SID_REMOVABLE 0x80 122 1.16 bouyer 123 1.27 reinoud /* 3*/ u_int8_t version; 124 1.3 enami #define SID_ANSII 0x07 125 1.3 enami #define SID_ECMA 0x38 126 1.3 enami #define SID_ISO 0xC0 127 1.16 bouyer 128 1.27 reinoud /* 4*/ u_int8_t response_format; 129 1.13 dante #define SID_RespDataFmt 0x0F 130 1.16 bouyer #define SID_FORMAT_SCSI1 0x00 /* SCSI-1 format */ 131 1.16 bouyer #define SID_FORMAT_CCS 0x01 /* SCSI CCS format */ 132 1.16 bouyer #define SID_FORMAT_ISO 0x02 /* ISO format */ 133 1.16 bouyer 134 1.27 reinoud /* 5*/ u_int8_t additional_length; /* n-4 */ 135 1.27 reinoud /* 6*/ u_int8_t flags1; 136 1.13 dante #define SID_SCC 0x80 137 1.27 reinoud /* 7*/ u_int8_t flags2; 138 1.13 dante #define SID_Addr16 0x01 139 1.16 bouyer #define SID_MChngr 0x08 140 1.13 dante #define SID_MultiPort 0x10 141 1.13 dante #define SID_EncServ 0x40 142 1.13 dante #define SID_BasQue 0x80 143 1.27 reinoud /* 8*/ u_int8_t flags3; 144 1.2 bouyer #define SID_SftRe 0x01 145 1.2 bouyer #define SID_CmdQue 0x02 146 1.2 bouyer #define SID_Linked 0x08 147 1.2 bouyer #define SID_Sync 0x10 148 1.2 bouyer #define SID_WBus16 0x20 149 1.2 bouyer #define SID_WBus32 0x40 150 1.2 bouyer #define SID_RelAdr 0x80 151 1.16 bouyer /* 9*/ char vendor[8]; 152 1.16 bouyer /*17*/ char product[16]; 153 1.16 bouyer /*33*/ char revision[4]; 154 1.25 mycroft #define SCSIPI_INQUIRY_LENGTH_SCSI2 36 155 1.27 reinoud /*37*/ u_int8_t vendor_specific[20]; 156 1.27 reinoud /*57*/ u_int8_t flags4; 157 1.16 bouyer #define SID_IUS 0x01 158 1.16 bouyer #define SID_QAS 0x02 159 1.16 bouyer #define SID_Clocking 0x0C 160 1.16 bouyer #define SID_CLOCKING_ST_ONLY 0x00 161 1.16 bouyer #define SID_CLOCKING_DT_ONLY 0x04 162 1.16 bouyer #define SID_CLOCKING_SD_DT 0x0C 163 1.27 reinoud /*58*/ u_int8_t reserved; 164 1.16 bouyer /*59*/ char version_descriptor[8][2]; 165 1.25 mycroft #define SCSIPI_INQUIRY_LENGTH_SCSI3 74 166 1.31 martin } __attribute__((packed)); /* 74 Bytes */ 167 1.17 bouyer 168 1.11 thorpej #endif /* _DEV_SCSIPI_SCSIPI_ALL_H_ */ 169