mpi2_tool.h 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright 2000-2020 Broadcom Inc. All rights reserved.
  4. *
  5. *
  6. * Name: mpi2_tool.h
  7. * Title: MPI diagnostic tool structures and definitions
  8. * Creation Date: March 26, 2007
  9. *
  10. * mpi2_tool.h Version: 02.00.16
  11. *
  12. * Version History
  13. * ---------------
  14. *
  15. * Date Version Description
  16. * -------- -------- ------------------------------------------------------
  17. * 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
  18. * 12-18-07 02.00.01 Added Diagnostic Buffer Post and Diagnostic Release
  19. * structures and defines.
  20. * 02-29-08 02.00.02 Modified various names to make them 32-character unique.
  21. * 05-06-09 02.00.03 Added ISTWI Read Write Tool and Diagnostic CLI Tool.
  22. * 07-30-09 02.00.04 Added ExtendedType field to DiagnosticBufferPost request
  23. * and reply messages.
  24. * Added MPI2_DIAG_BUF_TYPE_EXTENDED.
  25. * Incremented MPI2_DIAG_BUF_TYPE_COUNT.
  26. * 05-12-10 02.00.05 Added Diagnostic Data Upload tool.
  27. * 08-11-10 02.00.06 Added defines that were missing for Diagnostic Buffer
  28. * Post Request.
  29. * 05-25-11 02.00.07 Added Flags field and related defines to
  30. * MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST.
  31. * 11-18-11 02.00.08 Incorporating additions for MPI v2.5.
  32. * 07-10-12 02.00.09 Add MPI v2.5 Toolbox Diagnostic CLI Tool Request
  33. * message.
  34. * 07-26-12 02.00.10 Modified MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST so that
  35. * it uses MPI Chain SGE as well as MPI Simple SGE.
  36. * 08-19-13 02.00.11 Added MPI2_TOOLBOX_TEXT_DISPLAY_TOOL and related info.
  37. * 01-08-14 02.00.12 Added MPI2_TOOLBOX_CLEAN_BIT26_PRODUCT_SPECIFIC.
  38. * 11-18-14 02.00.13 Updated copyright information.
  39. * 08-25-16 02.00.14 Added new values for the Flags field of Toolbox Clean
  40. * Tool Request Message.
  41. * 07-22-18 02.00.15 Added defines for new TOOLBOX_PCIE_LANE_MARGINING tool.
  42. * Added option for DeviceInfo field in ISTWI tool.
  43. * 12-17-18 02.00.16 Shorten some defines to be compatible with DOS.
  44. * --------------------------------------------------------------------------
  45. */
  46. #ifndef MPI2_TOOL_H
  47. #define MPI2_TOOL_H
  48. /*****************************************************************************
  49. *
  50. * Toolbox Messages
  51. *
  52. *****************************************************************************/
  53. /*defines for the Tools */
  54. #define MPI2_TOOLBOX_CLEAN_TOOL (0x00)
  55. #define MPI2_TOOLBOX_MEMORY_MOVE_TOOL (0x01)
  56. #define MPI2_TOOLBOX_DIAG_DATA_UPLOAD_TOOL (0x02)
  57. #define MPI2_TOOLBOX_ISTWI_READ_WRITE_TOOL (0x03)
  58. #define MPI2_TOOLBOX_BEACON_TOOL (0x05)
  59. #define MPI2_TOOLBOX_DIAGNOSTIC_CLI_TOOL (0x06)
  60. #define MPI2_TOOLBOX_TEXT_DISPLAY_TOOL (0x07)
  61. #define MPI26_TOOLBOX_BACKEND_PCIE_LANE_MARGIN (0x08)
  62. /****************************************************************************
  63. * Toolbox reply
  64. ****************************************************************************/
  65. typedef struct _MPI2_TOOLBOX_REPLY {
  66. U8 Tool; /*0x00 */
  67. U8 Reserved1; /*0x01 */
  68. U8 MsgLength; /*0x02 */
  69. U8 Function; /*0x03 */
  70. U16 Reserved2; /*0x04 */
  71. U8 Reserved3; /*0x06 */
  72. U8 MsgFlags; /*0x07 */
  73. U8 VP_ID; /*0x08 */
  74. U8 VF_ID; /*0x09 */
  75. U16 Reserved4; /*0x0A */
  76. U16 Reserved5; /*0x0C */
  77. U16 IOCStatus; /*0x0E */
  78. U32 IOCLogInfo; /*0x10 */
  79. } MPI2_TOOLBOX_REPLY, *PTR_MPI2_TOOLBOX_REPLY,
  80. Mpi2ToolboxReply_t, *pMpi2ToolboxReply_t;
  81. /****************************************************************************
  82. * Toolbox Clean Tool request
  83. ****************************************************************************/
  84. typedef struct _MPI2_TOOLBOX_CLEAN_REQUEST {
  85. U8 Tool; /*0x00 */
  86. U8 Reserved1; /*0x01 */
  87. U8 ChainOffset; /*0x02 */
  88. U8 Function; /*0x03 */
  89. U16 Reserved2; /*0x04 */
  90. U8 Reserved3; /*0x06 */
  91. U8 MsgFlags; /*0x07 */
  92. U8 VP_ID; /*0x08 */
  93. U8 VF_ID; /*0x09 */
  94. U16 Reserved4; /*0x0A */
  95. U32 Flags; /*0x0C */
  96. } MPI2_TOOLBOX_CLEAN_REQUEST, *PTR_MPI2_TOOLBOX_CLEAN_REQUEST,
  97. Mpi2ToolboxCleanRequest_t, *pMpi2ToolboxCleanRequest_t;
  98. /*values for the Flags field */
  99. #define MPI2_TOOLBOX_CLEAN_BOOT_SERVICES (0x80000000)
  100. #define MPI2_TOOLBOX_CLEAN_PERSIST_MANUFACT_PAGES (0x40000000)
  101. #define MPI2_TOOLBOX_CLEAN_OTHER_PERSIST_PAGES (0x20000000)
  102. #define MPI2_TOOLBOX_CLEAN_FW_CURRENT (0x10000000)
  103. #define MPI2_TOOLBOX_CLEAN_FW_BACKUP (0x08000000)
  104. #define MPI2_TOOLBOX_CLEAN_BIT26_PRODUCT_SPECIFIC (0x04000000)
  105. #define MPI2_TOOLBOX_CLEAN_MEGARAID (0x02000000)
  106. #define MPI2_TOOLBOX_CLEAN_INITIALIZATION (0x01000000)
  107. #define MPI2_TOOLBOX_CLEAN_SBR (0x00800000)
  108. #define MPI2_TOOLBOX_CLEAN_SBR_BACKUP (0x00400000)
  109. #define MPI2_TOOLBOX_CLEAN_HIIM (0x00200000)
  110. #define MPI2_TOOLBOX_CLEAN_HIIA (0x00100000)
  111. #define MPI2_TOOLBOX_CLEAN_CTLR (0x00080000)
  112. #define MPI2_TOOLBOX_CLEAN_IMR_FIRMWARE (0x00040000)
  113. #define MPI2_TOOLBOX_CLEAN_MR_NVDATA (0x00020000)
  114. #define MPI2_TOOLBOX_CLEAN_RESERVED_5_16 (0x0001FFE0)
  115. #define MPI2_TOOLBOX_CLEAN_ALL_BUT_MPB (0x00000010)
  116. #define MPI2_TOOLBOX_CLEAN_ENTIRE_FLASH (0x00000008)
  117. #define MPI2_TOOLBOX_CLEAN_FLASH (0x00000004)
  118. #define MPI2_TOOLBOX_CLEAN_SEEPROM (0x00000002)
  119. #define MPI2_TOOLBOX_CLEAN_NVSRAM (0x00000001)
  120. /****************************************************************************
  121. * Toolbox Memory Move request
  122. ****************************************************************************/
  123. typedef struct _MPI2_TOOLBOX_MEM_MOVE_REQUEST {
  124. U8 Tool; /*0x00 */
  125. U8 Reserved1; /*0x01 */
  126. U8 ChainOffset; /*0x02 */
  127. U8 Function; /*0x03 */
  128. U16 Reserved2; /*0x04 */
  129. U8 Reserved3; /*0x06 */
  130. U8 MsgFlags; /*0x07 */
  131. U8 VP_ID; /*0x08 */
  132. U8 VF_ID; /*0x09 */
  133. U16 Reserved4; /*0x0A */
  134. MPI2_SGE_SIMPLE_UNION SGL; /*0x0C */
  135. } MPI2_TOOLBOX_MEM_MOVE_REQUEST, *PTR_MPI2_TOOLBOX_MEM_MOVE_REQUEST,
  136. Mpi2ToolboxMemMoveRequest_t, *pMpi2ToolboxMemMoveRequest_t;
  137. /****************************************************************************
  138. * Toolbox Diagnostic Data Upload request
  139. ****************************************************************************/
  140. typedef struct _MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST {
  141. U8 Tool; /*0x00 */
  142. U8 Reserved1; /*0x01 */
  143. U8 ChainOffset; /*0x02 */
  144. U8 Function; /*0x03 */
  145. U16 Reserved2; /*0x04 */
  146. U8 Reserved3; /*0x06 */
  147. U8 MsgFlags; /*0x07 */
  148. U8 VP_ID; /*0x08 */
  149. U8 VF_ID; /*0x09 */
  150. U16 Reserved4; /*0x0A */
  151. U8 SGLFlags; /*0x0C */
  152. U8 Reserved5; /*0x0D */
  153. U16 Reserved6; /*0x0E */
  154. U32 Flags; /*0x10 */
  155. U32 DataLength; /*0x14 */
  156. MPI2_SGE_SIMPLE_UNION SGL; /*0x18 */
  157. } MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST,
  158. *PTR_MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST,
  159. Mpi2ToolboxDiagDataUploadRequest_t,
  160. *pMpi2ToolboxDiagDataUploadRequest_t;
  161. /*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
  162. typedef struct _MPI2_DIAG_DATA_UPLOAD_HEADER {
  163. U32 DiagDataLength; /*00h */
  164. U8 FormatCode; /*04h */
  165. U8 Reserved1; /*05h */
  166. U16 Reserved2; /*06h */
  167. } MPI2_DIAG_DATA_UPLOAD_HEADER, *PTR_MPI2_DIAG_DATA_UPLOAD_HEADER,
  168. Mpi2DiagDataUploadHeader_t, *pMpi2DiagDataUploadHeader_t;
  169. /****************************************************************************
  170. * Toolbox ISTWI Read Write Tool
  171. ****************************************************************************/
  172. /*Toolbox ISTWI Read Write Tool request message */
  173. typedef struct _MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST {
  174. U8 Tool; /*0x00 */
  175. U8 Reserved1; /*0x01 */
  176. U8 ChainOffset; /*0x02 */
  177. U8 Function; /*0x03 */
  178. U16 Reserved2; /*0x04 */
  179. U8 Reserved3; /*0x06 */
  180. U8 MsgFlags; /*0x07 */
  181. U8 VP_ID; /*0x08 */
  182. U8 VF_ID; /*0x09 */
  183. U16 Reserved4; /*0x0A */
  184. U32 Reserved5; /*0x0C */
  185. U32 Reserved6; /*0x10 */
  186. U8 DevIndex; /*0x14 */
  187. U8 Action; /*0x15 */
  188. U8 SGLFlags; /*0x16 */
  189. U8 Flags; /*0x17 */
  190. U16 TxDataLength; /*0x18 */
  191. U16 RxDataLength; /*0x1A */
  192. U32 Reserved8; /*0x1C */
  193. U32 Reserved9; /*0x20 */
  194. U32 Reserved10; /*0x24 */
  195. U32 Reserved11; /*0x28 */
  196. U32 Reserved12; /*0x2C */
  197. MPI2_SGE_SIMPLE_UNION SGL; /*0x30 */
  198. } MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST,
  199. *PTR_MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST,
  200. Mpi2ToolboxIstwiReadWriteRequest_t,
  201. *pMpi2ToolboxIstwiReadWriteRequest_t;
  202. /*values for the Action field */
  203. #define MPI2_TOOL_ISTWI_ACTION_READ_DATA (0x01)
  204. #define MPI2_TOOL_ISTWI_ACTION_WRITE_DATA (0x02)
  205. #define MPI2_TOOL_ISTWI_ACTION_SEQUENCE (0x03)
  206. #define MPI2_TOOL_ISTWI_ACTION_RESERVE_BUS (0x10)
  207. #define MPI2_TOOL_ISTWI_ACTION_RELEASE_BUS (0x11)
  208. #define MPI2_TOOL_ISTWI_ACTION_RESET (0x12)
  209. /*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
  210. /*values for the Flags field */
  211. #define MPI2_TOOL_ISTWI_FLAG_AUTO_RESERVE_RELEASE (0x80)
  212. #define MPI2_TOOL_ISTWI_FLAG_PAGE_ADDR_MASK (0x07)
  213. /*MPI26 TOOLBOX Request MsgFlags defines */
  214. #define MPI26_TOOL_ISTWI_MSGFLG_ADDR_MASK (0x01)
  215. /*Request uses Man Page 43 device index addressing */
  216. #define MPI26_TOOL_ISTWI_MSGFLG_ADDR_INDEX (0x00)
  217. /*Request uses Man Page 43 device info struct addressing */
  218. #define MPI26_TOOL_ISTWI_MSGFLG_ADDR_INFO (0x01)
  219. /*Toolbox ISTWI Read Write Tool reply message */
  220. typedef struct _MPI2_TOOLBOX_ISTWI_REPLY {
  221. U8 Tool; /*0x00 */
  222. U8 Reserved1; /*0x01 */
  223. U8 MsgLength; /*0x02 */
  224. U8 Function; /*0x03 */
  225. U16 Reserved2; /*0x04 */
  226. U8 Reserved3; /*0x06 */
  227. U8 MsgFlags; /*0x07 */
  228. U8 VP_ID; /*0x08 */
  229. U8 VF_ID; /*0x09 */
  230. U16 Reserved4; /*0x0A */
  231. U16 Reserved5; /*0x0C */
  232. U16 IOCStatus; /*0x0E */
  233. U32 IOCLogInfo; /*0x10 */
  234. U8 DevIndex; /*0x14 */
  235. U8 Action; /*0x15 */
  236. U8 IstwiStatus; /*0x16 */
  237. U8 Reserved6; /*0x17 */
  238. U16 TxDataCount; /*0x18 */
  239. U16 RxDataCount; /*0x1A */
  240. } MPI2_TOOLBOX_ISTWI_REPLY, *PTR_MPI2_TOOLBOX_ISTWI_REPLY,
  241. Mpi2ToolboxIstwiReply_t, *pMpi2ToolboxIstwiReply_t;
  242. /****************************************************************************
  243. * Toolbox Beacon Tool request
  244. ****************************************************************************/
  245. typedef struct _MPI2_TOOLBOX_BEACON_REQUEST {
  246. U8 Tool; /*0x00 */
  247. U8 Reserved1; /*0x01 */
  248. U8 ChainOffset; /*0x02 */
  249. U8 Function; /*0x03 */
  250. U16 Reserved2; /*0x04 */
  251. U8 Reserved3; /*0x06 */
  252. U8 MsgFlags; /*0x07 */
  253. U8 VP_ID; /*0x08 */
  254. U8 VF_ID; /*0x09 */
  255. U16 Reserved4; /*0x0A */
  256. U8 Reserved5; /*0x0C */
  257. U8 PhysicalPort; /*0x0D */
  258. U8 Reserved6; /*0x0E */
  259. U8 Flags; /*0x0F */
  260. } MPI2_TOOLBOX_BEACON_REQUEST, *PTR_MPI2_TOOLBOX_BEACON_REQUEST,
  261. Mpi2ToolboxBeaconRequest_t, *pMpi2ToolboxBeaconRequest_t;
  262. /*values for the Flags field */
  263. #define MPI2_TOOLBOX_FLAGS_BEACONMODE_OFF (0x00)
  264. #define MPI2_TOOLBOX_FLAGS_BEACONMODE_ON (0x01)
  265. /****************************************************************************
  266. * Toolbox Diagnostic CLI Tool
  267. ****************************************************************************/
  268. #define MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH (0x5C)
  269. /*MPI v2.0 Toolbox Diagnostic CLI Tool request message */
  270. typedef struct _MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST {
  271. U8 Tool; /*0x00 */
  272. U8 Reserved1; /*0x01 */
  273. U8 ChainOffset; /*0x02 */
  274. U8 Function; /*0x03 */
  275. U16 Reserved2; /*0x04 */
  276. U8 Reserved3; /*0x06 */
  277. U8 MsgFlags; /*0x07 */
  278. U8 VP_ID; /*0x08 */
  279. U8 VF_ID; /*0x09 */
  280. U16 Reserved4; /*0x0A */
  281. U8 SGLFlags; /*0x0C */
  282. U8 Reserved5; /*0x0D */
  283. U16 Reserved6; /*0x0E */
  284. U32 DataLength; /*0x10 */
  285. U8 DiagnosticCliCommand[MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH];/*0x14 */
  286. MPI2_MPI_SGE_IO_UNION SGL; /*0x70 */
  287. } MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
  288. *PTR_MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
  289. Mpi2ToolboxDiagnosticCliRequest_t,
  290. *pMpi2ToolboxDiagnosticCliRequest_t;
  291. /*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
  292. /*MPI v2.5 Toolbox Diagnostic CLI Tool request message */
  293. typedef struct _MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST {
  294. U8 Tool; /*0x00 */
  295. U8 Reserved1; /*0x01 */
  296. U8 ChainOffset; /*0x02 */
  297. U8 Function; /*0x03 */
  298. U16 Reserved2; /*0x04 */
  299. U8 Reserved3; /*0x06 */
  300. U8 MsgFlags; /*0x07 */
  301. U8 VP_ID; /*0x08 */
  302. U8 VF_ID; /*0x09 */
  303. U16 Reserved4; /*0x0A */
  304. U32 Reserved5; /*0x0C */
  305. U32 DataLength; /*0x10 */
  306. U8 DiagnosticCliCommand[MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH];/*0x14 */
  307. MPI25_SGE_IO_UNION SGL; /* 0x70 */
  308. } MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
  309. *PTR_MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
  310. Mpi25ToolboxDiagnosticCliRequest_t,
  311. *pMpi25ToolboxDiagnosticCliRequest_t;
  312. /*Toolbox Diagnostic CLI Tool reply message */
  313. typedef struct _MPI2_TOOLBOX_DIAGNOSTIC_CLI_REPLY {
  314. U8 Tool; /*0x00 */
  315. U8 Reserved1; /*0x01 */
  316. U8 MsgLength; /*0x02 */
  317. U8 Function; /*0x03 */
  318. U16 Reserved2; /*0x04 */
  319. U8 Reserved3; /*0x06 */
  320. U8 MsgFlags; /*0x07 */
  321. U8 VP_ID; /*0x08 */
  322. U8 VF_ID; /*0x09 */
  323. U16 Reserved4; /*0x0A */
  324. U16 Reserved5; /*0x0C */
  325. U16 IOCStatus; /*0x0E */
  326. U32 IOCLogInfo; /*0x10 */
  327. U32 ReturnedDataLength; /*0x14 */
  328. } MPI2_TOOLBOX_DIAGNOSTIC_CLI_REPLY,
  329. *PTR_MPI2_TOOLBOX_DIAG_CLI_REPLY,
  330. Mpi2ToolboxDiagnosticCliReply_t,
  331. *pMpi2ToolboxDiagnosticCliReply_t;
  332. /****************************************************************************
  333. * Toolbox Console Text Display Tool
  334. ****************************************************************************/
  335. /* Toolbox Console Text Display Tool request message */
  336. typedef struct _MPI2_TOOLBOX_TEXT_DISPLAY_REQUEST {
  337. U8 Tool; /* 0x00 */
  338. U8 Reserved1; /* 0x01 */
  339. U8 ChainOffset; /* 0x02 */
  340. U8 Function; /* 0x03 */
  341. U16 Reserved2; /* 0x04 */
  342. U8 Reserved3; /* 0x06 */
  343. U8 MsgFlags; /* 0x07 */
  344. U8 VP_ID; /* 0x08 */
  345. U8 VF_ID; /* 0x09 */
  346. U16 Reserved4; /* 0x0A */
  347. U8 Console; /* 0x0C */
  348. U8 Flags; /* 0x0D */
  349. U16 Reserved6; /* 0x0E */
  350. U8 TextToDisplay[4]; /* 0x10 */
  351. } MPI2_TOOLBOX_TEXT_DISPLAY_REQUEST,
  352. *PTR_MPI2_TOOLBOX_TEXT_DISPLAY_REQUEST,
  353. Mpi2ToolboxTextDisplayRequest_t,
  354. *pMpi2ToolboxTextDisplayRequest_t;
  355. /* defines for the Console field */
  356. #define MPI2_TOOLBOX_CONSOLE_TYPE_MASK (0xF0)
  357. #define MPI2_TOOLBOX_CONSOLE_TYPE_DEFAULT (0x00)
  358. #define MPI2_TOOLBOX_CONSOLE_TYPE_UART (0x10)
  359. #define MPI2_TOOLBOX_CONSOLE_TYPE_ETHERNET (0x20)
  360. #define MPI2_TOOLBOX_CONSOLE_NUMBER_MASK (0x0F)
  361. /* defines for the Flags field */
  362. #define MPI2_TOOLBOX_CONSOLE_FLAG_TIMESTAMP (0x01)
  363. /***************************************************************************
  364. * Toolbox Backend Lane Margining Tool
  365. ***************************************************************************
  366. */
  367. /*Toolbox Backend Lane Margining Tool request message */
  368. typedef struct _MPI26_TOOLBOX_LANE_MARGIN_REQUEST {
  369. U8 Tool; /*0x00 */
  370. U8 Reserved1; /*0x01 */
  371. U8 ChainOffset; /*0x02 */
  372. U8 Function; /*0x03 */
  373. U16 Reserved2; /*0x04 */
  374. U8 Reserved3; /*0x06 */
  375. U8 MsgFlags; /*0x07 */
  376. U8 VP_ID; /*0x08 */
  377. U8 VF_ID; /*0x09 */
  378. U16 Reserved4; /*0x0A */
  379. U8 Command; /*0x0C */
  380. U8 SwitchPort; /*0x0D */
  381. U16 DevHandle; /*0x0E */
  382. U8 RegisterOffset; /*0x10 */
  383. U8 Reserved5; /*0x11 */
  384. U16 DataLength; /*0x12 */
  385. MPI25_SGE_IO_UNION SGL; /*0x14 */
  386. } MPI26_TOOLBOX_LANE_MARGINING_REQUEST,
  387. *PTR_MPI2_TOOLBOX_LANE_MARGINING_REQUEST,
  388. Mpi26ToolboxLaneMarginingRequest_t,
  389. *pMpi2ToolboxLaneMarginingRequest_t;
  390. /* defines for the Command field */
  391. #define MPI26_TOOL_MARGIN_COMMAND_ENTER_MARGIN_MODE (0x01)
  392. #define MPI26_TOOL_MARGIN_COMMAND_READ_REGISTER_DATA (0x02)
  393. #define MPI26_TOOL_MARGIN_COMMAND_WRITE_REGISTER_DATA (0x03)
  394. #define MPI26_TOOL_MARGIN_COMMAND_EXIT_MARGIN_MODE (0x04)
  395. /*Toolbox Backend Lane Margining Tool reply message */
  396. typedef struct _MPI26_TOOLBOX_LANE_MARGIN_REPLY {
  397. U8 Tool; /*0x00 */
  398. U8 Reserved1; /*0x01 */
  399. U8 MsgLength; /*0x02 */
  400. U8 Function; /*0x03 */
  401. U16 Reserved2; /*0x04 */
  402. U8 Reserved3; /*0x06 */
  403. U8 MsgFlags; /*0x07 */
  404. U8 VP_ID; /*0x08 */
  405. U8 VF_ID; /*0x09 */
  406. U16 Reserved4; /*0x0A */
  407. U16 Reserved5; /*0x0C */
  408. U16 IOCStatus; /*0x0E */
  409. U32 IOCLogInfo; /*0x10 */
  410. U16 ReturnedDataLength; /*0x14 */
  411. U16 Reserved6; /*0x16 */
  412. } MPI26_TOOLBOX_LANE_MARGINING_REPLY,
  413. *PTR_MPI26_TOOLBOX_LANE_MARGINING_REPLY,
  414. Mpi26ToolboxLaneMarginingReply_t,
  415. *pMpi26ToolboxLaneMarginingReply_t;
  416. /*****************************************************************************
  417. *
  418. * Diagnostic Buffer Messages
  419. *
  420. *****************************************************************************/
  421. /****************************************************************************
  422. * Diagnostic Buffer Post request
  423. ****************************************************************************/
  424. typedef struct _MPI2_DIAG_BUFFER_POST_REQUEST {
  425. U8 ExtendedType; /*0x00 */
  426. U8 BufferType; /*0x01 */
  427. U8 ChainOffset; /*0x02 */
  428. U8 Function; /*0x03 */
  429. U16 Reserved2; /*0x04 */
  430. U8 Reserved3; /*0x06 */
  431. U8 MsgFlags; /*0x07 */
  432. U8 VP_ID; /*0x08 */
  433. U8 VF_ID; /*0x09 */
  434. U16 Reserved4; /*0x0A */
  435. U64 BufferAddress; /*0x0C */
  436. U32 BufferLength; /*0x14 */
  437. U32 Reserved5; /*0x18 */
  438. U32 Reserved6; /*0x1C */
  439. U32 Flags; /*0x20 */
  440. U32 ProductSpecific[23]; /*0x24 */
  441. } MPI2_DIAG_BUFFER_POST_REQUEST, *PTR_MPI2_DIAG_BUFFER_POST_REQUEST,
  442. Mpi2DiagBufferPostRequest_t, *pMpi2DiagBufferPostRequest_t;
  443. /*values for the ExtendedType field */
  444. #define MPI2_DIAG_EXTENDED_TYPE_UTILIZATION (0x02)
  445. /*values for the BufferType field */
  446. #define MPI2_DIAG_BUF_TYPE_TRACE (0x00)
  447. #define MPI2_DIAG_BUF_TYPE_SNAPSHOT (0x01)
  448. #define MPI2_DIAG_BUF_TYPE_EXTENDED (0x02)
  449. /*count of the number of buffer types */
  450. #define MPI2_DIAG_BUF_TYPE_COUNT (0x03)
  451. /*values for the Flags field */
  452. #define MPI2_DIAG_BUF_FLAG_RELEASE_ON_FULL (0x00000002)
  453. #define MPI2_DIAG_BUF_FLAG_IMMEDIATE_RELEASE (0x00000001)
  454. /****************************************************************************
  455. * Diagnostic Buffer Post reply
  456. ****************************************************************************/
  457. typedef struct _MPI2_DIAG_BUFFER_POST_REPLY {
  458. U8 ExtendedType; /*0x00 */
  459. U8 BufferType; /*0x01 */
  460. U8 MsgLength; /*0x02 */
  461. U8 Function; /*0x03 */
  462. U16 Reserved2; /*0x04 */
  463. U8 Reserved3; /*0x06 */
  464. U8 MsgFlags; /*0x07 */
  465. U8 VP_ID; /*0x08 */
  466. U8 VF_ID; /*0x09 */
  467. U16 Reserved4; /*0x0A */
  468. U16 Reserved5; /*0x0C */
  469. U16 IOCStatus; /*0x0E */
  470. U32 IOCLogInfo; /*0x10 */
  471. U32 TransferLength; /*0x14 */
  472. } MPI2_DIAG_BUFFER_POST_REPLY, *PTR_MPI2_DIAG_BUFFER_POST_REPLY,
  473. Mpi2DiagBufferPostReply_t, *pMpi2DiagBufferPostReply_t;
  474. /****************************************************************************
  475. * Diagnostic Release request
  476. ****************************************************************************/
  477. typedef struct _MPI2_DIAG_RELEASE_REQUEST {
  478. U8 Reserved1; /*0x00 */
  479. U8 BufferType; /*0x01 */
  480. U8 ChainOffset; /*0x02 */
  481. U8 Function; /*0x03 */
  482. U16 Reserved2; /*0x04 */
  483. U8 Reserved3; /*0x06 */
  484. U8 MsgFlags; /*0x07 */
  485. U8 VP_ID; /*0x08 */
  486. U8 VF_ID; /*0x09 */
  487. U16 Reserved4; /*0x0A */
  488. } MPI2_DIAG_RELEASE_REQUEST, *PTR_MPI2_DIAG_RELEASE_REQUEST,
  489. Mpi2DiagReleaseRequest_t, *pMpi2DiagReleaseRequest_t;
  490. /****************************************************************************
  491. * Diagnostic Buffer Post reply
  492. ****************************************************************************/
  493. typedef struct _MPI2_DIAG_RELEASE_REPLY {
  494. U8 Reserved1; /*0x00 */
  495. U8 BufferType; /*0x01 */
  496. U8 MsgLength; /*0x02 */
  497. U8 Function; /*0x03 */
  498. U16 Reserved2; /*0x04 */
  499. U8 Reserved3; /*0x06 */
  500. U8 MsgFlags; /*0x07 */
  501. U8 VP_ID; /*0x08 */
  502. U8 VF_ID; /*0x09 */
  503. U16 Reserved4; /*0x0A */
  504. U16 Reserved5; /*0x0C */
  505. U16 IOCStatus; /*0x0E */
  506. U32 IOCLogInfo; /*0x10 */
  507. } MPI2_DIAG_RELEASE_REPLY, *PTR_MPI2_DIAG_RELEASE_REPLY,
  508. Mpi2DiagReleaseReply_t, *pMpi2DiagReleaseReply_t;
  509. #endif