mpi_log_sas.h 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /***************************************************************************
  3. * *
  4. * Copyright (c) 2000-2008 LSI Corporation. All rights reserved. *
  5. * *
  6. * Description *
  7. * ------------ *
  8. * This include file contains SAS firmware interface IOC Log Info codes *
  9. * *
  10. *-------------------------------------------------------------------------*
  11. */
  12. #ifndef IOPI_IOCLOGINFO_H_INCLUDED
  13. #define IOPI_IOCLOGINFO_H_INCLUDED
  14. #define SAS_LOGINFO_NEXUS_LOSS 0x31170000
  15. #define SAS_LOGINFO_MASK 0xFFFF0000
  16. /****************************************************************************/
  17. /* IOC LOGINFO defines, 0x00000000 - 0x0FFFFFFF */
  18. /* Format: */
  19. /* Bits 31-28: MPI_IOCLOGINFO_TYPE_SAS (3) */
  20. /* Bits 27-24: IOC_LOGINFO_ORIGINATOR: 0=IOP, 1=PL, 2=IR */
  21. /* Bits 23-16: LOGINFO_CODE */
  22. /* Bits 15-0: LOGINFO_CODE Specific */
  23. /****************************************************************************/
  24. /****************************************************************************/
  25. /* IOC_LOGINFO_ORIGINATOR defines */
  26. /****************************************************************************/
  27. #define IOC_LOGINFO_ORIGINATOR_IOP (0x00000000)
  28. #define IOC_LOGINFO_ORIGINATOR_PL (0x01000000)
  29. #define IOC_LOGINFO_ORIGINATOR_IR (0x02000000)
  30. #define IOC_LOGINFO_ORIGINATOR_MASK (0x0F000000)
  31. /****************************************************************************/
  32. /* LOGINFO_CODE defines */
  33. /****************************************************************************/
  34. #define IOC_LOGINFO_CODE_MASK (0x00FF0000)
  35. #define IOC_LOGINFO_CODE_SHIFT (16)
  36. /****************************************************************************/
  37. /* IOP LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = IOP */
  38. /****************************************************************************/
  39. #define IOP_LOGINFO_CODE_INVALID_SAS_ADDRESS (0x00010000)
  40. #define IOP_LOGINFO_CODE_UNUSED2 (0x00020000)
  41. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE (0x00030000)
  42. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_RT (0x00030100) /* Route Table Entry not found */
  43. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PN (0x00030200) /* Invalid Page Number */
  44. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_FORM (0x00030300) /* Invalid FORM */
  45. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PT (0x00030400) /* Invalid Page Type */
  46. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_DNM (0x00030500) /* Device Not Mapped */
  47. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PERSIST (0x00030600) /* Persistent Page not found */
  48. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_DEFAULT (0x00030700) /* Default Page not found */
  49. #define IOP_LOGINFO_CODE_FWUPLOAD_NO_FLASH_AVAILABLE (0x0003E000) /* Tried to upload from flash, but there is none */
  50. #define IOP_LOGINFO_CODE_FWUPLOAD_UNKNOWN_IMAGE_TYPE (0x0003E001) /* ImageType field contents were invalid */
  51. #define IOP_LOGINFO_CODE_FWUPLOAD_WRONG_IMAGE_SIZE (0x0003E002) /* ImageSize field in TCSGE was bad/offset in MfgPg 4 was wrong */
  52. #define IOP_LOGINFO_CODE_FWUPLOAD_ENTIRE_FLASH_UPLOAD_FAILED (0x0003E003) /* Error occurred while attempting to upload the entire flash */
  53. #define IOP_LOGINFO_CODE_FWUPLOAD_REGION_UPLOAD_FAILED (0x0003E004) /* Error occurred while attempting to upload single flash region */
  54. #define IOP_LOGINFO_CODE_FWUPLOAD_DMA_FAILURE (0x0003E005) /* Problem occurred while DMAing FW to host memory */
  55. #define IOP_LOGINFO_CODE_DIAG_MSG_ERROR (0x00040000) /* Error handling diag msg - or'd with diag status */
  56. #define IOP_LOGINFO_CODE_TASK_TERMINATED (0x00050000)
  57. #define IOP_LOGINFO_CODE_ENCL_MGMT_READ_ACTION_ERR0R (0x00060001) /* Read Action not supported for SEP msg */
  58. #define IOP_LOGINFO_CODE_ENCL_MGMT_INVALID_BUS_ID_ERR0R (0x00060002) /* Invalid Bus/ID in SEP msg */
  59. #define IOP_LOGINFO_CODE_TARGET_ASSIST_TERMINATED (0x00070001)
  60. #define IOP_LOGINFO_CODE_TARGET_STATUS_SEND_TERMINATED (0x00070002)
  61. #define IOP_LOGINFO_CODE_TARGET_MODE_ABORT_ALL_IO (0x00070003)
  62. #define IOP_LOGINFO_CODE_TARGET_MODE_ABORT_EXACT_IO (0x00070004)
  63. #define IOP_LOGINFO_CODE_TARGET_MODE_ABORT_EXACT_IO_REQ (0x00070005)
  64. #define IOP_LOGINFO_CODE_LOG_TIMESTAMP_EVENT (0x00080000)
  65. /****************************************************************************/
  66. /* PL LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = PL */
  67. /****************************************************************************/
  68. #define PL_LOGINFO_CODE_OPEN_FAILURE (0x00010000) /* see SUB_CODE_OPEN_FAIL_ below */
  69. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_NO_DEST_TIME_OUT (0x00000001)
  70. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_PATHWAY_BLOCKED (0x00000002)
  71. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RES_CONTINUE0 (0x00000003)
  72. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RES_CONTINUE1 (0x00000004)
  73. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RES_INITIALIZE0 (0x00000005)
  74. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RES_INITIALIZE1 (0x00000006)
  75. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RES_STOP0 (0x00000007)
  76. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RES_STOP1 (0x00000008)
  77. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RETRY (0x00000009)
  78. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_BREAK (0x0000000A)
  79. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_UNUSED_0B (0x0000000B)
  80. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_OPEN_TIMEOUT_EXP (0x0000000C)
  81. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_UNUSED_0D (0x0000000D)
  82. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_DVTBLE_ACCSS_FAIL (0x0000000E)
  83. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_BAD_DEST (0x00000011)
  84. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RATE_NOT_SUPP (0x00000012)
  85. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_PROT_NOT_SUPP (0x00000013)
  86. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RESERVED_ABANDON0 (0x00000014)
  87. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RESERVED_ABANDON1 (0x00000015)
  88. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RESERVED_ABANDON2 (0x00000016)
  89. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_RESERVED_ABANDON3 (0x00000017)
  90. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_STP_RESOURCES_BSY (0x00000018)
  91. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_WRONG_DESTINATION (0x00000019)
  92. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_PATH_BLOCKED (0x0000001B) /* Retry Timeout */
  93. #define PL_LOGINFO_SUB_CODE_OPEN_FAIL_AWT_MAXED (0x0000001C) /* Retry Timeout */
  94. #define PL_LOGINFO_CODE_INVALID_SGL (0x00020000)
  95. #define PL_LOGINFO_CODE_WRONG_REL_OFF_OR_FRAME_LENGTH (0x00030000)
  96. #define PL_LOGINFO_CODE_FRAME_XFER_ERROR (0x00040000)
  97. #define PL_LOGINFO_CODE_TX_FM_CONNECTED_LOW (0x00050000)
  98. #define PL_LOGINFO_CODE_SATA_NON_NCQ_RW_ERR_BIT_SET (0x00060000)
  99. #define PL_LOGINFO_CODE_SATA_READ_LOG_RECEIVE_DATA_ERR (0x00070000)
  100. #define PL_LOGINFO_CODE_SATA_NCQ_FAIL_ALL_CMDS_AFTR_ERR (0x00080000)
  101. #define PL_LOGINFO_CODE_SATA_ERR_IN_RCV_SET_DEV_BIT_FIS (0x00090000)
  102. #define PL_LOGINFO_CODE_RX_FM_INVALID_MESSAGE (0x000A0000)
  103. #define PL_LOGINFO_CODE_RX_CTX_MESSAGE_VALID_ERROR (0x000B0000)
  104. #define PL_LOGINFO_CODE_RX_FM_CURRENT_FRAME_ERROR (0x000C0000)
  105. #define PL_LOGINFO_CODE_SATA_LINK_DOWN (0x000D0000)
  106. #define PL_LOGINFO_CODE_DISCOVERY_SATA_INIT_W_IOS (0x000E0000)
  107. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE (0x000F0000)
  108. #define PL_LOGINFO_CODE_CONFIG_PL_NOT_INITIALIZED (0x000F0001) /* PL not yet initialized, can't do config page req. */
  109. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_PT (0x000F0100) /* Invalid Page Type */
  110. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NUM_PHYS (0x000F0200) /* Invalid Number of Phys */
  111. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NOT_IMP (0x000F0300) /* Case Not Handled */
  112. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NO_DEV (0x000F0400) /* No Device Found */
  113. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_FORM (0x000F0500) /* Invalid FORM */
  114. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_PHY (0x000F0600) /* Invalid Phy */
  115. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NO_OWNER (0x000F0700) /* No Owner Found */
  116. #define PL_LOGINFO_CODE_DSCVRY_SATA_INIT_TIMEOUT (0x00100000)
  117. #define PL_LOGINFO_CODE_RESET (0x00110000) /* See Sub-Codes below (PL_LOGINFO_SUB_CODE) */
  118. #define PL_LOGINFO_CODE_ABORT (0x00120000) /* See Sub-Codes below (PL_LOGINFO_SUB_CODE)*/
  119. #define PL_LOGINFO_CODE_IO_NOT_YET_EXECUTED (0x00130000)
  120. #define PL_LOGINFO_CODE_IO_EXECUTED (0x00140000)
  121. #define PL_LOGINFO_CODE_PERS_RESV_OUT_NOT_AFFIL_OWNER (0x00150000)
  122. #define PL_LOGINFO_CODE_OPEN_TXDMA_ABORT (0x00160000)
  123. #define PL_LOGINFO_CODE_IO_DEVICE_MISSING_DELAY_RETRY (0x00170000)
  124. #define PL_LOGINFO_CODE_IO_CANCELLED_DUE_TO_R_ERR (0x00180000)
  125. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE (0x00000100)
  126. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_NO_DEST_TIMEOUT (0x00000101)
  127. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_SATA_NEG_RATE_2HI (0x00000102)
  128. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_RATE_NOT_SUPPORTED (0x00000103)
  129. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_BREAK (0x00000104)
  130. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ZONE_VIOLATION (0x00000114)
  131. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ABANDON0 (0x00000114) /* Open Reject (Zone Violation) - available on SAS-2 devices */
  132. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ABANDON1 (0x00000115)
  133. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ABANDON2 (0x00000116)
  134. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ABANDON3 (0x00000117)
  135. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ORR_TIMEOUT (0x0000011A) /* Open Reject (Retry) Timeout */
  136. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_PATH_BLOCKED (0x0000011B)
  137. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_AWT_MAXED (0x0000011C) /* Arbitration Wait Timer Maxed */
  138. #define PL_LOGINFO_SUB_CODE_TARGET_BUS_RESET (0x00000120)
  139. #define PL_LOGINFO_SUB_CODE_TRANSPORT_LAYER (0x00000130) /* Leave lower nibble (1-f) reserved. */
  140. #define PL_LOGINFO_SUB_CODE_PORT_LAYER (0x00000140) /* Leave lower nibble (1-f) reserved. */
  141. #define PL_LOGINFO_SUB_CODE_INVALID_SGL (0x00000200)
  142. #define PL_LOGINFO_SUB_CODE_WRONG_REL_OFF_OR_FRAME_LENGTH (0x00000300)
  143. #define PL_LOGINFO_SUB_CODE_FRAME_XFER_ERROR (0x00000400)
  144. /* Bits 0-3 encode Transport Status Register (offset 0x08) */
  145. /* Bit 0 is Status Bit 0: FrameXferErr */
  146. /* Bit 1 & 2 are Status Bits 16 and 17: FrameXmitErrStatus */
  147. /* Bit 3 is Status Bit 18 WriteDataLenghtGTDataLengthErr */
  148. #define PL_LOGINFO_SUB_CODE_TX_FM_CONNECTED_LOW (0x00000500)
  149. #define PL_LOGINFO_SUB_CODE_SATA_NON_NCQ_RW_ERR_BIT_SET (0x00000600)
  150. #define PL_LOGINFO_SUB_CODE_SATA_READ_LOG_RECEIVE_DATA_ERR (0x00000700)
  151. #define PL_LOGINFO_SUB_CODE_SATA_NCQ_FAIL_ALL_CMDS_AFTR_ERR (0x00000800)
  152. #define PL_LOGINFO_SUB_CODE_SATA_ERR_IN_RCV_SET_DEV_BIT_FIS (0x00000900)
  153. #define PL_LOGINFO_SUB_CODE_RX_FM_INVALID_MESSAGE (0x00000A00)
  154. #define PL_LOGINFO_SUB_CODE_RX_CTX_MESSAGE_VALID_ERROR (0x00000B00)
  155. #define PL_LOGINFO_SUB_CODE_RX_FM_CURRENT_FRAME_ERROR (0x00000C00)
  156. #define PL_LOGINFO_SUB_CODE_SATA_LINK_DOWN (0x00000D00)
  157. #define PL_LOGINFO_SUB_CODE_DISCOVERY_SATA_INIT_W_IOS (0x00000E00)
  158. #define PL_LOGINFO_SUB_CODE_DISCOVERY_REMOTE_SEP_RESET (0x00000E01)
  159. #define PL_LOGINFO_SUB_CODE_SECOND_OPEN (0x00000F00)
  160. #define PL_LOGINFO_SUB_CODE_DSCVRY_SATA_INIT_TIMEOUT (0x00001000)
  161. #define PL_LOGINFO_SUB_CODE_BREAK_ON_SATA_CONNECTION (0x00002000)
  162. /* not currently used in mainline */
  163. #define PL_LOGINFO_SUB_CODE_BREAK_ON_STUCK_LINK (0x00003000)
  164. #define PL_LOGINFO_SUB_CODE_BREAK_ON_STUCK_LINK_AIP (0x00004000)
  165. #define PL_LOGINFO_SUB_CODE_BREAK_ON_INCOMPLETE_BREAK_RCVD (0x00005000)
  166. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_FRAME_FAILURE (0x00200000) /* Can't get SMP Frame */
  167. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_READ_ERROR (0x00200010) /* Error occurred on SMP Read */
  168. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_WRITE_ERROR (0x00200020) /* Error occurred on SMP Write */
  169. #define PL_LOGINFO_CODE_ENCL_MGMT_NOT_SUPPORTED_ON_ENCL (0x00200040) /* Encl Mgmt services not available for this WWID */
  170. #define PL_LOGINFO_CODE_ENCL_MGMT_ADDR_MODE_NOT_SUPPORTED (0x00200050) /* Address Mode not suppored */
  171. #define PL_LOGINFO_CODE_ENCL_MGMT_BAD_SLOT_NUM (0x00200060) /* Invalid Slot Number in SEP Msg */
  172. #define PL_LOGINFO_CODE_ENCL_MGMT_SGPIO_NOT_PRESENT (0x00200070) /* SGPIO not present/enabled */
  173. #define PL_LOGINFO_CODE_ENCL_MGMT_GPIO_NOT_CONFIGURED (0x00200080) /* GPIO not configured */
  174. #define PL_LOGINFO_CODE_ENCL_MGMT_GPIO_FRAME_ERROR (0x00200090) /* GPIO can't allocate a frame */
  175. #define PL_LOGINFO_CODE_ENCL_MGMT_GPIO_CONFIG_PAGE_ERROR (0x002000A0) /* GPIO failed config page request */
  176. #define PL_LOGINFO_CODE_ENCL_MGMT_SES_FRAME_ALLOC_ERROR (0x002000B0) /* Can't get frame for SES command */
  177. #define PL_LOGINFO_CODE_ENCL_MGMT_SES_IO_ERROR (0x002000C0) /* I/O execution error */
  178. #define PL_LOGINFO_CODE_ENCL_MGMT_SES_RETRIES_EXHAUSTED (0x002000D0) /* SEP I/O retries exhausted */
  179. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_FRAME_ALLOC_ERROR (0x002000E0) /* Can't get frame for SMP command */
  180. #define PL_LOGINFO_DA_SEP_NOT_PRESENT (0x00200100) /* SEP not present when msg received */
  181. #define PL_LOGINFO_DA_SEP_SINGLE_THREAD_ERROR (0x00200101) /* Can only accept 1 msg at a time */
  182. #define PL_LOGINFO_DA_SEP_ISTWI_INTR_IN_IDLE_STATE (0x00200102) /* ISTWI interrupt recvd. while IDLE */
  183. #define PL_LOGINFO_DA_SEP_RECEIVED_NACK_FROM_SLAVE (0x00200103) /* SEP NACK'd, it is busy */
  184. #define PL_LOGINFO_DA_SEP_DID_NOT_RECEIVE_ACK (0x00200104) /* SEP didn't rcv. ACK (Last Rcvd Bit = 1) */
  185. #define PL_LOGINFO_DA_SEP_BAD_STATUS_HDR_CHKSUM (0x00200105) /* SEP stopped or sent bad chksum in Hdr */
  186. #define PL_LOGINFO_DA_SEP_STOP_ON_DATA (0x00200106) /* SEP stopped while transferring data */
  187. #define PL_LOGINFO_DA_SEP_STOP_ON_SENSE_DATA (0x00200107) /* SEP stopped while transferring sense data */
  188. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_SCSI_STATUS_1 (0x00200108) /* SEP returned unknown scsi status */
  189. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_SCSI_STATUS_2 (0x00200109) /* SEP returned unknown scsi status */
  190. #define PL_LOGINFO_DA_SEP_CHKSUM_ERROR_AFTER_STOP (0x0020010A) /* SEP returned bad chksum after STOP */
  191. #define PL_LOGINFO_DA_SEP_CHKSUM_ERROR_AFTER_STOP_GETDATA (0x0020010B) /* SEP returned bad chksum after STOP while gettin data*/
  192. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_COMMAND (0x0020010C) /* SEP doesn't support CDB opcode f/w location 1 */
  193. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_COMMAND_2 (0x0020010D) /* SEP doesn't support CDB opcode f/w location 2 */
  194. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_COMMAND_3 (0x0020010E) /* SEP doesn't support CDB opcode f/w location 3 */
  195. /****************************************************************************/
  196. /* IR LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = IR */
  197. /****************************************************************************/
  198. #define IR_LOGINFO_RAID_ACTION_ERROR (0x00010000)
  199. #define IR_LOGINFO_CODE_UNUSED2 (0x00020000)
  200. /* Amount of information passed down for Create Volume is too large */
  201. #define IR_LOGINFO_VOLUME_CREATE_INVALID_LENGTH (0x00010001)
  202. /* Creation of duplicate volume attempted (Bus/Target ID checked) */
  203. #define IR_LOGINFO_VOLUME_CREATE_DUPLICATE (0x00010002)
  204. /* Creation failed due to maximum number of supported volumes exceeded */
  205. #define IR_LOGINFO_VOLUME_CREATE_NO_SLOTS (0x00010003)
  206. /* Creation failed due to DMA error in trying to read from host */
  207. #define IR_LOGINFO_VOLUME_CREATE_DMA_ERROR (0x00010004)
  208. /* Creation failed due to invalid volume type passed down */
  209. #define IR_LOGINFO_VOLUME_CREATE_INVALID_VOLUME_TYPE (0x00010005)
  210. /* Creation failed due to error reading MFG Page 4 */
  211. #define IR_LOGINFO_VOLUME_MFG_PAGE4_ERROR (0x00010006)
  212. /* Creation failed when trying to create internal structures */
  213. #define IR_LOGINFO_VOLUME_INTERNAL_CONFIG_STRUCTURE_ERROR (0x00010007)
  214. /* Activation failed due to trying to activate an already active volume */
  215. #define IR_LOGINFO_VOLUME_ACTIVATING_AN_ACTIVE_VOLUME (0x00010010)
  216. /* Activation failed due to trying to active unsupported volume type */
  217. #define IR_LOGINFO_VOLUME_ACTIVATING_INVALID_VOLUME_TYPE (0x00010011)
  218. /* Activation failed due to trying to active too many volumes */
  219. #define IR_LOGINFO_VOLUME_ACTIVATING_TOO_MANY_VOLUMES (0x00010012)
  220. /* Activation failed due to Volume ID in use already */
  221. #define IR_LOGINFO_VOLUME_ACTIVATING_VOLUME_ID_IN_USE (0x00010013)
  222. /* Activation failed call to activateVolume returned failure */
  223. #define IR_LOGINFO_VOLUME_ACTIVATE_VOLUME_FAILED (0x00010014)
  224. /* Activation failed trying to import the volume */
  225. #define IR_LOGINFO_VOLUME_ACTIVATING_IMPORT_VOLUME_FAILED (0x00010015)
  226. /* Activation failed trying to import the volume */
  227. #define IR_LOGINFO_VOLUME_ACTIVATING_TOO_MANY_PHYS_DISKS (0x00010016)
  228. /* Phys Disk failed, too many phys disks */
  229. #define IR_LOGINFO_PHYSDISK_CREATE_TOO_MANY_DISKS (0x00010020)
  230. /* Amount of information passed down for Create Pnysdisk is too large */
  231. #define IR_LOGINFO_PHYSDISK_CREATE_INVALID_LENGTH (0x00010021)
  232. /* Creation failed due to DMA error in trying to read from host */
  233. #define IR_LOGINFO_PHYSDISK_CREATE_DMA_ERROR (0x00010022)
  234. /* Creation failed due to invalid Bus TargetID passed down */
  235. #define IR_LOGINFO_PHYSDISK_CREATE_BUS_TID_INVALID (0x00010023)
  236. /* Creation failed due to error in creating RAID Phys Disk Config Page */
  237. #define IR_LOGINFO_PHYSDISK_CREATE_CONFIG_PAGE_ERROR (0x00010024)
  238. /* Compatibility Error : IR Disabled */
  239. #define IR_LOGINFO_COMPAT_ERROR_RAID_DISABLED (0x00010030)
  240. /* Compatibility Error : Inquiry Command failed */
  241. #define IR_LOGINFO_COMPAT_ERROR_INQUIRY_FAILED (0x00010031)
  242. /* Compatibility Error : Device not direct access device */
  243. #define IR_LOGINFO_COMPAT_ERROR_NOT_DIRECT_ACCESS (0x00010032)
  244. /* Compatibility Error : Removable device found */
  245. #define IR_LOGINFO_COMPAT_ERROR_REMOVABLE_FOUND (0x00010033)
  246. /* Compatibility Error : Device SCSI Version not 2 or higher */
  247. #define IR_LOGINFO_COMPAT_ERROR_NEED_SCSI_2_OR_HIGHER (0x00010034)
  248. /* Compatibility Error : SATA device, 48 BIT LBA not supported */
  249. #define IR_LOGINFO_COMPAT_ERROR_SATA_48BIT_LBA_NOT_SUPPORTED (0x00010035)
  250. /* Compatibility Error : Device does not have 512 byte block sizes */
  251. #define IR_LOGINFO_COMPAT_ERROR_DEVICE_NOT_512_BYTE_BLOCK (0x00010036)
  252. /* Compatibility Error : Volume Type check failed */
  253. #define IR_LOGINFO_COMPAT_ERROR_VOLUME_TYPE_CHECK_FAILED (0x00010037)
  254. /* Compatibility Error : Volume Type is unsupported by FW */
  255. #define IR_LOGINFO_COMPAT_ERROR_UNSUPPORTED_VOLUME_TYPE (0x00010038)
  256. /* Compatibility Error : Disk drive too small for use in volume */
  257. #define IR_LOGINFO_COMPAT_ERROR_DISK_TOO_SMALL (0x00010039)
  258. /* Compatibility Error : Phys disk for Create Volume not found */
  259. #define IR_LOGINFO_COMPAT_ERROR_PHYS_DISK_NOT_FOUND (0x0001003A)
  260. /* Compatibility Error : membership count error, too many or too few disks for volume type */
  261. #define IR_LOGINFO_COMPAT_ERROR_MEMBERSHIP_COUNT (0x0001003B)
  262. /* Compatibility Error : Disk stripe sizes must be 64KB */
  263. #define IR_LOGINFO_COMPAT_ERROR_NON_64K_STRIPE_SIZE (0x0001003C)
  264. /* Compatibility Error : IME size limited to < 2TB */
  265. #define IR_LOGINFO_COMPAT_ERROR_IME_VOL_NOT_CURRENTLY_SUPPORTED (0x0001003D)
  266. /* Device Firmware Update: DFU can only be started once */
  267. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_DFU_IN_PROGRESS (0x00010050)
  268. /* Device Firmware Update: Volume must be Optimal/Active/non-Quiesced */
  269. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_DEVICE_IN_INVALID_STATE (0x00010051)
  270. /* Device Firmware Update: DFU Timeout cannot be zero */
  271. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_INVALID_TIMEOUT (0x00010052)
  272. /* Device Firmware Update: CREATE TIMER FAILED */
  273. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_NO_TIMERS (0x00010053)
  274. /* Device Firmware Update: Failed to read SAS_IO_UNIT_PG_1 */
  275. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_READING_CFG_PAGE (0x00010054)
  276. /* Device Firmware Update: Invalid SAS_IO_UNIT_PG_1 value(s) */
  277. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_PORT_IO_TIMEOUTS_REQUIRED (0x00010055)
  278. /* Device Firmware Update: Unable to allocate memory for page */
  279. #define IR_LOGINFO_DEV_FW_UPDATE_ERR_ALLOC_CFG_PAGE (0x00010056)
  280. /****************************************************************************/
  281. /* Defines for convenience */
  282. /****************************************************************************/
  283. #define IOC_LOGINFO_PREFIX_IOP ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_IOP)
  284. #define IOC_LOGINFO_PREFIX_PL ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_PL)
  285. #define IOC_LOGINFO_PREFIX_IR ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_IR)
  286. #endif /* end of file */