mpi_log_sas.h 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /***************************************************************************
  2. * *
  3. * Copyright 2003 LSI Logic Corporation. All rights reserved. *
  4. * *
  5. * This file is confidential and a trade secret of LSI Logic. The *
  6. * receipt of or possession of this file does not convey any rights to *
  7. * reproduce or disclose its contents or to manufacture, use, or sell *
  8. * anything it may describe, in whole, or in part, without the specific *
  9. * written consent of LSI Logic Corporation. *
  10. * *
  11. ***************************************************************************
  12. *
  13. * Name: iopiIocLogInfo.h
  14. * Title: SAS Firmware IOP Interface IOC Log Info Definitions
  15. * Programmer: Guy Kendall
  16. * Creation Date: September 24, 2003
  17. *
  18. * Version History
  19. * ---------------
  20. *
  21. * Last Updated
  22. * -------------
  23. * Version %version: 22 %
  24. * Date Updated %date_modified: %
  25. * Programmer %created_by: nperucca %
  26. *
  27. * Date Who Description
  28. * -------- --- -------------------------------------------------------
  29. * 09/24/03 GWK Initial version
  30. *
  31. *
  32. * Description
  33. * ------------
  34. * This include file contains SAS firmware interface IOC Log Info codes
  35. *
  36. *-------------------------------------------------------------------------
  37. */
  38. #ifndef IOPI_IOCLOGINFO_H_INCLUDED
  39. #define IOPI_IOCLOGINFO_H_INCLUDED
  40. /****************************************************************************/
  41. /* IOC LOGINFO defines, 0x00000000 - 0x0FFFFFFF */
  42. /* Format: */
  43. /* Bits 31-28: MPI_IOCLOGINFO_TYPE_SAS (3) */
  44. /* Bits 27-24: IOC_LOGINFO_ORIGINATOR: 0=IOP, 1=PL, 2=IR */
  45. /* Bits 23-16: LOGINFO_CODE */
  46. /* Bits 15-0: LOGINFO_CODE Specific */
  47. /****************************************************************************/
  48. /****************************************************************************/
  49. /* IOC_LOGINFO_ORIGINATOR defines */
  50. /****************************************************************************/
  51. #define IOC_LOGINFO_ORIGINATOR_IOP (0x00000000)
  52. #define IOC_LOGINFO_ORIGINATOR_PL (0x01000000)
  53. #define IOC_LOGINFO_ORIGINATOR_IR (0x02000000)
  54. /****************************************************************************/
  55. /* LOGINFO_CODE defines */
  56. /****************************************************************************/
  57. #define IOC_LOGINFO_CODE_MASK (0x00FF0000)
  58. #define IOC_LOGINFO_CODE_SHIFT (16)
  59. /****************************************************************************/
  60. /* IOP LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = IOP */
  61. /****************************************************************************/
  62. #define IOP_LOGINFO_CODE_INVALID_SAS_ADDRESS (0x00010000)
  63. #define IOP_LOGINFO_CODE_UNUSED2 (0x00020000)
  64. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE (0x00030000)
  65. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_RT (0x00030100) /* Route Table Entry not found */
  66. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PN (0x00030200) /* Invalid Page Number */
  67. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_FORM (0x00030300) /* Invalid FORM */
  68. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PT (0x00030400) /* Invalid Page Type */
  69. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_DNM (0x00030500) /* Device Not Mapped */
  70. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PERSIST (0x00030600) /* Persistent Page not found */
  71. #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_DEFAULT (0x00030700) /* Default Page not found */
  72. #define IOP_LOGINFO_CODE_TASK_TERMINATED (0x00050000)
  73. /****************************************************************************/
  74. /* PL LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = PL */
  75. /****************************************************************************/
  76. #define PL_LOGINFO_CODE_OPEN_FAILURE (0x00010000)
  77. #define PL_LOGINFO_CODE_INVALID_SGL (0x00020000)
  78. #define PL_LOGINFO_CODE_WRONG_REL_OFF_OR_FRAME_LENGTH (0x00030000)
  79. #define PL_LOGINFO_CODE_FRAME_XFER_ERROR (0x00040000)
  80. #define PL_LOGINFO_CODE_TX_FM_CONNECTED_LOW (0x00050000)
  81. #define PL_LOGINFO_CODE_SATA_NON_NCQ_RW_ERR_BIT_SET (0x00060000)
  82. #define PL_LOGINFO_CODE_SATA_READ_LOG_RECEIVE_DATA_ERR (0x00070000)
  83. #define PL_LOGINFO_CODE_SATA_NCQ_FAIL_ALL_CMDS_AFTR_ERR (0x00080000)
  84. #define PL_LOGINFO_CODE_SATA_ERR_IN_RCV_SET_DEV_BIT_FIS (0x00090000)
  85. #define PL_LOGINFO_CODE_RX_FM_INVALID_MESSAGE (0x000A0000)
  86. #define PL_LOGINFO_CODE_RX_CTX_MESSAGE_VALID_ERROR (0x000B0000)
  87. #define PL_LOGINFO_CODE_RX_FM_CURRENT_FRAME_ERROR (0x000C0000)
  88. #define PL_LOGINFO_CODE_SATA_LINK_DOWN (0x000D0000)
  89. #define PL_LOGINFO_CODE_DISCOVERY_SATA_INIT_W_IOS (0x000E0000)
  90. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE (0x000F0000)
  91. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_PT (0x000F0100) /* Invalid Page Type */
  92. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NUM_PHYS (0x000F0200) /* Invalid Number of Phys */
  93. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NOT_IMP (0x000F0300) /* Case Not Handled */
  94. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NO_DEV (0x000F0400) /* No Device Found */
  95. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_FORM (0x000F0500) /* Invalid FORM */
  96. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_PHY (0x000F0600) /* Invalid Phy */
  97. #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NO_OWNER (0x000F0700) /* No Owner Found */
  98. #define PL_LOGINFO_CODE_DSCVRY_SATA_INIT_TIMEOUT (0x00100000)
  99. #define PL_LOGINFO_CODE_RESET (0x00110000)
  100. #define PL_LOGINFO_CODE_ABORT (0x00120000)
  101. #define PL_LOGINFO_CODE_IO_NOT_YET_EXECUTED (0x00130000)
  102. #define PL_LOGINFO_CODE_IO_EXECUTED (0x00140000)
  103. #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE (0x00000100)
  104. #define PL_LOGINFO_SUB_CODE_INVALID_SGL (0x00000200)
  105. #define PL_LOGINFO_SUB_CODE_WRONG_REL_OFF_OR_FRAME_LENGTH (0x00000300)
  106. #define PL_LOGINFO_SUB_CODE_FRAME_XFER_ERROR (0x00000400)
  107. #define PL_LOGINFO_SUB_CODE_TX_FM_CONNECTED_LOW (0x00000500)
  108. #define PL_LOGINFO_SUB_CODE_SATA_NON_NCQ_RW_ERR_BIT_SET (0x00000600)
  109. #define PL_LOGINFO_SUB_CODE_SATA_READ_LOG_RECEIVE_DATA_ERR (0x00000700)
  110. #define PL_LOGINFO_SUB_CODE_SATA_NCQ_FAIL_ALL_CMDS_AFTR_ERR (0x00000800)
  111. #define PL_LOGINFO_SUB_CODE_SATA_ERR_IN_RCV_SET_DEV_BIT_FIS (0x00000900)
  112. #define PL_LOGINFO_SUB_CODE_RX_FM_INVALID_MESSAGE (0x00000A00)
  113. #define PL_LOGINFO_SUB_CODE_RX_CTX_MESSAGE_VALID_ERROR (0x00000B00)
  114. #define PL_LOGINFO_SUB_CODE_RX_FM_CURRENT_FRAME_ERROR (0x00000C00)
  115. #define PL_LOGINFO_SUB_CODE_SATA_LINK_DOWN (0x00000D00)
  116. #define PL_LOGINFO_SUB_CODE_DISCOVERY_SATA_INIT_W_IOS (0x00000E00)
  117. #define PL_LOGINFO_SUB_CODE_DSCVRY_SATA_INIT_TIMEOUT (0x00001000)
  118. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_FRAME_FAILURE (0x00200000) /* Can't get SMP Frame */
  119. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_READ_ERROR (0x00200001) /* Error occured on SMP Read */
  120. #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_WRITE_ERROR (0x00200002) /* Error occured on SMP Write */
  121. #define PL_LOGINFO_CODE_ENCL_MGMT_NOT_SUPPORTED_ON_ENCL (0x00200004) /* Encl Mgmt services not available for this WWID */
  122. #define PL_LOGINFO_CODE_ENCL_MGMT_ADDR_MODE_NOT_SUPPORTED (0x00200005) /* Address Mode not suppored */
  123. #define PL_LOGINFO_CODE_ENCL_MGMT_BAD_SLOT_NUM (0x00200006) /* Invalid Slot Number in SEP Msg */
  124. #define PL_LOGINFO_CODE_ENCL_MGMT_SGPIO_NOT_PRESENT (0x00200007) /* SGPIO not present/enabled */
  125. #define PL_LOGINFO_DA_SEP_NOT_PRESENT (0x00200100) /* SEP not present when msg received */
  126. #define PL_LOGINFO_DA_SEP_SINGLE_THREAD_ERROR (0x00200101) /* Can only accept 1 msg at a time */
  127. #define PL_LOGINFO_DA_SEP_ISTWI_INTR_IN_IDLE_STATE (0x00200102) /* ISTWI interrupt recvd. while IDLE */
  128. #define PL_LOGINFO_DA_SEP_RECEIVED_NACK_FROM_SLAVE (0x00200103) /* SEP NACK'd, it is busy */
  129. #define PL_LOGINFO_DA_SEP_BAD_STATUS_HDR_CHKSUM (0x00200104) /* SEP stopped or sent bad chksum in Hdr */
  130. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_SCSI_STATUS_1 (0x00200105) /* SEP returned unknown scsi status */
  131. #define PL_LOGINFO_DA_SEP_UNSUPPORTED_SCSI_STATUS_2 (0x00200106) /* SEP returned unknown scsi status */
  132. #define PL_LOGINFO_DA_SEP_CHKSUM_ERROR_AFTER_STOP (0x00200107) /* SEP returned bad chksum after STOP */
  133. #define PL_LOGINFO_DA_SEP_CHKSUM_ERROR_AFTER_STOP_GETDATA (0x00200108) /* SEP returned bad chksum after STOP while gettin data*/
  134. /****************************************************************************/
  135. /* IR LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = IR */
  136. /****************************************************************************/
  137. #define IR_LOGINFO_CODE_UNUSED1 (0x00010000)
  138. #define IR_LOGINFO_CODE_UNUSED2 (0x00020000)
  139. /****************************************************************************/
  140. /* Defines for convienence */
  141. /****************************************************************************/
  142. #define IOC_LOGINFO_PREFIX_IOP ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_IOP)
  143. #define IOC_LOGINFO_PREFIX_PL ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_PL)
  144. #define IOC_LOGINFO_PREFIX_IR ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_IR)
  145. #endif /* end of file */