scsireq.h 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. /* this file is also included by usb/disk and cdfs */
  2. typedef struct Umsc Umsc;
  3. #pragma incomplete Umsc
  4. enum { /* fundamental constants/defaults */
  5. NTargetID = 8, /* number of target IDs */
  6. CtlrID = 7, /* default controller target ID */
  7. MaxDirData = 255, /* max. direct data returned */
  8. LBsize = 512, /* default logical-block size */
  9. };
  10. typedef struct {
  11. uchar *p;
  12. long count;
  13. uchar write;
  14. } ScsiPtr;
  15. typedef struct {
  16. int flags;
  17. char *unit; /* unit directory */
  18. int lun;
  19. ulong lbsize;
  20. ulong offset; /* in blocks of lbsize bytes */
  21. int fd;
  22. Umsc *umsc; /* lun */
  23. ScsiPtr cmd;
  24. ScsiPtr data;
  25. int status; /* returned status */
  26. uchar sense[MaxDirData]; /* returned sense data */
  27. uchar inquiry[MaxDirData]; /* returned inquiry data */
  28. int readblock; /* flag: read a block since open */
  29. } ScsiReq;
  30. enum { /* software flags */
  31. Fopen = 0x0001, /* open */
  32. Fseqdev = 0x0002, /* sequential-access device */
  33. Fwritten = 0x0004, /* device written */
  34. Fronly = 0x0008, /* device is read-only */
  35. Fwormdev = 0x0010, /* write-once read-multiple device */
  36. Fprintdev = 0x0020, /* printer */
  37. Fbfixed = 0x0040, /* fixed block size */
  38. Fchanger = 0x0080, /* medium-changer device */
  39. Finqok = 0x0100, /* inquiry data is OK */
  40. Fmode6 = 0x0200, /* use 6-byte modeselect */
  41. Frw10 = 0x0400, /* use 10-byte read/write */
  42. Fusb = 0x0800, /* USB transparent scsi */
  43. };
  44. enum {
  45. STnomem =-4, /* buffer allocation failed */
  46. STharderr =-3, /* controller error of some kind */
  47. STtimeout =-2, /* bus timeout */
  48. STok = 0, /* good */
  49. STcheck = 0x02, /* check condition */
  50. STcondmet = 0x04, /* condition met/good */
  51. STbusy = 0x08, /* busy */
  52. STintok = 0x10, /* intermediate/good */
  53. STintcondmet = 0x14, /* intermediate/condition met/good */
  54. STresconf = 0x18, /* reservation conflict */
  55. STterminated = 0x22, /* command terminated */
  56. STqfull = 0x28, /* queue full */
  57. };
  58. enum { /* status */
  59. Status_SD = 0x80, /* sense-data available */
  60. Status_SW = 0x83, /* internal software error */
  61. Status_BADARG = 0x84, /* bad argument to request */
  62. Status_RO = 0x85, /* device is read-only */
  63. };
  64. enum { /* SCSI command codes */
  65. ScmdTur = 0x00, /* test unit ready */
  66. ScmdRewind = 0x01, /* rezero/rewind */
  67. ScmdRsense = 0x03, /* request sense */
  68. ScmdFormat = 0x04, /* format unit */
  69. ScmdRblimits = 0x05, /* read block limits */
  70. ScmdRead = 0x08, /* read */
  71. ScmdWrite = 0x0A, /* write */
  72. ScmdSeek = 0x0B, /* seek */
  73. ScmdFmark = 0x10, /* write filemarks */
  74. ScmdSpace = 0x11, /* space forward/backward */
  75. ScmdInq = 0x12, /* inquiry */
  76. ScmdMselect6 = 0x15, /* mode select */
  77. ScmdMselect10 = 0x55, /* mode select */
  78. ScmdMsense6 = 0x1A, /* mode sense */
  79. ScmdMsense10 = 0x5A, /* mode sense */
  80. ScmdStart = 0x1B, /* start/stop unit */
  81. ScmdRcapacity = 0x25, /* read capacity */
  82. ScmdExtread = 0x28, /* extended read */
  83. ScmdExtwrite = 0x2A, /* extended write */
  84. ScmdExtseek = 0x2B, /* extended seek */
  85. ScmdSynccache = 0x35, /* flush cache */
  86. ScmdRTOC = 0x43, /* read TOC data */
  87. ScmdRdiscinfo = 0x51, /* read disc information */
  88. ScmdRtrackinfo = 0x52, /* read track information */
  89. ScmdReserve = 0x53, /* reserve track */
  90. ScmdBlank = 0xA1, /* blank *-RW media */
  91. ScmdCDpause = 0x4B, /* pause/resume */
  92. ScmdCDstop = 0x4E, /* stop play/scan */
  93. ScmdCDplay = 0xA5, /* play audio */
  94. ScmdCDload = 0xA6, /* load/unload */
  95. ScmdCDscan = 0xBA, /* fast forward/reverse */
  96. ScmdCDstatus = 0xBD, /* mechanism status */
  97. Scmdgetconf = 0x46, /* get configuration */
  98. ScmdEInitialise = 0x07, /* initialise element status */
  99. ScmdMMove = 0xA5, /* move medium */
  100. ScmdEStatus = 0xB8, /* read element status */
  101. ScmdMExchange = 0xA6, /* exchange medium */
  102. ScmdEposition = 0x2B, /* position to element */
  103. ScmdReadDVD = 0xAD, /* read dvd structure */
  104. ScmdReportKey = 0xA4, /* read dvd key */
  105. ScmdSendKey = 0xA3, /* write dvd key */
  106. ScmdClosetracksess= 0x5B,
  107. ScmdRead12 = 0xA8,
  108. ScmdSetcdspeed = 0xBB,
  109. ScmdReadcd = 0xBE,
  110. /* vendor-specific */
  111. ScmdFwaddr = 0xE2, /* first writeable address */
  112. ScmdTreserve = 0xE4, /* reserve track */
  113. ScmdTinfo = 0xE5, /* read track info */
  114. ScmdTwrite = 0xE6, /* write track */
  115. ScmdMload = 0xE7, /* medium load/unload */
  116. ScmdFixation = 0xE9, /* fixation */
  117. };
  118. enum {
  119. /* sense data byte 0 */
  120. Sd0valid = 0x80, /* valid sense data present */
  121. /* sense data byte 2 */
  122. /* incorrect-length indicator, difference in bytes 3—6 */
  123. Sd2ili = 0x20,
  124. Sd2eom = 0x40, /* end of medium (tape) */
  125. Sd2filemark = 0x80, /* at a filemark (tape) */
  126. /* command byte 1 */
  127. Cmd1fixed = 1, /* use fixed-length blocks */
  128. Cmd1sili = 2, /* don't set Sd2ili */
  129. /* limit of block #s in 24-bit ccbs */
  130. Max24off = (1<<21) - 1, /* 2⁲ⁱ - 1 */
  131. /* mode pages */
  132. Allmodepages = 0x3F,
  133. };
  134. /* p arguments should be of type uchar* */
  135. #define GETBELONG(p) ((ulong)(p)[0]<<24 | (ulong)(p)[1]<<16 | (p)[2]<<8 | (p)[3])
  136. #define PUTBELONG(p, ul) ((p)[0] = (ul)>>24, (p)[1] = (ul)>>16, \
  137. (p)[2] = (ul)>>8, (p)[3] = (ul))
  138. #define GETBE24(p) ((ulong)(p)[0]<<16 | (p)[1]<<8 | (p)[2])
  139. #define PUTBE24(p, ul) ((p)[0] = (ul)>>16, (p)[1] = (ul)>>8, (p)[2] = (ul))
  140. extern long maxiosize;
  141. long SRready(ScsiReq*);
  142. long SRrewind(ScsiReq*);
  143. long SRreqsense(ScsiReq*);
  144. long SRformat(ScsiReq*);
  145. long SRrblimits(ScsiReq*, uchar*);
  146. long SRread(ScsiReq*, void*, long);
  147. long SRwrite(ScsiReq*, void*, long);
  148. long SRseek(ScsiReq*, long, int);
  149. long SRfilemark(ScsiReq*, ulong);
  150. long SRspace(ScsiReq*, uchar, long);
  151. long SRinquiry(ScsiReq*);
  152. long SRmodeselect6(ScsiReq*, uchar*, long);
  153. long SRmodeselect10(ScsiReq*, uchar*, long);
  154. long SRmodesense6(ScsiReq*, uchar, uchar*, long);
  155. long SRmodesense10(ScsiReq*, uchar, uchar*, long);
  156. long SRstart(ScsiReq*, uchar);
  157. long SRrcapacity(ScsiReq*, uchar*);
  158. long SRblank(ScsiReq*, uchar, uchar); /* MMC CD-R/CD-RW commands */
  159. long SRsynccache(ScsiReq*);
  160. long SRTOC(ScsiReq*, void*, int, uchar, uchar);
  161. long SRrdiscinfo(ScsiReq*, void*, int);
  162. long SRrtrackinfo(ScsiReq*, void*, int, int);
  163. long SRcdpause(ScsiReq*, int); /* MMC CD audio commands */
  164. long SRcdstop(ScsiReq*);
  165. long SRcdload(ScsiReq*, int, int);
  166. long SRcdplay(ScsiReq*, int, long, long);
  167. long SRcdstatus(ScsiReq*, uchar*, int);
  168. long SRgetconf(ScsiReq*, uchar*, int);
  169. /* old CD-R/CD-RW commands */
  170. long SRfwaddr(ScsiReq*, uchar, uchar, uchar, uchar*);
  171. long SRtreserve(ScsiReq*, long);
  172. long SRtinfo(ScsiReq*, uchar, uchar*);
  173. long SRwtrack(ScsiReq*, void*, long, uchar, uchar);
  174. long SRmload(ScsiReq*, uchar);
  175. long SRfixation(ScsiReq*, uchar);
  176. long SReinitialise(ScsiReq*); /* CHANGER commands */
  177. long SRestatus(ScsiReq*, uchar, uchar*, int);
  178. long SRmmove(ScsiReq*, int, int, int, int);
  179. long SRrequest(ScsiReq*);
  180. int SRclose(ScsiReq*);
  181. int SRopenraw(ScsiReq*, char*);
  182. int SRopen(ScsiReq*, char*);
  183. void makesense(ScsiReq*);
  184. long umsrequest(struct Umsc*, ScsiPtr*, ScsiPtr*, int*);