srp.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. /*
  2. * Copyright (c) 2005 Cisco Systems. All rights reserved.
  3. *
  4. * This software is available to you under a choice of one of two
  5. * licenses. You may choose to be licensed under the terms of the GNU
  6. * General Public License (GPL) Version 2, available from the file
  7. * COPYING in the main directory of this source tree, or the
  8. * OpenIB.org BSD license below:
  9. *
  10. * Redistribution and use in source and binary forms, with or
  11. * without modification, are permitted provided that the following
  12. * conditions are met:
  13. *
  14. * - Redistributions of source code must retain the above
  15. * copyright notice, this list of conditions and the following
  16. * disclaimer.
  17. *
  18. * - Redistributions in binary form must reproduce the above
  19. * copyright notice, this list of conditions and the following
  20. * disclaimer in the documentation and/or other materials
  21. * provided with the distribution.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  27. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  28. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  29. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  30. * SOFTWARE.
  31. *
  32. * $Id$
  33. */
  34. #ifndef SCSI_SRP_H
  35. #define SCSI_SRP_H
  36. /*
  37. * Structures and constants for the SCSI RDMA Protocol (SRP) as
  38. * defined by the INCITS T10 committee. This file was written using
  39. * draft Revision 16a of the SRP standard.
  40. */
  41. #include <linux/types.h>
  42. #include <scsi/scsi.h>
  43. enum {
  44. SRP_LOGIN_REQ = 0x00,
  45. SRP_TSK_MGMT = 0x01,
  46. SRP_CMD = 0x02,
  47. SRP_I_LOGOUT = 0x03,
  48. SRP_LOGIN_RSP = 0xc0,
  49. SRP_RSP = 0xc1,
  50. SRP_LOGIN_REJ = 0xc2,
  51. SRP_T_LOGOUT = 0x80,
  52. SRP_CRED_REQ = 0x81,
  53. SRP_AER_REQ = 0x82,
  54. SRP_CRED_RSP = 0x41,
  55. SRP_AER_RSP = 0x42
  56. };
  57. enum {
  58. SRP_BUF_FORMAT_DIRECT = 1 << 1,
  59. SRP_BUF_FORMAT_INDIRECT = 1 << 2
  60. };
  61. enum {
  62. SRP_NO_DATA_DESC = 0,
  63. SRP_DATA_DESC_DIRECT = 1,
  64. SRP_DATA_DESC_INDIRECT = 2
  65. };
  66. enum {
  67. SRP_TSK_ABORT_TASK = 0x01,
  68. SRP_TSK_ABORT_TASK_SET = 0x02,
  69. SRP_TSK_CLEAR_TASK_SET = 0x04,
  70. SRP_TSK_LUN_RESET = 0x08,
  71. SRP_TSK_CLEAR_ACA = 0x40
  72. };
  73. enum srp_login_rej_reason {
  74. SRP_LOGIN_REJ_UNABLE_ESTABLISH_CHANNEL = 0x00010000,
  75. SRP_LOGIN_REJ_INSUFFICIENT_RESOURCES = 0x00010001,
  76. SRP_LOGIN_REJ_REQ_IT_IU_LENGTH_TOO_LARGE = 0x00010002,
  77. SRP_LOGIN_REJ_UNABLE_ASSOCIATE_CHANNEL = 0x00010003,
  78. SRP_LOGIN_REJ_UNSUPPORTED_DESCRIPTOR_FMT = 0x00010004,
  79. SRP_LOGIN_REJ_MULTI_CHANNEL_UNSUPPORTED = 0x00010005,
  80. SRP_LOGIN_REJ_CHANNEL_LIMIT_REACHED = 0x00010006
  81. };
  82. enum {
  83. SRP_REV10_IB_IO_CLASS = 0xff00,
  84. SRP_REV16A_IB_IO_CLASS = 0x0100
  85. };
  86. struct srp_direct_buf {
  87. __be64 va;
  88. __be32 key;
  89. __be32 len;
  90. };
  91. /*
  92. * We need the packed attribute because the SRP spec puts the list of
  93. * descriptors at an offset of 20, which is not aligned to the size of
  94. * struct srp_direct_buf. The whole structure must be packed to avoid
  95. * having the 20-byte structure padded to 24 bytes on 64-bit architectures.
  96. */
  97. struct srp_indirect_buf {
  98. struct srp_direct_buf table_desc;
  99. __be32 len;
  100. struct srp_direct_buf desc_list[0];
  101. } __attribute__((packed));
  102. enum {
  103. SRP_MULTICHAN_SINGLE = 0,
  104. SRP_MULTICHAN_MULTI = 1
  105. };
  106. struct srp_login_req {
  107. u8 opcode;
  108. u8 reserved1[7];
  109. u64 tag;
  110. __be32 req_it_iu_len;
  111. u8 reserved2[4];
  112. __be16 req_buf_fmt;
  113. u8 req_flags;
  114. u8 reserved3[5];
  115. u8 initiator_port_id[16];
  116. u8 target_port_id[16];
  117. };
  118. /**
  119. * struct srp_login_req_rdma - RDMA/CM login parameters.
  120. *
  121. * RDMA/CM over InfiniBand can only carry 92 - 36 = 56 bytes of private
  122. * data. The %srp_login_req_rdma structure contains the same information as
  123. * %srp_login_req but with the reserved data removed.
  124. */
  125. struct srp_login_req_rdma {
  126. u64 tag;
  127. __be16 req_buf_fmt;
  128. u8 req_flags;
  129. u8 opcode;
  130. __be32 req_it_iu_len;
  131. u8 initiator_port_id[16];
  132. u8 target_port_id[16];
  133. };
  134. /*
  135. * The SRP spec defines the size of the LOGIN_RSP structure to be 52
  136. * bytes, so it needs to be packed to avoid having it padded to 56
  137. * bytes on 64-bit architectures.
  138. */
  139. struct srp_login_rsp {
  140. u8 opcode;
  141. u8 reserved1[3];
  142. __be32 req_lim_delta;
  143. u64 tag;
  144. __be32 max_it_iu_len;
  145. __be32 max_ti_iu_len;
  146. __be16 buf_fmt;
  147. u8 rsp_flags;
  148. u8 reserved2[25];
  149. } __attribute__((packed));
  150. struct srp_login_rej {
  151. u8 opcode;
  152. u8 reserved1[3];
  153. __be32 reason;
  154. u64 tag;
  155. u8 reserved2[8];
  156. __be16 buf_fmt;
  157. u8 reserved3[6];
  158. };
  159. struct srp_i_logout {
  160. u8 opcode;
  161. u8 reserved[7];
  162. u64 tag;
  163. };
  164. struct srp_t_logout {
  165. u8 opcode;
  166. u8 sol_not;
  167. u8 reserved[2];
  168. __be32 reason;
  169. u64 tag;
  170. };
  171. /*
  172. * We need the packed attribute because the SRP spec only aligns the
  173. * 8-byte LUN field to 4 bytes.
  174. */
  175. struct srp_tsk_mgmt {
  176. u8 opcode;
  177. u8 sol_not;
  178. u8 reserved1[6];
  179. u64 tag;
  180. u8 reserved2[4];
  181. struct scsi_lun lun;
  182. u8 reserved3[2];
  183. u8 tsk_mgmt_func;
  184. u8 reserved4;
  185. u64 task_tag;
  186. u8 reserved5[8];
  187. };
  188. /*
  189. * We need the packed attribute because the SRP spec only aligns the
  190. * 8-byte LUN field to 4 bytes.
  191. */
  192. struct srp_cmd {
  193. u8 opcode;
  194. u8 sol_not;
  195. u8 reserved1[3];
  196. u8 buf_fmt;
  197. u8 data_out_desc_cnt;
  198. u8 data_in_desc_cnt;
  199. u64 tag;
  200. u8 reserved2[4];
  201. struct scsi_lun lun;
  202. u8 reserved3;
  203. u8 task_attr;
  204. u8 reserved4;
  205. u8 add_cdb_len;
  206. u8 cdb[16];
  207. u8 add_data[0];
  208. };
  209. enum {
  210. SRP_RSP_FLAG_RSPVALID = 1 << 0,
  211. SRP_RSP_FLAG_SNSVALID = 1 << 1,
  212. SRP_RSP_FLAG_DOOVER = 1 << 2,
  213. SRP_RSP_FLAG_DOUNDER = 1 << 3,
  214. SRP_RSP_FLAG_DIOVER = 1 << 4,
  215. SRP_RSP_FLAG_DIUNDER = 1 << 5
  216. };
  217. /*
  218. * The SRP spec defines the size of the RSP structure to be 36 bytes,
  219. * so it needs to be packed to avoid having it padded to 40 bytes on
  220. * 64-bit architectures.
  221. */
  222. struct srp_rsp {
  223. u8 opcode;
  224. u8 sol_not;
  225. u8 reserved1[2];
  226. __be32 req_lim_delta;
  227. u64 tag;
  228. u8 reserved2[2];
  229. u8 flags;
  230. u8 status;
  231. __be32 data_out_res_cnt;
  232. __be32 data_in_res_cnt;
  233. __be32 sense_data_len;
  234. __be32 resp_data_len;
  235. u8 data[0];
  236. } __attribute__((packed));
  237. struct srp_cred_req {
  238. u8 opcode;
  239. u8 sol_not;
  240. u8 reserved[2];
  241. __be32 req_lim_delta;
  242. u64 tag;
  243. };
  244. struct srp_cred_rsp {
  245. u8 opcode;
  246. u8 reserved[7];
  247. u64 tag;
  248. };
  249. /*
  250. * The SRP spec defines the fixed portion of the AER_REQ structure to be
  251. * 36 bytes, so it needs to be packed to avoid having it padded to 40 bytes
  252. * on 64-bit architectures.
  253. */
  254. struct srp_aer_req {
  255. u8 opcode;
  256. u8 sol_not;
  257. u8 reserved[2];
  258. __be32 req_lim_delta;
  259. u64 tag;
  260. u32 reserved2;
  261. struct scsi_lun lun;
  262. __be32 sense_data_len;
  263. u32 reserved3;
  264. u8 sense_data[0];
  265. } __attribute__((packed));
  266. struct srp_aer_rsp {
  267. u8 opcode;
  268. u8 reserved[7];
  269. u64 tag;
  270. };
  271. #endif /* SCSI_SRP_H */