11da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 2cddc0ab71194a09c0ac359be10a0f1ef976ddc95Prakash, Sathya * Copyright (c) 2000-2008 LSI 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 * 9fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * mpi_cnfg.h Version: 01.05.18 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. 279eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * 10-11-06 01.05.13 Added NumForceWWID field and ForceWWID array to 280eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Manufacturing Page 5. 281eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added Manufacturing pages 8 through 10. 282eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added defines for supported metadata size bits in 283eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * CapabilitiesFlags field of IOC Page 6. 284eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added defines for metadata size bits in VolumeSettings 285eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * field of RAID Volume Page 0. 286eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added SATA Link Reset settings, Enable SATA Asynchronous 287eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Notification bit, and HideNonZeroAttachedPhyIdentifiers 288eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * bit to AdditionalControlFlags field of SAS IO Unit 289eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Page 1. 290eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added defines for Enclosure Devices Unmapped and 291eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Device Limit Exceeded bits in Status field of SAS IO 292eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Unit Page 2. 293eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added more AccessStatus values for SAS Device Page 0. 294eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Added bit for SATA Asynchronous Notification Support in 295eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore * Flags field of SAS Device Page 0. 296d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * 02-28-07 01.05.14 Added ExtFlags field to Manufacturing Page 4. 297d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Added Disable SMART Polling for CapabilitiesFlags of 298d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * IOC Page 6. 299d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Added Disable SMART Polling to DeviceSettings of BIOS 300d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Page 1. 301d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Added Multi-Port Domain bit for DiscoveryStatus field 302d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * of SAS IO Unit Page. 303d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Added Multi-Port Domain Illegal flag for SAS IO Unit 304d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Page 1 AdditionalControlFlags field. 305d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * 05-24-07 01.05.15 Added Hide Physical Disks with Non-Integrated RAID 306d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Metadata bit to Manufacturing Page 4 ExtFlags field. 307d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Added Internal Connector to End Device Present bit to 308d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Expander Page 0 Flags field. 309d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * Fixed define for 310d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore * MPI_SAS_EXPANDER1_DISCINFO_BAD_PHY_DISABLED. 311fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * 08-07-07 01.05.16 Added MPI_IOCPAGE6_CAP_FLAGS_MULTIPORT_DRIVE_SUPPORT 312fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * define. 313fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Added BIOS Page 4 structure. 314fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Added MPI_RAID_PHYS_DISK1_PATH_MAX define for RAID 315fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Physcial Disk Page 1. 316fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * 01-15-07 01.05.17 Added additional bit defines for ExtFlags field of 317fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Manufacturing Page 4. 318fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Added Solid State Drives Supported bit to IOC Page 6 319fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Capabilities Flags. 320fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Added new value for AccessStatus field of SAS Device 321fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Page 0 (_SATA_NEEDS_INITIALIZATION). 322fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * 03-28-08 01.05.18 Defined new bits in Manufacturing Page 4 ExtFlags field 323fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * to control coercion size and the mixing of SAS and SATA 324fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * SSD drives. 3251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * -------------------------------------------------------------------------- 3261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 3271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_CNFG_H 3291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CNFG_H 3301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/***************************************************************************** 3331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 3341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus 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 3351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 3361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds*****************************************************************************/ 3371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_HEADER 3391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 3401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageVersion; /* 00h */ 3411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageLength; /* 01h */ 3421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageNumber; /* 02h */ 3431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageType; /* 03h */ 344c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_HEADER, MPI_POINTER PTR_CONFIG_PAGE_HEADER, 3451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t, MPI_POINTER pConfigPageHeader_t; 3461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef union _CONFIG_PAGE_HEADER_UNION 3481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 3491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t Struct; 3501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bytes[4]; 3511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Word16[2]; 3521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Word32; 3531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} ConfigPageHeaderUnion, MPI_POINTER pConfigPageHeaderUnion, 354c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER_UNION, MPI_POINTER PTR_CONFIG_PAGE_HEADER_UNION; 3551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_EXTENDED_PAGE_HEADER 3571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 3581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageVersion; /* 00h */ 3591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 01h */ 3601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageNumber; /* 02h */ 3611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PageType; /* 03h */ 3621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExtPageLength; /* 04h */ 3631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtPageType; /* 06h */ 3641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 07h */ 365c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_EXTENDED_PAGE_HEADER, MPI_POINTER PTR_CONFIG_EXTENDED_PAGE_HEADER, 3661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigExtendedPageHeader_t, MPI_POINTER pConfigExtendedPageHeader_t; 3671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 3711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* PageType field values 3721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 3731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_READ_ONLY (0x00) 3741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_CHANGEABLE (0x10) 3751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_PERSISTENT (0x20) 3761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_RO_PERSISTENT (0x30) 3771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGEATTR_MASK (0xF0) 3781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_IO_UNIT (0x00) 3801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_IOC (0x01) 3811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_BIOS (0x02) 3821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_SCSI_PORT (0x03) 3831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_SCSI_DEVICE (0x04) 3841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_FC_PORT (0x05) 3851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_FC_DEVICE (0x06) 3861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_LAN (0x07) 3871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_RAID_VOLUME (0x08) 3881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_MANUFACTURING (0x09) 3891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_RAID_PHYSDISK (0x0A) 3901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_INBAND (0x0B) 3911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_EXTENDED (0x0F) 3921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_PAGETYPE_MASK (0x0F) 3931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_TYPENUM_MASK (0x0FFF) 3951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 3981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* ExtPageType field values 3991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 4001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_IO_UNIT (0x10) 4011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_EXPANDER (0x11) 4021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_DEVICE (0x12) 4031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_EXTPAGETYPE_SAS_PHY (0x13) 404c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_CONFIG_EXTPAGETYPE_LOG (0x14) 405c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_CONFIG_EXTPAGETYPE_ENCLOSURE (0x15) 4061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 4091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* PageAddress field values 4101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 4111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_PORT_PGAD_PORT_MASK (0x000000FF) 4121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 413c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_FORM_MASK (0xF0000000) 414c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_FORM_BUS_TID (0x00000000) 4151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_TARGET_ID_MASK (0x000000FF) 4161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_TARGET_ID_SHIFT (0) 4171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_BUS_MASK (0x0000FF00) 4181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSI_DEVICE_BUS_SHIFT (8) 419c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_FORM_TARGET_MODE (0x10000000) 420c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_RESPOND_ID_MASK (0x000000FF) 421c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_RESPOND_ID_SHIFT (0) 422c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_BUS_MASK (0x0000FF00) 423c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_BUS_SHIFT (8) 424c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_INIT_ID_MASK (0x00FF0000) 425c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSI_DEVICE_TM_INIT_ID_SHIFT (16) 4261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_PORT_MASK (0xF0000000) 4281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_PORT_SHIFT (28) 4291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_FORM_MASK (0x0F000000) 4301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_FORM_INDEX (0x01000000) 4311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_INDEX_MASK (0x0000FFFF) 4321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PGAD_INDEX_SHIFT (0) 4331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_PORT_MASK (0xF0000000) 4351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_PORT_SHIFT (28) 4361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_FORM_MASK (0x0F000000) 4371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_FORM_NEXT_DID (0x00000000) 4381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_PORT_MASK (0xF0000000) 4391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_PORT_SHIFT (28) 4401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_DID_MASK (0x00FFFFFF) 4411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_ND_DID_SHIFT (0) 4421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_FORM_BUS_TID (0x01000000) 4431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_BUS_MASK (0x0000FF00) 4441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_BUS_SHIFT (8) 4451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_TID_MASK (0x000000FF) 4461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PGAD_BT_TID_SHIFT (0) 4471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK_PGAD_PHYSDISKNUM_MASK (0x000000FF) 4491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK_PGAD_PHYSDISKNUM_SHIFT (0) 4501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 451c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_MASK (0xF0000000) 452c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_SHIFT (28) 453c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_GET_NEXT_HANDLE (0x00000000) 454c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_HANDLE_PHY_NUM (0x00000001) 455c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_FORM_HANDLE (0x00000002) 456c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_GNH_MASK_HANDLE (0x0000FFFF) 457c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_GNH_SHIFT_HANDLE (0) 458c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_MASK_PHY (0x00FF0000) 459c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_SHIFT_PHY (16) 460c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_MASK_HANDLE (0x0000FFFF) 461c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_HPN_SHIFT_HANDLE (0) 462c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_H_MASK_HANDLE (0x0000FFFF) 463c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPAND_PGAD_H_SHIFT_HANDLE (0) 464c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 4651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_MASK (0xF0000000) 4661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_SHIFT (28) 4671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_GET_NEXT_HANDLE (0x00000000) 4681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID (0x00000001) 4691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_FORM_HANDLE (0x00000002) 4701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_GNH_HANDLE_MASK (0x0000FFFF) 4711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_GNH_HANDLE_SHIFT (0) 4721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_BUS_MASK (0x0000FF00) 4731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_BUS_SHIFT (8) 4741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_TID_MASK (0x000000FF) 4751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_BT_TID_SHIFT (0) 4761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_H_HANDLE_MASK (0x0000FFFF) 4771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_DEVICE_PGAD_H_HANDLE_SHIFT (0) 4781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 479c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_MASK (0xF0000000) 480c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_SHIFT (28) 481c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_PHY_NUMBER (0x0) 482c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_FORM_PHY_TBL_INDEX (0x1) 483c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_NUMBER_MASK (0x000000FF) 484c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_NUMBER_SHIFT (0) 485c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_TBL_INDEX_MASK (0x0000FFFF) 486c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_PHY_PGAD_PHY_TBL_INDEX_SHIFT (0) 487c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 488c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_MASK (0xF0000000) 489c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_SHIFT (28) 490c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_GET_NEXT_HANDLE (0x00000000) 491c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_FORM_HANDLE (0x00000001) 492c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_GNH_HANDLE_MASK (0x0000FFFF) 493c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_GNH_HANDLE_SHIFT (0) 494c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_H_HANDLE_MASK (0x0000FFFF) 495c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLOS_PGAD_H_HANDLE_SHIFT (0) 496c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 4971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 4991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 5001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Config Request Message 5011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 5021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MSG_CONFIG 5031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 5041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Action; /* 00h */ 5051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 01h */ 5061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChainOffset; /* 02h */ 5071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Function; /* 03h */ 5081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExtPageLength; /* 04h */ 5091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtPageType; /* 06h */ 5101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MsgFlags; /* 07h */ 5111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MsgContext; /* 08h */ 5121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2[8]; /* 0Ch */ 513c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 14h */ 5141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PageAddress; /* 18h */ 5151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SGE_IO_UNION PageBufferSGE; /* 1Ch */ 5161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MSG_CONFIG, MPI_POINTER PTR_MSG_CONFIG, 5171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Config_t, MPI_POINTER pConfig_t; 5181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 5211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Action field values 5221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 5231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_HEADER (0x00) 5241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_READ_CURRENT (0x01) 5251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_WRITE_CURRENT (0x02) 5261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_DEFAULT (0x03) 5271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_WRITE_NVRAM (0x04) 5281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_READ_DEFAULT (0x05) 5291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_CONFIG_ACTION_PAGE_READ_NVRAM (0x06) 5301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* Config Reply Message */ 5331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MSG_CONFIG_REPLY 5341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 5351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Action; /* 00h */ 5361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 01h */ 5371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MsgLength; /* 02h */ 5381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Function; /* 03h */ 5391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExtPageLength; /* 04h */ 5401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtPageType; /* 06h */ 5411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MsgFlags; /* 07h */ 5421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MsgContext; /* 08h */ 5431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2[2]; /* 0Ch */ 5441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOCStatus; /* 0Eh */ 5451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IOCLogInfo; /* 10h */ 546c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 14h */ 5471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MSG_CONFIG_REPLY, MPI_POINTER PTR_MSG_CONFIG_REPLY, 5481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigReply_t, MPI_POINTER pConfigReply_t; 5491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/***************************************************************************** 5531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 5541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* C o n f i g u r a t i o n P a g e s 5551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* 5561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds*****************************************************************************/ 5571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 5591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Manufacturing Config pages 5601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 5611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_VENDORID_LSILOGIC (0x1000) 5621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* Fibre Channel */ 5631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC909 (0x0621) 5641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC919 (0x0624) 5651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC929 (0x0622) 5661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC919X (0x0628) 5671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVICEID_FC929X (0x0626) 568c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVICEID_FC939X (0x0642) 569c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVICEID_FC949X (0x0640) 5704b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANUFACTPAGE_DEVICEID_FC949E (0x0646) 5711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* SCSI */ 5721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1030 (0x0030) 5731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1030ZC (0x0031) 5741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_1030_53C1035 (0x0032) 5751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_1030ZC_53C1035 (0x0033) 5761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1035 (0x0040) 5771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_53C1035ZC (0x0041) 5781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* SAS */ 5791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTPAGE_DEVID_SAS1064 (0x0050) 580c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1064A (0x005C) 581c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1064E (0x0056) 582c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1066 (0x005E) 583c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1066E (0x005A) 584c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1068 (0x0054) 585c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANUFACTPAGE_DEVID_SAS1068E (0x0058) 58685d37226fb5faaf7bec55df50c2cd029bd6bb3cdChandrakala Chavva#define MPI_MANUFACTPAGE_DEVID_SAS1068_820XELP (0x0059) 5874b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANUFACTPAGE_DEVID_SAS1078 (0x0062) 5881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 5901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_0 5911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 592c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 5931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChipName[16]; /* 04h */ 5941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ChipRevision[8]; /* 14h */ 5951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BoardName[16]; /* 1Ch */ 5961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BoardAssembly[16]; /* 2Ch */ 5971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BoardTracerNumber[16]; /* 3Ch */ 5981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 599c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_0, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_0, 6001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage0_t, MPI_POINTER pManufacturingPage0_t; 6011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING0_PAGEVERSION (0x00) 6031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_1 6061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 607c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VPD[256]; /* 04h */ 609c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_1, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_1, 6101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage1_t, MPI_POINTER pManufacturingPage1_t; 6111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING1_PAGEVERSION (0x00) 6131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_CHIP_REVISION_ID 6161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 6171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DeviceID; /* 00h */ 6181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PCIRevisionID; /* 02h */ 6191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 03h */ 6201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_CHIP_REVISION_ID, MPI_POINTER PTR_MPI_CHIP_REVISION_ID, 6211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MpiChipRevisionId_t, MPI_POINTER pMpiChipRevisionId_t; 6221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 6251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 6261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 6271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 6281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_MAN_PAGE_2_HW_SETTINGS_WORDS 6291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MAN_PAGE_2_HW_SETTINGS_WORDS (1) 6301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 6311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_2 6331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 634c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_CHIP_REVISION_ID ChipId; /* 04h */ 6361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HwSettings[MPI_MAN_PAGE_2_HW_SETTINGS_WORDS];/* 08h */ 637c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_2, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_2, 6381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage2_t, MPI_POINTER pManufacturingPage2_t; 6391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING2_PAGEVERSION (0x00) 6411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 6441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 6451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 6461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 6471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_MAN_PAGE_3_INFO_WORDS 6481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MAN_PAGE_3_INFO_WORDS (1) 6491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 6501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_3 6521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 653c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_CHIP_REVISION_ID ChipId; /* 04h */ 6551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Info[MPI_MAN_PAGE_3_INFO_WORDS];/* 08h */ 656c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_3, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_3, 6571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage3_t, MPI_POINTER pManufacturingPage3_t; 6581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING3_PAGEVERSION (0x00) 6601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_4 6631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 664c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 6651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 04h */ 6661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoOffset0; /* 08h */ 6671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoSize0; /* 09h */ 6681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoOffset1; /* 0Ah */ 6691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InfoSize1; /* 0Bh */ 6701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InquirySize; /* 0Ch */ 6711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 0Dh */ 672d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U16 ExtFlags; /* 0Eh */ 6731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InquiryData[56]; /* 10h */ 6741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ISVolumeSettings; /* 48h */ 6751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IMEVolumeSettings; /* 4Ch */ 6761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IMVolumeSettings; /* 50h */ 677c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 54h */ 678c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 58h */ 6794b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 Reserved5; /* 5Ch */ 680c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMEDataScrubRate; /* 60h */ 681c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMEResyncRate; /* 61h */ 682c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved6; /* 62h */ 683c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMDataScrubRate; /* 64h */ 684c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 IMResyncRate; /* 65h */ 685c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved7; /* 66h */ 686c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 68h */ 687c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 6Ch */ 688c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_4, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_4, 6891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage4_t, MPI_POINTER pManufacturingPage4_t; 6901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 691d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_MANUFACTURING4_PAGEVERSION (0x05) 6921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 6931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* defines for the Flags field */ 6942076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE4_FORCE_BAD_BLOCK_TABLE (0x80) 6952076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE4_FORCE_OFFLINE_FAILOVER (0x40) 6964b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IME_DISABLE (0x20) 6974b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IM_DISABLE (0x10) 6984b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IS_DISABLE (0x08) 6994b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IR_MODEPAGE8_DISABLE (0x04) 7004b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_MANPAGE4_IM_RESYNC_CACHE_ENABLE (0x02) 7011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANPAGE4_IR_NO_MIX_SAS_SATA (0x01) 7021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 703d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore/* defines for the ExtFlags field */ 704fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_MASK_COERCION_SIZE (0x0180) 705fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_SHIFT_COERCION_SIZE (7) 706fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_1GB_COERCION_SIZE (0) 707fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_128MB_COERCION_SIZE (1) 708fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai 709fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_NO_MIX_SSD_SAS_SATA (0x0040) 710fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_MIX_SSD_AND_NON_SSD (0x0020) 711fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_MANPAGE4_EXTFLAGS_DUAL_PORT_SUPPORT (0x0010) 712d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_MANPAGE4_EXTFLAGS_HIDE_NON_IR_METADATA (0x0008) 713d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_MANPAGE4_EXTFLAGS_SAS_CACHE_DISABLE (0x0004) 714d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_MANPAGE4_EXTFLAGS_SATA_CACHE_DISABLE (0x0002) 715d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_MANPAGE4_EXTFLAGS_LEGACY_MODE (0x0001) 716d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore 7171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 718eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#ifndef MPI_MANPAGE5_NUM_FORCEWWID 719eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_MANPAGE5_NUM_FORCEWWID (1) 720eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#endif 721eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 7221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_5 7231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 724c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 7251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 BaseWWID; /* 04h */ 726c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Flags; /* 0Ch */ 727eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U8 NumForceWWID; /* 0Dh */ 728c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved2; /* 0Eh */ 729eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U32 Reserved3; /* 10h */ 730eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U32 Reserved4; /* 14h */ 731eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U64 ForceWWID[MPI_MANPAGE5_NUM_FORCEWWID]; /* 18h */ 732c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_5, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_5, 7331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage5_t, MPI_POINTER pManufacturingPage5_t; 7341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 735eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_MANUFACTURING5_PAGEVERSION (0x02) 736c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 737c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* defines for the Flags field */ 738c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_MANPAGE5_TWO_WWID_PER_PHY (0x01) 7391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_MANUFACTURING_6 7421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 743c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 7441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ProductSpecificInfo;/* 04h */ 745c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_MANUFACTURING_6, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_6, 7461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ManufacturingPage6_t, MPI_POINTER pManufacturingPage6_t; 7471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_MANUFACTURING6_PAGEVERSION (0x00) 7491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 7512076eb6ab8339bf09620a0160be3607bbbb61a50Eric Mooretypedef struct _MPI_MANPAGE7_CONNECTOR_INFO 7522076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore{ 7532076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Pinout; /* 00h */ 7542076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Connector[16]; /* 04h */ 7552076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Location; /* 14h */ 7562076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved1; /* 15h */ 7572076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Slot; /* 16h */ 7582076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved2; /* 18h */ 7592076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore} MPI_MANPAGE7_CONNECTOR_INFO, MPI_POINTER PTR_MPI_MANPAGE7_CONNECTOR_INFO, 7602076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore MpiManPage7ConnectorInfo_t, MPI_POINTER pMpiManPage7ConnectorInfo_t; 7612076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7622076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for the Pinout field */ 7632076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L4 (0x00080000) 7642076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L3 (0x00040000) 7652076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L2 (0x00020000) 7662076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8484_L1 (0x00010000) 7672076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L4 (0x00000800) 7682076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L3 (0x00000400) 7692076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L2 (0x00000200) 7702076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8470_L1 (0x00000100) 7712076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_SFF_8482 (0x00000002) 7722076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_PINOUT_CONNECTION_UNKNOWN (0x00000001) 7732076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7742076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for the Location field */ 7752076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_UNKNOWN (0x01) 7762076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_INTERNAL (0x02) 7772076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_EXTERNAL (0x04) 7782076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_SWITCHABLE (0x08) 7792076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_AUTO (0x10) 7802076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_NOT_PRESENT (0x20) 7812076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_LOCATION_NOT_CONNECTED (0x80) 7822076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7832076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* 7842076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 7852076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore * one and check NumPhys at runtime. 7862076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore */ 7872076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#ifndef MPI_MANPAGE7_CONNECTOR_INFO_MAX 7882076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_CONNECTOR_INFO_MAX (1) 7892076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#endif 7902076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 7912076eb6ab8339bf09620a0160be3607bbbb61a50Eric Mooretypedef struct _CONFIG_PAGE_MANUFACTURING_7 7922076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore{ 7932076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 7942076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved1; /* 04h */ 7952076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved2; /* 08h */ 7962076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Flags; /* 0Ch */ 7972076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 EnclosureName[16]; /* 10h */ 7982076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 NumPhys; /* 20h */ 7992076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved3; /* 21h */ 8002076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved4; /* 22h */ 8012076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore MPI_MANPAGE7_CONNECTOR_INFO ConnectorInfo[MPI_MANPAGE7_CONNECTOR_INFO_MAX]; /* 24h */ 8022076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore} CONFIG_PAGE_MANUFACTURING_7, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_7, 8032076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore ManufacturingPage7_t, MPI_POINTER pManufacturingPage7_t; 8042076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 8052076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANUFACTURING7_PAGEVERSION (0x00) 8062076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 8072076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for the Flags field */ 8082076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_MANPAGE7_FLAG_USE_SLOT_INFO (0x00000001) 8092076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 8102076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 811eae225eb5947825bc4e845c33ded9aedd74407cfEric Mooretypedef struct _CONFIG_PAGE_MANUFACTURING_8 812eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore{ 813eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 814eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U32 ProductSpecificInfo;/* 04h */ 815eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore} CONFIG_PAGE_MANUFACTURING_8, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_8, 816eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore ManufacturingPage8_t, MPI_POINTER pManufacturingPage8_t; 817eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 818eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_MANUFACTURING8_PAGEVERSION (0x00) 819eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 820eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 821eae225eb5947825bc4e845c33ded9aedd74407cfEric Mooretypedef struct _CONFIG_PAGE_MANUFACTURING_9 822eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore{ 823eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 824eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U32 ProductSpecificInfo;/* 04h */ 825eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore} CONFIG_PAGE_MANUFACTURING_9, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_9, 826eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore ManufacturingPage9_t, MPI_POINTER pManufacturingPage9_t; 827eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 828d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_MANUFACTURING9_PAGEVERSION (0x00) 829eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 830eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 831eae225eb5947825bc4e845c33ded9aedd74407cfEric Mooretypedef struct _CONFIG_PAGE_MANUFACTURING_10 832eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore{ 833eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 834eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore U32 ProductSpecificInfo;/* 04h */ 835eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore} CONFIG_PAGE_MANUFACTURING_10, MPI_POINTER PTR_CONFIG_PAGE_MANUFACTURING_10, 836eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore ManufacturingPage10_t, MPI_POINTER pManufacturingPage10_t; 837eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 838eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_MANUFACTURING10_PAGEVERSION (0x00) 839eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 840eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 8411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 8421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* IO Unit Config Pages 8431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 8441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_0 8461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 847c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 8481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 UniqueValue; /* 04h */ 849c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_0, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_0, 8501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage0_t, MPI_POINTER pIOUnitPage0_t; 8511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE0_PAGEVERSION (0x00) 8531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_1 8561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 857c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 8581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 859c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_1, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_1, 8601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage1_t, MPI_POINTER pIOUnitPage1_t; 8611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8624b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_IOUNITPAGE1_PAGEVERSION (0x02) 8631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IO Unit Page 1 Flags defines */ 8651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_MULTI_FUNCTION (0x00000000) 8661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_SINGLE_FUNCTION (0x00000001) 8671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_MULTI_PATHING (0x00000002) 8681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_SINGLE_PATHING (0x00000000) 8691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_IR_USE_STATIC_VOLUME_ID (0x00000004) 8701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_DISABLE_QUEUE_FULL_HANDLING (0x00000020) 8711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_DISABLE_IR (0x00000040) 8721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_FORCE_32 (0x00000080) 8731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE1_NATIVE_COMMAND_Q_DISABLE (0x00000100) 8744b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_IOUNITPAGE1_SATA_WRITE_CACHE_DISABLE (0x00000200) 8751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_ADAPTER_INFO 8771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 8781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PciBusNumber; /* 00h */ 8791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PciDeviceAndFunctionNumber; /* 01h */ 8801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 AdapterFlags; /* 02h */ 8811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_ADAPTER_INFO, MPI_POINTER PTR_MPI_ADAPTER_INFO, 8821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MpiAdapterInfo_t, MPI_POINTER pMpiAdapterInfo_t; 8831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_ADAPTER_INFO_FLAGS_EMBEDDED (0x0001) 8851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_ADAPTER_INFO_FLAGS_INIT_STATUS (0x0002) 8861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_2 8881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 889c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 8901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 8911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BiosVersion; /* 08h */ 8921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_ADAPTER_INFO AdapterOrder[4]; /* 0Ch */ 893c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 1Ch */ 894c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_2, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_2, 8951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage2_t, MPI_POINTER pIOUnitPage2_t; 8961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 897c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_IOUNITPAGE2_PAGEVERSION (0x02) 8981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 8991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_PAUSE_ON_ERROR (0x00000002) 9001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_VERBOSE_ENABLE (0x00000004) 9011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_COLOR_VIDEO_DISABLE (0x00000008) 9021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_DONT_HOOK_INT_40 (0x00000010) 9031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_DEV_LIST_DISPLAY_MASK (0x000000E0) 9051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_INSTALLED_DEV_DISPLAY (0x00000000) 9061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_ADAPTER_DISPLAY (0x00000020) 9071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE2_FLAGS_ADAPTER_DEV_DISPLAY (0x00000040) 9081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 9111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 9121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 9131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 9141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IO_UNIT_PAGE_3_GPIO_VAL_MAX 9151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IO_UNIT_PAGE_3_GPIO_VAL_MAX (1) 9161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 9171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IO_UNIT_3 9191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 920c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 9211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 GPIOCount; /* 04h */ 9221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 05h */ 9231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 06h */ 9241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 GPIOVal[MPI_IO_UNIT_PAGE_3_GPIO_VAL_MAX]; /* 08h */ 925c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_3, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_3, 9261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOUnitPage3_t, MPI_POINTER pIOUnitPage3_t; 9271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_PAGEVERSION (0x01) 9291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_FUNCTION_MASK (0xFC) 9311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_FUNCTION_SHIFT (2) 9321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_SETTING_OFF (0x00) 9331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOUNITPAGE3_GPIO_SETTING_ON (0x01) 9341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 936c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_IO_UNIT_4 937c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 938c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 939c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 04h */ 940c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SGE_SIMPLE_UNION FWImageSGE; /* 08h */ 941c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IO_UNIT_4, MPI_POINTER PTR_CONFIG_PAGE_IO_UNIT_4, 942c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean IOUnitPage4_t, MPI_POINTER pIOUnitPage4_t; 943c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 944c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_IOUNITPAGE4_PAGEVERSION (0x00) 945c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 946c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 9471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 9481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* IOC Config Pages 9491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 9501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_0 9521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 953c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 9541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 TotalNVStore; /* 04h */ 9551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 FreeNVStore; /* 08h */ 9561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 VendorID; /* 0Ch */ 9571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DeviceID; /* 0Eh */ 9581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 RevisionID; /* 10h */ 9591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved[3]; /* 11h */ 9601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ClassCode; /* 14h */ 9611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 SubsystemVendorID; /* 18h */ 9621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 SubsystemID; /* 1Ah */ 963c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_0, MPI_POINTER PTR_CONFIG_PAGE_IOC_0, 9641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage0_t, MPI_POINTER pIOCPage0_t; 9651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE0_PAGEVERSION (0x01) 9671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_1 9701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 971c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 9721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 9731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 CoalescingTimeout; /* 08h */ 9741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CoalescingDepth; /* 0Ch */ 9751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PCISlotNum; /* 0Dh */ 9761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved[2]; /* 0Eh */ 977c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_1, MPI_POINTER PTR_CONFIG_PAGE_IOC_1, 9781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage1_t, MPI_POINTER pIOCPage1_t; 9791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 980ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_PAGEVERSION (0x03) 9811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* defines for the Flags field */ 983ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_MASK (0x07000000) 984ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_OFF (0x00000000) 985ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_T10 (0x01000000) 986ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE1_EEDP_MODE_LSI_1 (0x02000000) 987c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_IOCPAGE1_INITIATOR_CONTEXT_REPLY_DISABLE (0x00000010) 9881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE1_REPLY_COALESCING (0x00000001) 9891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE1_PCISLOTNUM_UNKNOWN (0xFF) 9911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 9931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_2_RAID_VOL 9941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 9951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeID; /* 00h */ 9961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeBus; /* 01h */ 9971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeIOC; /* 02h */ 9981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumePageNumber; /* 03h */ 9991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeType; /* 04h */ 10001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 05h */ 10011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved3; /* 06h */ 1002c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_2_RAID_VOL, MPI_POINTER PTR_CONFIG_PAGE_IOC_2_RAID_VOL, 10031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageIoc2RaidVol_t, MPI_POINTER pConfigPageIoc2RaidVol_t; 10041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 2 Volume RAID Type values, also used in RAID Volume pages */ 10061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_TYPE_IS (0x00) 10081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_TYPE_IME (0x01) 10091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_TYPE_IM (0x02) 1010ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_5 (0x03) 1011ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_6 (0x04) 1012ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_10 (0x05) 1013ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_RAID_50 (0x06) 1014ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAID_VOL_TYPE_UNKNOWN (0xFF) 10151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 2 Volume Flags values */ 10171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_FLAG_VOLUME_INACTIVE (0x08) 10191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 10211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 10221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 10231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 10241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_2_RAID_VOLUME_MAX 10251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_2_RAID_VOLUME_MAX (1) 10261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 10271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_2 10291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1030c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 10311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 CapabilitiesFlags; /* 04h */ 10321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumActiveVolumes; /* 08h */ 10331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxVolumes; /* 09h */ 10341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumActivePhysDisks; /* 0Ah */ 10351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxPhysDisks; /* 0Bh */ 1036c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_IOC_2_RAID_VOL RaidVolume[MPI_IOC_PAGE_2_RAID_VOLUME_MAX];/* 0Ch */ 1037c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_2, MPI_POINTER PTR_CONFIG_PAGE_IOC_2, 10381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage2_t, MPI_POINTER pIOCPage2_t; 10391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10402076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE2_PAGEVERSION (0x04) 10411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 2 Capabilities flags */ 10431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_IS_SUPPORT (0x00000001) 10451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_IME_SUPPORT (0x00000002) 10461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_IM_SUPPORT (0x00000004) 1047ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_5_SUPPORT (0x00000008) 1048ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_6_SUPPORT (0x00000010) 1049ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_10_SUPPORT (0x00000020) 1050ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_IOCPAGE2_CAP_FLAGS_RAID_50_SUPPORT (0x00000040) 10512076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE2_CAP_FLAGS_RAID_64_BIT_ADDRESSING (0x10000000) 10521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_SES_SUPPORT (0x20000000) 10531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_SAFTE_SUPPORT (0x40000000) 10541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE2_CAP_FLAGS_CROSS_CHANNEL_SUPPORT (0x80000000) 10551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _IOC_3_PHYS_DISK 10581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 10591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskID; /* 00h */ 10601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskBus; /* 01h */ 10611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskIOC; /* 02h */ 10621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 03h */ 10631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} IOC_3_PHYS_DISK, MPI_POINTER PTR_IOC_3_PHYS_DISK, 10641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Ioc3PhysDisk_t, MPI_POINTER pIoc3PhysDisk_t; 10651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 10671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 10681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 10691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 10701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_3_PHYSDISK_MAX 10711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_3_PHYSDISK_MAX (1) 10721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 10731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_3 10751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1076c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 10771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhysDisks; /* 04h */ 10781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 05h */ 10791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 06h */ 10801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOC_3_PHYS_DISK PhysDisk[MPI_IOC_PAGE_3_PHYSDISK_MAX]; /* 08h */ 1081c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_3, MPI_POINTER PTR_CONFIG_PAGE_IOC_3, 10821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage3_t, MPI_POINTER pIOCPage3_t; 10831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE3_PAGEVERSION (0x00) 10851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _IOC_4_SEP 10881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 10891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SEPTargetID; /* 00h */ 10901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SEPBus; /* 01h */ 10911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 10921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} IOC_4_SEP, MPI_POINTER PTR_IOC_4_SEP, 10931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Ioc4Sep_t, MPI_POINTER pIoc4Sep_t; 10941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 10951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 10961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 10971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 10981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 10991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_4_SEP_MAX 11001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_4_SEP_MAX (1) 11011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 11021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_4 11041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1105c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 11061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ActiveSEP; /* 04h */ 11071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxSEP; /* 05h */ 11081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved1; /* 06h */ 11091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOC_4_SEP SEP[MPI_IOC_PAGE_4_SEP_MAX]; /* 08h */ 1110c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_4, MPI_POINTER PTR_CONFIG_PAGE_IOC_4, 11111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage4_t, MPI_POINTER pIOCPage4_t; 11121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE4_PAGEVERSION (0x00) 11141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _IOC_5_HOT_SPARE 11171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 11181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 00h */ 11191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 01h */ 11201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HotSparePool; /* 02h */ 11211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 03h */ 11221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} IOC_5_HOT_SPARE, MPI_POINTER PTR_IOC_5_HOT_SPARE, 11231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds Ioc5HotSpare_t, MPI_POINTER pIoc5HotSpare_t; 11241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* IOC Page 5 HotSpare Flags */ 11261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_5_HOT_SPARE_ACTIVE (0x01) 11271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 11291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 11301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 11311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 11321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_IOC_PAGE_5_HOT_SPARE_MAX 11331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOC_PAGE_5_HOT_SPARE_MAX (1) 11341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 11351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_IOC_5 11371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1138c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 11391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 04h */ 11401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumHotSpares; /* 08h */ 11411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 09h */ 11421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved3; /* 0Ah */ 11431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOC_5_HOT_SPARE HotSpare[MPI_IOC_PAGE_5_HOT_SPARE_MAX]; /* 0Ch */ 1144c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_IOC_5, MPI_POINTER PTR_CONFIG_PAGE_IOC_5, 11451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds IOCPage5_t, MPI_POINTER pIOCPage5_t; 11461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_IOCPAGE5_PAGEVERSION (0x00) 11481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11492076eb6ab8339bf09620a0160be3607bbbb61a50Eric Mooretypedef struct _CONFIG_PAGE_IOC_6 11502076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore{ 11512076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore CONFIG_PAGE_HEADER Header; /* 00h */ 11522076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 CapabilitiesFlags; /* 04h */ 11532076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxDrivesIS; /* 08h */ 11542076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxDrivesIM; /* 09h */ 11552076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxDrivesIME; /* 0Ah */ 11562076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved1; /* 0Bh */ 11572076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MinDrivesIS; /* 0Ch */ 11582076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MinDrivesIM; /* 0Dh */ 11592076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MinDrivesIME; /* 0Eh */ 11602076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved2; /* 0Fh */ 11612076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxGlobalHotSpares; /* 10h */ 11622076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved3; /* 11h */ 11632076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved4; /* 12h */ 11642076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved5; /* 14h */ 11652076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 SupportedStripeSizeMapIS; /* 18h */ 11662076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 SupportedStripeSizeMapIME; /* 1Ch */ 11672076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved6; /* 20h */ 11682076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MetadataSize; /* 24h */ 11692076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Reserved7; /* 25h */ 11702076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved8; /* 26h */ 11712076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 MaxBadBlockTableEntries; /* 28h */ 11722076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved9; /* 2Ah */ 11732076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 IRNvsramUsage; /* 2Ch */ 11742076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved10; /* 2Eh */ 11752076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 IRNvsramVersion; /* 30h */ 11762076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved11; /* 34h */ 11772076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 Reserved12; /* 38h */ 11782076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore} CONFIG_PAGE_IOC_6, MPI_POINTER PTR_CONFIG_PAGE_IOC_6, 11792076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore IOCPage6_t, MPI_POINTER pIOCPage6_t; 11802076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 1181eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_IOCPAGE6_PAGEVERSION (0x01) 11822076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 11832076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* IOC Page 6 Capabilities Flags */ 11842076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 1185fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_IOCPAGE6_CAP_FLAGS_SSD_SUPPORT (0x00000020) 1186fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_IOCPAGE6_CAP_FLAGS_MULTIPORT_DRIVE_SUPPORT (0x00000010) 1187d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_IOCPAGE6_CAP_FLAGS_DISABLE_SMART_POLLING (0x00000008) 1188d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore 1189eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_IOCPAGE6_CAP_FLAGS_MASK_METADATA_SIZE (0x00000006) 1190eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_IOCPAGE6_CAP_FLAGS_64MB_METADATA_SIZE (0x00000000) 1191eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_IOCPAGE6_CAP_FLAGS_512MB_METADATA_SIZE (0x00000002) 1192eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 11932076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_IOCPAGE6_CAP_FLAGS_GLOBAL_HOT_SPARE (0x00000001) 11942076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 11951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 11961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 1197c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* BIOS Config Pages 11981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 11991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_BIOS_1 12011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1202c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 12031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BiosOptions; /* 04h */ 12041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 IOCSettings; /* 08h */ 12051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 0Ch */ 12061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DeviceSettings; /* 10h */ 12071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 NumberOfDevices; /* 14h */ 12084b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 ExpanderSpinup; /* 16h */ 12094b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 Reserved2; /* 17h */ 12101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutBlockDevicesNonRM; /* 18h */ 12111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutSequential; /* 1Ah */ 12121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutOther; /* 1Ch */ 12131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IOTimeoutBlockDevicesRM; /* 1Eh */ 1214c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_BIOS_1, MPI_POINTER PTR_CONFIG_PAGE_BIOS_1, 12151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds BIOSPage1_t, MPI_POINTER pBIOSPage1_t; 12161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12174b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_PAGEVERSION (0x03) 12181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for the BiosOptions field */ 12201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_SPI_ENABLE (0x00000400) 12211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_FC_ENABLE (0x00000200) 12221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_SAS_ENABLE (0x00000100) 12231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_OPTIONS_DISABLE_BIOS (0x00000001) 12241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for the IOCSettings field */ 12264b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_MASK_INITIAL_SPINUP_DELAY (0x0F000000) 12274b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_SHIFT_INITIAL_SPINUP_DELAY (24) 12284b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 1229ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_BIOSPAGE1_IOCSET_MASK_PORT_ENABLE_DELAY (0x00F00000) 1230ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_BIOSPAGE1_IOCSET_SHIFT_PORT_ENABLE_DELAY (20) 12314b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 12324b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_AUTO_PORT_ENABLE (0x00080000) 12334b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_IOCSET_DIRECT_ATTACH_SPINUP_MODE (0x00040000) 12344b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 1235c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_MASK_BOOT_PREFERENCE (0x00030000) 1236c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_ENCLOSURE_SLOT_BOOT (0x00000000) 1237c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_SAS_ADDRESS_BOOT (0x00010000) 1238c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1239c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_MASK_MAX_TARGET_SPIN_UP (0x0000F000) 1240c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE1_IOCSET_SHIFT_MAX_TARGET_SPIN_UP (12) 1241c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 12421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MASK_SPINUP_DELAY (0x00000F00) 12431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_SHIFT_SPINUP_DELAY (8) 12441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MASK_RM_SETTING (0x000000C0) 12461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_NONE_RM_SETTING (0x00000000) 12471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_BOOT_RM_SETTING (0x00000040) 12481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MEDIA_RM_SETTING (0x00000080) 12491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_MASK_ADAPTER_SUPPORT (0x00000030) 12511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_NO_SUPPORT (0x00000000) 12521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_BIOS_SUPPORT (0x00000010) 12531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_OS_SUPPORT (0x00000020) 12541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_ALL_SUPPORT (0x00000030) 12551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_IOCSET_ALTERNATE_CHS (0x00000008) 12571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for the DeviceSettings field */ 1259d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_BIOSPAGE1_DEVSET_DISABLE_SMART_POLLING (0x00000010) 12601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_SEQ_LUN (0x00000008) 12611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_RM_LUN (0x00000004) 12621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_NON_RM_LUN (0x00000002) 12631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_BIOSPAGE1_DEVSET_DISABLE_OTHER_LUN (0x00000001) 12641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 12654b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric/* defines for the ExpanderSpinup field */ 12664b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_EXPSPINUP_MASK_MAX_TARGET (0xF0) 12674b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_EXPSPINUP_SHIFT_MAX_TARGET (4) 12684b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_BIOSPAGE1_EXPSPINUP_MASK_DELAY (0x0F) 12694b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 1270c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_ADAPTER_ORDER 1271c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1272c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 00h */ 1273c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 04h */ 1274c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 08h */ 1275c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 0Ch */ 1276c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 10h */ 1277c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 14h */ 1278c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 18h */ 1279c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 1Ch */ 1280c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 20h */ 1281c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 24h */ 1282c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 28h */ 1283c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 2Ch */ 1284c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 30h */ 1285c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 34h */ 1286c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved15; /* 38h */ 1287c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved16; /* 3Ch */ 1288c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved17; /* 40h */ 1289c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_ADAPTER_ORDER, MPI_POINTER PTR_MPI_BOOT_DEVICE_ADAPTER_ORDER; 1290c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1291c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_ADAPTER_NUMBER 1292c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1293c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 TargetID; /* 00h */ 1294c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Bus; /* 01h */ 1295c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 AdapterNumber; /* 02h */ 1296c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 03h */ 1297c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 04h */ 1298c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 08h */ 1299c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 0Ch */ 1300c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1301c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 18h */ 1302c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 1Ch */ 1303c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 20h */ 1304c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 24h */ 1305c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 28h */ 1306c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 2Ch */ 1307c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 30h */ 1308c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 34h */ 1309c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 38h */ 1310c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 3Ch */ 1311c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved15; /* 40h */ 1312c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_ADAPTER_NUMBER, MPI_POINTER PTR_MPI_BOOT_DEVICE_ADAPTER_NUMBER; 1313c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1314c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_PCI_ADDRESS 1315c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1316c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 TargetID; /* 00h */ 1317c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Bus; /* 01h */ 1318c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 PCIAddress; /* 02h */ 1319c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 04h */ 1320c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 08h */ 1321c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 0Ch */ 1322c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1323c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 18h */ 1324c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 1Ch */ 1325c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 20h */ 1326c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 24h */ 1327c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 28h */ 1328c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 2Ch */ 1329c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 30h */ 1330c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 34h */ 1331c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 38h */ 1332c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 3Ch */ 1333c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 40h */ 1334c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_PCI_ADDRESS, MPI_POINTER PTR_MPI_BOOT_DEVICE_PCI_ADDRESS; 1335c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1336c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_SLOT_NUMBER 1337c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1338c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 TargetID; /* 00h */ 1339c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Bus; /* 01h */ 1340c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PCISlotNumber; /* 02h */ 1341c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 03h */ 1342c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 04h */ 1343c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 08h */ 1344c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 0Ch */ 1345c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1346c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 18h */ 1347c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 1Ch */ 1348c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 20h */ 1349c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 24h */ 1350c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 28h */ 1351c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 2Ch */ 1352c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 30h */ 1353c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 34h */ 1354c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 38h */ 1355c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved14; /* 3Ch */ 1356c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved15; /* 40h */ 1357c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_PCI_SLOT_NUMBER, MPI_POINTER PTR_MPI_BOOT_DEVICE_PCI_SLOT_NUMBER; 1358c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1359c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_FC_WWN 1360c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1361c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 WWPN; /* 00h */ 1362c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 1363c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 1364c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1365c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 18h */ 1366c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 1Ch */ 1367c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 20h */ 1368c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 24h */ 1369c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 28h */ 1370c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 2Ch */ 1371c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 30h */ 1372c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 34h */ 1373c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 38h */ 1374c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 3Ch */ 1375c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 40h */ 1376c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_FC_WWN, MPI_POINTER PTR_MPI_BOOT_DEVICE_FC_WWN; 1377c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1378c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_SAS_WWN 1379c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1380c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 SASAddress; /* 00h */ 1381c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 1382c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 1383c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1384c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 18h */ 1385c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 1Ch */ 1386c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 20h */ 1387c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 24h */ 1388c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 28h */ 1389c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 2Ch */ 1390c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 30h */ 1391c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 34h */ 1392c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 38h */ 1393c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 3Ch */ 1394c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 40h */ 1395c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_SAS_WWN, MPI_POINTER PTR_MPI_BOOT_DEVICE_SAS_WWN; 1396c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1397c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_BOOT_DEVICE_ENCLOSURE_SLOT 1398c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1399c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 EnclosureLogicalID; /* 00h */ 1400c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 1401c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 1402c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 LUN[8]; /* 10h */ 1403c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 SlotNumber; /* 18h */ 1404c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved3; /* 1Ah */ 1405c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 1Ch */ 1406c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 20h */ 1407c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 24h */ 1408c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved7; /* 28h */ 1409c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved8; /* 2Ch */ 1410c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved9; /* 30h */ 1411c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved10; /* 34h */ 1412c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved11; /* 38h */ 1413c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved12; /* 3Ch */ 1414c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved13; /* 40h */ 1415c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BOOT_DEVICE_ENCLOSURE_SLOT, 1416c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_POINTER PTR_MPI_BOOT_DEVICE_ENCLOSURE_SLOT; 1417c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1418c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef union _MPI_BIOSPAGE2_BOOT_DEVICE 1419c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1420c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_ADAPTER_ORDER AdapterOrder; 1421c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_ADAPTER_NUMBER AdapterNumber; 1422c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_PCI_ADDRESS PCIAddress; 1423c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_PCI_SLOT_NUMBER PCISlotNumber; 1424c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_FC_WWN FcWwn; 1425c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_SAS_WWN SasWwn; 1426c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BOOT_DEVICE_ENCLOSURE_SLOT EnclosureSlot; 1427c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_BIOSPAGE2_BOOT_DEVICE, MPI_POINTER PTR_MPI_BIOSPAGE2_BOOT_DEVICE; 1428c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1429c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_BIOS_2 1430c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 1431c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 1432c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 04h */ 1433c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 08h */ 1434c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 0Ch */ 1435c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved4; /* 10h */ 1436c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved5; /* 14h */ 1437c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved6; /* 18h */ 1438c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 BootDeviceForm; /* 1Ch */ 14392076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 PrevBootDeviceForm; /* 1Ch */ 1440c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved8; /* 1Eh */ 1441c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_BIOSPAGE2_BOOT_DEVICE BootDevice; /* 20h */ 1442c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_BIOS_2, MPI_POINTER PTR_CONFIG_PAGE_BIOS_2, 1443c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean BIOSPage2_t, MPI_POINTER pBIOSPage2_t; 1444c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 14452076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_BIOSPAGE2_PAGEVERSION (0x02) 1446c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1447c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_MASK (0x0F) 1448c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_ADAPTER_ORDER (0x00) 1449c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_ADAPTER_NUMBER (0x01) 1450c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_PCI_ADDRESS (0x02) 1451c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_PCI_SLOT_NUMBER (0x03) 1452c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_FC_WWN (0x04) 1453c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_BIOSPAGE2_FORM_SAS_WWN (0x05) 1454ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_BIOSPAGE2_FORM_ENCLOSURE_SLOT (0x06) 1455c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 1456fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desaitypedef struct _CONFIG_PAGE_BIOS_4 1457fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai{ 1458fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai CONFIG_PAGE_HEADER Header; /* 00h */ 1459fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai U64 ReassignmentBaseWWID; /* 04h */ 1460fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai} CONFIG_PAGE_BIOS_4, MPI_POINTER PTR_CONFIG_PAGE_BIOS_4, 1461fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai BIOSPage4_t, MPI_POINTER pBIOSPage4_t; 1462fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai 1463fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_BIOSPAGE4_PAGEVERSION (0x00) 1464fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai 14651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 14671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* SCSI Port Config Pages 14681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 14691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_PORT_0 14711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1472c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 14731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Capabilities; /* 04h */ 14741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhysicalInterface; /* 08h */ 1475c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_PORT_0, MPI_POINTER PTR_CONFIG_PAGE_SCSI_PORT_0, 14761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIPortPage0_t, MPI_POINTER pSCSIPortPage0_t; 14771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 1478c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIPORTPAGE0_PAGEVERSION (0x02) 14791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_IU (0x00000001) 14811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_DT (0x00000002) 14821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_QAS (0x00000004) 14831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_MIN_SYNC_PERIOD_MASK (0x0000FF00) 14841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_ASYNC (0x00) 14851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_5 (0x32) 14861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_10 (0x19) 14871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_20 (0x0C) 14881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_33_33 (0x0B) 14891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_40 (0x0A) 14901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_80 (0x09) 14911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_160 (0x08) 14921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_SYNC_UNKNOWN (0xFF) 14931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 14941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_SHIFT_MIN_SYNC_PERIOD (8) 14951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_GET_MIN_SYNC_PERIOD(Cap) \ 14964b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric ( ((Cap) & MPI_SCSIPORTPAGE0_CAP_MIN_SYNC_PERIOD_MASK) \ 14971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds >> MPI_SCSIPORTPAGE0_CAP_SHIFT_MIN_SYNC_PERIOD \ 14981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ) 14991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_MAX_SYNC_OFFSET_MASK (0x00FF0000) 15001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_SHIFT_MAX_SYNC_OFFSET (16) 15011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_GET_MAX_SYNC_OFFSET(Cap) \ 15024b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric ( ((Cap) & MPI_SCSIPORTPAGE0_CAP_MAX_SYNC_OFFSET_MASK) \ 15031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds >> MPI_SCSIPORTPAGE0_CAP_SHIFT_MAX_SYNC_OFFSET \ 15041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ) 1505c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIPORTPAGE0_CAP_IDP (0x08000000) 15061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_WIDE (0x20000000) 15071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_CAP_AIP (0x80000000) 15081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_TYPE_MASK (0x00000003) 15101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_HVD (0x01) 15111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_SE (0x02) 15121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SIGNAL_LVD (0x03) 15131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_MASK_CONNECTED_ID (0xFF000000) 15141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_SHIFT_CONNECTED_ID (24) 15151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_BUS_FREE_CONNECTED_ID (0xFE) 15161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE0_PHY_UNKNOWN_CONNECTED_ID (0xFF) 15171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_PORT_1 15201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1521c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 15221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Configuration; /* 04h */ 15231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 OnBusTimerValue; /* 08h */ 15241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetConfig; /* 0Ch */ 15251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 0Dh */ 15261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IDConfig; /* 0Eh */ 1527c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_PORT_1, MPI_POINTER PTR_CONFIG_PAGE_SCSI_PORT_1, 15281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIPortPage1_t, MPI_POINTER pSCSIPortPage1_t; 15291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_PAGEVERSION (0x03) 15311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* Configuration values */ 15331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_CFG_PORT_SCSI_ID_MASK (0x000000FF) 15341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_CFG_PORT_RESPONSE_ID_MASK (0xFFFF0000) 15351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_CFG_SHIFT_PORT_RESPONSE_ID (16) 15361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* TargetConfig values */ 15381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_TARGCONFIG_TARG_ONLY (0x01) 15391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE1_TARGCONFIG_INIT_TARG (0x02) 15401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_DEVICE_INFO 15431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 15441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Timeout; /* 00h */ 15451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SyncFactor; /* 01h */ 15461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DeviceFlags; /* 02h */ 15471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_DEVICE_INFO, MPI_POINTER PTR_MPI_DEVICE_INFO, 15481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MpiDeviceInfo_t, MPI_POINTER pMpiDeviceInfo_t; 15491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_PORT_2 15511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1552c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 15531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortFlags; /* 04h */ 15541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortSettings; /* 08h */ 15551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_DEVICE_INFO DeviceSettings[16]; /* 0Ch */ 1556c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_PORT_2, MPI_POINTER PTR_CONFIG_PAGE_SCSI_PORT_2, 15571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIPortPage2_t, MPI_POINTER pSCSIPortPage2_t; 15581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PAGEVERSION (0x02) 15601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* PortFlags values */ 15621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_SCAN_HIGH_TO_LOW (0x00000001) 15631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_AVOID_SCSI_RESET (0x00000004) 15641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_ALTERNATE_CHS (0x00000008) 15651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_TERMINATION_DISABLE (0x00000010) 15661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_DV_MASK (0x00000060) 15681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_FULL_DV (0x00000000) 15691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_BASIC_DV_ONLY (0x00000020) 15701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_FLAGS_OFF_DV (0x00000060) 15711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* PortSettings values */ 15741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_HOST_ID_MASK (0x0000000F) 15751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_MASK_INIT_HBA (0x00000030) 15761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_DISABLE_INIT_HBA (0x00000000) 15771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_BIOS_INIT_HBA (0x00000010) 15781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_OS_INIT_HBA (0x00000020) 15791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_BIOS_OS_INIT_HBA (0x00000030) 15801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_REMOVABLE_MEDIA (0x000000C0) 15811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_RM_NONE (0x00000000) 15821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_RM_BOOT_ONLY (0x00000040) 15831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_RM_WITH_MEDIA (0x00000080) 15841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_SPINUP_DELAY_MASK (0x00000F00) 15851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_SHIFT_SPINUP_DELAY (8) 15861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_MASK_NEGO_MASTER_SETTINGS (0x00003000) 15871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_NEGO_MASTER_SETTINGS (0x00000000) 15881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_NONE_MASTER_SETTINGS (0x00001000) 15891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_PORT_ALL_MASTER_SETTINGS (0x00003000) 15901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_DISCONNECT_ENABLE (0x0001) 15921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_ID_SCAN_ENABLE (0x0002) 15931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_LUN_SCAN_ENABLE (0x0004) 15941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_TAG_QUEUE_ENABLE (0x0008) 15951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_WIDE_DISABLE (0x0010) 15961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIPORTPAGE2_DEVICE_BOOT_CHOICE (0x0020) 15971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 15991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 16001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* SCSI Target Device Config Pages 16011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 16021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_0 16041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1605c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 16061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NegotiatedParameters; /* 04h */ 16071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Information; /* 08h */ 1608c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_0, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_0, 16091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage0_t, MPI_POINTER pSCSIDevicePage0_t; 16101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 1611c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE0_PAGEVERSION (0x04) 16121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_IU (0x00000001) 16141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_DT (0x00000002) 16151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_QAS (0x00000004) 16161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_HOLD_MCS (0x00000008) 16171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_WR_FLOW (0x00000010) 16181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_RD_STRM (0x00000020) 16191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_RTI (0x00000040) 16201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_PCOMP_EN (0x00000080) 16211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_NEG_SYNC_PERIOD_MASK (0x0000FF00) 16221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_SHIFT_SYNC_PERIOD (8) 16231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_NEG_SYNC_OFFSET_MASK (0x00FF0000) 16241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_SHIFT_SYNC_OFFSET (16) 1625c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE0_NP_IDP (0x08000000) 16261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_WIDE (0x20000000) 16271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_NP_AIP (0x80000000) 16281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_PARAMS_NEGOTIATED (0x00000001) 16301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_SDTR_REJECTED (0x00000002) 16311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_WDTR_REJECTED (0x00000004) 16321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE0_INFO_PPR_REJECTED (0x00000008) 16331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_1 16361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1637c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 16381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 RequestedParameters; /* 04h */ 16391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 08h */ 16401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Configuration; /* 0Ch */ 1641c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_1, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_1, 16421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage1_t, MPI_POINTER pSCSIDevicePage1_t; 16431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 1644c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE1_PAGEVERSION (0x05) 16451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_IU (0x00000001) 16471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_DT (0x00000002) 16481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_QAS (0x00000004) 16491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_HOLD_MCS (0x00000008) 16501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_WR_FLOW (0x00000010) 16511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_RD_STRM (0x00000020) 16521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_RTI (0x00000040) 16531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_PCOMP_EN (0x00000080) 16541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_MIN_SYNC_PERIOD_MASK (0x0000FF00) 16551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_SHIFT_MIN_SYNC_PERIOD (8) 16561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_MAX_SYNC_OFFSET_MASK (0x00FF0000) 16571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_SHIFT_MAX_SYNC_OFFSET (16) 1658c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SCSIDEVPAGE1_RP_IDP (0x08000000) 16591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_WIDE (0x20000000) 16601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_RP_AIP (0x80000000) 16611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_WDTR_DISALLOWED (0x00000002) 16631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_SDTR_DISALLOWED (0x00000004) 16641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_EXTENDED_PARAMS_ENABLE (0x00000008) 16651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE1_CONF_FORCE_PPR_MSG (0x00000010) 16661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_2 16691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1670c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 16711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DomainValidation; /* 04h */ 16721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ParityPipeSelect; /* 08h */ 16731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DataPipeSelect; /* 0Ch */ 1674c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_2, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_2, 16751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage2_t, MPI_POINTER pSCSIDevicePage2_t; 16761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_PAGEVERSION (0x01) 16781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_ISI_ENABLE (0x00000010) 16801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_SECONDARY_DRIVER_ENABLE (0x00000020) 16811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_SLEW_RATE_CTRL (0x00000380) 16821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_PRIM_DRIVE_STR_CTRL (0x00001C00) 16831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_SECOND_DRIVE_STR_CTRL (0x0000E000) 16841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKH_ST (0x10000000) 16851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKS_ST (0x20000000) 16861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKH_DT (0x40000000) 16871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DV_XCLKS_DT (0x80000000) 16881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_PPS_PPS_MASK (0x00000003) 16901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 16911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_0_PL_SELECT_MASK (0x00000003) 16921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_1_PL_SELECT_MASK (0x0000000C) 16931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_2_PL_SELECT_MASK (0x00000030) 16941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_3_PL_SELECT_MASK (0x000000C0) 16951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_4_PL_SELECT_MASK (0x00000300) 16961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_5_PL_SELECT_MASK (0x00000C00) 16971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_6_PL_SELECT_MASK (0x00003000) 16981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_7_PL_SELECT_MASK (0x0000C000) 16991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_8_PL_SELECT_MASK (0x00030000) 17001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_9_PL_SELECT_MASK (0x000C0000) 17011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_10_PL_SELECT_MASK (0x00300000) 17021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_11_PL_SELECT_MASK (0x00C00000) 17031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_12_PL_SELECT_MASK (0x03000000) 17041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_13_PL_SELECT_MASK (0x0C000000) 17051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_14_PL_SELECT_MASK (0x30000000) 17061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE2_DPS_BIT_15_PL_SELECT_MASK (0xC0000000) 17071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SCSI_DEVICE_3 17101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1711c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 17121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MsgRejectCount; /* 04h */ 17131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 PhaseErrorCount; /* 06h */ 17141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ParityErrorCount; /* 08h */ 17151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 0Ah */ 1716c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SCSI_DEVICE_3, MPI_POINTER PTR_CONFIG_PAGE_SCSI_DEVICE_3, 17171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SCSIDevicePage3_t, MPI_POINTER pSCSIDevicePage3_t; 17181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE3_PAGEVERSION (0x00) 17201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE3_MAX_COUNTER (0xFFFE) 17221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SCSIDEVPAGE3_UNSUPPORTED_COUNTER (0xFFFF) 17231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 17261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* FC Port Config Pages 17271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 17281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_0 17301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1731c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 17321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 17331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MPIPortNumber; /* 08h */ 17341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 LinkType; /* 09h */ 17351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortState; /* 0Ah */ 17361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 0Bh */ 17371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortIdentifier; /* 0Ch */ 17381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWNN; /* 10h */ 17391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWPN; /* 18h */ 17401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 SupportedServiceClass; /* 20h */ 17411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 SupportedSpeeds; /* 24h */ 17421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 CurrentSpeed; /* 28h */ 17431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxFrameSize; /* 2Ch */ 17441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 FabricWWNN; /* 30h */ 17451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 FabricWWPN; /* 38h */ 17461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DiscoveredPortsCount; /* 40h */ 17471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxInitiators; /* 44h */ 17481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxAliasesSupported; /* 48h */ 17491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 MaxHardAliasesSupported; /* 49h */ 17501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumCurrentAliases; /* 4Ah */ 17511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 4Bh */ 1752c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_0, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_0, 17531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage0_t, MPI_POINTER pFCPortPage0_t; 17541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PAGEVERSION (0x02) 17561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_MASK (0x0000000F) 17581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_FCP_INIT (MPI_PORTFACTS_PROTOCOL_INITIATOR) 17591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_FCP_TARG (MPI_PORTFACTS_PROTOCOL_TARGET) 17601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_LAN (MPI_PORTFACTS_PROTOCOL_LAN) 17611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_PROT_LOGBUSADDR (MPI_PORTFACTS_PROTOCOL_LOGBUSADDR) 17621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ALIAS_ALPA_SUPPORTED (0x00000010) 17641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ALIAS_WWN_SUPPORTED (0x00000020) 17651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_FABRIC_WWN_VALID (0x00000040) 17661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_TYPE_MASK (0x00000F00) 17681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_NO_INIT (0x00000000) 17691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_POINT_TO_POINT (0x00000100) 17701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_PRIVATE_LOOP (0x00000200) 17711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_FABRIC_DIRECT (0x00000400) 17721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_FLAGS_ATTACH_PUBLIC_LOOP (0x00000800) 17731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_RESERVED (0x00) 17751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_OTHER (0x01) 17761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_UNKNOWN (0x02) 17771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_COPPER (0x03) 17781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_SINGLE_1300 (0x04) 17791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_SINGLE_1500 (0x05) 17801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_50_LASER_MULTI (0x06) 17811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_50_LED_MULTI (0x07) 17821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_62_LASER_MULTI (0x08) 17831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_62_LED_MULTI (0x09) 17841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_MULTI_LONG_WAVE (0x0A) 17851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_MULTI_SHORT_WAVE (0x0B) 17861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_LASER_SHORT_WAVE (0x0C) 17871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_LED_SHORT_WAVE (0x0D) 17881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_1300_LONG_WAVE (0x0E) 17891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_LTYPE_1500_LONG_WAVE (0x0F) 17901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 17911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_UNKNOWN (0x01) /*(SNIA)HBA_PORTSTATE_UNKNOWN 1 Unknown */ 17921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_ONLINE (0x02) /*(SNIA)HBA_PORTSTATE_ONLINE 2 Operational */ 17931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_OFFLINE (0x03) /*(SNIA)HBA_PORTSTATE_OFFLINE 3 User Offline */ 17941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_BYPASSED (0x04) /*(SNIA)HBA_PORTSTATE_BYPASSED 4 Bypassed */ 17951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_DIAGNOST (0x05) /*(SNIA)HBA_PORTSTATE_DIAGNOSTICS 5 In diagnostics mode */ 17961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_LINKDOWN (0x06) /*(SNIA)HBA_PORTSTATE_LINKDOWN 6 Link Down */ 17971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_ERROR (0x07) /*(SNIA)HBA_PORTSTATE_ERROR 7 Port Error */ 17981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_PORTSTATE_LOOPBACK (0x08) /*(SNIA)HBA_PORTSTATE_LOOPBACK 8 Loopback */ 17991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_CLASS_1 (0x00000001) 18011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_CLASS_2 (0x00000002) 18021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_CLASS_3 (0x00000004) 18031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_SPEED_UKNOWN (0x00000000) /* (SNIA)HBA_PORTSPEED_UNKNOWN 0 Unknown - transceiver incapable of reporting */ 18051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_1GBIT_SPEED (0x00000001) /* (SNIA)HBA_PORTSPEED_1GBIT 1 1 GBit/sec */ 18061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_2GBIT_SPEED (0x00000002) /* (SNIA)HBA_PORTSPEED_2GBIT 2 2 GBit/sec */ 18071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_10GBIT_SPEED (0x00000004) /* (SNIA)HBA_PORTSPEED_10GBIT 4 10 GBit/sec */ 18081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_SUPPORT_4GBIT_SPEED (0x00000008) /* (SNIA)HBA_PORTSPEED_4GBIT 8 4 GBit/sec */ 18091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_UKNOWN MPI_FCPORTPAGE0_SUPPORT_SPEED_UKNOWN 18111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_1GBIT MPI_FCPORTPAGE0_SUPPORT_1GBIT_SPEED 18121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_2GBIT MPI_FCPORTPAGE0_SUPPORT_2GBIT_SPEED 18131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_10GBIT MPI_FCPORTPAGE0_SUPPORT_10GBIT_SPEED 18141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_4GBIT MPI_FCPORTPAGE0_SUPPORT_4GBIT_SPEED 18151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE0_CURRENT_SPEED_NOT_NEGOTIATED (0x00008000) /* (SNIA)HBA_PORTSPEED_NOT_NEGOTIATED (1<<15) Speed not established */ 18161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_1 18191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1820c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 18211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Flags; /* 04h */ 18221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 NoSEEPROMWWNN; /* 08h */ 18231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 NoSEEPROMWWPN; /* 10h */ 18241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HardALPA; /* 18h */ 18251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 LinkConfig; /* 19h */ 18261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TopologyConfig; /* 1Ah */ 18271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 AltConnector; /* 1Bh */ 18281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumRequestedAliases; /* 1Ch */ 18291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 RR_TOV; /* 1Dh */ 18301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InitiatorDeviceTimeout; /* 1Eh */ 18311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InitiatorIoPendTimeout; /* 1Fh */ 1832c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_1, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_1, 18331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage1_t, MPI_POINTER pFCPortPage1_t; 18341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_PAGEVERSION (0x06) 18361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_EXT_FCP_STATUS_EN (0x08000000) 18381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_IMMEDIATE_ERROR_REPLY (0x04000000) 18391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_FORCE_USE_NOSEEPROM_WWNS (0x02000000) 18401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_VERBOSE_RESCAN_EVENTS (0x01000000) 18411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_TARGET_MODE_OXID (0x00800000) 18421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PORT_OFFLINE (0x00400000) 18431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SOFT_ALPA_FALLBACK (0x00200000) 1844c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_FCPORTPAGE1_FLAGS_TARGET_LARGE_CDB_ENABLE (0x00000080) 18451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_MASK_RR_TOV_UNITS (0x00000070) 18461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SUPPRESS_PROT_REG (0x00000008) 18471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PLOGI_ON_LOGO (0x00000004) 18481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_MAINTAIN_LOGINS (0x00000002) 18491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SORT_BY_DID (0x00000001) 18501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_SORT_BY_WWN (0x00000000) 18511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_MASK (0xF0000000) 18531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT (28) 18541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_FCP_INIT ((U32)MPI_PORTFACTS_PROTOCOL_INITIATOR << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 18551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_FCP_TARG ((U32)MPI_PORTFACTS_PROTOCOL_TARGET << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 18561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_LAN ((U32)MPI_PORTFACTS_PROTOCOL_LAN << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 18571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_PROT_LOGBUSADDR ((U32)MPI_PORTFACTS_PROTOCOL_LOGBUSADDR << MPI_FCPORTPAGE1_FLAGS_PROT_SHIFT) 18581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_NONE_RR_TOV_UNITS (0x00000000) 18601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_THOUSANDTH_RR_TOV_UNITS (0x00000010) 18611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_TENTH_RR_TOV_UNITS (0x00000030) 18621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_FLAGS_TEN_RR_TOV_UNITS (0x00000050) 18631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_HARD_ALPA_NOT_USED (0xFF) 18651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_MASK (0x0F) 18671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_1GIG (0x00) 18681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_2GIG (0x01) 18691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_4GIG (0x02) 18701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_10GIG (0x03) 18711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_LCONFIG_SPEED_AUTO (0x0F) 18721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_MASK (0x0F) 18741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_NLPORT (0x01) 18751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_NPORT (0x02) 18761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_TOPOLOGY_AUTO (0x0F) 18771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_ALT_CONN_UNKNOWN (0x00) 18791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE1_INITIATOR_DEV_TIMEOUT_MASK (0x7F) 1881c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_FCPORTPAGE1_INITIATOR_DEV_UNIT_16 (0x80) 18821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_2 18851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1886c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 18871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumberActive; /* 04h */ 18881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ALPA[127]; /* 05h */ 1889c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_2, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_2, 18901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage2_t, MPI_POINTER pFCPortPage2_t; 18911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE2_PAGEVERSION (0x01) 18931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 18951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _WWN_FORMAT 18961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 18971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWNN; /* 00h */ 18981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWPN; /* 08h */ 18991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} WWN_FORMAT, MPI_POINTER PTR_WWN_FORMAT, 19001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds WWNFormat, MPI_POINTER pWWNFormat; 19011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef union _FC_PORT_PERSISTENT_PHYSICAL_ID 19031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 19041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds WWN_FORMAT WWN; 19051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Did; 19061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} FC_PORT_PERSISTENT_PHYSICAL_ID, MPI_POINTER PTR_FC_PORT_PERSISTENT_PHYSICAL_ID, 19071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds PersistentPhysicalId_t, MPI_POINTER pPersistentPhysicalId_t; 19081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _FC_PORT_PERSISTENT 19101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 19111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FC_PORT_PERSISTENT_PHYSICAL_ID PhysicalIdentifier; /* 00h */ 19121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetID; /* 10h */ 19131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bus; /* 11h */ 19141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Flags; /* 12h */ 19151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} FC_PORT_PERSISTENT, MPI_POINTER PTR_FC_PORT_PERSISTENT, 19161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds PersistentData_t, MPI_POINTER pPersistentData_t; 19171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_SHIFT (16) 19191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_ENTRY_VALID (0x0001) 19201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_SCAN_ID (0x0002) 19211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_SCAN_LUNS (0x0004) 19221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_BOOT_DEVICE (0x0008) 19231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PERSISTENT_FLAGS_BY_DID (0x0080) 19241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 19261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 19271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 19281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 19291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_FC_PORT_PAGE_3_ENTRY_MAX 19301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_PORT_PAGE_3_ENTRY_MAX (1) 19311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 19321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_3 19341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1935c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 19361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FC_PORT_PERSISTENT Entry[MPI_FC_PORT_PAGE_3_ENTRY_MAX]; /* 04h */ 1937c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_3, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_3, 19381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage3_t, MPI_POINTER pFCPortPage3_t; 19391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE3_PAGEVERSION (0x01) 19411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_4 19441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1945c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 19461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortFlags; /* 04h */ 19471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortSettings; /* 08h */ 1948c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_4, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_4, 19491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage4_t, MPI_POINTER pFCPortPage4_t; 19501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PAGEVERSION (0x00) 19521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_FLAGS_ALTERNATE_CHS (0x00000008) 19541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_MASK_INIT_HBA (0x00000030) 19561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_DISABLE_INIT_HBA (0x00000000) 19571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_BIOS_INIT_HBA (0x00000010) 19581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_OS_INIT_HBA (0x00000020) 19591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_BIOS_OS_INIT_HBA (0x00000030) 19601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_REMOVABLE_MEDIA (0x000000C0) 19611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE4_PORT_SPINUP_DELAY_MASK (0x00000F00) 19621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_5_ALIAS_INFO 19651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 19661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 00h */ 19671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 AliasAlpa; /* 01h */ 19681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 19691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 AliasWWNN; /* 04h */ 19701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 AliasWWPN; /* 0Ch */ 1971c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_5_ALIAS_INFO, 19721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_5_ALIAS_INFO, 19731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FcPortPage5AliasInfo_t, MPI_POINTER pFcPortPage5AliasInfo_t; 19741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_5 19761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1977c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 1978c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_FC_PORT_5_ALIAS_INFO AliasInfo; /* 04h */ 1979c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_5, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_5, 19801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage5_t, MPI_POINTER pFCPortPage5_t; 19811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_PAGEVERSION (0x02) 19831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_ALPA_ACQUIRED (0x01) 19851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_HARD_ALPA (0x02) 19861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_HARD_WWNN (0x04) 19871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_HARD_WWPN (0x08) 19881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE5_FLAGS_DISABLE (0x10) 19891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 19901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_6 19911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 1992c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 19931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 04h */ 19941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 TimeSinceReset; /* 08h */ 19951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 TxFrames; /* 10h */ 19961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 RxFrames; /* 18h */ 19971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 TxWords; /* 20h */ 19981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 RxWords; /* 28h */ 19991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LipCount; /* 30h */ 20001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 NosCount; /* 38h */ 20011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 ErrorFrames; /* 40h */ 20021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 DumpedFrames; /* 48h */ 20031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LinkFailureCount; /* 50h */ 20041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LossOfSyncCount; /* 58h */ 20051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 LossOfSignalCount; /* 60h */ 20061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 PrimativeSeqErrCount; /* 68h */ 20071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 InvalidTxWordCount; /* 70h */ 20081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 InvalidCrcCount; /* 78h */ 20091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 FcpInitiatorIoCount; /* 80h */ 2010c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_6, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_6, 20111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage6_t, MPI_POINTER pFCPortPage6_t; 20121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE6_PAGEVERSION (0x00) 20141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_7 20171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2018c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 20191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 04h */ 20201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortSymbolicName[256]; /* 08h */ 2021c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_7, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_7, 20221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage7_t, MPI_POINTER pFCPortPage7_t; 20231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE7_PAGEVERSION (0x00) 20251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_8 20281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2029c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 20301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BitVector[8]; /* 04h */ 2031c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_8, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_8, 20321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage8_t, MPI_POINTER pFCPortPage8_t; 20331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE8_PAGEVERSION (0x00) 20351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_9 20381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2039c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 20401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved; /* 04h */ 20411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 GlobalWWPN; /* 08h */ 20421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 GlobalWWNN; /* 10h */ 20431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 UnitType; /* 18h */ 20441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhysicalPortNumber; /* 1Ch */ 20451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NumAttachedNodes; /* 20h */ 20461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 IPVersion; /* 24h */ 20471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 UDPPortNumber; /* 26h */ 20481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 IPAddress[16]; /* 28h */ 20491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved1; /* 38h */ 20501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 TopologyDiscoveryFlags; /* 3Ah */ 2051c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_9, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_9, 20521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage9_t, MPI_POINTER pFCPortPage9_t; 20531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE9_PAGEVERSION (0x00) 20551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA 20581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 20591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Id; /* 10h */ 20601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ExtId; /* 11h */ 20611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Connector; /* 12h */ 20621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Transceiver[8]; /* 13h */ 20631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Encoding; /* 1Bh */ 20641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BitRate_100mbs; /* 1Ch */ 20651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 1Dh */ 20661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length9u_km; /* 1Eh */ 20671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length9u_100m; /* 1Fh */ 20681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length50u_10m; /* 20h */ 20691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Length62p5u_10m; /* 21h */ 20701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 LengthCopper_m; /* 22h */ 20711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reseverved2; /* 22h */ 20721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorName[16]; /* 24h */ 20731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved3; /* 34h */ 20741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorOUI[3]; /* 35h */ 20751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorPN[16]; /* 38h */ 20761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorRev[4]; /* 48h */ 2077c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Wavelength; /* 4Ch */ 2078c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved4; /* 4Eh */ 20791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CC_BASE; /* 4Fh */ 2080c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA, 20811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA, 20821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage10BaseSfpData_t, MPI_POINTER pFCPortPage10BaseSfpData_t; 20831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_UNKNOWN (0x00) 20851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_GBIC (0x01) 20861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_FIXED (0x02) 20871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_SFP (0x03) 20881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_SFP_MIN (0x04) 20891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_SFP_MAX (0x7F) 20901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ID_VEND_SPEC_MASK (0x80) 20911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 20921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_UNKNOWN (0x00) 20931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF1 (0x01) 20941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF2 (0x02) 20951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF3 (0x03) 20961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_SEEPROM (0x04) 20971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF5 (0x05) 20981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF6 (0x06) 20991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_MODDEF7 (0x07) 21001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_EXTID_VNDSPC_MASK (0x80) 21011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_UNKNOWN (0x00) 21031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_SC (0x01) 21041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_COPPER1 (0x02) 21051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_COPPER2 (0x03) 21061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_BNC_TNC (0x04) 21071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_COAXIAL (0x05) 21081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_FIBERJACK (0x06) 21091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_LC (0x07) 21101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_MT_RJ (0x08) 21111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_MU (0x09) 21121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_SG (0x0A) 21131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_OPT_PIGT (0x0B) 21141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV1_MIN (0x0C) 21151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV1_MAX (0x1F) 21161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_HSSDC_II (0x20) 21171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_CPR_PIGT (0x21) 21181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV2_MIN (0x22) 21191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_RSV2_MAX (0x7F) 21201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_CONN_VNDSPC_MASK (0x80) 21211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_UNSPEC (0x00) 21231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_8B10B (0x01) 21241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_4B5B (0x02) 21251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_NRZ (0x03) 21261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_BASE_ENCODE_MANCHESTER (0x04) 21271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA 21301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 21311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Options[2]; /* 50h */ 21321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BitRateMax; /* 52h */ 21331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 BitRateMin; /* 53h */ 21341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorSN[16]; /* 54h */ 21351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 DateCode[8]; /* 64h */ 2136c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 DiagMonitoringType; /* 6Ch */ 2137c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 EnhancedOptions; /* 6Dh */ 2138c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SFF8472Compliance; /* 6Eh */ 21391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CC_EXT; /* 6Fh */ 2140c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA, 21411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA, 21421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage10ExtendedSfpData_t, MPI_POINTER pFCPortPage10ExtendedSfpData_t; 21431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_RATESEL (0x20) 21451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_TX_DISABLE (0x10) 21461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_TX_FAULT (0x08) 21471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_LOS_INVERT (0x04) 21481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORT10_EXT_OPTION1_LOS (0x02) 21491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_PORT_10 21521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2153c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 21541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 04h */ 21551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 05h */ 21561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved2; /* 06h */ 21571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HwConfig1; /* 08h */ 21581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HwConfig2; /* 0Ch */ 2159c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_FC_PORT_10_BASE_SFP_DATA Base; /* 10h */ 2160c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_FC_PORT_10_EXTENDED_SFP_DATA Extended; /* 50h */ 21611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorSpecific[32]; /* 70h */ 2162c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_PORT_10, MPI_POINTER PTR_CONFIG_PAGE_FC_PORT_10, 21631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCPortPage10_t, MPI_POINTER pFCPortPage10_t; 21641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2165c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_FCPORTPAGE10_PAGEVERSION (0x01) 21661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* standard MODDEF pin definitions (from GBIC spec.) */ 21681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_MASK (0x00000007) 21691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF2 (0x00000001) 21701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF1 (0x00000002) 21711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF0 (0x00000004) 21721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_NOGBIC (0x00000007) 21731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_CPR_IEEE_CX (0x00000006) 21741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_COPPER (0x00000005) 21751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_OPTICAL_LW (0x00000004) 21761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_SEEPROM (0x00000003) 21771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_SW_OPTICAL (0x00000002) 21781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_LX_IEEE_OPT_LW (0x00000001) 21791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_MODDEF_SX_IEEE_OPT_SW (0x00000000) 21801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_CC_BASE_OK (0x00000010) 21821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FCPORTPAGE10_FLAGS_CC_EXT_OK (0x00000020) 21831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 21861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* FC Device Config Pages 21871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 21881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 21891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_FC_DEVICE_0 21901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2191c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 21921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWNN; /* 04h */ 21931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 WWPN; /* 0Ch */ 21941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PortIdentifier; /* 14h */ 21951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Protocol; /* 18h */ 21961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 19h */ 21971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 BBCredit; /* 1Ah */ 21981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MaxRxFrameSize; /* 1Ch */ 21991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ADISCHardALPA; /* 1Eh */ 22001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortNumber; /* 1Fh */ 22011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 FcPhLowestVersion; /* 20h */ 22021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 FcPhHighestVersion; /* 21h */ 22031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CurrentTargetID; /* 22h */ 22041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CurrentBus; /* 23h */ 2205c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_FC_DEVICE_0, MPI_POINTER PTR_CONFIG_PAGE_FC_DEVICE_0, 22061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds FCDevicePage0_t, MPI_POINTER pFCDevicePage0_t; 22071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PAGEVERSION (0x03) 22091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_FLAGS_TARGETID_BUS_VALID (0x01) 22111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_FLAGS_PLOGI_INVALID (0x02) 22121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_FLAGS_PRLI_INVALID (0x04) 22131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_IP (0x01) 22151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_FCP_TARGET (0x02) 22161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_FCP_INITIATOR (0x04) 22171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PROT_FCP_RETRY (0x08) 22181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_PORT_MASK (MPI_FC_DEVICE_PGAD_PORT_MASK) 22201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_FORM_MASK (MPI_FC_DEVICE_PGAD_FORM_MASK) 22211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_FORM_NEXT_DID (MPI_FC_DEVICE_PGAD_FORM_NEXT_DID) 22221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_FORM_BUS_TID (MPI_FC_DEVICE_PGAD_FORM_BUS_TID) 22231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_DID_MASK (MPI_FC_DEVICE_PGAD_ND_DID_MASK) 22241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_BUS_MASK (MPI_FC_DEVICE_PGAD_BT_BUS_MASK) 22251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_BUS_SHIFT (MPI_FC_DEVICE_PGAD_BT_BUS_SHIFT) 22261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_PGAD_TID_MASK (MPI_FC_DEVICE_PGAD_BT_TID_MASK) 22271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_FC_DEVICE_PAGE0_HARD_ALPA_UNKNOWN (0xFF) 22291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 22311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* RAID Volume Config Pages 22321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 22331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_VOL0_PHYS_DISK 22351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 00h */ 22371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskMap; /* 02h */ 22381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 03h */ 22391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_VOL0_PHYS_DISK, MPI_POINTER PTR_RAID_VOL0_PHYS_DISK, 22401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVol0PhysDisk_t, MPI_POINTER pRaidVol0PhysDisk_t; 22411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_PHYSDISK_PRIMARY (0x01) 22431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_PHYSDISK_SECONDARY (0x02) 22441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_VOL0_STATUS 22461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 00h */ 22481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 State; /* 01h */ 22491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 22501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_VOL0_STATUS, MPI_POINTER PTR_RAID_VOL0_STATUS, 22511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVol0Status_t, MPI_POINTER pRaidVol0Status_t; 22521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume Page 0 VolumeStatus defines */ 22541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_ENABLED (0x01) 22551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_QUIESCED (0x02) 22561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_RESYNC_IN_PROGRESS (0x04) 22571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_FLAG_VOLUME_INACTIVE (0x08) 2258ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAIDVOL0_STATUS_FLAG_BAD_BLOCK_TABLE_FULL (0x10) 22591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_STATE_OPTIMAL (0x00) 22611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_STATE_DEGRADED (0x01) 22621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_STATUS_STATE_FAILED (0x02) 2263c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOL0_STATUS_STATE_MISSING (0x03) 22641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_VOL0_SETTINGS 22661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 22671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Settings; /* 00h */ 22681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HotSparePool; /* 01h */ /* MPI_RAID_HOT_SPARE_POOL_ */ 22691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved; /* 02h */ 22701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_VOL0_SETTINGS, MPI_POINTER PTR_RAID_VOL0_SETTINGS, 22711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVol0Settings, MPI_POINTER pRaidVol0Settings; 22721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume Page 0 VolumeSettings defines */ 22741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_WRITE_CACHING_ENABLE (0x0001) 22751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_OFFLINE_ON_SMART (0x0002) 22761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_AUTO_CONFIGURE (0x0004) 22771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_PRIORITY_RESYNC (0x0008) 2278c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOL0_SETTING_FAST_DATA_SCRUBBING_0102 (0x0020) /* obsolete */ 2279eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 2280eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_RAIDVOL0_SETTING_MASK_METADATA_SIZE (0x00C0) 2281eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_RAIDVOL0_SETTING_64MB_METADATA_SIZE (0x0000) 2282eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_RAIDVOL0_SETTING_512MB_METADATA_SIZE (0x0040) 2283eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore 22841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_USE_PRODUCT_ID_SUFFIX (0x0010) 22851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAIDVOL0_SETTING_USE_DEFAULTS (0x8000) 22861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* RAID Volume Page 0 HotSparePool defines, also used in RAID Physical Disk */ 22881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_0 (0x01) 22891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_1 (0x02) 22901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_2 (0x04) 22911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_3 (0x08) 22921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_4 (0x10) 22931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_5 (0x20) 22941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_6 (0x40) 22951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_HOT_SPARE_POOL_7 (0x80) 22961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 22971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 22981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 22991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 23001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 23011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_RAID_VOL_PAGE_0_PHYSDISK_MAX 23021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_RAID_VOL_PAGE_0_PHYSDISK_MAX (1) 23031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 23041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_RAID_VOL_0 23061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2307c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 23081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeID; /* 04h */ 23091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeBus; /* 05h */ 23101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeIOC; /* 06h */ 23111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VolumeType; /* 07h */ /* MPI_RAID_VOL_TYPE_ */ 23121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_VOL0_STATUS VolumeStatus; /* 08h */ 23131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_VOL0_SETTINGS VolumeSettings; /* 0Ch */ 23141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxLBA; /* 10h */ 23152076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 MaxLBAHigh; /* 14h */ 23161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 StripeSize; /* 18h */ 23171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved2; /* 1Ch */ 23181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved3; /* 20h */ 23191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhysDisks; /* 24h */ 2320c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 DataScrubRate; /* 25h */ 2321c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ResyncRate; /* 26h */ 2322c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 InactiveStatus; /* 27h */ 23231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_VOL0_PHYS_DISK PhysDisk[MPI_RAID_VOL_PAGE_0_PHYSDISK_MAX];/* 28h */ 2324c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_VOL_0, MPI_POINTER PTR_CONFIG_PAGE_RAID_VOL_0, 23251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidVolumePage0_t, MPI_POINTER pRaidVolumePage0_t; 23261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2327eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_RAIDVOLPAGE0_PAGEVERSION (0x07) 2328c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2329c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for RAID Volume Page 0 InactiveStatus field */ 2330c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_UNKNOWN_INACTIVE (0x00) 2331c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_STALE_METADATA_INACTIVE (0x01) 2332c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_FOREIGN_VOLUME_INACTIVE (0x02) 2333c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_INSUFFICIENT_RESOURCE_INACTIVE (0x03) 2334c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_CLONE_VOLUME_INACTIVE (0x04) 2335c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_INSUFFICIENT_METADATA_INACTIVE (0x05) 2336c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE0_PREVIOUSLY_DELETED (0x06) 2337c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2338c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2339c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_RAID_VOL_1 2340c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2341c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 2342d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 VolumeID; /* 04h */ 2343d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 VolumeBus; /* 05h */ 2344d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 VolumeIOC; /* 06h */ 2345d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 Reserved0; /* 07h */ 2346d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 GUID[24]; /* 08h */ 2347c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Name[32]; /* 20h */ 2348c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 WWID; /* 40h */ 2349c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 48h */ 2350c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 4Ch */ 2351c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_VOL_1, MPI_POINTER PTR_CONFIG_PAGE_RAID_VOL_1, 2352c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RaidVolumePage1_t, MPI_POINTER pRaidVolumePage1_t; 2353c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2354c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDVOLPAGE1_PAGEVERSION (0x01) 23551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 23581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* RAID Physical Disk Config Pages 23591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 23601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK0_ERROR_DATA 23621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 23631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorCdbByte; /* 00h */ 23641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorSenseKey; /* 01h */ 23651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 23661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ErrorCount; /* 04h */ 23671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorASC; /* 06h */ 23681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ErrorASCQ; /* 07h */ 23691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 SmartCount; /* 08h */ 23701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SmartASC; /* 0Ah */ 23711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SmartASCQ; /* 0Bh */ 23721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_ERROR_DATA, MPI_POINTER PTR_RAID_PHYS_DISK0_ERROR_DATA, 23731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDisk0ErrorData_t, MPI_POINTER pRaidPhysDisk0ErrorData_t; 23741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK_INQUIRY_DATA 23761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 23771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 VendorID[8]; /* 00h */ 23781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ProductID[16]; /* 08h */ 23791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 ProductRevLevel[4]; /* 18h */ 23801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Info[32]; /* 1Ch */ 23811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_INQUIRY_DATA, MPI_POINTER PTR_RAID_PHYS_DISK0_INQUIRY_DATA, 23821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDisk0InquiryData, MPI_POINTER pRaidPhysDisk0InquiryData; 23831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK0_SETTINGS 23851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 23861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SepID; /* 00h */ 23871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SepBus; /* 01h */ 23881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 HotSparePool; /* 02h */ /* MPI_RAID_HOT_SPARE_POOL_ */ 23891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskSettings; /* 03h */ 23901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_SETTINGS, MPI_POINTER PTR_RAID_PHYS_DISK0_SETTINGS, 23911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDiskSettings_t, MPI_POINTER pRaidPhysDiskSettings_t; 23921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 23931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _RAID_PHYS_DISK0_STATUS 23941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 23951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 00h */ 23961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 State; /* 01h */ 23971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 02h */ 23981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} RAID_PHYS_DISK0_STATUS, MPI_POINTER PTR_RAID_PHYS_DISK0_STATUS, 23991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDiskStatus_t, MPI_POINTER pRaidPhysDiskStatus_t; 24001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2401d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore/* RAID Physical Disk PhysDiskStatus flags */ 24021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FLAG_OUT_OF_SYNC (0x01) 24041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FLAG_QUIESCED (0x02) 2405c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_PHYSDISK0_STATUS_FLAG_INACTIVE_VOLUME (0x04) 2406ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_PHYSDISK0_STATUS_FLAG_OPTIMAL_PREVIOUS (0x00) 2407ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_PHYSDISK0_STATUS_FLAG_NOT_OPTIMAL_PREVIOUS (0x08) 24081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_ONLINE (0x00) 24101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_MISSING (0x01) 24111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_NOT_COMPATIBLE (0x02) 24121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FAILED (0x03) 24131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_INITIALIZING (0x04) 24141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_OFFLINE_REQUESTED (0x05) 24151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_FAILED_REQUESTED (0x06) 24161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_PHYSDISK0_STATUS_OTHER_OFFLINE (0xFF) 24171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_RAID_PHYS_DISK_0 24191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2420c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 24211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskID; /* 04h */ 24221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskBus; /* 05h */ 24231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskIOC; /* 06h */ 24241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysDiskNum; /* 07h */ 24251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_SETTINGS PhysDiskSettings; /* 08h */ 24261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 0Ch */ 2427c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ExtDiskIdentifier[8]; /* 10h */ 24281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 DiskIdentifier[16]; /* 18h */ 24291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_INQUIRY_DATA InquiryData; /* 28h */ 24301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_STATUS PhysDiskStatus; /* 64h */ 24311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxLBA; /* 68h */ 24321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RAID_PHYS_DISK0_ERROR_DATA ErrorData; /* 6Ch */ 2433c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_PHYS_DISK_0, MPI_POINTER PTR_CONFIG_PAGE_RAID_PHYS_DISK_0, 24341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds RaidPhysDiskPage0_t, MPI_POINTER pRaidPhysDiskPage0_t; 24351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2436ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_RAIDPHYSDISKPAGE0_PAGEVERSION (0x02) 2437c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2438c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2439c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _RAID_PHYS_DISK1_PATH 2440c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2441c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysDiskID; /* 00h */ 2442c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysDiskBus; /* 01h */ 2443c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved1; /* 02h */ 2444c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 WWID; /* 04h */ 2445c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 OwnerWWID; /* 0Ch */ 2446c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 OwnerIdentifier; /* 14h */ 2447c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved2; /* 15h */ 2448c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Flags; /* 16h */ 2449c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} RAID_PHYS_DISK1_PATH, MPI_POINTER PTR_RAID_PHYS_DISK1_PATH, 2450c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RaidPhysDisk1Path_t, MPI_POINTER pRaidPhysDisk1Path_t; 2451c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2452c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* RAID Physical Disk Page 1 Flags field defines */ 2453c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAID_PHYSDISK1_FLAG_BROKEN (0x0002) 2454c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAID_PHYSDISK1_FLAG_INVALID (0x0001) 2455c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2456fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai 2457fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai/* 2458fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 2459fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai * one and check Header.PageLength or NumPhysDiskPaths at runtime. 2460fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai */ 2461fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#ifndef MPI_RAID_PHYS_DISK1_PATH_MAX 2462fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_RAID_PHYS_DISK1_PATH_MAX (1) 2463fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#endif 2464fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai 2465c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_RAID_PHYS_DISK_1 2466c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2467c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 2468c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NumPhysDiskPaths; /* 04h */ 2469c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysDiskNum; /* 05h */ 2470c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved2; /* 06h */ 2471c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 2472fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai RAID_PHYS_DISK1_PATH Path[MPI_RAID_PHYS_DISK1_PATH_MAX];/* 0Ch */ 2473c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_RAID_PHYS_DISK_1, MPI_POINTER PTR_CONFIG_PAGE_RAID_PHYS_DISK_1, 2474c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean RaidPhysDiskPage1_t, MPI_POINTER pRaidPhysDiskPage1_t; 2475c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2476c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_RAIDPHYSDISKPAGE1_PAGEVERSION (0x00) 24771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 24801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* LAN Config Pages 24811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 24821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_LAN_0 24841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 24851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t Header; /* 00h */ 24861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 TxRxModes; /* 04h */ 24871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 06h */ 24881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PacketPrePad; /* 08h */ 2489c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_LAN_0, MPI_POINTER PTR_CONFIG_PAGE_LAN_0, 24901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds LANPage0_t, MPI_POINTER pLANPage0_t; 24911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_PAGEVERSION (0x01) 24931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_RETURN_LOOPBACK (0x0000) 24951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_SUPPRESS_LOOPBACK (0x0001) 24961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE0_LOOPBACK_MASK (0x0001) 24971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 24981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_LAN_1 24991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 25001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds ConfigPageHeader_t Header; /* 00h */ 25011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved; /* 04h */ 25021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 CurrentDeviceState; /* 06h */ 25031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved1; /* 07h */ 25041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MinPacketSize; /* 08h */ 25051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxPacketSize; /* 0Ch */ 25061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HardwareAddressLow; /* 10h */ 25071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 HardwareAddressHigh; /* 14h */ 25081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxWireSpeedLow; /* 18h */ 25091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxWireSpeedHigh; /* 1Ch */ 25101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 BucketsRemaining; /* 20h */ 25111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxReplySize; /* 24h */ 25121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NegWireSpeedLow; /* 28h */ 25131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 NegWireSpeedHigh; /* 2Ch */ 2514c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_LAN_1, MPI_POINTER PTR_CONFIG_PAGE_LAN_1, 25151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds LANPage1_t, MPI_POINTER pLANPage1_t; 25161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE1_PAGEVERSION (0x03) 25181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE1_DEV_STATE_RESET (0x00) 25201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_LAN_PAGE1_DEV_STATE_OPERATIONAL (0x01) 25211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 25241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* Inband Config Pages 25251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 25261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_INBAND_0 25281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2529c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_PAGE_HEADER Header; /* 00h */ 25301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_VERSION_FORMAT InbandVersion; /* 04h */ 25311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MaximumBuffers; /* 08h */ 25321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved1; /* 0Ah */ 2533c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_INBAND_0, MPI_POINTER PTR_CONFIG_PAGE_INBAND_0, 25341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds InbandPage0_t, MPI_POINTER pInbandPage0_t; 25351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_INBAND_PAGEVERSION (0x00) 25371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25401da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/**************************************************************************** 25411da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds* SAS IO Unit Config Pages 25421da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds****************************************************************************/ 25431da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25441da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_SAS_IO_UNIT0_PHY_DATA 25451da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 25461da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Port; /* 00h */ 25471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PortFlags; /* 01h */ 25481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhyFlags; /* 02h */ 25491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NegotiatedLinkRate; /* 03h */ 25501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 ControllerPhyDeviceInfo;/* 04h */ 25511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 AttachedDeviceHandle; /* 08h */ 25521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ControllerDevHandle; /* 0Ah */ 2553c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 DiscoveryStatus; /* 0Ch */ 25541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_SAS_IO_UNIT0_PHY_DATA, MPI_POINTER PTR_MPI_SAS_IO_UNIT0_PHY_DATA, 25551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnit0PhyData, MPI_POINTER pSasIOUnit0PhyData; 25561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 25581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 25591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 25601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 25611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_SAS_IOUNIT0_PHY_MAX 25621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_MAX (1) 25631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 25641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_0 25661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2567c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 25682076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 NvdataVersionDefault; /* 08h */ 25692076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 NvdataVersionPersistent; /* 0Ah */ 25701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhys; /* 0Ch */ 25711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 0Dh */ 25721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Reserved3; /* 0Eh */ 25731da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds MPI_SAS_IO_UNIT0_PHY_DATA PhyData[MPI_SAS_IOUNIT0_PHY_MAX]; /* 10h */ 2574c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_0, 25751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage0_t, MPI_POINTER pSasIOUnitPage0_t; 25761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25772076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SASIOUNITPAGE0_PAGEVERSION (0x04) 25781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 PortFlags */ 25801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_DISCOVERY_IN_PROGRESS (0x08) 25811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_0_TARGET_IOC_NUM (0x00) 25821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_1_TARGET_IOC_NUM (0x04) 25831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PORT_FLAGS_AUTO_PORT_CONFIG (0x01) 25841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 PhyFlags */ 25861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_FLAGS_PHY_DISABLED (0x04) 25871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_FLAGS_TX_INVERT (0x02) 25881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_PHY_FLAGS_RX_INVERT (0x01) 25891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 NegotiatedLinkRate */ 25911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_UNKNOWN (0x00) 25921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_PHY_DISABLED (0x01) 25931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_FAILED_SPEED_NEGOTIATION (0x02) 25941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_SATA_OOB_COMPLETE (0x03) 25951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_1_5 (0x08) 25961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT0_RATE_3_0 (0x09) 2597d75733d51fdab5c99a0d9491b25f22e13b39cdc1Kashyap, Desai#define MPI_SAS_IOUNIT0_RATE_6_0 (0x0A) 25981da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 25991da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* see mpi_sas.h for values for SAS IO Unit Page 0 ControllerPhyDeviceInfo values */ 26001da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2601c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS IO Unit Page 0 DiscoveryStatus */ 2602c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_LOOP_DETECTED (0x00000001) 2603c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_UNADDRESSABLE_DEVICE (0x00000002) 2604c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_MULTIPLE_PORTS (0x00000004) 2605c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_EXPANDER_ERR (0x00000008) 2606c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SMP_TIMEOUT (0x00000010) 2607c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_OUT_ROUTE_ENTRIES (0x00000020) 2608c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_INDEX_NOT_EXIST (0x00000040) 2609c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SMP_FUNCTION_FAILED (0x00000080) 2610c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SMP_CRC_ERROR (0x00000100) 2611c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_SUBTRACTIVE_LINK (0x00000200) 2612c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_TABLE_LINK (0x00000400) 2613c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT0_DS_UNSUPPORTED_DEVICE (0x00000800) 2614ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_IOUNIT0_DS_MAX_SATA_TARGETS (0x00001000) 2615d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_SAS_IOUNIT0_DS_MULTI_PORT_DOMAIN (0x00002000) 2616c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 26171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _MPI_SAS_IO_UNIT1_PHY_DATA 26191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 26202076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 Port; /* 00h */ 26212076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 PortFlags; /* 01h */ 26222076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 PhyFlags; /* 02h */ 26232076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 MaxMinLinkRate; /* 03h */ 26242076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U32 ControllerPhyDeviceInfo; /* 04h */ 26252076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 MaxTargetPortConnectTime; /* 08h */ 26262076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved1; /* 0Ah */ 26271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds} MPI_SAS_IO_UNIT1_PHY_DATA, MPI_POINTER PTR_MPI_SAS_IO_UNIT1_PHY_DATA, 26281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnit1PhyData, MPI_POINTER pSasIOUnit1PhyData; 26291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* 26311da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 26321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds * one and check Header.PageLength at runtime. 26331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds */ 26341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#ifndef MPI_SAS_IOUNIT1_PHY_MAX 26351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT1_PHY_MAX (1) 26361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 26371da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26381da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_1 26391da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2640c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2641c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 ControlFlags; /* 08h */ 2642c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 MaxNumSATATargets; /* 0Ah */ 26432076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 AdditionalControlFlags; /* 0Ch */ 26442076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U16 Reserved1; /* 0Eh */ 2645c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NumPhys; /* 10h */ 2646c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SATAMaxQDepth; /* 11h */ 26472076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 ReportDeviceMissingDelay; /* 12h */ 26482076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore U8 IODeviceMissingDelay; /* 13h */ 2649c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_SAS_IO_UNIT1_PHY_DATA PhyData[MPI_SAS_IOUNIT1_PHY_MAX]; /* 14h */ 2650c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_1, 26511da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage1_t, MPI_POINTER pSasIOUnitPage1_t; 26521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2653eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SASIOUNITPAGE1_PAGEVERSION (0x07) 2654c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2655c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS IO Unit Page 1 ControlFlags */ 26564b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEVICE_SELF_TEST (0x8000) 26574b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_3_0_MAX (0x4000) 26584b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_1_5_MAX (0x2000) 26594b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_SW_PRESERVE (0x1000) 26604b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DISABLE_SAS_HASH (0x0800) 26614b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 26624b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_MASK_DEV_SUPPORT (0x0600) 26634b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SHIFT_DEV_SUPPORT (9) 26644b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEV_SUPPORT_BOTH (0x00) 26654b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEV_SAS_SUPPORT (0x01) 26664b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_DEV_SATA_SUPPORT (0x02) 26674b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric 26684b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_POSTPONE_SATA_INIT (0x0100) 26694b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_48BIT_LBA_REQUIRED (0x0080) 26704b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_SMART_REQUIRED (0x0040) 26714b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_NCQ_REQUIRED (0x0020) 26724b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SATA_FUA_REQUIRED (0x0010) 26734b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_PHY_ENABLE_ORDER_HIGH (0x0008) 26744b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_SUBTRACTIVE_ILLEGAL (0x0004) 26754b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_FIRST_LVL_DISC_ONLY (0x0002) 26764b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_CONTROL_CLEAR_AFFILIATION (0x0001) 2677c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 26782076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* values for SAS IO Unit Page 1 AdditionalControlFlags */ 2679d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_SAS_IOUNIT1_ACONTROL_MULTI_PORT_DOMAIN_ILLEGAL (0x0080) 2680eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_SATA_ASYNCHROUNOUS_NOTIFICATION (0x0040) 2681eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_HIDE_NONZERO_ATTACHED_PHY_IDENT (0x0020) 2682eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_PORT_ENABLE_ONLY_SATA_LINK_RESET (0x0010) 2683eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_OTHER_AFFILIATION_SATA_LINK_RESET (0x0008) 2684eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_SELF_AFFILIATION_SATA_LINK_RESET (0x0004) 2685eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_NO_AFFILIATION_SATA_LINK_RESET (0x0002) 2686eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT1_ACONTROL_ALLOW_TABLE_TO_TABLE (0x0001) 26872076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 26882076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore/* defines for SAS IO Unit Page 1 ReportDeviceMissingDelay */ 26892076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SAS_IOUNIT1_REPORT_MISSING_TIMEOUT_MASK (0x7F) 26902076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore#define MPI_SAS_IOUNIT1_REPORT_MISSING_UNIT_16 (0x80) 26912076eb6ab8339bf09620a0160be3607bbbb61a50Eric Moore 2692c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS IO Unit Page 1 PortFlags */ 26934b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PORT_FLAGS_0_TARGET_IOC_NUM (0x00) 26944b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PORT_FLAGS_1_TARGET_IOC_NUM (0x04) 26954b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PORT_FLAGS_AUTO_PORT_CONFIG (0x01) 26961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 26971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 PhyFlags */ 26984b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PHY_FLAGS_PHY_DISABLE (0x04) 26994b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PHY_FLAGS_TX_INVERT (0x02) 27004b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_PHY_FLAGS_RX_INVERT (0x01) 27011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 0 MaxMinLinkRate */ 27034b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MAX_RATE_MASK (0xF0) 27044b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MAX_RATE_1_5 (0x80) 27054b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MAX_RATE_3_0 (0x90) 27064b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MIN_RATE_MASK (0x0F) 27074b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MIN_RATE_1_5 (0x08) 27084b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT1_MIN_RATE_3_0 (0x09) 27091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* see mpi_sas.h for values for SAS IO Unit Page 1 ControllerPhyDeviceInfo values */ 27111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_2 27141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2715c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 27164b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 NumDevsPerEnclosure; /* 08h */ 27174b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 Reserved1; /* 09h */ 27184b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 Reserved2; /* 0Ah */ 27191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 MaxPersistentIDs; /* 0Ch */ 27201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 NumPersistentIDsUsed; /* 0Eh */ 27211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Status; /* 10h */ 27221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 11h */ 27234b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 MaxNumPhysicalMappedIDs;/* 12h */ 2724c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_2, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_2, 27251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage2_t, MPI_POINTER pSasIOUnitPage2_t; 27261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2727eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SASIOUNITPAGE2_PAGEVERSION (0x06) 27281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 2 Status field */ 2730eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT2_STATUS_DEVICE_LIMIT_EXCEEDED (0x08) 2731eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_IOUNIT2_STATUS_ENCLOSURE_DEVICES_UNMAPPED (0x04) 27321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT2_STATUS_DISABLED_PERSISTENT_MAPPINGS (0x02) 27331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT2_STATUS_FULL_PERSISTENT_MAPPINGS (0x01) 27341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS IO Unit Page 2 Flags field */ 27361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_IOUNIT2_FLAGS_DISABLE_PERSISTENT_MAPPINGS (0x01) 2737c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* Physical Mapping Modes */ 2738c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_MASK_PHYS_MAP_MODE (0x0E) 2739c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_SHIFT_PHYS_MAP_MODE (1) 2740c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_NO_PHYS_MAP (0x00) 2741c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_DIRECT_ATTACH_PHYS_MAP (0x01) 2742c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_ENCLOSURE_SLOT_PHYS_MAP (0x02) 27434b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SAS_IOUNIT2_FLAGS_HOST_ASSIGNED_PHYS_MAP (0x07) 2744c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2745c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_IOUNIT2_FLAGS_RESERVE_ID_0_FOR_BOOT (0x10) 2746ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_IOUNIT2_FLAGS_DA_STARTING_SLOT (0x20) 27471da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27481da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27491da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_IO_UNIT_3 27501da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2751c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 27521da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 08h */ 27531da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxInvalidDwordCount; /* 0Ch */ 27541da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 InvalidDwordCountTime; /* 10h */ 27551da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxRunningDisparityErrorCount; /* 14h */ 27561da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 RunningDisparityErrorTime; /* 18h */ 27571da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxLossDwordSynchCount; /* 1Ch */ 27581da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 LossDwordSynchCountTime; /* 20h */ 27591da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 MaxPhyResetProblemCount; /* 24h */ 27601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhyResetProblemTime; /* 28h */ 2761c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_IO_UNIT_3, MPI_POINTER PTR_CONFIG_PAGE_SAS_IO_UNIT_3, 27621da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasIOUnitPage3_t, MPI_POINTER pSasIOUnitPage3_t; 27631da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27641da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SASIOUNITPAGE3_PAGEVERSION (0x00) 27651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2767c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2768c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS Expander Config Pages 2769c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2770c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 27711da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_EXPANDER_0 27721da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2773c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2774c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysicalPort; /* 08h */ 2775c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 09h */ 27764b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 EnclosureHandle; /* 0Ah */ 27771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 2778c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 DiscoveryStatus; /* 14h */ 27791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DevHandle; /* 18h */ 27801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ParentDevHandle; /* 1Ah */ 27811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExpanderChangeCount; /* 1Ch */ 27821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 ExpanderRouteIndexes; /* 1Eh */ 27831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 NumPhys; /* 20h */ 27841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 SASLevel; /* 21h */ 27851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Flags; /* 22h */ 27861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved3; /* 23h */ 2787c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_EXPANDER_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_EXPANDER_0, 27881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasExpanderPage0_t, MPI_POINTER pSasExpanderPage0_t; 27891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 27904b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_SASEXPANDER0_PAGEVERSION (0x03) 2791c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2792c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Expander Page 0 DiscoveryStatus field */ 2793c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_LOOP_DETECTED (0x00000001) 2794c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_UNADDRESSABLE_DEVICE (0x00000002) 2795c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_MULTIPLE_PORTS (0x00000004) 2796c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_EXPANDER_ERR (0x00000008) 2797c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SMP_TIMEOUT (0x00000010) 2798c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_OUT_ROUTE_ENTRIES (0x00000020) 2799c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_INDEX_NOT_EXIST (0x00000040) 2800c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SMP_FUNCTION_FAILED (0x00000080) 2801c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SMP_CRC_ERROR (0x00000100) 2802c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_SUBTRACTIVE_LINK (0x00000200) 2803c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_TABLE_LINK (0x00000400) 2804c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER0_DS_UNSUPPORTED_DEVICE (0x00000800) 28051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS Expander Page 0 Flags field */ 2807d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_SAS_EXPANDER0_FLAGS_CONNECTOR_END_DEVICE (0x04) 28081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_EXPANDER0_FLAGS_ROUTE_TABLE_CONFIG (0x02) 28091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_EXPANDER0_FLAGS_CONFIG_IN_PROGRESS (0x01) 28101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 28111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2812c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_SAS_EXPANDER_1 2813c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2814c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2815c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhysicalPort; /* 08h */ 2816c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved1; /* 09h */ 2817c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved2; /* 0Ah */ 2818c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NumPhys; /* 0Ch */ 2819c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Phy; /* 0Dh */ 2820c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 NumTableEntriesProgrammed; /* 0Eh */ 2821c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ProgrammedLinkRate; /* 10h */ 2822c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 HwLinkRate; /* 11h */ 2823c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 AttachedDevHandle; /* 12h */ 2824c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 PhyInfo; /* 14h */ 2825c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 AttachedDeviceInfo; /* 18h */ 2826c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 OwnerDevHandle; /* 1Ch */ 2827c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 ChangeCount; /* 1Eh */ 2828c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 NegotiatedLinkRate; /* 1Fh */ 2829c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhyIdentifier; /* 20h */ 2830c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 AttachedPhyIdentifier; /* 21h */ 28314b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 Reserved3; /* 22h */ 2832c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 DiscoveryInfo; /* 23h */ 28334b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 Reserved4; /* 24h */ 2834c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_EXPANDER_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_EXPANDER_1, 2835c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SasExpanderPage1_t, MPI_POINTER pSasExpanderPage1_t; 2836c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2837c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SASEXPANDER1_PAGEVERSION (0x01) 2838c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2839c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* use MPI_SAS_PHY0_PRATE_ defines for ProgrammedLinkRate */ 2840c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2841c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* use MPI_SAS_PHY0_HWRATE_ defines for HwLinkRate */ 2842c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2843c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* use MPI_SAS_PHY0_PHYINFO_ defines for PhyInfo */ 2844c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2845c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* see mpi_sas.h for values for SAS Expander Page 1 AttachedDeviceInfo values */ 2846c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2847c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Expander Page 1 DiscoveryInfo field */ 2848d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore#define MPI_SAS_EXPANDER1_DISCINFO_BAD_PHY_DISABLED (0x04) 2849c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_DISCINFO_LINK_STATUS_CHANGE (0x02) 2850c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_DISCINFO_NO_ROUTING_ENTRIES (0x01) 2851c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2852c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Expander Page 1 NegotiatedLinkRate field */ 2853c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_UNKNOWN (0x00) 2854c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_PHY_DISABLED (0x01) 2855c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_FAILED_NEGOTIATION (0x02) 2856c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_SATA_OOB_COMPLETE (0x03) 2857c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_1_5 (0x08) 2858c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_EXPANDER1_NEG_RATE_3_0 (0x09) 2859c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2860c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2861c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2862c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS Device Config Pages 2863c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2864c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 28651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_DEVICE_0 28661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2867c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2868c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Slot; /* 08h */ 2869c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 EnclosureHandle; /* 0Ah */ 28701da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 2871c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 ParentDevHandle; /* 14h */ 2872c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 PhyNum; /* 16h */ 2873c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 AccessStatus; /* 17h */ 28741da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DevHandle; /* 18h */ 28751da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetID; /* 1Ah */ 28761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bus; /* 1Bh */ 28771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 DeviceInfo; /* 1Ch */ 28781da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 Flags; /* 20h */ 28791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 PhysicalPort; /* 22h */ 2880c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 Reserved2; /* 23h */ 2881c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_DEVICE_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_DEVICE_0, 28821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasDevicePage0_t, MPI_POINTER pSasDevicePage0_t; 28831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2884eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SASDEVICE0_PAGEVERSION (0x05) 2885c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2886c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Device Page 0 AccessStatus field */ 2887eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_NO_ERRORS (0x00) 2888eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SATA_INIT_FAILED (0x01) 2889eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SATA_CAPABILITY_FAILED (0x02) 2890eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SATA_AFFILIATION_CONFLICT (0x03) 2891fd7a253311412b3fc7c85586552c90eca61e7d23Kashyap, Desai#define MPI_SAS_DEVICE0_ASTATUS_SATA_NEEDS_INITIALIZATION (0x04) 2892eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore/* specific values for SATA Init failures */ 2893eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_UNKNOWN (0x10) 2894eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_AFFILIATION_CONFLICT (0x11) 2895eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_DIAG (0x12) 2896eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_IDENTIFICATION (0x13) 2897eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_CHECK_POWER (0x14) 2898eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_PIO_SN (0x15) 2899eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_MDMA_SN (0x16) 2900eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_UDMA_SN (0x17) 2901eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_ZONING_VIOLATION (0x18) 2902eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_NOT_ADDRESSABLE (0x19) 2903eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_ASTATUS_SIF_MAX (0x1F) 29041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS Device Page 0 Flags field */ 2906eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_SATA_ASYNCHRONOUS_NOTIFY (0x0400) 2907eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_SATA_SW_PRESERVE (0x0200) 2908eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_UNSUPPORTED_DEVICE (0x0100) 2909eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_SATA_48BIT_LBA_SUPPORTED (0x0080) 2910eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_SATA_SMART_SUPPORTED (0x0040) 2911eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_SATA_NCQ_SUPPORTED (0x0020) 2912eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_SATA_FUA_SUPPORTED (0x0010) 2913eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_PORT_SELECTOR_ATTACH (0x0008) 2914eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_MAPPING_PERSISTENT (0x0004) 2915eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED (0x0002) 2916eae225eb5947825bc4e845c33ded9aedd74407cfEric Moore#define MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT (0x0001) 29171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* see mpi_sas.h for values for SAS Device Page 0 DeviceInfo values */ 29191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_DEVICE_1 29221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2923c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 29241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 08h */ 29251da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 29261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved2; /* 14h */ 29271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 DevHandle; /* 18h */ 29281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 TargetID; /* 1Ah */ 29291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Bus; /* 1Bh */ 29301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 InitialRegDeviceFIS[20];/* 1Ch */ 2931c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_DEVICE_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_DEVICE_1, 29321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasDevicePage1_t, MPI_POINTER pSasDevicePage1_t; 29331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SASDEVICE1_PAGEVERSION (0x00) 29351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2937c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_SAS_DEVICE_2 2938c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 2939c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2940c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 PhysicalIdentifier; /* 08h */ 2941ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U32 EnclosureMapping; /* 10h */ 2942c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_DEVICE_2, MPI_POINTER PTR_CONFIG_PAGE_SAS_DEVICE_2, 2943c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SasDevicePage2_t, MPI_POINTER pSasDevicePage2_t; 2944c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2945ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_PAGEVERSION (0x01) 2946ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig 2947ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig/* defines for SAS Device Page 2 EnclosureMapping field */ 2948ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_MASK_MISSING_COUNT (0x0000000F) 2949ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_SHIFT_MISSING_COUNT (0) 2950ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_MASK_NUM_SLOTS (0x000007F0) 2951ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_SHIFT_NUM_SLOTS (4) 2952ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_MASK_START_INDEX (0x001FF800) 2953ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASDEVICE2_ENC_MAP_SHIFT_START_INDEX (11) 2954c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2955c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 2956c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 2957c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS PHY Config Pages 2958c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 2959c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 29601da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_PHY_0 29611da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 2962c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 2963ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U16 OwnerDevHandle; /* 08h */ 2964ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig U16 Reserved1; /* 0Ah */ 29651da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U64 SASAddress; /* 0Ch */ 29661da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U16 AttachedDevHandle; /* 14h */ 29671da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 AttachedPhyIdentifier; /* 16h */ 29681da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U8 Reserved2; /* 17h */ 29691da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 AttachedDeviceInfo; /* 18h */ 2970d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 ProgrammedLinkRate; /* 1Ch */ 2971d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 HwLinkRate; /* 1Dh */ 2972d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 ChangeCount; /* 1Eh */ 2973d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U8 Flags; /* 1Fh */ 2974d16291b1f2656f2bb1beea5fcce3eb0d1546e981Eric Moore U32 PhyInfo; /* 20h */ 2975c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_PHY_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_PHY_0, 29761da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasPhyPage0_t, MPI_POINTER pSasPhyPage0_t; 29771da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2978ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASPHY0_PAGEVERSION (0x01) 29791da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29801da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS PHY Page 0 ProgrammedLinkRate field */ 29811da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_MASK (0xF0) 29821da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_NOT_PROGRAMMABLE (0x00) 29831da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_1_5 (0x80) 29841da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MAX_RATE_3_0 (0x90) 29851da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_MASK (0x0F) 29861da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_NOT_PROGRAMMABLE (0x00) 29871da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_1_5 (0x08) 29881da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PRATE_MIN_RATE_3_0 (0x09) 29891da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 29901da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS PHY Page 0 HwLinkRate field */ 29911da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MAX_RATE_MASK (0xF0) 29921da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MAX_RATE_1_5 (0x80) 29931da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MAX_RATE_3_0 (0x90) 29941da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MIN_RATE_MASK (0x0F) 29951da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MIN_RATE_1_5 (0x08) 29961da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_HWRATE_MIN_RATE_3_0 (0x09) 29971da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 2998ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig/* values for SAS PHY Page 0 Flags field */ 2999ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_PHY0_FLAGS_SGPIO_DIRECT_ATTACH_ENC (0x01) 3000ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig 30011da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds/* values for SAS PHY Page 0 PhyInfo field */ 30021da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SATA_PORT_ACTIVE (0x00004000) 30031da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SATA_PORT_SELECTOR (0x00002000) 30041da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_VIRTUAL_PHY (0x00001000) 30051da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30061da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_MASK_PARTIAL_PATHWAY_TIME (0x00000F00) 30071da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SHIFT_PARTIAL_PATHWAY_TIME (8) 30081da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30091da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_MASK_ROUTING_ATTRIBUTE (0x000000F0) 30101da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_DIRECT_ROUTING (0x00000000) 30111da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SUBTRACTIVE_ROUTING (0x00000010) 30121da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_TABLE_ROUTING (0x00000020) 30131da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30141da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_MASK_LINK_RATE (0x0000000F) 30151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_UNKNOWN_LINK_RATE (0x00000000) 30161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_PHY_DISABLED (0x00000001) 30171da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_NEGOTIATION_FAILED (0x00000002) 30181da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_SATA_OOB_COMPLETE (0x00000003) 30191da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_RATE_1_5 (0x00000008) 30201da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SAS_PHY0_PHYINFO_RATE_3_0 (0x00000009) 30211da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30221da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30231da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvaldstypedef struct _CONFIG_PAGE_SAS_PHY_1 30241da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds{ 3025c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 30261da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 Reserved1; /* 08h */ 30271da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 InvalidDwordCount; /* 0Ch */ 30281da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 RunningDisparityErrorCount; /* 10h */ 30291da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 LossDwordSynchCount; /* 14h */ 30301da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds U32 PhyResetProblemCount; /* 18h */ 3031c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_PHY_1, MPI_POINTER PTR_CONFIG_PAGE_SAS_PHY_1, 30321da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds SasPhyPage1_t, MPI_POINTER pSasPhyPage1_t; 30331da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30341da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#define MPI_SASPHY1_PAGEVERSION (0x00) 30351da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 30361da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3037c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 3038c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* SAS Enclosure Config Pages 3039c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 3040c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3041c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_SAS_ENCLOSURE_0 3042c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 3043c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 3044c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 3045c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U64 EnclosureLogicalID; /* 0Ch */ 3046c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Flags; /* 14h */ 3047c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 EnclosureHandle; /* 16h */ 3048c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 NumSlots; /* 18h */ 3049c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 StartSlot; /* 1Ah */ 3050c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 StartTargetID; /* 1Ch */ 3051c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 StartBus; /* 1Dh */ 3052c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SEPTargetID; /* 1Eh */ 3053c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U8 SEPBus; /* 1Fh */ 3054c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 20h */ 3055c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved3; /* 24h */ 3056c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_SAS_ENCLOSURE_0, MPI_POINTER PTR_CONFIG_PAGE_SAS_ENCLOSURE_0, 3057c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean SasEnclosurePage0_t, MPI_POINTER pSasEnclosurePage0_t; 3058c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3059ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SASENCLOSURE0_PAGEVERSION (0x01) 3060c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3061c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for SAS Enclosure Page 0 Flags field */ 3062c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_SEP_BUS_ID_VALID (0x0020) 3063c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_START_BUS_ID_VALID (0x0010) 3064c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3065c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_MASK (0x000F) 3066c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_UNKNOWN (0x0000) 3067c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_IOC_SES (0x0001) 3068c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_IOC_SGPIO (0x0002) 3069c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_EXP_SGPIO (0x0003) 3070c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_SAS_ENCLS0_FLAGS_MNG_SES_ENCLOSURE (0x0004) 3071ccf3b7bd26b242b39d54148ea2117295721681d3Christoph Hellwig#define MPI_SAS_ENCLS0_FLAGS_MNG_IOC_GPIO (0x0005) 3072c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3073c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3074c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/**************************************************************************** 3075c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean* Log Config Pages 3076c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean****************************************************************************/ 3077c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* 3078c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * Host code (drivers, BIOS, utilities, etc.) should leave this define set to 3079c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean * one and check NumLogEntries at runtime. 3080c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean */ 3081c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#ifndef MPI_LOG_0_NUM_LOG_ENTRIES 3082c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_LOG_0_NUM_LOG_ENTRIES (1) 3083c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#endif 3084c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 30854b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_LOG_0_LOG_DATA_LENGTH (0x1C) 3086c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3087c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _MPI_LOG_0_ENTRY 3088c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 30894b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 TimeStamp; /* 00h */ 30904b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U32 Reserved1; /* 04h */ 30914b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 LogSequence; /* 08h */ 30924b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U16 LogEntryQualifier; /* 0Ah */ 30934b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric U8 LogData[MPI_LOG_0_LOG_DATA_LENGTH]; /* 0Ch */ 3094c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} MPI_LOG_0_ENTRY, MPI_POINTER PTR_MPI_LOG_0_ENTRY, 3095c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MpiLog0Entry_t, MPI_POINTER pMpiLog0Entry_t; 3096c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3097c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean/* values for Log Page 0 LogEntry LogEntryQualifier field */ 3098c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_LOG_0_ENTRY_QUAL_ENTRY_UNUSED (0x0000) 3099c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean#define MPI_LOG_0_ENTRY_QUAL_POWER_ON_RESET (0x0001) 3100c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3101c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Deantypedef struct _CONFIG_PAGE_LOG_0 3102c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean{ 3103c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean CONFIG_EXTENDED_PAGE_HEADER Header; /* 00h */ 3104c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved1; /* 08h */ 3105c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U32 Reserved2; /* 0Ch */ 3106c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 NumLogEntries; /* 10h */ 3107c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean U16 Reserved3; /* 12h */ 3108c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean MPI_LOG_0_ENTRY LogEntry[MPI_LOG_0_NUM_LOG_ENTRIES]; /* 14h */ 3109c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean} CONFIG_PAGE_LOG_0, MPI_POINTER PTR_CONFIG_PAGE_LOG_0, 3110c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean LogPage0_t, MPI_POINTER pLogPage0_t; 3111c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 31124b915a73663fe0951077ebcdaf02337ff2bddcfcMoore, Eric#define MPI_LOG_0_PAGEVERSION (0x01) 3113c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 3114c1a71d1c0440c47e006845f8accc1f212ca86852Moore, Eric Dean 31151da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds#endif 31161da177e4c3f41524e886b7f1b8a0c1fc7321cacLinus Torvalds 3117