57xx_iscsi_hsi.h 36 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520
  1. /* 57xx_iscsi_hsi.h: Broadcom NetXtreme II iSCSI HSI.
  2. *
  3. * Copyright (c) 2006 - 2012 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_RESERVED1 (0x3<<6)
  559. #define ISCSI_KWQE_INIT1_RESERVED1_SHIFT 6
  560. u16 cq_num_wqes;
  561. #elif defined(__LITTLE_ENDIAN)
  562. u16 cq_num_wqes;
  563. u8 flags;
  564. #define ISCSI_KWQE_INIT1_PAGE_SIZE (0xF<<0)
  565. #define ISCSI_KWQE_INIT1_PAGE_SIZE_SHIFT 0
  566. #define ISCSI_KWQE_INIT1_DELAYED_ACK_ENABLE (0x1<<4)
  567. #define ISCSI_KWQE_INIT1_DELAYED_ACK_ENABLE_SHIFT 4
  568. #define ISCSI_KWQE_INIT1_KEEP_ALIVE_ENABLE (0x1<<5)
  569. #define ISCSI_KWQE_INIT1_KEEP_ALIVE_ENABLE_SHIFT 5
  570. #define ISCSI_KWQE_INIT1_RESERVED1 (0x3<<6)
  571. #define ISCSI_KWQE_INIT1_RESERVED1_SHIFT 6
  572. u8 cq_log_wqes_per_page;
  573. #endif
  574. #if defined(__BIG_ENDIAN)
  575. u16 cq_num_pages;
  576. u16 sq_num_pages;
  577. #elif defined(__LITTLE_ENDIAN)
  578. u16 sq_num_pages;
  579. u16 cq_num_pages;
  580. #endif
  581. #if defined(__BIG_ENDIAN)
  582. u16 rq_buffer_size;
  583. u16 rq_num_wqes;
  584. #elif defined(__LITTLE_ENDIAN)
  585. u16 rq_num_wqes;
  586. u16 rq_buffer_size;
  587. #endif
  588. };
  589. /*
  590. * iSCSI firmware init request 2
  591. */
  592. struct iscsi_kwqe_init2 {
  593. #if defined(__BIG_ENDIAN)
  594. struct iscsi_kwqe_header hdr;
  595. u16 max_cq_sqn;
  596. #elif defined(__LITTLE_ENDIAN)
  597. u16 max_cq_sqn;
  598. struct iscsi_kwqe_header hdr;
  599. #endif
  600. u32 error_bit_map[2];
  601. u32 reserved1[5];
  602. };
  603. /*
  604. * Initial iSCSI connection offload request 1
  605. */
  606. struct iscsi_kwqe_conn_offload1 {
  607. #if defined(__BIG_ENDIAN)
  608. struct iscsi_kwqe_header hdr;
  609. u16 iscsi_conn_id;
  610. #elif defined(__LITTLE_ENDIAN)
  611. u16 iscsi_conn_id;
  612. struct iscsi_kwqe_header hdr;
  613. #endif
  614. u32 sq_page_table_addr_lo;
  615. u32 sq_page_table_addr_hi;
  616. u32 cq_page_table_addr_lo;
  617. u32 cq_page_table_addr_hi;
  618. u32 reserved0[3];
  619. };
  620. /*
  621. * iSCSI Page Table Entry (PTE)
  622. */
  623. struct iscsi_pte {
  624. u32 hi;
  625. u32 lo;
  626. };
  627. /*
  628. * Initial iSCSI connection offload request 2
  629. */
  630. struct iscsi_kwqe_conn_offload2 {
  631. #if defined(__BIG_ENDIAN)
  632. struct iscsi_kwqe_header hdr;
  633. u16 reserved0;
  634. #elif defined(__LITTLE_ENDIAN)
  635. u16 reserved0;
  636. struct iscsi_kwqe_header hdr;
  637. #endif
  638. u32 rq_page_table_addr_lo;
  639. u32 rq_page_table_addr_hi;
  640. struct iscsi_pte sq_first_pte;
  641. struct iscsi_pte cq_first_pte;
  642. u32 num_additional_wqes;
  643. };
  644. /*
  645. * Initial iSCSI connection offload request 3
  646. */
  647. struct iscsi_kwqe_conn_offload3 {
  648. #if defined(__BIG_ENDIAN)
  649. struct iscsi_kwqe_header hdr;
  650. u16 reserved0;
  651. #elif defined(__LITTLE_ENDIAN)
  652. u16 reserved0;
  653. struct iscsi_kwqe_header hdr;
  654. #endif
  655. u32 reserved1;
  656. struct iscsi_pte qp_first_pte[3];
  657. };
  658. /*
  659. * iSCSI connection update request
  660. */
  661. struct iscsi_kwqe_conn_update {
  662. #if defined(__BIG_ENDIAN)
  663. struct iscsi_kwqe_header hdr;
  664. u16 reserved0;
  665. #elif defined(__LITTLE_ENDIAN)
  666. u16 reserved0;
  667. struct iscsi_kwqe_header hdr;
  668. #endif
  669. #if defined(__BIG_ENDIAN)
  670. u8 session_error_recovery_level;
  671. u8 max_outstanding_r2ts;
  672. u8 reserved2;
  673. u8 conn_flags;
  674. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST (0x1<<0)
  675. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST_SHIFT 0
  676. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST (0x1<<1)
  677. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST_SHIFT 1
  678. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T (0x1<<2)
  679. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T_SHIFT 2
  680. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA (0x1<<3)
  681. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA_SHIFT 3
  682. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE (0x3<<4)
  683. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE_SHIFT 4
  684. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1 (0x3<<6)
  685. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1_SHIFT 6
  686. #elif defined(__LITTLE_ENDIAN)
  687. u8 conn_flags;
  688. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST (0x1<<0)
  689. #define ISCSI_KWQE_CONN_UPDATE_HEADER_DIGEST_SHIFT 0
  690. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST (0x1<<1)
  691. #define ISCSI_KWQE_CONN_UPDATE_DATA_DIGEST_SHIFT 1
  692. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T (0x1<<2)
  693. #define ISCSI_KWQE_CONN_UPDATE_INITIAL_R2T_SHIFT 2
  694. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA (0x1<<3)
  695. #define ISCSI_KWQE_CONN_UPDATE_IMMEDIATE_DATA_SHIFT 3
  696. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE (0x3<<4)
  697. #define ISCSI_KWQE_CONN_UPDATE_OOO_SUPPORT_MODE_SHIFT 4
  698. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1 (0x3<<6)
  699. #define ISCSI_KWQE_CONN_UPDATE_RESERVED1_SHIFT 6
  700. u8 reserved2;
  701. u8 max_outstanding_r2ts;
  702. u8 session_error_recovery_level;
  703. #endif
  704. u32 context_id;
  705. u32 max_send_pdu_length;
  706. u32 max_recv_pdu_length;
  707. u32 first_burst_length;
  708. u32 max_burst_length;
  709. u32 exp_stat_sn;
  710. };
  711. /*
  712. * iSCSI destroy connection request
  713. */
  714. struct iscsi_kwqe_conn_destroy {
  715. #if defined(__BIG_ENDIAN)
  716. struct iscsi_kwqe_header hdr;
  717. u16 reserved0;
  718. #elif defined(__LITTLE_ENDIAN)
  719. u16 reserved0;
  720. struct iscsi_kwqe_header hdr;
  721. #endif
  722. u32 context_id;
  723. u32 reserved1[6];
  724. };
  725. /*
  726. * iSCSI KWQ WQE
  727. */
  728. union iscsi_kwqe {
  729. struct iscsi_kwqe_init1 init1;
  730. struct iscsi_kwqe_init2 init2;
  731. struct iscsi_kwqe_conn_offload1 conn_offload1;
  732. struct iscsi_kwqe_conn_offload2 conn_offload2;
  733. struct iscsi_kwqe_conn_update conn_update;
  734. struct iscsi_kwqe_conn_destroy conn_destroy;
  735. };
  736. /*
  737. * iSCSI Login SQ WQE
  738. */
  739. struct bnx2i_login_request {
  740. #if defined(__BIG_ENDIAN)
  741. u8 op_code;
  742. u8 op_attr;
  743. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE (0x3<<0)
  744. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE_SHIFT 0
  745. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE (0x3<<2)
  746. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE_SHIFT 2
  747. #define ISCSI_LOGIN_REQUEST_RESERVED0 (0x3<<4)
  748. #define ISCSI_LOGIN_REQUEST_RESERVED0_SHIFT 4
  749. #define ISCSI_LOGIN_REQUEST_CONT (0x1<<6)
  750. #define ISCSI_LOGIN_REQUEST_CONT_SHIFT 6
  751. #define ISCSI_LOGIN_REQUEST_TRANSIT (0x1<<7)
  752. #define ISCSI_LOGIN_REQUEST_TRANSIT_SHIFT 7
  753. u8 version_max;
  754. u8 version_min;
  755. #elif defined(__LITTLE_ENDIAN)
  756. u8 version_min;
  757. u8 version_max;
  758. u8 op_attr;
  759. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE (0x3<<0)
  760. #define ISCSI_LOGIN_REQUEST_NEXT_STAGE_SHIFT 0
  761. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE (0x3<<2)
  762. #define ISCSI_LOGIN_REQUEST_CURRENT_STAGE_SHIFT 2
  763. #define ISCSI_LOGIN_REQUEST_RESERVED0 (0x3<<4)
  764. #define ISCSI_LOGIN_REQUEST_RESERVED0_SHIFT 4
  765. #define ISCSI_LOGIN_REQUEST_CONT (0x1<<6)
  766. #define ISCSI_LOGIN_REQUEST_CONT_SHIFT 6
  767. #define ISCSI_LOGIN_REQUEST_TRANSIT (0x1<<7)
  768. #define ISCSI_LOGIN_REQUEST_TRANSIT_SHIFT 7
  769. u8 op_code;
  770. #endif
  771. u32 data_length;
  772. u32 isid_lo;
  773. #if defined(__BIG_ENDIAN)
  774. u16 isid_hi;
  775. u16 tsih;
  776. #elif defined(__LITTLE_ENDIAN)
  777. u16 tsih;
  778. u16 isid_hi;
  779. #endif
  780. #if defined(__BIG_ENDIAN)
  781. u16 reserved2;
  782. u16 itt;
  783. #define ISCSI_LOGIN_REQUEST_INDEX (0x3FFF<<0)
  784. #define ISCSI_LOGIN_REQUEST_INDEX_SHIFT 0
  785. #define ISCSI_LOGIN_REQUEST_TYPE (0x3<<14)
  786. #define ISCSI_LOGIN_REQUEST_TYPE_SHIFT 14
  787. #elif defined(__LITTLE_ENDIAN)
  788. u16 itt;
  789. #define ISCSI_LOGIN_REQUEST_INDEX (0x3FFF<<0)
  790. #define ISCSI_LOGIN_REQUEST_INDEX_SHIFT 0
  791. #define ISCSI_LOGIN_REQUEST_TYPE (0x3<<14)
  792. #define ISCSI_LOGIN_REQUEST_TYPE_SHIFT 14
  793. u16 reserved2;
  794. #endif
  795. #if defined(__BIG_ENDIAN)
  796. u16 cid;
  797. u16 reserved3;
  798. #elif defined(__LITTLE_ENDIAN)
  799. u16 reserved3;
  800. u16 cid;
  801. #endif
  802. u32 cmd_sn;
  803. u32 exp_stat_sn;
  804. u32 reserved4;
  805. u32 resp_bd_list_addr_lo;
  806. u32 resp_bd_list_addr_hi;
  807. u32 resp_buffer;
  808. #define ISCSI_LOGIN_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  809. #define ISCSI_LOGIN_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  810. #define ISCSI_LOGIN_REQUEST_NUM_RESP_BDS (0xFF<<24)
  811. #define ISCSI_LOGIN_REQUEST_NUM_RESP_BDS_SHIFT 24
  812. #if defined(__BIG_ENDIAN)
  813. u16 reserved8;
  814. u8 reserved7;
  815. u8 flags;
  816. #define ISCSI_LOGIN_REQUEST_RESERVED5 (0x3<<0)
  817. #define ISCSI_LOGIN_REQUEST_RESERVED5_SHIFT 0
  818. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN (0x1<<2)
  819. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN_SHIFT 2
  820. #define ISCSI_LOGIN_REQUEST_RESERVED6 (0x1F<<3)
  821. #define ISCSI_LOGIN_REQUEST_RESERVED6_SHIFT 3
  822. #elif defined(__LITTLE_ENDIAN)
  823. u8 flags;
  824. #define ISCSI_LOGIN_REQUEST_RESERVED5 (0x3<<0)
  825. #define ISCSI_LOGIN_REQUEST_RESERVED5_SHIFT 0
  826. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN (0x1<<2)
  827. #define ISCSI_LOGIN_REQUEST_UPDATE_EXP_STAT_SN_SHIFT 2
  828. #define ISCSI_LOGIN_REQUEST_RESERVED6 (0x1F<<3)
  829. #define ISCSI_LOGIN_REQUEST_RESERVED6_SHIFT 3
  830. u8 reserved7;
  831. u16 reserved8;
  832. #endif
  833. u32 bd_list_addr_lo;
  834. u32 bd_list_addr_hi;
  835. #if defined(__BIG_ENDIAN)
  836. u8 cq_index;
  837. u8 reserved10;
  838. u8 reserved9;
  839. u8 num_bds;
  840. #elif defined(__LITTLE_ENDIAN)
  841. u8 num_bds;
  842. u8 reserved9;
  843. u8 reserved10;
  844. u8 cq_index;
  845. #endif
  846. };
  847. /*
  848. * iSCSI Login CQE
  849. */
  850. struct bnx2i_login_response {
  851. #if defined(__BIG_ENDIAN)
  852. u8 op_code;
  853. u8 response_flags;
  854. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE (0x3<<0)
  855. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE_SHIFT 0
  856. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE (0x3<<2)
  857. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE_SHIFT 2
  858. #define ISCSI_LOGIN_RESPONSE_RESERVED0 (0x3<<4)
  859. #define ISCSI_LOGIN_RESPONSE_RESERVED0_SHIFT 4
  860. #define ISCSI_LOGIN_RESPONSE_CONT (0x1<<6)
  861. #define ISCSI_LOGIN_RESPONSE_CONT_SHIFT 6
  862. #define ISCSI_LOGIN_RESPONSE_TRANSIT (0x1<<7)
  863. #define ISCSI_LOGIN_RESPONSE_TRANSIT_SHIFT 7
  864. u8 version_max;
  865. u8 version_active;
  866. #elif defined(__LITTLE_ENDIAN)
  867. u8 version_active;
  868. u8 version_max;
  869. u8 response_flags;
  870. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE (0x3<<0)
  871. #define ISCSI_LOGIN_RESPONSE_NEXT_STAGE_SHIFT 0
  872. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE (0x3<<2)
  873. #define ISCSI_LOGIN_RESPONSE_CURRENT_STAGE_SHIFT 2
  874. #define ISCSI_LOGIN_RESPONSE_RESERVED0 (0x3<<4)
  875. #define ISCSI_LOGIN_RESPONSE_RESERVED0_SHIFT 4
  876. #define ISCSI_LOGIN_RESPONSE_CONT (0x1<<6)
  877. #define ISCSI_LOGIN_RESPONSE_CONT_SHIFT 6
  878. #define ISCSI_LOGIN_RESPONSE_TRANSIT (0x1<<7)
  879. #define ISCSI_LOGIN_RESPONSE_TRANSIT_SHIFT 7
  880. u8 op_code;
  881. #endif
  882. u32 data_length;
  883. u32 exp_cmd_sn;
  884. u32 max_cmd_sn;
  885. u32 reserved1[2];
  886. #if defined(__BIG_ENDIAN)
  887. u16 reserved3;
  888. u8 err_code;
  889. u8 reserved2;
  890. #elif defined(__LITTLE_ENDIAN)
  891. u8 reserved2;
  892. u8 err_code;
  893. u16 reserved3;
  894. #endif
  895. u32 stat_sn;
  896. u32 isid_lo;
  897. #if defined(__BIG_ENDIAN)
  898. u16 isid_hi;
  899. u16 tsih;
  900. #elif defined(__LITTLE_ENDIAN)
  901. u16 tsih;
  902. u16 isid_hi;
  903. #endif
  904. #if defined(__BIG_ENDIAN)
  905. u8 status_class;
  906. u8 status_detail;
  907. u16 reserved4;
  908. #elif defined(__LITTLE_ENDIAN)
  909. u16 reserved4;
  910. u8 status_detail;
  911. u8 status_class;
  912. #endif
  913. u32 reserved5[3];
  914. #if defined(__BIG_ENDIAN)
  915. u16 reserved6;
  916. u16 itt;
  917. #define ISCSI_LOGIN_RESPONSE_INDEX (0x3FFF<<0)
  918. #define ISCSI_LOGIN_RESPONSE_INDEX_SHIFT 0
  919. #define ISCSI_LOGIN_RESPONSE_TYPE (0x3<<14)
  920. #define ISCSI_LOGIN_RESPONSE_TYPE_SHIFT 14
  921. #elif defined(__LITTLE_ENDIAN)
  922. u16 itt;
  923. #define ISCSI_LOGIN_RESPONSE_INDEX (0x3FFF<<0)
  924. #define ISCSI_LOGIN_RESPONSE_INDEX_SHIFT 0
  925. #define ISCSI_LOGIN_RESPONSE_TYPE (0x3<<14)
  926. #define ISCSI_LOGIN_RESPONSE_TYPE_SHIFT 14
  927. u16 reserved6;
  928. #endif
  929. u32 cq_req_sn;
  930. };
  931. /*
  932. * iSCSI Logout SQ WQE
  933. */
  934. struct bnx2i_logout_request {
  935. #if defined(__BIG_ENDIAN)
  936. u8 op_code;
  937. u8 op_attr;
  938. #define ISCSI_LOGOUT_REQUEST_REASON (0x7F<<0)
  939. #define ISCSI_LOGOUT_REQUEST_REASON_SHIFT 0
  940. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE (0x1<<7)
  941. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE_SHIFT 7
  942. u16 reserved0;
  943. #elif defined(__LITTLE_ENDIAN)
  944. u16 reserved0;
  945. u8 op_attr;
  946. #define ISCSI_LOGOUT_REQUEST_REASON (0x7F<<0)
  947. #define ISCSI_LOGOUT_REQUEST_REASON_SHIFT 0
  948. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE (0x1<<7)
  949. #define ISCSI_LOGOUT_REQUEST_ALWAYS_ONE_SHIFT 7
  950. u8 op_code;
  951. #endif
  952. u32 data_length;
  953. u32 reserved1[2];
  954. #if defined(__BIG_ENDIAN)
  955. u16 reserved2;
  956. u16 itt;
  957. #define ISCSI_LOGOUT_REQUEST_INDEX (0x3FFF<<0)
  958. #define ISCSI_LOGOUT_REQUEST_INDEX_SHIFT 0
  959. #define ISCSI_LOGOUT_REQUEST_TYPE (0x3<<14)
  960. #define ISCSI_LOGOUT_REQUEST_TYPE_SHIFT 14
  961. #elif defined(__LITTLE_ENDIAN)
  962. u16 itt;
  963. #define ISCSI_LOGOUT_REQUEST_INDEX (0x3FFF<<0)
  964. #define ISCSI_LOGOUT_REQUEST_INDEX_SHIFT 0
  965. #define ISCSI_LOGOUT_REQUEST_TYPE (0x3<<14)
  966. #define ISCSI_LOGOUT_REQUEST_TYPE_SHIFT 14
  967. u16 reserved2;
  968. #endif
  969. #if defined(__BIG_ENDIAN)
  970. u16 cid;
  971. u16 reserved3;
  972. #elif defined(__LITTLE_ENDIAN)
  973. u16 reserved3;
  974. u16 cid;
  975. #endif
  976. u32 cmd_sn;
  977. u32 reserved4[5];
  978. u32 zero_fill;
  979. u32 bd_list_addr_lo;
  980. u32 bd_list_addr_hi;
  981. #if defined(__BIG_ENDIAN)
  982. u8 cq_index;
  983. u8 reserved6;
  984. u8 reserved5;
  985. u8 num_bds;
  986. #elif defined(__LITTLE_ENDIAN)
  987. u8 num_bds;
  988. u8 reserved5;
  989. u8 reserved6;
  990. u8 cq_index;
  991. #endif
  992. };
  993. /*
  994. * iSCSI Logout CQE
  995. */
  996. struct bnx2i_logout_response {
  997. #if defined(__BIG_ENDIAN)
  998. u8 op_code;
  999. u8 reserved1;
  1000. u8 response;
  1001. u8 reserved0;
  1002. #elif defined(__LITTLE_ENDIAN)
  1003. u8 reserved0;
  1004. u8 response;
  1005. u8 reserved1;
  1006. u8 op_code;
  1007. #endif
  1008. u32 reserved2;
  1009. u32 exp_cmd_sn;
  1010. u32 max_cmd_sn;
  1011. u32 reserved3[2];
  1012. #if defined(__BIG_ENDIAN)
  1013. u16 reserved5;
  1014. u8 err_code;
  1015. u8 reserved4;
  1016. #elif defined(__LITTLE_ENDIAN)
  1017. u8 reserved4;
  1018. u8 err_code;
  1019. u16 reserved5;
  1020. #endif
  1021. u32 reserved6[3];
  1022. #if defined(__BIG_ENDIAN)
  1023. u16 time_to_wait;
  1024. u16 time_to_retain;
  1025. #elif defined(__LITTLE_ENDIAN)
  1026. u16 time_to_retain;
  1027. u16 time_to_wait;
  1028. #endif
  1029. u32 reserved7[3];
  1030. #if defined(__BIG_ENDIAN)
  1031. u16 reserved8;
  1032. u16 itt;
  1033. #define ISCSI_LOGOUT_RESPONSE_INDEX (0x3FFF<<0)
  1034. #define ISCSI_LOGOUT_RESPONSE_INDEX_SHIFT 0
  1035. #define ISCSI_LOGOUT_RESPONSE_TYPE (0x3<<14)
  1036. #define ISCSI_LOGOUT_RESPONSE_TYPE_SHIFT 14
  1037. #elif defined(__LITTLE_ENDIAN)
  1038. u16 itt;
  1039. #define ISCSI_LOGOUT_RESPONSE_INDEX (0x3FFF<<0)
  1040. #define ISCSI_LOGOUT_RESPONSE_INDEX_SHIFT 0
  1041. #define ISCSI_LOGOUT_RESPONSE_TYPE (0x3<<14)
  1042. #define ISCSI_LOGOUT_RESPONSE_TYPE_SHIFT 14
  1043. u16 reserved8;
  1044. #endif
  1045. u32 cq_req_sn;
  1046. };
  1047. /*
  1048. * iSCSI Nop-In CQE
  1049. */
  1050. struct bnx2i_nop_in_msg {
  1051. #if defined(__BIG_ENDIAN)
  1052. u8 op_code;
  1053. u8 reserved1;
  1054. u16 reserved0;
  1055. #elif defined(__LITTLE_ENDIAN)
  1056. u16 reserved0;
  1057. u8 reserved1;
  1058. u8 op_code;
  1059. #endif
  1060. u32 data_length;
  1061. u32 exp_cmd_sn;
  1062. u32 max_cmd_sn;
  1063. u32 ttt;
  1064. u32 reserved2;
  1065. #if defined(__BIG_ENDIAN)
  1066. u16 reserved4;
  1067. u8 err_code;
  1068. u8 reserved3;
  1069. #elif defined(__LITTLE_ENDIAN)
  1070. u8 reserved3;
  1071. u8 err_code;
  1072. u16 reserved4;
  1073. #endif
  1074. u32 reserved5;
  1075. u32 lun[2];
  1076. u32 reserved6[4];
  1077. #if defined(__BIG_ENDIAN)
  1078. u16 reserved7;
  1079. u16 itt;
  1080. #define ISCSI_NOP_IN_MSG_INDEX (0x3FFF<<0)
  1081. #define ISCSI_NOP_IN_MSG_INDEX_SHIFT 0
  1082. #define ISCSI_NOP_IN_MSG_TYPE (0x3<<14)
  1083. #define ISCSI_NOP_IN_MSG_TYPE_SHIFT 14
  1084. #elif defined(__LITTLE_ENDIAN)
  1085. u16 itt;
  1086. #define ISCSI_NOP_IN_MSG_INDEX (0x3FFF<<0)
  1087. #define ISCSI_NOP_IN_MSG_INDEX_SHIFT 0
  1088. #define ISCSI_NOP_IN_MSG_TYPE (0x3<<14)
  1089. #define ISCSI_NOP_IN_MSG_TYPE_SHIFT 14
  1090. u16 reserved7;
  1091. #endif
  1092. u32 cq_req_sn;
  1093. };
  1094. /*
  1095. * iSCSI NOP-OUT SQ WQE
  1096. */
  1097. struct bnx2i_nop_out_request {
  1098. #if defined(__BIG_ENDIAN)
  1099. u8 op_code;
  1100. u8 op_attr;
  1101. #define ISCSI_NOP_OUT_REQUEST_RESERVED1 (0x7F<<0)
  1102. #define ISCSI_NOP_OUT_REQUEST_RESERVED1_SHIFT 0
  1103. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE (0x1<<7)
  1104. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE_SHIFT 7
  1105. u16 reserved0;
  1106. #elif defined(__LITTLE_ENDIAN)
  1107. u16 reserved0;
  1108. u8 op_attr;
  1109. #define ISCSI_NOP_OUT_REQUEST_RESERVED1 (0x7F<<0)
  1110. #define ISCSI_NOP_OUT_REQUEST_RESERVED1_SHIFT 0
  1111. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE (0x1<<7)
  1112. #define ISCSI_NOP_OUT_REQUEST_ALWAYS_ONE_SHIFT 7
  1113. u8 op_code;
  1114. #endif
  1115. u32 data_length;
  1116. u32 lun[2];
  1117. #if defined(__BIG_ENDIAN)
  1118. u16 reserved2;
  1119. u16 itt;
  1120. #define ISCSI_NOP_OUT_REQUEST_INDEX (0x3FFF<<0)
  1121. #define ISCSI_NOP_OUT_REQUEST_INDEX_SHIFT 0
  1122. #define ISCSI_NOP_OUT_REQUEST_TYPE (0x3<<14)
  1123. #define ISCSI_NOP_OUT_REQUEST_TYPE_SHIFT 14
  1124. #elif defined(__LITTLE_ENDIAN)
  1125. u16 itt;
  1126. #define ISCSI_NOP_OUT_REQUEST_INDEX (0x3FFF<<0)
  1127. #define ISCSI_NOP_OUT_REQUEST_INDEX_SHIFT 0
  1128. #define ISCSI_NOP_OUT_REQUEST_TYPE (0x3<<14)
  1129. #define ISCSI_NOP_OUT_REQUEST_TYPE_SHIFT 14
  1130. u16 reserved2;
  1131. #endif
  1132. u32 ttt;
  1133. u32 cmd_sn;
  1134. u32 reserved3[2];
  1135. u32 resp_bd_list_addr_lo;
  1136. u32 resp_bd_list_addr_hi;
  1137. u32 resp_buffer;
  1138. #define ISCSI_NOP_OUT_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  1139. #define ISCSI_NOP_OUT_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  1140. #define ISCSI_NOP_OUT_REQUEST_NUM_RESP_BDS (0xFF<<24)
  1141. #define ISCSI_NOP_OUT_REQUEST_NUM_RESP_BDS_SHIFT 24
  1142. #if defined(__BIG_ENDIAN)
  1143. u16 reserved7;
  1144. u8 reserved6;
  1145. u8 flags;
  1146. #define ISCSI_NOP_OUT_REQUEST_RESERVED4 (0x1<<0)
  1147. #define ISCSI_NOP_OUT_REQUEST_RESERVED4_SHIFT 0
  1148. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION (0x1<<1)
  1149. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION_SHIFT 1
  1150. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL (0x3F<<2)
  1151. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL_SHIFT 2
  1152. #elif defined(__LITTLE_ENDIAN)
  1153. u8 flags;
  1154. #define ISCSI_NOP_OUT_REQUEST_RESERVED4 (0x1<<0)
  1155. #define ISCSI_NOP_OUT_REQUEST_RESERVED4_SHIFT 0
  1156. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION (0x1<<1)
  1157. #define ISCSI_NOP_OUT_REQUEST_LOCAL_COMPLETION_SHIFT 1
  1158. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL (0x3F<<2)
  1159. #define ISCSI_NOP_OUT_REQUEST_ZERO_FILL_SHIFT 2
  1160. u8 reserved6;
  1161. u16 reserved7;
  1162. #endif
  1163. u32 bd_list_addr_lo;
  1164. u32 bd_list_addr_hi;
  1165. #if defined(__BIG_ENDIAN)
  1166. u8 cq_index;
  1167. u8 reserved9;
  1168. u8 reserved8;
  1169. u8 num_bds;
  1170. #elif defined(__LITTLE_ENDIAN)
  1171. u8 num_bds;
  1172. u8 reserved8;
  1173. u8 reserved9;
  1174. u8 cq_index;
  1175. #endif
  1176. };
  1177. /*
  1178. * iSCSI Reject CQE
  1179. */
  1180. struct bnx2i_reject_msg {
  1181. #if defined(__BIG_ENDIAN)
  1182. u8 op_code;
  1183. u8 reserved1;
  1184. u8 reason;
  1185. u8 reserved0;
  1186. #elif defined(__LITTLE_ENDIAN)
  1187. u8 reserved0;
  1188. u8 reason;
  1189. u8 reserved1;
  1190. u8 op_code;
  1191. #endif
  1192. u32 data_length;
  1193. u32 exp_cmd_sn;
  1194. u32 max_cmd_sn;
  1195. u32 reserved2[2];
  1196. #if defined(__BIG_ENDIAN)
  1197. u16 reserved4;
  1198. u8 err_code;
  1199. u8 reserved3;
  1200. #elif defined(__LITTLE_ENDIAN)
  1201. u8 reserved3;
  1202. u8 err_code;
  1203. u16 reserved4;
  1204. #endif
  1205. u32 reserved5[8];
  1206. u32 cq_req_sn;
  1207. };
  1208. /*
  1209. * bnx2i iSCSI TMF SQ WQE
  1210. */
  1211. struct bnx2i_tmf_request {
  1212. #if defined(__BIG_ENDIAN)
  1213. u8 op_code;
  1214. u8 op_attr;
  1215. #define ISCSI_TMF_REQUEST_FUNCTION (0x7F<<0)
  1216. #define ISCSI_TMF_REQUEST_FUNCTION_SHIFT 0
  1217. #define ISCSI_TMF_REQUEST_ALWAYS_ONE (0x1<<7)
  1218. #define ISCSI_TMF_REQUEST_ALWAYS_ONE_SHIFT 7
  1219. u16 reserved0;
  1220. #elif defined(__LITTLE_ENDIAN)
  1221. u16 reserved0;
  1222. u8 op_attr;
  1223. #define ISCSI_TMF_REQUEST_FUNCTION (0x7F<<0)
  1224. #define ISCSI_TMF_REQUEST_FUNCTION_SHIFT 0
  1225. #define ISCSI_TMF_REQUEST_ALWAYS_ONE (0x1<<7)
  1226. #define ISCSI_TMF_REQUEST_ALWAYS_ONE_SHIFT 7
  1227. u8 op_code;
  1228. #endif
  1229. u32 data_length;
  1230. u32 lun[2];
  1231. #if defined(__BIG_ENDIAN)
  1232. u16 reserved1;
  1233. u16 itt;
  1234. #define ISCSI_TMF_REQUEST_INDEX (0x3FFF<<0)
  1235. #define ISCSI_TMF_REQUEST_INDEX_SHIFT 0
  1236. #define ISCSI_TMF_REQUEST_TYPE (0x3<<14)
  1237. #define ISCSI_TMF_REQUEST_TYPE_SHIFT 14
  1238. #elif defined(__LITTLE_ENDIAN)
  1239. u16 itt;
  1240. #define ISCSI_TMF_REQUEST_INDEX (0x3FFF<<0)
  1241. #define ISCSI_TMF_REQUEST_INDEX_SHIFT 0
  1242. #define ISCSI_TMF_REQUEST_TYPE (0x3<<14)
  1243. #define ISCSI_TMF_REQUEST_TYPE_SHIFT 14
  1244. u16 reserved1;
  1245. #endif
  1246. u32 ref_itt;
  1247. u32 cmd_sn;
  1248. u32 reserved2;
  1249. u32 ref_cmd_sn;
  1250. u32 reserved3[3];
  1251. u32 zero_fill;
  1252. u32 bd_list_addr_lo;
  1253. u32 bd_list_addr_hi;
  1254. #if defined(__BIG_ENDIAN)
  1255. u8 cq_index;
  1256. u8 reserved5;
  1257. u8 reserved4;
  1258. u8 num_bds;
  1259. #elif defined(__LITTLE_ENDIAN)
  1260. u8 num_bds;
  1261. u8 reserved4;
  1262. u8 reserved5;
  1263. u8 cq_index;
  1264. #endif
  1265. };
  1266. /*
  1267. * iSCSI Text SQ WQE
  1268. */
  1269. struct bnx2i_text_request {
  1270. #if defined(__BIG_ENDIAN)
  1271. u8 op_code;
  1272. u8 op_attr;
  1273. #define ISCSI_TEXT_REQUEST_RESERVED1 (0x3F<<0)
  1274. #define ISCSI_TEXT_REQUEST_RESERVED1_SHIFT 0
  1275. #define ISCSI_TEXT_REQUEST_CONT (0x1<<6)
  1276. #define ISCSI_TEXT_REQUEST_CONT_SHIFT 6
  1277. #define ISCSI_TEXT_REQUEST_FINAL (0x1<<7)
  1278. #define ISCSI_TEXT_REQUEST_FINAL_SHIFT 7
  1279. u16 reserved0;
  1280. #elif defined(__LITTLE_ENDIAN)
  1281. u16 reserved0;
  1282. u8 op_attr;
  1283. #define ISCSI_TEXT_REQUEST_RESERVED1 (0x3F<<0)
  1284. #define ISCSI_TEXT_REQUEST_RESERVED1_SHIFT 0
  1285. #define ISCSI_TEXT_REQUEST_CONT (0x1<<6)
  1286. #define ISCSI_TEXT_REQUEST_CONT_SHIFT 6
  1287. #define ISCSI_TEXT_REQUEST_FINAL (0x1<<7)
  1288. #define ISCSI_TEXT_REQUEST_FINAL_SHIFT 7
  1289. u8 op_code;
  1290. #endif
  1291. u32 data_length;
  1292. u32 lun[2];
  1293. #if defined(__BIG_ENDIAN)
  1294. u16 reserved3;
  1295. u16 itt;
  1296. #define ISCSI_TEXT_REQUEST_INDEX (0x3FFF<<0)
  1297. #define ISCSI_TEXT_REQUEST_INDEX_SHIFT 0
  1298. #define ISCSI_TEXT_REQUEST_TYPE (0x3<<14)
  1299. #define ISCSI_TEXT_REQUEST_TYPE_SHIFT 14
  1300. #elif defined(__LITTLE_ENDIAN)
  1301. u16 itt;
  1302. #define ISCSI_TEXT_REQUEST_INDEX (0x3FFF<<0)
  1303. #define ISCSI_TEXT_REQUEST_INDEX_SHIFT 0
  1304. #define ISCSI_TEXT_REQUEST_TYPE (0x3<<14)
  1305. #define ISCSI_TEXT_REQUEST_TYPE_SHIFT 14
  1306. u16 reserved3;
  1307. #endif
  1308. u32 ttt;
  1309. u32 cmd_sn;
  1310. u32 reserved4[2];
  1311. u32 resp_bd_list_addr_lo;
  1312. u32 resp_bd_list_addr_hi;
  1313. u32 resp_buffer;
  1314. #define ISCSI_TEXT_REQUEST_RESP_BUFFER_LENGTH (0xFFFFFF<<0)
  1315. #define ISCSI_TEXT_REQUEST_RESP_BUFFER_LENGTH_SHIFT 0
  1316. #define ISCSI_TEXT_REQUEST_NUM_RESP_BDS (0xFF<<24)
  1317. #define ISCSI_TEXT_REQUEST_NUM_RESP_BDS_SHIFT 24
  1318. u32 zero_fill;
  1319. u32 bd_list_addr_lo;
  1320. u32 bd_list_addr_hi;
  1321. #if defined(__BIG_ENDIAN)
  1322. u8 cq_index;
  1323. u8 reserved7;
  1324. u8 reserved6;
  1325. u8 num_bds;
  1326. #elif defined(__LITTLE_ENDIAN)
  1327. u8 num_bds;
  1328. u8 reserved6;
  1329. u8 reserved7;
  1330. u8 cq_index;
  1331. #endif
  1332. };
  1333. /*
  1334. * iSCSI SQ WQE
  1335. */
  1336. union iscsi_request {
  1337. struct bnx2i_cmd_request cmd;
  1338. struct bnx2i_tmf_request tmf;
  1339. struct bnx2i_nop_out_request nop_out;
  1340. struct bnx2i_login_request login_req;
  1341. struct bnx2i_text_request text;
  1342. struct bnx2i_logout_request logout_req;
  1343. struct bnx2i_cleanup_request cleanup;
  1344. };
  1345. /*
  1346. * iSCSI TMF CQE
  1347. */
  1348. struct bnx2i_tmf_response {
  1349. #if defined(__BIG_ENDIAN)
  1350. u8 op_code;
  1351. u8 reserved1;
  1352. u8 response;
  1353. u8 reserved0;
  1354. #elif defined(__LITTLE_ENDIAN)
  1355. u8 reserved0;
  1356. u8 response;
  1357. u8 reserved1;
  1358. u8 op_code;
  1359. #endif
  1360. u32 reserved2;
  1361. u32 exp_cmd_sn;
  1362. u32 max_cmd_sn;
  1363. u32 reserved3[2];
  1364. #if defined(__BIG_ENDIAN)
  1365. u16 reserved5;
  1366. u8 err_code;
  1367. u8 reserved4;
  1368. #elif defined(__LITTLE_ENDIAN)
  1369. u8 reserved4;
  1370. u8 err_code;
  1371. u16 reserved5;
  1372. #endif
  1373. u32 reserved6[7];
  1374. #if defined(__BIG_ENDIAN)
  1375. u16 reserved7;
  1376. u16 itt;
  1377. #define ISCSI_TMF_RESPONSE_INDEX (0x3FFF<<0)
  1378. #define ISCSI_TMF_RESPONSE_INDEX_SHIFT 0
  1379. #define ISCSI_TMF_RESPONSE_TYPE (0x3<<14)
  1380. #define ISCSI_TMF_RESPONSE_TYPE_SHIFT 14
  1381. #elif defined(__LITTLE_ENDIAN)
  1382. u16 itt;
  1383. #define ISCSI_TMF_RESPONSE_INDEX (0x3FFF<<0)
  1384. #define ISCSI_TMF_RESPONSE_INDEX_SHIFT 0
  1385. #define ISCSI_TMF_RESPONSE_TYPE (0x3<<14)
  1386. #define ISCSI_TMF_RESPONSE_TYPE_SHIFT 14
  1387. u16 reserved7;
  1388. #endif
  1389. u32 cq_req_sn;
  1390. };
  1391. /*
  1392. * iSCSI Text CQE
  1393. */
  1394. struct bnx2i_text_response {
  1395. #if defined(__BIG_ENDIAN)
  1396. u8 op_code;
  1397. u8 response_flags;
  1398. #define ISCSI_TEXT_RESPONSE_RESERVED1 (0x3F<<0)
  1399. #define ISCSI_TEXT_RESPONSE_RESERVED1_SHIFT 0
  1400. #define ISCSI_TEXT_RESPONSE_CONT (0x1<<6)
  1401. #define ISCSI_TEXT_RESPONSE_CONT_SHIFT 6
  1402. #define ISCSI_TEXT_RESPONSE_FINAL (0x1<<7)
  1403. #define ISCSI_TEXT_RESPONSE_FINAL_SHIFT 7
  1404. u16 reserved0;
  1405. #elif defined(__LITTLE_ENDIAN)
  1406. u16 reserved0;
  1407. u8 response_flags;
  1408. #define ISCSI_TEXT_RESPONSE_RESERVED1 (0x3F<<0)
  1409. #define ISCSI_TEXT_RESPONSE_RESERVED1_SHIFT 0
  1410. #define ISCSI_TEXT_RESPONSE_CONT (0x1<<6)
  1411. #define ISCSI_TEXT_RESPONSE_CONT_SHIFT 6
  1412. #define ISCSI_TEXT_RESPONSE_FINAL (0x1<<7)
  1413. #define ISCSI_TEXT_RESPONSE_FINAL_SHIFT 7
  1414. u8 op_code;
  1415. #endif
  1416. u32 data_length;
  1417. u32 exp_cmd_sn;
  1418. u32 max_cmd_sn;
  1419. u32 ttt;
  1420. u32 reserved2;
  1421. #if defined(__BIG_ENDIAN)
  1422. u16 reserved4;
  1423. u8 err_code;
  1424. u8 reserved3;
  1425. #elif defined(__LITTLE_ENDIAN)
  1426. u8 reserved3;
  1427. u8 err_code;
  1428. u16 reserved4;
  1429. #endif
  1430. u32 reserved5;
  1431. u32 lun[2];
  1432. u32 reserved6[4];
  1433. #if defined(__BIG_ENDIAN)
  1434. u16 reserved7;
  1435. u16 itt;
  1436. #define ISCSI_TEXT_RESPONSE_INDEX (0x3FFF<<0)
  1437. #define ISCSI_TEXT_RESPONSE_INDEX_SHIFT 0
  1438. #define ISCSI_TEXT_RESPONSE_TYPE (0x3<<14)
  1439. #define ISCSI_TEXT_RESPONSE_TYPE_SHIFT 14
  1440. #elif defined(__LITTLE_ENDIAN)
  1441. u16 itt;
  1442. #define ISCSI_TEXT_RESPONSE_INDEX (0x3FFF<<0)
  1443. #define ISCSI_TEXT_RESPONSE_INDEX_SHIFT 0
  1444. #define ISCSI_TEXT_RESPONSE_TYPE (0x3<<14)
  1445. #define ISCSI_TEXT_RESPONSE_TYPE_SHIFT 14
  1446. u16 reserved7;
  1447. #endif
  1448. u32 cq_req_sn;
  1449. };
  1450. /*
  1451. * iSCSI CQE
  1452. */
  1453. union iscsi_response {
  1454. struct bnx2i_cmd_response cmd;
  1455. struct bnx2i_tmf_response tmf;
  1456. struct bnx2i_login_response login_resp;
  1457. struct bnx2i_text_response text;
  1458. struct bnx2i_logout_response logout_resp;
  1459. struct bnx2i_cleanup_response cleanup;
  1460. struct bnx2i_reject_msg reject;
  1461. struct bnx2i_async_msg async;
  1462. struct bnx2i_nop_in_msg nop_in;
  1463. };
  1464. #endif /* __57XX_ISCSI_HSI_LINUX_LE__ */