1 2 /*************************************************************************** 3 * * 4 * Copyright 2003 LSI Logic Corporation. All rights reserved. * 5 * * 6 * Description * 7 * ------------ * 8 * This include file contains SAS firmware interface IOC Log Info codes * 9 * * 10 *-------------------------------------------------------------------------* 11 */ 12 13 #ifndef IOPI_IOCLOGINFO_H_INCLUDED 14 #define IOPI_IOCLOGINFO_H_INCLUDED 15 16 17 /****************************************************************************/ 18 /* IOC LOGINFO defines, 0x00000000 - 0x0FFFFFFF */ 19 /* Format: */ 20 /* Bits 31-28: MPI_IOCLOGINFO_TYPE_SAS (3) */ 21 /* Bits 27-24: IOC_LOGINFO_ORIGINATOR: 0=IOP, 1=PL, 2=IR */ 22 /* Bits 23-16: LOGINFO_CODE */ 23 /* Bits 15-0: LOGINFO_CODE Specific */ 24 /****************************************************************************/ 25 26 /****************************************************************************/ 27 /* IOC_LOGINFO_ORIGINATOR defines */ 28 /****************************************************************************/ 29 #define IOC_LOGINFO_ORIGINATOR_IOP (0x00000000) 30 #define IOC_LOGINFO_ORIGINATOR_PL (0x01000000) 31 #define IOC_LOGINFO_ORIGINATOR_IR (0x02000000) 32 33 #define IOC_LOGINFO_ORIGINATOR_MASK (0x0F000000) 34 35 /****************************************************************************/ 36 /* LOGINFO_CODE defines */ 37 /****************************************************************************/ 38 #define IOC_LOGINFO_CODE_MASK (0x00FF0000) 39 #define IOC_LOGINFO_CODE_SHIFT (16) 40 41 /****************************************************************************/ 42 /* IOP LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = IOP */ 43 /****************************************************************************/ 44 #define IOP_LOGINFO_CODE_INVALID_SAS_ADDRESS (0x00010000) 45 #define IOP_LOGINFO_CODE_UNUSED2 (0x00020000) 46 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE (0x00030000) 47 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_RT (0x00030100) /* Route Table Entry not found */ 48 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PN (0x00030200) /* Invalid Page Number */ 49 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_FORM (0x00030300) /* Invalid FORM */ 50 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PT (0x00030400) /* Invalid Page Type */ 51 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_DNM (0x00030500) /* Device Not Mapped */ 52 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_PERSIST (0x00030600) /* Persistent Page not found */ 53 #define IOP_LOGINFO_CODE_CONFIG_INVALID_PAGE_DEFAULT (0x00030700) /* Default Page not found */ 54 #define IOP_LOGINFO_CODE_TASK_TERMINATED (0x00050000) 55 56 #define IOP_LOGINFO_CODE_ENCL_MGMT_READ_ACTION_ERR0R (0x00060001) /* Read Action not supported for SEP msg */ 57 #define IOP_LOGINFO_CODE_ENCL_MGMT_INVALID_BUS_ID_ERR0R (0x00060002) /* Invalid Bus/ID in SEP msg */ 58 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 65 /****************************************************************************/ 66 /* PL LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = PL */ 67 /****************************************************************************/ 68 #define PL_LOGINFO_CODE_OPEN_FAILURE (0x00010000) 69 #define PL_LOG_INFO_CODE_OPEN_FAILURE_NO_DEST_TIME_OUT (0x00010001) 70 #define PL_LOGINFO_CODE_OPEN_FAILURE_BAD_DESTINATION (0x00010011) 71 #define PL_LOGINFO_CODE_OPEN_FAILURE_PROTOCOL_NOT_SUPPORTED (0x00010013) 72 #define PL_LOGINFO_CODE_OPEN_FAILURE_STP_RESOURCES_BSY (0x00010018) 73 #define PL_LOGINFO_CODE_OPEN_FAILURE_WRONG_DESTINATION (0x00010019) 74 #define PL_LOGINFO_CODE_OPEN_FAILURE_ORR_TIMEOUT (0X0001001A) 75 #define PL_LOGINFO_CODE_OPEN_FAILURE_PATHWAY_BLOCKED (0x0001001B) 76 #define PL_LOGINFO_CODE_OPEN_FAILURE_AWT_MAXED (0x0001001C) 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_PL_NOT_INITIALIZED (0x000F0001) /* PL not yet initialized, can't do config page req. */ 92 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_PT (0x000F0100) /* Invalid Page Type */ 93 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NUM_PHYS (0x000F0200) /* Invalid Number of Phys */ 94 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NOT_IMP (0x000F0300) /* Case Not Handled */ 95 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NO_DEV (0x000F0400) /* No Device Found */ 96 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_FORM (0x000F0500) /* Invalid FORM */ 97 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_PHY (0x000F0600) /* Invalid Phy */ 98 #define PL_LOGINFO_CODE_CONFIG_INVALID_PAGE_NO_OWNER (0x000F0700) /* No Owner Found */ 99 #define PL_LOGINFO_CODE_DSCVRY_SATA_INIT_TIMEOUT (0x00100000) 100 #define PL_LOGINFO_CODE_RESET (0x00110000) /* See Sub-Codes below */ 101 #define PL_LOGINFO_CODE_ABORT (0x00120000) /* See Sub-Codes below */ 102 #define PL_LOGINFO_CODE_IO_NOT_YET_EXECUTED (0x00130000) 103 #define PL_LOGINFO_CODE_IO_EXECUTED (0x00140000) 104 #define PL_LOGINFO_CODE_PERS_RESV_OUT_NOT_AFFIL_OWNER (0x00150000) 105 #define PL_LOGINFO_CODE_OPEN_TXDMA_ABORT (0x00160000) 106 #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE (0x00000100) 107 #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_NO_DEST_TIMEOUT (0x00000101) 108 #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_ORR_TIMEOUT (0x0000011A) /* Open Reject (Retry) Timeout */ 109 #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_PATHWAY_BLOCKED (0x0000011B) 110 #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE_AWT_MAXED (0x0000011C) /* Arbitration Wait Timer Maxed */ 111 112 #define PL_LOGINFO_SUB_CODE_TARGET_BUS_RESET (0x00000120) 113 #define PL_LOGINFO_SUB_CODE_TRANSPORT_LAYER (0x00000130) /* Leave lower nibble (1-f) reserved. */ 114 #define PL_LOGINFO_SUB_CODE_PORT_LAYER (0x00000140) /* Leave lower nibble (1-f) reserved. */ 115 116 117 #define PL_LOGINFO_SUB_CODE_INVALID_SGL (0x00000200) 118 #define PL_LOGINFO_SUB_CODE_WRONG_REL_OFF_OR_FRAME_LENGTH (0x00000300) 119 #define PL_LOGINFO_SUB_CODE_FRAME_XFER_ERROR (0x00000400) 120 #define PL_LOGINFO_SUB_CODE_TX_FM_CONNECTED_LOW (0x00000500) 121 #define PL_LOGINFO_SUB_CODE_SATA_NON_NCQ_RW_ERR_BIT_SET (0x00000600) 122 #define PL_LOGINFO_SUB_CODE_SATA_READ_LOG_RECEIVE_DATA_ERR (0x00000700) 123 #define PL_LOGINFO_SUB_CODE_SATA_NCQ_FAIL_ALL_CMDS_AFTR_ERR (0x00000800) 124 #define PL_LOGINFO_SUB_CODE_SATA_ERR_IN_RCV_SET_DEV_BIT_FIS (0x00000900) 125 #define PL_LOGINFO_SUB_CODE_RX_FM_INVALID_MESSAGE (0x00000A00) 126 #define PL_LOGINFO_SUB_CODE_RX_CTX_MESSAGE_VALID_ERROR (0x00000B00) 127 #define PL_LOGINFO_SUB_CODE_RX_FM_CURRENT_FRAME_ERROR (0x00000C00) 128 #define PL_LOGINFO_SUB_CODE_SATA_LINK_DOWN (0x00000D00) 129 #define PL_LOGINFO_SUB_CODE_DISCOVERY_SATA_INIT_W_IOS (0x00000E00) 130 #define PL_LOGINFO_SUB_CODE_DISCOVERY_REMOTE_SEP_RESET (0x00000E01) 131 #define PL_LOGINFO_SUB_CODE_SECOND_OPEN (0x00000F00) 132 #define PL_LOGINFO_SUB_CODE_DSCVRY_SATA_INIT_TIMEOUT (0x00001000) 133 134 135 #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_FRAME_FAILURE (0x00200000) /* Can't get SMP Frame */ 136 #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_READ_ERROR (0x00200010) /* Error occured on SMP Read */ 137 #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_WRITE_ERROR (0x00200020) /* Error occured on SMP Write */ 138 #define PL_LOGINFO_CODE_ENCL_MGMT_NOT_SUPPORTED_ON_ENCL (0x00200040) /* Encl Mgmt services not available for this WWID */ 139 #define PL_LOGINFO_CODE_ENCL_MGMT_ADDR_MODE_NOT_SUPPORTED (0x00200050) /* Address Mode not suppored */ 140 #define PL_LOGINFO_CODE_ENCL_MGMT_BAD_SLOT_NUM (0x00200060) /* Invalid Slot Number in SEP Msg */ 141 #define PL_LOGINFO_CODE_ENCL_MGMT_SGPIO_NOT_PRESENT (0x00200070) /* SGPIO not present/enabled */ 142 #define PL_LOGINFO_CODE_ENCL_MGMT_GPIO_NOT_CONFIGURED (0x00200080) /* GPIO not configured */ 143 #define PL_LOGINFO_CODE_ENCL_MGMT_GPIO_FRAME_ERROR (0x00200090) /* GPIO can't allocate a frame */ 144 #define PL_LOGINFO_CODE_ENCL_MGMT_GPIO_CONFIG_PAGE_ERROR (0x002000A0) /* GPIO failed config page request */ 145 #define PL_LOGINFO_CODE_ENCL_MGMT_SES_FRAME_ALLOC_ERROR (0x002000B0) /* Can't get frame for SES command */ 146 #define PL_LOGINFO_CODE_ENCL_MGMT_SES_IO_ERROR (0x002000C0) /* I/O execution error */ 147 #define PL_LOGINFO_CODE_ENCL_MGMT_SES_RETRIES_EXHAUSTED (0x002000D0) /* SEP I/O retries exhausted */ 148 #define PL_LOGINFO_CODE_ENCL_MGMT_SMP_FRAME_ALLOC_ERROR (0x002000E0) /* Can't get frame for SMP command */ 149 150 #define PL_LOGINFO_DA_SEP_NOT_PRESENT (0x00200100) /* SEP not present when msg received */ 151 #define PL_LOGINFO_DA_SEP_SINGLE_THREAD_ERROR (0x00200101) /* Can only accept 1 msg at a time */ 152 #define PL_LOGINFO_DA_SEP_ISTWI_INTR_IN_IDLE_STATE (0x00200102) /* ISTWI interrupt recvd. while IDLE */ 153 #define PL_LOGINFO_DA_SEP_RECEIVED_NACK_FROM_SLAVE (0x00200103) /* SEP NACK'd, it is busy */ 154 #define PL_LOGINFO_DA_SEP_DID_NOT_RECEIVE_ACK (0x00200104) /* SEP didn't rcv. ACK (Last Rcvd Bit = 1) */ 155 #define PL_LOGINFO_DA_SEP_BAD_STATUS_HDR_CHKSUM (0x00200105) /* SEP stopped or sent bad chksum in Hdr */ 156 #define PL_LOGINFO_DA_SEP_STOP_ON_DATA (0x00200106) /* SEP stopped while transfering data */ 157 #define PL_LOGINFO_DA_SEP_STOP_ON_SENSE_DATA (0x00200107) /* SEP stopped while transfering sense data */ 158 #define PL_LOGINFO_DA_SEP_UNSUPPORTED_SCSI_STATUS_1 (0x00200108) /* SEP returned unknown scsi status */ 159 #define PL_LOGINFO_DA_SEP_UNSUPPORTED_SCSI_STATUS_2 (0x00200109) /* SEP returned unknown scsi status */ 160 #define PL_LOGINFO_DA_SEP_CHKSUM_ERROR_AFTER_STOP (0x0020010A) /* SEP returned bad chksum after STOP */ 161 #define PL_LOGINFO_DA_SEP_CHKSUM_ERROR_AFTER_STOP_GETDATA (0x0020010B) /* SEP returned bad chksum after STOP while gettin data*/ 162 #define PL_LOGINFO_DA_SEP_UNSUPPORTED_COMMAND (0x0020010C) /* SEP doesn't support CDB opcode */ 163 164 165 /****************************************************************************/ 166 /* IR LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = IR */ 167 /****************************************************************************/ 168 #define IR_LOGINFO_CODE_UNUSED1 (0x00010000) 169 #define IR_LOGINFO_CODE_UNUSED2 (0x00020000) 170 171 /****************************************************************************/ 172 /* Defines for convienence */ 173 /****************************************************************************/ 174 #define IOC_LOGINFO_PREFIX_IOP ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_IOP) 175 #define IOC_LOGINFO_PREFIX_PL ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_PL) 176 #define IOC_LOGINFO_PREFIX_IR ((MPI_IOCLOGINFO_TYPE_SAS << MPI_IOCLOGINFO_TYPE_SHIFT) | IOC_LOGINFO_ORIGINATOR_IR) 177 178 #endif /* end of file */ 179 180