diff options
| author | Eric Moore <eric.moore@lsi.com> | 2009-03-09 01:21:12 -0600 | 
|---|---|---|
| committer | James Bottomley <James.Bottomley@HansenPartnership.com> | 2009-03-13 16:08:49 -0500 | 
| commit | 635374e7eb110e80d9918b8611198edd56a32975 (patch) | |
| tree | 1c96f9dac921b0b26ee4e93ecd9c79a96fbc7ba6 /drivers/scsi/mpt2sas/mpi/mpi2_init.h | |
| parent | dec3f95959bff957f5bcbf16c2a2823f7e33d1e7 (diff) | |
| download | olio-linux-3.10-635374e7eb110e80d9918b8611198edd56a32975.tar.xz olio-linux-3.10-635374e7eb110e80d9918b8611198edd56a32975.zip  | |
[SCSI] mpt2sas v00.100.11.15
* This is new scsi lld device driver from LSI supporting the SAS 2.0
  standard. I have split patchs by filename.
* Here is list of new 6gb host controllers:
  LSI SAS2004
  LSI SAS2008
  LSI SAS2108
  LSI SAS2116
* Here are the changes in the 4th posting of this patch set:
(1) fix compile errors when SCSI_MPT2SAS_LOGGING is not enabled
(2) add mpt2sas to the SCSI Mid Layer Makefile
(3) append mpt2sas_ to the naming of all non-static functions
(4) fix oops for SMP_PASSTHRU
(5) doorbell algorithm imported changes from windows driver
* Here are the changes in the 3rd posting of this patch set:
(1) add readl following writel from the function that disables interrupts
(2) replace 0xFFFFFFFFFFFFFFFFULL with ~0ULL
(3) when calling pci_enable_msix, only pass one msix entry (instead of 15).
(4) remove the "current HW implementation uses..... " comment in the sources
(5) merged bug fix for SIGIO/POLLIN notifcation; reported by the storlib team.
* Here are the changes in the 2nd posting of this patch set:
(1) use little endian types in the mpi headers
(2) merged in bug fix's from inhouse drivers.
Signed-off-by: Eric Moore <eric.moore@lsi.com>
Tested-by: peter Bogdanovic <pbog@us.ibm.com>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/scsi/mpt2sas/mpi/mpi2_init.h')
| -rw-r--r-- | drivers/scsi/mpt2sas/mpi/mpi2_init.h | 420 | 
1 files changed, 420 insertions, 0 deletions
diff --git a/drivers/scsi/mpt2sas/mpi/mpi2_init.h b/drivers/scsi/mpt2sas/mpi/mpi2_init.h new file mode 100644 index 00000000000..f1115f0f0eb --- /dev/null +++ b/drivers/scsi/mpt2sas/mpi/mpi2_init.h @@ -0,0 +1,420 @@ +/* + *  Copyright (c) 2000-2008 LSI Corporation. + * + * + *           Name:  mpi2_init.h + *          Title:  MPI SCSI initiator mode messages and structures + *  Creation Date:  June 23, 2006 + * + *    mpi2_init.h Version:  02.00.06 + * + *  Version History + *  --------------- + * + *  Date      Version   Description + *  --------  --------  ------------------------------------------------------ + *  04-30-07  02.00.00  Corresponds to Fusion-MPT MPI Specification Rev A. + *  10-31-07  02.00.01  Fixed name for pMpi2SCSITaskManagementRequest_t. + *  12-18-07  02.00.02  Modified Task Management Target Reset Method defines. + *  02-29-08  02.00.03  Added Query Task Set and Query Unit Attention. + *  03-03-08  02.00.04  Fixed name of struct _MPI2_SCSI_TASK_MANAGE_REPLY. + *  05-21-08  02.00.05  Fixed typo in name of Mpi2SepRequest_t. + *  10-02-08  02.00.06  Removed Untagged and No Disconnect values from SCSI IO + *                      Control field Task Attribute flags. + *                      Moved LUN field defines to mpi2.h becasue they are + *                      common to many structures. + *  -------------------------------------------------------------------------- + */ + +#ifndef MPI2_INIT_H +#define MPI2_INIT_H + +/***************************************************************************** +* +*               SCSI Initiator Messages +* +*****************************************************************************/ + +/**************************************************************************** +*  SCSI IO messages and associated structures +****************************************************************************/ + +typedef struct +{ +    U8                      CDB[20];                    /* 0x00 */ +    U32                     PrimaryReferenceTag;        /* 0x14 */ +    U16                     PrimaryApplicationTag;      /* 0x18 */ +    U16                     PrimaryApplicationTagMask;  /* 0x1A */ +    U32                     TransferLength;             /* 0x1C */ +} MPI2_SCSI_IO_CDB_EEDP32, MPI2_POINTER PTR_MPI2_SCSI_IO_CDB_EEDP32, +  Mpi2ScsiIoCdbEedp32_t, MPI2_POINTER pMpi2ScsiIoCdbEedp32_t; + +/* TBD: I don't think this is needed for MPI2/Gen2 */ +#if 0 +typedef struct +{ +    U8                      CDB[16];                    /* 0x00 */ +    U32                     DataLength;                 /* 0x10 */ +    U32                     PrimaryReferenceTag;        /* 0x14 */ +    U16                     PrimaryApplicationTag;      /* 0x18 */ +    U16                     PrimaryApplicationTagMask;  /* 0x1A */ +    U32                     TransferLength;             /* 0x1C */ +} MPI2_SCSI_IO32_CDB_EEDP16, MPI2_POINTER PTR_MPI2_SCSI_IO32_CDB_EEDP16, +  Mpi2ScsiIo32CdbEedp16_t, MPI2_POINTER pMpi2ScsiIo32CdbEedp16_t; +#endif + +typedef union +{ +    U8                      CDB32[32]; +    MPI2_SCSI_IO_CDB_EEDP32 EEDP32; +    MPI2_SGE_SIMPLE_UNION   SGE; +} MPI2_SCSI_IO_CDB_UNION, MPI2_POINTER PTR_MPI2_SCSI_IO_CDB_UNION, +  Mpi2ScsiIoCdb_t, MPI2_POINTER pMpi2ScsiIoCdb_t; + +/* SCSI IO Request Message */ +typedef struct _MPI2_SCSI_IO_REQUEST +{ +    U16                     DevHandle;                      /* 0x00 */ +    U8                      ChainOffset;                    /* 0x02 */ +    U8                      Function;                       /* 0x03 */ +    U16                     Reserved1;                      /* 0x04 */ +    U8                      Reserved2;                      /* 0x06 */ +    U8                      MsgFlags;                       /* 0x07 */ +    U8                      VP_ID;                          /* 0x08 */ +    U8                      VF_ID;                          /* 0x09 */ +    U16                     Reserved3;                      /* 0x0A */ +    U32                     SenseBufferLowAddress;          /* 0x0C */ +    U16                     SGLFlags;                       /* 0x10 */ +    U8                      SenseBufferLength;              /* 0x12 */ +    U8                      Reserved4;                      /* 0x13 */ +    U8                      SGLOffset0;                     /* 0x14 */ +    U8                      SGLOffset1;                     /* 0x15 */ +    U8                      SGLOffset2;                     /* 0x16 */ +    U8                      SGLOffset3;                     /* 0x17 */ +    U32                     SkipCount;                      /* 0x18 */ +    U32                     DataLength;                     /* 0x1C */ +    U32                     BidirectionalDataLength;        /* 0x20 */ +    U16                     IoFlags;                        /* 0x24 */ +    U16                     EEDPFlags;                      /* 0x26 */ +    U32                     EEDPBlockSize;                  /* 0x28 */ +    U32                     SecondaryReferenceTag;          /* 0x2C */ +    U16                     SecondaryApplicationTag;        /* 0x30 */ +    U16                     ApplicationTagTranslationMask;  /* 0x32 */ +    U8                      LUN[8];                         /* 0x34 */ +    U32                     Control;                        /* 0x3C */ +    MPI2_SCSI_IO_CDB_UNION  CDB;                            /* 0x40 */ +    MPI2_SGE_IO_UNION       SGL;                            /* 0x60 */ +} MPI2_SCSI_IO_REQUEST, MPI2_POINTER PTR_MPI2_SCSI_IO_REQUEST, +  Mpi2SCSIIORequest_t, MPI2_POINTER pMpi2SCSIIORequest_t; + +/* SCSI IO MsgFlags bits */ + +/* MsgFlags for SenseBufferAddressSpace */ +#define MPI2_SCSIIO_MSGFLAGS_MASK_SENSE_ADDR        (0x0C) +#define MPI2_SCSIIO_MSGFLAGS_SYSTEM_SENSE_ADDR      (0x00) +#define MPI2_SCSIIO_MSGFLAGS_IOCDDR_SENSE_ADDR      (0x04) +#define MPI2_SCSIIO_MSGFLAGS_IOCPLB_SENSE_ADDR      (0x08) +#define MPI2_SCSIIO_MSGFLAGS_IOCPLBNTA_SENSE_ADDR   (0x0C) + +/* SCSI IO SGLFlags bits */ + +/* base values for Data Location Address Space */ +#define MPI2_SCSIIO_SGLFLAGS_ADDR_MASK              (0x0C) +#define MPI2_SCSIIO_SGLFLAGS_SYSTEM_ADDR            (0x00) +#define MPI2_SCSIIO_SGLFLAGS_IOCDDR_ADDR            (0x04) +#define MPI2_SCSIIO_SGLFLAGS_IOCPLB_ADDR            (0x08) +#define MPI2_SCSIIO_SGLFLAGS_IOCPLBNTA_ADDR         (0x0C) + +/* base values for Type */ +#define MPI2_SCSIIO_SGLFLAGS_TYPE_MASK              (0x03) +#define MPI2_SCSIIO_SGLFLAGS_TYPE_MPI               (0x00) +#define MPI2_SCSIIO_SGLFLAGS_TYPE_IEEE32            (0x01) +#define MPI2_SCSIIO_SGLFLAGS_TYPE_IEEE64            (0x02) + +/* shift values for each sub-field */ +#define MPI2_SCSIIO_SGLFLAGS_SGL3_SHIFT             (12) +#define MPI2_SCSIIO_SGLFLAGS_SGL2_SHIFT             (8) +#define MPI2_SCSIIO_SGLFLAGS_SGL1_SHIFT             (4) +#define MPI2_SCSIIO_SGLFLAGS_SGL0_SHIFT             (0) + +/* SCSI IO IoFlags bits */ + +/* Large CDB Address Space */ +#define MPI2_SCSIIO_CDB_ADDR_MASK                   (0x6000) +#define MPI2_SCSIIO_CDB_ADDR_SYSTEM                 (0x0000) +#define MPI2_SCSIIO_CDB_ADDR_IOCDDR                 (0x2000) +#define MPI2_SCSIIO_CDB_ADDR_IOCPLB                 (0x4000) +#define MPI2_SCSIIO_CDB_ADDR_IOCPLBNTA              (0x6000) + +#define MPI2_SCSIIO_IOFLAGS_LARGE_CDB               (0x1000) +#define MPI2_SCSIIO_IOFLAGS_BIDIRECTIONAL           (0x0800) +#define MPI2_SCSIIO_IOFLAGS_MULTICAST               (0x0400) +#define MPI2_SCSIIO_IOFLAGS_CMD_DETERMINES_DATA_DIR (0x0200) +#define MPI2_SCSIIO_IOFLAGS_CDBLENGTH_MASK          (0x01FF) + +/* SCSI IO EEDPFlags bits */ + +#define MPI2_SCSIIO_EEDPFLAGS_INC_PRI_REFTAG        (0x8000) +#define MPI2_SCSIIO_EEDPFLAGS_INC_SEC_REFTAG        (0x4000) +#define MPI2_SCSIIO_EEDPFLAGS_INC_PRI_APPTAG        (0x2000) +#define MPI2_SCSIIO_EEDPFLAGS_INC_SEC_APPTAG        (0x1000) + +#define MPI2_SCSIIO_EEDPFLAGS_CHECK_REFTAG          (0x0400) +#define MPI2_SCSIIO_EEDPFLAGS_CHECK_APPTAG          (0x0200) +#define MPI2_SCSIIO_EEDPFLAGS_CHECK_GUARD           (0x0100) + +#define MPI2_SCSIIO_EEDPFLAGS_PASSTHRU_REFTAG       (0x0008) + +#define MPI2_SCSIIO_EEDPFLAGS_MASK_OP               (0x0007) +#define MPI2_SCSIIO_EEDPFLAGS_NOOP_OP               (0x0000) +#define MPI2_SCSIIO_EEDPFLAGS_CHECK_OP              (0x0001) +#define MPI2_SCSIIO_EEDPFLAGS_STRIP_OP              (0x0002) +#define MPI2_SCSIIO_EEDPFLAGS_CHECK_REMOVE_OP       (0x0003) +#define MPI2_SCSIIO_EEDPFLAGS_INSERT_OP             (0x0004) +#define MPI2_SCSIIO_EEDPFLAGS_REPLACE_OP            (0x0006) +#define MPI2_SCSIIO_EEDPFLAGS_CHECK_REGEN_OP        (0x0007) + +/* SCSI IO LUN fields: use MPI2_LUN_ from mpi2.h */ + +/* SCSI IO Control bits */ +#define MPI2_SCSIIO_CONTROL_ADDCDBLEN_MASK      (0xFC000000) +#define MPI2_SCSIIO_CONTROL_ADDCDBLEN_SHIFT     (26) + +#define MPI2_SCSIIO_CONTROL_DATADIRECTION_MASK  (0x03000000) +#define MPI2_SCSIIO_CONTROL_NODATATRANSFER      (0x00000000) +#define MPI2_SCSIIO_CONTROL_WRITE               (0x01000000) +#define MPI2_SCSIIO_CONTROL_READ                (0x02000000) +#define MPI2_SCSIIO_CONTROL_BIDIRECTIONAL       (0x03000000) + +#define MPI2_SCSIIO_CONTROL_TASKPRI_MASK        (0x00007800) +#define MPI2_SCSIIO_CONTROL_TASKPRI_SHIFT       (11) + +#define MPI2_SCSIIO_CONTROL_TASKATTRIBUTE_MASK  (0x00000700) +#define MPI2_SCSIIO_CONTROL_SIMPLEQ             (0x00000000) +#define MPI2_SCSIIO_CONTROL_HEADOFQ             (0x00000100) +#define MPI2_SCSIIO_CONTROL_ORDEREDQ            (0x00000200) +#define MPI2_SCSIIO_CONTROL_ACAQ                (0x00000400) + +#define MPI2_SCSIIO_CONTROL_TLR_MASK            (0x000000C0) +#define MPI2_SCSIIO_CONTROL_NO_TLR              (0x00000000) +#define MPI2_SCSIIO_CONTROL_TLR_ON              (0x00000040) +#define MPI2_SCSIIO_CONTROL_TLR_OFF             (0x00000080) + + +/* SCSI IO Error Reply Message */ +typedef struct _MPI2_SCSI_IO_REPLY +{ +    U16                     DevHandle;                      /* 0x00 */ +    U8                      MsgLength;                      /* 0x02 */ +    U8                      Function;                       /* 0x03 */ +    U16                     Reserved1;                      /* 0x04 */ +    U8                      Reserved2;                      /* 0x06 */ +    U8                      MsgFlags;                       /* 0x07 */ +    U8                      VP_ID;                          /* 0x08 */ +    U8                      VF_ID;                          /* 0x09 */ +    U16                     Reserved3;                      /* 0x0A */ +    U8                      SCSIStatus;                     /* 0x0C */ +    U8                      SCSIState;                      /* 0x0D */ +    U16                     IOCStatus;                      /* 0x0E */ +    U32                     IOCLogInfo;                     /* 0x10 */ +    U32                     TransferCount;                  /* 0x14 */ +    U32                     SenseCount;                     /* 0x18 */ +    U32                     ResponseInfo;                   /* 0x1C */ +    U16                     TaskTag;                        /* 0x20 */ +    U16                     Reserved4;                      /* 0x22 */ +    U32                     BidirectionalTransferCount;     /* 0x24 */ +    U32                     Reserved5;                      /* 0x28 */ +    U32                     Reserved6;                      /* 0x2C */ +} MPI2_SCSI_IO_REPLY, MPI2_POINTER PTR_MPI2_SCSI_IO_REPLY, +  Mpi2SCSIIOReply_t, MPI2_POINTER pMpi2SCSIIOReply_t; + +/* SCSI IO Reply SCSIStatus values (SAM-4 status codes) */ + +#define MPI2_SCSI_STATUS_GOOD                   (0x00) +#define MPI2_SCSI_STATUS_CHECK_CONDITION        (0x02) +#define MPI2_SCSI_STATUS_CONDITION_MET          (0x04) +#define MPI2_SCSI_STATUS_BUSY                   (0x08) +#define MPI2_SCSI_STATUS_INTERMEDIATE           (0x10) +#define MPI2_SCSI_STATUS_INTERMEDIATE_CONDMET   (0x14) +#define MPI2_SCSI_STATUS_RESERVATION_CONFLICT   (0x18) +#define MPI2_SCSI_STATUS_COMMAND_TERMINATED     (0x22) /* obsolete */ +#define MPI2_SCSI_STATUS_TASK_SET_FULL          (0x28) +#define MPI2_SCSI_STATUS_ACA_ACTIVE             (0x30) +#define MPI2_SCSI_STATUS_TASK_ABORTED           (0x40) + +/* SCSI IO Reply SCSIState flags */ + +#define MPI2_SCSI_STATE_RESPONSE_INFO_VALID     (0x10) +#define MPI2_SCSI_STATE_TERMINATED              (0x08) +#define MPI2_SCSI_STATE_NO_SCSI_STATUS          (0x04) +#define MPI2_SCSI_STATE_AUTOSENSE_FAILED        (0x02) +#define MPI2_SCSI_STATE_AUTOSENSE_VALID         (0x01) + +#define MPI2_SCSI_TASKTAG_UNKNOWN               (0xFFFF) + + +/**************************************************************************** +*  SCSI Task Management messages +****************************************************************************/ + +/* SCSI Task Management Request Message */ +typedef struct _MPI2_SCSI_TASK_MANAGE_REQUEST +{ +    U16                     DevHandle;                      /* 0x00 */ +    U8                      ChainOffset;                    /* 0x02 */ +    U8                      Function;                       /* 0x03 */ +    U8                      Reserved1;                      /* 0x04 */ +    U8                      TaskType;                       /* 0x05 */ +    U8                      Reserved2;                      /* 0x06 */ +    U8                      MsgFlags;                       /* 0x07 */ +    U8                      VP_ID;                          /* 0x08 */ +    U8                      VF_ID;                          /* 0x09 */ +    U16                     Reserved3;                      /* 0x0A */ +    U8                      LUN[8];                         /* 0x0C */ +    U32                     Reserved4[7];                   /* 0x14 */ +    U16                     TaskMID;                        /* 0x30 */ +    U16                     Reserved5;                      /* 0x32 */ +} MPI2_SCSI_TASK_MANAGE_REQUEST, +  MPI2_POINTER PTR_MPI2_SCSI_TASK_MANAGE_REQUEST, +  Mpi2SCSITaskManagementRequest_t, +  MPI2_POINTER pMpi2SCSITaskManagementRequest_t; + +/* TaskType values */ + +#define MPI2_SCSITASKMGMT_TASKTYPE_ABORT_TASK           (0x01) +#define MPI2_SCSITASKMGMT_TASKTYPE_ABRT_TASK_SET        (0x02) +#define MPI2_SCSITASKMGMT_TASKTYPE_TARGET_RESET         (0x03) +#define MPI2_SCSITASKMGMT_TASKTYPE_LOGICAL_UNIT_RESET   (0x05) +#define MPI2_SCSITASKMGMT_TASKTYPE_CLEAR_TASK_SET       (0x06) +#define MPI2_SCSITASKMGMT_TASKTYPE_QUERY_TASK           (0x07) +#define MPI2_SCSITASKMGMT_TASKTYPE_CLR_ACA              (0x08) +#define MPI2_SCSITASKMGMT_TASKTYPE_QRY_TASK_SET         (0x09) +#define MPI2_SCSITASKMGMT_TASKTYPE_QRY_UNIT_ATTENTION   (0x0A) + +/* MsgFlags bits */ + +#define MPI2_SCSITASKMGMT_MSGFLAGS_MASK_TARGET_RESET    (0x18) +#define MPI2_SCSITASKMGMT_MSGFLAGS_LINK_RESET           (0x00) +#define MPI2_SCSITASKMGMT_MSGFLAGS_NEXUS_RESET_SRST     (0x08) +#define MPI2_SCSITASKMGMT_MSGFLAGS_SAS_HARD_LINK_RESET  (0x10) + +#define MPI2_SCSITASKMGMT_MSGFLAGS_DO_NOT_SEND_TASK_IU  (0x01) + + + +/* SCSI Task Management Reply Message */ +typedef struct _MPI2_SCSI_TASK_MANAGE_REPLY +{ +    U16                     DevHandle;                      /* 0x00 */ +    U8                      MsgLength;                      /* 0x02 */ +    U8                      Function;                       /* 0x03 */ +    U8                      ResponseCode;                   /* 0x04 */ +    U8                      TaskType;                       /* 0x05 */ +    U8                      Reserved1;                      /* 0x06 */ +    U8                      MsgFlags;                       /* 0x07 */ +    U8                      VP_ID;                          /* 0x08 */ +    U8                      VF_ID;                          /* 0x09 */ +    U16                     Reserved2;                      /* 0x0A */ +    U16                     Reserved3;                      /* 0x0C */ +    U16                     IOCStatus;                      /* 0x0E */ +    U32                     IOCLogInfo;                     /* 0x10 */ +    U32                     TerminationCount;               /* 0x14 */ +} MPI2_SCSI_TASK_MANAGE_REPLY, +  MPI2_POINTER PTR_MPI2_SCSI_TASK_MANAGE_REPLY, +  Mpi2SCSITaskManagementReply_t, MPI2_POINTER pMpi2SCSIManagementReply_t; + +/* ResponseCode values */ + +#define MPI2_SCSITASKMGMT_RSP_TM_COMPLETE               (0x00) +#define MPI2_SCSITASKMGMT_RSP_INVALID_FRAME             (0x02) +#define MPI2_SCSITASKMGMT_RSP_TM_NOT_SUPPORTED          (0x04) +#define MPI2_SCSITASKMGMT_RSP_TM_FAILED                 (0x05) +#define MPI2_SCSITASKMGMT_RSP_TM_SUCCEEDED              (0x08) +#define MPI2_SCSITASKMGMT_RSP_TM_INVALID_LUN            (0x09) +#define MPI2_SCSITASKMGMT_RSP_IO_QUEUED_ON_IOC          (0x80) + + +/**************************************************************************** +*  SCSI Enclosure Processor messages +****************************************************************************/ + +/* SCSI Enclosure Processor Request Message */ +typedef struct _MPI2_SEP_REQUEST +{ +    U16                     DevHandle;          /* 0x00 */ +    U8                      ChainOffset;        /* 0x02 */ +    U8                      Function;           /* 0x03 */ +    U8                      Action;             /* 0x04 */ +    U8                      Flags;              /* 0x05 */ +    U8                      Reserved1;          /* 0x06 */ +    U8                      MsgFlags;           /* 0x07 */ +    U8                      VP_ID;              /* 0x08 */ +    U8                      VF_ID;              /* 0x09 */ +    U16                     Reserved2;          /* 0x0A */ +    U32                     SlotStatus;         /* 0x0C */ +    U32                     Reserved3;          /* 0x10 */ +    U32                     Reserved4;          /* 0x14 */ +    U32                     Reserved5;          /* 0x18 */ +    U16                     Slot;               /* 0x1C */ +    U16                     EnclosureHandle;    /* 0x1E */ +} MPI2_SEP_REQUEST, MPI2_POINTER PTR_MPI2_SEP_REQUEST, +  Mpi2SepRequest_t, MPI2_POINTER pMpi2SepRequest_t; + +/* Action defines */ +#define MPI2_SEP_REQ_ACTION_WRITE_STATUS                (0x00) +#define MPI2_SEP_REQ_ACTION_READ_STATUS                 (0x01) + +/* Flags defines */ +#define MPI2_SEP_REQ_FLAGS_DEVHANDLE_ADDRESS            (0x00) +#define MPI2_SEP_REQ_FLAGS_ENCLOSURE_SLOT_ADDRESS       (0x01) + +/* SlotStatus defines */ +#define MPI2_SEP_REQ_SLOTSTATUS_REQUEST_REMOVE          (0x00040000) +#define MPI2_SEP_REQ_SLOTSTATUS_IDENTIFY_REQUEST        (0x00020000) +#define MPI2_SEP_REQ_SLOTSTATUS_REBUILD_STOPPED         (0x00000200) +#define MPI2_SEP_REQ_SLOTSTATUS_HOT_SPARE               (0x00000100) +#define MPI2_SEP_REQ_SLOTSTATUS_UNCONFIGURED            (0x00000080) +#define MPI2_SEP_REQ_SLOTSTATUS_PREDICTED_FAULT         (0x00000040) +#define MPI2_SEP_REQ_SLOTSTATUS_DEV_REBUILDING          (0x00000004) +#define MPI2_SEP_REQ_SLOTSTATUS_DEV_FAULTY              (0x00000002) +#define MPI2_SEP_REQ_SLOTSTATUS_NO_ERROR                (0x00000001) + + +/* SCSI Enclosure Processor Reply Message */ +typedef struct _MPI2_SEP_REPLY +{ +    U16                     DevHandle;          /* 0x00 */ +    U8                      MsgLength;          /* 0x02 */ +    U8                      Function;           /* 0x03 */ +    U8                      Action;             /* 0x04 */ +    U8                      Flags;              /* 0x05 */ +    U8                      Reserved1;          /* 0x06 */ +    U8                      MsgFlags;           /* 0x07 */ +    U8                      VP_ID;              /* 0x08 */ +    U8                      VF_ID;              /* 0x09 */ +    U16                     Reserved2;          /* 0x0A */ +    U16                     Reserved3;          /* 0x0C */ +    U16                     IOCStatus;          /* 0x0E */ +    U32                     IOCLogInfo;         /* 0x10 */ +    U32                     SlotStatus;         /* 0x14 */ +    U32                     Reserved4;          /* 0x18 */ +    U16                     Slot;               /* 0x1C */ +    U16                     EnclosureHandle;    /* 0x1E */ +} MPI2_SEP_REPLY, MPI2_POINTER PTR_MPI2_SEP_REPLY, +  Mpi2SepReply_t, MPI2_POINTER pMpi2SepReply_t; + +/* SlotStatus defines */ +#define MPI2_SEP_REPLY_SLOTSTATUS_REMOVE_READY          (0x00040000) +#define MPI2_SEP_REPLY_SLOTSTATUS_IDENTIFY_REQUEST      (0x00020000) +#define MPI2_SEP_REPLY_SLOTSTATUS_REBUILD_STOPPED       (0x00000200) +#define MPI2_SEP_REPLY_SLOTSTATUS_HOT_SPARE             (0x00000100) +#define MPI2_SEP_REPLY_SLOTSTATUS_UNCONFIGURED          (0x00000080) +#define MPI2_SEP_REPLY_SLOTSTATUS_PREDICTED_FAULT       (0x00000040) +#define MPI2_SEP_REPLY_SLOTSTATUS_DEV_REBUILDING        (0x00000004) +#define MPI2_SEP_REPLY_SLOTSTATUS_DEV_FAULTY            (0x00000002) +#define MPI2_SEP_REPLY_SLOTSTATUS_NO_ERROR              (0x00000001) + + +#endif + +  |