57xx_iscsi_hsi.h 36 KB

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