57xx_iscsi_hsi.h 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524
  1. /* 57xx_iscsi_hsi.h: Broadcom NetXtreme II iSCSI HSI.
  2. *
  3. * Copyright (c) 2006 - 2013 Broadcom Corporation
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation.
  8. *
  9. * Written by: Anil Veerabhadrappa (anilgv@broadcom.com)
  10. * Maintained by: Eddie Wai (eddie.wai@broadcom.com)
  11. */
  12. #ifndef __57XX_ISCSI_HSI_LINUX_LE__
  13. #define __57XX_ISCSI_HSI_LINUX_LE__
  14. /*
  15. * iSCSI Async CQE
  16. */
  17. struct bnx2i_async_msg {
  18. #if defined(__BIG_ENDIAN)
  19. u8 op_code;
  20. u8 reserved1;
  21. u16 reserved0;
  22. #elif defined(__LITTLE_ENDIAN)
  23. u16 reserved0;
  24. u8 reserved1;
  25. u8 op_code;
  26. #endif
  27. u32 reserved2;
  28. u32 exp_cmd_sn;
  29. u32 max_cmd_sn;
  30. u32 reserved3[2];
  31. #if defined(__BIG_ENDIAN)
  32. u16 reserved5;
  33. u8 err_code;
  34. u8 reserved4;
  35. #elif defined(__LITTLE_ENDIAN)
  36. u8 reserved4;
  37. u8 err_code;
  38. u16 reserved5;
  39. #endif
  40. u32 reserved6;
  41. u32 lun[2];
  42. #if defined(__BIG_ENDIAN)
  43. u8 async_event;
  44. u8 async_vcode;
  45. u16 param1;
  46. #elif defined(__LITTLE_ENDIAN)
  47. u16 param1;
  48. u8 async_vcode;
  49. u8 async_event;
  50. #endif
  51. #if defined(__BIG_ENDIAN)
  52. u16 param2;
  53. u16 param3;
  54. #elif defined(__LITTLE_ENDIAN)
  55. u16 param3;
  56. u16 param2;
  57. #endif
  58. u32 reserved7[3];
  59. u32 cq_req_sn;
  60. };
  61. /*
  62. * iSCSI Buffer Descriptor (BD)
  63. */
  64. struct iscsi_bd {
  65. u32 buffer_addr_hi;
  66. u32 buffer_addr_lo;
  67. #if defined(__BIG_ENDIAN)
  68. u16 reserved0;
  69. u16 buffer_length;
  70. #elif defined(__LITTLE_ENDIAN)
  71. u16 buffer_length;
  72. u16 reserved0;
  73. #endif
  74. #if defined(__BIG_ENDIAN)
  75. u16 reserved3;
  76. u16 flags;
  77. #define ISCSI_BD_RESERVED1 (0x3F<<0)
  78. #define ISCSI_BD_RESERVED1_SHIFT 0
  79. #define ISCSI_BD_LAST_IN_BD_CHAIN (0x1<<6)
  80. #define ISCSI_BD_LAST_IN_BD_CHAIN_SHIFT 6
  81. #define ISCSI_BD_FIRST_IN_BD_CHAIN (0x1<<7)
  82. #define ISCSI_BD_FIRST_IN_BD_CHAIN_SHIFT 7
  83. #define ISCSI_BD_RESERVED2 (0xFF<<8)
  84. #define ISCSI_BD_RESERVED2_SHIFT 8
  85. #elif defined(__LITTLE_ENDIAN)
  86. u16 flags;
  87. #define ISCSI_BD_RESERVED1 (0x3F<<0)
  88. #define ISCSI_BD_RESERVED1_SHIFT 0
  89. #define ISCSI_BD_LAST_IN_BD_CHAIN (0x1<<6)
  90. #define ISCSI_BD_LAST_IN_BD_CHAIN_SHIFT 6
  91. #define ISCSI_BD_FIRST_IN_BD_CHAIN (0x1<<7)
  92. #define ISCSI_BD_FIRST_IN_BD_CHAIN_SHIFT 7
  93. #define ISCSI_BD_RESERVED2 (0xFF<<8)
  94. #define ISCSI_BD_RESERVED2_SHIFT 8
  95. u16 reserved3;
  96. #endif
  97. };
  98. /*
  99. * iSCSI Cleanup SQ WQE
  100. */
  101. struct bnx2i_cleanup_request {
  102. #if defined(__BIG_ENDIAN)
  103. u8 op_code;
  104. u8 reserved1;
  105. u16 reserved0;
  106. #elif defined(__LITTLE_ENDIAN)
  107. u16 reserved0;
  108. u8 reserved1;
  109. u8 op_code;
  110. #endif
  111. u32 reserved2[3];
  112. #if defined(__BIG_ENDIAN)
  113. u16 reserved3;
  114. u16 itt;
  115. #define ISCSI_CLEANUP_REQUEST_INDEX (0x3FFF<<0)
  116. #define ISCSI_CLEANUP_REQUEST_INDEX_SHIFT 0
  117. #define ISCSI_CLEANUP_REQUEST_TYPE (0x3<<14)
  118. #define ISCSI_CLEANUP_REQUEST_TYPE_SHIFT 14
  119. #elif defined(__LITTLE_ENDIAN)
  120. u16 itt;
  121. #define ISCSI_CLEANUP_REQUEST_INDEX (0x3FFF<<0)
  122. #define ISCSI_CLEANUP_REQUEST_INDEX_SHIFT 0
  123. #define ISCSI_CLEANUP_REQUEST_TYPE (0x3<<14)
  124. #define ISCSI_CLEANUP_REQUEST_TYPE_SHIFT 14
  125. u16 reserved3;
  126. #endif
  127. u32 reserved4[10];
  128. #if defined(__BIG_ENDIAN)
  129. u8 cq_index;
  130. u8 reserved6;
  131. u16 reserved5;
  132. #elif defined(__LITTLE_ENDIAN)
  133. u16 reserved5;
  134. u8 reserved6;
  135. u8 cq_index;
  136. #endif
  137. };
  138. /*
  139. * iSCSI Cleanup CQE
  140. */
  141. struct bnx2i_cleanup_response {
  142. #if defined(__BIG_ENDIAN)
  143. u8 op_code;
  144. u8 status;
  145. u16 reserved0;
  146. #elif defined(__LITTLE_ENDIAN)
  147. u16 reserved0;
  148. u8 status;
  149. u8 op_code;
  150. #endif
  151. u32 reserved1[3];
  152. u32 reserved2[2];
  153. #if defined(__BIG_ENDIAN)
  154. u16 reserved4;
  155. u8 err_code;
  156. u8 reserved3;
  157. #elif defined(__LITTLE_ENDIAN)
  158. u8 reserved3;
  159. u8 err_code;
  160. u16 reserved4;
  161. #endif
  162. u32 reserved5[7];
  163. #if defined(__BIG_ENDIAN)
  164. u16 reserved6;
  165. u16 itt;
  166. #define ISCSI_CLEANUP_RESPONSE_INDEX (0x3FFF<<0)
  167. #define ISCSI_CLEANUP_RESPONSE_INDEX_SHIFT 0
  168. #define ISCSI_CLEANUP_RESPONSE_TYPE (0x3<<14)
  169. #define ISCSI_CLEANUP_RESPONSE_TYPE_SHIFT 14
  170. #elif defined(__LITTLE_ENDIAN)
  171. u16 itt;
  172. #define ISCSI_CLEANUP_RESPONSE_INDEX (0x3FFF<<0)
  173. #define ISCSI_CLEANUP_RESPONSE_INDEX_SHIFT 0
  174. #define ISCSI_CLEANUP_RESPONSE_TYPE (0x3<<14)
  175. #define ISCSI_CLEANUP_RESPONSE_TYPE_SHIFT 14
  176. u16 reserved6;
  177. #endif
  178. u32 cq_req_sn;
  179. };
  180. /*
  181. * SCSI read/write SQ WQE
  182. */
  183. struct bnx2i_cmd_request {
  184. #if defined(__BIG_ENDIAN)
  185. u8 op_code;
  186. u8 op_attr;
  187. #define ISCSI_CMD_REQUEST_TASK_ATTR (0x7<<0)
  188. #define ISCSI_CMD_REQUEST_TASK_ATTR_SHIFT 0
  189. #define ISCSI_CMD_REQUEST_RESERVED1 (0x3<<3)
  190. #define ISCSI_CMD_REQUEST_RESERVED1_SHIFT 3
  191. #define ISCSI_CMD_REQUEST_WRITE (0x1<<5)
  192. #define ISCSI_CMD_REQUEST_WRITE_SHIFT 5
  193. #define ISCSI_CMD_REQUEST_READ (0x1<<6)
  194. #define ISCSI_CMD_REQUEST_READ_SHIFT 6
  195. #define ISCSI_CMD_REQUEST_FINAL (0x1<<7)
  196. #define ISCSI_CMD_REQUEST_FINAL_SHIFT 7
  197. u16 reserved0;
  198. #elif defined(__LITTLE_ENDIAN)
  199. u16 reserved0;
  200. u8 op_attr;
  201. #define ISCSI_CMD_REQUEST_TASK_ATTR (0x7<<0)
  202. #define ISCSI_CMD_REQUEST_TASK_ATTR_SHIFT 0
  203. #define ISCSI_CMD_REQUEST_RESERVED1 (0x3<<3)
  204. #define ISCSI_CMD_REQUEST_RESERVED1_SHIFT 3
  205. #define ISCSI_CMD_REQUEST_WRITE (0x1<<5)
  206. #define ISCSI_CMD_REQUEST_WRITE_SHIFT 5
  207. #define ISCSI_CMD_REQUEST_READ (0x1<<6)
  208. #define ISCSI_CMD_REQUEST_READ_SHIFT 6
  209. #define ISCSI_CMD_REQUEST_FINAL (0x1<<7)
  210. #define ISCSI_CMD_REQUEST_FINAL_SHIFT 7
  211. u8 op_code;
  212. #endif
  213. #if defined(__BIG_ENDIAN)
  214. u16 ud_buffer_offset;
  215. u16 sd_buffer_offset;
  216. #elif defined(__LITTLE_ENDIAN)
  217. u16 sd_buffer_offset;
  218. u16 ud_buffer_offset;
  219. #endif
  220. u32 lun[2];
  221. #if defined(__BIG_ENDIAN)
  222. u16 reserved2;
  223. u16 itt;
  224. #define ISCSI_CMD_REQUEST_INDEX (0x3FFF<<0)
  225. #define ISCSI_CMD_REQUEST_INDEX_SHIFT 0
  226. #define ISCSI_CMD_REQUEST_TYPE (0x3<<14)
  227. #define ISCSI_CMD_REQUEST_TYPE_SHIFT 14
  228. #elif defined(__LITTLE_ENDIAN)
  229. u16 itt;
  230. #define ISCSI_CMD_REQUEST_INDEX (0x3FFF<<0)
  231. #define ISCSI_CMD_REQUEST_INDEX_SHIFT 0
  232. #define ISCSI_CMD_REQUEST_TYPE (0x3<<14)
  233. #define ISCSI_CMD_REQUEST_TYPE_SHIFT 14
  234. u16 reserved2;
  235. #endif
  236. u32 total_data_transfer_length;
  237. u32 cmd_sn;
  238. u32 reserved3;
  239. u32 cdb[4];
  240. u32 zero_fill;
  241. u32 bd_list_addr_lo;
  242. u32 bd_list_addr_hi;
  243. #if defined(__BIG_ENDIAN)
  244. u8 cq_index;
  245. u8 sd_start_bd_index;
  246. u8 ud_start_bd_index;
  247. u8 num_bds;
  248. #elif defined(__LITTLE_ENDIAN)
  249. u8 num_bds;
  250. u8 ud_start_bd_index;
  251. u8 sd_start_bd_index;
  252. u8 cq_index;
  253. #endif
  254. };
  255. /*
  256. * task statistics for write response
  257. */
  258. struct bnx2i_write_resp_task_stat {
  259. #if defined(__BIG_ENDIAN)
  260. u16 num_r2ts;
  261. u16 num_data_outs;
  262. #elif defined(__LITTLE_ENDIAN)
  263. u16 num_data_outs;
  264. u16 num_r2ts;
  265. #endif
  266. };
  267. /*
  268. * task statistics for read response
  269. */
  270. struct bnx2i_read_resp_task_stat {
  271. #if defined(__BIG_ENDIAN)
  272. u16 reserved;
  273. u16 num_data_ins;
  274. #elif defined(__LITTLE_ENDIAN)
  275. u16 num_data_ins;
  276. u16 reserved;
  277. #endif
  278. };
  279. /*
  280. * task statistics for iSCSI cmd response
  281. */
  282. union bnx2i_cmd_resp_task_stat {
  283. struct bnx2i_write_resp_task_stat write_stat;
  284. struct bnx2i_read_resp_task_stat read_stat;
  285. };
  286. /*
  287. * SCSI Command CQE
  288. */
  289. struct bnx2i_cmd_response {
  290. #if defined(__BIG_ENDIAN)
  291. u8 op_code;
  292. u8 response_flags;
  293. #define ISCSI_CMD_RESPONSE_RESERVED0 (0x1<<0)
  294. #define ISCSI_CMD_RESPONSE_RESERVED0_SHIFT 0
  295. #define ISCSI_CMD_RESPONSE_RESIDUAL_UNDERFLOW (0x1<<1)
  296. #define ISCSI_CMD_RESPONSE_RESIDUAL_UNDERFLOW_SHIFT 1
  297. #define ISCSI_CMD_RESPONSE_RESIDUAL_OVERFLOW (0x1<<2)
  298. #define ISCSI_CMD_RESPONSE_RESIDUAL_OVERFLOW_SHIFT 2
  299. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_UNDERFLOW (0x1<<3)
  300. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_UNDERFLOW_SHIFT 3
  301. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_OVERFLOW (0x1<<4)
  302. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_OVERFLOW_SHIFT 4
  303. #define ISCSI_CMD_RESPONSE_RESERVED1 (0x7<<5)
  304. #define ISCSI_CMD_RESPONSE_RESERVED1_SHIFT 5
  305. u8 response;
  306. u8 status;
  307. #elif defined(__LITTLE_ENDIAN)
  308. u8 status;
  309. u8 response;
  310. u8 response_flags;
  311. #define ISCSI_CMD_RESPONSE_RESERVED0 (0x1<<0)
  312. #define ISCSI_CMD_RESPONSE_RESERVED0_SHIFT 0
  313. #define ISCSI_CMD_RESPONSE_RESIDUAL_UNDERFLOW (0x1<<1)
  314. #define ISCSI_CMD_RESPONSE_RESIDUAL_UNDERFLOW_SHIFT 1
  315. #define ISCSI_CMD_RESPONSE_RESIDUAL_OVERFLOW (0x1<<2)
  316. #define ISCSI_CMD_RESPONSE_RESIDUAL_OVERFLOW_SHIFT 2
  317. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_UNDERFLOW (0x1<<3)
  318. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_UNDERFLOW_SHIFT 3
  319. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_OVERFLOW (0x1<<4)
  320. #define ISCSI_CMD_RESPONSE_BR_RESIDUAL_OVERFLOW_SHIFT 4
  321. #define ISCSI_CMD_RESPONSE_RESERVED1 (0x7<<5)
  322. #define ISCSI_CMD_RESPONSE_RESERVED1_SHIFT 5
  323. u8 op_code;
  324. #endif
  325. u32 data_length;
  326. u32 exp_cmd_sn;
  327. u32 max_cmd_sn;
  328. u32 reserved2;
  329. u32 residual_count;
  330. #if defined(__BIG_ENDIAN)
  331. u16 reserved4;
  332. u8 err_code;
  333. u8 reserved3;
  334. #elif defined(__LITTLE_ENDIAN)
  335. u8 reserved3;
  336. u8 err_code;
  337. u16 reserved4;
  338. #endif
  339. u32 reserved5[5];
  340. union bnx2i_cmd_resp_task_stat task_stat;
  341. u32 reserved6;
  342. #if defined(__BIG_ENDIAN)
  343. u16 reserved7;
  344. u16 itt;
  345. #define ISCSI_CMD_RESPONSE_INDEX (0x3FFF<<0)
  346. #define ISCSI_CMD_RESPONSE_INDEX_SHIFT 0
  347. #define ISCSI_CMD_RESPONSE_TYPE (0x3<<14)
  348. #define ISCSI_CMD_RESPONSE_TYPE_SHIFT 14
  349. #elif defined(__LITTLE_ENDIAN)
  350. u16 itt;
  351. #define ISCSI_CMD_RESPONSE_INDEX (0x3FFF<<0)
  352. #define ISCSI_CMD_RESPONSE_INDEX_SHIFT 0
  353. #define ISCSI_CMD_RESPONSE_TYPE (0x3<<14)
  354. #define ISCSI_CMD_RESPONSE_TYPE_SHIFT 14
  355. u16 reserved7;
  356. #endif
  357. u32 cq_req_sn;
  358. };
  359. /*
  360. * firmware middle-path request SQ WQE
  361. */
  362. struct bnx2i_fw_mp_request {
  363. #if defined(__BIG_ENDIAN)
  364. u8 op_code;
  365. u8 op_attr;
  366. u16 hdr_opaque1;
  367. #elif defined(__LITTLE_ENDIAN)
  368. u16 hdr_opaque1;
  369. u8 op_attr;
  370. u8 op_code;
  371. #endif
  372. u32 data_length;
  373. u32 hdr_opaque2[2];
  374. #if defined(__BIG_ENDIAN)
  375. u16 reserved0;
  376. u16 itt;
  377. #define ISCSI_FW_MP_REQUEST_INDEX (0x3FFF<<0)
  378. #define ISCSI_FW_MP_REQUEST_INDEX_SHIFT 0
  379. #define ISCSI_FW_MP_REQUEST_TYPE (0x3<<14)
  380. #define ISCSI_FW_MP_REQUEST_TYPE_SHIFT 14
  381. #elif defined(__LITTLE_ENDIAN)
  382. u16 itt;
  383. #define ISCSI_FW_MP_REQUEST_INDEX (0x3FFF<<0)
  384. #define ISCSI_FW_MP_REQUEST_INDEX_SHIFT 0
  385. #define ISCSI_FW_MP_REQUEST_TYPE (0x3<<14)
  386. #define ISCSI_FW_MP_REQUEST_TYPE_SHIFT 14
  387. u16 reserved0;
  388. #endif
  389. u32 hdr_opaque3[4];
  390. u32 resp_bd_list_addr_lo;
  391. u32 resp_bd_list_addr_hi;
  392. u32 resp_buffer;
  393. #define ISCSI_FW_MP_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  394. #define ISCSI_FW_MP_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  395. #define ISCSI_FW_MP_REQUEST_NUM_RESP_BDS (0xFF<<24)
  396. #define ISCSI_FW_MP_REQUEST_NUM_RESP_BDS_SHIFT 24
  397. #if defined(__BIG_ENDIAN)
  398. u16 reserved4;
  399. u8 reserved3;
  400. u8 flags;
  401. #define ISCSI_FW_MP_REQUEST_RESERVED1 (0x1<<0)
  402. #define ISCSI_FW_MP_REQUEST_RESERVED1_SHIFT 0
  403. #define ISCSI_FW_MP_REQUEST_LOCAL_COMPLETION (0x1<<1)
  404. #define ISCSI_FW_MP_REQUEST_LOCAL_COMPLETION_SHIFT 1
  405. #define ISCSI_FW_MP_REQUEST_UPDATE_EXP_STAT_SN (0x1<<2)
  406. #define ISCSI_FW_MP_REQUEST_UPDATE_EXP_STAT_SN_SHIFT 2
  407. #define ISCSI_FW_MP_REQUEST_RESERVED2 (0x1F<<3)
  408. #define ISCSI_FW_MP_REQUEST_RESERVED2_SHIFT 3
  409. #elif defined(__LITTLE_ENDIAN)
  410. u8 flags;
  411. #define ISCSI_FW_MP_REQUEST_RESERVED1 (0x1<<0)
  412. #define ISCSI_FW_MP_REQUEST_RESERVED1_SHIFT 0
  413. #define ISCSI_FW_MP_REQUEST_LOCAL_COMPLETION (0x1<<1)
  414. #define ISCSI_FW_MP_REQUEST_LOCAL_COMPLETION_SHIFT 1
  415. #define ISCSI_FW_MP_REQUEST_UPDATE_EXP_STAT_SN (0x1<<2)
  416. #define ISCSI_FW_MP_REQUEST_UPDATE_EXP_STAT_SN_SHIFT 2
  417. #define ISCSI_FW_MP_REQUEST_RESERVED2 (0x1F<<3)
  418. #define ISCSI_FW_MP_REQUEST_RESERVED2_SHIFT 3
  419. u8 reserved3;
  420. u16 reserved4;
  421. #endif
  422. u32 bd_list_addr_lo;
  423. u32 bd_list_addr_hi;
  424. #if defined(__BIG_ENDIAN)
  425. u8 cq_index;
  426. u8 reserved6;
  427. u8 reserved5;
  428. u8 num_bds;
  429. #elif defined(__LITTLE_ENDIAN)
  430. u8 num_bds;
  431. u8 reserved5;
  432. u8 reserved6;
  433. u8 cq_index;
  434. #endif
  435. };
  436. /*
  437. * firmware response - CQE: used only by firmware
  438. */
  439. struct bnx2i_fw_response {
  440. u32 hdr_dword1[2];
  441. u32 hdr_exp_cmd_sn;
  442. u32 hdr_max_cmd_sn;
  443. u32 hdr_ttt;
  444. u32 hdr_res_cnt;
  445. u32 cqe_flags;
  446. #define ISCSI_FW_RESPONSE_RESERVED2 (0xFF<<0)
  447. #define ISCSI_FW_RESPONSE_RESERVED2_SHIFT 0
  448. #define ISCSI_FW_RESPONSE_ERR_CODE (0xFF<<8)
  449. #define ISCSI_FW_RESPONSE_ERR_CODE_SHIFT 8
  450. #define ISCSI_FW_RESPONSE_RESERVED3 (0xFFFF<<16)
  451. #define ISCSI_FW_RESPONSE_RESERVED3_SHIFT 16
  452. u32 stat_sn;
  453. u32 hdr_dword2[2];
  454. u32 hdr_dword3[2];
  455. u32 task_stat;
  456. u32 reserved0;
  457. u32 hdr_itt;
  458. u32 cq_req_sn;
  459. };
  460. /*
  461. * iSCSI KCQ CQE parameters
  462. */
  463. union iscsi_kcqe_params {
  464. u32 reserved0[4];
  465. };
  466. /*
  467. * iSCSI KCQ CQE
  468. */
  469. struct iscsi_kcqe {
  470. u32 iscsi_conn_id;
  471. u32 completion_status;
  472. u32 iscsi_conn_context_id;
  473. union iscsi_kcqe_params params;
  474. #if defined(__BIG_ENDIAN)
  475. u8 flags;
  476. #define ISCSI_KCQE_RESERVED0 (0xF<<0)
  477. #define ISCSI_KCQE_RESERVED0_SHIFT 0
  478. #define ISCSI_KCQE_LAYER_CODE (0x7<<4)
  479. #define ISCSI_KCQE_LAYER_CODE_SHIFT 4
  480. #define ISCSI_KCQE_RESERVED1 (0x1<<7)
  481. #define ISCSI_KCQE_RESERVED1_SHIFT 7
  482. u8 op_code;
  483. u16 qe_self_seq;
  484. #elif defined(__LITTLE_ENDIAN)
  485. u16 qe_self_seq;
  486. u8 op_code;
  487. u8 flags;
  488. #define ISCSI_KCQE_RESERVED0 (0xF<<0)
  489. #define ISCSI_KCQE_RESERVED0_SHIFT 0
  490. #define ISCSI_KCQE_LAYER_CODE (0x7<<4)
  491. #define ISCSI_KCQE_LAYER_CODE_SHIFT 4
  492. #define ISCSI_KCQE_RESERVED1 (0x1<<7)
  493. #define ISCSI_KCQE_RESERVED1_SHIFT 7
  494. #endif
  495. };
  496. /*
  497. * iSCSI KWQE header
  498. */
  499. struct iscsi_kwqe_header {
  500. #if defined(__BIG_ENDIAN)
  501. u8 flags;
  502. #define ISCSI_KWQE_HEADER_RESERVED0 (0xF<<0)
  503. #define ISCSI_KWQE_HEADER_RESERVED0_SHIFT 0
  504. #define ISCSI_KWQE_HEADER_LAYER_CODE (0x7<<4)
  505. #define ISCSI_KWQE_HEADER_LAYER_CODE_SHIFT 4
  506. #define ISCSI_KWQE_HEADER_RESERVED1 (0x1<<7)
  507. #define ISCSI_KWQE_HEADER_RESERVED1_SHIFT 7
  508. u8 op_code;
  509. #elif defined(__LITTLE_ENDIAN)
  510. u8 op_code;
  511. u8 flags;
  512. #define ISCSI_KWQE_HEADER_RESERVED0 (0xF<<0)
  513. #define ISCSI_KWQE_HEADER_RESERVED0_SHIFT 0
  514. #define ISCSI_KWQE_HEADER_LAYER_CODE (0x7<<4)
  515. #define ISCSI_KWQE_HEADER_LAYER_CODE_SHIFT 4
  516. #define ISCSI_KWQE_HEADER_RESERVED1 (0x1<<7)
  517. #define ISCSI_KWQE_HEADER_RESERVED1_SHIFT 7
  518. #endif
  519. };
  520. /*
  521. * iSCSI firmware init request 1
  522. */
  523. struct iscsi_kwqe_init1 {
  524. #if defined(__BIG_ENDIAN)
  525. struct iscsi_kwqe_header hdr;
  526. u8 reserved0;
  527. u8 num_cqs;
  528. #elif defined(__LITTLE_ENDIAN)
  529. u8 num_cqs;
  530. u8 reserved0;
  531. struct iscsi_kwqe_header hdr;
  532. #endif
  533. u32 dummy_buffer_addr_lo;
  534. u32 dummy_buffer_addr_hi;
  535. #if defined(__BIG_ENDIAN)
  536. u16 num_ccells_per_conn;
  537. u16 num_tasks_per_conn;
  538. #elif defined(__LITTLE_ENDIAN)
  539. u16 num_tasks_per_conn;
  540. u16 num_ccells_per_conn;
  541. #endif
  542. #if defined(__BIG_ENDIAN)
  543. u16 sq_wqes_per_page;
  544. u16 sq_num_wqes;
  545. #elif defined(__LITTLE_ENDIAN)
  546. u16 sq_num_wqes;
  547. u16 sq_wqes_per_page;
  548. #endif
  549. #if defined(__BIG_ENDIAN)
  550. u8 cq_log_wqes_per_page;
  551. u8 flags;
  552. #define ISCSI_KWQE_INIT1_PAGE_SIZE (0xF<<0)
  553. #define ISCSI_KWQE_INIT1_PAGE_SIZE_SHIFT 0
  554. #define ISCSI_KWQE_INIT1_DELAYED_ACK_ENABLE (0x1<<4)
  555. #define ISCSI_KWQE_INIT1_DELAYED_ACK_ENABLE_SHIFT 4
  556. #define ISCSI_KWQE_INIT1_KEEP_ALIVE_ENABLE (0x1<<5)
  557. #define ISCSI_KWQE_INIT1_KEEP_ALIVE_ENABLE_SHIFT 5
  558. #define ISCSI_KWQE_INIT1_TIME_STAMPS_ENABLE (0x1<<6)
  559. #define ISCSI_KWQE_INIT1_TIME_STAMPS_ENABLE_SHIFT 6
  560. #define ISCSI_KWQE_INIT1_RESERVED1 (0x1<<7)
  561. #define ISCSI_KWQE_INIT1_RESERVED1_SHIFT 7
  562. u16 cq_num_wqes;
  563. #elif defined(__LITTLE_ENDIAN)
  564. u16 cq_num_wqes;
  565. u8 flags;
  566. #define ISCSI_KWQE_INIT1_PAGE_SIZE (0xF<<0)
  567. #define ISCSI_KWQE_INIT1_PAGE_SIZE_SHIFT 0
  568. #define ISCSI_KWQE_INIT1_DELAYED_ACK_ENABLE (0x1<<4)
  569. #define ISCSI_KWQE_INIT1_DELAYED_ACK_ENABLE_SHIFT 4
  570. #define ISCSI_KWQE_INIT1_KEEP_ALIVE_ENABLE (0x1<<5)
  571. #define ISCSI_KWQE_INIT1_KEEP_ALIVE_ENABLE_SHIFT 5
  572. #define ISCSI_KWQE_INIT1_TIME_STAMPS_ENABLE (0x1<<6)
  573. #define ISCSI_KWQE_INIT1_TIME_STAMPS_ENABLE_SHIFT 6
  574. #define ISCSI_KWQE_INIT1_RESERVED1 (0x1<<7)
  575. #define ISCSI_KWQE_INIT1_RESERVED1_SHIFT 7
  576. u8 cq_log_wqes_per_page;
  577. #endif
  578. #if defined(__BIG_ENDIAN)
  579. u16 cq_num_pages;
  580. u16 sq_num_pages;
  581. #elif defined(__LITTLE_ENDIAN)
  582. u16 sq_num_pages;
  583. u16 cq_num_pages;
  584. #endif
  585. #if defined(__BIG_ENDIAN)
  586. u16 rq_buffer_size;
  587. u16 rq_num_wqes;
  588. #elif defined(__LITTLE_ENDIAN)
  589. u16 rq_num_wqes;
  590. u16 rq_buffer_size;
  591. #endif
  592. };
  593. /*
  594. * iSCSI firmware init request 2
  595. */
  596. struct iscsi_kwqe_init2 {
  597. #if defined(__BIG_ENDIAN)
  598. struct iscsi_kwqe_header hdr;
  599. u16 max_cq_sqn;
  600. #elif defined(__LITTLE_ENDIAN)
  601. u16 max_cq_sqn;
  602. struct iscsi_kwqe_header hdr;
  603. #endif
  604. u32 error_bit_map[2];
  605. u32 reserved1[5];
  606. };
  607. /*
  608. * Initial iSCSI connection offload request 1
  609. */
  610. struct iscsi_kwqe_conn_offload1 {
  611. #if defined(__BIG_ENDIAN)
  612. struct iscsi_kwqe_header hdr;
  613. u16 iscsi_conn_id;
  614. #elif defined(__LITTLE_ENDIAN)
  615. u16 iscsi_conn_id;
  616. struct iscsi_kwqe_header hdr;
  617. #endif
  618. u32 sq_page_table_addr_lo;
  619. u32 sq_page_table_addr_hi;
  620. u32 cq_page_table_addr_lo;
  621. u32 cq_page_table_addr_hi;
  622. u32 reserved0[3];
  623. };
  624. /*
  625. * iSCSI Page Table Entry (PTE)
  626. */
  627. struct iscsi_pte {
  628. u32 hi;
  629. u32 lo;
  630. };
  631. /*
  632. * Initial iSCSI connection offload request 2
  633. */
  634. struct iscsi_kwqe_conn_offload2 {
  635. #if defined(__BIG_ENDIAN)
  636. struct iscsi_kwqe_header hdr;
  637. u16 reserved0;
  638. #elif defined(__LITTLE_ENDIAN)
  639. u16 reserved0;
  640. struct iscsi_kwqe_header hdr;
  641. #endif
  642. u32 rq_page_table_addr_lo;
  643. u32 rq_page_table_addr_hi;
  644. struct iscsi_pte sq_first_pte;
  645. struct iscsi_pte cq_first_pte;
  646. u32 num_additional_wqes;
  647. };
  648. /*
  649. * Initial iSCSI connection offload request 3
  650. */
  651. struct iscsi_kwqe_conn_offload3 {
  652. #if defined(__BIG_ENDIAN)
  653. struct iscsi_kwqe_header hdr;
  654. u16 reserved0;
  655. #elif defined(__LITTLE_ENDIAN)
  656. u16 reserved0;
  657. struct iscsi_kwqe_header hdr;
  658. #endif
  659. u32 reserved1;
  660. struct iscsi_pte qp_first_pte[3];
  661. };
  662. /*
  663. * iSCSI connection update request
  664. */
  665. struct iscsi_kwqe_conn_update {
  666. #if defined(__BIG_ENDIAN)
  667. struct iscsi_kwqe_header hdr;
  668. u16 reserved0;
  669. #elif defined(__LITTLE_ENDIAN)
  670. u16 reserved0;
  671. struct iscsi_kwqe_header hdr;
  672. #endif
  673. #if defined(__BIG_ENDIAN)
  674. u8 session_error_recovery_level;
  675. u8 max_outstanding_r2ts;
  676. u8 reserved2;
  677. u8 conn_flags;
  678. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST (0x1<<0)
  679. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST_SHIFT 0
  680. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST (0x1<<1)
  681. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST_SHIFT 1
  682. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T (0x1<<2)
  683. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T_SHIFT 2
  684. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA (0x1<<3)
  685. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA_SHIFT 3
  686. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE (0x3<<4)
  687. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE_SHIFT 4
  688. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1 (0x3<<6)
  689. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1_SHIFT 6
  690. #elif defined(__LITTLE_ENDIAN)
  691. u8 conn_flags;
  692. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST (0x1<<0)
  693. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST_SHIFT 0
  694. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST (0x1<<1)
  695. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST_SHIFT 1
  696. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T (0x1<<2)
  697. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T_SHIFT 2
  698. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA (0x1<<3)
  699. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA_SHIFT 3
  700. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE (0x3<<4)
  701. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE_SHIFT 4
  702. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1 (0x3<<6)
  703. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1_SHIFT 6
  704. u8 reserved2;
  705. u8 max_outstanding_r2ts;
  706. u8 session_error_recovery_level;
  707. #endif
  708. u32 context_id;
  709. u32 max_send_pdu_length;
  710. u32 max_recv_pdu_length;
  711. u32 first_burst_length;
  712. u32 max_burst_length;
  713. u32 exp_stat_sn;
  714. };
  715. /*
  716. * iSCSI destroy connection request
  717. */
  718. struct iscsi_kwqe_conn_destroy {
  719. #if defined(__BIG_ENDIAN)
  720. struct iscsi_kwqe_header hdr;
  721. u16 reserved0;
  722. #elif defined(__LITTLE_ENDIAN)
  723. u16 reserved0;
  724. struct iscsi_kwqe_header hdr;
  725. #endif
  726. u32 context_id;
  727. u32 reserved1[6];
  728. };
  729. /*
  730. * iSCSI KWQ WQE
  731. */
  732. union iscsi_kwqe {
  733. struct iscsi_kwqe_init1 init1;
  734. struct iscsi_kwqe_init2 init2;
  735. struct iscsi_kwqe_conn_offload1 conn_offload1;
  736. struct iscsi_kwqe_conn_offload2 conn_offload2;
  737. struct iscsi_kwqe_conn_update conn_update;
  738. struct iscsi_kwqe_conn_destroy conn_destroy;
  739. };
  740. /*
  741. * iSCSI Login SQ WQE
  742. */
  743. struct bnx2i_login_request {
  744. #if defined(__BIG_ENDIAN)
  745. u8 op_code;
  746. u8 op_attr;
  747. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE (0x3<<0)
  748. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE_SHIFT 0
  749. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE (0x3<<2)
  750. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE_SHIFT 2
  751. #define ISCSI_LOGIN_REQUEST_RESERVED0 (0x3<<4)
  752. #define ISCSI_LOGIN_REQUEST_RESERVED0_SHIFT 4
  753. #define ISCSI_LOGIN_REQUEST_CONT (0x1<<6)
  754. #define ISCSI_LOGIN_REQUEST_CONT_SHIFT 6
  755. #define ISCSI_LOGIN_REQUEST_TRANSIT (0x1<<7)
  756. #define ISCSI_LOGIN_REQUEST_TRANSIT_SHIFT 7
  757. u8 version_max;
  758. u8 version_min;
  759. #elif defined(__LITTLE_ENDIAN)
  760. u8 version_min;
  761. u8 version_max;
  762. u8 op_attr;
  763. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE (0x3<<0)
  764. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE_SHIFT 0
  765. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE (0x3<<2)
  766. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE_SHIFT 2
  767. #define ISCSI_LOGIN_REQUEST_RESERVED0 (0x3<<4)
  768. #define ISCSI_LOGIN_REQUEST_RESERVED0_SHIFT 4
  769. #define ISCSI_LOGIN_REQUEST_CONT (0x1<<6)
  770. #define ISCSI_LOGIN_REQUEST_CONT_SHIFT 6
  771. #define ISCSI_LOGIN_REQUEST_TRANSIT (0x1<<7)
  772. #define ISCSI_LOGIN_REQUEST_TRANSIT_SHIFT 7
  773. u8 op_code;
  774. #endif
  775. u32 data_length;
  776. u32 isid_lo;
  777. #if defined(__BIG_ENDIAN)
  778. u16 isid_hi;
  779. u16 tsih;
  780. #elif defined(__LITTLE_ENDIAN)
  781. u16 tsih;
  782. u16 isid_hi;
  783. #endif
  784. #if defined(__BIG_ENDIAN)
  785. u16 reserved2;
  786. u16 itt;
  787. #define ISCSI_LOGIN_REQUEST_INDEX (0x3FFF<<0)
  788. #define ISCSI_LOGIN_REQUEST_INDEX_SHIFT 0
  789. #define ISCSI_LOGIN_REQUEST_TYPE (0x3<<14)
  790. #define ISCSI_LOGIN_REQUEST_TYPE_SHIFT 14
  791. #elif defined(__LITTLE_ENDIAN)
  792. u16 itt;
  793. #define ISCSI_LOGIN_REQUEST_INDEX (0x3FFF<<0)
  794. #define ISCSI_LOGIN_REQUEST_INDEX_SHIFT 0
  795. #define ISCSI_LOGIN_REQUEST_TYPE (0x3<<14)
  796. #define ISCSI_LOGIN_REQUEST_TYPE_SHIFT 14
  797. u16 reserved2;
  798. #endif
  799. #if defined(__BIG_ENDIAN)
  800. u16 cid;
  801. u16 reserved3;
  802. #elif defined(__LITTLE_ENDIAN)
  803. u16 reserved3;
  804. u16 cid;
  805. #endif
  806. u32 cmd_sn;
  807. u32 exp_stat_sn;
  808. u32 reserved4;
  809. u32 resp_bd_list_addr_lo;
  810. u32 resp_bd_list_addr_hi;
  811. u32 resp_buffer;
  812. #define ISCSI_LOGIN_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  813. #define ISCSI_LOGIN_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  814. #define ISCSI_LOGIN_REQUEST_NUM_RESP_BDS (0xFF<<24)
  815. #define ISCSI_LOGIN_REQUEST_NUM_RESP_BDS_SHIFT 24
  816. #if defined(__BIG_ENDIAN)
  817. u16 reserved8;
  818. u8 reserved7;
  819. u8 flags;
  820. #define ISCSI_LOGIN_REQUEST_RESERVED5 (0x3<<0)
  821. #define ISCSI_LOGIN_REQUEST_RESERVED5_SHIFT 0
  822. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN (0x1<<2)
  823. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN_SHIFT 2
  824. #define ISCSI_LOGIN_REQUEST_RESERVED6 (0x1F<<3)
  825. #define ISCSI_LOGIN_REQUEST_RESERVED6_SHIFT 3
  826. #elif defined(__LITTLE_ENDIAN)
  827. u8 flags;
  828. #define ISCSI_LOGIN_REQUEST_RESERVED5 (0x3<<0)
  829. #define ISCSI_LOGIN_REQUEST_RESERVED5_SHIFT 0
  830. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN (0x1<<2)
  831. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN_SHIFT 2
  832. #define ISCSI_LOGIN_REQUEST_RESERVED6 (0x1F<<3)
  833. #define ISCSI_LOGIN_REQUEST_RESERVED6_SHIFT 3
  834. u8 reserved7;
  835. u16 reserved8;
  836. #endif
  837. u32 bd_list_addr_lo;
  838. u32 bd_list_addr_hi;
  839. #if defined(__BIG_ENDIAN)
  840. u8 cq_index;
  841. u8 reserved10;
  842. u8 reserved9;
  843. u8 num_bds;
  844. #elif defined(__LITTLE_ENDIAN)
  845. u8 num_bds;
  846. u8 reserved9;
  847. u8 reserved10;
  848. u8 cq_index;
  849. #endif
  850. };
  851. /*
  852. * iSCSI Login CQE
  853. */
  854. struct bnx2i_login_response {
  855. #if defined(__BIG_ENDIAN)
  856. u8 op_code;
  857. u8 response_flags;
  858. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE (0x3<<0)
  859. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE_SHIFT 0
  860. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE (0x3<<2)
  861. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE_SHIFT 2
  862. #define ISCSI_LOGIN_RESPONSE_RESERVED0 (0x3<<4)
  863. #define ISCSI_LOGIN_RESPONSE_RESERVED0_SHIFT 4
  864. #define ISCSI_LOGIN_RESPONSE_CONT (0x1<<6)
  865. #define ISCSI_LOGIN_RESPONSE_CONT_SHIFT 6
  866. #define ISCSI_LOGIN_RESPONSE_TRANSIT (0x1<<7)
  867. #define ISCSI_LOGIN_RESPONSE_TRANSIT_SHIFT 7
  868. u8 version_max;
  869. u8 version_active;
  870. #elif defined(__LITTLE_ENDIAN)
  871. u8 version_active;
  872. u8 version_max;
  873. u8 response_flags;
  874. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE (0x3<<0)
  875. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE_SHIFT 0
  876. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE (0x3<<2)
  877. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE_SHIFT 2
  878. #define ISCSI_LOGIN_RESPONSE_RESERVED0 (0x3<<4)
  879. #define ISCSI_LOGIN_RESPONSE_RESERVED0_SHIFT 4
  880. #define ISCSI_LOGIN_RESPONSE_CONT (0x1<<6)
  881. #define ISCSI_LOGIN_RESPONSE_CONT_SHIFT 6
  882. #define ISCSI_LOGIN_RESPONSE_TRANSIT (0x1<<7)
  883. #define ISCSI_LOGIN_RESPONSE_TRANSIT_SHIFT 7
  884. u8 op_code;
  885. #endif
  886. u32 data_length;
  887. u32 exp_cmd_sn;
  888. u32 max_cmd_sn;
  889. u32 reserved1[2];
  890. #if defined(__BIG_ENDIAN)
  891. u16 reserved3;
  892. u8 err_code;
  893. u8 reserved2;
  894. #elif defined(__LITTLE_ENDIAN)
  895. u8 reserved2;
  896. u8 err_code;
  897. u16 reserved3;
  898. #endif
  899. u32 stat_sn;
  900. u32 isid_lo;
  901. #if defined(__BIG_ENDIAN)
  902. u16 isid_hi;
  903. u16 tsih;
  904. #elif defined(__LITTLE_ENDIAN)
  905. u16 tsih;
  906. u16 isid_hi;
  907. #endif
  908. #if defined(__BIG_ENDIAN)
  909. u8 status_class;
  910. u8 status_detail;
  911. u16 reserved4;
  912. #elif defined(__LITTLE_ENDIAN)
  913. u16 reserved4;
  914. u8 status_detail;
  915. u8 status_class;
  916. #endif
  917. u32 reserved5[3];
  918. #if defined(__BIG_ENDIAN)
  919. u16 reserved6;
  920. u16 itt;
  921. #define ISCSI_LOGIN_RESPONSE_INDEX (0x3FFF<<0)
  922. #define ISCSI_LOGIN_RESPONSE_INDEX_SHIFT 0
  923. #define ISCSI_LOGIN_RESPONSE_TYPE (0x3<<14)
  924. #define ISCSI_LOGIN_RESPONSE_TYPE_SHIFT 14
  925. #elif defined(__LITTLE_ENDIAN)
  926. u16 itt;
  927. #define ISCSI_LOGIN_RESPONSE_INDEX (0x3FFF<<0)
  928. #define ISCSI_LOGIN_RESPONSE_INDEX_SHIFT 0
  929. #define ISCSI_LOGIN_RESPONSE_TYPE (0x3<<14)
  930. #define ISCSI_LOGIN_RESPONSE_TYPE_SHIFT 14
  931. u16 reserved6;
  932. #endif
  933. u32 cq_req_sn;
  934. };
  935. /*
  936. * iSCSI Logout SQ WQE
  937. */
  938. struct bnx2i_logout_request {
  939. #if defined(__BIG_ENDIAN)
  940. u8 op_code;
  941. u8 op_attr;
  942. #define ISCSI_LOGOUT_REQUEST_REASON (0x7F<<0)
  943. #define ISCSI_LOGOUT_REQUEST_REASON_SHIFT 0
  944. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE (0x1<<7)
  945. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE_SHIFT 7
  946. u16 reserved0;
  947. #elif defined(__LITTLE_ENDIAN)
  948. u16 reserved0;
  949. u8 op_attr;
  950. #define ISCSI_LOGOUT_REQUEST_REASON (0x7F<<0)
  951. #define ISCSI_LOGOUT_REQUEST_REASON_SHIFT 0
  952. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE (0x1<<7)
  953. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE_SHIFT 7
  954. u8 op_code;
  955. #endif
  956. u32 data_length;
  957. u32 reserved1[2];
  958. #if defined(__BIG_ENDIAN)
  959. u16 reserved2;
  960. u16 itt;
  961. #define ISCSI_LOGOUT_REQUEST_INDEX (0x3FFF<<0)
  962. #define ISCSI_LOGOUT_REQUEST_INDEX_SHIFT 0
  963. #define ISCSI_LOGOUT_REQUEST_TYPE (0x3<<14)
  964. #define ISCSI_LOGOUT_REQUEST_TYPE_SHIFT 14
  965. #elif defined(__LITTLE_ENDIAN)
  966. u16 itt;
  967. #define ISCSI_LOGOUT_REQUEST_INDEX (0x3FFF<<0)
  968. #define ISCSI_LOGOUT_REQUEST_INDEX_SHIFT 0
  969. #define ISCSI_LOGOUT_REQUEST_TYPE (0x3<<14)
  970. #define ISCSI_LOGOUT_REQUEST_TYPE_SHIFT 14
  971. u16 reserved2;
  972. #endif
  973. #if defined(__BIG_ENDIAN)
  974. u16 cid;
  975. u16 reserved3;
  976. #elif defined(__LITTLE_ENDIAN)
  977. u16 reserved3;
  978. u16 cid;
  979. #endif
  980. u32 cmd_sn;
  981. u32 reserved4[5];
  982. u32 zero_fill;
  983. u32 bd_list_addr_lo;
  984. u32 bd_list_addr_hi;
  985. #if defined(__BIG_ENDIAN)
  986. u8 cq_index;
  987. u8 reserved6;
  988. u8 reserved5;
  989. u8 num_bds;
  990. #elif defined(__LITTLE_ENDIAN)
  991. u8 num_bds;
  992. u8 reserved5;
  993. u8 reserved6;
  994. u8 cq_index;
  995. #endif
  996. };
  997. /*
  998. * iSCSI Logout CQE
  999. */
  1000. struct bnx2i_logout_response {
  1001. #if defined(__BIG_ENDIAN)
  1002. u8 op_code;
  1003. u8 reserved1;
  1004. u8 response;
  1005. u8 reserved0;
  1006. #elif defined(__LITTLE_ENDIAN)
  1007. u8 reserved0;
  1008. u8 response;
  1009. u8 reserved1;
  1010. u8 op_code;
  1011. #endif
  1012. u32 reserved2;
  1013. u32 exp_cmd_sn;
  1014. u32 max_cmd_sn;
  1015. u32 reserved3[2];
  1016. #if defined(__BIG_ENDIAN)
  1017. u16 reserved5;
  1018. u8 err_code;
  1019. u8 reserved4;
  1020. #elif defined(__LITTLE_ENDIAN)
  1021. u8 reserved4;
  1022. u8 err_code;
  1023. u16 reserved5;
  1024. #endif
  1025. u32 reserved6[3];
  1026. #if defined(__BIG_ENDIAN)
  1027. u16 time_to_wait;
  1028. u16 time_to_retain;
  1029. #elif defined(__LITTLE_ENDIAN)
  1030. u16 time_to_retain;
  1031. u16 time_to_wait;
  1032. #endif
  1033. u32 reserved7[3];
  1034. #if defined(__BIG_ENDIAN)
  1035. u16 reserved8;
  1036. u16 itt;
  1037. #define ISCSI_LOGOUT_RESPONSE_INDEX (0x3FFF<<0)
  1038. #define ISCSI_LOGOUT_RESPONSE_INDEX_SHIFT 0
  1039. #define ISCSI_LOGOUT_RESPONSE_TYPE (0x3<<14)
  1040. #define ISCSI_LOGOUT_RESPONSE_TYPE_SHIFT 14
  1041. #elif defined(__LITTLE_ENDIAN)
  1042. u16 itt;
  1043. #define ISCSI_LOGOUT_RESPONSE_INDEX (0x3FFF<<0)
  1044. #define ISCSI_LOGOUT_RESPONSE_INDEX_SHIFT 0
  1045. #define ISCSI_LOGOUT_RESPONSE_TYPE (0x3<<14)
  1046. #define ISCSI_LOGOUT_RESPONSE_TYPE_SHIFT 14
  1047. u16 reserved8;
  1048. #endif
  1049. u32 cq_req_sn;
  1050. };
  1051. /*
  1052. * iSCSI Nop-In CQE
  1053. */
  1054. struct bnx2i_nop_in_msg {
  1055. #if defined(__BIG_ENDIAN)
  1056. u8 op_code;
  1057. u8 reserved1;
  1058. u16 reserved0;
  1059. #elif defined(__LITTLE_ENDIAN)
  1060. u16 reserved0;
  1061. u8 reserved1;
  1062. u8 op_code;
  1063. #endif
  1064. u32 data_length;
  1065. u32 exp_cmd_sn;
  1066. u32 max_cmd_sn;
  1067. u32 ttt;
  1068. u32 reserved2;
  1069. #if defined(__BIG_ENDIAN)
  1070. u16 reserved4;
  1071. u8 err_code;
  1072. u8 reserved3;
  1073. #elif defined(__LITTLE_ENDIAN)
  1074. u8 reserved3;
  1075. u8 err_code;
  1076. u16 reserved4;
  1077. #endif
  1078. u32 reserved5;
  1079. u32 lun[2];
  1080. u32 reserved6[4];
  1081. #if defined(__BIG_ENDIAN)
  1082. u16 reserved7;
  1083. u16 itt;
  1084. #define ISCSI_NOP_IN_MSG_INDEX (0x3FFF<<0)
  1085. #define ISCSI_NOP_IN_MSG_INDEX_SHIFT 0
  1086. #define ISCSI_NOP_IN_MSG_TYPE (0x3<<14)
  1087. #define ISCSI_NOP_IN_MSG_TYPE_SHIFT 14
  1088. #elif defined(__LITTLE_ENDIAN)
  1089. u16 itt;
  1090. #define ISCSI_NOP_IN_MSG_INDEX (0x3FFF<<0)
  1091. #define ISCSI_NOP_IN_MSG_INDEX_SHIFT 0
  1092. #define ISCSI_NOP_IN_MSG_TYPE (0x3<<14)
  1093. #define ISCSI_NOP_IN_MSG_TYPE_SHIFT 14
  1094. u16 reserved7;
  1095. #endif
  1096. u32 cq_req_sn;
  1097. };
  1098. /*
  1099. * iSCSI NOP-OUT SQ WQE
  1100. */
  1101. struct bnx2i_nop_out_request {
  1102. #if defined(__BIG_ENDIAN)
  1103. u8 op_code;
  1104. u8 op_attr;
  1105. #define ISCSI_NOP_OUT_REQUEST_RESERVED1 (0x7F<<0)
  1106. #define ISCSI_NOP_OUT_REQUEST_RESERVED1_SHIFT 0
  1107. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE (0x1<<7)
  1108. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE_SHIFT 7
  1109. u16 reserved0;
  1110. #elif defined(__LITTLE_ENDIAN)
  1111. u16 reserved0;
  1112. u8 op_attr;
  1113. #define ISCSI_NOP_OUT_REQUEST_RESERVED1 (0x7F<<0)
  1114. #define ISCSI_NOP_OUT_REQUEST_RESERVED1_SHIFT 0
  1115. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE (0x1<<7)
  1116. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE_SHIFT 7
  1117. u8 op_code;
  1118. #endif
  1119. u32 data_length;
  1120. u32 lun[2];
  1121. #if defined(__BIG_ENDIAN)
  1122. u16 reserved2;
  1123. u16 itt;
  1124. #define ISCSI_NOP_OUT_REQUEST_INDEX (0x3FFF<<0)
  1125. #define ISCSI_NOP_OUT_REQUEST_INDEX_SHIFT 0
  1126. #define ISCSI_NOP_OUT_REQUEST_TYPE (0x3<<14)
  1127. #define ISCSI_NOP_OUT_REQUEST_TYPE_SHIFT 14
  1128. #elif defined(__LITTLE_ENDIAN)
  1129. u16 itt;
  1130. #define ISCSI_NOP_OUT_REQUEST_INDEX (0x3FFF<<0)
  1131. #define ISCSI_NOP_OUT_REQUEST_INDEX_SHIFT 0
  1132. #define ISCSI_NOP_OUT_REQUEST_TYPE (0x3<<14)
  1133. #define ISCSI_NOP_OUT_REQUEST_TYPE_SHIFT 14
  1134. u16 reserved2;
  1135. #endif
  1136. u32 ttt;
  1137. u32 cmd_sn;
  1138. u32 reserved3[2];
  1139. u32 resp_bd_list_addr_lo;
  1140. u32 resp_bd_list_addr_hi;
  1141. u32 resp_buffer;
  1142. #define ISCSI_NOP_OUT_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  1143. #define ISCSI_NOP_OUT_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  1144. #define ISCSI_NOP_OUT_REQUEST_NUM_RESP_BDS (0xFF<<24)
  1145. #define ISCSI_NOP_OUT_REQUEST_NUM_RESP_BDS_SHIFT 24
  1146. #if defined(__BIG_ENDIAN)
  1147. u16 reserved7;
  1148. u8 reserved6;
  1149. u8 flags;
  1150. #define ISCSI_NOP_OUT_REQUEST_RESERVED4 (0x1<<0)
  1151. #define ISCSI_NOP_OUT_REQUEST_RESERVED4_SHIFT 0
  1152. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION (0x1<<1)
  1153. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION_SHIFT 1
  1154. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL (0x3F<<2)
  1155. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL_SHIFT 2
  1156. #elif defined(__LITTLE_ENDIAN)
  1157. u8 flags;
  1158. #define ISCSI_NOP_OUT_REQUEST_RESERVED4 (0x1<<0)
  1159. #define ISCSI_NOP_OUT_REQUEST_RESERVED4_SHIFT 0
  1160. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION (0x1<<1)
  1161. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION_SHIFT 1
  1162. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL (0x3F<<2)
  1163. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL_SHIFT 2
  1164. u8 reserved6;
  1165. u16 reserved7;
  1166. #endif
  1167. u32 bd_list_addr_lo;
  1168. u32 bd_list_addr_hi;
  1169. #if defined(__BIG_ENDIAN)
  1170. u8 cq_index;
  1171. u8 reserved9;
  1172. u8 reserved8;
  1173. u8 num_bds;
  1174. #elif defined(__LITTLE_ENDIAN)
  1175. u8 num_bds;
  1176. u8 reserved8;
  1177. u8 reserved9;
  1178. u8 cq_index;
  1179. #endif
  1180. };
  1181. /*
  1182. * iSCSI Reject CQE
  1183. */
  1184. struct bnx2i_reject_msg {
  1185. #if defined(__BIG_ENDIAN)
  1186. u8 op_code;
  1187. u8 reserved1;
  1188. u8 reason;
  1189. u8 reserved0;
  1190. #elif defined(__LITTLE_ENDIAN)
  1191. u8 reserved0;
  1192. u8 reason;
  1193. u8 reserved1;
  1194. u8 op_code;
  1195. #endif
  1196. u32 data_length;
  1197. u32 exp_cmd_sn;
  1198. u32 max_cmd_sn;
  1199. u32 reserved2[2];
  1200. #if defined(__BIG_ENDIAN)
  1201. u16 reserved4;
  1202. u8 err_code;
  1203. u8 reserved3;
  1204. #elif defined(__LITTLE_ENDIAN)
  1205. u8 reserved3;
  1206. u8 err_code;
  1207. u16 reserved4;
  1208. #endif
  1209. u32 reserved5[8];
  1210. u32 cq_req_sn;
  1211. };
  1212. /*
  1213. * bnx2i iSCSI TMF SQ WQE
  1214. */
  1215. struct bnx2i_tmf_request {
  1216. #if defined(__BIG_ENDIAN)
  1217. u8 op_code;
  1218. u8 op_attr;
  1219. #define ISCSI_TMF_REQUEST_FUNCTION (0x7F<<0)
  1220. #define ISCSI_TMF_REQUEST_FUNCTION_SHIFT 0
  1221. #define ISCSI_TMF_REQUEST_ALWAYS_ONE (0x1<<7)
  1222. #define ISCSI_TMF_REQUEST_ALWAYS_ONE_SHIFT 7
  1223. u16 reserved0;
  1224. #elif defined(__LITTLE_ENDIAN)
  1225. u16 reserved0;
  1226. u8 op_attr;
  1227. #define ISCSI_TMF_REQUEST_FUNCTION (0x7F<<0)
  1228. #define ISCSI_TMF_REQUEST_FUNCTION_SHIFT 0
  1229. #define ISCSI_TMF_REQUEST_ALWAYS_ONE (0x1<<7)
  1230. #define ISCSI_TMF_REQUEST_ALWAYS_ONE_SHIFT 7
  1231. u8 op_code;
  1232. #endif
  1233. u32 data_length;
  1234. u32 lun[2];
  1235. #if defined(__BIG_ENDIAN)
  1236. u16 reserved1;
  1237. u16 itt;
  1238. #define ISCSI_TMF_REQUEST_INDEX (0x3FFF<<0)
  1239. #define ISCSI_TMF_REQUEST_INDEX_SHIFT 0
  1240. #define ISCSI_TMF_REQUEST_TYPE (0x3<<14)
  1241. #define ISCSI_TMF_REQUEST_TYPE_SHIFT 14
  1242. #elif defined(__LITTLE_ENDIAN)
  1243. u16 itt;
  1244. #define ISCSI_TMF_REQUEST_INDEX (0x3FFF<<0)
  1245. #define ISCSI_TMF_REQUEST_INDEX_SHIFT 0
  1246. #define ISCSI_TMF_REQUEST_TYPE (0x3<<14)
  1247. #define ISCSI_TMF_REQUEST_TYPE_SHIFT 14
  1248. u16 reserved1;
  1249. #endif
  1250. u32 ref_itt;
  1251. u32 cmd_sn;
  1252. u32 reserved2;
  1253. u32 ref_cmd_sn;
  1254. u32 reserved3[3];
  1255. u32 zero_fill;
  1256. u32 bd_list_addr_lo;
  1257. u32 bd_list_addr_hi;
  1258. #if defined(__BIG_ENDIAN)
  1259. u8 cq_index;
  1260. u8 reserved5;
  1261. u8 reserved4;
  1262. u8 num_bds;
  1263. #elif defined(__LITTLE_ENDIAN)
  1264. u8 num_bds;
  1265. u8 reserved4;
  1266. u8 reserved5;
  1267. u8 cq_index;
  1268. #endif
  1269. };
  1270. /*
  1271. * iSCSI Text SQ WQE
  1272. */
  1273. struct bnx2i_text_request {
  1274. #if defined(__BIG_ENDIAN)
  1275. u8 op_code;
  1276. u8 op_attr;
  1277. #define ISCSI_TEXT_REQUEST_RESERVED1 (0x3F<<0)
  1278. #define ISCSI_TEXT_REQUEST_RESERVED1_SHIFT 0
  1279. #define ISCSI_TEXT_REQUEST_CONT (0x1<<6)
  1280. #define ISCSI_TEXT_REQUEST_CONT_SHIFT 6
  1281. #define ISCSI_TEXT_REQUEST_FINAL (0x1<<7)
  1282. #define ISCSI_TEXT_REQUEST_FINAL_SHIFT 7
  1283. u16 reserved0;
  1284. #elif defined(__LITTLE_ENDIAN)
  1285. u16 reserved0;
  1286. u8 op_attr;
  1287. #define ISCSI_TEXT_REQUEST_RESERVED1 (0x3F<<0)
  1288. #define ISCSI_TEXT_REQUEST_RESERVED1_SHIFT 0
  1289. #define ISCSI_TEXT_REQUEST_CONT (0x1<<6)
  1290. #define ISCSI_TEXT_REQUEST_CONT_SHIFT 6
  1291. #define ISCSI_TEXT_REQUEST_FINAL (0x1<<7)
  1292. #define ISCSI_TEXT_REQUEST_FINAL_SHIFT 7
  1293. u8 op_code;
  1294. #endif
  1295. u32 data_length;
  1296. u32 lun[2];
  1297. #if defined(__BIG_ENDIAN)
  1298. u16 reserved3;
  1299. u16 itt;
  1300. #define ISCSI_TEXT_REQUEST_INDEX (0x3FFF<<0)
  1301. #define ISCSI_TEXT_REQUEST_INDEX_SHIFT 0
  1302. #define ISCSI_TEXT_REQUEST_TYPE (0x3<<14)
  1303. #define ISCSI_TEXT_REQUEST_TYPE_SHIFT 14
  1304. #elif defined(__LITTLE_ENDIAN)
  1305. u16 itt;
  1306. #define ISCSI_TEXT_REQUEST_INDEX (0x3FFF<<0)
  1307. #define ISCSI_TEXT_REQUEST_INDEX_SHIFT 0
  1308. #define ISCSI_TEXT_REQUEST_TYPE (0x3<<14)
  1309. #define ISCSI_TEXT_REQUEST_TYPE_SHIFT 14
  1310. u16 reserved3;
  1311. #endif
  1312. u32 ttt;
  1313. u32 cmd_sn;
  1314. u32 reserved4[2];
  1315. u32 resp_bd_list_addr_lo;
  1316. u32 resp_bd_list_addr_hi;
  1317. u32 resp_buffer;
  1318. #define ISCSI_TEXT_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  1319. #define ISCSI_TEXT_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  1320. #define ISCSI_TEXT_REQUEST_NUM_RESP_BDS (0xFF<<24)
  1321. #define ISCSI_TEXT_REQUEST_NUM_RESP_BDS_SHIFT 24
  1322. u32 zero_fill;
  1323. u32 bd_list_addr_lo;
  1324. u32 bd_list_addr_hi;
  1325. #if defined(__BIG_ENDIAN)
  1326. u8 cq_index;
  1327. u8 reserved7;
  1328. u8 reserved6;
  1329. u8 num_bds;
  1330. #elif defined(__LITTLE_ENDIAN)
  1331. u8 num_bds;
  1332. u8 reserved6;
  1333. u8 reserved7;
  1334. u8 cq_index;
  1335. #endif
  1336. };
  1337. /*
  1338. * iSCSI SQ WQE
  1339. */
  1340. union iscsi_request {
  1341. struct bnx2i_cmd_request cmd;
  1342. struct bnx2i_tmf_request tmf;
  1343. struct bnx2i_nop_out_request nop_out;
  1344. struct bnx2i_login_request login_req;
  1345. struct bnx2i_text_request text;
  1346. struct bnx2i_logout_request logout_req;
  1347. struct bnx2i_cleanup_request cleanup;
  1348. };
  1349. /*
  1350. * iSCSI TMF CQE
  1351. */
  1352. struct bnx2i_tmf_response {
  1353. #if defined(__BIG_ENDIAN)
  1354. u8 op_code;
  1355. u8 reserved1;
  1356. u8 response;
  1357. u8 reserved0;
  1358. #elif defined(__LITTLE_ENDIAN)
  1359. u8 reserved0;
  1360. u8 response;
  1361. u8 reserved1;
  1362. u8 op_code;
  1363. #endif
  1364. u32 reserved2;
  1365. u32 exp_cmd_sn;
  1366. u32 max_cmd_sn;
  1367. u32 reserved3[2];
  1368. #if defined(__BIG_ENDIAN)
  1369. u16 reserved5;
  1370. u8 err_code;
  1371. u8 reserved4;
  1372. #elif defined(__LITTLE_ENDIAN)
  1373. u8 reserved4;
  1374. u8 err_code;
  1375. u16 reserved5;
  1376. #endif
  1377. u32 reserved6[7];
  1378. #if defined(__BIG_ENDIAN)
  1379. u16 reserved7;
  1380. u16 itt;
  1381. #define ISCSI_TMF_RESPONSE_INDEX (0x3FFF<<0)
  1382. #define ISCSI_TMF_RESPONSE_INDEX_SHIFT 0
  1383. #define ISCSI_TMF_RESPONSE_TYPE (0x3<<14)
  1384. #define ISCSI_TMF_RESPONSE_TYPE_SHIFT 14
  1385. #elif defined(__LITTLE_ENDIAN)
  1386. u16 itt;
  1387. #define ISCSI_TMF_RESPONSE_INDEX (0x3FFF<<0)
  1388. #define ISCSI_TMF_RESPONSE_INDEX_SHIFT 0
  1389. #define ISCSI_TMF_RESPONSE_TYPE (0x3<<14)
  1390. #define ISCSI_TMF_RESPONSE_TYPE_SHIFT 14
  1391. u16 reserved7;
  1392. #endif
  1393. u32 cq_req_sn;
  1394. };
  1395. /*
  1396. * iSCSI Text CQE
  1397. */
  1398. struct bnx2i_text_response {
  1399. #if defined(__BIG_ENDIAN)
  1400. u8 op_code;
  1401. u8 response_flags;
  1402. #define ISCSI_TEXT_RESPONSE_RESERVED1 (0x3F<<0)
  1403. #define ISCSI_TEXT_RESPONSE_RESERVED1_SHIFT 0
  1404. #define ISCSI_TEXT_RESPONSE_CONT (0x1<<6)
  1405. #define ISCSI_TEXT_RESPONSE_CONT_SHIFT 6
  1406. #define ISCSI_TEXT_RESPONSE_FINAL (0x1<<7)
  1407. #define ISCSI_TEXT_RESPONSE_FINAL_SHIFT 7
  1408. u16 reserved0;
  1409. #elif defined(__LITTLE_ENDIAN)
  1410. u16 reserved0;
  1411. u8 response_flags;
  1412. #define ISCSI_TEXT_RESPONSE_RESERVED1 (0x3F<<0)
  1413. #define ISCSI_TEXT_RESPONSE_RESERVED1_SHIFT 0
  1414. #define ISCSI_TEXT_RESPONSE_CONT (0x1<<6)
  1415. #define ISCSI_TEXT_RESPONSE_CONT_SHIFT 6
  1416. #define ISCSI_TEXT_RESPONSE_FINAL (0x1<<7)
  1417. #define ISCSI_TEXT_RESPONSE_FINAL_SHIFT 7
  1418. u8 op_code;
  1419. #endif
  1420. u32 data_length;
  1421. u32 exp_cmd_sn;
  1422. u32 max_cmd_sn;
  1423. u32 ttt;
  1424. u32 reserved2;
  1425. #if defined(__BIG_ENDIAN)
  1426. u16 reserved4;
  1427. u8 err_code;
  1428. u8 reserved3;
  1429. #elif defined(__LITTLE_ENDIAN)
  1430. u8 reserved3;
  1431. u8 err_code;
  1432. u16 reserved4;
  1433. #endif
  1434. u32 reserved5;
  1435. u32 lun[2];
  1436. u32 reserved6[4];
  1437. #if defined(__BIG_ENDIAN)
  1438. u16 reserved7;
  1439. u16 itt;
  1440. #define ISCSI_TEXT_RESPONSE_INDEX (0x3FFF<<0)
  1441. #define ISCSI_TEXT_RESPONSE_INDEX_SHIFT 0
  1442. #define ISCSI_TEXT_RESPONSE_TYPE (0x3<<14)
  1443. #define ISCSI_TEXT_RESPONSE_TYPE_SHIFT 14
  1444. #elif defined(__LITTLE_ENDIAN)
  1445. u16 itt;
  1446. #define ISCSI_TEXT_RESPONSE_INDEX (0x3FFF<<0)
  1447. #define ISCSI_TEXT_RESPONSE_INDEX_SHIFT 0
  1448. #define ISCSI_TEXT_RESPONSE_TYPE (0x3<<14)
  1449. #define ISCSI_TEXT_RESPONSE_TYPE_SHIFT 14
  1450. u16 reserved7;
  1451. #endif
  1452. u32 cq_req_sn;
  1453. };
  1454. /*
  1455. * iSCSI CQE
  1456. */
  1457. union iscsi_response {
  1458. struct bnx2i_cmd_response cmd;
  1459. struct bnx2i_tmf_response tmf;
  1460. struct bnx2i_login_response login_resp;
  1461. struct bnx2i_text_response text;
  1462. struct bnx2i_logout_response logout_resp;
  1463. struct bnx2i_cleanup_response cleanup;
  1464. struct bnx2i_reject_msg reject;
  1465. struct bnx2i_async_msg async;
  1466. struct bnx2i_nop_in_msg nop_in;
  1467. };
  1468. #endif /* __57XX_ISCSI_HSI_LINUX_LE__ */