scsi.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * This header file contains public constants and structures used by
  4. * the SCSI initiator code.
  5. */
  6. #ifndef _SCSI_SCSI_H
  7. #define _SCSI_SCSI_H
  8. #include <linux/types.h>
  9. #include <linux/scatterlist.h>
  10. #include <linux/kernel.h>
  11. #include <scsi/scsi_common.h>
  12. #include <scsi/scsi_proto.h>
  13. #include <scsi/scsi_status.h>
  14. struct scsi_cmnd;
  15. enum scsi_timeouts {
  16. SCSI_DEFAULT_EH_TIMEOUT = 10 * HZ,
  17. };
  18. /*
  19. * DIX-capable adapters effectively support infinite chaining for the
  20. * protection information scatterlist
  21. */
  22. #define SCSI_MAX_PROT_SG_SEGMENTS 0xFFFF
  23. /*
  24. * Special value for scanning to specify scanning or rescanning of all
  25. * possible channels, (target) ids, or luns on a given shost.
  26. */
  27. #define SCAN_WILD_CARD ~0
  28. /*
  29. * standard mode-select header prepended to all mode-select commands
  30. */
  31. struct ccs_modesel_head {
  32. __u8 _r1; /* reserved */
  33. __u8 medium; /* device-specific medium type */
  34. __u8 _r2; /* reserved */
  35. __u8 block_desc_length; /* block descriptor length */
  36. __u8 density; /* device-specific density code */
  37. __u8 number_blocks_hi; /* number of blocks in this block desc */
  38. __u8 number_blocks_med;
  39. __u8 number_blocks_lo;
  40. __u8 _r3;
  41. __u8 block_length_hi; /* block length for blocks in this desc */
  42. __u8 block_length_med;
  43. __u8 block_length_lo;
  44. };
  45. /*
  46. * The Well Known LUNS (SAM-3) in our int representation of a LUN
  47. */
  48. #define SCSI_W_LUN_BASE 0xc100
  49. #define SCSI_W_LUN_REPORT_LUNS (SCSI_W_LUN_BASE + 1)
  50. #define SCSI_W_LUN_ACCESS_CONTROL (SCSI_W_LUN_BASE + 2)
  51. #define SCSI_W_LUN_TARGET_LOG_PAGE (SCSI_W_LUN_BASE + 3)
  52. static inline int scsi_is_wlun(u64 lun)
  53. {
  54. return (lun & 0xff00) == SCSI_W_LUN_BASE;
  55. }
  56. /**
  57. * scsi_status_is_check_condition - check the status return.
  58. *
  59. * @status: the status passed up from the driver (including host and
  60. * driver components)
  61. *
  62. * This returns true if the status code is SAM_STAT_CHECK_CONDITION.
  63. */
  64. static inline int scsi_status_is_check_condition(int status)
  65. {
  66. if (status < 0)
  67. return false;
  68. status &= 0xfe;
  69. return status == SAM_STAT_CHECK_CONDITION;
  70. }
  71. /*
  72. * Extended message codes.
  73. */
  74. #define EXTENDED_MODIFY_DATA_POINTER 0x00
  75. #define EXTENDED_SDTR 0x01
  76. #define EXTENDED_EXTENDED_IDENTIFY 0x02 /* SCSI-I only */
  77. #define EXTENDED_WDTR 0x03
  78. #define EXTENDED_PPR 0x04
  79. #define EXTENDED_MODIFY_BIDI_DATA_PTR 0x05
  80. /*
  81. * Internal return values.
  82. */
  83. enum scsi_disposition {
  84. NEEDS_RETRY = 0x2001,
  85. SUCCESS = 0x2002,
  86. FAILED = 0x2003,
  87. QUEUED = 0x2004,
  88. SOFT_ERROR = 0x2005,
  89. ADD_TO_MLQUEUE = 0x2006,
  90. TIMEOUT_ERROR = 0x2007,
  91. SCSI_RETURN_NOT_HANDLED = 0x2008,
  92. FAST_IO_FAIL = 0x2009,
  93. };
  94. /*
  95. * Midlevel queue return values.
  96. */
  97. #define SCSI_MLQUEUE_HOST_BUSY 0x1055
  98. #define SCSI_MLQUEUE_DEVICE_BUSY 0x1056
  99. #define SCSI_MLQUEUE_EH_RETRY 0x1057
  100. #define SCSI_MLQUEUE_TARGET_BUSY 0x1058
  101. /*
  102. * Use these to separate status msg and our bytes
  103. *
  104. * These are set by:
  105. *
  106. * status byte = set from target device
  107. * msg_byte (unused)
  108. * host_byte = set by low-level driver to indicate status.
  109. */
  110. #define host_byte(result) (((result) >> 16) & 0xff)
  111. #define sense_class(sense) (((sense) >> 4) & 0x7)
  112. #define sense_error(sense) ((sense) & 0xf)
  113. #define sense_valid(sense) ((sense) & 0x80)
  114. /*
  115. * default timeouts
  116. */
  117. #define FORMAT_UNIT_TIMEOUT (2 * 60 * 60 * HZ)
  118. #define START_STOP_TIMEOUT (60 * HZ)
  119. #define MOVE_MEDIUM_TIMEOUT (5 * 60 * HZ)
  120. #define READ_ELEMENT_STATUS_TIMEOUT (5 * 60 * HZ)
  121. #define READ_DEFECT_DATA_TIMEOUT (60 * HZ )
  122. #define IDENTIFY_BASE 0x80
  123. #define IDENTIFY(can_disconnect, lun) (IDENTIFY_BASE |\
  124. ((can_disconnect) ? 0x40 : 0) |\
  125. ((lun) & 0x07))
  126. /*
  127. * struct scsi_device::scsi_level values. For SCSI devices other than those
  128. * prior to SCSI-2 (i.e. over 12 years old) this value is (resp[2] + 1)
  129. * where "resp" is a byte array of the response to an INQUIRY. The scsi_level
  130. * variable is visible to the user via sysfs.
  131. */
  132. #define SCSI_UNKNOWN 0
  133. #define SCSI_1 1
  134. #define SCSI_1_CCS 2
  135. #define SCSI_2 3
  136. #define SCSI_3 4 /* SPC */
  137. #define SCSI_SPC_2 5
  138. #define SCSI_SPC_3 6
  139. /*
  140. * INQ PERIPHERAL QUALIFIERS
  141. */
  142. #define SCSI_INQ_PQ_CON 0x00
  143. #define SCSI_INQ_PQ_NOT_CON 0x01
  144. #define SCSI_INQ_PQ_NOT_CAP 0x03
  145. /*
  146. * Here are some scsi specific ioctl commands which are sometimes useful.
  147. *
  148. * Note that include/linux/cdrom.h also defines IOCTL 0x5300 - 0x5395
  149. */
  150. /* Used to obtain PUN and LUN info. Conflicts with CDROMAUDIOBUFSIZ */
  151. #define SCSI_IOCTL_GET_IDLUN 0x5382
  152. /* 0x5383 and 0x5384 were used for SCSI_IOCTL_TAGGED_{ENABLE,DISABLE} */
  153. /* Used to obtain the host number of a device. */
  154. #define SCSI_IOCTL_PROBE_HOST 0x5385
  155. /* Used to obtain the bus number for a device */
  156. #define SCSI_IOCTL_GET_BUS_NUMBER 0x5386
  157. /* Used to obtain the PCI location of a device */
  158. #define SCSI_IOCTL_GET_PCI 0x5387
  159. /** scsi_status_is_good - check the status return.
  160. *
  161. * @status: the status passed up from the driver (including host and
  162. * driver components)
  163. *
  164. * This returns true for known good conditions that may be treated as
  165. * command completed normally
  166. */
  167. static inline bool scsi_status_is_good(int status)
  168. {
  169. if (status < 0)
  170. return false;
  171. if (host_byte(status) == DID_NO_CONNECT)
  172. return false;
  173. /*
  174. * FIXME: bit0 is listed as reserved in SCSI-2, but is
  175. * significant in SCSI-3. For now, we follow the SCSI-2
  176. * behaviour and ignore reserved bits.
  177. */
  178. status &= 0xfe;
  179. return ((status == SAM_STAT_GOOD) ||
  180. (status == SAM_STAT_CONDITION_MET) ||
  181. /* Next two "intermediate" statuses are obsolete in SAM-4 */
  182. (status == SAM_STAT_INTERMEDIATE) ||
  183. (status == SAM_STAT_INTERMEDIATE_CONDITION_MET) ||
  184. /* FIXME: this is obsolete in SAM-3 */
  185. (status == SAM_STAT_COMMAND_TERMINATED));
  186. }
  187. #endif /* _SCSI_SCSI_H */