You've already forked linux-rockchip
mirror of
https://github.com/armbian/linux-rockchip.git
synced 2026-01-06 11:08:10 -08:00
[SCSI] mpt3sas: add new driver supporting 12GB SAS
These driver files are initially, substantially similar to mpt2sas but, because mpt2sas is going into maintenance mode and mp3sas will become heavily developed, we elected to keep the code bases separate. Signed-off-by: Sreekanth Reddy <Sreekanth.Reddy@lsi.com> Reviewed-by: Nagalakshmi Nandigama <Nagalakshmi.Nandigama@lsi.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
This commit is contained in:
committed by
James Bottomley
parent
d84fd392bd
commit
f92363d123
@@ -603,6 +603,7 @@ config SCSI_ARCMSR
|
||||
|
||||
source "drivers/scsi/megaraid/Kconfig.megaraid"
|
||||
source "drivers/scsi/mpt2sas/Kconfig"
|
||||
source "drivers/scsi/mpt3sas/Kconfig"
|
||||
source "drivers/scsi/ufs/Kconfig"
|
||||
|
||||
config SCSI_HPTIOP
|
||||
|
||||
@@ -107,6 +107,7 @@ obj-$(CONFIG_MEGARAID_LEGACY) += megaraid.o
|
||||
obj-$(CONFIG_MEGARAID_NEWGEN) += megaraid/
|
||||
obj-$(CONFIG_MEGARAID_SAS) += megaraid/
|
||||
obj-$(CONFIG_SCSI_MPT2SAS) += mpt2sas/
|
||||
obj-$(CONFIG_SCSI_MPT3SAS) += mpt3sas/
|
||||
obj-$(CONFIG_SCSI_UFSHCD) += ufs/
|
||||
obj-$(CONFIG_SCSI_ACARD) += atp870u.o
|
||||
obj-$(CONFIG_SCSI_SUNESP) += esp_scsi.o sun_esp.o
|
||||
|
||||
67
drivers/scsi/mpt3sas/Kconfig
Normal file
67
drivers/scsi/mpt3sas/Kconfig
Normal file
@@ -0,0 +1,67 @@
|
||||
#
|
||||
# Kernel configuration file for the MPT3SAS
|
||||
#
|
||||
# This code is based on drivers/scsi/mpt3sas/Kconfig
|
||||
# Copyright (C) 2012 LSI Corporation
|
||||
# (mailto:DL-MPTFusionLinux@lsi.com)
|
||||
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public License
|
||||
# as published by the Free Software Foundation; either version 2
|
||||
# of the License, or (at your option) any later version.
|
||||
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# NO WARRANTY
|
||||
# THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
|
||||
# CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
|
||||
# LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
|
||||
# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
|
||||
# solely responsible for determining the appropriateness of using and
|
||||
# distributing the Program and assumes all risks associated with its
|
||||
# exercise of rights under this Agreement, including but not limited to
|
||||
# the risks and costs of program errors, damage to or loss of data,
|
||||
# programs or equipment, and unavailability or interruption of operations.
|
||||
|
||||
# DISCLAIMER OF LIABILITY
|
||||
# NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
|
||||
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
# DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
|
||||
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
|
||||
# TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
||||
# USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
|
||||
# HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
||||
# USA.
|
||||
|
||||
config SCSI_MPT3SAS
|
||||
tristate "LSI MPT Fusion SAS 3.0 Device Driver"
|
||||
depends on PCI && SCSI
|
||||
select SCSI_SAS_ATTRS
|
||||
select RAID_ATTRS
|
||||
---help---
|
||||
This driver supports PCI-Express SAS 12Gb/s Host Adapters.
|
||||
|
||||
config SCSI_MPT3SAS_MAX_SGE
|
||||
int "LSI MPT Fusion Max number of SG Entries (16 - 256)"
|
||||
depends on PCI && SCSI && SCSI_MPT3SAS
|
||||
default "128"
|
||||
range 16 256
|
||||
---help---
|
||||
This option allows you to specify the maximum number of scatter-
|
||||
gather entries per I/O. The driver default is 128, which matches
|
||||
MAX_PHYS_SEGMENTS in most kernels. However in SuSE kernels this
|
||||
can be 256. However, it may decreased down to 16. Decreasing this
|
||||
parameter will reduce memory requirements on a per controller instance.
|
||||
|
||||
config SCSI_MPT3SAS_LOGGING
|
||||
bool "LSI MPT Fusion logging facility"
|
||||
depends on PCI && SCSI && SCSI_MPT3SAS
|
||||
---help---
|
||||
This turns on a logging facility.
|
||||
8
drivers/scsi/mpt3sas/Makefile
Normal file
8
drivers/scsi/mpt3sas/Makefile
Normal file
@@ -0,0 +1,8 @@
|
||||
# mpt3sas makefile
|
||||
obj-m += mpt3sas.o
|
||||
mpt3sas-y += mpt3sas_base.o \
|
||||
mpt3sas_config.o \
|
||||
mpt3sas_scsih.o \
|
||||
mpt3sas_transport.o \
|
||||
mpt3sas_ctl.o \
|
||||
mpt3sas_trigger_diag.o
|
||||
1164
drivers/scsi/mpt3sas/mpi/mpi2.h
Normal file
1164
drivers/scsi/mpt3sas/mpi/mpi2.h
Normal file
File diff suppressed because it is too large
Load Diff
3323
drivers/scsi/mpt3sas/mpi/mpi2_cnfg.h
Normal file
3323
drivers/scsi/mpt3sas/mpi/mpi2_cnfg.h
Normal file
File diff suppressed because it is too large
Load Diff
560
drivers/scsi/mpt3sas/mpi/mpi2_init.h
Normal file
560
drivers/scsi/mpt3sas/mpi/mpi2_init.h
Normal file
File diff suppressed because it is too large
Load Diff
1665
drivers/scsi/mpt3sas/mpi/mpi2_ioc.h
Normal file
1665
drivers/scsi/mpt3sas/mpi/mpi2_ioc.h
Normal file
File diff suppressed because it is too large
Load Diff
346
drivers/scsi/mpt3sas/mpi/mpi2_raid.h
Normal file
346
drivers/scsi/mpt3sas/mpi/mpi2_raid.h
Normal file
@@ -0,0 +1,346 @@
|
||||
/*
|
||||
* Copyright (c) 2000-2012 LSI Corporation.
|
||||
*
|
||||
*
|
||||
* Name: mpi2_raid.h
|
||||
* Title: MPI Integrated RAID messages and structures
|
||||
* Creation Date: April 26, 2007
|
||||
*
|
||||
* mpi2_raid.h Version: 02.00.08
|
||||
*
|
||||
* Version History
|
||||
* ---------------
|
||||
*
|
||||
* Date Version Description
|
||||
* -------- -------- ------------------------------------------------------
|
||||
* 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
|
||||
* 08-31-07 02.00.01 Modifications to RAID Action request and reply,
|
||||
* including the Actions and ActionData.
|
||||
* 02-29-08 02.00.02 Added MPI2_RAID_ACTION_ADATA_DISABL_FULL_REBUILD.
|
||||
* 05-21-08 02.00.03 Added MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS so that
|
||||
* the PhysDisk array in MPI2_RAID_VOLUME_CREATION_STRUCT
|
||||
* can be sized by the build environment.
|
||||
* 07-30-09 02.00.04 Added proper define for the Use Default Settings bit of
|
||||
* VolumeCreationFlags and marked the old one as obsolete.
|
||||
* 05-12-10 02.00.05 Added MPI2_RAID_VOL_FLAGS_OP_MDC define.
|
||||
* 08-24-10 02.00.06 Added MPI2_RAID_ACTION_COMPATIBILITY_CHECK along with
|
||||
* related structures and defines.
|
||||
* Added product-specific range to RAID Action values.
|
||||
* 11-18-11 02.00.07 Incorporating additions for MPI v2.5.
|
||||
* 02-06-12 02.00.08 Added MPI2_RAID_ACTION_PHYSDISK_HIDDEN.
|
||||
* --------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#ifndef MPI2_RAID_H
|
||||
#define MPI2_RAID_H
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* Integrated RAID Messages
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* RAID Action messages
|
||||
****************************************************************************/
|
||||
|
||||
/*ActionDataWord defines for use with MPI2_RAID_ACTION_DELETE_VOLUME action */
|
||||
#define MPI2_RAID_ACTION_ADATA_KEEP_LBA0 (0x00000000)
|
||||
#define MPI2_RAID_ACTION_ADATA_ZERO_LBA0 (0x00000001)
|
||||
|
||||
/*use MPI2_RAIDVOL0_SETTING_ defines from mpi2_cnfg.h for
|
||||
*MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE action */
|
||||
|
||||
/*ActionDataWord defines for use with
|
||||
*MPI2_RAID_ACTION_DISABLE_ALL_VOLUMES action */
|
||||
#define MPI2_RAID_ACTION_ADATA_DISABL_FULL_REBUILD (0x00000001)
|
||||
|
||||
/*ActionDataWord for MPI2_RAID_ACTION_SET_RAID_FUNCTION_RATE Action */
|
||||
typedef struct _MPI2_RAID_ACTION_RATE_DATA {
|
||||
U8 RateToChange; /*0x00 */
|
||||
U8 RateOrMode; /*0x01 */
|
||||
U16 DataScrubDuration; /*0x02 */
|
||||
} MPI2_RAID_ACTION_RATE_DATA, *PTR_MPI2_RAID_ACTION_RATE_DATA,
|
||||
Mpi2RaidActionRateData_t, *pMpi2RaidActionRateData_t;
|
||||
|
||||
#define MPI2_RAID_ACTION_SET_RATE_RESYNC (0x00)
|
||||
#define MPI2_RAID_ACTION_SET_RATE_DATA_SCRUB (0x01)
|
||||
#define MPI2_RAID_ACTION_SET_RATE_POWERSAVE_MODE (0x02)
|
||||
|
||||
/*ActionDataWord for MPI2_RAID_ACTION_START_RAID_FUNCTION Action */
|
||||
typedef struct _MPI2_RAID_ACTION_START_RAID_FUNCTION {
|
||||
U8 RAIDFunction; /*0x00 */
|
||||
U8 Flags; /*0x01 */
|
||||
U16 Reserved1; /*0x02 */
|
||||
} MPI2_RAID_ACTION_START_RAID_FUNCTION,
|
||||
*PTR_MPI2_RAID_ACTION_START_RAID_FUNCTION,
|
||||
Mpi2RaidActionStartRaidFunction_t,
|
||||
*pMpi2RaidActionStartRaidFunction_t;
|
||||
|
||||
/*defines for the RAIDFunction field */
|
||||
#define MPI2_RAID_ACTION_START_BACKGROUND_INIT (0x00)
|
||||
#define MPI2_RAID_ACTION_START_ONLINE_CAP_EXPANSION (0x01)
|
||||
#define MPI2_RAID_ACTION_START_CONSISTENCY_CHECK (0x02)
|
||||
|
||||
/*defines for the Flags field */
|
||||
#define MPI2_RAID_ACTION_START_NEW (0x00)
|
||||
#define MPI2_RAID_ACTION_START_RESUME (0x01)
|
||||
|
||||
/*ActionDataWord for MPI2_RAID_ACTION_STOP_RAID_FUNCTION Action */
|
||||
typedef struct _MPI2_RAID_ACTION_STOP_RAID_FUNCTION {
|
||||
U8 RAIDFunction; /*0x00 */
|
||||
U8 Flags; /*0x01 */
|
||||
U16 Reserved1; /*0x02 */
|
||||
} MPI2_RAID_ACTION_STOP_RAID_FUNCTION,
|
||||
*PTR_MPI2_RAID_ACTION_STOP_RAID_FUNCTION,
|
||||
Mpi2RaidActionStopRaidFunction_t,
|
||||
*pMpi2RaidActionStopRaidFunction_t;
|
||||
|
||||
/*defines for the RAIDFunction field */
|
||||
#define MPI2_RAID_ACTION_STOP_BACKGROUND_INIT (0x00)
|
||||
#define MPI2_RAID_ACTION_STOP_ONLINE_CAP_EXPANSION (0x01)
|
||||
#define MPI2_RAID_ACTION_STOP_CONSISTENCY_CHECK (0x02)
|
||||
|
||||
/*defines for the Flags field */
|
||||
#define MPI2_RAID_ACTION_STOP_ABORT (0x00)
|
||||
#define MPI2_RAID_ACTION_STOP_PAUSE (0x01)
|
||||
|
||||
/*ActionDataWord for MPI2_RAID_ACTION_CREATE_HOT_SPARE Action */
|
||||
typedef struct _MPI2_RAID_ACTION_HOT_SPARE {
|
||||
U8 HotSparePool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U16 DevHandle; /*0x02 */
|
||||
} MPI2_RAID_ACTION_HOT_SPARE, *PTR_MPI2_RAID_ACTION_HOT_SPARE,
|
||||
Mpi2RaidActionHotSpare_t, *pMpi2RaidActionHotSpare_t;
|
||||
|
||||
/*ActionDataWord for MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE Action */
|
||||
typedef struct _MPI2_RAID_ACTION_FW_UPDATE_MODE {
|
||||
U8 Flags; /*0x00 */
|
||||
U8 DeviceFirmwareUpdateModeTimeout; /*0x01 */
|
||||
U16 Reserved1; /*0x02 */
|
||||
} MPI2_RAID_ACTION_FW_UPDATE_MODE,
|
||||
*PTR_MPI2_RAID_ACTION_FW_UPDATE_MODE,
|
||||
Mpi2RaidActionFwUpdateMode_t,
|
||||
*pMpi2RaidActionFwUpdateMode_t;
|
||||
|
||||
/*ActionDataWord defines for use with
|
||||
*MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE action */
|
||||
#define MPI2_RAID_ACTION_ADATA_DISABLE_FW_UPDATE (0x00)
|
||||
#define MPI2_RAID_ACTION_ADATA_ENABLE_FW_UPDATE (0x01)
|
||||
|
||||
typedef union _MPI2_RAID_ACTION_DATA {
|
||||
U32 Word;
|
||||
MPI2_RAID_ACTION_RATE_DATA Rates;
|
||||
MPI2_RAID_ACTION_START_RAID_FUNCTION StartRaidFunction;
|
||||
MPI2_RAID_ACTION_STOP_RAID_FUNCTION StopRaidFunction;
|
||||
MPI2_RAID_ACTION_HOT_SPARE HotSpare;
|
||||
MPI2_RAID_ACTION_FW_UPDATE_MODE FwUpdateMode;
|
||||
} MPI2_RAID_ACTION_DATA, *PTR_MPI2_RAID_ACTION_DATA,
|
||||
Mpi2RaidActionData_t, *pMpi2RaidActionData_t;
|
||||
|
||||
/*RAID Action Request Message */
|
||||
typedef struct _MPI2_RAID_ACTION_REQUEST {
|
||||
U8 Action; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 VolDevHandle; /*0x04 */
|
||||
U8 PhysDiskNum; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved2; /*0x0A */
|
||||
U32 Reserved3; /*0x0C */
|
||||
MPI2_RAID_ACTION_DATA ActionDataWord; /*0x10 */
|
||||
MPI2_SGE_SIMPLE_UNION ActionDataSGE; /*0x14 */
|
||||
} MPI2_RAID_ACTION_REQUEST, *PTR_MPI2_RAID_ACTION_REQUEST,
|
||||
Mpi2RaidActionRequest_t, *pMpi2RaidActionRequest_t;
|
||||
|
||||
/*RAID Action request Action values */
|
||||
|
||||
#define MPI2_RAID_ACTION_INDICATOR_STRUCT (0x01)
|
||||
#define MPI2_RAID_ACTION_CREATE_VOLUME (0x02)
|
||||
#define MPI2_RAID_ACTION_DELETE_VOLUME (0x03)
|
||||
#define MPI2_RAID_ACTION_DISABLE_ALL_VOLUMES (0x04)
|
||||
#define MPI2_RAID_ACTION_ENABLE_ALL_VOLUMES (0x05)
|
||||
#define MPI2_RAID_ACTION_PHYSDISK_OFFLINE (0x0A)
|
||||
#define MPI2_RAID_ACTION_PHYSDISK_ONLINE (0x0B)
|
||||
#define MPI2_RAID_ACTION_FAIL_PHYSDISK (0x0F)
|
||||
#define MPI2_RAID_ACTION_ACTIVATE_VOLUME (0x11)
|
||||
#define MPI2_RAID_ACTION_DEVICE_FW_UPDATE_MODE (0x15)
|
||||
#define MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE (0x17)
|
||||
#define MPI2_RAID_ACTION_SET_VOLUME_NAME (0x18)
|
||||
#define MPI2_RAID_ACTION_SET_RAID_FUNCTION_RATE (0x19)
|
||||
#define MPI2_RAID_ACTION_ENABLE_FAILED_VOLUME (0x1C)
|
||||
#define MPI2_RAID_ACTION_CREATE_HOT_SPARE (0x1D)
|
||||
#define MPI2_RAID_ACTION_DELETE_HOT_SPARE (0x1E)
|
||||
#define MPI2_RAID_ACTION_SYSTEM_SHUTDOWN_INITIATED (0x20)
|
||||
#define MPI2_RAID_ACTION_START_RAID_FUNCTION (0x21)
|
||||
#define MPI2_RAID_ACTION_STOP_RAID_FUNCTION (0x22)
|
||||
#define MPI2_RAID_ACTION_COMPATIBILITY_CHECK (0x23)
|
||||
#define MPI2_RAID_ACTION_PHYSDISK_HIDDEN (0x24)
|
||||
#define MPI2_RAID_ACTION_MIN_PRODUCT_SPECIFIC (0x80)
|
||||
#define MPI2_RAID_ACTION_MAX_PRODUCT_SPECIFIC (0xFF)
|
||||
|
||||
/*RAID Volume Creation Structure */
|
||||
|
||||
/*
|
||||
*The following define can be customized for the targeted product.
|
||||
*/
|
||||
#ifndef MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS
|
||||
#define MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS (1)
|
||||
#endif
|
||||
|
||||
typedef struct _MPI2_RAID_VOLUME_PHYSDISK {
|
||||
U8 RAIDSetNum; /*0x00 */
|
||||
U8 PhysDiskMap; /*0x01 */
|
||||
U16 PhysDiskDevHandle; /*0x02 */
|
||||
} MPI2_RAID_VOLUME_PHYSDISK, *PTR_MPI2_RAID_VOLUME_PHYSDISK,
|
||||
Mpi2RaidVolumePhysDisk_t, *pMpi2RaidVolumePhysDisk_t;
|
||||
|
||||
/*defines for the PhysDiskMap field */
|
||||
#define MPI2_RAIDACTION_PHYSDISK_PRIMARY (0x01)
|
||||
#define MPI2_RAIDACTION_PHYSDISK_SECONDARY (0x02)
|
||||
|
||||
typedef struct _MPI2_RAID_VOLUME_CREATION_STRUCT {
|
||||
U8 NumPhysDisks; /*0x00 */
|
||||
U8 VolumeType; /*0x01 */
|
||||
U16 Reserved1; /*0x02 */
|
||||
U32 VolumeCreationFlags; /*0x04 */
|
||||
U32 VolumeSettings; /*0x08 */
|
||||
U8 Reserved2; /*0x0C */
|
||||
U8 ResyncRate; /*0x0D */
|
||||
U16 DataScrubDuration; /*0x0E */
|
||||
U64 VolumeMaxLBA; /*0x10 */
|
||||
U32 StripeSize; /*0x18 */
|
||||
U8 Name[16]; /*0x1C */
|
||||
MPI2_RAID_VOLUME_PHYSDISK
|
||||
PhysDisk[MPI2_RAID_VOL_CREATION_NUM_PHYSDISKS]; /*0x2C */
|
||||
} MPI2_RAID_VOLUME_CREATION_STRUCT,
|
||||
*PTR_MPI2_RAID_VOLUME_CREATION_STRUCT,
|
||||
Mpi2RaidVolumeCreationStruct_t,
|
||||
*pMpi2RaidVolumeCreationStruct_t;
|
||||
|
||||
/*use MPI2_RAID_VOL_TYPE_ defines from mpi2_cnfg.h for VolumeType */
|
||||
|
||||
/*defines for the VolumeCreationFlags field */
|
||||
#define MPI2_RAID_VOL_CREATION_DEFAULT_SETTINGS (0x80000000)
|
||||
#define MPI2_RAID_VOL_CREATION_BACKGROUND_INIT (0x00000004)
|
||||
#define MPI2_RAID_VOL_CREATION_LOW_LEVEL_INIT (0x00000002)
|
||||
#define MPI2_RAID_VOL_CREATION_MIGRATE_DATA (0x00000001)
|
||||
/*The following is an obsolete define.
|
||||
*It must be shifted left 24 bits in order to set the proper bit.
|
||||
*/
|
||||
#define MPI2_RAID_VOL_CREATION_USE_DEFAULT_SETTINGS (0x80)
|
||||
|
||||
/*RAID Online Capacity Expansion Structure */
|
||||
|
||||
typedef struct _MPI2_RAID_ONLINE_CAPACITY_EXPANSION {
|
||||
U32 Flags; /*0x00 */
|
||||
U16 DevHandle0; /*0x04 */
|
||||
U16 Reserved1; /*0x06 */
|
||||
U16 DevHandle1; /*0x08 */
|
||||
U16 Reserved2; /*0x0A */
|
||||
} MPI2_RAID_ONLINE_CAPACITY_EXPANSION,
|
||||
*PTR_MPI2_RAID_ONLINE_CAPACITY_EXPANSION,
|
||||
Mpi2RaidOnlineCapacityExpansion_t,
|
||||
*pMpi2RaidOnlineCapacityExpansion_t;
|
||||
|
||||
/*RAID Compatibility Input Structure */
|
||||
|
||||
typedef struct _MPI2_RAID_COMPATIBILITY_INPUT_STRUCT {
|
||||
U16 SourceDevHandle; /*0x00 */
|
||||
U16 CandidateDevHandle; /*0x02 */
|
||||
U32 Flags; /*0x04 */
|
||||
U32 Reserved1; /*0x08 */
|
||||
U32 Reserved2; /*0x0C */
|
||||
} MPI2_RAID_COMPATIBILITY_INPUT_STRUCT,
|
||||
*PTR_MPI2_RAID_COMPATIBILITY_INPUT_STRUCT,
|
||||
Mpi2RaidCompatibilityInputStruct_t,
|
||||
*pMpi2RaidCompatibilityInputStruct_t;
|
||||
|
||||
/*defines for RAID Compatibility Structure Flags field */
|
||||
#define MPI2_RAID_COMPAT_SOURCE_IS_VOLUME_FLAG (0x00000002)
|
||||
#define MPI2_RAID_COMPAT_REPORT_SOURCE_INFO_FLAG (0x00000001)
|
||||
|
||||
/*RAID Volume Indicator Structure */
|
||||
|
||||
typedef struct _MPI2_RAID_VOL_INDICATOR {
|
||||
U64 TotalBlocks; /*0x00 */
|
||||
U64 BlocksRemaining; /*0x08 */
|
||||
U32 Flags; /*0x10 */
|
||||
} MPI2_RAID_VOL_INDICATOR, *PTR_MPI2_RAID_VOL_INDICATOR,
|
||||
Mpi2RaidVolIndicator_t, *pMpi2RaidVolIndicator_t;
|
||||
|
||||
/*defines for RAID Volume Indicator Flags field */
|
||||
#define MPI2_RAID_VOL_FLAGS_OP_MASK (0x0000000F)
|
||||
#define MPI2_RAID_VOL_FLAGS_OP_BACKGROUND_INIT (0x00000000)
|
||||
#define MPI2_RAID_VOL_FLAGS_OP_ONLINE_CAP_EXPANSION (0x00000001)
|
||||
#define MPI2_RAID_VOL_FLAGS_OP_CONSISTENCY_CHECK (0x00000002)
|
||||
#define MPI2_RAID_VOL_FLAGS_OP_RESYNC (0x00000003)
|
||||
#define MPI2_RAID_VOL_FLAGS_OP_MDC (0x00000004)
|
||||
|
||||
/*RAID Compatibility Result Structure */
|
||||
|
||||
typedef struct _MPI2_RAID_COMPATIBILITY_RESULT_STRUCT {
|
||||
U8 State; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U16 Reserved2; /*0x02 */
|
||||
U32 GenericAttributes; /*0x04 */
|
||||
U32 OEMSpecificAttributes; /*0x08 */
|
||||
U32 Reserved3; /*0x0C */
|
||||
U32 Reserved4; /*0x10 */
|
||||
} MPI2_RAID_COMPATIBILITY_RESULT_STRUCT,
|
||||
*PTR_MPI2_RAID_COMPATIBILITY_RESULT_STRUCT,
|
||||
Mpi2RaidCompatibilityResultStruct_t,
|
||||
*pMpi2RaidCompatibilityResultStruct_t;
|
||||
|
||||
/*defines for RAID Compatibility Result Structure State field */
|
||||
#define MPI2_RAID_COMPAT_STATE_COMPATIBLE (0x00)
|
||||
#define MPI2_RAID_COMPAT_STATE_NOT_COMPATIBLE (0x01)
|
||||
|
||||
/*defines for RAID Compatibility Result Structure GenericAttributes field */
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_4K_SECTOR (0x00000010)
|
||||
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_MEDIA_MASK (0x0000000C)
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_SOLID_STATE_DRIVE (0x00000008)
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_HARD_DISK_DRIVE (0x00000004)
|
||||
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_PROTOCOL_MASK (0x00000003)
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_SAS_PROTOCOL (0x00000002)
|
||||
#define MPI2_RAID_COMPAT_GENATTRIB_SATA_PROTOCOL (0x00000001)
|
||||
|
||||
/*RAID Action Reply ActionData union */
|
||||
typedef union _MPI2_RAID_ACTION_REPLY_DATA {
|
||||
U32 Word[5];
|
||||
MPI2_RAID_VOL_INDICATOR RaidVolumeIndicator;
|
||||
U16 VolDevHandle;
|
||||
U8 VolumeState;
|
||||
U8 PhysDiskNum;
|
||||
MPI2_RAID_COMPATIBILITY_RESULT_STRUCT RaidCompatibilityResult;
|
||||
} MPI2_RAID_ACTION_REPLY_DATA, *PTR_MPI2_RAID_ACTION_REPLY_DATA,
|
||||
Mpi2RaidActionReplyData_t, *pMpi2RaidActionReplyData_t;
|
||||
|
||||
/*use MPI2_RAIDVOL0_SETTING_ defines from mpi2_cnfg.h for
|
||||
*MPI2_RAID_ACTION_CHANGE_VOL_WRITE_CACHE action */
|
||||
|
||||
/*RAID Action Reply Message */
|
||||
typedef struct _MPI2_RAID_ACTION_REPLY {
|
||||
U8 Action; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 VolDevHandle; /*0x04 */
|
||||
U8 PhysDiskNum; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved2; /*0x0A */
|
||||
U16 Reserved3; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
MPI2_RAID_ACTION_REPLY_DATA ActionData; /*0x14 */
|
||||
} MPI2_RAID_ACTION_REPLY, *PTR_MPI2_RAID_ACTION_REPLY,
|
||||
Mpi2RaidActionReply_t, *pMpi2RaidActionReply_t;
|
||||
|
||||
#endif
|
||||
295
drivers/scsi/mpt3sas/mpi/mpi2_sas.h
Normal file
295
drivers/scsi/mpt3sas/mpi/mpi2_sas.h
Normal file
@@ -0,0 +1,295 @@
|
||||
/*
|
||||
* Copyright (c) 2000-2012 LSI Corporation.
|
||||
*
|
||||
*
|
||||
* Name: mpi2_sas.h
|
||||
* Title: MPI Serial Attached SCSI structures and definitions
|
||||
* Creation Date: February 9, 2007
|
||||
*
|
||||
* mpi2_sas.h Version: 02.00.07
|
||||
*
|
||||
* NOTE: Names (typedefs, defines, etc.) beginning with an MPI25 or Mpi25
|
||||
* prefix are for use only on MPI v2.5 products, and must not be used
|
||||
* with MPI v2.0 products. Unless otherwise noted, names beginning with
|
||||
* MPI2 or Mpi2 are for use with both MPI v2.0 and MPI v2.5 products.
|
||||
*
|
||||
* Version History
|
||||
* ---------------
|
||||
*
|
||||
* Date Version Description
|
||||
* -------- -------- ------------------------------------------------------
|
||||
* 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
|
||||
* 06-26-07 02.00.01 Added Clear All Persistent Operation to SAS IO Unit
|
||||
* Control Request.
|
||||
* 10-02-08 02.00.02 Added Set IOC Parameter Operation to SAS IO Unit Control
|
||||
* Request.
|
||||
* 10-28-09 02.00.03 Changed the type of SGL in MPI2_SATA_PASSTHROUGH_REQUEST
|
||||
* to MPI2_SGE_IO_UNION since it supports chained SGLs.
|
||||
* 05-12-10 02.00.04 Modified some comments.
|
||||
* 08-11-10 02.00.05 Added NCQ operations to SAS IO Unit Control.
|
||||
* 11-18-11 02.00.06 Incorporating additions for MPI v2.5.
|
||||
* 07-10-12 02.00.07 Added MPI2_SATA_PT_SGE_UNION for use in the SATA
|
||||
* Passthrough Request message.
|
||||
* --------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#ifndef MPI2_SAS_H
|
||||
#define MPI2_SAS_H
|
||||
|
||||
/*
|
||||
*Values for SASStatus.
|
||||
*/
|
||||
#define MPI2_SASSTATUS_SUCCESS (0x00)
|
||||
#define MPI2_SASSTATUS_UNKNOWN_ERROR (0x01)
|
||||
#define MPI2_SASSTATUS_INVALID_FRAME (0x02)
|
||||
#define MPI2_SASSTATUS_UTC_BAD_DEST (0x03)
|
||||
#define MPI2_SASSTATUS_UTC_BREAK_RECEIVED (0x04)
|
||||
#define MPI2_SASSTATUS_UTC_CONNECT_RATE_NOT_SUPPORTED (0x05)
|
||||
#define MPI2_SASSTATUS_UTC_PORT_LAYER_REQUEST (0x06)
|
||||
#define MPI2_SASSTATUS_UTC_PROTOCOL_NOT_SUPPORTED (0x07)
|
||||
#define MPI2_SASSTATUS_UTC_STP_RESOURCES_BUSY (0x08)
|
||||
#define MPI2_SASSTATUS_UTC_WRONG_DESTINATION (0x09)
|
||||
#define MPI2_SASSTATUS_SHORT_INFORMATION_UNIT (0x0A)
|
||||
#define MPI2_SASSTATUS_LONG_INFORMATION_UNIT (0x0B)
|
||||
#define MPI2_SASSTATUS_XFER_RDY_INCORRECT_WRITE_DATA (0x0C)
|
||||
#define MPI2_SASSTATUS_XFER_RDY_REQUEST_OFFSET_ERROR (0x0D)
|
||||
#define MPI2_SASSTATUS_XFER_RDY_NOT_EXPECTED (0x0E)
|
||||
#define MPI2_SASSTATUS_DATA_INCORRECT_DATA_LENGTH (0x0F)
|
||||
#define MPI2_SASSTATUS_DATA_TOO_MUCH_READ_DATA (0x10)
|
||||
#define MPI2_SASSTATUS_DATA_OFFSET_ERROR (0x11)
|
||||
#define MPI2_SASSTATUS_SDSF_NAK_RECEIVED (0x12)
|
||||
#define MPI2_SASSTATUS_SDSF_CONNECTION_FAILED (0x13)
|
||||
#define MPI2_SASSTATUS_INITIATOR_RESPONSE_TIMEOUT (0x14)
|
||||
|
||||
/*
|
||||
*Values for the SAS DeviceInfo field used in SAS Device Status Change Event
|
||||
*data and SAS Configuration pages.
|
||||
*/
|
||||
#define MPI2_SAS_DEVICE_INFO_SEP (0x00004000)
|
||||
#define MPI2_SAS_DEVICE_INFO_ATAPI_DEVICE (0x00002000)
|
||||
#define MPI2_SAS_DEVICE_INFO_LSI_DEVICE (0x00001000)
|
||||
#define MPI2_SAS_DEVICE_INFO_DIRECT_ATTACH (0x00000800)
|
||||
#define MPI2_SAS_DEVICE_INFO_SSP_TARGET (0x00000400)
|
||||
#define MPI2_SAS_DEVICE_INFO_STP_TARGET (0x00000200)
|
||||
#define MPI2_SAS_DEVICE_INFO_SMP_TARGET (0x00000100)
|
||||
#define MPI2_SAS_DEVICE_INFO_SATA_DEVICE (0x00000080)
|
||||
#define MPI2_SAS_DEVICE_INFO_SSP_INITIATOR (0x00000040)
|
||||
#define MPI2_SAS_DEVICE_INFO_STP_INITIATOR (0x00000020)
|
||||
#define MPI2_SAS_DEVICE_INFO_SMP_INITIATOR (0x00000010)
|
||||
#define MPI2_SAS_DEVICE_INFO_SATA_HOST (0x00000008)
|
||||
|
||||
#define MPI2_SAS_DEVICE_INFO_MASK_DEVICE_TYPE (0x00000007)
|
||||
#define MPI2_SAS_DEVICE_INFO_NO_DEVICE (0x00000000)
|
||||
#define MPI2_SAS_DEVICE_INFO_END_DEVICE (0x00000001)
|
||||
#define MPI2_SAS_DEVICE_INFO_EDGE_EXPANDER (0x00000002)
|
||||
#define MPI2_SAS_DEVICE_INFO_FANOUT_EXPANDER (0x00000003)
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* SAS Messages
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* SMP Passthrough messages
|
||||
****************************************************************************/
|
||||
|
||||
/*SMP Passthrough Request Message */
|
||||
typedef struct _MPI2_SMP_PASSTHROUGH_REQUEST {
|
||||
U8 PassthroughFlags; /*0x00 */
|
||||
U8 PhysicalPort; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 RequestDataLength; /*0x04 */
|
||||
U8 SGLFlags; /*0x06*//*MPI v2.0 only. Reserved on MPI v2.5*/
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved1; /*0x0A */
|
||||
U32 Reserved2; /*0x0C */
|
||||
U64 SASAddress; /*0x10 */
|
||||
U32 Reserved3; /*0x18 */
|
||||
U32 Reserved4; /*0x1C */
|
||||
MPI2_SIMPLE_SGE_UNION SGL;/*0x20 */
|
||||
} MPI2_SMP_PASSTHROUGH_REQUEST, *PTR_MPI2_SMP_PASSTHROUGH_REQUEST,
|
||||
Mpi2SmpPassthroughRequest_t, *pMpi2SmpPassthroughRequest_t;
|
||||
|
||||
/*values for PassthroughFlags field */
|
||||
#define MPI2_SMP_PT_REQ_PT_FLAGS_IMMEDIATE (0x80)
|
||||
|
||||
/*MPI v2.0: use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
|
||||
|
||||
/*SMP Passthrough Reply Message */
|
||||
typedef struct _MPI2_SMP_PASSTHROUGH_REPLY {
|
||||
U8 PassthroughFlags; /*0x00 */
|
||||
U8 PhysicalPort; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 ResponseDataLength; /*0x04 */
|
||||
U8 SGLFlags; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved1; /*0x0A */
|
||||
U8 Reserved2; /*0x0C */
|
||||
U8 SASStatus; /*0x0D */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
U32 Reserved3; /*0x14 */
|
||||
U8 ResponseData[4]; /*0x18 */
|
||||
} MPI2_SMP_PASSTHROUGH_REPLY, *PTR_MPI2_SMP_PASSTHROUGH_REPLY,
|
||||
Mpi2SmpPassthroughReply_t, *pMpi2SmpPassthroughReply_t;
|
||||
|
||||
/*values for PassthroughFlags field */
|
||||
#define MPI2_SMP_PT_REPLY_PT_FLAGS_IMMEDIATE (0x80)
|
||||
|
||||
/*values for SASStatus field are at the top of this file */
|
||||
|
||||
/****************************************************************************
|
||||
* SATA Passthrough messages
|
||||
****************************************************************************/
|
||||
|
||||
typedef union _MPI2_SATA_PT_SGE_UNION {
|
||||
MPI2_SGE_SIMPLE_UNION MpiSimple; /*MPI v2.0 only */
|
||||
MPI2_SGE_CHAIN_UNION MpiChain; /*MPI v2.0 only */
|
||||
MPI2_IEEE_SGE_SIMPLE_UNION IeeeSimple;
|
||||
MPI2_IEEE_SGE_CHAIN_UNION IeeeChain; /*MPI v2.0 only */
|
||||
MPI25_IEEE_SGE_CHAIN64 IeeeChain64; /*MPI v2.5 only */
|
||||
} MPI2_SATA_PT_SGE_UNION, *PTR_MPI2_SATA_PT_SGE_UNION,
|
||||
Mpi2SataPTSGEUnion_t, *pMpi2SataPTSGEUnion_t;
|
||||
|
||||
/*SATA Passthrough Request Message */
|
||||
typedef struct _MPI2_SATA_PASSTHROUGH_REQUEST {
|
||||
U16 DevHandle; /*0x00 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 PassthroughFlags; /*0x04 */
|
||||
U8 SGLFlags; /*0x06*//*MPI v2.0 only. Reserved on MPI v2.5*/
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved1; /*0x0A */
|
||||
U32 Reserved2; /*0x0C */
|
||||
U32 Reserved3; /*0x10 */
|
||||
U32 Reserved4; /*0x14 */
|
||||
U32 DataLength; /*0x18 */
|
||||
U8 CommandFIS[20]; /*0x1C */
|
||||
MPI2_SATA_PT_SGE_UNION SGL;/*0x30*//*MPI v2.5: IEEE 64 elements only*/
|
||||
} MPI2_SATA_PASSTHROUGH_REQUEST, *PTR_MPI2_SATA_PASSTHROUGH_REQUEST,
|
||||
Mpi2SataPassthroughRequest_t,
|
||||
*pMpi2SataPassthroughRequest_t;
|
||||
|
||||
/*values for PassthroughFlags field */
|
||||
#define MPI2_SATA_PT_REQ_PT_FLAGS_EXECUTE_DIAG (0x0100)
|
||||
#define MPI2_SATA_PT_REQ_PT_FLAGS_DMA (0x0020)
|
||||
#define MPI2_SATA_PT_REQ_PT_FLAGS_PIO (0x0010)
|
||||
#define MPI2_SATA_PT_REQ_PT_FLAGS_UNSPECIFIED_VU (0x0004)
|
||||
#define MPI2_SATA_PT_REQ_PT_FLAGS_WRITE (0x0002)
|
||||
#define MPI2_SATA_PT_REQ_PT_FLAGS_READ (0x0001)
|
||||
|
||||
/*MPI v2.0: use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
|
||||
|
||||
/*SATA Passthrough Reply Message */
|
||||
typedef struct _MPI2_SATA_PASSTHROUGH_REPLY {
|
||||
U16 DevHandle; /*0x00 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 PassthroughFlags; /*0x04 */
|
||||
U8 SGLFlags; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved1; /*0x0A */
|
||||
U8 Reserved2; /*0x0C */
|
||||
U8 SASStatus; /*0x0D */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
U8 StatusFIS[20]; /*0x14 */
|
||||
U32 StatusControlRegisters; /*0x28 */
|
||||
U32 TransferCount; /*0x2C */
|
||||
} MPI2_SATA_PASSTHROUGH_REPLY, *PTR_MPI2_SATA_PASSTHROUGH_REPLY,
|
||||
Mpi2SataPassthroughReply_t, *pMpi2SataPassthroughReply_t;
|
||||
|
||||
/*values for SASStatus field are at the top of this file */
|
||||
|
||||
/****************************************************************************
|
||||
* SAS IO Unit Control messages
|
||||
****************************************************************************/
|
||||
|
||||
/*SAS IO Unit Control Request Message */
|
||||
typedef struct _MPI2_SAS_IOUNIT_CONTROL_REQUEST {
|
||||
U8 Operation; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 DevHandle; /*0x04 */
|
||||
U8 IOCParameter; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved3; /*0x0A */
|
||||
U16 Reserved4; /*0x0C */
|
||||
U8 PhyNum; /*0x0E */
|
||||
U8 PrimFlags; /*0x0F */
|
||||
U32 Primitive; /*0x10 */
|
||||
U8 LookupMethod; /*0x14 */
|
||||
U8 Reserved5; /*0x15 */
|
||||
U16 SlotNumber; /*0x16 */
|
||||
U64 LookupAddress; /*0x18 */
|
||||
U32 IOCParameterValue; /*0x20 */
|
||||
U32 Reserved7; /*0x24 */
|
||||
U32 Reserved8; /*0x28 */
|
||||
} MPI2_SAS_IOUNIT_CONTROL_REQUEST,
|
||||
*PTR_MPI2_SAS_IOUNIT_CONTROL_REQUEST,
|
||||
Mpi2SasIoUnitControlRequest_t,
|
||||
*pMpi2SasIoUnitControlRequest_t;
|
||||
|
||||
/*values for the Operation field */
|
||||
#define MPI2_SAS_OP_CLEAR_ALL_PERSISTENT (0x02)
|
||||
#define MPI2_SAS_OP_PHY_LINK_RESET (0x06)
|
||||
#define MPI2_SAS_OP_PHY_HARD_RESET (0x07)
|
||||
#define MPI2_SAS_OP_PHY_CLEAR_ERROR_LOG (0x08)
|
||||
#define MPI2_SAS_OP_SEND_PRIMITIVE (0x0A)
|
||||
#define MPI2_SAS_OP_FORCE_FULL_DISCOVERY (0x0B)
|
||||
#define MPI2_SAS_OP_TRANSMIT_PORT_SELECT_SIGNAL (0x0C)
|
||||
#define MPI2_SAS_OP_REMOVE_DEVICE (0x0D)
|
||||
#define MPI2_SAS_OP_LOOKUP_MAPPING (0x0E)
|
||||
#define MPI2_SAS_OP_SET_IOC_PARAMETER (0x0F)
|
||||
#define MPI25_SAS_OP_ENABLE_FP_DEVICE (0x10)
|
||||
#define MPI25_SAS_OP_DISABLE_FP_DEVICE (0x11)
|
||||
#define MPI25_SAS_OP_ENABLE_FP_ALL (0x12)
|
||||
#define MPI25_SAS_OP_DISABLE_FP_ALL (0x13)
|
||||
#define MPI2_SAS_OP_DEV_ENABLE_NCQ (0x14)
|
||||
#define MPI2_SAS_OP_DEV_DISABLE_NCQ (0x15)
|
||||
#define MPI2_SAS_OP_PRODUCT_SPECIFIC_MIN (0x80)
|
||||
|
||||
/*values for the PrimFlags field */
|
||||
#define MPI2_SAS_PRIMFLAGS_SINGLE (0x08)
|
||||
#define MPI2_SAS_PRIMFLAGS_TRIPLE (0x02)
|
||||
#define MPI2_SAS_PRIMFLAGS_REDUNDANT (0x01)
|
||||
|
||||
/*values for the LookupMethod field */
|
||||
#define MPI2_SAS_LOOKUP_METHOD_SAS_ADDRESS (0x01)
|
||||
#define MPI2_SAS_LOOKUP_METHOD_SAS_ENCLOSURE_SLOT (0x02)
|
||||
#define MPI2_SAS_LOOKUP_METHOD_SAS_DEVICE_NAME (0x03)
|
||||
|
||||
/*SAS IO Unit Control Reply Message */
|
||||
typedef struct _MPI2_SAS_IOUNIT_CONTROL_REPLY {
|
||||
U8 Operation; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 DevHandle; /*0x04 */
|
||||
U8 IOCParameter; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved3; /*0x0A */
|
||||
U16 Reserved4; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
} MPI2_SAS_IOUNIT_CONTROL_REPLY,
|
||||
*PTR_MPI2_SAS_IOUNIT_CONTROL_REPLY,
|
||||
Mpi2SasIoUnitControlReply_t, *pMpi2SasIoUnitControlReply_t;
|
||||
|
||||
#endif
|
||||
437
drivers/scsi/mpt3sas/mpi/mpi2_tool.h
Normal file
437
drivers/scsi/mpt3sas/mpi/mpi2_tool.h
Normal file
@@ -0,0 +1,437 @@
|
||||
/*
|
||||
* Copyright (c) 2000-2012 LSI Corporation.
|
||||
*
|
||||
*
|
||||
* Name: mpi2_tool.h
|
||||
* Title: MPI diagnostic tool structures and definitions
|
||||
* Creation Date: March 26, 2007
|
||||
*
|
||||
* mpi2_tool.h Version: 02.00.09
|
||||
*
|
||||
* Version History
|
||||
* ---------------
|
||||
*
|
||||
* Date Version Description
|
||||
* -------- -------- ------------------------------------------------------
|
||||
* 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
|
||||
* 12-18-07 02.00.01 Added Diagnostic Buffer Post and Diagnostic Release
|
||||
* structures and defines.
|
||||
* 02-29-08 02.00.02 Modified various names to make them 32-character unique.
|
||||
* 05-06-09 02.00.03 Added ISTWI Read Write Tool and Diagnostic CLI Tool.
|
||||
* 07-30-09 02.00.04 Added ExtendedType field to DiagnosticBufferPost request
|
||||
* and reply messages.
|
||||
* Added MPI2_DIAG_BUF_TYPE_EXTENDED.
|
||||
* Incremented MPI2_DIAG_BUF_TYPE_COUNT.
|
||||
* 05-12-10 02.00.05 Added Diagnostic Data Upload tool.
|
||||
* 08-11-10 02.00.06 Added defines that were missing for Diagnostic Buffer
|
||||
* Post Request.
|
||||
* 05-25-11 02.00.07 Added Flags field and related defines to
|
||||
* MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST.
|
||||
* 11-18-11 02.00.08 Incorporating additions for MPI v2.5.
|
||||
* 07-10-12 02.00.09 Add MPI v2.5 Toolbox Diagnostic CLI Tool Request
|
||||
* message.
|
||||
* --------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#ifndef MPI2_TOOL_H
|
||||
#define MPI2_TOOL_H
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* Toolbox Messages
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/*defines for the Tools */
|
||||
#define MPI2_TOOLBOX_CLEAN_TOOL (0x00)
|
||||
#define MPI2_TOOLBOX_MEMORY_MOVE_TOOL (0x01)
|
||||
#define MPI2_TOOLBOX_DIAG_DATA_UPLOAD_TOOL (0x02)
|
||||
#define MPI2_TOOLBOX_ISTWI_READ_WRITE_TOOL (0x03)
|
||||
#define MPI2_TOOLBOX_BEACON_TOOL (0x05)
|
||||
#define MPI2_TOOLBOX_DIAGNOSTIC_CLI_TOOL (0x06)
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox reply
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_TOOLBOX_REPLY {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U16 Reserved5; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
} MPI2_TOOLBOX_REPLY, *PTR_MPI2_TOOLBOX_REPLY,
|
||||
Mpi2ToolboxReply_t, *pMpi2ToolboxReply_t;
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox Clean Tool request
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_TOOLBOX_CLEAN_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U32 Flags; /*0x0C */
|
||||
} MPI2_TOOLBOX_CLEAN_REQUEST, *PTR_MPI2_TOOLBOX_CLEAN_REQUEST,
|
||||
Mpi2ToolboxCleanRequest_t, *pMpi2ToolboxCleanRequest_t;
|
||||
|
||||
/*values for the Flags field */
|
||||
#define MPI2_TOOLBOX_CLEAN_BOOT_SERVICES (0x80000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_PERSIST_MANUFACT_PAGES (0x40000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_OTHER_PERSIST_PAGES (0x20000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_FW_CURRENT (0x10000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_FW_BACKUP (0x08000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_MEGARAID (0x02000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_INITIALIZATION (0x01000000)
|
||||
#define MPI2_TOOLBOX_CLEAN_FLASH (0x00000004)
|
||||
#define MPI2_TOOLBOX_CLEAN_SEEPROM (0x00000002)
|
||||
#define MPI2_TOOLBOX_CLEAN_NVSRAM (0x00000001)
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox Memory Move request
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_TOOLBOX_MEM_MOVE_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
MPI2_SGE_SIMPLE_UNION SGL; /*0x0C */
|
||||
} MPI2_TOOLBOX_MEM_MOVE_REQUEST, *PTR_MPI2_TOOLBOX_MEM_MOVE_REQUEST,
|
||||
Mpi2ToolboxMemMoveRequest_t, *pMpi2ToolboxMemMoveRequest_t;
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox Diagnostic Data Upload request
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U8 SGLFlags; /*0x0C */
|
||||
U8 Reserved5; /*0x0D */
|
||||
U16 Reserved6; /*0x0E */
|
||||
U32 Flags; /*0x10 */
|
||||
U32 DataLength; /*0x14 */
|
||||
MPI2_SGE_SIMPLE_UNION SGL; /*0x18 */
|
||||
} MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST,
|
||||
*PTR_MPI2_TOOLBOX_DIAG_DATA_UPLOAD_REQUEST,
|
||||
Mpi2ToolboxDiagDataUploadRequest_t,
|
||||
*pMpi2ToolboxDiagDataUploadRequest_t;
|
||||
|
||||
/*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
|
||||
|
||||
typedef struct _MPI2_DIAG_DATA_UPLOAD_HEADER {
|
||||
U32 DiagDataLength; /*00h */
|
||||
U8 FormatCode; /*04h */
|
||||
U8 Reserved1; /*05h */
|
||||
U16 Reserved2; /*06h */
|
||||
} MPI2_DIAG_DATA_UPLOAD_HEADER, *PTR_MPI2_DIAG_DATA_UPLOAD_HEADER,
|
||||
Mpi2DiagDataUploadHeader_t, *pMpi2DiagDataUploadHeader_t;
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox ISTWI Read Write Tool
|
||||
****************************************************************************/
|
||||
|
||||
/*Toolbox ISTWI Read Write Tool request message */
|
||||
typedef struct _MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U32 Reserved5; /*0x0C */
|
||||
U32 Reserved6; /*0x10 */
|
||||
U8 DevIndex; /*0x14 */
|
||||
U8 Action; /*0x15 */
|
||||
U8 SGLFlags; /*0x16 */
|
||||
U8 Flags; /*0x17 */
|
||||
U16 TxDataLength; /*0x18 */
|
||||
U16 RxDataLength; /*0x1A */
|
||||
U32 Reserved8; /*0x1C */
|
||||
U32 Reserved9; /*0x20 */
|
||||
U32 Reserved10; /*0x24 */
|
||||
U32 Reserved11; /*0x28 */
|
||||
U32 Reserved12; /*0x2C */
|
||||
MPI2_SGE_SIMPLE_UNION SGL; /*0x30 */
|
||||
} MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST,
|
||||
*PTR_MPI2_TOOLBOX_ISTWI_READ_WRITE_REQUEST,
|
||||
Mpi2ToolboxIstwiReadWriteRequest_t,
|
||||
*pMpi2ToolboxIstwiReadWriteRequest_t;
|
||||
|
||||
/*values for the Action field */
|
||||
#define MPI2_TOOL_ISTWI_ACTION_READ_DATA (0x01)
|
||||
#define MPI2_TOOL_ISTWI_ACTION_WRITE_DATA (0x02)
|
||||
#define MPI2_TOOL_ISTWI_ACTION_SEQUENCE (0x03)
|
||||
#define MPI2_TOOL_ISTWI_ACTION_RESERVE_BUS (0x10)
|
||||
#define MPI2_TOOL_ISTWI_ACTION_RELEASE_BUS (0x11)
|
||||
#define MPI2_TOOL_ISTWI_ACTION_RESET (0x12)
|
||||
|
||||
/*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
|
||||
|
||||
/*values for the Flags field */
|
||||
#define MPI2_TOOL_ISTWI_FLAG_AUTO_RESERVE_RELEASE (0x80)
|
||||
#define MPI2_TOOL_ISTWI_FLAG_PAGE_ADDR_MASK (0x07)
|
||||
|
||||
/*Toolbox ISTWI Read Write Tool reply message */
|
||||
typedef struct _MPI2_TOOLBOX_ISTWI_REPLY {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U16 Reserved5; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
U8 DevIndex; /*0x14 */
|
||||
U8 Action; /*0x15 */
|
||||
U8 IstwiStatus; /*0x16 */
|
||||
U8 Reserved6; /*0x17 */
|
||||
U16 TxDataCount; /*0x18 */
|
||||
U16 RxDataCount; /*0x1A */
|
||||
} MPI2_TOOLBOX_ISTWI_REPLY, *PTR_MPI2_TOOLBOX_ISTWI_REPLY,
|
||||
Mpi2ToolboxIstwiReply_t, *pMpi2ToolboxIstwiReply_t;
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox Beacon Tool request
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_TOOLBOX_BEACON_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U8 Reserved5; /*0x0C */
|
||||
U8 PhysicalPort; /*0x0D */
|
||||
U8 Reserved6; /*0x0E */
|
||||
U8 Flags; /*0x0F */
|
||||
} MPI2_TOOLBOX_BEACON_REQUEST, *PTR_MPI2_TOOLBOX_BEACON_REQUEST,
|
||||
Mpi2ToolboxBeaconRequest_t, *pMpi2ToolboxBeaconRequest_t;
|
||||
|
||||
/*values for the Flags field */
|
||||
#define MPI2_TOOLBOX_FLAGS_BEACONMODE_OFF (0x00)
|
||||
#define MPI2_TOOLBOX_FLAGS_BEACONMODE_ON (0x01)
|
||||
|
||||
/****************************************************************************
|
||||
* Toolbox Diagnostic CLI Tool
|
||||
****************************************************************************/
|
||||
|
||||
#define MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH (0x5C)
|
||||
|
||||
/*MPI v2.0 Toolbox Diagnostic CLI Tool request message */
|
||||
typedef struct _MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U8 SGLFlags; /*0x0C */
|
||||
U8 Reserved5; /*0x0D */
|
||||
U16 Reserved6; /*0x0E */
|
||||
U32 DataLength; /*0x10 */
|
||||
U8 DiagnosticCliCommand[MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH];/*0x14 */
|
||||
MPI2_SGE_SIMPLE_UNION SGL; /*0x70 */
|
||||
} MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
|
||||
*PTR_MPI2_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
|
||||
Mpi2ToolboxDiagnosticCliRequest_t,
|
||||
*pMpi2ToolboxDiagnosticCliRequest_t;
|
||||
|
||||
/*use MPI2_SGLFLAGS_ defines from mpi2.h for the SGLFlags field */
|
||||
|
||||
/*MPI v2.5 Toolbox Diagnostic CLI Tool request message */
|
||||
typedef struct _MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U32 Reserved5; /*0x0C */
|
||||
U32 DataLength; /*0x10 */
|
||||
U8 DiagnosticCliCommand[MPI2_TOOLBOX_DIAG_CLI_CMD_LENGTH];/*0x14 */
|
||||
MPI25_SGE_IO_UNION SGL; /*0x70 */
|
||||
} MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
|
||||
*PTR_MPI25_TOOLBOX_DIAGNOSTIC_CLI_REQUEST,
|
||||
Mpi25ToolboxDiagnosticCliRequest_t,
|
||||
*pMpi25ToolboxDiagnosticCliRequest_t;
|
||||
|
||||
/*Toolbox Diagnostic CLI Tool reply message */
|
||||
typedef struct _MPI2_TOOLBOX_DIAGNOSTIC_CLI_REPLY {
|
||||
U8 Tool; /*0x00 */
|
||||
U8 Reserved1; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U16 Reserved5; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
U32 ReturnedDataLength; /*0x14 */
|
||||
} MPI2_TOOLBOX_DIAGNOSTIC_CLI_REPLY,
|
||||
*PTR_MPI2_TOOLBOX_DIAG_CLI_REPLY,
|
||||
Mpi2ToolboxDiagnosticCliReply_t,
|
||||
*pMpi2ToolboxDiagnosticCliReply_t;
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* Diagnostic Buffer Messages
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Diagnostic Buffer Post request
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_DIAG_BUFFER_POST_REQUEST {
|
||||
U8 ExtendedType; /*0x00 */
|
||||
U8 BufferType; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U64 BufferAddress; /*0x0C */
|
||||
U32 BufferLength; /*0x14 */
|
||||
U32 Reserved5; /*0x18 */
|
||||
U32 Reserved6; /*0x1C */
|
||||
U32 Flags; /*0x20 */
|
||||
U32 ProductSpecific[23]; /*0x24 */
|
||||
} MPI2_DIAG_BUFFER_POST_REQUEST, *PTR_MPI2_DIAG_BUFFER_POST_REQUEST,
|
||||
Mpi2DiagBufferPostRequest_t, *pMpi2DiagBufferPostRequest_t;
|
||||
|
||||
/*values for the ExtendedType field */
|
||||
#define MPI2_DIAG_EXTENDED_TYPE_UTILIZATION (0x02)
|
||||
|
||||
/*values for the BufferType field */
|
||||
#define MPI2_DIAG_BUF_TYPE_TRACE (0x00)
|
||||
#define MPI2_DIAG_BUF_TYPE_SNAPSHOT (0x01)
|
||||
#define MPI2_DIAG_BUF_TYPE_EXTENDED (0x02)
|
||||
/*count of the number of buffer types */
|
||||
#define MPI2_DIAG_BUF_TYPE_COUNT (0x03)
|
||||
|
||||
/*values for the Flags field */
|
||||
#define MPI2_DIAG_BUF_FLAG_RELEASE_ON_FULL (0x00000002)
|
||||
#define MPI2_DIAG_BUF_FLAG_IMMEDIATE_RELEASE (0x00000001)
|
||||
|
||||
/****************************************************************************
|
||||
* Diagnostic Buffer Post reply
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_DIAG_BUFFER_POST_REPLY {
|
||||
U8 ExtendedType; /*0x00 */
|
||||
U8 BufferType; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U16 Reserved5; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
U32 TransferLength; /*0x14 */
|
||||
} MPI2_DIAG_BUFFER_POST_REPLY, *PTR_MPI2_DIAG_BUFFER_POST_REPLY,
|
||||
Mpi2DiagBufferPostReply_t, *pMpi2DiagBufferPostReply_t;
|
||||
|
||||
/****************************************************************************
|
||||
* Diagnostic Release request
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_DIAG_RELEASE_REQUEST {
|
||||
U8 Reserved1; /*0x00 */
|
||||
U8 BufferType; /*0x01 */
|
||||
U8 ChainOffset; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
} MPI2_DIAG_RELEASE_REQUEST, *PTR_MPI2_DIAG_RELEASE_REQUEST,
|
||||
Mpi2DiagReleaseRequest_t, *pMpi2DiagReleaseRequest_t;
|
||||
|
||||
/****************************************************************************
|
||||
* Diagnostic Buffer Post reply
|
||||
****************************************************************************/
|
||||
|
||||
typedef struct _MPI2_DIAG_RELEASE_REPLY {
|
||||
U8 Reserved1; /*0x00 */
|
||||
U8 BufferType; /*0x01 */
|
||||
U8 MsgLength; /*0x02 */
|
||||
U8 Function; /*0x03 */
|
||||
U16 Reserved2; /*0x04 */
|
||||
U8 Reserved3; /*0x06 */
|
||||
U8 MsgFlags; /*0x07 */
|
||||
U8 VP_ID; /*0x08 */
|
||||
U8 VF_ID; /*0x09 */
|
||||
U16 Reserved4; /*0x0A */
|
||||
U16 Reserved5; /*0x0C */
|
||||
U16 IOCStatus; /*0x0E */
|
||||
U32 IOCLogInfo; /*0x10 */
|
||||
} MPI2_DIAG_RELEASE_REPLY, *PTR_MPI2_DIAG_RELEASE_REPLY,
|
||||
Mpi2DiagReleaseReply_t, *pMpi2DiagReleaseReply_t;
|
||||
|
||||
#endif
|
||||
56
drivers/scsi/mpt3sas/mpi/mpi2_type.h
Normal file
56
drivers/scsi/mpt3sas/mpi/mpi2_type.h
Normal file
@@ -0,0 +1,56 @@
|
||||
/*
|
||||
* Copyright (c) 2000-2007 LSI Corporation.
|
||||
*
|
||||
*
|
||||
* Name: mpi2_type.h
|
||||
* Title: MPI basic type definitions
|
||||
* Creation Date: August 16, 2006
|
||||
*
|
||||
* mpi2_type.h Version: 02.00.00
|
||||
*
|
||||
* Version History
|
||||
* ---------------
|
||||
*
|
||||
* Date Version Description
|
||||
* -------- -------- ------------------------------------------------------
|
||||
* 04-30-07 02.00.00 Corresponds to Fusion-MPT MPI Specification Rev A.
|
||||
* --------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#ifndef MPI2_TYPE_H
|
||||
#define MPI2_TYPE_H
|
||||
|
||||
/*******************************************************************************
|
||||
* Define * if it hasn't already been defined. By default
|
||||
* * is defined to be a near pointer. MPI2_POINTER can be defined as
|
||||
* a far pointer by defining * as "far *" before this header file is
|
||||
* included.
|
||||
*/
|
||||
|
||||
/* the basic types may have already been included by mpi_type.h */
|
||||
#ifndef MPI_TYPE_H
|
||||
/*****************************************************************************
|
||||
*
|
||||
* Basic Types
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
typedef u8 U8;
|
||||
typedef __le16 U16;
|
||||
typedef __le32 U32;
|
||||
typedef __le64 U64 __attribute__ ((aligned(4)));
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* Pointer Types
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
typedef U8 *PU8;
|
||||
typedef U16 *PU16;
|
||||
typedef U32 *PU32;
|
||||
typedef U64 *PU64;
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
4840
drivers/scsi/mpt3sas/mpt3sas_base.c
Normal file
4840
drivers/scsi/mpt3sas/mpt3sas_base.c
Normal file
File diff suppressed because it is too large
Load Diff
1139
drivers/scsi/mpt3sas/mpt3sas_base.h
Normal file
1139
drivers/scsi/mpt3sas/mpt3sas_base.h
Normal file
File diff suppressed because it is too large
Load Diff
1650
drivers/scsi/mpt3sas/mpt3sas_config.c
Normal file
1650
drivers/scsi/mpt3sas/mpt3sas_config.c
Normal file
File diff suppressed because it is too large
Load Diff
3297
drivers/scsi/mpt3sas/mpt3sas_ctl.c
Normal file
3297
drivers/scsi/mpt3sas/mpt3sas_ctl.c
Normal file
File diff suppressed because it is too large
Load Diff
418
drivers/scsi/mpt3sas/mpt3sas_ctl.h
Normal file
418
drivers/scsi/mpt3sas/mpt3sas_ctl.h
Normal file
@@ -0,0 +1,418 @@
|
||||
/*
|
||||
* Management Module Support for MPT (Message Passing Technology) based
|
||||
* controllers
|
||||
*
|
||||
* This code is based on drivers/scsi/mpt3sas/mpt3sas_ctl.h
|
||||
* Copyright (C) 2012 LSI Corporation
|
||||
* (mailto:DL-MPTFusionLinux@lsi.com)
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* NO WARRANTY
|
||||
* THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
|
||||
* CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
|
||||
* LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
|
||||
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
|
||||
* solely responsible for determining the appropriateness of using and
|
||||
* distributing the Program and assumes all risks associated with its
|
||||
* exercise of rights under this Agreement, including but not limited to
|
||||
* the risks and costs of program errors, damage to or loss of data,
|
||||
* programs or equipment, and unavailability or interruption of operations.
|
||||
|
||||
* DISCLAIMER OF LIABILITY
|
||||
* NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
|
||||
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
||||
* USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
|
||||
* HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
|
||||
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
||||
* USA.
|
||||
*/
|
||||
|
||||
#ifndef MPT3SAS_CTL_H_INCLUDED
|
||||
#define MPT3SAS_CTL_H_INCLUDED
|
||||
|
||||
#ifdef __KERNEL__
|
||||
#include <linux/miscdevice.h>
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef MPT3SAS_MINOR
|
||||
#define MPT3SAS_MINOR (MPT_MINOR + 2)
|
||||
#endif
|
||||
#define MPT3SAS_DEV_NAME "mpt3ctl"
|
||||
#define MPT3_MAGIC_NUMBER 'L'
|
||||
#define MPT3_IOCTL_DEFAULT_TIMEOUT (10) /* in seconds */
|
||||
|
||||
/**
|
||||
* IOCTL opcodes
|
||||
*/
|
||||
#define MPT3IOCINFO _IOWR(MPT3_MAGIC_NUMBER, 17, \
|
||||
struct mpt3_ioctl_iocinfo)
|
||||
#define MPT3COMMAND _IOWR(MPT3_MAGIC_NUMBER, 20, \
|
||||
struct mpt3_ioctl_command)
|
||||
#ifdef CONFIG_COMPAT
|
||||
#define MPT3COMMAND32 _IOWR(MPT3_MAGIC_NUMBER, 20, \
|
||||
struct mpt3_ioctl_command32)
|
||||
#endif
|
||||
#define MPT3EVENTQUERY _IOWR(MPT3_MAGIC_NUMBER, 21, \
|
||||
struct mpt3_ioctl_eventquery)
|
||||
#define MPT3EVENTENABLE _IOWR(MPT3_MAGIC_NUMBER, 22, \
|
||||
struct mpt3_ioctl_eventenable)
|
||||
#define MPT3EVENTREPORT _IOWR(MPT3_MAGIC_NUMBER, 23, \
|
||||
struct mpt3_ioctl_eventreport)
|
||||
#define MPT3HARDRESET _IOWR(MPT3_MAGIC_NUMBER, 24, \
|
||||
struct mpt3_ioctl_diag_reset)
|
||||
#define MPT3BTDHMAPPING _IOWR(MPT3_MAGIC_NUMBER, 31, \
|
||||
struct mpt3_ioctl_btdh_mapping)
|
||||
|
||||
/* diag buffer support */
|
||||
#define MPT3DIAGREGISTER _IOWR(MPT3_MAGIC_NUMBER, 26, \
|
||||
struct mpt3_diag_register)
|
||||
#define MPT3DIAGRELEASE _IOWR(MPT3_MAGIC_NUMBER, 27, \
|
||||
struct mpt3_diag_release)
|
||||
#define MPT3DIAGUNREGISTER _IOWR(MPT3_MAGIC_NUMBER, 28, \
|
||||
struct mpt3_diag_unregister)
|
||||
#define MPT3DIAGQUERY _IOWR(MPT3_MAGIC_NUMBER, 29, \
|
||||
struct mpt3_diag_query)
|
||||
#define MPT3DIAGREADBUFFER _IOWR(MPT3_MAGIC_NUMBER, 30, \
|
||||
struct mpt3_diag_read_buffer)
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_header - main header structure
|
||||
* @ioc_number - IOC unit number
|
||||
* @port_number - IOC port number
|
||||
* @max_data_size - maximum number bytes to transfer on read
|
||||
*/
|
||||
struct mpt3_ioctl_header {
|
||||
uint32_t ioc_number;
|
||||
uint32_t port_number;
|
||||
uint32_t max_data_size;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_diag_reset - diagnostic reset
|
||||
* @hdr - generic header
|
||||
*/
|
||||
struct mpt3_ioctl_diag_reset {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_pci_info - pci device info
|
||||
* @device - pci device id
|
||||
* @function - pci function id
|
||||
* @bus - pci bus id
|
||||
* @segment_id - pci segment id
|
||||
*/
|
||||
struct mpt3_ioctl_pci_info {
|
||||
union {
|
||||
struct {
|
||||
uint32_t device:5;
|
||||
uint32_t function:3;
|
||||
uint32_t bus:24;
|
||||
} bits;
|
||||
uint32_t word;
|
||||
} u;
|
||||
uint32_t segment_id;
|
||||
};
|
||||
|
||||
|
||||
#define MPT2_IOCTL_INTERFACE_SCSI (0x00)
|
||||
#define MPT2_IOCTL_INTERFACE_FC (0x01)
|
||||
#define MPT2_IOCTL_INTERFACE_FC_IP (0x02)
|
||||
#define MPT2_IOCTL_INTERFACE_SAS (0x03)
|
||||
#define MPT2_IOCTL_INTERFACE_SAS2 (0x04)
|
||||
#define MPT3_IOCTL_INTERFACE_SAS3 (0x06)
|
||||
#define MPT2_IOCTL_VERSION_LENGTH (32)
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_iocinfo - generic controller info
|
||||
* @hdr - generic header
|
||||
* @adapter_type - type of adapter (spi, fc, sas)
|
||||
* @port_number - port number
|
||||
* @pci_id - PCI Id
|
||||
* @hw_rev - hardware revision
|
||||
* @sub_system_device - PCI subsystem Device ID
|
||||
* @sub_system_vendor - PCI subsystem Vendor ID
|
||||
* @rsvd0 - reserved
|
||||
* @firmware_version - firmware version
|
||||
* @bios_version - BIOS version
|
||||
* @driver_version - driver version - 32 ASCII characters
|
||||
* @rsvd1 - reserved
|
||||
* @scsi_id - scsi id of adapter 0
|
||||
* @rsvd2 - reserved
|
||||
* @pci_information - pci info (2nd revision)
|
||||
*/
|
||||
struct mpt3_ioctl_iocinfo {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t adapter_type;
|
||||
uint32_t port_number;
|
||||
uint32_t pci_id;
|
||||
uint32_t hw_rev;
|
||||
uint32_t subsystem_device;
|
||||
uint32_t subsystem_vendor;
|
||||
uint32_t rsvd0;
|
||||
uint32_t firmware_version;
|
||||
uint32_t bios_version;
|
||||
uint8_t driver_version[MPT2_IOCTL_VERSION_LENGTH];
|
||||
uint8_t rsvd1;
|
||||
uint8_t scsi_id;
|
||||
uint16_t rsvd2;
|
||||
struct mpt3_ioctl_pci_info pci_information;
|
||||
};
|
||||
|
||||
|
||||
/* number of event log entries */
|
||||
#define MPT3SAS_CTL_EVENT_LOG_SIZE (50)
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_eventquery - query event count and type
|
||||
* @hdr - generic header
|
||||
* @event_entries - number of events returned by get_event_report
|
||||
* @rsvd - reserved
|
||||
* @event_types - type of events currently being captured
|
||||
*/
|
||||
struct mpt3_ioctl_eventquery {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint16_t event_entries;
|
||||
uint16_t rsvd;
|
||||
uint32_t event_types[MPI2_EVENT_NOTIFY_EVENTMASK_WORDS];
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_eventenable - enable/disable event capturing
|
||||
* @hdr - generic header
|
||||
* @event_types - toggle off/on type of events to be captured
|
||||
*/
|
||||
struct mpt3_ioctl_eventenable {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t event_types[4];
|
||||
};
|
||||
|
||||
#define MPT3_EVENT_DATA_SIZE (192)
|
||||
/**
|
||||
* struct MPT3_IOCTL_EVENTS -
|
||||
* @event - the event that was reported
|
||||
* @context - unique value for each event assigned by driver
|
||||
* @data - event data returned in fw reply message
|
||||
*/
|
||||
struct MPT3_IOCTL_EVENTS {
|
||||
uint32_t event;
|
||||
uint32_t context;
|
||||
uint8_t data[MPT3_EVENT_DATA_SIZE];
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_eventreport - returing event log
|
||||
* @hdr - generic header
|
||||
* @event_data - (see struct MPT3_IOCTL_EVENTS)
|
||||
*/
|
||||
struct mpt3_ioctl_eventreport {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
struct MPT3_IOCTL_EVENTS event_data[1];
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_command - generic mpt firmware passthru ioctl
|
||||
* @hdr - generic header
|
||||
* @timeout - command timeout in seconds. (if zero then use driver default
|
||||
* value).
|
||||
* @reply_frame_buf_ptr - reply location
|
||||
* @data_in_buf_ptr - destination for read
|
||||
* @data_out_buf_ptr - data source for write
|
||||
* @sense_data_ptr - sense data location
|
||||
* @max_reply_bytes - maximum number of reply bytes to be sent to app.
|
||||
* @data_in_size - number bytes for data transfer in (read)
|
||||
* @data_out_size - number bytes for data transfer out (write)
|
||||
* @max_sense_bytes - maximum number of bytes for auto sense buffers
|
||||
* @data_sge_offset - offset in words from the start of the request message to
|
||||
* the first SGL
|
||||
* @mf[1];
|
||||
*/
|
||||
struct mpt3_ioctl_command {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t timeout;
|
||||
void __user *reply_frame_buf_ptr;
|
||||
void __user *data_in_buf_ptr;
|
||||
void __user *data_out_buf_ptr;
|
||||
void __user *sense_data_ptr;
|
||||
uint32_t max_reply_bytes;
|
||||
uint32_t data_in_size;
|
||||
uint32_t data_out_size;
|
||||
uint32_t max_sense_bytes;
|
||||
uint32_t data_sge_offset;
|
||||
uint8_t mf[1];
|
||||
};
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
struct mpt3_ioctl_command32 {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t timeout;
|
||||
uint32_t reply_frame_buf_ptr;
|
||||
uint32_t data_in_buf_ptr;
|
||||
uint32_t data_out_buf_ptr;
|
||||
uint32_t sense_data_ptr;
|
||||
uint32_t max_reply_bytes;
|
||||
uint32_t data_in_size;
|
||||
uint32_t data_out_size;
|
||||
uint32_t max_sense_bytes;
|
||||
uint32_t data_sge_offset;
|
||||
uint8_t mf[1];
|
||||
};
|
||||
#endif
|
||||
|
||||
/**
|
||||
* struct mpt3_ioctl_btdh_mapping - mapping info
|
||||
* @hdr - generic header
|
||||
* @id - target device identification number
|
||||
* @bus - SCSI bus number that the target device exists on
|
||||
* @handle - device handle for the target device
|
||||
* @rsvd - reserved
|
||||
*
|
||||
* To obtain a bus/id the application sets
|
||||
* handle to valid handle, and bus/id to 0xFFFF.
|
||||
*
|
||||
* To obtain the device handle the application sets
|
||||
* bus/id valid value, and the handle to 0xFFFF.
|
||||
*/
|
||||
struct mpt3_ioctl_btdh_mapping {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t id;
|
||||
uint32_t bus;
|
||||
uint16_t handle;
|
||||
uint16_t rsvd;
|
||||
};
|
||||
|
||||
|
||||
|
||||
/* application flags for mpt3_diag_register, mpt3_diag_query */
|
||||
#define MPT3_APP_FLAGS_APP_OWNED (0x0001)
|
||||
#define MPT3_APP_FLAGS_BUFFER_VALID (0x0002)
|
||||
#define MPT3_APP_FLAGS_FW_BUFFER_ACCESS (0x0004)
|
||||
|
||||
/* flags for mpt3_diag_read_buffer */
|
||||
#define MPT3_FLAGS_REREGISTER (0x0001)
|
||||
|
||||
#define MPT3_PRODUCT_SPECIFIC_DWORDS 23
|
||||
|
||||
/**
|
||||
* struct mpt3_diag_register - application register with driver
|
||||
* @hdr - generic header
|
||||
* @reserved -
|
||||
* @buffer_type - specifies either TRACE, SNAPSHOT, or EXTENDED
|
||||
* @application_flags - misc flags
|
||||
* @diagnostic_flags - specifies flags affecting command processing
|
||||
* @product_specific - product specific information
|
||||
* @requested_buffer_size - buffers size in bytes
|
||||
* @unique_id - tag specified by application that is used to signal ownership
|
||||
* of the buffer.
|
||||
*
|
||||
* This will allow the driver to setup any required buffers that will be
|
||||
* needed by firmware to communicate with the driver.
|
||||
*/
|
||||
struct mpt3_diag_register {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint8_t reserved;
|
||||
uint8_t buffer_type;
|
||||
uint16_t application_flags;
|
||||
uint32_t diagnostic_flags;
|
||||
uint32_t product_specific[MPT3_PRODUCT_SPECIFIC_DWORDS];
|
||||
uint32_t requested_buffer_size;
|
||||
uint32_t unique_id;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_diag_unregister - application unregister with driver
|
||||
* @hdr - generic header
|
||||
* @unique_id - tag uniquely identifies the buffer to be unregistered
|
||||
*
|
||||
* This will allow the driver to cleanup any memory allocated for diag
|
||||
* messages and to free up any resources.
|
||||
*/
|
||||
struct mpt3_diag_unregister {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t unique_id;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_diag_query - query relevant info associated with diag buffers
|
||||
* @hdr - generic header
|
||||
* @reserved -
|
||||
* @buffer_type - specifies either TRACE, SNAPSHOT, or EXTENDED
|
||||
* @application_flags - misc flags
|
||||
* @diagnostic_flags - specifies flags affecting command processing
|
||||
* @product_specific - product specific information
|
||||
* @total_buffer_size - diag buffer size in bytes
|
||||
* @driver_added_buffer_size - size of extra space appended to end of buffer
|
||||
* @unique_id - unique id associated with this buffer.
|
||||
*
|
||||
* The application will send only buffer_type and unique_id. Driver will
|
||||
* inspect unique_id first, if valid, fill in all the info. If unique_id is
|
||||
* 0x00, the driver will return info specified by Buffer Type.
|
||||
*/
|
||||
struct mpt3_diag_query {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint8_t reserved;
|
||||
uint8_t buffer_type;
|
||||
uint16_t application_flags;
|
||||
uint32_t diagnostic_flags;
|
||||
uint32_t product_specific[MPT3_PRODUCT_SPECIFIC_DWORDS];
|
||||
uint32_t total_buffer_size;
|
||||
uint32_t driver_added_buffer_size;
|
||||
uint32_t unique_id;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_diag_release - request to send Diag Release Message to firmware
|
||||
* @hdr - generic header
|
||||
* @unique_id - tag uniquely identifies the buffer to be released
|
||||
*
|
||||
* This allows ownership of the specified buffer to returned to the driver,
|
||||
* allowing an application to read the buffer without fear that firmware is
|
||||
* overwritting information in the buffer.
|
||||
*/
|
||||
struct mpt3_diag_release {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint32_t unique_id;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct mpt3_diag_read_buffer - request for copy of the diag buffer
|
||||
* @hdr - generic header
|
||||
* @status -
|
||||
* @reserved -
|
||||
* @flags - misc flags
|
||||
* @starting_offset - starting offset within drivers buffer where to start
|
||||
* reading data at into the specified application buffer
|
||||
* @bytes_to_read - number of bytes to copy from the drivers buffer into the
|
||||
* application buffer starting at starting_offset.
|
||||
* @unique_id - unique id associated with this buffer.
|
||||
* @diagnostic_data - data payload
|
||||
*/
|
||||
struct mpt3_diag_read_buffer {
|
||||
struct mpt3_ioctl_header hdr;
|
||||
uint8_t status;
|
||||
uint8_t reserved;
|
||||
uint16_t flags;
|
||||
uint32_t starting_offset;
|
||||
uint32_t bytes_to_read;
|
||||
uint32_t unique_id;
|
||||
uint32_t diagnostic_data[1];
|
||||
};
|
||||
|
||||
#endif /* MPT3SAS_CTL_H_INCLUDED */
|
||||
219
drivers/scsi/mpt3sas/mpt3sas_debug.h
Normal file
219
drivers/scsi/mpt3sas/mpt3sas_debug.h
Normal file
@@ -0,0 +1,219 @@
|
||||
/*
|
||||
* Logging Support for MPT (Message Passing Technology) based controllers
|
||||
*
|
||||
* This code is based on drivers/scsi/mpt3sas/mpt3sas_debug.c
|
||||
* Copyright (C) 2012 LSI Corporation
|
||||
* (mailto:DL-MPTFusionLinux@lsi.com)
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* NO WARRANTY
|
||||
* THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
|
||||
* CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
|
||||
* LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
|
||||
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
|
||||
* solely responsible for determining the appropriateness of using and
|
||||
* distributing the Program and assumes all risks associated with its
|
||||
* exercise of rights under this Agreement, including but not limited to
|
||||
* the risks and costs of program errors, damage to or loss of data,
|
||||
* programs or equipment, and unavailability or interruption of operations.
|
||||
|
||||
* DISCLAIMER OF LIABILITY
|
||||
* NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
|
||||
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
||||
* USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
|
||||
* HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
|
||||
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
||||
* USA.
|
||||
*/
|
||||
|
||||
#ifndef MPT3SAS_DEBUG_H_INCLUDED
|
||||
#define MPT3SAS_DEBUG_H_INCLUDED
|
||||
|
||||
#define MPT_DEBUG 0x00000001
|
||||
#define MPT_DEBUG_MSG_FRAME 0x00000002
|
||||
#define MPT_DEBUG_SG 0x00000004
|
||||
#define MPT_DEBUG_EVENTS 0x00000008
|
||||
#define MPT_DEBUG_EVENT_WORK_TASK 0x00000010
|
||||
#define MPT_DEBUG_INIT 0x00000020
|
||||
#define MPT_DEBUG_EXIT 0x00000040
|
||||
#define MPT_DEBUG_FAIL 0x00000080
|
||||
#define MPT_DEBUG_TM 0x00000100
|
||||
#define MPT_DEBUG_REPLY 0x00000200
|
||||
#define MPT_DEBUG_HANDSHAKE 0x00000400
|
||||
#define MPT_DEBUG_CONFIG 0x00000800
|
||||
#define MPT_DEBUG_DL 0x00001000
|
||||
#define MPT_DEBUG_RESET 0x00002000
|
||||
#define MPT_DEBUG_SCSI 0x00004000
|
||||
#define MPT_DEBUG_IOCTL 0x00008000
|
||||
#define MPT_DEBUG_SAS 0x00020000
|
||||
#define MPT_DEBUG_TRANSPORT 0x00040000
|
||||
#define MPT_DEBUG_TASK_SET_FULL 0x00080000
|
||||
|
||||
#define MPT_DEBUG_TRIGGER_DIAG 0x00200000
|
||||
|
||||
|
||||
/*
|
||||
* CONFIG_SCSI_MPT3SAS_LOGGING - enabled in Kconfig
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_SCSI_MPT3SAS_LOGGING
|
||||
#define MPT_CHECK_LOGGING(IOC, CMD, BITS) \
|
||||
{ \
|
||||
if (IOC->logging_level & BITS) \
|
||||
CMD; \
|
||||
}
|
||||
#else
|
||||
#define MPT_CHECK_LOGGING(IOC, CMD, BITS)
|
||||
#endif /* CONFIG_SCSI_MPT3SAS_LOGGING */
|
||||
|
||||
|
||||
/*
|
||||
* debug macros
|
||||
*/
|
||||
|
||||
#define dprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG)
|
||||
|
||||
#define dsgprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_SG)
|
||||
|
||||
#define devtprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_EVENTS)
|
||||
|
||||
#define dewtprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_EVENT_WORK_TASK)
|
||||
|
||||
#define dinitprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_INIT)
|
||||
|
||||
#define dexitprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_EXIT)
|
||||
|
||||
#define dfailprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_FAIL)
|
||||
|
||||
#define dtmprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_TM)
|
||||
|
||||
#define dreplyprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_REPLY)
|
||||
|
||||
#define dhsprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_HANDSHAKE)
|
||||
|
||||
#define dcprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_CONFIG)
|
||||
|
||||
#define ddlprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_DL)
|
||||
|
||||
#define drsprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_RESET)
|
||||
|
||||
#define dsprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_SCSI)
|
||||
|
||||
#define dctlprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_IOCTL)
|
||||
|
||||
#define dsasprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_SAS)
|
||||
|
||||
#define dsastransport(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_SAS_WIDE)
|
||||
|
||||
#define dmfprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_MSG_FRAME)
|
||||
|
||||
#define dtsfprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_TASK_SET_FULL)
|
||||
|
||||
#define dtransportprintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_TRANSPORT)
|
||||
|
||||
#define dTriggerDiagPrintk(IOC, CMD) \
|
||||
MPT_CHECK_LOGGING(IOC, CMD, MPT_DEBUG_TRIGGER_DIAG)
|
||||
|
||||
|
||||
|
||||
/* inline functions for dumping debug data*/
|
||||
#ifdef CONFIG_SCSI_MPT3SAS_LOGGING
|
||||
/**
|
||||
* _debug_dump_mf - print message frame contents
|
||||
* @mpi_request: pointer to message frame
|
||||
* @sz: number of dwords
|
||||
*/
|
||||
static inline void
|
||||
_debug_dump_mf(void *mpi_request, int sz)
|
||||
{
|
||||
int i;
|
||||
__le32 *mfp = (__le32 *)mpi_request;
|
||||
|
||||
pr_info("mf:\n\t");
|
||||
for (i = 0; i < sz; i++) {
|
||||
if (i && ((i % 8) == 0))
|
||||
pr_info("\n\t");
|
||||
pr_info("%08x ", le32_to_cpu(mfp[i]));
|
||||
}
|
||||
pr_info("\n");
|
||||
}
|
||||
/**
|
||||
* _debug_dump_reply - print message frame contents
|
||||
* @mpi_request: pointer to message frame
|
||||
* @sz: number of dwords
|
||||
*/
|
||||
static inline void
|
||||
_debug_dump_reply(void *mpi_request, int sz)
|
||||
{
|
||||
int i;
|
||||
__le32 *mfp = (__le32 *)mpi_request;
|
||||
|
||||
pr_info("reply:\n\t");
|
||||
for (i = 0; i < sz; i++) {
|
||||
if (i && ((i % 8) == 0))
|
||||
pr_info("\n\t");
|
||||
pr_info("%08x ", le32_to_cpu(mfp[i]));
|
||||
}
|
||||
pr_info("\n");
|
||||
}
|
||||
/**
|
||||
* _debug_dump_config - print config page contents
|
||||
* @mpi_request: pointer to message frame
|
||||
* @sz: number of dwords
|
||||
*/
|
||||
static inline void
|
||||
_debug_dump_config(void *mpi_request, int sz)
|
||||
{
|
||||
int i;
|
||||
__le32 *mfp = (__le32 *)mpi_request;
|
||||
|
||||
pr_info("config:\n\t");
|
||||
for (i = 0; i < sz; i++) {
|
||||
if (i && ((i % 8) == 0))
|
||||
pr_info("\n\t");
|
||||
pr_info("%08x ", le32_to_cpu(mfp[i]));
|
||||
}
|
||||
pr_info("\n");
|
||||
}
|
||||
#else
|
||||
#define _debug_dump_mf(mpi_request, sz)
|
||||
#define _debug_dump_reply(mpi_request, sz)
|
||||
#define _debug_dump_config(mpi_request, sz)
|
||||
#endif /* CONFIG_SCSI_MPT3SAS_LOGGING */
|
||||
|
||||
#endif /* MPT3SAS_DEBUG_H_INCLUDED */
|
||||
8167
drivers/scsi/mpt3sas/mpt3sas_scsih.c
Normal file
8167
drivers/scsi/mpt3sas/mpt3sas_scsih.c
Normal file
File diff suppressed because it is too large
Load Diff
2128
drivers/scsi/mpt3sas/mpt3sas_transport.c
Normal file
2128
drivers/scsi/mpt3sas/mpt3sas_transport.c
Normal file
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user