Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 1 | |
| 2 | /*************************************************************************** |
| 3 | * * |
| 4 | * Copyright 2003 LSI Logic Corporation. All rights reserved. * |
| 5 | * * |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 6 | * Description * |
| 7 | * ------------ * |
| 8 | * This include file contains SAS firmware interface IOC Log Info codes * |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 9 | * * |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 10 | *-------------------------------------------------------------------------* |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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 | |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 33 | #define IOC_LOGINFO_ORIGINATOR_MASK (0x0F000000) |
| 34 | |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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 | |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 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) |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 64 | |
| 65 | /****************************************************************************/ |
| 66 | /* PL LOGINFO_CODE defines, valid if IOC_LOGINFO_ORIGINATOR = PL */ |
| 67 | /****************************************************************************/ |
| 68 | #define PL_LOGINFO_CODE_OPEN_FAILURE (0x00010000) |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 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) |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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) |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 91 | #define PL_LOGINFO_CODE_CONFIG_PL_NOT_INITIALIZED (0x000F0001) /* PL not yet initialized, can't do config page req. */ |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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) |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 100 | #define PL_LOGINFO_CODE_RESET (0x00110000) /* See Sub-Codes below */ |
| 101 | #define PL_LOGINFO_CODE_ABORT (0x00120000) /* See Sub-Codes below */ |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 102 | #define PL_LOGINFO_CODE_IO_NOT_YET_EXECUTED (0x00130000) |
| 103 | #define PL_LOGINFO_CODE_IO_EXECUTED (0x00140000) |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 104 | #define PL_LOGINFO_CODE_PERS_RESV_OUT_NOT_AFFIL_OWNER (0x00150000) |
| 105 | #define PL_LOGINFO_CODE_OPEN_TXDMA_ABORT (0x00160000) |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 106 | #define PL_LOGINFO_SUB_CODE_OPEN_FAILURE (0x00000100) |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 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 | |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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) |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 130 | #define PL_LOGINFO_SUB_CODE_DISCOVERY_REMOTE_SEP_RESET (0x00000E01) |
| 131 | #define PL_LOGINFO_SUB_CODE_SECOND_OPEN (0x00000F00) |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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 */ |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 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 */ |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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 */ |
Moore, Eric | 5bf52c4 | 2006-03-14 09:14:01 -0700 | [diff] [blame^] | 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 */ |
Moore, Eric | 4b915a7 | 2006-01-13 16:25:23 -0700 | [diff] [blame] | 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 | |