mpi2_raid.h 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. /*
  2. * Copyright (c) 2000-2013 LSI Corporation.
  3. *
  4. *
  5. * Name: mpi2_raid.h
  6. * Title: MPI Integrated RAID messages and structures
  7. * Creation Date: April 26, 2007
  8. *
  9. * mpi2_raid.h Version: 02.00.09
  10. *
  11. * Version History
  12. * ---------------
  13. *
  14. * Date Version Description
  15. * -------- -------- ------------------------------------------------------
  16. * 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
  17. * 08-31-07 02.00.01 Modifications to RAID Action request and reply,
  18. * including the Actions and ActionData.
  19. * 02-29-08 02.00.02 Added MPI2_RAID_ACTION_ADATA_DISABL_FULL_REBUILD.
  20. * 05-21-08 02.00.03 Added MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS so that
  21. * the PhysDisk array in MPI2_RAID_VOLUME_CREATION_STRUCT
  22. * can be sized by the build environment.
  23. * 07-30-09 02.00.04 Added proper define for the Use Default Settings bit of
  24. * VolumeCreationFlags and marked the old one as obsolete.
  25. * 05-12-10 02.00.05 Added MPI2_RAID_VOL_FLAGS_OP_MDC define.
  26. * 08-24-10 02.00.06 Added MPI2_RAID_ACTION_COMPATIBILITY_CHECK along with
  27. * related structures and defines.
  28. * Added product-specific range to RAID Action values.
  29. * 02-06-12 02.00.08 Added MPI2_RAID_ACTION_PHYSDISK_HIDDEN.
  30. * 07-26-12 02.00.09 Added ElapsedSeconds field to MPI2_RAID_VOL_INDICATOR.
  31. * Added MPI2_RAID_VOL_FLAGS_ELAPSED_SECONDS_VALID define.
  32. * --------------------------------------------------------------------------
  33. */
  34. #ifndef MPI2_RAID_H
  35. #define MPI2_RAID_H
  36. /*****************************************************************************
  37. *
  38. * Integrated RAID Messages
  39. *
  40. *****************************************************************************/
  41. /****************************************************************************
  42. * RAID Action messages
  43. ****************************************************************************/
  44. /* ActionDataWord defines for use with MPI2_RAID_ACTION_DELETE_VOLUME action */
  45. #define MPI2_RAID_ACTION_ADATA_KEEP_LBA0 (0x00000000)
  46. #define MPI2_RAID_ACTION_ADATA_ZERO_LBA0 (0x00000001)
  47. /* use MPI2_RAIDVOL0_SETTING_ defines from mpi2_cnfg.h for MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE action */
  48. /* ActionDataWord defines for use with MPI2_RAID_ACTION_DISABLE_ALL_VOLUMES action */
  49. #define MPI2_RAID_ACTION_ADATA_DISABL_FULL_REBUILD (0x00000001)
  50. /* ActionDataWord for MPI2_RAID_ACTION_SET_RAID_FUNCTION_RATE Action */
  51. typedef struct _MPI2_RAID_ACTION_RATE_DATA
  52. {
  53. U8 RateToChange; /* 0x00 */
  54. U8 RateOrMode; /* 0x01 */
  55. U16 DataScrubDuration; /* 0x02 */
  56. } MPI2_RAID_ACTION_RATE_DATA, MPI2_POINTER PTR_MPI2_RAID_ACTION_RATE_DATA,
  57. Mpi2RaidActionRateData_t, MPI2_POINTER pMpi2RaidActionRateData_t;
  58. #define MPI2_RAID_ACTION_SET_RATE_RESYNC (0x00)
  59. #define MPI2_RAID_ACTION_SET_RATE_DATA_SCRUB (0x01)
  60. #define MPI2_RAID_ACTION_SET_RATE_POWERSAVE_MODE (0x02)
  61. /* ActionDataWord for MPI2_RAID_ACTION_START_RAID_FUNCTION Action */
  62. typedef struct _MPI2_RAID_ACTION_START_RAID_FUNCTION
  63. {
  64. U8 RAIDFunction; /* 0x00 */
  65. U8 Flags; /* 0x01 */
  66. U16 Reserved1; /* 0x02 */
  67. } MPI2_RAID_ACTION_START_RAID_FUNCTION,
  68. MPI2_POINTER PTR_MPI2_RAID_ACTION_START_RAID_FUNCTION,
  69. Mpi2RaidActionStartRaidFunction_t,
  70. MPI2_POINTER pMpi2RaidActionStartRaidFunction_t;
  71. /* defines for the RAIDFunction field */
  72. #define MPI2_RAID_ACTION_START_BACKGROUND_INIT (0x00)
  73. #define MPI2_RAID_ACTION_START_ONLINE_CAP_EXPANSION (0x01)
  74. #define MPI2_RAID_ACTION_START_CONSISTENCY_CHECK (0x02)
  75. /* defines for the Flags field */
  76. #define MPI2_RAID_ACTION_START_NEW (0x00)
  77. #define MPI2_RAID_ACTION_START_RESUME (0x01)
  78. /* ActionDataWord for MPI2_RAID_ACTION_STOP_RAID_FUNCTION Action */
  79. typedef struct _MPI2_RAID_ACTION_STOP_RAID_FUNCTION
  80. {
  81. U8 RAIDFunction; /* 0x00 */
  82. U8 Flags; /* 0x01 */
  83. U16 Reserved1; /* 0x02 */
  84. } MPI2_RAID_ACTION_STOP_RAID_FUNCTION,
  85. MPI2_POINTER PTR_MPI2_RAID_ACTION_STOP_RAID_FUNCTION,
  86. Mpi2RaidActionStopRaidFunction_t,
  87. MPI2_POINTER pMpi2RaidActionStopRaidFunction_t;
  88. /* defines for the RAIDFunction field */
  89. #define MPI2_RAID_ACTION_STOP_BACKGROUND_INIT (0x00)
  90. #define MPI2_RAID_ACTION_STOP_ONLINE_CAP_EXPANSION (0x01)
  91. #define MPI2_RAID_ACTION_STOP_CONSISTENCY_CHECK (0x02)
  92. /* defines for the Flags field */
  93. #define MPI2_RAID_ACTION_STOP_ABORT (0x00)
  94. #define MPI2_RAID_ACTION_STOP_PAUSE (0x01)
  95. /* ActionDataWord for MPI2_RAID_ACTION_CREATE_HOT_SPARE Action */
  96. typedef struct _MPI2_RAID_ACTION_HOT_SPARE
  97. {
  98. U8 HotSparePool; /* 0x00 */
  99. U8 Reserved1; /* 0x01 */
  100. U16 DevHandle; /* 0x02 */
  101. } MPI2_RAID_ACTION_HOT_SPARE, MPI2_POINTER PTR_MPI2_RAID_ACTION_HOT_SPARE,
  102. Mpi2RaidActionHotSpare_t, MPI2_POINTER pMpi2RaidActionHotSpare_t;
  103. /* ActionDataWord for MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE Action */
  104. typedef struct _MPI2_RAID_ACTION_FW_UPDATE_MODE
  105. {
  106. U8 Flags; /* 0x00 */
  107. U8 DeviceFirmwareUpdateModeTimeout; /* 0x01 */
  108. U16 Reserved1; /* 0x02 */
  109. } MPI2_RAID_ACTION_FW_UPDATE_MODE,
  110. MPI2_POINTER PTR_MPI2_RAID_ACTION_FW_UPDATE_MODE,
  111. Mpi2RaidActionFwUpdateMode_t, MPI2_POINTER pMpi2RaidActionFwUpdateMode_t;
  112. /* ActionDataWord defines for use with MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE action */
  113. #define MPI2_RAID_ACTION_ADATA_DISABLE_FW_UPDATE (0x00)
  114. #define MPI2_RAID_ACTION_ADATA_ENABLE_FW_UPDATE (0x01)
  115. typedef union _MPI2_RAID_ACTION_DATA
  116. {
  117. U32 Word;
  118. MPI2_RAID_ACTION_RATE_DATA Rates;
  119. MPI2_RAID_ACTION_START_RAID_FUNCTION StartRaidFunction;
  120. MPI2_RAID_ACTION_STOP_RAID_FUNCTION StopRaidFunction;
  121. MPI2_RAID_ACTION_HOT_SPARE HotSpare;
  122. MPI2_RAID_ACTION_FW_UPDATE_MODE FwUpdateMode;
  123. } MPI2_RAID_ACTION_DATA, MPI2_POINTER PTR_MPI2_RAID_ACTION_DATA,
  124. Mpi2RaidActionData_t, MPI2_POINTER pMpi2RaidActionData_t;
  125. /* RAID Action Request Message */
  126. typedef struct _MPI2_RAID_ACTION_REQUEST
  127. {
  128. U8 Action; /* 0x00 */
  129. U8 Reserved1; /* 0x01 */
  130. U8 ChainOffset; /* 0x02 */
  131. U8 Function; /* 0x03 */
  132. U16 VolDevHandle; /* 0x04 */
  133. U8 PhysDiskNum; /* 0x06 */
  134. U8 MsgFlags; /* 0x07 */
  135. U8 VP_ID; /* 0x08 */
  136. U8 VF_ID; /* 0x09 */
  137. U16 Reserved2; /* 0x0A */
  138. U32 Reserved3; /* 0x0C */
  139. MPI2_RAID_ACTION_DATA ActionDataWord; /* 0x10 */
  140. MPI2_SGE_SIMPLE_UNION ActionDataSGE; /* 0x14 */
  141. } MPI2_RAID_ACTION_REQUEST, MPI2_POINTER PTR_MPI2_RAID_ACTION_REQUEST,
  142. Mpi2RaidActionRequest_t, MPI2_POINTER pMpi2RaidActionRequest_t;
  143. /* RAID Action request Action values */
  144. #define MPI2_RAID_ACTION_INDICATOR_STRUCT (0x01)
  145. #define MPI2_RAID_ACTION_CREATE_VOLUME (0x02)
  146. #define MPI2_RAID_ACTION_DELETE_VOLUME (0x03)
  147. #define MPI2_RAID_ACTION_DISABLE_ALL_VOLUMES (0x04)
  148. #define MPI2_RAID_ACTION_ENABLE_ALL_VOLUMES (0x05)
  149. #define MPI2_RAID_ACTION_PHYSDISK_OFFLINE (0x0A)
  150. #define MPI2_RAID_ACTION_PHYSDISK_ONLINE (0x0B)
  151. #define MPI2_RAID_ACTION_FAIL_PHYSDISK (0x0F)
  152. #define MPI2_RAID_ACTION_ACTIVATE_VOLUME (0x11)
  153. #define MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE (0x15)
  154. #define MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE (0x17)
  155. #define MPI2_RAID_ACTION_SET_VOLUME_NAME (0x18)
  156. #define MPI2_RAID_ACTION_SET_RAID_FUNCTION_RATE (0x19)
  157. #define MPI2_RAID_ACTION_ENABLE_FAILED_VOLUME (0x1C)
  158. #define MPI2_RAID_ACTION_CREATE_HOT_SPARE (0x1D)
  159. #define MPI2_RAID_ACTION_DELETE_HOT_SPARE (0x1E)
  160. #define MPI2_RAID_ACTION_SYSTEM_SHUTDOWN_INITIATED (0x20)
  161. #define MPI2_RAID_ACTION_START_RAID_FUNCTION (0x21)
  162. #define MPI2_RAID_ACTION_STOP_RAID_FUNCTION (0x22)
  163. #define MPI2_RAID_ACTION_COMPATIBILITY_CHECK (0x23)
  164. #define MPI2_RAID_ACTION_PHYSDISK_HIDDEN (0x24)
  165. #define MPI2_RAID_ACTION_MIN_PRODUCT_SPECIFIC (0x80)
  166. #define MPI2_RAID_ACTION_MAX_PRODUCT_SPECIFIC (0xFF)
  167. /* RAID Volume Creation Structure */
  168. /*
  169. * The following define can be customized for the targeted product.
  170. */
  171. #ifndef MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS
  172. #define MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS (1)
  173. #endif
  174. typedef struct _MPI2_RAID_VOLUME_PHYSDISK
  175. {
  176. U8 RAIDSetNum; /* 0x00 */
  177. U8 PhysDiskMap; /* 0x01 */
  178. U16 PhysDiskDevHandle; /* 0x02 */
  179. } MPI2_RAID_VOLUME_PHYSDISK, MPI2_POINTER PTR_MPI2_RAID_VOLUME_PHYSDISK,
  180. Mpi2RaidVolumePhysDisk_t, MPI2_POINTER pMpi2RaidVolumePhysDisk_t;
  181. /* defines for the PhysDiskMap field */
  182. #define MPI2_RAIDACTION_PHYSDISK_PRIMARY (0x01)
  183. #define MPI2_RAIDACTION_PHYSDISK_SECONDARY (0x02)
  184. typedef struct _MPI2_RAID_VOLUME_CREATION_STRUCT
  185. {
  186. U8 NumPhysDisks; /* 0x00 */
  187. U8 VolumeType; /* 0x01 */
  188. U16 Reserved1; /* 0x02 */
  189. U32 VolumeCreationFlags; /* 0x04 */
  190. U32 VolumeSettings; /* 0x08 */
  191. U8 Reserved2; /* 0x0C */
  192. U8 ResyncRate; /* 0x0D */
  193. U16 DataScrubDuration; /* 0x0E */
  194. U64 VolumeMaxLBA; /* 0x10 */
  195. U32 StripeSize; /* 0x18 */
  196. U8 Name[16]; /* 0x1C */
  197. MPI2_RAID_VOLUME_PHYSDISK PhysDisk[MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS];/* 0x2C */
  198. } MPI2_RAID_VOLUME_CREATION_STRUCT,
  199. MPI2_POINTER PTR_MPI2_RAID_VOLUME_CREATION_STRUCT,
  200. Mpi2RaidVolumeCreationStruct_t, MPI2_POINTER pMpi2RaidVolumeCreationStruct_t;
  201. /* use MPI2_RAID_VOL_TYPE_ defines from mpi2_cnfg.h for VolumeType */
  202. /* defines for the VolumeCreationFlags field */
  203. #define MPI2_RAID_VOL_CREATION_DEFAULT_SETTINGS (0x80000000)
  204. #define MPI2_RAID_VOL_CREATION_BACKGROUND_INIT (0x00000004)
  205. #define MPI2_RAID_VOL_CREATION_LOW_LEVEL_INIT (0x00000002)
  206. #define MPI2_RAID_VOL_CREATION_MIGRATE_DATA (0x00000001)
  207. /* The following is an obsolete define.
  208. * It must be shifted left 24 bits in order to set the proper bit.
  209. */
  210. #define MPI2_RAID_VOL_CREATION_USE_DEFAULT_SETTINGS (0x80)
  211. /* RAID Online Capacity Expansion Structure */
  212. typedef struct _MPI2_RAID_ONLINE_CAPACITY_EXPANSION
  213. {
  214. U32 Flags; /* 0x00 */
  215. U16 DevHandle0; /* 0x04 */
  216. U16 Reserved1; /* 0x06 */
  217. U16 DevHandle1; /* 0x08 */
  218. U16 Reserved2; /* 0x0A */
  219. } MPI2_RAID_ONLINE_CAPACITY_EXPANSION,
  220. MPI2_POINTER PTR_MPI2_RAID_ONLINE_CAPACITY_EXPANSION,
  221. Mpi2RaidOnlineCapacityExpansion_t,
  222. MPI2_POINTER pMpi2RaidOnlineCapacityExpansion_t;
  223. /* RAID Compatibility Input Structure */
  224. typedef struct _MPI2_RAID_COMPATIBILITY_INPUT_STRUCT {
  225. U16 SourceDevHandle; /* 0x00 */
  226. U16 CandidateDevHandle; /* 0x02 */
  227. U32 Flags; /* 0x04 */
  228. U32 Reserved1; /* 0x08 */
  229. U32 Reserved2; /* 0x0C */
  230. } MPI2_RAID_COMPATIBILITY_INPUT_STRUCT,
  231. MPI2_POINTER PTR_MPI2_RAID_COMPATIBILITY_INPUT_STRUCT,
  232. Mpi2RaidCompatibilityInputStruct_t,
  233. MPI2_POINTER pMpi2RaidCompatibilityInputStruct_t;
  234. /* defines for RAID Compatibility Structure Flags field */
  235. #define MPI2_RAID_COMPAT_SOURCE_IS_VOLUME_FLAG (0x00000002)
  236. #define MPI2_RAID_COMPAT_REPORT_SOURCE_INFO_FLAG (0x00000001)
  237. /* RAID Volume Indicator Structure */
  238. typedef struct _MPI2_RAID_VOL_INDICATOR
  239. {
  240. U64 TotalBlocks; /* 0x00 */
  241. U64 BlocksRemaining; /* 0x08 */
  242. U32 Flags; /* 0x10 */
  243. U32 ElapsedSeconds; /* 0x14 */
  244. } MPI2_RAID_VOL_INDICATOR, MPI2_POINTER PTR_MPI2_RAID_VOL_INDICATOR,
  245. Mpi2RaidVolIndicator_t, MPI2_POINTER pMpi2RaidVolIndicator_t;
  246. /* defines for RAID Volume Indicator Flags field */
  247. #define MPI2_RAID_VOL_FLAGS_ELAPSED_SECONDS_VALID (0x80000000)
  248. #define MPI2_RAID_VOL_FLAGS_OP_MASK (0x0000000F)
  249. #define MPI2_RAID_VOL_FLAGS_OP_BACKGROUND_INIT (0x00000000)
  250. #define MPI2_RAID_VOL_FLAGS_OP_ONLINE_CAP_EXPANSION (0x00000001)
  251. #define MPI2_RAID_VOL_FLAGS_OP_CONSISTENCY_CHECK (0x00000002)
  252. #define MPI2_RAID_VOL_FLAGS_OP_RESYNC (0x00000003)
  253. #define MPI2_RAID_VOL_FLAGS_OP_MDC (0x00000004)
  254. /* RAID Compatibility Result Structure */
  255. typedef struct _MPI2_RAID_COMPATIBILITY_RESULT_STRUCT {
  256. U8 State; /* 0x00 */
  257. U8 Reserved1; /* 0x01 */
  258. U16 Reserved2; /* 0x02 */
  259. U32 GenericAttributes; /* 0x04 */
  260. U32 OEMSpecificAttributes; /* 0x08 */
  261. U32 Reserved3; /* 0x0C */
  262. U32 Reserved4; /* 0x10 */
  263. } MPI2_RAID_COMPATIBILITY_RESULT_STRUCT,
  264. MPI2_POINTER PTR_MPI2_RAID_COMPATIBILITY_RESULT_STRUCT,
  265. Mpi2RaidCompatibilityResultStruct_t,
  266. MPI2_POINTER pMpi2RaidCompatibilityResultStruct_t;
  267. /* defines for RAID Compatibility Result Structure State field */
  268. #define MPI2_RAID_COMPAT_STATE_COMPATIBLE (0x00)
  269. #define MPI2_RAID_COMPAT_STATE_NOT_COMPATIBLE (0x01)
  270. /* defines for RAID Compatibility Result Structure GenericAttributes field */
  271. #define MPI2_RAID_COMPAT_GENATTRIB_4K_SECTOR (0x00000010)
  272. #define MPI2_RAID_COMPAT_GENATTRIB_MEDIA_MASK (0x0000000C)
  273. #define MPI2_RAID_COMPAT_GENATTRIB_SOLID_STATE_DRIVE (0x00000008)
  274. #define MPI2_RAID_COMPAT_GENATTRIB_HARD_DISK_DRIVE (0x00000004)
  275. #define MPI2_RAID_COMPAT_GENATTRIB_PROTOCOL_MASK (0x00000003)
  276. #define MPI2_RAID_COMPAT_GENATTRIB_SAS_PROTOCOL (0x00000002)
  277. #define MPI2_RAID_COMPAT_GENATTRIB_SATA_PROTOCOL (0x00000001)
  278. /* RAID Action Reply ActionData union */
  279. typedef union _MPI2_RAID_ACTION_REPLY_DATA
  280. {
  281. U32 Word[6];
  282. MPI2_RAID_VOL_INDICATOR RaidVolumeIndicator;
  283. U16 VolDevHandle;
  284. U8 VolumeState;
  285. U8 PhysDiskNum;
  286. MPI2_RAID_COMPATIBILITY_RESULT_STRUCT RaidCompatibilityResult;
  287. } MPI2_RAID_ACTION_REPLY_DATA, MPI2_POINTER PTR_MPI2_RAID_ACTION_REPLY_DATA,
  288. Mpi2RaidActionReplyData_t, MPI2_POINTER pMpi2RaidActionReplyData_t;
  289. /* use MPI2_RAIDVOL0_SETTING_ defines from mpi2_cnfg.h for MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE action */
  290. /* RAID Action Reply Message */
  291. typedef struct _MPI2_RAID_ACTION_REPLY
  292. {
  293. U8 Action; /* 0x00 */
  294. U8 Reserved1; /* 0x01 */
  295. U8 MsgLength; /* 0x02 */
  296. U8 Function; /* 0x03 */
  297. U16 VolDevHandle; /* 0x04 */
  298. U8 PhysDiskNum; /* 0x06 */
  299. U8 MsgFlags; /* 0x07 */
  300. U8 VP_ID; /* 0x08 */
  301. U8 VF_ID; /* 0x09 */
  302. U16 Reserved2; /* 0x0A */
  303. U16 Reserved3; /* 0x0C */
  304. U16 IOCStatus; /* 0x0E */
  305. U32 IOCLogInfo; /* 0x10 */
  306. MPI2_RAID_ACTION_REPLY_DATA ActionData; /* 0x14 */
  307. } MPI2_RAID_ACTION_REPLY, MPI2_POINTER PTR_MPI2_RAID_ACTION_REPLY,
  308. Mpi2RaidActionReply_t, MPI2_POINTER pMpi2RaidActionReply_t;
  309. #endif