mpi_cnfg.h revision 2076eb6ab8339bf09620a0160be3607bbbb61a50
11da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 2c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Copyright (c) 2000-2005 LSI Logic Corporation. 31da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 41da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 51da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Name: mpi_cnfg.h 61da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Title: MPI Config message, structures, and Pages 71da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Creation Date: July 27, 2000 81da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 92076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * mpi_cnfg.h Version: 01.05.12 101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Version History 121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * --------------- 131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Date Version Description 151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * -------- -------- ------------------------------------------------------ 161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 05-08-00 00.10.01 Original release for 0.10 spec dated 4/26/2000. 171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 06-06-00 01.00.01 Update version number for 1.0 release. 181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 06-08-00 01.00.02 Added _PAGEVERSION definitions for all pages. 191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added FcPhLowestVersion, FcPhHighestVersion, Reserved2 201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * fields to FC_DEVICE_0 page, updated the page version. 211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Changed _FREE_RUNNING_CLOCK to _PACING_TRANSFERS in 221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * SCSI_PORT_0, SCSI_DEVICE_0 and SCSI_DEVICE_1 pages 231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * and updated the page versions. 241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added _RESPONSE_ID_MASK definition to SCSI_PORT_1 251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * page and updated the page version. 261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added Information field and _INFO_PARAMS_NEGOTIATED 271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * definitionto SCSI_DEVICE_0 page. 281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 06-22-00 01.00.03 Removed batch controls from LAN_0 page and updated the 291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * page version. 301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added BucketsRemaining to LAN_1 page, redefined the 311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * state values, and updated the page version. 321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Revised bus width definitions in SCSI_PORT_0, 331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * SCSI_DEVICE_0 and SCSI_DEVICE_1 pages. 341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 06-30-00 01.00.04 Added MaxReplySize to LAN_1 page and updated the page 351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * version. 361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Moved FC_DEVICE_0 PageAddress description to spec. 371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 07-27-00 01.00.05 Corrected the SubsystemVendorID and SubsystemID field 381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * widths in IOC_0 page and updated the page version. 391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 11-02-00 01.01.01 Original release for post 1.0 work 401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added Manufacturing pages, IO Unit Page 2, SCSI SPI 411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Port Page 2, FC Port Page 4, FC Port Page 5 421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 11-15-00 01.01.02 Interim changes to match proposals 431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 12-04-00 01.01.03 Config page changes to match MPI rev 1.00.01. 441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 12-05-00 01.01.04 Modified config page actions. 451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 01-09-01 01.01.05 Added defines for page address formats. 461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Data size for Manufacturing pages 2 and 3 no longer 471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * defined here. 481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Io Unit Page 2 size is fixed at 4 adapters and some 491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * flags were changed. 501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * SCSI Port Page 2 Device Settings modified. 511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * New fields added to FC Port Page 0 and some flags 521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * cleaned up. 531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Removed impedance flash from FC Port Page 1. 541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added FC Port pages 6 and 7. 551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 01-25-01 01.01.06 Added MaxInitiators field to FcPortPage0. 561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 01-29-01 01.01.07 Changed some defines to make them 32 character unique. 571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added some LinkType defines for FcPortPage0. 581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 02-20-01 01.01.08 Started using MPI_POINTER. 591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 02-27-01 01.01.09 Replaced MPI_CONFIG_PAGETYPE_SCSI_LUN with 601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_CONFIG_PAGETYPE_RAID_VOLUME. 611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added definitions and structures for IOC Page 2 and 621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * RAID Volume Page 2. 631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 03-27-01 01.01.10 Added CONFIG_PAGE_FC_PORT_8 and CONFIG_PAGE_FC_PORT_9. 641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * CONFIG_PAGE_FC_PORT_3 now supports persistent by DID. 651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added VendorId and ProductRevLevel fields to 661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * RAIDVOL2_IM_PHYS_ID struct. 671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified values for MPI_FCPORTPAGE0_FLAGS_ATTACH_ 681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * defines to make them compatible to MPI version 1.0. 691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added structure offset comments. 701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 04-09-01 01.01.11 Added some new defines for the PageAddress field and 711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * removed some obsolete ones. 721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added IO Unit Page 3. 731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified defines for Scsi Port Page 2. 741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified RAID Volume Pages. 751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 08-08-01 01.02.01 Original release for v1.2 work. 761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added SepID and SepBus to RVP2 IMPhysicalDisk struct. 771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added defines for the SEP bits in RVP2 VolumeSettings. 781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified the DeviceSettings field in RVP2 to use the 791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * proper structure. 801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added defines for SES, SAF-TE, and cross channel for 811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * IOCPage2 CapabilitiesFlags. 821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Removed define for MPI_IOUNITPAGE2_FLAGS_RAID_DISABLE. 831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Removed define for 841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_SCSIPORTPAGE2_PORT_FLAGS_PARITY_ENABLE. 851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added define for MPI_CONFIG_PAGEATTR_RO_PERSISTENT. 861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 08-29-01 01.02.02 Fixed value for MPI_MANUFACTPAGE_DEVID_53C1035. 871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added defines for MPI_FCPORTPAGE1_FLAGS_HARD_ALPA_ONLY 881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * and MPI_FCPORTPAGE1_FLAGS_IMMEDIATE_ERROR_REPLY. 891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Removed MPI_SCSIPORTPAGE0_CAP_PACING_TRANSFERS, 901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_SCSIDEVPAGE0_NP_PACING_TRANSFERS, and 911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_SCSIDEVPAGE1_RP_PACING_TRANSFERS, and 921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_SCSIDEVPAGE1_CONF_PPR_ALLOWED. 931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added defines for MPI_SCSIDEVPAGE1_CONF_WDTR_DISALLOWED 941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * and MPI_SCSIDEVPAGE1_CONF_SDTR_DISALLOWED. 951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added OnBusTimerValue to CONFIG_PAGE_SCSI_PORT_1. 961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added rejected bits to SCSI Device Page 0 Information. 971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Increased size of ALPA array in FC Port Page 2 by one 981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * and removed a one byte reserved field. 991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 09-28-01 01.02.03 Swapped NegWireSpeedLow and NegWireSpeedLow in 1001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * CONFIG_PAGE_LAN_1 to match preferred 64-bit ordering. 1011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added structures for Manufacturing Page 4, IO Unit 1021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Page 3, IOC Page 3, IOC Page 4, RAID Volume Page 0, and 1031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * RAID PhysDisk Page 0. 1041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 10-04-01 01.02.04 Added define for MPI_CONFIG_PAGETYPE_RAID_PHYSDISK. 1051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified some of the new defines to make them 32 1061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * character unique. 1071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified how variable length pages (arrays) are defined. 1081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added generic defines for hot spare pools and RAID 1091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * volume types. 1101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 11-01-01 01.02.05 Added define for MPI_IOUNITPAGE1_DISABLE_IR. 1111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 03-14-02 01.02.06 Added PCISlotNum field to CONFIG_PAGE_IOC_1 along with 1121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * related define, and bumped the page version define. 1131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 05-31-02 01.02.07 Added a Flags field to CONFIG_PAGE_IOC_2_RAID_VOL in a 1141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * reserved byte and added a define. 1151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added define for 1161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_RAIDVOL0_STATUS_FLAG_VOLUME_INACTIVE. 1171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added new config page: CONFIG_PAGE_IOC_5. 1181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added MaxAliases, MaxHardAliases, and NumCurrentAliases 1191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * fields to CONFIG_PAGE_FC_PORT_0. 1201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added AltConnector and NumRequestedAliases fields to 1211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * CONFIG_PAGE_FC_PORT_1. 1221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added new config page: CONFIG_PAGE_FC_PORT_10. 1231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 07-12-02 01.02.08 Added more MPI_MANUFACTPAGE_DEVID_ defines. 1241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added additional MPI_SCSIDEVPAGE0_NP_ defines. 1251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added more MPI_SCSIDEVPAGE1_RP_ defines. 1261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added define for 1271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * MPI_SCSIDEVPAGE1_CONF_EXTENDED_PARAMS_ENABLE. 1281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added new config page: CONFIG_PAGE_SCSI_DEVICE_3. 1291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Modified MPI_FCPORTPAGE5_FLAGS_ defines. 1301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 09-16-02 01.02.09 Added MPI_SCSIDEVPAGE1_CONF_FORCE_PPR_MSG define. 1311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 11-15-02 01.02.10 Added ConnectedID defines for CONFIG_PAGE_SCSI_PORT_0. 1321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added more Flags defines for CONFIG_PAGE_FC_PORT_1. 1331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added more Flags defines for CONFIG_PAGE_FC_DEVICE_0. 1341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 04-01-03 01.02.11 Added RR_TOV field and additional Flags defines for 1351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * CONFIG_PAGE_FC_PORT_1. 1361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added define MPI_FCPORTPAGE5_FLAGS_DISABLE to disable 1371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * an alias. 1381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added more device id defines. 1391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * 06-26-03 01.02.12 Added MPI_IOUNITPAGE1_IR_USE_STATIC_VOLUME_ID define. 1401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added TargetConfig and IDConfig fields to 1411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * CONFIG_PAGE_SCSI_PORT_1. 1421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added more PortFlags defines for CONFIG_PAGE_SCSI_PORT_2 1431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * to control DV. 1441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added more Flags defines for CONFIG_PAGE_FC_PORT_1. 1451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * In CONFIG_PAGE_FC_DEVICE_0, replaced Reserved1 field 1461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * with ADISCHardALPA. 1471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Added MPI_FC_DEVICE_PAGE0_PROT_FCP_RETRY define. 148c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 01-16-04 01.02.13 Added InitiatorDeviceTimeout and InitiatorIoPendTimeout 149c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * fields and related defines to CONFIG_PAGE_FC_PORT_1. 150c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added define for 151c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * MPI_FCPORTPAGE1_FLAGS_SOFT_ALPA_FALLBACK. 152c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added new fields to the substructures of 153c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * CONFIG_PAGE_FC_PORT_10. 154c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 04-29-04 01.02.14 Added define for IDP bit for CONFIG_PAGE_SCSI_PORT_0, 155c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * CONFIG_PAGE_SCSI_DEVICE_0, and 156c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * CONFIG_PAGE_SCSI_DEVICE_1. Also bumped Page Version for 157c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * these pages. 158c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 05-11-04 01.03.01 Added structure for CONFIG_PAGE_INBAND_0. 159c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 08-19-04 01.05.01 Modified MSG_CONFIG request to support extended config 160c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * pages. 161c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added a new structure for extended config page header. 162c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added new extended config pages types and structures for 163c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * SAS IO Unit, SAS Expander, SAS Device, and SAS PHY. 164c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Replaced a reserved byte in CONFIG_PAGE_MANUFACTURING_4 165c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * to add a Flags field. 166c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Two new Manufacturing config pages (5 and 6). 167c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Two new bits defined for IO Unit Page 1 Flags field. 168c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Modified CONFIG_PAGE_IO_UNIT_2 to add three new fields 169c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * to specify the BIOS boot device. 170c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Four new Flags bits defined for IO Unit Page 2. 171c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added IO Unit Page 4. 172c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added EEDP Flags settings to IOC Page 1. 173c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added new BIOS Page 1 config page. 174c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 10-05-04 01.05.02 Added define for 175c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * MPI_IOCPAGE1_INITIATOR_CONTEXT_REPLY_DISABLE. 176c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added new Flags field to CONFIG_PAGE_MANUFACTURING_5 and 177c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * associated defines. 178c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added more defines for SAS IO Unit Page 0 179c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * DiscoveryStatus field. 180c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added define for MPI_SAS_IOUNIT0_DS_SUBTRACTIVE_LINK 181c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * and MPI_SAS_IOUNIT0_DS_TABLE_LINK. 182c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added defines for Physical Mapping Modes to SAS IO Unit 183c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 2. 184c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added define for 185c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * MPI_SAS_DEVICE0_FLAGS_PORT_SELECTOR_ATTACH. 186c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 10-27-04 01.05.03 Added defines for new SAS PHY page addressing mode. 187c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added defines for MaxTargetSpinUp to BIOS Page 1. 188c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added 5 new ControlFlags defines for SAS IO Unit 189c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 1. 190c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added MaxNumPhysicalMappedIDs field to SAS IO Unit 191c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 2. 192c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added AccessStatus field to SAS Device Page 0 and added 193c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * new Flags bits for supported SATA features. 194c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 12-07-04 01.05.04 Added config page structures for BIOS Page 2, RAID 195c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Volume Page 1, and RAID Physical Disk Page 1. 196c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Replaced IO Unit Page 1 BootTargetID,BootBus, and 197c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * BootAdapterNum with reserved field. 198c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added DataScrubRate and ResyncRate to RAID Volume 199c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 0. 200c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added MPI_SAS_IOUNIT2_FLAGS_RESERVE_ID_0_FOR_BOOT 201c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * define. 202c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 12-09-04 01.05.05 Added Target Mode Large CDB Enable to FC Port Page 1 203c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Flags field. 204c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added Auto Port Config flag define for SAS IOUNIT 205c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 1 ControlFlags. 206c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added Disabled bad Phy define to Expander Page 1 207c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Discovery Info field. 208c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added SAS/SATA device support to SAS IOUnit Page 1 209c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * ControlFlags. 210c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added Unsupported device to SAS Dev Page 0 Flags field 211c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added disable use SATA Hash Address for SAS IOUNIT 212c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * page 1 in ControlFields. 213c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 01-15-05 01.05.06 Added defaults for data scrub rate and resync rate to 214c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Manufacturing Page 4. 215c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added new defines for BIOS Page 1 IOCSettings field. 216c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added ExtDiskIdentifier field to RAID Physical Disk 217c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 0. 218c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added new defines for SAS IO Unit Page 1 ControlFlags 219c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * and to SAS Device Page 0 Flags to control SATA devices. 220c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added defines and structures for the new Log Page 0, a 221c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * new type of configuration page. 222c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 02-09-05 01.05.07 Added InactiveStatus field to RAID Volume Page 0. 223c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added WWID field to RAID Volume Page 1. 224c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added PhysicalPort field to SAS Expander pages 0 and 1. 225c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * 03-11-05 01.05.08 Removed the EEDP flags from IOC Page 1. 226c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added Enclosure/Slot boot device format to BIOS Page 2. 227c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * New status value for RAID Volume Page 0 VolumeStatus 228c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * (VolumeState subfield). 229c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * New value for RAID Physical Page 0 InactiveStatus. 230c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added Inactive Volume Member flag RAID Physical Disk 231c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Page 0 PhysDiskStatus field. 232c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * New physical mapping mode in SAS IO Unit Page 2. 233c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added CONFIG_PAGE_SAS_ENCLOSURE_0. 234c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Added Slot and Enclosure fields to SAS Device Page 0. 235ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * 06-24-05 01.05.09 Added EEDP defines to IOC Page 1. 236ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added more RAID type defines to IOC Page 2. 237ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added Port Enable Delay settings to BIOS Page 1. 238ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added Bad Block Table Full define to RAID Volume Page 0. 239ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added Previous State defines to RAID Physical Disk 240ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Page 0. 241ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added Max Sata Targets define for DiscoveryStatus field 242ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * of SAS IO Unit Page 0. 243ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added Device Self Test to Control Flags of SAS IO Unit 244ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Page 1. 245ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added Direct Attach Starting Slot Number define for SAS 246ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * IO Unit Page 2. 247ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added new fields in SAS Device Page 2 for enclosure 248ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * mapping. 249ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added OwnerDevHandle and Flags field to SAS PHY Page 0. 250ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Added IOC GPIO Flags define to SAS Enclosure Page 0. 251ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig * Fixed the value for MPI_SAS_IOUNIT1_CONTROL_DEV_SATA_SUPPORT. 2524b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * 08-03-05 01.05.10 Removed ISDataScrubRate and ISResyncRate from 2534b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Manufacturing Page 4. 2544b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added MPI_IOUNITPAGE1_SATA_WRITE_CACHE_DISABLE bit. 2554b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added NumDevsPerEnclosure field to SAS IO Unit page 2. 2564b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added MPI_SAS_IOUNIT2_FLAGS_HOST_ASSIGNED_PHYS_MAP 2574b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * define. 2584b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added EnclosureHandle field to SAS Expander page 0. 2594b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Removed redundant NumTableEntriesProg field from SAS 2604b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Expander Page 1. 2614b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * 08-30-05 01.05.11 Added DeviceID for FC949E and changed the DeviceID for 2624b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * SAS1078. 2634b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added more defines for Manufacturing Page 4 Flags field. 2644b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added more defines for IOCSettings and added 2654b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * ExpanderSpinup field to Bios Page 1. 2664b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Added postpone SATA Init bit to SAS IO Unit Page 1 2674b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * ControlFlags. 2684b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric * Changed LogEntry format for Log Page 0. 2692076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * 03-27-06 01.05.12 Added two new Flags defines for Manufacturing Page 4. 2702076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added Manufacturing Page 7. 2712076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added MPI_IOCPAGE2_CAP_FLAGS_RAID_64_BIT_ADDRESSING. 2722076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added IOC Page 6. 2732076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added PrevBootDeviceForm field to CONFIG_PAGE_BIOS_2. 2742076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added MaxLBAHigh field to RAID Volume Page 0. 2752076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added Nvdata version fields to SAS IO Unit Page 0. 2762076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Added AdditionalControlFlags, MaxTargetPortConnectTime, 2772076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * ReportDeviceMissingDelay, and IODeviceMissingDelay 2782076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * fields to SAS IO Unit Page 1. 2791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * -------------------------------------------------------------------------- 2801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 2811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_CNFG_H 2831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CNFG_H 2841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/***************************************************************************** 2871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 2881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* C o n f i g M e s s a g e a n d S t r u c t u r e s 2891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 2901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds*****************************************************************************/ 2911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_HEADER 2931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageVersion; /* 00h */ 2951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageLength; /* 01h */ 2961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageNumber; /* 02h */ 2971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageType; /* 03h */ 298c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_HEADER, MPI_POINTER PTR_CONFIG_PAGE_HEADER, 2991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t, MPI_POINTER pConfigPageHeader_t; 3001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef union _CONFIG_PAGE_HEADER_UNION 3021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 3031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t Struct; 3041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bytes[4]; 3051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Word16[2]; 3061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Word32; 3071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} ConfigPageHeaderUnion, MPI_POINTER pConfigPageHeaderUnion, 308c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER_UNION, MPI_POINTER PTR_CONFIG_PAGE_HEADER_UNION; 3091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_EXTENDED_PAGE_HEADER 3111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 3121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageVersion; /* 00h */ 3131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 01h */ 3141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageNumber; /* 02h */ 3151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageType; /* 03h */ 3161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExtPageLength; /* 04h */ 3171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtPageType; /* 06h */ 3181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 07h */ 319c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_EXTENDED_PAGE_HEADER, MPI_POINTER PTR_CONFIG_EXTENDED_PAGE_HEADER, 3201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigExtendedPageHeader_t, MPI_POINTER pConfigExtendedPageHeader_t; 3211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 3251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* PageType field values 3261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 3271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_READ_ONLY (0x00) 3281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_CHANGEABLE (0x10) 3291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_PERSISTENT (0x20) 3301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_RO_PERSISTENT (0x30) 3311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_MASK (0xF0) 3321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_IO_UNIT (0x00) 3341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_IOC (0x01) 3351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_BIOS (0x02) 3361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_SCSI_PORT (0x03) 3371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_SCSI_DEVICE (0x04) 3381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_FC_PORT (0x05) 3391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_FC_DEVICE (0x06) 3401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_LAN (0x07) 3411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_RAID_VOLUME (0x08) 3421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_MANUFACTURING (0x09) 3431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_RAID_PHYSDISK (0x0A) 3441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_INBAND (0x0B) 3451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_EXTENDED (0x0F) 3461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_MASK (0x0F) 3471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_TYPENUM_MASK (0x0FFF) 3491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 3521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* ExtPageType field values 3531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 3541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_IO_UNIT (0x10) 3551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_EXPANDER (0x11) 3561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_DEVICE (0x12) 3571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_PHY (0x13) 358c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_CONFIG_EXTPAGETYPE_LOG (0x14) 359c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_CONFIG_EXTPAGETYPE_ENCLOSURE (0x15) 3601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 3631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* PageAddress field values 3641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 3651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_PORT_PGAD_PORT_MASK (0x000000FF) 3661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 367c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_FORM_MASK (0xF0000000) 368c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_FORM_BUS_TID (0x00000000) 3691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_TARGET_ID_MASK (0x000000FF) 3701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_TARGET_ID_SHIFT (0) 3711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_BUS_MASK (0x0000FF00) 3721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_BUS_SHIFT (8) 373c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_FORM_TARGET_MODE (0x10000000) 374c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_RESPOND_ID_MASK (0x000000FF) 375c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_RESPOND_ID_SHIFT (0) 376c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_BUS_MASK (0x0000FF00) 377c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_BUS_SHIFT (8) 378c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_INIT_ID_MASK (0x00FF0000) 379c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_INIT_ID_SHIFT (16) 3801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_PORT_MASK (0xF0000000) 3821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_PORT_SHIFT (28) 3831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_FORM_MASK (0x0F000000) 3841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_FORM_INDEX (0x01000000) 3851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_INDEX_MASK (0x0000FFFF) 3861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_INDEX_SHIFT (0) 3871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_PORT_MASK (0xF0000000) 3891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_PORT_SHIFT (28) 3901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_FORM_MASK (0x0F000000) 3911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_FORM_NEXT_DID (0x00000000) 3921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_PORT_MASK (0xF0000000) 3931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_PORT_SHIFT (28) 3941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_DID_MASK (0x00FFFFFF) 3951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_DID_SHIFT (0) 3961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_FORM_BUS_TID (0x01000000) 3971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_BUS_MASK (0x0000FF00) 3981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_BUS_SHIFT (8) 3991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_TID_MASK (0x000000FF) 4001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_TID_SHIFT (0) 4011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK_PGAD_PHYSDISKNUM_MASK (0x000000FF) 4031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK_PGAD_PHYSDISKNUM_SHIFT (0) 4041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 405c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_MASK (0xF0000000) 406c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_SHIFT (28) 407c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_GET_NEXT_HANDLE (0x00000000) 408c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_HANDLE_PHY_NUM (0x00000001) 409c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_HANDLE (0x00000002) 410c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_GNH_MASK_HANDLE (0x0000FFFF) 411c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_GNH_SHIFT_HANDLE (0) 412c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_MASK_PHY (0x00FF0000) 413c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_SHIFT_PHY (16) 414c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_MASK_HANDLE (0x0000FFFF) 415c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_SHIFT_HANDLE (0) 416c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_H_MASK_HANDLE (0x0000FFFF) 417c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_H_SHIFT_HANDLE (0) 418c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 4191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_MASK (0xF0000000) 4201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_SHIFT (28) 4211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_GET_NEXT_HANDLE (0x00000000) 4221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID (0x00000001) 4231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_HANDLE (0x00000002) 4241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_GNH_HANDLE_MASK (0x0000FFFF) 4251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_GNH_HANDLE_SHIFT (0) 4261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_BUS_MASK (0x0000FF00) 4271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_BUS_SHIFT (8) 4281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_TID_MASK (0x000000FF) 4291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_TID_SHIFT (0) 4301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_H_HANDLE_MASK (0x0000FFFF) 4311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_H_HANDLE_SHIFT (0) 4321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 433c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_MASK (0xF0000000) 434c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_SHIFT (28) 435c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_PHY_NUMBER (0x0) 436c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_PHY_TBL_INDEX (0x1) 437c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_NUMBER_MASK (0x000000FF) 438c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_NUMBER_SHIFT (0) 439c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_TBL_INDEX_MASK (0x0000FFFF) 440c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_TBL_INDEX_SHIFT (0) 441c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 442c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_MASK (0xF0000000) 443c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_SHIFT (28) 444c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_GET_NEXT_HANDLE (0x00000000) 445c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_HANDLE (0x00000001) 446c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_GNH_HANDLE_MASK (0x0000FFFF) 447c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_GNH_HANDLE_SHIFT (0) 448c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_H_HANDLE_MASK (0x0000FFFF) 449c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_H_HANDLE_SHIFT (0) 450c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 4511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 4541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Config Request Message 4551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 4561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MSG_CONFIG 4571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 4581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Action; /* 00h */ 4591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 01h */ 4601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChainOffset; /* 02h */ 4611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Function; /* 03h */ 4621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExtPageLength; /* 04h */ 4631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtPageType; /* 06h */ 4641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MsgFlags; /* 07h */ 4651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MsgContext; /* 08h */ 4661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2[8]; /* 0Ch */ 467c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 14h */ 4681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PageAddress; /* 18h */ 4691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SGE_IO_UNION PageBufferSGE; /* 1Ch */ 4701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MSG_CONFIG, MPI_POINTER PTR_MSG_CONFIG, 4711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Config_t, MPI_POINTER pConfig_t; 4721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 4751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Action field values 4761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 4771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_HEADER (0x00) 4781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_READ_CURRENT (0x01) 4791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_WRITE_CURRENT (0x02) 4801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_DEFAULT (0x03) 4811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_WRITE_NVRAM (0x04) 4821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_READ_DEFAULT (0x05) 4831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_READ_NVRAM (0x06) 4841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* Config Reply Message */ 4871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MSG_CONFIG_REPLY 4881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 4891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Action; /* 00h */ 4901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 01h */ 4911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MsgLength; /* 02h */ 4921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Function; /* 03h */ 4931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExtPageLength; /* 04h */ 4941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtPageType; /* 06h */ 4951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MsgFlags; /* 07h */ 4961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MsgContext; /* 08h */ 4971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2[2]; /* 0Ch */ 4981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOCStatus; /* 0Eh */ 4991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IOCLogInfo; /* 10h */ 500c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 14h */ 5011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MSG_CONFIG_REPLY, MPI_POINTER PTR_MSG_CONFIG_REPLY, 5021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigReply_t, MPI_POINTER pConfigReply_t; 5031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/***************************************************************************** 5071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 5081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* C o n f i g u r a t i o n P a g e s 5091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 5101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds*****************************************************************************/ 5111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 5131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Manufacturing Config pages 5141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 5151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_VENDORID_LSILOGIC (0x1000) 5161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* Fibre Channel */ 5171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC909 (0x0621) 5181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC919 (0x0624) 5191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC929 (0x0622) 5201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC919X (0x0628) 5211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC929X (0x0626) 522c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVICEID_FC939X (0x0642) 523c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVICEID_FC949X (0x0640) 5244b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANUFACTPAGE_DEVICEID_FC949E (0x0646) 5251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* SCSI */ 5261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1030 (0x0030) 5271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1030ZC (0x0031) 5281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_1030_53C1035 (0x0032) 5291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_1030ZC_53C1035 (0x0033) 5301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1035 (0x0040) 5311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1035ZC (0x0041) 5321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* SAS */ 5331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_SAS1064 (0x0050) 534c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1064A (0x005C) 535c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1064E (0x0056) 536c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1066 (0x005E) 537c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1066E (0x005A) 538c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1068 (0x0054) 539c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1068E (0x0058) 5404b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANUFACTPAGE_DEVID_SAS1078 (0x0062) 5411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_0 5441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 545c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 5461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChipName[16]; /* 04h */ 5471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChipRevision[8]; /* 14h */ 5481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BoardName[16]; /* 1Ch */ 5491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BoardAssembly[16]; /* 2Ch */ 5501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BoardTracerNumber[16]; /* 3Ch */ 5511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 552c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_0, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_0, 5531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage0_t, MPI_POINTER pManufacturingPage0_t; 5541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING0_PAGEVERSION (0x00) 5561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_1 5591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 560c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 5611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VPD[256]; /* 04h */ 562c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_1, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_1, 5631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage1_t, MPI_POINTER pManufacturingPage1_t; 5641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING1_PAGEVERSION (0x00) 5661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_CHIP_REVISION_ID 5691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 5701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DeviceID; /* 00h */ 5711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PCIRevisionID; /* 02h */ 5721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 03h */ 5731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_CHIP_REVISION_ID, MPI_POINTER PTR_MPI_CHIP_REVISION_ID, 5741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MpiChipRevisionId_t, MPI_POINTER pMpiChipRevisionId_t; 5751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 5781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 5791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 5801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 5811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_MAN_PAGE_2_HW_SETTINGS_WORDS 5821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MAN_PAGE_2_HW_SETTINGS_WORDS (1) 5831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 5841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_2 5861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 587c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 5881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_CHIP_REVISION_ID ChipId; /* 04h */ 5891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HwSettings[MPI_MAN_PAGE_2_HW_SETTINGS_WORDS];/* 08h */ 590c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_2, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_2, 5911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage2_t, MPI_POINTER pManufacturingPage2_t; 5921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING2_PAGEVERSION (0x00) 5941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 5971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 5981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 5991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 6001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_MAN_PAGE_3_INFO_WORDS 6011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MAN_PAGE_3_INFO_WORDS (1) 6021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 6031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_3 6051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 606c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_CHIP_REVISION_ID ChipId; /* 04h */ 6081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Info[MPI_MAN_PAGE_3_INFO_WORDS];/* 08h */ 609c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_3, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_3, 6101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage3_t, MPI_POINTER pManufacturingPage3_t; 6111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING3_PAGEVERSION (0x00) 6131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_4 6161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 617c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 04h */ 6191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoOffset0; /* 08h */ 6201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoSize0; /* 09h */ 6211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoOffset1; /* 0Ah */ 6221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoSize1; /* 0Bh */ 6231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InquirySize; /* 0Ch */ 6241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 0Dh */ 6251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 0Eh */ 6261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InquiryData[56]; /* 10h */ 6271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ISVolumeSettings; /* 48h */ 6281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IMEVolumeSettings; /* 4Ch */ 6291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IMVolumeSettings; /* 50h */ 630c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 54h */ 631c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 58h */ 6324b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 Reserved5; /* 5Ch */ 633c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMEDataScrubRate; /* 60h */ 634c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMEResyncRate; /* 61h */ 635c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved6; /* 62h */ 636c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMDataScrubRate; /* 64h */ 637c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMResyncRate; /* 65h */ 638c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved7; /* 66h */ 639c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 68h */ 640c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 6Ch */ 641c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_4, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_4, 6421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage4_t, MPI_POINTER pManufacturingPage4_t; 6431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6442076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANUFACTURING4_PAGEVERSION (0x04) 6451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* defines for the Flags field */ 6472076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE4_FORCE_BAD_BLOCK_TABLE (0x80) 6482076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE4_FORCE_OFFLINE_FAILOVER (0x40) 6494b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IME_DISABLE (0x20) 6504b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IM_DISABLE (0x10) 6514b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IS_DISABLE (0x08) 6524b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IR_MODEPAGE8_DISABLE (0x04) 6534b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IM_RESYNC_CACHE_ENABLE (0x02) 6541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANPAGE4_IR_NO_MIX_SAS_SATA (0x01) 6551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_5 6581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 659c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 BaseWWID; /* 04h */ 661c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Flags; /* 0Ch */ 662c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 0Dh */ 663c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved2; /* 0Eh */ 664c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_5, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_5, 6651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage5_t, MPI_POINTER pManufacturingPage5_t; 6661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 667c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTURING5_PAGEVERSION (0x01) 668c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 669c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* defines for the Flags field */ 670c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANPAGE5_TWO_WWID_PER_PHY (0x01) 6711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_6 6741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 675c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ProductSpecificInfo;/* 04h */ 677c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_6, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_6, 6781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage6_t, MPI_POINTER pManufacturingPage6_t; 6791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING6_PAGEVERSION (0x00) 6811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6832076eb6ab8339bf09620a0160be3607bbbb61a50Eric Mooretypedef struct _MPI_MANPAGE7_CONNECTOR_INFO 6842076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore{ 6852076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Pinout; /* 00h */ 6862076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Connector[16]; /* 04h */ 6872076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Location; /* 14h */ 6882076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved1; /* 15h */ 6892076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Slot; /* 16h */ 6902076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved2; /* 18h */ 6912076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore} MPI_MANPAGE7_CONNECTOR_INFO, MPI_POINTER PTR_MPI_MANPAGE7_CONNECTOR_INFO, 6922076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore MpiManPage7ConnectorInfo_t, MPI_POINTER pMpiManPage7ConnectorInfo_t; 6932076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 6942076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for the Pinout field */ 6952076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L4 (0x00080000) 6962076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L3 (0x00040000) 6972076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L2 (0x00020000) 6982076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L1 (0x00010000) 6992076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L4 (0x00000800) 7002076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L3 (0x00000400) 7012076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L2 (0x00000200) 7022076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L1 (0x00000100) 7032076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8482 (0x00000002) 7042076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_CONNECTION_UNKNOWN (0x00000001) 7052076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7062076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for the Location field */ 7072076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_UNKNOWN (0x01) 7082076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_INTERNAL (0x02) 7092076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_EXTERNAL (0x04) 7102076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_SWITCHABLE (0x08) 7112076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_AUTO (0x10) 7122076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_NOT_PRESENT (0x20) 7132076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_NOT_CONNECTED (0x80) 7142076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7152076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* 7162076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 7172076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * one and check NumPhys at runtime. 7182076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore */ 7192076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#ifndef MPI_MANPAGE7_CONNECTOR_INFO_MAX 7202076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_CONNECTOR_INFO_MAX (1) 7212076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#endif 7222076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7232076eb6ab8339bf09620a0160be3607bbbb61a50Eric Mooretypedef struct _CONFIG_PAGE_MANUFACTURING_7 7242076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore{ 7252076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 7262076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved1; /* 04h */ 7272076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved2; /* 08h */ 7282076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Flags; /* 0Ch */ 7292076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 EnclosureName[16]; /* 10h */ 7302076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 NumPhys; /* 20h */ 7312076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved3; /* 21h */ 7322076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved4; /* 22h */ 7332076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore MPI_MANPAGE7_CONNECTOR_INFO ConnectorInfo[MPI_MANPAGE7_CONNECTOR_INFO_MAX]; /* 24h */ 7342076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore} CONFIG_PAGE_MANUFACTURING_7, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_7, 7352076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore ManufacturingPage7_t, MPI_POINTER pManufacturingPage7_t; 7362076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7372076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANUFACTURING7_PAGEVERSION (0x00) 7382076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7392076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for the Flags field */ 7402076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_FLAG_USE_SLOT_INFO (0x00000001) 7412076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7422076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 7441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* IO Unit Config Pages 7451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 7461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_0 7481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 749c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 7501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 UniqueValue; /* 04h */ 751c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_0, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_0, 7521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage0_t, MPI_POINTER pIOUnitPage0_t; 7531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE0_PAGEVERSION (0x00) 7551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_1 7581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 759c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 7601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 761c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_1, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_1, 7621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage1_t, MPI_POINTER pIOUnitPage1_t; 7631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7644b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_IOUNITPAGE1_PAGEVERSION (0x02) 7651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IO Unit Page 1 Flags defines */ 7671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_MULTI_FUNCTION (0x00000000) 7681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_SINGLE_FUNCTION (0x00000001) 7691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_MULTI_PATHING (0x00000002) 7701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_SINGLE_PATHING (0x00000000) 7711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_IR_USE_STATIC_VOLUME_ID (0x00000004) 7721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_DISABLE_QUEUE_FULL_HANDLING (0x00000020) 7731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_DISABLE_IR (0x00000040) 7741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_FORCE_32 (0x00000080) 7751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_NATIVE_COMMAND_Q_DISABLE (0x00000100) 7764b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_IOUNITPAGE1_SATA_WRITE_CACHE_DISABLE (0x00000200) 7771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_ADAPTER_INFO 7791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 7801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PciBusNumber; /* 00h */ 7811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PciDeviceAndFunctionNumber; /* 01h */ 7821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 AdapterFlags; /* 02h */ 7831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_ADAPTER_INFO, MPI_POINTER PTR_MPI_ADAPTER_INFO, 7841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MpiAdapterInfo_t, MPI_POINTER pMpiAdapterInfo_t; 7851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_ADAPTER_INFO_FLAGS_EMBEDDED (0x0001) 7871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_ADAPTER_INFO_FLAGS_INIT_STATUS (0x0002) 7881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_2 7901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 791c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 7921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 7931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BiosVersion; /* 08h */ 7941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_ADAPTER_INFO AdapterOrder[4]; /* 0Ch */ 795c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 1Ch */ 796c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_2, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_2, 7971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage2_t, MPI_POINTER pIOUnitPage2_t; 7981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 799c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_IOUNITPAGE2_PAGEVERSION (0x02) 8001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_PAUSE_ON_ERROR (0x00000002) 8021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_VERBOSE_ENABLE (0x00000004) 8031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_COLOR_VIDEO_DISABLE (0x00000008) 8041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_DONT_HOOK_INT_40 (0x00000010) 8051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_DEV_LIST_DISPLAY_MASK (0x000000E0) 8071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_INSTALLED_DEV_DISPLAY (0x00000000) 8081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_ADAPTER_DISPLAY (0x00000020) 8091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_ADAPTER_DEV_DISPLAY (0x00000040) 8101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 8131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 8141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 8151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 8161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IO_UNIT_PAGE_3_GPIO_VAL_MAX 8171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IO_UNIT_PAGE_3_GPIO_VAL_MAX (1) 8181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 8191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_3 8211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 822c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 8231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 GPIOCount; /* 04h */ 8241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 05h */ 8251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 06h */ 8261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 GPIOVal[MPI_IO_UNIT_PAGE_3_GPIO_VAL_MAX]; /* 08h */ 827c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_3, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_3, 8281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage3_t, MPI_POINTER pIOUnitPage3_t; 8291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_PAGEVERSION (0x01) 8311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_FUNCTION_MASK (0xFC) 8331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_FUNCTION_SHIFT (2) 8341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_SETTING_OFF (0x00) 8351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_SETTING_ON (0x01) 8361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 838c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_IO_UNIT_4 839c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 840c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 841c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 04h */ 842c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SGE_SIMPLE_UNION FWImageSGE; /* 08h */ 843c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_4, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_4, 844c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean IOUnitPage4_t, MPI_POINTER pIOUnitPage4_t; 845c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 846c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_IOUNITPAGE4_PAGEVERSION (0x00) 847c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 848c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 8491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 8501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* IOC Config Pages 8511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 8521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_0 8541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 855c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 8561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 TotalNVStore; /* 04h */ 8571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 FreeNVStore; /* 08h */ 8581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 VendorID; /* 0Ch */ 8591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DeviceID; /* 0Eh */ 8601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 RevisionID; /* 10h */ 8611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved[3]; /* 11h */ 8621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ClassCode; /* 14h */ 8631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 SubsystemVendorID; /* 18h */ 8641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 SubsystemID; /* 1Ah */ 865c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_0, MPI_POINTER PTR_CONFIG_PAGE_IOC_0, 8661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage0_t, MPI_POINTER pIOCPage0_t; 8671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE0_PAGEVERSION (0x01) 8691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_1 8721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 873c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 8741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 8751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 CoalescingTimeout; /* 08h */ 8761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CoalescingDepth; /* 0Ch */ 8771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PCISlotNum; /* 0Dh */ 8781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved[2]; /* 0Eh */ 879c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_1, MPI_POINTER PTR_CONFIG_PAGE_IOC_1, 8801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage1_t, MPI_POINTER pIOCPage1_t; 8811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 882ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_PAGEVERSION (0x03) 8831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* defines for the Flags field */ 885ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_MASK (0x07000000) 886ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_OFF (0x00000000) 887ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_T10 (0x01000000) 888ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_LSI_1 (0x02000000) 889c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_IOCPAGE1_INITIATOR_CONTEXT_REPLY_DISABLE (0x00000010) 8901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE1_REPLY_COALESCING (0x00000001) 8911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE1_PCISLOTNUM_UNKNOWN (0xFF) 8931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_2_RAID_VOL 8961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 8971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeID; /* 00h */ 8981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeBus; /* 01h */ 8991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeIOC; /* 02h */ 9001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumePageNumber; /* 03h */ 9011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeType; /* 04h */ 9021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 05h */ 9031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved3; /* 06h */ 904c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_2_RAID_VOL, MPI_POINTER PTR_CONFIG_PAGE_IOC_2_RAID_VOL, 9051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageIoc2RaidVol_t, MPI_POINTER pConfigPageIoc2RaidVol_t; 9061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 2 Volume RAID Type values, also used in RAID Volume pages */ 9081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_TYPE_IS (0x00) 9101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_TYPE_IME (0x01) 9111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_TYPE_IM (0x02) 912ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_5 (0x03) 913ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_6 (0x04) 914ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_10 (0x05) 915ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_50 (0x06) 916ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_UNKNOWN (0xFF) 9171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 2 Volume Flags values */ 9191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_FLAG_VOLUME_INACTIVE (0x08) 9211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 9231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 9241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 9251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 9261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_2_RAID_VOLUME_MAX 9271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_2_RAID_VOLUME_MAX (1) 9281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 9291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_2 9311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 932c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 9331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 CapabilitiesFlags; /* 04h */ 9341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumActiveVolumes; /* 08h */ 9351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxVolumes; /* 09h */ 9361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumActivePhysDisks; /* 0Ah */ 9371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxPhysDisks; /* 0Bh */ 938c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_IOC_2_RAID_VOL RaidVolume[MPI_IOC_PAGE_2_RAID_VOLUME_MAX];/* 0Ch */ 939c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_2, MPI_POINTER PTR_CONFIG_PAGE_IOC_2, 9401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage2_t, MPI_POINTER pIOCPage2_t; 9411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9422076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE2_PAGEVERSION (0x04) 9431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 2 Capabilities flags */ 9451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_IS_SUPPORT (0x00000001) 9471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_IME_SUPPORT (0x00000002) 9481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_IM_SUPPORT (0x00000004) 949ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_5_SUPPORT (0x00000008) 950ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_6_SUPPORT (0x00000010) 951ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_10_SUPPORT (0x00000020) 952ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_50_SUPPORT (0x00000040) 9532076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE2_CAP_FLAGS_RAID_64_BIT_ADDRESSING (0x10000000) 9541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_SES_SUPPORT (0x20000000) 9551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_SAFTE_SUPPORT (0x40000000) 9561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_CROSS_CHANNEL_SUPPORT (0x80000000) 9571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _IOC_3_PHYS_DISK 9601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 9611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskID; /* 00h */ 9621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskBus; /* 01h */ 9631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskIOC; /* 02h */ 9641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 03h */ 9651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} IOC_3_PHYS_DISK, MPI_POINTER PTR_IOC_3_PHYS_DISK, 9661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Ioc3PhysDisk_t, MPI_POINTER pIoc3PhysDisk_t; 9671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 9691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 9701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 9711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 9721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_3_PHYSDISK_MAX 9731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_3_PHYSDISK_MAX (1) 9741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 9751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_3 9771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 978c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 9791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhysDisks; /* 04h */ 9801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 05h */ 9811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 06h */ 9821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOC_3_PHYS_DISK PhysDisk[MPI_IOC_PAGE_3_PHYSDISK_MAX]; /* 08h */ 983c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_3, MPI_POINTER PTR_CONFIG_PAGE_IOC_3, 9841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage3_t, MPI_POINTER pIOCPage3_t; 9851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE3_PAGEVERSION (0x00) 9871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _IOC_4_SEP 9901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 9911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SEPTargetID; /* 00h */ 9921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SEPBus; /* 01h */ 9931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 9941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} IOC_4_SEP, MPI_POINTER PTR_IOC_4_SEP, 9951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Ioc4Sep_t, MPI_POINTER pIoc4Sep_t; 9961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 9981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 9991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 10001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 10011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_4_SEP_MAX 10021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_4_SEP_MAX (1) 10031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 10041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_4 10061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1007c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 10081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ActiveSEP; /* 04h */ 10091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxSEP; /* 05h */ 10101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved1; /* 06h */ 10111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOC_4_SEP SEP[MPI_IOC_PAGE_4_SEP_MAX]; /* 08h */ 1012c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_4, MPI_POINTER PTR_CONFIG_PAGE_IOC_4, 10131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage4_t, MPI_POINTER pIOCPage4_t; 10141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE4_PAGEVERSION (0x00) 10161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _IOC_5_HOT_SPARE 10191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 10201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 00h */ 10211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 01h */ 10221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HotSparePool; /* 02h */ 10231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 03h */ 10241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} IOC_5_HOT_SPARE, MPI_POINTER PTR_IOC_5_HOT_SPARE, 10251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Ioc5HotSpare_t, MPI_POINTER pIoc5HotSpare_t; 10261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 5 HotSpare Flags */ 10281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_5_HOT_SPARE_ACTIVE (0x01) 10291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 10311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 10321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 10331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 10341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_5_HOT_SPARE_MAX 10351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_5_HOT_SPARE_MAX (1) 10361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 10371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_5 10391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1040c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 10411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 04h */ 10421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumHotSpares; /* 08h */ 10431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 09h */ 10441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved3; /* 0Ah */ 10451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOC_5_HOT_SPARE HotSpare[MPI_IOC_PAGE_5_HOT_SPARE_MAX]; /* 0Ch */ 1046c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_5, MPI_POINTER PTR_CONFIG_PAGE_IOC_5, 10471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage5_t, MPI_POINTER pIOCPage5_t; 10481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE5_PAGEVERSION (0x00) 10501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10512076eb6ab8339bf09620a0160be3607bbbb61a50Eric Mooretypedef struct _CONFIG_PAGE_IOC_6 10522076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore{ 10532076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 10542076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 CapabilitiesFlags; /* 04h */ 10552076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxDrivesIS; /* 08h */ 10562076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxDrivesIM; /* 09h */ 10572076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxDrivesIME; /* 0Ah */ 10582076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved1; /* 0Bh */ 10592076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MinDrivesIS; /* 0Ch */ 10602076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MinDrivesIM; /* 0Dh */ 10612076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MinDrivesIME; /* 0Eh */ 10622076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved2; /* 0Fh */ 10632076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxGlobalHotSpares; /* 10h */ 10642076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved3; /* 11h */ 10652076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved4; /* 12h */ 10662076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved5; /* 14h */ 10672076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 SupportedStripeSizeMapIS; /* 18h */ 10682076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 SupportedStripeSizeMapIME; /* 1Ch */ 10692076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved6; /* 20h */ 10702076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MetadataSize; /* 24h */ 10712076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved7; /* 25h */ 10722076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved8; /* 26h */ 10732076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 MaxBadBlockTableEntries; /* 28h */ 10742076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved9; /* 2Ah */ 10752076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 IRNvsramUsage; /* 2Ch */ 10762076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved10; /* 2Eh */ 10772076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 IRNvsramVersion; /* 30h */ 10782076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved11; /* 34h */ 10792076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved12; /* 38h */ 10802076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore} CONFIG_PAGE_IOC_6, MPI_POINTER PTR_CONFIG_PAGE_IOC_6, 10812076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore IOCPage6_t, MPI_POINTER pIOCPage6_t; 10822076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 10832076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE6_PAGEVERSION (0x00) 10842076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 10852076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* IOC Page 6 Capabilities Flags */ 10862076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 10872076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE6_CAP_FLAGS_GLOBAL_HOT_SPARE (0x00000001) 10882076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 10891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 1091c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* BIOS Config Pages 10921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 10931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_BIOS_1 10951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1096c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 10971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BiosOptions; /* 04h */ 10981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IOCSettings; /* 08h */ 10991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 0Ch */ 11001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DeviceSettings; /* 10h */ 11011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 NumberOfDevices; /* 14h */ 11024b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 ExpanderSpinup; /* 16h */ 11034b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 Reserved2; /* 17h */ 11041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutBlockDevicesNonRM; /* 18h */ 11051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutSequential; /* 1Ah */ 11061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutOther; /* 1Ch */ 11071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutBlockDevicesRM; /* 1Eh */ 1108c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_BIOS_1, MPI_POINTER PTR_CONFIG_PAGE_BIOS_1, 11091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds BIOSPage1_t, MPI_POINTER pBIOSPage1_t; 11101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11114b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_PAGEVERSION (0x03) 11121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for the BiosOptions field */ 11141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_SPI_ENABLE (0x00000400) 11151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_FC_ENABLE (0x00000200) 11161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_SAS_ENABLE (0x00000100) 11171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_DISABLE_BIOS (0x00000001) 11181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for the IOCSettings field */ 11204b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_MASK_INITIAL_SPINUP_DELAY (0x0F000000) 11214b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_SHIFT_INITIAL_SPINUP_DELAY (24) 11224b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 1123ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_BIOSPAGE1_IOCSET_MASK_PORT_ENABLE_DELAY (0x00F00000) 1124ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_BIOSPAGE1_IOCSET_SHIFT_PORT_ENABLE_DELAY (20) 11254b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 11264b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_AUTO_PORT_ENABLE (0x00080000) 11274b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_DIRECT_ATTACH_SPINUP_MODE (0x00040000) 11284b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 1129c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_MASK_BOOT_PREFERENCE (0x00030000) 1130c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_ENCLOSURE_SLOT_BOOT (0x00000000) 1131c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_SAS_ADDRESS_BOOT (0x00010000) 1132c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1133c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_MASK_MAX_TARGET_SPIN_UP (0x0000F000) 1134c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_SHIFT_MAX_TARGET_SPIN_UP (12) 1135c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 11361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MASK_SPINUP_DELAY (0x00000F00) 11371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_SHIFT_SPINUP_DELAY (8) 11381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MASK_RM_SETTING (0x000000C0) 11401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_NONE_RM_SETTING (0x00000000) 11411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_BOOT_RM_SETTING (0x00000040) 11421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MEDIA_RM_SETTING (0x00000080) 11431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MASK_ADAPTER_SUPPORT (0x00000030) 11451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_NO_SUPPORT (0x00000000) 11461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_BIOS_SUPPORT (0x00000010) 11471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_OS_SUPPORT (0x00000020) 11481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_ALL_SUPPORT (0x00000030) 11491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_ALTERNATE_CHS (0x00000008) 11511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for the DeviceSettings field */ 11531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_SEQ_LUN (0x00000008) 11541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_RM_LUN (0x00000004) 11551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_NON_RM_LUN (0x00000002) 11561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_OTHER_LUN (0x00000001) 11571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11584b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric/* defines for the ExpanderSpinup field */ 11594b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_EXPSPINUP_MASK_MAX_TARGET (0xF0) 11604b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_EXPSPINUP_SHIFT_MAX_TARGET (4) 11614b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_EXPSPINUP_MASK_DELAY (0x0F) 11624b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 1163c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_ADAPTER_ORDER 1164c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1165c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 00h */ 1166c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 04h */ 1167c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 08h */ 1168c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 0Ch */ 1169c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 10h */ 1170c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 14h */ 1171c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 18h */ 1172c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 1Ch */ 1173c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 20h */ 1174c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 24h */ 1175c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 28h */ 1176c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 2Ch */ 1177c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 30h */ 1178c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 34h */ 1179c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved15; /* 38h */ 1180c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved16; /* 3Ch */ 1181c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved17; /* 40h */ 1182c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_ADAPTER_ORDER, MPI_POINTER PTR_MPI_BOOT_DEVICE_ADAPTER_ORDER; 1183c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1184c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_ADAPTER_NUMBER 1185c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1186c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 TargetID; /* 00h */ 1187c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Bus; /* 01h */ 1188c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 AdapterNumber; /* 02h */ 1189c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 03h */ 1190c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 04h */ 1191c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 08h */ 1192c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 0Ch */ 1193c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1194c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 18h */ 1195c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 1Ch */ 1196c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 20h */ 1197c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 24h */ 1198c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 28h */ 1199c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 2Ch */ 1200c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 30h */ 1201c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 34h */ 1202c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 38h */ 1203c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 3Ch */ 1204c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved15; /* 40h */ 1205c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_ADAPTER_NUMBER, MPI_POINTER PTR_MPI_BOOT_DEVICE_ADAPTER_NUMBER; 1206c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1207c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_PCI_ADDRESS 1208c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1209c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 TargetID; /* 00h */ 1210c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Bus; /* 01h */ 1211c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 PCIAddress; /* 02h */ 1212c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 04h */ 1213c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 08h */ 1214c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 0Ch */ 1215c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1216c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 18h */ 1217c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 1Ch */ 1218c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 20h */ 1219c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 24h */ 1220c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 28h */ 1221c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 2Ch */ 1222c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 30h */ 1223c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 34h */ 1224c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 38h */ 1225c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 3Ch */ 1226c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 40h */ 1227c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_PCI_ADDRESS, MPI_POINTER PTR_MPI_BOOT_DEVICE_PCI_ADDRESS; 1228c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1229c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_SLOT_NUMBER 1230c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1231c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 TargetID; /* 00h */ 1232c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Bus; /* 01h */ 1233c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PCISlotNumber; /* 02h */ 1234c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 03h */ 1235c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 04h */ 1236c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 08h */ 1237c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 0Ch */ 1238c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1239c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 18h */ 1240c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 1Ch */ 1241c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 20h */ 1242c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 24h */ 1243c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 28h */ 1244c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 2Ch */ 1245c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 30h */ 1246c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 34h */ 1247c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 38h */ 1248c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 3Ch */ 1249c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved15; /* 40h */ 1250c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_PCI_SLOT_NUMBER, MPI_POINTER PTR_MPI_BOOT_DEVICE_PCI_SLOT_NUMBER; 1251c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1252c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_FC_WWN 1253c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1254c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 WWPN; /* 00h */ 1255c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 1256c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 1257c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1258c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 18h */ 1259c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 1Ch */ 1260c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 20h */ 1261c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 24h */ 1262c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 28h */ 1263c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 2Ch */ 1264c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 30h */ 1265c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 34h */ 1266c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 38h */ 1267c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 3Ch */ 1268c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 40h */ 1269c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_FC_WWN, MPI_POINTER PTR_MPI_BOOT_DEVICE_FC_WWN; 1270c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1271c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_SAS_WWN 1272c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1273c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 SASAddress; /* 00h */ 1274c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 1275c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 1276c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1277c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 18h */ 1278c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 1Ch */ 1279c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 20h */ 1280c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 24h */ 1281c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 28h */ 1282c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 2Ch */ 1283c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 30h */ 1284c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 34h */ 1285c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 38h */ 1286c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 3Ch */ 1287c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 40h */ 1288c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_SAS_WWN, MPI_POINTER PTR_MPI_BOOT_DEVICE_SAS_WWN; 1289c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1290c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_ENCLOSURE_SLOT 1291c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1292c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 EnclosureLogicalID; /* 00h */ 1293c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 1294c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 1295c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1296c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 SlotNumber; /* 18h */ 1297c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved3; /* 1Ah */ 1298c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 1Ch */ 1299c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 20h */ 1300c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 24h */ 1301c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 28h */ 1302c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 2Ch */ 1303c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 30h */ 1304c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 34h */ 1305c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 38h */ 1306c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 3Ch */ 1307c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 40h */ 1308c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_ENCLOSURE_SLOT, 1309c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_POINTER PTR_MPI_BOOT_DEVICE_ENCLOSURE_SLOT; 1310c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1311c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef union _MPI_BIOSPAGE2_BOOT_DEVICE 1312c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1313c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_ADAPTER_ORDER AdapterOrder; 1314c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_ADAPTER_NUMBER AdapterNumber; 1315c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_PCI_ADDRESS PCIAddress; 1316c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_PCI_SLOT_NUMBER PCISlotNumber; 1317c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_FC_WWN FcWwn; 1318c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_SAS_WWN SasWwn; 1319c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_ENCLOSURE_SLOT EnclosureSlot; 1320c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BIOSPAGE2_BOOT_DEVICE, MPI_POINTER PTR_MPI_BIOSPAGE2_BOOT_DEVICE; 1321c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1322c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_BIOS_2 1323c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1324c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 1325c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 04h */ 1326c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 08h */ 1327c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 0Ch */ 1328c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 10h */ 1329c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 14h */ 1330c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 18h */ 1331c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 BootDeviceForm; /* 1Ch */ 13322076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 PrevBootDeviceForm; /* 1Ch */ 1333c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved8; /* 1Eh */ 1334c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BIOSPAGE2_BOOT_DEVICE BootDevice; /* 20h */ 1335c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_BIOS_2, MPI_POINTER PTR_CONFIG_PAGE_BIOS_2, 1336c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean BIOSPage2_t, MPI_POINTER pBIOSPage2_t; 1337c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 13382076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_BIOSPAGE2_PAGEVERSION (0x02) 1339c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1340c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_MASK (0x0F) 1341c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_ADAPTER_ORDER (0x00) 1342c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_ADAPTER_NUMBER (0x01) 1343c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_PCI_ADDRESS (0x02) 1344c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_PCI_SLOT_NUMBER (0x03) 1345c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_FC_WWN (0x04) 1346c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_SAS_WWN (0x05) 1347ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_BIOSPAGE2_FORM_ENCLOSURE_SLOT (0x06) 1348c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 13491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 13501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 13511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* SCSI Port Config Pages 13521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 13531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 13541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_PORT_0 13551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1356c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 13571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Capabilities; /* 04h */ 13581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhysicalInterface; /* 08h */ 1359c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_PORT_0, MPI_POINTER PTR_CONFIG_PAGE_SCSI_PORT_0, 13601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIPortPage0_t, MPI_POINTER pSCSIPortPage0_t; 13611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 1362c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIPORTPAGE0_PAGEVERSION (0x02) 13631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 13641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_IU (0x00000001) 13651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_DT (0x00000002) 13661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_QAS (0x00000004) 13671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_MIN_SYNC_PERIOD_MASK (0x0000FF00) 13681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_ASYNC (0x00) 13691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_5 (0x32) 13701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_10 (0x19) 13711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_20 (0x0C) 13721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_33_33 (0x0B) 13731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_40 (0x0A) 13741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_80 (0x09) 13751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_160 (0x08) 13761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_UNKNOWN (0xFF) 13771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 13781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_SHIFT_MIN_SYNC_PERIOD (8) 13791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_GET_MIN_SYNC_PERIOD(Cap) \ 13804b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric ( ((Cap) & MPI_SCSIPORTPAGE0_CAP_MIN_SYNC_PERIOD_MASK) \ 13811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds >> MPI_SCSIPORTPAGE0_CAP_SHIFT_MIN_SYNC_PERIOD \ 13821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ) 13831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_MAX_SYNC_OFFSET_MASK (0x00FF0000) 13841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_SHIFT_MAX_SYNC_OFFSET (16) 13851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_GET_MAX_SYNC_OFFSET(Cap) \ 13864b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric ( ((Cap) & MPI_SCSIPORTPAGE0_CAP_MAX_SYNC_OFFSET_MASK) \ 13871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds >> MPI_SCSIPORTPAGE0_CAP_SHIFT_MAX_SYNC_OFFSET \ 13881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ) 1389c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIPORTPAGE0_CAP_IDP (0x08000000) 13901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_WIDE (0x20000000) 13911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_AIP (0x80000000) 13921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 13931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_TYPE_MASK (0x00000003) 13941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_HVD (0x01) 13951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_SE (0x02) 13961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_LVD (0x03) 13971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_MASK_CONNECTED_ID (0xFF000000) 13981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SHIFT_CONNECTED_ID (24) 13991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_BUS_FREE_CONNECTED_ID (0xFE) 14001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_UNKNOWN_CONNECTED_ID (0xFF) 14011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_PORT_1 14041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1405c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 14061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Configuration; /* 04h */ 14071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 OnBusTimerValue; /* 08h */ 14081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetConfig; /* 0Ch */ 14091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 0Dh */ 14101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IDConfig; /* 0Eh */ 1411c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_PORT_1, MPI_POINTER PTR_CONFIG_PAGE_SCSI_PORT_1, 14121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIPortPage1_t, MPI_POINTER pSCSIPortPage1_t; 14131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_PAGEVERSION (0x03) 14151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* Configuration values */ 14171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_CFG_PORT_SCSI_ID_MASK (0x000000FF) 14181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_CFG_PORT_RESPONSE_ID_MASK (0xFFFF0000) 14191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_CFG_SHIFT_PORT_RESPONSE_ID (16) 14201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* TargetConfig values */ 14221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_TARGCONFIG_TARG_ONLY (0x01) 14231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_TARGCONFIG_INIT_TARG (0x02) 14241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_DEVICE_INFO 14271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 14281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Timeout; /* 00h */ 14291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SyncFactor; /* 01h */ 14301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DeviceFlags; /* 02h */ 14311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_DEVICE_INFO, MPI_POINTER PTR_MPI_DEVICE_INFO, 14321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MpiDeviceInfo_t, MPI_POINTER pMpiDeviceInfo_t; 14331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_PORT_2 14351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1436c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 14371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortFlags; /* 04h */ 14381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortSettings; /* 08h */ 14391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_DEVICE_INFO DeviceSettings[16]; /* 0Ch */ 1440c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_PORT_2, MPI_POINTER PTR_CONFIG_PAGE_SCSI_PORT_2, 14411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIPortPage2_t, MPI_POINTER pSCSIPortPage2_t; 14421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PAGEVERSION (0x02) 14441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* PortFlags values */ 14461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_SCAN_HIGH_TO_LOW (0x00000001) 14471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_AVOID_SCSI_RESET (0x00000004) 14481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_ALTERNATE_CHS (0x00000008) 14491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_TERMINATION_DISABLE (0x00000010) 14501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_DV_MASK (0x00000060) 14521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_FULL_DV (0x00000000) 14531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_BASIC_DV_ONLY (0x00000020) 14541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_OFF_DV (0x00000060) 14551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* PortSettings values */ 14581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_HOST_ID_MASK (0x0000000F) 14591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_MASK_INIT_HBA (0x00000030) 14601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_DISABLE_INIT_HBA (0x00000000) 14611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_BIOS_INIT_HBA (0x00000010) 14621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_OS_INIT_HBA (0x00000020) 14631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_BIOS_OS_INIT_HBA (0x00000030) 14641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_REMOVABLE_MEDIA (0x000000C0) 14651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_RM_NONE (0x00000000) 14661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_RM_BOOT_ONLY (0x00000040) 14671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_RM_WITH_MEDIA (0x00000080) 14681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_SPINUP_DELAY_MASK (0x00000F00) 14691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_SHIFT_SPINUP_DELAY (8) 14701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_MASK_NEGO_MASTER_SETTINGS (0x00003000) 14711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_NEGO_MASTER_SETTINGS (0x00000000) 14721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_NONE_MASTER_SETTINGS (0x00001000) 14731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_ALL_MASTER_SETTINGS (0x00003000) 14741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_DISCONNECT_ENABLE (0x0001) 14761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_ID_SCAN_ENABLE (0x0002) 14771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_LUN_SCAN_ENABLE (0x0004) 14781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_TAG_QUEUE_ENABLE (0x0008) 14791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_WIDE_DISABLE (0x0010) 14801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_BOOT_CHOICE (0x0020) 14811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 14841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* SCSI Target Device Config Pages 14851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 14861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_0 14881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1489c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 14901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NegotiatedParameters; /* 04h */ 14911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Information; /* 08h */ 1492c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_0, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_0, 14931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage0_t, MPI_POINTER pSCSIDevicePage0_t; 14941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 1495c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE0_PAGEVERSION (0x04) 14961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_IU (0x00000001) 14981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_DT (0x00000002) 14991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_QAS (0x00000004) 15001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_HOLD_MCS (0x00000008) 15011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_WR_FLOW (0x00000010) 15021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_RD_STRM (0x00000020) 15031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_RTI (0x00000040) 15041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_PCOMP_EN (0x00000080) 15051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_NEG_SYNC_PERIOD_MASK (0x0000FF00) 15061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_SHIFT_SYNC_PERIOD (8) 15071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_NEG_SYNC_OFFSET_MASK (0x00FF0000) 15081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_SHIFT_SYNC_OFFSET (16) 1509c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE0_NP_IDP (0x08000000) 15101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_WIDE (0x20000000) 15111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_AIP (0x80000000) 15121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_PARAMS_NEGOTIATED (0x00000001) 15141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_SDTR_REJECTED (0x00000002) 15151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_WDTR_REJECTED (0x00000004) 15161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_PPR_REJECTED (0x00000008) 15171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_1 15201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1521c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 15221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 RequestedParameters; /* 04h */ 15231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 08h */ 15241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Configuration; /* 0Ch */ 1525c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_1, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_1, 15261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage1_t, MPI_POINTER pSCSIDevicePage1_t; 15271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 1528c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE1_PAGEVERSION (0x05) 15291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_IU (0x00000001) 15311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_DT (0x00000002) 15321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_QAS (0x00000004) 15331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_HOLD_MCS (0x00000008) 15341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_WR_FLOW (0x00000010) 15351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_RD_STRM (0x00000020) 15361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_RTI (0x00000040) 15371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_PCOMP_EN (0x00000080) 15381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_MIN_SYNC_PERIOD_MASK (0x0000FF00) 15391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_SHIFT_MIN_SYNC_PERIOD (8) 15401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_MAX_SYNC_OFFSET_MASK (0x00FF0000) 15411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_SHIFT_MAX_SYNC_OFFSET (16) 1542c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE1_RP_IDP (0x08000000) 15431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_WIDE (0x20000000) 15441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_AIP (0x80000000) 15451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_WDTR_DISALLOWED (0x00000002) 15471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_SDTR_DISALLOWED (0x00000004) 15481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_EXTENDED_PARAMS_ENABLE (0x00000008) 15491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_FORCE_PPR_MSG (0x00000010) 15501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_2 15531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1554c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 15551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DomainValidation; /* 04h */ 15561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ParityPipeSelect; /* 08h */ 15571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DataPipeSelect; /* 0Ch */ 1558c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_2, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_2, 15591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage2_t, MPI_POINTER pSCSIDevicePage2_t; 15601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_PAGEVERSION (0x01) 15621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_ISI_ENABLE (0x00000010) 15641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_SECONDARY_DRIVER_ENABLE (0x00000020) 15651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_SLEW_RATE_CTRL (0x00000380) 15661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_PRIM_DRIVE_STR_CTRL (0x00001C00) 15671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_SECOND_DRIVE_STR_CTRL (0x0000E000) 15681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKH_ST (0x10000000) 15691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKS_ST (0x20000000) 15701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKH_DT (0x40000000) 15711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKS_DT (0x80000000) 15721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_PPS_PPS_MASK (0x00000003) 15741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_0_PL_SELECT_MASK (0x00000003) 15761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_1_PL_SELECT_MASK (0x0000000C) 15771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_2_PL_SELECT_MASK (0x00000030) 15781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_3_PL_SELECT_MASK (0x000000C0) 15791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_4_PL_SELECT_MASK (0x00000300) 15801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_5_PL_SELECT_MASK (0x00000C00) 15811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_6_PL_SELECT_MASK (0x00003000) 15821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_7_PL_SELECT_MASK (0x0000C000) 15831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_8_PL_SELECT_MASK (0x00030000) 15841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_9_PL_SELECT_MASK (0x000C0000) 15851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_10_PL_SELECT_MASK (0x00300000) 15861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_11_PL_SELECT_MASK (0x00C00000) 15871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_12_PL_SELECT_MASK (0x03000000) 15881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_13_PL_SELECT_MASK (0x0C000000) 15891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_14_PL_SELECT_MASK (0x30000000) 15901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_15_PL_SELECT_MASK (0xC0000000) 15911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_3 15941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1595c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 15961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MsgRejectCount; /* 04h */ 15971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 PhaseErrorCount; /* 06h */ 15981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ParityErrorCount; /* 08h */ 15991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 0Ah */ 1600c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_3, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_3, 16011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage3_t, MPI_POINTER pSCSIDevicePage3_t; 16021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE3_PAGEVERSION (0x00) 16041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE3_MAX_COUNTER (0xFFFE) 16061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE3_UNSUPPORTED_COUNTER (0xFFFF) 16071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 16101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* FC Port Config Pages 16111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 16121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_0 16141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1615c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 16161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 16171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MPIPortNumber; /* 08h */ 16181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 LinkType; /* 09h */ 16191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortState; /* 0Ah */ 16201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 0Bh */ 16211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortIdentifier; /* 0Ch */ 16221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWNN; /* 10h */ 16231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWPN; /* 18h */ 16241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 SupportedServiceClass; /* 20h */ 16251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 SupportedSpeeds; /* 24h */ 16261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 CurrentSpeed; /* 28h */ 16271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxFrameSize; /* 2Ch */ 16281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 FabricWWNN; /* 30h */ 16291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 FabricWWPN; /* 38h */ 16301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DiscoveredPortsCount; /* 40h */ 16311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxInitiators; /* 44h */ 16321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxAliasesSupported; /* 48h */ 16331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxHardAliasesSupported; /* 49h */ 16341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumCurrentAliases; /* 4Ah */ 16351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 4Bh */ 1636c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_0, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_0, 16371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage0_t, MPI_POINTER pFCPortPage0_t; 16381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PAGEVERSION (0x02) 16401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_MASK (0x0000000F) 16421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_FCP_INIT (MPI_PORTFACTS_PROTOCOL_INITIATOR) 16431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_FCP_TARG (MPI_PORTFACTS_PROTOCOL_TARGET) 16441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_LAN (MPI_PORTFACTS_PROTOCOL_LAN) 16451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_LOGBUSADDR (MPI_PORTFACTS_PROTOCOL_LOGBUSADDR) 16461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ALIAS_ALPA_SUPPORTED (0x00000010) 16481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ALIAS_WWN_SUPPORTED (0x00000020) 16491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_FABRIC_WWN_VALID (0x00000040) 16501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_TYPE_MASK (0x00000F00) 16521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_NO_INIT (0x00000000) 16531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_POINT_TO_POINT (0x00000100) 16541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_PRIVATE_LOOP (0x00000200) 16551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_FABRIC_DIRECT (0x00000400) 16561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_PUBLIC_LOOP (0x00000800) 16571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_RESERVED (0x00) 16591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_OTHER (0x01) 16601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_UNKNOWN (0x02) 16611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_COPPER (0x03) 16621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_SINGLE_1300 (0x04) 16631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_SINGLE_1500 (0x05) 16641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_50_LASER_MULTI (0x06) 16651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_50_LED_MULTI (0x07) 16661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_62_LASER_MULTI (0x08) 16671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_62_LED_MULTI (0x09) 16681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_MULTI_LONG_WAVE (0x0A) 16691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_MULTI_SHORT_WAVE (0x0B) 16701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_LASER_SHORT_WAVE (0x0C) 16711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_LED_SHORT_WAVE (0x0D) 16721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_1300_LONG_WAVE (0x0E) 16731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_1500_LONG_WAVE (0x0F) 16741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_UNKNOWN (0x01) /*(SNIA)HBA_PORTSTATE_UNKNOWN 1 Unknown */ 16761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_ONLINE (0x02) /*(SNIA)HBA_PORTSTATE_ONLINE 2 Operational */ 16771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_OFFLINE (0x03) /*(SNIA)HBA_PORTSTATE_OFFLINE 3 User Offline */ 16781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_BYPASSED (0x04) /*(SNIA)HBA_PORTSTATE_BYPASSED 4 Bypassed */ 16791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_DIAGNOST (0x05) /*(SNIA)HBA_PORTSTATE_DIAGNOSTICS 5 In diagnostics mode */ 16801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_LINKDOWN (0x06) /*(SNIA)HBA_PORTSTATE_LINKDOWN 6 Link Down */ 16811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_ERROR (0x07) /*(SNIA)HBA_PORTSTATE_ERROR 7 Port Error */ 16821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_LOOPBACK (0x08) /*(SNIA)HBA_PORTSTATE_LOOPBACK 8 Loopback */ 16831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_CLASS_1 (0x00000001) 16851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_CLASS_2 (0x00000002) 16861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_CLASS_3 (0x00000004) 16871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_SPEED_UKNOWN (0x00000000) /* (SNIA)HBA_PORTSPEED_UNKNOWN 0 Unknown - transceiver incapable of reporting */ 16891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_1GBIT_SPEED (0x00000001) /* (SNIA)HBA_PORTSPEED_1GBIT 1 1 GBit/sec */ 16901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_2GBIT_SPEED (0x00000002) /* (SNIA)HBA_PORTSPEED_2GBIT 2 2 GBit/sec */ 16911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_10GBIT_SPEED (0x00000004) /* (SNIA)HBA_PORTSPEED_10GBIT 4 10 GBit/sec */ 16921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_4GBIT_SPEED (0x00000008) /* (SNIA)HBA_PORTSPEED_4GBIT 8 4 GBit/sec */ 16931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_UKNOWN MPI_FCPORTPAGE0_SUPPORT_SPEED_UKNOWN 16951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_1GBIT MPI_FCPORTPAGE0_SUPPORT_1GBIT_SPEED 16961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_2GBIT MPI_FCPORTPAGE0_SUPPORT_2GBIT_SPEED 16971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_10GBIT MPI_FCPORTPAGE0_SUPPORT_10GBIT_SPEED 16981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_4GBIT MPI_FCPORTPAGE0_SUPPORT_4GBIT_SPEED 16991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_NOT_NEGOTIATED (0x00008000) /* (SNIA)HBA_PORTSPEED_NOT_NEGOTIATED (1<<15) Speed not established */ 17001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_1 17031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1704c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 17051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 17061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 NoSEEPROMWWNN; /* 08h */ 17071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 NoSEEPROMWWPN; /* 10h */ 17081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HardALPA; /* 18h */ 17091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 LinkConfig; /* 19h */ 17101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TopologyConfig; /* 1Ah */ 17111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 AltConnector; /* 1Bh */ 17121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumRequestedAliases; /* 1Ch */ 17131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 RR_TOV; /* 1Dh */ 17141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InitiatorDeviceTimeout; /* 1Eh */ 17151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InitiatorIoPendTimeout; /* 1Fh */ 1716c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_1, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_1, 17171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage1_t, MPI_POINTER pFCPortPage1_t; 17181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_PAGEVERSION (0x06) 17201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_EXT_FCP_STATUS_EN (0x08000000) 17221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_IMMEDIATE_ERROR_REPLY (0x04000000) 17231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_FORCE_USE_NOSEEPROM_WWNS (0x02000000) 17241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_VERBOSE_RESCAN_EVENTS (0x01000000) 17251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_TARGET_MODE_OXID (0x00800000) 17261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PORT_OFFLINE (0x00400000) 17271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SOFT_ALPA_FALLBACK (0x00200000) 1728c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_FCPORTPAGE1_FLAGS_TARGET_LARGE_CDB_ENABLE (0x00000080) 17291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_MASK_RR_TOV_UNITS (0x00000070) 17301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SUPPRESS_PROT_REG (0x00000008) 17311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PLOGI_ON_LOGO (0x00000004) 17321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_MAINTAIN_LOGINS (0x00000002) 17331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SORT_BY_DID (0x00000001) 17341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SORT_BY_WWN (0x00000000) 17351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_MASK (0xF0000000) 17371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT (28) 17381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_FCP_INIT ((U32)MPI_PORTFACTS_PROTOCOL_INITIATOR << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 17391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_FCP_TARG ((U32)MPI_PORTFACTS_PROTOCOL_TARGET << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 17401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_LAN ((U32)MPI_PORTFACTS_PROTOCOL_LAN << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 17411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_LOGBUSADDR ((U32)MPI_PORTFACTS_PROTOCOL_LOGBUSADDR << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 17421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_NONE_RR_TOV_UNITS (0x00000000) 17441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_THOUSANDTH_RR_TOV_UNITS (0x00000010) 17451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_TENTH_RR_TOV_UNITS (0x00000030) 17461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_TEN_RR_TOV_UNITS (0x00000050) 17471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_HARD_ALPA_NOT_USED (0xFF) 17491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_MASK (0x0F) 17511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_1GIG (0x00) 17521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_2GIG (0x01) 17531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_4GIG (0x02) 17541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_10GIG (0x03) 17551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_AUTO (0x0F) 17561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_MASK (0x0F) 17581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_NLPORT (0x01) 17591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_NPORT (0x02) 17601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_AUTO (0x0F) 17611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_ALT_CONN_UNKNOWN (0x00) 17631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_INITIATOR_DEV_TIMEOUT_MASK (0x7F) 1765c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_FCPORTPAGE1_INITIATOR_DEV_UNIT_16 (0x80) 17661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_2 17691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1770c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 17711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumberActive; /* 04h */ 17721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ALPA[127]; /* 05h */ 1773c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_2, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_2, 17741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage2_t, MPI_POINTER pFCPortPage2_t; 17751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE2_PAGEVERSION (0x01) 17771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _WWN_FORMAT 17801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 17811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWNN; /* 00h */ 17821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWPN; /* 08h */ 17831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} WWN_FORMAT, MPI_POINTER PTR_WWN_FORMAT, 17841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds WWNFormat, MPI_POINTER pWWNFormat; 17851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef union _FC_PORT_PERSISTENT_PHYSICAL_ID 17871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 17881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds WWN_FORMAT WWN; 17891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Did; 17901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} FC_PORT_PERSISTENT_PHYSICAL_ID, MPI_POINTER PTR_FC_PORT_PERSISTENT_PHYSICAL_ID, 17911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds PersistentPhysicalId_t, MPI_POINTER pPersistentPhysicalId_t; 17921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _FC_PORT_PERSISTENT 17941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 17951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FC_PORT_PERSISTENT_PHYSICAL_ID PhysicalIdentifier; /* 00h */ 17961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetID; /* 10h */ 17971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bus; /* 11h */ 17981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Flags; /* 12h */ 17991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} FC_PORT_PERSISTENT, MPI_POINTER PTR_FC_PORT_PERSISTENT, 18001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds PersistentData_t, MPI_POINTER pPersistentData_t; 18011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_SHIFT (16) 18031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_ENTRY_VALID (0x0001) 18041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_SCAN_ID (0x0002) 18051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_SCAN_LUNS (0x0004) 18061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_BOOT_DEVICE (0x0008) 18071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_BY_DID (0x0080) 18081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 18101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 18111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 18121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 18131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_FC_PORT_PAGE_3_ENTRY_MAX 18141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PAGE_3_ENTRY_MAX (1) 18151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 18161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_3 18181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1819c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 18201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FC_PORT_PERSISTENT Entry[MPI_FC_PORT_PAGE_3_ENTRY_MAX]; /* 04h */ 1821c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_3, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_3, 18221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage3_t, MPI_POINTER pFCPortPage3_t; 18231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE3_PAGEVERSION (0x01) 18251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_4 18281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1829c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 18301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortFlags; /* 04h */ 18311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortSettings; /* 08h */ 1832c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_4, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_4, 18331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage4_t, MPI_POINTER pFCPortPage4_t; 18341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PAGEVERSION (0x00) 18361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_FLAGS_ALTERNATE_CHS (0x00000008) 18381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_MASK_INIT_HBA (0x00000030) 18401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_DISABLE_INIT_HBA (0x00000000) 18411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_BIOS_INIT_HBA (0x00000010) 18421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_OS_INIT_HBA (0x00000020) 18431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_BIOS_OS_INIT_HBA (0x00000030) 18441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_REMOVABLE_MEDIA (0x000000C0) 18451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_SPINUP_DELAY_MASK (0x00000F00) 18461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_5_ALIAS_INFO 18491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 18501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 00h */ 18511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 AliasAlpa; /* 01h */ 18521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 18531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 AliasWWNN; /* 04h */ 18541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 AliasWWPN; /* 0Ch */ 1855c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_5_ALIAS_INFO, 18561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_5_ALIAS_INFO, 18571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FcPortPage5AliasInfo_t, MPI_POINTER pFcPortPage5AliasInfo_t; 18581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_5 18601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1861c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 1862c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_FC_PORT_5_ALIAS_INFO AliasInfo; /* 04h */ 1863c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_5, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_5, 18641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage5_t, MPI_POINTER pFCPortPage5_t; 18651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_PAGEVERSION (0x02) 18671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_ALPA_ACQUIRED (0x01) 18691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_HARD_ALPA (0x02) 18701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_HARD_WWNN (0x04) 18711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_HARD_WWPN (0x08) 18721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_DISABLE (0x10) 18731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_6 18751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1876c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 18771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 04h */ 18781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 TimeSinceReset; /* 08h */ 18791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 TxFrames; /* 10h */ 18801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 RxFrames; /* 18h */ 18811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 TxWords; /* 20h */ 18821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 RxWords; /* 28h */ 18831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LipCount; /* 30h */ 18841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 NosCount; /* 38h */ 18851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 ErrorFrames; /* 40h */ 18861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 DumpedFrames; /* 48h */ 18871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LinkFailureCount; /* 50h */ 18881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LossOfSyncCount; /* 58h */ 18891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LossOfSignalCount; /* 60h */ 18901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 PrimativeSeqErrCount; /* 68h */ 18911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 InvalidTxWordCount; /* 70h */ 18921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 InvalidCrcCount; /* 78h */ 18931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 FcpInitiatorIoCount; /* 80h */ 1894c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_6, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_6, 18951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage6_t, MPI_POINTER pFCPortPage6_t; 18961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE6_PAGEVERSION (0x00) 18981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_7 19011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1902c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 19031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 04h */ 19041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortSymbolicName[256]; /* 08h */ 1905c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_7, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_7, 19061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage7_t, MPI_POINTER pFCPortPage7_t; 19071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE7_PAGEVERSION (0x00) 19091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_8 19121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1913c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 19141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BitVector[8]; /* 04h */ 1915c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_8, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_8, 19161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage8_t, MPI_POINTER pFCPortPage8_t; 19171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE8_PAGEVERSION (0x00) 19191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_9 19221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1923c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 19241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 04h */ 19251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 GlobalWWPN; /* 08h */ 19261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 GlobalWWNN; /* 10h */ 19271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 UnitType; /* 18h */ 19281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhysicalPortNumber; /* 1Ch */ 19291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NumAttachedNodes; /* 20h */ 19301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IPVersion; /* 24h */ 19311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 UDPPortNumber; /* 26h */ 19321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 IPAddress[16]; /* 28h */ 19331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved1; /* 38h */ 19341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 TopologyDiscoveryFlags; /* 3Ah */ 1935c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_9, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_9, 19361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage9_t, MPI_POINTER pFCPortPage9_t; 19371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE9_PAGEVERSION (0x00) 19391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA 19421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 19431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Id; /* 10h */ 19441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtId; /* 11h */ 19451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Connector; /* 12h */ 19461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Transceiver[8]; /* 13h */ 19471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Encoding; /* 1Bh */ 19481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BitRate_100mbs; /* 1Ch */ 19491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 1Dh */ 19501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length9u_km; /* 1Eh */ 19511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length9u_100m; /* 1Fh */ 19521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length50u_10m; /* 20h */ 19531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length62p5u_10m; /* 21h */ 19541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 LengthCopper_m; /* 22h */ 19551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reseverved2; /* 22h */ 19561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorName[16]; /* 24h */ 19571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved3; /* 34h */ 19581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorOUI[3]; /* 35h */ 19591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorPN[16]; /* 38h */ 19601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorRev[4]; /* 48h */ 1961c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Wavelength; /* 4Ch */ 1962c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved4; /* 4Eh */ 19631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CC_BASE; /* 4Fh */ 1964c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA, 19651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA, 19661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage10BaseSfpData_t, MPI_POINTER pFCPortPage10BaseSfpData_t; 19671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_UNKNOWN (0x00) 19691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_GBIC (0x01) 19701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_FIXED (0x02) 19711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_SFP (0x03) 19721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_SFP_MIN (0x04) 19731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_SFP_MAX (0x7F) 19741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_VEND_SPEC_MASK (0x80) 19751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_UNKNOWN (0x00) 19771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF1 (0x01) 19781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF2 (0x02) 19791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF3 (0x03) 19801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_SEEPROM (0x04) 19811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF5 (0x05) 19821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF6 (0x06) 19831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF7 (0x07) 19841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_VNDSPC_MASK (0x80) 19851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_UNKNOWN (0x00) 19871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_SC (0x01) 19881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_COPPER1 (0x02) 19891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_COPPER2 (0x03) 19901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_BNC_TNC (0x04) 19911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_COAXIAL (0x05) 19921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_FIBERJACK (0x06) 19931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_LC (0x07) 19941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_MT_RJ (0x08) 19951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_MU (0x09) 19961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_SG (0x0A) 19971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_OPT_PIGT (0x0B) 19981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV1_MIN (0x0C) 19991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV1_MAX (0x1F) 20001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_HSSDC_II (0x20) 20011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_CPR_PIGT (0x21) 20021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV2_MIN (0x22) 20031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV2_MAX (0x7F) 20041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_VNDSPC_MASK (0x80) 20051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_UNSPEC (0x00) 20071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_8B10B (0x01) 20081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_4B5B (0x02) 20091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_NRZ (0x03) 20101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_MANCHESTER (0x04) 20111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA 20141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 20151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Options[2]; /* 50h */ 20161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BitRateMax; /* 52h */ 20171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BitRateMin; /* 53h */ 20181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorSN[16]; /* 54h */ 20191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 DateCode[8]; /* 64h */ 2020c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 DiagMonitoringType; /* 6Ch */ 2021c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 EnhancedOptions; /* 6Dh */ 2022c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SFF8472Compliance; /* 6Eh */ 20231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CC_EXT; /* 6Fh */ 2024c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA, 20251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA, 20261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage10ExtendedSfpData_t, MPI_POINTER pFCPortPage10ExtendedSfpData_t; 20271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_RATESEL (0x20) 20291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_TX_DISABLE (0x10) 20301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_TX_FAULT (0x08) 20311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_LOS_INVERT (0x04) 20321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_LOS (0x02) 20331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_10 20361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2037c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 20381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 04h */ 20391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 05h */ 20401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 06h */ 20411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HwConfig1; /* 08h */ 20421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HwConfig2; /* 0Ch */ 2043c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA Base; /* 10h */ 2044c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA Extended; /* 50h */ 20451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorSpecific[32]; /* 70h */ 2046c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_10, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_10, 20471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage10_t, MPI_POINTER pFCPortPage10_t; 20481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2049c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_FCPORTPAGE10_PAGEVERSION (0x01) 20501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* standard MODDEF pin definitions (from GBIC spec.) */ 20521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_MASK (0x00000007) 20531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF2 (0x00000001) 20541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF1 (0x00000002) 20551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF0 (0x00000004) 20561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_NOGBIC (0x00000007) 20571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_CPR_IEEE_CX (0x00000006) 20581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_COPPER (0x00000005) 20591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_OPTICAL_LW (0x00000004) 20601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_SEEPROM (0x00000003) 20611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_SW_OPTICAL (0x00000002) 20621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_LX_IEEE_OPT_LW (0x00000001) 20631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_SX_IEEE_OPT_SW (0x00000000) 20641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_CC_BASE_OK (0x00000010) 20661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_CC_EXT_OK (0x00000020) 20671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 20701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* FC Device Config Pages 20711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 20721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_DEVICE_0 20741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2075c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 20761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWNN; /* 04h */ 20771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWPN; /* 0Ch */ 20781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortIdentifier; /* 14h */ 20791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Protocol; /* 18h */ 20801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 19h */ 20811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 BBCredit; /* 1Ah */ 20821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MaxRxFrameSize; /* 1Ch */ 20831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ADISCHardALPA; /* 1Eh */ 20841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortNumber; /* 1Fh */ 20851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 FcPhLowestVersion; /* 20h */ 20861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 FcPhHighestVersion; /* 21h */ 20871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CurrentTargetID; /* 22h */ 20881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CurrentBus; /* 23h */ 2089c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_DEVICE_0, MPI_POINTER PTR_CONFIG_PAGE_FC_DEVICE_0, 20901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCDevicePage0_t, MPI_POINTER pFCDevicePage0_t; 20911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PAGEVERSION (0x03) 20931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_FLAGS_TARGETID_BUS_VALID (0x01) 20951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_FLAGS_PLOGI_INVALID (0x02) 20961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_FLAGS_PRLI_INVALID (0x04) 20971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_IP (0x01) 20991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_FCP_TARGET (0x02) 21001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_FCP_INITIATOR (0x04) 21011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_FCP_RETRY (0x08) 21021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_PORT_MASK (MPI_FC_DEVICE_PGAD_PORT_MASK) 21041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_FORM_MASK (MPI_FC_DEVICE_PGAD_FORM_MASK) 21051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_FORM_NEXT_DID (MPI_FC_DEVICE_PGAD_FORM_NEXT_DID) 21061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_FORM_BUS_TID (MPI_FC_DEVICE_PGAD_FORM_BUS_TID) 21071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_DID_MASK (MPI_FC_DEVICE_PGAD_ND_DID_MASK) 21081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_BUS_MASK (MPI_FC_DEVICE_PGAD_BT_BUS_MASK) 21091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_BUS_SHIFT (MPI_FC_DEVICE_PGAD_BT_BUS_SHIFT) 21101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_TID_MASK (MPI_FC_DEVICE_PGAD_BT_TID_MASK) 21111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_HARD_ALPA_UNKNOWN (0xFF) 21131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 21151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* RAID Volume Config Pages 21161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 21171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_VOL0_PHYS_DISK 21191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 21201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 00h */ 21211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskMap; /* 02h */ 21221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 03h */ 21231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_VOL0_PHYS_DISK, MPI_POINTER PTR_RAID_VOL0_PHYS_DISK, 21241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVol0PhysDisk_t, MPI_POINTER pRaidVol0PhysDisk_t; 21251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_PHYSDISK_PRIMARY (0x01) 21271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_PHYSDISK_SECONDARY (0x02) 21281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_VOL0_STATUS 21301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 21311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 00h */ 21321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 State; /* 01h */ 21331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 21341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_VOL0_STATUS, MPI_POINTER PTR_RAID_VOL0_STATUS, 21351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVol0Status_t, MPI_POINTER pRaidVol0Status_t; 21361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume Page 0 VolumeStatus defines */ 21381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_ENABLED (0x01) 21391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_QUIESCED (0x02) 21401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_RESYNC_IN_PROGRESS (0x04) 21411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_VOLUME_INACTIVE (0x08) 2142ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAIDVOL0_STATUS_FLAG_BAD_BLOCK_TABLE_FULL (0x10) 21431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_STATE_OPTIMAL (0x00) 21451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_STATE_DEGRADED (0x01) 21461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_STATE_FAILED (0x02) 2147c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOL0_STATUS_STATE_MISSING (0x03) 21481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_VOL0_SETTINGS 21501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 21511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Settings; /* 00h */ 21521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HotSparePool; /* 01h */ /* MPI_RAID_HOT_SPARE_POOL_ */ 21531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 02h */ 21541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_VOL0_SETTINGS, MPI_POINTER PTR_RAID_VOL0_SETTINGS, 21551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVol0Settings, MPI_POINTER pRaidVol0Settings; 21561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume Page 0 VolumeSettings defines */ 21581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_WRITE_CACHING_ENABLE (0x0001) 21591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_OFFLINE_ON_SMART (0x0002) 21601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_AUTO_CONFIGURE (0x0004) 21611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_PRIORITY_RESYNC (0x0008) 2162c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOL0_SETTING_FAST_DATA_SCRUBBING_0102 (0x0020) /* obsolete */ 21631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_USE_PRODUCT_ID_SUFFIX (0x0010) 21641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_USE_DEFAULTS (0x8000) 21651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume Page 0 HotSparePool defines, also used in RAID Physical Disk */ 21671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_0 (0x01) 21681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_1 (0x02) 21691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_2 (0x04) 21701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_3 (0x08) 21711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_4 (0x10) 21721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_5 (0x20) 21731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_6 (0x40) 21741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_7 (0x80) 21751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 21771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 21781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 21791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 21801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_RAID_VOL_PAGE_0_PHYSDISK_MAX 21811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_PAGE_0_PHYSDISK_MAX (1) 21821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 21831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_RAID_VOL_0 21851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2186c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 21871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeID; /* 04h */ 21881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeBus; /* 05h */ 21891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeIOC; /* 06h */ 21901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeType; /* 07h */ /* MPI_RAID_VOL_TYPE_ */ 21911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_VOL0_STATUS VolumeStatus; /* 08h */ 21921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_VOL0_SETTINGS VolumeSettings; /* 0Ch */ 21931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxLBA; /* 10h */ 21942076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 MaxLBAHigh; /* 14h */ 21951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 StripeSize; /* 18h */ 21961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved2; /* 1Ch */ 21971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved3; /* 20h */ 21981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhysDisks; /* 24h */ 2199c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 DataScrubRate; /* 25h */ 2200c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ResyncRate; /* 26h */ 2201c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 InactiveStatus; /* 27h */ 22021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_VOL0_PHYS_DISK PhysDisk[MPI_RAID_VOL_PAGE_0_PHYSDISK_MAX];/* 28h */ 2203c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_VOL_0, MPI_POINTER PTR_CONFIG_PAGE_RAID_VOL_0, 22041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVolumePage0_t, MPI_POINTER pRaidVolumePage0_t; 22051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22062076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_RAIDVOLPAGE0_PAGEVERSION (0x06) 2207c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2208c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for RAID Volume Page 0 InactiveStatus field */ 2209c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_UNKNOWN_INACTIVE (0x00) 2210c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_STALE_METADATA_INACTIVE (0x01) 2211c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_FOREIGN_VOLUME_INACTIVE (0x02) 2212c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_INSUFFICIENT_RESOURCE_INACTIVE (0x03) 2213c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_CLONE_VOLUME_INACTIVE (0x04) 2214c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_INSUFFICIENT_METADATA_INACTIVE (0x05) 2215c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_PREVIOUSLY_DELETED (0x06) 2216c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2217c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2218c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_RAID_VOL_1 2219c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2220c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 2221c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 VolumeID; /* 01h */ 2222c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 VolumeBus; /* 02h */ 2223c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 VolumeIOC; /* 03h */ 2224c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved0; /* 04h */ 2225c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 GUID[24]; /* 05h */ 2226c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Name[32]; /* 20h */ 2227c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 WWID; /* 40h */ 2228c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 48h */ 2229c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 4Ch */ 2230c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_VOL_1, MPI_POINTER PTR_CONFIG_PAGE_RAID_VOL_1, 2231c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RaidVolumePage1_t, MPI_POINTER pRaidVolumePage1_t; 2232c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2233c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE1_PAGEVERSION (0x01) 22341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 22371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* RAID Physical Disk Config Pages 22381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 22391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK0_ERROR_DATA 22411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorCdbByte; /* 00h */ 22431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorSenseKey; /* 01h */ 22441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 22451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ErrorCount; /* 04h */ 22461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorASC; /* 06h */ 22471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorASCQ; /* 07h */ 22481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 SmartCount; /* 08h */ 22491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SmartASC; /* 0Ah */ 22501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SmartASCQ; /* 0Bh */ 22511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_ERROR_DATA, MPI_POINTER PTR_RAID_PHYS_DISK0_ERROR_DATA, 22521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDisk0ErrorData_t, MPI_POINTER pRaidPhysDisk0ErrorData_t; 22531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK_INQUIRY_DATA 22551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorID[8]; /* 00h */ 22571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ProductID[16]; /* 08h */ 22581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ProductRevLevel[4]; /* 18h */ 22591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Info[32]; /* 1Ch */ 22601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_INQUIRY_DATA, MPI_POINTER PTR_RAID_PHYS_DISK0_INQUIRY_DATA, 22611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDisk0InquiryData, MPI_POINTER pRaidPhysDisk0InquiryData; 22621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK0_SETTINGS 22641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SepID; /* 00h */ 22661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SepBus; /* 01h */ 22671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HotSparePool; /* 02h */ /* MPI_RAID_HOT_SPARE_POOL_ */ 22681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskSettings; /* 03h */ 22691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_SETTINGS, MPI_POINTER PTR_RAID_PHYS_DISK0_SETTINGS, 22701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDiskSettings_t, MPI_POINTER pRaidPhysDiskSettings_t; 22711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK0_STATUS 22731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 00h */ 22751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 State; /* 01h */ 22761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 22771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_STATUS, MPI_POINTER PTR_RAID_PHYS_DISK0_STATUS, 22781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDiskStatus_t, MPI_POINTER pRaidPhysDiskStatus_t; 22791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume 2 IM Physical Disk DiskStatus flags */ 22811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FLAG_OUT_OF_SYNC (0x01) 22831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FLAG_QUIESCED (0x02) 2284c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_PHYSDISK0_STATUS_FLAG_INACTIVE_VOLUME (0x04) 2285ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_PHYSDISK0_STATUS_FLAG_OPTIMAL_PREVIOUS (0x00) 2286ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_PHYSDISK0_STATUS_FLAG_NOT_OPTIMAL_PREVIOUS (0x08) 22871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_ONLINE (0x00) 22891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_MISSING (0x01) 22901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_NOT_COMPATIBLE (0x02) 22911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FAILED (0x03) 22921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_INITIALIZING (0x04) 22931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_OFFLINE_REQUESTED (0x05) 22941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FAILED_REQUESTED (0x06) 22951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_OTHER_OFFLINE (0xFF) 22961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_RAID_PHYS_DISK_0 22981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2299c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 23001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskID; /* 04h */ 23011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskBus; /* 05h */ 23021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskIOC; /* 06h */ 23031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 07h */ 23041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_SETTINGS PhysDiskSettings; /* 08h */ 23051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 0Ch */ 2306c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ExtDiskIdentifier[8]; /* 10h */ 23071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 DiskIdentifier[16]; /* 18h */ 23081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_INQUIRY_DATA InquiryData; /* 28h */ 23091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_STATUS PhysDiskStatus; /* 64h */ 23101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxLBA; /* 68h */ 23111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_ERROR_DATA ErrorData; /* 6Ch */ 2312c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_PHYS_DISK_0, MPI_POINTER PTR_CONFIG_PAGE_RAID_PHYS_DISK_0, 23131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDiskPage0_t, MPI_POINTER pRaidPhysDiskPage0_t; 23141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2315ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAIDPHYSDISKPAGE0_PAGEVERSION (0x02) 2316c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2317c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2318c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _RAID_PHYS_DISK1_PATH 2319c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2320c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysDiskID; /* 00h */ 2321c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysDiskBus; /* 01h */ 2322c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved1; /* 02h */ 2323c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 WWID; /* 04h */ 2324c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 OwnerWWID; /* 0Ch */ 2325c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 OwnerIdentifier; /* 14h */ 2326c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved2; /* 15h */ 2327c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Flags; /* 16h */ 2328c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} RAID_PHYS_DISK1_PATH, MPI_POINTER PTR_RAID_PHYS_DISK1_PATH, 2329c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RaidPhysDisk1Path_t, MPI_POINTER pRaidPhysDisk1Path_t; 2330c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2331c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* RAID Physical Disk Page 1 Flags field defines */ 2332c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAID_PHYSDISK1_FLAG_BROKEN (0x0002) 2333c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAID_PHYSDISK1_FLAG_INVALID (0x0001) 2334c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2335c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_RAID_PHYS_DISK_1 2336c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2337c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 2338c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NumPhysDiskPaths; /* 04h */ 2339c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysDiskNum; /* 05h */ 2340c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved2; /* 06h */ 2341c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 2342c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RAID_PHYS_DISK1_PATH Path[1]; /* 0Ch */ 2343c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_PHYS_DISK_1, MPI_POINTER PTR_CONFIG_PAGE_RAID_PHYS_DISK_1, 2344c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RaidPhysDiskPage1_t, MPI_POINTER pRaidPhysDiskPage1_t; 2345c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2346c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDPHYSDISKPAGE1_PAGEVERSION (0x00) 23471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 23501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* LAN Config Pages 23511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 23521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_LAN_0 23541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 23551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t Header; /* 00h */ 23561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 TxRxModes; /* 04h */ 23571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 06h */ 23581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PacketPrePad; /* 08h */ 2359c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_LAN_0, MPI_POINTER PTR_CONFIG_PAGE_LAN_0, 23601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds LANPage0_t, MPI_POINTER pLANPage0_t; 23611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_PAGEVERSION (0x01) 23631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_RETURN_LOOPBACK (0x0000) 23651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_SUPPRESS_LOOPBACK (0x0001) 23661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_LOOPBACK_MASK (0x0001) 23671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_LAN_1 23691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 23701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t Header; /* 00h */ 23711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 04h */ 23721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CurrentDeviceState; /* 06h */ 23731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 07h */ 23741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MinPacketSize; /* 08h */ 23751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxPacketSize; /* 0Ch */ 23761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HardwareAddressLow; /* 10h */ 23771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HardwareAddressHigh; /* 14h */ 23781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxWireSpeedLow; /* 18h */ 23791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxWireSpeedHigh; /* 1Ch */ 23801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BucketsRemaining; /* 20h */ 23811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxReplySize; /* 24h */ 23821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NegWireSpeedLow; /* 28h */ 23831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NegWireSpeedHigh; /* 2Ch */ 2384c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_LAN_1, MPI_POINTER PTR_CONFIG_PAGE_LAN_1, 23851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds LANPage1_t, MPI_POINTER pLANPage1_t; 23861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE1_PAGEVERSION (0x03) 23881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE1_DEV_STATE_RESET (0x00) 23901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE1_DEV_STATE_OPERATIONAL (0x01) 23911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 23941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Inband Config Pages 23951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 23961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_INBAND_0 23981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2399c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 24001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_VERSION_FORMAT InbandVersion; /* 04h */ 24011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MaximumBuffers; /* 08h */ 24021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved1; /* 0Ah */ 2403c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_INBAND_0, MPI_POINTER PTR_CONFIG_PAGE_INBAND_0, 24041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds InbandPage0_t, MPI_POINTER pInbandPage0_t; 24051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_INBAND_PAGEVERSION (0x00) 24071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 24111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* SAS IO Unit Config Pages 24121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 24131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_SAS_IO_UNIT0_PHY_DATA 24151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 24161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Port; /* 00h */ 24171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortFlags; /* 01h */ 24181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhyFlags; /* 02h */ 24191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NegotiatedLinkRate; /* 03h */ 24201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ControllerPhyDeviceInfo;/* 04h */ 24211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 AttachedDeviceHandle; /* 08h */ 24221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ControllerDevHandle; /* 0Ah */ 2423c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 DiscoveryStatus; /* 0Ch */ 24241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_SAS_IO_UNIT0_PHY_DATA, MPI_POINTER PTR_MPI_SAS_IO_UNIT0_PHY_DATA, 24251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnit0PhyData, MPI_POINTER pSasIOUnit0PhyData; 24261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 24281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 24291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 24301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 24311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_SAS_IOUNIT0_PHY_MAX 24321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_MAX (1) 24331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 24341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_0 24361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2437c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 24382076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 NvdataVersionDefault; /* 08h */ 24392076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 NvdataVersionPersistent; /* 0Ah */ 24401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhys; /* 0Ch */ 24411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 0Dh */ 24421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved3; /* 0Eh */ 24431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_SAS_IO_UNIT0_PHY_DATA PhyData[MPI_SAS_IOUNIT0_PHY_MAX]; /* 10h */ 2444c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_0, 24451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage0_t, MPI_POINTER pSasIOUnitPage0_t; 24461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24472076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SASIOUNITPAGE0_PAGEVERSION (0x04) 24481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 PortFlags */ 24501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_DISCOVERY_IN_PROGRESS (0x08) 24511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_0_TARGET_IOC_NUM (0x00) 24521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_1_TARGET_IOC_NUM (0x04) 24531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_AUTO_PORT_CONFIG (0x01) 24541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 PhyFlags */ 24561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_FLAGS_PHY_DISABLED (0x04) 24571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_FLAGS_TX_INVERT (0x02) 24581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_FLAGS_RX_INVERT (0x01) 24591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 NegotiatedLinkRate */ 24611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_UNKNOWN (0x00) 24621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_PHY_DISABLED (0x01) 24631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_FAILED_SPEED_NEGOTIATION (0x02) 24641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_SATA_OOB_COMPLETE (0x03) 24651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_1_5 (0x08) 24661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_3_0 (0x09) 24671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* see mpi_sas.h for values for SAS IO Unit Page 0 ControllerPhyDeviceInfo values */ 24691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2470c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS IO Unit Page 0 DiscoveryStatus */ 2471c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_LOOP_DETECTED (0x00000001) 2472c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_UNADDRESSABLE_DEVICE (0x00000002) 2473c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_MULTIPLE_PORTS (0x00000004) 2474c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_EXPANDER_ERR (0x00000008) 2475c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SMP_TIMEOUT (0x00000010) 2476c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_OUT_ROUTE_ENTRIES (0x00000020) 2477c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_INDEX_NOT_EXIST (0x00000040) 2478c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SMP_FUNCTION_FAILED (0x00000080) 2479c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SMP_CRC_ERROR (0x00000100) 2480c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SUBTRACTIVE_LINK (0x00000200) 2481c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_TABLE_LINK (0x00000400) 2482c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_UNSUPPORTED_DEVICE (0x00000800) 2483ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_IOUNIT0_DS_MAX_SATA_TARGETS (0x00001000) 2484c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 24851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_SAS_IO_UNIT1_PHY_DATA 24871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 24882076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Port; /* 00h */ 24892076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 PortFlags; /* 01h */ 24902076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 PhyFlags; /* 02h */ 24912076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxMinLinkRate; /* 03h */ 24922076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 ControllerPhyDeviceInfo; /* 04h */ 24932076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 MaxTargetPortConnectTime; /* 08h */ 24942076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved1; /* 0Ah */ 24951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_SAS_IO_UNIT1_PHY_DATA, MPI_POINTER PTR_MPI_SAS_IO_UNIT1_PHY_DATA, 24961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnit1PhyData, MPI_POINTER pSasIOUnit1PhyData; 24971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 24991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 25001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 25011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 25021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_SAS_IOUNIT1_PHY_MAX 25031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT1_PHY_MAX (1) 25041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 25051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_1 25071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2508c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2509c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 ControlFlags; /* 08h */ 2510c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 MaxNumSATATargets; /* 0Ah */ 25112076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 AdditionalControlFlags; /* 0Ch */ 25122076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved1; /* 0Eh */ 2513c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NumPhys; /* 10h */ 2514c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SATAMaxQDepth; /* 11h */ 25152076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 ReportDeviceMissingDelay; /* 12h */ 25162076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 IODeviceMissingDelay; /* 13h */ 2517c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_SAS_IO_UNIT1_PHY_DATA PhyData[MPI_SAS_IOUNIT1_PHY_MAX]; /* 14h */ 2518c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_1, 25191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage1_t, MPI_POINTER pSasIOUnitPage1_t; 25201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25212076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SASIOUNITPAGE1_PAGEVERSION (0x06) 2522c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2523c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS IO Unit Page 1 ControlFlags */ 25244b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEVICE_SELF_TEST (0x8000) 25254b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_3_0_MAX (0x4000) 25264b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_1_5_MAX (0x2000) 25274b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_SW_PRESERVE (0x1000) 25284b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DISABLE_SAS_HASH (0x0800) 25294b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 25304b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_MASK_DEV_SUPPORT (0x0600) 25314b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SHIFT_DEV_SUPPORT (9) 25324b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEV_SUPPORT_BOTH (0x00) 25334b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEV_SAS_SUPPORT (0x01) 25344b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEV_SATA_SUPPORT (0x02) 25354b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 25364b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_POSTPONE_SATA_INIT (0x0100) 25374b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_48BIT_LBA_REQUIRED (0x0080) 25384b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_SMART_REQUIRED (0x0040) 25394b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_NCQ_REQUIRED (0x0020) 25404b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_FUA_REQUIRED (0x0010) 25414b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_PHY_ENABLE_ORDER_HIGH (0x0008) 25424b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SUBTRACTIVE_ILLEGAL (0x0004) 25434b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_FIRST_LVL_DISC_ONLY (0x0002) 25444b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_CLEAR_AFFILIATION (0x0001) 2545c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 25462076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* values for SAS IO Unit Page 1 AdditionalControlFlags */ 25472076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SAS_IOUNIT1_ACONTROL_ALLOW_TABLE_TO_TABLE (0x0001) 25482076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 25492076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for SAS IO Unit Page 1 ReportDeviceMissingDelay */ 25502076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SAS_IOUNIT1_REPORT_MISSING_TIMEOUT_MASK (0x7F) 25512076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SAS_IOUNIT1_REPORT_MISSING_UNIT_16 (0x80) 25522076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 2553c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS IO Unit Page 1 PortFlags */ 25544b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PORT_FLAGS_0_TARGET_IOC_NUM (0x00) 25554b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PORT_FLAGS_1_TARGET_IOC_NUM (0x04) 25564b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PORT_FLAGS_AUTO_PORT_CONFIG (0x01) 25571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 PhyFlags */ 25594b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PHY_FLAGS_PHY_DISABLE (0x04) 25604b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PHY_FLAGS_TX_INVERT (0x02) 25614b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PHY_FLAGS_RX_INVERT (0x01) 25621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 MaxMinLinkRate */ 25644b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MAX_RATE_MASK (0xF0) 25654b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MAX_RATE_1_5 (0x80) 25664b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MAX_RATE_3_0 (0x90) 25674b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MIN_RATE_MASK (0x0F) 25684b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MIN_RATE_1_5 (0x08) 25694b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MIN_RATE_3_0 (0x09) 25701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* see mpi_sas.h for values for SAS IO Unit Page 1 ControllerPhyDeviceInfo values */ 25721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_2 25751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2576c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 25774b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 NumDevsPerEnclosure; /* 08h */ 25784b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 Reserved1; /* 09h */ 25794b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 Reserved2; /* 0Ah */ 25801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MaxPersistentIDs; /* 0Ch */ 25811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 NumPersistentIDsUsed; /* 0Eh */ 25821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Status; /* 10h */ 25831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 11h */ 25844b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 MaxNumPhysicalMappedIDs;/* 12h */ 2585c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_2, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_2, 25861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage2_t, MPI_POINTER pSasIOUnitPage2_t; 25871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25884b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SASIOUNITPAGE2_PAGEVERSION (0x05) 25891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 2 Status field */ 25911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT2_STATUS_DISABLED_PERSISTENT_MAPPINGS (0x02) 25921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT2_STATUS_FULL_PERSISTENT_MAPPINGS (0x01) 25931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 2 Flags field */ 25951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT2_FLAGS_DISABLE_PERSISTENT_MAPPINGS (0x01) 2596c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* Physical Mapping Modes */ 2597c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_MASK_PHYS_MAP_MODE (0x0E) 2598c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_SHIFT_PHYS_MAP_MODE (1) 2599c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_NO_PHYS_MAP (0x00) 2600c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_DIRECT_ATTACH_PHYS_MAP (0x01) 2601c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_ENCLOSURE_SLOT_PHYS_MAP (0x02) 26024b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT2_FLAGS_HOST_ASSIGNED_PHYS_MAP (0x07) 2603c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2604c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_RESERVE_ID_0_FOR_BOOT (0x10) 2605ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_IOUNIT2_FLAGS_DA_STARTING_SLOT (0x20) 26061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_3 26091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2610c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 26111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 08h */ 26121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxInvalidDwordCount; /* 0Ch */ 26131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 InvalidDwordCountTime; /* 10h */ 26141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxRunningDisparityErrorCount; /* 14h */ 26151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 RunningDisparityErrorTime; /* 18h */ 26161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxLossDwordSynchCount; /* 1Ch */ 26171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 LossDwordSynchCountTime; /* 20h */ 26181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxPhyResetProblemCount; /* 24h */ 26191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhyResetProblemTime; /* 28h */ 2620c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_3, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_3, 26211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage3_t, MPI_POINTER pSasIOUnitPage3_t; 26221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SASIOUNITPAGE3_PAGEVERSION (0x00) 26241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2626c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2627c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS Expander Config Pages 2628c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2629c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 26301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_EXPANDER_0 26311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2632c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2633c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysicalPort; /* 08h */ 2634c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 09h */ 26354b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 EnclosureHandle; /* 0Ah */ 26361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 2637c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 DiscoveryStatus; /* 14h */ 26381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DevHandle; /* 18h */ 26391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ParentDevHandle; /* 1Ah */ 26401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExpanderChangeCount; /* 1Ch */ 26411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExpanderRouteIndexes; /* 1Eh */ 26421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhys; /* 20h */ 26431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SASLevel; /* 21h */ 26441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 22h */ 26451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved3; /* 23h */ 2646c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_EXPANDER_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_EXPANDER_0, 26471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasExpanderPage0_t, MPI_POINTER pSasExpanderPage0_t; 26481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26494b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SASEXPANDER0_PAGEVERSION (0x03) 2650c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2651c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Expander Page 0 DiscoveryStatus field */ 2652c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_LOOP_DETECTED (0x00000001) 2653c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_UNADDRESSABLE_DEVICE (0x00000002) 2654c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_MULTIPLE_PORTS (0x00000004) 2655c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_EXPANDER_ERR (0x00000008) 2656c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SMP_TIMEOUT (0x00000010) 2657c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_OUT_ROUTE_ENTRIES (0x00000020) 2658c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_INDEX_NOT_EXIST (0x00000040) 2659c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SMP_FUNCTION_FAILED (0x00000080) 2660c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SMP_CRC_ERROR (0x00000100) 2661c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SUBTRACTIVE_LINK (0x00000200) 2662c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_TABLE_LINK (0x00000400) 2663c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_UNSUPPORTED_DEVICE (0x00000800) 26641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS Expander Page 0 Flags field */ 26661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_EXPANDER0_FLAGS_ROUTE_TABLE_CONFIG (0x02) 26671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_EXPANDER0_FLAGS_CONFIG_IN_PROGRESS (0x01) 26681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2670c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_SAS_EXPANDER_1 2671c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2672c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2673c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysicalPort; /* 08h */ 2674c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 09h */ 2675c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved2; /* 0Ah */ 2676c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NumPhys; /* 0Ch */ 2677c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Phy; /* 0Dh */ 2678c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 NumTableEntriesProgrammed; /* 0Eh */ 2679c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ProgrammedLinkRate; /* 10h */ 2680c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 HwLinkRate; /* 11h */ 2681c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 AttachedDevHandle; /* 12h */ 2682c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 PhyInfo; /* 14h */ 2683c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 AttachedDeviceInfo; /* 18h */ 2684c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 OwnerDevHandle; /* 1Ch */ 2685c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ChangeCount; /* 1Eh */ 2686c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NegotiatedLinkRate; /* 1Fh */ 2687c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhyIdentifier; /* 20h */ 2688c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 AttachedPhyIdentifier; /* 21h */ 26894b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 Reserved3; /* 22h */ 2690c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 DiscoveryInfo; /* 23h */ 26914b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 Reserved4; /* 24h */ 2692c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_EXPANDER_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_EXPANDER_1, 2693c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SasExpanderPage1_t, MPI_POINTER pSasExpanderPage1_t; 2694c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2695c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SASEXPANDER1_PAGEVERSION (0x01) 2696c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2697c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* use MPI_SAS_PHY0_PRATE_ defines for ProgrammedLinkRate */ 2698c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2699c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* use MPI_SAS_PHY0_HWRATE_ defines for HwLinkRate */ 2700c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2701c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* use MPI_SAS_PHY0_PHYINFO_ defines for PhyInfo */ 2702c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2703c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* see mpi_sas.h for values for SAS Expander Page 1 AttachedDeviceInfo values */ 2704c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2705c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Expander Page 1 DiscoveryInfo field */ 2706c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_DISCINFO_BAD_PHY DISABLED (0x04) 2707c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_DISCINFO_LINK_STATUS_CHANGE (0x02) 2708c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_DISCINFO_NO_ROUTING_ENTRIES (0x01) 2709c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2710c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Expander Page 1 NegotiatedLinkRate field */ 2711c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_UNKNOWN (0x00) 2712c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_PHY_DISABLED (0x01) 2713c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_FAILED_NEGOTIATION (0x02) 2714c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_SATA_OOB_COMPLETE (0x03) 2715c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_1_5 (0x08) 2716c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_3_0 (0x09) 2717c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2718c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2719c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2720c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS Device Config Pages 2721c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2722c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 27231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_DEVICE_0 27241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2725c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2726c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Slot; /* 08h */ 2727c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 EnclosureHandle; /* 0Ah */ 27281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 2729c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 ParentDevHandle; /* 14h */ 2730c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhyNum; /* 16h */ 2731c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 AccessStatus; /* 17h */ 27321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DevHandle; /* 18h */ 27331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetID; /* 1Ah */ 27341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bus; /* 1Bh */ 27351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DeviceInfo; /* 1Ch */ 27361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Flags; /* 20h */ 27371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysicalPort; /* 22h */ 2738c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved2; /* 23h */ 2739c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_DEVICE_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_DEVICE_0, 27401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasDevicePage0_t, MPI_POINTER pSasDevicePage0_t; 27411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2742c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SASDEVICE0_PAGEVERSION (0x04) 2743c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2744c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Device Page 0 AccessStatus field */ 2745c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_ASTATUS_NO_ERRORS (0x00) 2746c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_ASTATUS_SATA_INIT_FAILED (0x01) 2747c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_ASTATUS_SATA_CAPABILITY_FAILED (0x02) 27481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS Device Page 0 Flags field */ 2750c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_SATA_SW_PRESERVE (0x0200) 2751c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_UNSUPPORTED_DEVICE (0x0100) 2752c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_SATA_48BIT_LBA_SUPPORTED (0x0080) 2753c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_SATA_SMART_SUPPORTED (0x0040) 2754c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_SATA_NCQ_SUPPORTED (0x0020) 2755c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_SATA_FUA_SUPPORTED (0x0010) 2756c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_PORT_SELECTOR_ATTACH (0x0008) 2757c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_MAPPING_PERSISTENT (0x0004) 2758c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED (0x0002) 2759c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT (0x0001) 27601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* see mpi_sas.h for values for SAS Device Page 0 DeviceInfo values */ 27621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_DEVICE_1 27651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2766c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 27671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 08h */ 27681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 27691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved2; /* 14h */ 27701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DevHandle; /* 18h */ 27711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetID; /* 1Ah */ 27721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bus; /* 1Bh */ 27731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InitialRegDeviceFIS[20];/* 1Ch */ 2774c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_DEVICE_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_DEVICE_1, 27751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasDevicePage1_t, MPI_POINTER pSasDevicePage1_t; 27761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SASDEVICE1_PAGEVERSION (0x00) 27781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2780c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_SAS_DEVICE_2 2781c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2782c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2783c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 PhysicalIdentifier; /* 08h */ 2784ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U32 EnclosureMapping; /* 10h */ 2785c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_DEVICE_2, MPI_POINTER PTR_CONFIG_PAGE_SAS_DEVICE_2, 2786c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SasDevicePage2_t, MPI_POINTER pSasDevicePage2_t; 2787c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2788ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_PAGEVERSION (0x01) 2789ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig 2790ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig/* defines for SAS Device Page 2 EnclosureMapping field */ 2791ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_MASK_MISSING_COUNT (0x0000000F) 2792ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_SHIFT_MISSING_COUNT (0) 2793ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_MASK_NUM_SLOTS (0x000007F0) 2794ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_SHIFT_NUM_SLOTS (4) 2795ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_MASK_START_INDEX (0x001FF800) 2796ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_SHIFT_START_INDEX (11) 2797c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2798c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2799c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2800c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS PHY Config Pages 2801c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2802c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 28031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_PHY_0 28041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2805c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2806ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U16 OwnerDevHandle; /* 08h */ 2807ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U16 Reserved1; /* 0Ah */ 28081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 28091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 AttachedDevHandle; /* 14h */ 28101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 AttachedPhyIdentifier; /* 16h */ 28111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 17h */ 28121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 AttachedDeviceInfo; /* 18h */ 28131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ProgrammedLinkRate; /* 20h */ 28141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HwLinkRate; /* 21h */ 28151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChangeCount; /* 22h */ 2816ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U8 Flags; /* 23h */ 28171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhyInfo; /* 24h */ 2818c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_PHY_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_PHY_0, 28191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasPhyPage0_t, MPI_POINTER pSasPhyPage0_t; 28201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2821ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASPHY0_PAGEVERSION (0x01) 28221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS PHY Page 0 ProgrammedLinkRate field */ 28241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_MASK (0xF0) 28251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_NOT_PROGRAMMABLE (0x00) 28261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_1_5 (0x80) 28271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_3_0 (0x90) 28281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_MASK (0x0F) 28291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_NOT_PROGRAMMABLE (0x00) 28301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_1_5 (0x08) 28311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_3_0 (0x09) 28321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS PHY Page 0 HwLinkRate field */ 28341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MAX_RATE_MASK (0xF0) 28351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MAX_RATE_1_5 (0x80) 28361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MAX_RATE_3_0 (0x90) 28371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MIN_RATE_MASK (0x0F) 28381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MIN_RATE_1_5 (0x08) 28391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MIN_RATE_3_0 (0x09) 28401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2841ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig/* values for SAS PHY Page 0 Flags field */ 2842ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_PHY0_FLAGS_SGPIO_DIRECT_ATTACH_ENC (0x01) 2843ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig 28441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS PHY Page 0 PhyInfo field */ 28451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SATA_PORT_ACTIVE (0x00004000) 28461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SATA_PORT_SELECTOR (0x00002000) 28471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_VIRTUAL_PHY (0x00001000) 28481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_MASK_PARTIAL_PATHWAY_TIME (0x00000F00) 28501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SHIFT_PARTIAL_PATHWAY_TIME (8) 28511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_MASK_ROUTING_ATTRIBUTE (0x000000F0) 28531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_DIRECT_ROUTING (0x00000000) 28541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SUBTRACTIVE_ROUTING (0x00000010) 28551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_TABLE_ROUTING (0x00000020) 28561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_MASK_LINK_RATE (0x0000000F) 28581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_UNKNOWN_LINK_RATE (0x00000000) 28591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_PHY_DISABLED (0x00000001) 28601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_NEGOTIATION_FAILED (0x00000002) 28611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SATA_OOB_COMPLETE (0x00000003) 28621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_RATE_1_5 (0x00000008) 28631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_RATE_3_0 (0x00000009) 28641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_PHY_1 28671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2868c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 28691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 08h */ 28701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 InvalidDwordCount; /* 0Ch */ 28711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 RunningDisparityErrorCount; /* 10h */ 28721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 LossDwordSynchCount; /* 14h */ 28731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhyResetProblemCount; /* 18h */ 2874c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_PHY_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_PHY_1, 28751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasPhyPage1_t, MPI_POINTER pSasPhyPage1_t; 28761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SASPHY1_PAGEVERSION (0x00) 28781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2880c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2881c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS Enclosure Config Pages 2882c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2883c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2884c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_SAS_ENCLOSURE_0 2885c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2886c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2887c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 2888c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 EnclosureLogicalID; /* 0Ch */ 2889c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Flags; /* 14h */ 2890c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 EnclosureHandle; /* 16h */ 2891c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 NumSlots; /* 18h */ 2892c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 StartSlot; /* 1Ah */ 2893c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 StartTargetID; /* 1Ch */ 2894c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 StartBus; /* 1Dh */ 2895c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SEPTargetID; /* 1Eh */ 2896c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SEPBus; /* 1Fh */ 2897c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 20h */ 2898c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 24h */ 2899c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_ENCLOSURE_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_ENCLOSURE_0, 2900c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SasEnclosurePage0_t, MPI_POINTER pSasEnclosurePage0_t; 2901c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2902ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASENCLOSURE0_PAGEVERSION (0x01) 2903c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2904c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Enclosure Page 0 Flags field */ 2905c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_SEP_BUS_ID_VALID (0x0020) 2906c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_START_BUS_ID_VALID (0x0010) 2907c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2908c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_MASK (0x000F) 2909c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_UNKNOWN (0x0000) 2910c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_IOC_SES (0x0001) 2911c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_IOC_SGPIO (0x0002) 2912c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_EXP_SGPIO (0x0003) 2913c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_SES_ENCLOSURE (0x0004) 2914ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_ENCLS0_FLAGS_MNG_IOC_GPIO (0x0005) 2915c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2916c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2917c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2918c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* Log Config Pages 2919c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2920c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* 2921c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 2922c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * one and check NumLogEntries at runtime. 2923c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean */ 2924c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#ifndef MPI_LOG_0_NUM_LOG_ENTRIES 2925c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_LOG_0_NUM_LOG_ENTRIES (1) 2926c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#endif 2927c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 29284b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_LOG_0_LOG_DATA_LENGTH (0x1C) 2929c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2930c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_LOG_0_ENTRY 2931c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 29324b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 TimeStamp; /* 00h */ 29334b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 Reserved1; /* 04h */ 29344b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 LogSequence; /* 08h */ 29354b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 LogEntryQualifier; /* 0Ah */ 29364b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 LogData[MPI_LOG_0_LOG_DATA_LENGTH]; /* 0Ch */ 2937c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_LOG_0_ENTRY, MPI_POINTER PTR_MPI_LOG_0_ENTRY, 2938c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MpiLog0Entry_t, MPI_POINTER pMpiLog0Entry_t; 2939c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2940c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for Log Page 0 LogEntry LogEntryQualifier field */ 2941c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_LOG_0_ENTRY_QUAL_ENTRY_UNUSED (0x0000) 2942c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_LOG_0_ENTRY_QUAL_POWER_ON_RESET (0x0001) 2943c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2944c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_LOG_0 2945c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2946c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2947c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 2948c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 2949c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 NumLogEntries; /* 10h */ 2950c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved3; /* 12h */ 2951c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_LOG_0_ENTRY LogEntry[MPI_LOG_0_NUM_LOG_ENTRIES]; /* 14h */ 2952c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_LOG_0, MPI_POINTER PTR_CONFIG_PAGE_LOG_0, 2953c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean LogPage0_t, MPI_POINTER pLogPage0_t; 2954c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 29554b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_LOG_0_PAGEVERSION (0x01) 2956c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2957c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 29581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 29591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2960