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