e1000: update base driver
[dpdk.git] / lib / librte_pmd_e1000 / e1000 / e1000_defines.h
index 8f67050..febf304 100644 (file)
@@ -44,13 +44,7 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_WUC_PME_EN       0x00000002 /* PME Enable */
 #define E1000_WUC_PME_STATUS   0x00000004 /* PME Status */
 #define E1000_WUC_APMPME       0x00000008 /* Assert PME on APM Wakeup */
-#define E1000_WUC_LSCWE                0x00000010 /* Link Status wake up enable */
-#define E1000_WUC_PPROXYE      0x00000010 /* Protocol Proxy Enable */
-#define E1000_WUC_LSCWO                0x00000020 /* Link Status wake up override */
-#define E1000_WUC_SPM          0x80000000 /* Enable SPM */
 #define E1000_WUC_PHY_WAKE     0x00000100 /* if PHY supports wakeup */
-#define E1000_WUC_FLX6_PHY     0x4000 /* Flexible Filter 6 Enable */
-#define E1000_WUC_FLX7_PHY     0x8000 /* Flexible Filter 7 Enable */
 
 /* Wake Up Filter Control */
 #define E1000_WUFC_LNKC        0x00000001 /* Link Status Change Wakeup Enable */
@@ -60,41 +54,7 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_WUFC_BC  0x00000010 /* Broadcast Wakeup Enable */
 #define E1000_WUFC_ARP 0x00000020 /* ARP Request Packet Wakeup Enable */
 #define E1000_WUFC_IPV4        0x00000040 /* Directed IPv4 Packet Wakeup Enable */
-#define E1000_WUFC_IPV6        0x00000080 /* Directed IPv6 Packet Wakeup Enable */
-#define E1000_WUFC_IGNORE_TCO_PHY 0x00000800 /* Ignore WakeOn TCO packets */
-#define E1000_WUFC_FLX0_PHY    0x00001000 /* Flexible Filter 0 Enable */
-#define E1000_WUFC_FLX1_PHY    0x00002000 /* Flexible Filter 1 Enable */
-#define E1000_WUFC_FLX2_PHY    0x00004000 /* Flexible Filter 2 Enable */
-#define E1000_WUFC_FLX3_PHY    0x00008000 /* Flexible Filter 3 Enable */
-#define E1000_WUFC_FLX4_PHY    0x00000200 /* Flexible Filter 4 Enable */
-#define E1000_WUFC_FLX5_PHY    0x00000400 /* Flexible Filter 5 Enable */
-#define E1000_WUFC_IGNORE_TCO  0x00008000 /* Ignore WakeOn TCO packets */
 #define E1000_WUFC_FLX0                0x00010000 /* Flexible Filter 0 Enable */
-#define E1000_WUFC_FLX1                0x00020000 /* Flexible Filter 1 Enable */
-#define E1000_WUFC_FLX2                0x00040000 /* Flexible Filter 2 Enable */
-#define E1000_WUFC_FLX3                0x00080000 /* Flexible Filter 3 Enable */
-#define E1000_WUFC_FLX4                0x00100000 /* Flexible Filter 4 Enable */
-#define E1000_WUFC_FLX5                0x00200000 /* Flexible Filter 5 Enable */
-#define E1000_WUFC_FLX6                0x00400000 /* Flexible Filter 6 Enable */
-#define E1000_WUFC_FLX7                0x00800000 /* Flexible Filter 7 Enable */
-#define E1000_WUFC_FW_RST      0x80000000 /* Wake on FW Reset Enable */
-#define E1000_WUFC_ALL_FILTERS_PHY_4   0x0000F0FF /* wakeup filters mask */
-#define E1000_WUFC_FLX_OFFSET_PHY      12 /* Flexible Filters bits offset */
-#define E1000_WUFC_FLX_FILTERS_PHY_4   0x0000F000 /* 4 flexible filters mask */
-#define E1000_WUFC_ALL_FILTERS_PHY_6   0x0000F6FF /* 6 wakeup filters mask */
-#define E1000_WUFC_FLX_FILTERS_PHY_6   0x0000F600 /* 6 flexible filters mask */
-#define E1000_WUFC_ALL_FILTERS         0x000F00FF /* all wakeup filters mask */
-#define E1000_WUFC_ALL_FILTERS_6       0x003F00FF /* Mask all 6 wu filters */
-#define E1000_WUFC_ALL_FILTERS_8       0x00FF00FF /* Mask all 8 wu filters */
-#define E1000_WUFC_FLX_OFFSET          16 /* Flexible Filters bits offset */
-#define E1000_WUFC_FLX_FILTERS         0x000F0000 /* 4 flexible filters mask */
-#define E1000_WUFC_FLX_FILTERS_6       0x003F0000 /* 6 flexible filters mask */
-#define E1000_WUFC_FLX_FILTERS_8       0x00FF0000 /* 8 flexible filters mask */
-/*
- * For 82576 to utilize Extended filter masks in addition to
- * existing (filter) masks
- */
-#define E1000_WUFC_EXT_FLX_FILTERS     0x00300000 /* Ext. FLX filter mask */
 
 /* Wake Up Status */
 #define E1000_WUS_LNKC         E1000_WUFC_LNKC
@@ -102,74 +62,18 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_WUS_EX           E1000_WUFC_EX
 #define E1000_WUS_MC           E1000_WUFC_MC
 #define E1000_WUS_BC           E1000_WUFC_BC
-#define E1000_WUS_ARP          E1000_WUFC_ARP
-#define E1000_WUS_IPV4         E1000_WUFC_IPV4
-#define E1000_WUS_IPV6         E1000_WUFC_IPV6
-#define E1000_WUS_FLX0_PHY     E1000_WUFC_FLX0_PHY
-#define E1000_WUS_FLX1_PHY     E1000_WUFC_FLX1_PHY
-#define E1000_WUS_FLX2_PHY     E1000_WUFC_FLX2_PHY
-#define E1000_WUS_FLX3_PHY     E1000_WUFC_FLX3_PHY
-#define E1000_WUS_FLX_FILTERS_PHY_4    E1000_WUFC_FLX_FILTERS_PHY_4
-#define E1000_WUS_FLX0         E1000_WUFC_FLX0
-#define E1000_WUS_FLX1         E1000_WUFC_FLX1
-#define E1000_WUS_FLX2         E1000_WUFC_FLX2
-#define E1000_WUS_FLX3         E1000_WUFC_FLX3
-#define E1000_WUS_FLX4         E1000_WUFC_FLX4
-#define E1000_WUS_FLX5         E1000_WUFC_FLX5
-#define E1000_WUS_FLX6         E1000_WUFC_FLX6
-#define E1000_WUS_FLX7         E1000_WUFC_FLX7
-#define E1000_WUS_FLX4_PHY     E1000_WUFC_FLX4_PHY
-#define E1000_WUS_FLX5_PHY     E1000_WUFC_FLX5_PHY
-#define E1000_WUS_FLX6_PHY     0x0400
-#define E1000_WUS_FLX7_PHY     0x0800
-#define E1000_WUS_FLX_FILTERS  E1000_WUFC_FLX_FILTERS
-#define E1000_WUS_FLX_FILTERS_6                E1000_WUFC_FLX_FILTERS_6
-#define E1000_WUS_FLX_FILTERS_8                E1000_WUFC_FLX_FILTERS_8
-#define E1000_WUS_FLX_FILTERS_PHY_6    E1000_WUFC_FLX_FILTERS_PHY_6
-
-/* Wake Up Packet Length */
-#define E1000_WUPL_LENGTH_MASK 0x0FFF   /* Only the lower 12 bits are valid */
-
-/* Four Flexible Filters are supported */
-#define E1000_FLEXIBLE_FILTER_COUNT_MAX                4
-/* Six Flexible Filters are supported */
-#define E1000_FLEXIBLE_FILTER_COUNT_MAX_6      6
-/* Eight Flexible Filters are supported */
-#define E1000_FLEXIBLE_FILTER_COUNT_MAX_8      8
-/* Two Extended Flexible Filters are supported (82576) */
-#define E1000_EXT_FLEXIBLE_FILTER_COUNT_MAX    2
-#define E1000_FHFT_LENGTH_OFFSET       0xFC /* Length byte in FHFT */
-#define E1000_FHFT_LENGTH_MASK         0x0FF /* Length in lower byte */
-
-/* Each Flexible Filter is at most 128 (0x80) bytes in length */
-#define E1000_FLEXIBLE_FILTER_SIZE_MAX 128
-
-#define E1000_FFLT_SIZE                E1000_FLEXIBLE_FILTER_COUNT_MAX
-#define E1000_FFLT_SIZE_6      E1000_FLEXIBLE_FILTER_COUNT_MAX_6
-#define E1000_FFLT_SIZE_8      E1000_FLEXIBLE_FILTER_COUNT_MAX_8
-#define E1000_FFMT_SIZE                E1000_FLEXIBLE_FILTER_SIZE_MAX
-#define E1000_FFVT_SIZE                E1000_FLEXIBLE_FILTER_SIZE_MAX
 
 /* Extended Device Control */
-#define E1000_CTRL_EXT_GPI0_EN         0x00000001 /* Maps SDP4 to GPI0 */
-#define E1000_CTRL_EXT_GPI1_EN         0x00000002 /* Maps SDP5 to GPI1 */
-#define E1000_CTRL_EXT_PHYINT_EN       E1000_CTRL_EXT_GPI1_EN
-#define E1000_CTRL_EXT_GPI2_EN         0x00000004 /* Maps SDP6 to GPI2 */
-#define E1000_CTRL_EXT_GPI3_EN         0x00000008 /* Maps SDP7 to GPI3 */
-/* Reserved (bits 4,5) in >= 82575 */
+#define E1000_CTRL_EXT_LPCD            0x00000004 /* LCD Power Cycle Done */
 #define E1000_CTRL_EXT_SDP4_DATA       0x00000010 /* SW Definable Pin 4 data */
-#define E1000_CTRL_EXT_SDP5_DATA       0x00000020 /* SW Definable Pin 5 data */
-#define E1000_CTRL_EXT_PHY_INT         E1000_CTRL_EXT_SDP5_DATA
 #define E1000_CTRL_EXT_SDP6_DATA       0x00000040 /* SW Definable Pin 6 data */
 #define E1000_CTRL_EXT_SDP3_DATA       0x00000080 /* SW Definable Pin 3 data */
 /* SDP 4/5 (bits 8,9) are reserved in >= 82575 */
 #define E1000_CTRL_EXT_SDP4_DIR        0x00000100 /* Direction of SDP4 0=in 1=out */
-#define E1000_CTRL_EXT_SDP5_DIR        0x00000200 /* Direction of SDP5 0=in 1=out */
 #define E1000_CTRL_EXT_SDP6_DIR        0x00000400 /* Direction of SDP6 0=in 1=out */
 #define E1000_CTRL_EXT_SDP3_DIR        0x00000800 /* Direction of SDP3 0=in 1=out */
-#define E1000_CTRL_EXT_ASDCHK  0x00001000 /* Initiate an ASD sequence */
+#define E1000_CTRL_EXT_FORCE_SMBUS     0x00000800 /* Force SMBus mode */
 #define E1000_CTRL_EXT_EE_RST  0x00002000 /* Reinitialize from EEPROM */
-#define E1000_CTRL_EXT_IPS     0x00004000 /* Invert Power State */
 /* Physical Func Reset Done Indication */
 #define E1000_CTRL_EXT_PFRSTD  0x00004000
 #define E1000_CTRL_EXT_SPD_BYPS        0x00008000 /* Speed Select Bypass */
@@ -178,42 +82,22 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_CTRL_EXT_LINK_MODE_MASK  0x00C00000
 /* Offset of the link mode field in Ctrl Ext register */
 #define E1000_CTRL_EXT_LINK_MODE_OFFSET        22
-#define E1000_CTRL_EXT_LINK_MODE_82580_MASK    0x01C00000 /*82580 bit 24:22*/
 #define E1000_CTRL_EXT_LINK_MODE_1000BASE_KX   0x00400000
 #define E1000_CTRL_EXT_LINK_MODE_GMII  0x00000000
-#define E1000_CTRL_EXT_LINK_MODE_TBI   0x00C00000
-#define E1000_CTRL_EXT_LINK_MODE_KMRN  0x00000000
 #define E1000_CTRL_EXT_LINK_MODE_PCIE_SERDES   0x00C00000
-#define E1000_CTRL_EXT_LINK_MODE_PCIX_SERDES   0x00800000
 #define E1000_CTRL_EXT_LINK_MODE_SGMII 0x00800000
 #define E1000_CTRL_EXT_EIAME           0x01000000
 #define E1000_CTRL_EXT_IRCA            0x00000001
-#define E1000_CTRL_EXT_WR_WMARK_MASK   0x03000000
-#define E1000_CTRL_EXT_WR_WMARK_256    0x00000000
-#define E1000_CTRL_EXT_WR_WMARK_320    0x01000000
-#define E1000_CTRL_EXT_WR_WMARK_384    0x02000000
-#define E1000_CTRL_EXT_WR_WMARK_448    0x03000000
-#define E1000_CTRL_EXT_CANC            0x04000000 /* Int delay cancellation */
 #define E1000_CTRL_EXT_DRV_LOAD                0x10000000 /* Drv loaded bit for FW */
-/* IAME enable bit (27) was removed in >= 82575 */
 #define E1000_CTRL_EXT_IAME            0x08000000 /* Int ACK Auto-mask */
-/* packet buffer parity error detection enabled */
-#define E1000_CRTL_EXT_PB_PAREN                0x01000000
-/* descriptor FIFO parity error detection enable */
-#define E1000_CTRL_EXT_DF_PAREN                0x02000000
-#define E1000_CTRL_EXT_GHOST_PAREN     0x40000000
 #define E1000_CTRL_EXT_PBA_CLR         0x80000000 /* PBA Clear */
 #define E1000_CTRL_EXT_LSECCK          0x00001000
 #define E1000_CTRL_EXT_PHYPDEN         0x00100000
 #define E1000_I2CCMD_REG_ADDR_SHIFT    16
-#define E1000_I2CCMD_REG_ADDR          0x00FF0000
 #define E1000_I2CCMD_PHY_ADDR_SHIFT    24
-#define E1000_I2CCMD_PHY_ADDR          0x07000000
 #define E1000_I2CCMD_OPCODE_READ       0x08000000
 #define E1000_I2CCMD_OPCODE_WRITE      0x00000000
-#define E1000_I2CCMD_RESET             0x10000000
 #define E1000_I2CCMD_READY             0x20000000
-#define E1000_I2CCMD_INTERRUPT_ENA     0x40000000
 #define E1000_I2CCMD_ERROR             0x80000000
 #define E1000_I2CCMD_SFP_DATA_ADDR(a)  (0x0000 + (a))
 #define E1000_I2CCMD_SFP_DIAG_ADDR(a)  (0x0100 + (a))
@@ -234,11 +118,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_RXD_STAT_TCPCS   0x20    /* TCP xsum calculated */
 #define E1000_RXD_STAT_IPCS    0x40    /* IP xsum calculated */
 #define E1000_RXD_STAT_PIF     0x80    /* passed in-exact filter */
-#define E1000_RXD_STAT_CRCV    0x100   /* Speculative CRC Valid */
 #define E1000_RXD_STAT_IPIDV   0x200   /* IP identification valid */
 #define E1000_RXD_STAT_UDPV    0x400   /* Valid UDP checksum */
 #define E1000_RXD_STAT_DYNINT  0x800   /* Pkt caused INT via DYNINT */
-#define E1000_RXD_STAT_ACK     0x8000  /* ACK Packet indication */
 #define E1000_RXD_ERR_CE       0x01    /* CRC Error */
 #define E1000_RXD_ERR_SE       0x02    /* Symbol Error */
 #define E1000_RXD_ERR_SEQ      0x04    /* Sequence Error */
@@ -247,10 +129,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_RXD_ERR_IPE      0x40    /* IP Checksum Error */
 #define E1000_RXD_ERR_RXE      0x80    /* Rx Data Error */
 #define E1000_RXD_SPC_VLAN_MASK        0x0FFF  /* VLAN ID is in lower 12 bits */
-#define E1000_RXD_SPC_PRI_MASK 0xE000  /* Priority is in upper 3 bits */
-#define E1000_RXD_SPC_PRI_SHIFT        13
-#define E1000_RXD_SPC_CFI_MASK 0x1000  /* CFI is bit 12 */
-#define E1000_RXD_SPC_CFI_SHIFT        12
 
 #define E1000_RXDEXT_STATERR_TST       0x00000100 /* Time Stamp taken */
 #define E1000_RXDEXT_STATERR_LB                0x00040000
@@ -262,13 +140,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_RXDEXT_STATERR_IPE       0x40000000
 #define E1000_RXDEXT_STATERR_RXE       0x80000000
 
-#define E1000_RXDEXT_LSECH             0x01000000
-#define E1000_RXDEXT_LSECE_MASK                0x60000000
-#define E1000_RXDEXT_LSECE_NO_ERROR    0x00000000
-#define E1000_RXDEXT_LSECE_NO_SA_MATCH 0x20000000
-#define E1000_RXDEXT_LSECE_REPLAY_DETECT 0x40000000
-#define E1000_RXDEXT_LSECE_BAD_SIG     0x60000000
-
 /* mask to determine if packets should be dropped due to frame errors */
 #define E1000_RXD_ERR_FRAME_ERR_MASK ( \
        E1000_RXD_ERR_CE  |             \
@@ -285,61 +156,28 @@ POSSIBILITY OF SUCH DAMAGE.
        E1000_RXDEXT_STATERR_CXE |      \
        E1000_RXDEXT_STATERR_RXE)
 
-/* Packet Types as indicated in the Adv/Ext receive descriptor. */
-#define E1000_RXD_PKTTYPE_MASK                 0x000F0000
-#define E1000_RXD_PKTTYPE_PTP                  0x000E0000
-
-#define E1000_MRQC_ENABLE_MASK                 0x00000007
+#if !defined(EXTERNAL_RELEASE) || defined(E1000E_MQ)
 #define E1000_MRQC_ENABLE_RSS_2Q               0x00000001
-#define E1000_MRQC_ENABLE_RSS_INT              0x00000004
+#endif /* !EXTERNAL_RELEASE || E1000E_MQ */
 #define E1000_MRQC_RSS_FIELD_MASK              0xFFFF0000
 #define E1000_MRQC_RSS_FIELD_IPV4_TCP          0x00010000
 #define E1000_MRQC_RSS_FIELD_IPV4              0x00020000
 #define E1000_MRQC_RSS_FIELD_IPV6_TCP_EX       0x00040000
-#define E1000_MRQC_RSS_FIELD_IPV6_EX           0x00080000
 #define E1000_MRQC_RSS_FIELD_IPV6              0x00100000
 #define E1000_MRQC_RSS_FIELD_IPV6_TCP          0x00200000
 
 #define E1000_RXDPS_HDRSTAT_HDRSP              0x00008000
-#define E1000_RXDPS_HDRSTAT_HDRLEN_MASK                0x000003FF
 
 /* Management Control */
 #define E1000_MANC_SMBUS_EN    0x00000001 /* SMBus Enabled - RO */
 #define E1000_MANC_ASF_EN      0x00000002 /* ASF Enabled - RO */
-#define E1000_MANC_R_ON_FORCE  0x00000004 /* Reset on Force TCO - RO */
-#define E1000_MANC_RMCP_EN     0x00000100 /* Enable RCMP 026Fh Filtering */
-#define E1000_MANC_0298_EN     0x00000200 /* Enable RCMP 0298h Filtering */
-#define E1000_MANC_IPV4_EN     0x00000400 /* Enable IPv4 */
-#define E1000_MANC_IPV6_EN     0x00000800 /* Enable IPv6 */
-#define E1000_MANC_SNAP_EN     0x00001000 /* Accept LLC/SNAP */
 #define E1000_MANC_ARP_EN      0x00002000 /* Enable ARP Request Filtering */
-/* Enable Neighbor Discovery Filtering */
-#define E1000_MANC_NEIGHBOR_EN 0x00004000
-#define E1000_MANC_ARP_RES_EN  0x00008000 /* Enable ARP response Filtering */
-#define E1000_MANC_TCO_RESET   0x00010000 /* TCO Reset Occurred */
 #define E1000_MANC_RCV_TCO_EN  0x00020000 /* Receive TCO Packets Enabled */
-#define E1000_MANC_REPORT_STATUS 0x00040000 /* Status Reporting Enabled */
-#define E1000_MANC_RCV_ALL     0x00080000 /* Receive All Enabled */
 #define E1000_MANC_BLK_PHY_RST_ON_IDE  0x00040000 /* Block phy resets */
 /* Enable MAC address filtering */
 #define E1000_MANC_EN_MAC_ADDR_FILTER  0x00100000
 /* Enable MNG packets to host memory */
 #define E1000_MANC_EN_MNG2HOST         0x00200000
-/* Enable IP address filtering */
-#define E1000_MANC_EN_IP_ADDR_FILTER   0x00400000
-#define E1000_MANC_EN_XSUM_FILTER      0x00800000 /* Ena checksum filtering */
-#define E1000_MANC_BR_EN               0x01000000 /* Ena broadcast filtering */
-#define E1000_MANC_SMB_REQ             0x01000000 /* SMBus Request */
-#define E1000_MANC_SMB_GNT             0x02000000 /* SMBus Grant */
-#define E1000_MANC_SMB_CLK_IN          0x04000000 /* SMBus Clock In */
-#define E1000_MANC_SMB_DATA_IN         0x08000000 /* SMBus Data In */
-#define E1000_MANC_SMB_DATA_OUT                0x10000000 /* SMBus Data Out */
-#define E1000_MANC_SMB_CLK_OUT         0x20000000 /* SMBus Clock Out */
-#define E1000_MANC_MPROXYE             0x40000000 /* Mngment Proxy Enable */
-#define E1000_MANC_EN_BMC2OS           0x10000000 /* OS2BMC is enabld or not */
-
-#define E1000_MANC_SMB_DATA_OUT_SHIFT  28 /* SMBus Data Out Shift */
-#define E1000_MANC_SMB_CLK_OUT_SHIFT   29 /* SMBus Clock Out Shift */
 
 #define E1000_MANC2H_PORT_623          0x00000020 /* Port 0x26f */
 #define E1000_MANC2H_PORT_664          0x00000040 /* Port 0x298 */
@@ -355,19 +193,11 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_RCTL_LPE         0x00000020 /* long packet enable */
 #define E1000_RCTL_LBM_NO      0x00000000 /* no loopback mode */
 #define E1000_RCTL_LBM_MAC     0x00000040 /* MAC loopback mode */
-#define E1000_RCTL_LBM_SLP     0x00000080 /* serial link loopback mode */
 #define E1000_RCTL_LBM_TCVR    0x000000C0 /* tcvr loopback mode */
-#define E1000_RCTL_DTYP_MASK   0x00000C00 /* Descriptor type mask */
 #define E1000_RCTL_DTYP_PS     0x00000400 /* Packet Split descriptor */
 #define E1000_RCTL_RDMTS_HALF  0x00000000 /* Rx desc min thresh size */
-#define E1000_RCTL_RDMTS_QUAT  0x00000100 /* Rx desc min thresh size */
-#define E1000_RCTL_RDMTS_EIGTH 0x00000200 /* Rx desc min thresh size */
 #define E1000_RCTL_MO_SHIFT    12 /* multicast offset shift */
-#define E1000_RCTL_MO_0                0x00000000 /* multicast offset 11:0 */
-#define E1000_RCTL_MO_1                0x00001000 /* multicast offset 12:1 */
-#define E1000_RCTL_MO_2                0x00002000 /* multicast offset 13:2 */
 #define E1000_RCTL_MO_3                0x00003000 /* multicast offset 15:4 */
-#define E1000_RCTL_MDR         0x00004000 /* multicast desc ring 0 */
 #define E1000_RCTL_BAM         0x00008000 /* broadcast enable */
 /* these buffer sizes are valid if E1000_RCTL_BSEX is 0 */
 #define E1000_RCTL_SZ_2048     0x00000000 /* Rx buffer size 2048 */
@@ -385,11 +215,8 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_RCTL_PMCF                0x00800000 /* pass MAC control frames */
 #define E1000_RCTL_BSEX                0x02000000 /* Buffer size extension */
 #define E1000_RCTL_SECRC       0x04000000 /* Strip Ethernet CRC */
-#define E1000_RCTL_FLXBUF_MASK 0x78000000 /* Flexible buffer size */
-#define E1000_RCTL_FLXBUF_SHIFT        27 /* Flexible buffer shift */
 
-/*
- * Use byte values for the following shift parameters
+/* Use byte values for the following shift parameters
  * Usage:
  *     psrctl |= (((ROUNDUP(value0, 128) >> E1000_PSRCTL_BSIZE0_SHIFT) &
  *               E1000_PSRCTL_BSIZE0_MASK) |
@@ -424,16 +251,11 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_SWFW_PHY3_SM     0x40
 #define E1000_SWFW_SW_MNG_SM   0x400
 
-/* FACTPS Definitions */
-#define E1000_FACTPS_LFS       0x40000000  /* LAN Function Select */
 /* Device Control */
 #define E1000_CTRL_FD          0x00000001  /* Full duplex.0=half; 1=full */
-#define E1000_CTRL_BEM         0x00000002  /* Endian Mode.0=little,1=big */
 #define E1000_CTRL_PRIOR       0x00000004  /* Priority on PCI. 0=rx,1=fair */
 #define E1000_CTRL_GIO_MASTER_DISABLE 0x00000004 /*Blocks new Master reqs */
 #define E1000_CTRL_LRST                0x00000008  /* Link reset. 0=normal,1=reset */
-#define E1000_CTRL_TME         0x00000010  /* Test mode. 0=normal,1=test */
-#define E1000_CTRL_SLE         0x00000020  /* Serial Link on 0=dis,1=en */
 #define E1000_CTRL_ASDE                0x00000020  /* Auto-speed detect enable */
 #define E1000_CTRL_SLU         0x00000040  /* Set link up (Force Link) */
 #define E1000_CTRL_ILOS                0x00000080  /* Invert Loss-Of Signal */
@@ -441,50 +263,38 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_CTRL_SPD_10      0x00000000  /* Force 10Mb */
 #define E1000_CTRL_SPD_100     0x00000100  /* Force 100Mb */
 #define E1000_CTRL_SPD_1000    0x00000200  /* Force 1Gb */
-#define E1000_CTRL_BEM32       0x00000400  /* Big Endian 32 mode */
 #define E1000_CTRL_FRCSPD      0x00000800  /* Force Speed */
 #define E1000_CTRL_FRCDPX      0x00001000  /* Force Duplex */
-#define E1000_CTRL_D_UD_EN     0x00002000  /* Dock/Undock enable */
-/* Defined polarity of Dock/Undock indication in SDP[0] */
-#define E1000_CTRL_D_UD_POLARITY       0x00004000
-/* Reset both PHY ports, through PHYRST_N pin */
-#define E1000_CTRL_FORCE_PHY_RESET     0x00008000
-/* enable link status from external LINK_0 and LINK_1 pins */
-#define E1000_CTRL_EXT_LINK_EN         0x00010000
 #define E1000_CTRL_LANPHYPC_OVERRIDE   0x00010000 /* SW control of LANPHYPC */
 #define E1000_CTRL_LANPHYPC_VALUE      0x00020000 /* SW value of LANPHYPC */
+#define E1000_CTRL_MEHE                0x00080000 /* Memory Error Handling Enable */
 #define E1000_CTRL_SWDPIN0     0x00040000 /* SWDPIN 0 value */
 #define E1000_CTRL_SWDPIN1     0x00080000 /* SWDPIN 1 value */
 #define E1000_CTRL_SWDPIN2     0x00100000 /* SWDPIN 2 value */
 #define E1000_CTRL_ADVD3WUC    0x00100000 /* D3 WUC */
+#define E1000_CTRL_EN_PHY_PWR_MGMT     0x00200000 /* PHY PM enable */
 #define E1000_CTRL_SWDPIN3     0x00200000 /* SWDPIN 3 value */
 #define E1000_CTRL_SWDPIO0     0x00400000 /* SWDPIN 0 Input or output */
-#define E1000_CTRL_SWDPIO1     0x00800000 /* SWDPIN 1 input or output */
 #define E1000_CTRL_SWDPIO2     0x01000000 /* SWDPIN 2 input or output */
 #define E1000_CTRL_SWDPIO3     0x02000000 /* SWDPIN 3 input or output */
 #define E1000_CTRL_RST         0x04000000 /* Global reset */
 #define E1000_CTRL_RFCE                0x08000000 /* Receive Flow Control enable */
 #define E1000_CTRL_TFCE                0x10000000 /* Transmit flow control enable */
-#define E1000_CTRL_RTE         0x20000000 /* Routing tag enable */
 #define E1000_CTRL_VME         0x40000000 /* IEEE VLAN mode enable */
 #define E1000_CTRL_PHY_RST     0x80000000 /* PHY Reset */
-#define E1000_CTRL_SW2FW_INT   0x02000000 /* Initiate an interrupt to ME */
 #define E1000_CTRL_I2C_ENA     0x02000000 /* I2C enable */
 
-/*
- * Bit definitions for the Management Data IO (MDIO) and Management Data
- * Clock (MDC) pins in the Device Control Register.
- */
-#define E1000_CTRL_PHY_RESET_DIR       E1000_CTRL_SWDPIO0
-#define E1000_CTRL_PHY_RESET           E1000_CTRL_SWDPIN0
 #define E1000_CTRL_MDIO_DIR            E1000_CTRL_SWDPIO2
 #define E1000_CTRL_MDIO                        E1000_CTRL_SWDPIN2
 #define E1000_CTRL_MDC_DIR             E1000_CTRL_SWDPIO3
 #define E1000_CTRL_MDC                 E1000_CTRL_SWDPIN3
-#define E1000_CTRL_PHY_RESET_DIR4      E1000_CTRL_EXT_SDP4_DIR
-#define E1000_CTRL_PHY_RESET4          E1000_CTRL_EXT_SDP4_DATA
 
 #define E1000_CONNSW_ENRGSRC           0x4
+#define E1000_CONNSW_PHYSD             0x400
+#define E1000_CONNSW_PHY_PDN           0x800
+#define E1000_CONNSW_SERDESD           0x200
+#define E1000_CONNSW_AUTOSENSE_CONF    0x2
+#define E1000_CONNSW_AUTOSENSE_EN      0x1
 #define E1000_PCS_CFG_PCS_EN           8
 #define E1000_PCS_LCTL_FLV_LINK_UP     1
 #define E1000_PCS_LCTL_FSV_10          0
@@ -493,65 +303,39 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_PCS_LCTL_FDV_FULL                8
 #define E1000_PCS_LCTL_FSD             0x10
 #define E1000_PCS_LCTL_FORCE_LINK      0x20
-#define E1000_PCS_LCTL_LOW_LINK_LATCH  0x40
 #define E1000_PCS_LCTL_FORCE_FCTRL     0x80
 #define E1000_PCS_LCTL_AN_ENABLE       0x10000
 #define E1000_PCS_LCTL_AN_RESTART      0x20000
 #define E1000_PCS_LCTL_AN_TIMEOUT      0x40000
-#define E1000_PCS_LCTL_AN_SGMII_BYPASS 0x80000
-#define E1000_PCS_LCTL_AN_SGMII_TRIGGER        0x100000
-#define E1000_PCS_LCTL_FAST_LINK_TIMER 0x1000000
-#define E1000_PCS_LCTL_LINK_OK_FIX     0x2000000
-#define E1000_PCS_LCTL_CRS_ON_NI       0x4000000
 #define E1000_ENABLE_SERDES_LOOPBACK   0x0410
 
 #define E1000_PCS_LSTS_LINK_OK         1
-#define E1000_PCS_LSTS_SPEED_10                0
 #define E1000_PCS_LSTS_SPEED_100       2
 #define E1000_PCS_LSTS_SPEED_1000      4
 #define E1000_PCS_LSTS_DUPLEX_FULL     8
 #define E1000_PCS_LSTS_SYNK_OK         0x10
 #define E1000_PCS_LSTS_AN_COMPLETE     0x10000
-#define E1000_PCS_LSTS_AN_PAGE_RX      0x20000
-#define E1000_PCS_LSTS_AN_TIMED_OUT    0x40000
-#define E1000_PCS_LSTS_AN_REMOTE_FAULT 0x80000
-#define E1000_PCS_LSTS_AN_ERROR_RWS    0x100000
 
 /* Device Status */
 #define E1000_STATUS_FD                        0x00000001 /* Duplex 0=half 1=full */
 #define E1000_STATUS_LU                        0x00000002 /* Link up.0=no,1=link */
 #define E1000_STATUS_FUNC_MASK         0x0000000C /* PCI Function Mask */
 #define E1000_STATUS_FUNC_SHIFT                2
-#define E1000_STATUS_FUNC_0            0x00000000 /* Function 0 */
 #define E1000_STATUS_FUNC_1            0x00000004 /* Function 1 */
 #define E1000_STATUS_TXOFF             0x00000010 /* transmission paused */
-#define E1000_STATUS_TBIMODE           0x00000020 /* TBI mode */
-#define E1000_STATUS_SPEED_MASK                0x000000C0
+#define E1000_STATUS_SPEED_MASK        0x000000C0
 #define E1000_STATUS_SPEED_10          0x00000000 /* Speed 10Mb/s */
 #define E1000_STATUS_SPEED_100         0x00000040 /* Speed 100Mb/s */
 #define E1000_STATUS_SPEED_1000                0x00000080 /* Speed 1000Mb/s */
 #define E1000_STATUS_LAN_INIT_DONE     0x00000200 /* Lan Init Compltn by NVM */
-#define E1000_STATUS_ASDV              0x00000300 /* Auto speed detect value */
 #define E1000_STATUS_PHYRA             0x00000400 /* PHY Reset Asserted */
-/* Change in Dock/Undock state clear on write '0'. */
-#define E1000_STATUS_DOCK_CI           0x00000800
 #define E1000_STATUS_GIO_MASTER_ENABLE 0x00080000 /* Master request status */
-#define E1000_STATUS_MTXCKOK           0x00000400 /* MTX clock running OK */
 #define E1000_STATUS_PCI66             0x00000800 /* In 66Mhz slot */
 #define E1000_STATUS_BUS64             0x00001000 /* In 64 bit slot */
+#define E1000_STATUS_2P5_SKU           0x00001000 /* Val of 2.5GBE SKU strap */
+#define E1000_STATUS_2P5_SKU_OVER      0x00002000 /* Val of 2.5GBE SKU Over */
 #define E1000_STATUS_PCIX_MODE         0x00002000 /* PCI-X mode */
 #define E1000_STATUS_PCIX_SPEED                0x0000C000 /* PCI-X bus speed */
-#define E1000_STATUS_BMC_SKU_0         0x00100000 /* BMC USB redirect disbld */
-#define E1000_STATUS_BMC_SKU_1         0x00200000 /* BMC SRAM disabled */
-#define E1000_STATUS_BMC_SKU_2         0x00400000 /* BMC SDRAM disabled */
-#define E1000_STATUS_BMC_CRYPTO                0x00800000 /* BMC crypto disabled */
-/* BMC external code execution disabled */
-#define E1000_STATUS_BMC_LITE          0x01000000
-#define E1000_STATUS_RGMII_ENABLE      0x02000000 /* RGMII disabled */
-#define E1000_STATUS_FUSE_8            0x04000000
-#define E1000_STATUS_FUSE_9            0x08000000
-#define E1000_STATUS_SERDES0_DIS       0x10000000 /* SERDES disbld on port 0 */
-#define E1000_STATUS_SERDES1_DIS       0x20000000 /* SERDES disbld on port 1 */
 
 /* Constants used to interpret the masked PCI-X bus speed. */
 #define E1000_STATUS_PCIX_SPEED_66     0x00000000 /* PCI-X bus spd 50-66MHz */
@@ -561,6 +345,7 @@ POSSIBILITY OF SUCH DAMAGE.
 #define SPEED_10       10
 #define SPEED_100      100
 #define SPEED_1000     1000
+#define SPEED_2500     2500
 #define HALF_DUPLEX    1
 #define FULL_DUPLEX    2
 
@@ -582,8 +367,6 @@ POSSIBILITY OF SUCH DAMAGE.
        ADVERTISE_100_FULL)
 #define E1000_ALL_100_SPEED    (ADVERTISE_100_HALF | ADVERTISE_100_FULL)
 #define E1000_ALL_10_SPEED     (ADVERTISE_10_HALF | ADVERTISE_10_FULL)
-#define E1000_ALL_FULL_DUPLEX  ( \
-       ADVERTISE_10_FULL | ADVERTISE_100_FULL | ADVERTISE_1000_FULL)
 #define E1000_ALL_HALF_DUPLEX  (ADVERTISE_10_HALF | ADVERTISE_100_HALF)
 
 #define AUTONEG_ADVERTISE_SPEED_DEFAULT                E1000_ALL_SPEED_DUPLEX
@@ -591,51 +374,20 @@ POSSIBILITY OF SUCH DAMAGE.
 /* LED Control */
 #define E1000_PHY_LED0_MODE_MASK       0x00000007
 #define E1000_PHY_LED0_IVRT            0x00000008
-#define E1000_PHY_LED0_BLINK           0x00000010
 #define E1000_PHY_LED0_MASK            0x0000001F
 
 #define E1000_LEDCTL_LED0_MODE_MASK    0x0000000F
 #define E1000_LEDCTL_LED0_MODE_SHIFT   0
-#define E1000_LEDCTL_LED0_BLINK_RATE   0x00000020
 #define E1000_LEDCTL_LED0_IVRT         0x00000040
 #define E1000_LEDCTL_LED0_BLINK                0x00000080
-#define E1000_LEDCTL_LED1_MODE_MASK    0x00000F00
-#define E1000_LEDCTL_LED1_MODE_SHIFT   8
-#define E1000_LEDCTL_LED1_BLINK_RATE   0x00002000
-#define E1000_LEDCTL_LED1_IVRT         0x00004000
-#define E1000_LEDCTL_LED1_BLINK                0x00008000
-#define E1000_LEDCTL_LED2_MODE_MASK    0x000F0000
-#define E1000_LEDCTL_LED2_MODE_SHIFT   16
-#define E1000_LEDCTL_LED2_BLINK_RATE   0x00200000
-#define E1000_LEDCTL_LED2_IVRT         0x00400000
-#define E1000_LEDCTL_LED2_BLINK                0x00800000
-#define E1000_LEDCTL_LED3_MODE_MASK    0x0F000000
-#define E1000_LEDCTL_LED3_MODE_SHIFT   24
-#define E1000_LEDCTL_LED3_BLINK_RATE   0x20000000
-#define E1000_LEDCTL_LED3_IVRT         0x40000000
-#define E1000_LEDCTL_LED3_BLINK                0x80000000
-
-#define E1000_LEDCTL_MODE_LINK_10_1000 0x0
-#define E1000_LEDCTL_MODE_LINK_100_1000        0x1
+
 #define E1000_LEDCTL_MODE_LINK_UP      0x2
-#define E1000_LEDCTL_MODE_ACTIVITY     0x3
-#define E1000_LEDCTL_MODE_LINK_ACTIVITY        0x4
-#define E1000_LEDCTL_MODE_LINK_10      0x5
-#define E1000_LEDCTL_MODE_LINK_100     0x6
-#define E1000_LEDCTL_MODE_LINK_1000    0x7
-#define E1000_LEDCTL_MODE_PCIX_MODE    0x8
-#define E1000_LEDCTL_MODE_FULL_DUPLEX  0x9
-#define E1000_LEDCTL_MODE_COLLISION    0xA
-#define E1000_LEDCTL_MODE_BUS_SPEED    0xB
-#define E1000_LEDCTL_MODE_BUS_SIZE     0xC
-#define E1000_LEDCTL_MODE_PAUSED       0xD
 #define E1000_LEDCTL_MODE_LED_ON       0xE
 #define E1000_LEDCTL_MODE_LED_OFF      0xF
 
 /* Transmit Descriptor bit definitions */
 #define E1000_TXD_DTYP_D       0x00100000 /* Data Descriptor */
 #define E1000_TXD_DTYP_C       0x00000000 /* Context Descriptor */
-#define E1000_TXD_POPTS_SHIFT  8          /* POPTS shift */
 #define E1000_TXD_POPTS_IXSM   0x01       /* Insert IP checksum */
 #define E1000_TXD_POPTS_TXSM   0x02       /* Insert TCP/UDP checksum */
 #define E1000_TXD_CMD_EOP      0x01000000 /* End of Packet */
@@ -654,21 +406,14 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_TXD_CMD_IP       0x02000000 /* IP packet */
 #define E1000_TXD_CMD_TSE      0x04000000 /* TCP Seg enable */
 #define E1000_TXD_STAT_TC      0x00000004 /* Tx Underrun */
-/* Extended desc bits for Linksec and timesync */
-#define E1000_TXD_CMD_LINKSEC  0x10000000 /* Apply LinkSec on packet */
 #define E1000_TXD_EXTCMD_TSTAMP        0x00000010 /* IEEE1588 Timestamp packet */
 
 /* Transmit Control */
-#define E1000_TCTL_RST         0x00000001 /* software reset */
 #define E1000_TCTL_EN          0x00000002 /* enable Tx */
-#define E1000_TCTL_BCE         0x00000004 /* busy check enable */
 #define E1000_TCTL_PSP         0x00000008 /* pad short packets */
 #define E1000_TCTL_CT          0x00000ff0 /* collision threshold */
 #define E1000_TCTL_COLD                0x003ff000 /* collision distance */
-#define E1000_TCTL_SWXOFF      0x00400000 /* SW Xoff transmission */
-#define E1000_TCTL_PBE         0x00800000 /* Packet Burst Enable */
 #define E1000_TCTL_RTLC                0x01000000 /* Re-transmit on late collision */
-#define E1000_TCTL_NRTU                0x02000000 /* No Re-transmit on underrun */
 #define E1000_TCTL_MULR                0x10000000 /* Multiple request support */
 
 /* Transmit Arbitration Count */
@@ -676,29 +421,19 @@ POSSIBILITY OF SUCH DAMAGE.
 
 /* SerDes Control */
 #define E1000_SCTL_DISABLE_SERDES_LOOPBACK     0x0400
+#define E1000_SCTL_ENABLE_SERDES_LOOPBACK      0x0410
 
 /* Receive Checksum Control */
-#define E1000_RXCSUM_PCSS_MASK 0x000000FF /* Packet Checksum Start */
 #define E1000_RXCSUM_IPOFL     0x00000100 /* IPv4 checksum offload */
 #define E1000_RXCSUM_TUOFL     0x00000200 /* TCP / UDP checksum offload */
-#define E1000_RXCSUM_IPV6OFL   0x00000400 /* IPv6 checksum offload */
 #define E1000_RXCSUM_CRCOFL    0x00000800 /* CRC32 offload enable */
 #define E1000_RXCSUM_IPPCSE    0x00001000 /* IP payload checksum enable */
 #define E1000_RXCSUM_PCSD      0x00002000 /* packet checksum disabled */
 
 /* Header split receive */
-#define E1000_RFCTL_ISCSI_DIS          0x00000001
-#define E1000_RFCTL_ISCSI_DWC_MASK     0x0000003E
-#define E1000_RFCTL_ISCSI_DWC_SHIFT    1
 #define E1000_RFCTL_NFSW_DIS           0x00000040
 #define E1000_RFCTL_NFSR_DIS           0x00000080
-#define E1000_RFCTL_NFS_VER_MASK       0x00000300
-#define E1000_RFCTL_NFS_VER_SHIFT      8
-#define E1000_RFCTL_IPV6_DIS           0x00000400
-#define E1000_RFCTL_IPV6_XSUM_DIS      0x00000800
 #define E1000_RFCTL_ACK_DIS            0x00001000
-#define E1000_RFCTL_ACKD_DIS           0x00002000
-#define E1000_RFCTL_IPFRSP_DIS         0x00004000
 #define E1000_RFCTL_EXTEN              0x00008000
 #define E1000_RFCTL_IPV6_EX_DIS                0x00010000
 #define E1000_RFCTL_NEW_IPV6_EXT_DIS   0x00020000
@@ -716,8 +451,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define DEFAULT_82543_TIPG_IPGT_COPPER 8
 
 #define E1000_TIPG_IPGT_MASK           0x000003FF
-#define E1000_TIPG_IPGR1_MASK          0x000FFC00
-#define E1000_TIPG_IPGR2_MASK          0x3FF00000
 
 #define DEFAULT_82542_TIPG_IPGR1       2
 #define DEFAULT_82543_TIPG_IPGR1       8
@@ -745,7 +478,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_EXTCNF_CTRL_EXT_CNF_POINTER_MASK 0x0FFF0000
 #define E1000_EXTCNF_CTRL_EXT_CNF_POINTER_SHIFT        16
 
-#define E1000_PHY_CTRL_SPD_EN                  0x00000001
 #define E1000_PHY_CTRL_D0A_LPLU                        0x00000002
 #define E1000_PHY_CTRL_NOND0A_LPLU             0x00000004
 #define E1000_PHY_CTRL_NOND0A_GBE_DISABLE      0x00000008
@@ -754,12 +486,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_KABGTXD_BGSQLBIAS                        0x00050000
 
 /* Low Power IDLE Control */
-#define E1000_LPIC_1000ENABLE          0x00010000
-#define E1000_LPIC_100ENABLE           0x00020000
 #define E1000_LPIC_LPIET_SHIFT         24      /* Low Power Idle Entry Time */
 
 /* PBA constants */
-#define E1000_PBA_6K           0x0006    /* 6KB */
 #define E1000_PBA_8K           0x0008    /* 8KB */
 #define E1000_PBA_10K          0x000A    /* 10KB */
 #define E1000_PBA_12K          0x000C    /* 12KB */
@@ -782,7 +511,12 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_PBA_RXA_MASK     0xFFFF
 
 #define E1000_PBS_16K          E1000_PBA_16K
-#define E1000_PBS_24K          E1000_PBA_24K
+
+/* Uncorrectable/correctable ECC Error counts and enable bits */
+#define E1000_PBECCSTS_CORR_ERR_CNT_MASK       0x000000FF
+#define E1000_PBECCSTS_UNCORR_ERR_CNT_MASK     0x0000FF00
+#define E1000_PBECCSTS_UNCORR_ERR_CNT_SHIFT    8
+#define E1000_PBECCSTS_ECC_ENABLE              0x00010000
 
 #define IFS_MAX                        80
 #define IFS_MIN                        40
@@ -793,7 +527,6 @@ POSSIBILITY OF SUCH DAMAGE.
 /* SW Semaphore Register */
 #define E1000_SWSM_SMBI                0x00000001 /* Driver Semaphore bit */
 #define E1000_SWSM_SWESMBI     0x00000002 /* FW Semaphore bit */
-#define E1000_SWSM_WMNG                0x00000004 /* Wake MNG Clock */
 #define E1000_SWSM_DRV_LOAD    0x00000008 /* Driver Loaded Bit */
 
 #define E1000_SWSM2_LOCK       0x00000002 /* Secondary driver semaphore bit */
@@ -807,34 +540,19 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_ICR_RXO          0x00000040 /* Rx overrun */
 #define E1000_ICR_RXT0         0x00000080 /* Rx timer intr (ring 0) */
 #define E1000_ICR_VMMB         0x00000100 /* VM MB event */
-#define E1000_ICR_MDAC         0x00000200 /* MDIO access complete */
 #define E1000_ICR_RXCFG                0x00000400 /* Rx /c/ ordered set */
 #define E1000_ICR_GPI_EN0      0x00000800 /* GP Int 0 */
 #define E1000_ICR_GPI_EN1      0x00001000 /* GP Int 1 */
 #define E1000_ICR_GPI_EN2      0x00002000 /* GP Int 2 */
 #define E1000_ICR_GPI_EN3      0x00004000 /* GP Int 3 */
 #define E1000_ICR_TXD_LOW      0x00008000
-#define E1000_ICR_SRPD         0x00010000
-#define E1000_ICR_ACK          0x00020000 /* Receive Ack frame */
 #define E1000_ICR_MNG          0x00040000 /* Manageability event */
-#define E1000_ICR_DOCK         0x00080000 /* Dock/Undock */
+#define E1000_ICR_ECCER                0x00400000 /* Uncorrectable ECC Error */
 #define E1000_ICR_TS           0x00080000 /* Time Sync Interrupt */
 #define E1000_ICR_DRSTA                0x40000000 /* Device Reset Asserted */
 /* If this bit asserted, the driver should claim the interrupt */
 #define E1000_ICR_INT_ASSERTED 0x80000000
-#define E1000_ICR_RXD_FIFO_PAR0        0x00100000 /* Q0 Rx desc FIFO parity error */
-#define E1000_ICR_TXD_FIFO_PAR0        0x00200000 /* Q0 Tx desc FIFO parity error */
-#define E1000_ICR_HOST_ARB_PAR 0x00400000 /* host arb read buffer parity err */
-#define E1000_ICR_PB_PAR       0x00800000 /* packet buffer parity error */
-#define E1000_ICR_RXD_FIFO_PAR1        0x01000000 /* Q1 Rx desc FIFO parity error */
-#define E1000_ICR_TXD_FIFO_PAR1        0x02000000 /* Q1 Tx desc FIFO parity error */
-#define E1000_ICR_ALL_PARITY   0x03F00000 /* all parity error bits */
-/* FW changed the status of DISSW bit in the FWSM */
-#define E1000_ICR_DSW          0x00000020
-/* LAN connected device generates an interrupt */
-#define E1000_ICR_PHYINT       0x00001000
 #define E1000_ICR_DOUTSYNC     0x10000000 /* NIC DMA out of sync */
-#define E1000_ICR_EPRST                0x00100000 /* ME hardware reset occurs */
 #define E1000_ICR_RXQ0         0x00100000 /* Rx Queue 0 Interrupt */
 #define E1000_ICR_RXQ1         0x00200000 /* Rx Queue 1 Interrupt */
 #define E1000_ICR_TXQ0         0x00400000 /* Tx Queue 0 Interrupt */
@@ -845,9 +563,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_ICR_THS          0x00800000 /* ICR.THS: Thermal Sensor Event*/
 #define E1000_ICR_MDDET                0x10000000 /* Malicious Driver Detect */
 
-#define E1000_ITR_MASK         0x000FFFFF /* ITR value bitfield */
-#define E1000_ITR_MULT         256 /* ITR mulitplier in nsec */
-
 /* PBA ECC Register */
 #define E1000_PBA_ECC_COUNTER_MASK     0xFFF00000 /* ECC counter mask */
 #define E1000_PBA_ECC_COUNTER_SHIFT    20 /* ECC counter shift value */
@@ -872,16 +587,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_TCPTIMER_COUNT_FINISH    0x00000400 /* Count finish */
 #define E1000_TCPTIMER_LOOP    0x00000800 /* Loop */
 
-/*
- * This defines the bits that are set in the Interrupt Mask
- * Set/Read Register.  Each bit is documented below:
- *   o RXDMT0 = Receive Descriptor Minimum Threshold hit (ring 0)
- *   o RXSEQ  = Receive Sequence Error
- */
-#define POLL_IMS_ENABLE_MASK ( \
-       E1000_IMS_RXDMT0 |    \
-       E1000_IMS_RXSEQ)
-
 /* This defines the bits that are set in the Interrupt Mask
  * Set/Read Register.  Each bit is documented below:
  *   o RXT0   = Receiver Timer Interrupt (ring 0)
@@ -906,35 +611,11 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_IMS_RXDMT0       E1000_ICR_RXDMT0  /* Rx desc min. threshold */
 #define E1000_IMS_RXO          E1000_ICR_RXO     /* Rx overrun */
 #define E1000_IMS_RXT0         E1000_ICR_RXT0    /* Rx timer intr */
-#define E1000_IMS_MDAC         E1000_ICR_MDAC    /* MDIO access complete */
-#define E1000_IMS_RXCFG                E1000_ICR_RXCFG   /* Rx /c/ ordered set */
-#define E1000_IMS_GPI_EN0      E1000_ICR_GPI_EN0 /* GP Int 0 */
-#define E1000_IMS_GPI_EN1      E1000_ICR_GPI_EN1 /* GP Int 1 */
-#define E1000_IMS_GPI_EN2      E1000_ICR_GPI_EN2 /* GP Int 2 */
-#define E1000_IMS_GPI_EN3      E1000_ICR_GPI_EN3 /* GP Int 3 */
 #define E1000_IMS_TXD_LOW      E1000_ICR_TXD_LOW
-#define E1000_IMS_SRPD         E1000_ICR_SRPD
-#define E1000_IMS_ACK          E1000_ICR_ACK     /* Receive Ack frame */
-#define E1000_IMS_MNG          E1000_ICR_MNG     /* Manageability event */
-#define E1000_IMS_DOCK         E1000_ICR_DOCK    /* Dock/Undock */
+#define E1000_IMS_ECCER                E1000_ICR_ECCER   /* Uncorrectable ECC Error */
 #define E1000_IMS_TS           E1000_ICR_TS      /* Time Sync Interrupt */
 #define E1000_IMS_DRSTA                E1000_ICR_DRSTA   /* Device Reset Asserted */
-/* Q0 Rx desc FIFO parity error */
-#define E1000_IMS_RXD_FIFO_PAR0        E1000_ICR_RXD_FIFO_PAR0
-/* Q0 Tx desc FIFO parity error */
-#define E1000_IMS_TXD_FIFO_PAR0        E1000_ICR_TXD_FIFO_PAR0
-/* host arb read buffer parity error */
-#define E1000_IMS_HOST_ARB_PAR E1000_ICR_HOST_ARB_PAR
-/* packet buffer parity error */
-#define E1000_IMS_PB_PAR       E1000_ICR_PB_PAR
-/* Q1 Rx desc FIFO parity error */
-#define E1000_IMS_RXD_FIFO_PAR1        E1000_ICR_RXD_FIFO_PAR1
-/* Q1 Tx desc FIFO parity error */
-#define E1000_IMS_TXD_FIFO_PAR1        E1000_ICR_TXD_FIFO_PAR1
-#define E1000_IMS_DSW          E1000_ICR_DSW
-#define E1000_IMS_PHYINT       E1000_ICR_PHYINT
 #define E1000_IMS_DOUTSYNC     E1000_ICR_DOUTSYNC /* NIC DMA out of sync */
-#define E1000_IMS_EPRST                E1000_ICR_EPRST
 #define E1000_IMS_RXQ0         E1000_ICR_RXQ0 /* Rx Queue 0 Interrupt */
 #define E1000_IMS_RXQ1         E1000_ICR_RXQ1 /* Rx Queue 1 Interrupt */
 #define E1000_IMS_TXQ0         E1000_ICR_TXQ0 /* Tx Queue 0 Interrupt */
@@ -957,41 +638,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_EIMS_OTHER       E1000_EICR_OTHER   /* Interrupt Cause Active */
 
 /* Interrupt Cause Set */
-#define E1000_ICS_TXDW         E1000_ICR_TXDW      /* Tx desc written back */
-#define E1000_ICS_TXQE         E1000_ICR_TXQE      /* Transmit Queue empty */
 #define E1000_ICS_LSC          E1000_ICR_LSC       /* Link Status Change */
 #define E1000_ICS_RXSEQ                E1000_ICR_RXSEQ     /* Rx sequence error */
 #define E1000_ICS_RXDMT0       E1000_ICR_RXDMT0    /* Rx desc min. threshold */
-#define E1000_ICS_RXO          E1000_ICR_RXO       /* Rx overrun */
-#define E1000_ICS_RXT0         E1000_ICR_RXT0      /* Rx timer intr */
-#define E1000_ICS_MDAC         E1000_ICR_MDAC      /* MDIO access complete */
-#define E1000_ICS_RXCFG                E1000_ICR_RXCFG     /* Rx /c/ ordered set */
-#define E1000_ICS_GPI_EN0      E1000_ICR_GPI_EN0   /* GP Int 0 */
-#define E1000_ICS_GPI_EN1      E1000_ICR_GPI_EN1   /* GP Int 1 */
-#define E1000_ICS_GPI_EN2      E1000_ICR_GPI_EN2   /* GP Int 2 */
-#define E1000_ICS_GPI_EN3      E1000_ICR_GPI_EN3   /* GP Int 3 */
-#define E1000_ICS_TXD_LOW      E1000_ICR_TXD_LOW
-#define E1000_ICS_SRPD         E1000_ICR_SRPD
-#define E1000_ICS_ACK          E1000_ICR_ACK       /* Receive Ack frame */
-#define E1000_ICS_MNG          E1000_ICR_MNG       /* Manageability event */
-#define E1000_ICS_DOCK         E1000_ICR_DOCK      /* Dock/Undock */
-#define E1000_ICS_DRSTA                E1000_ICR_DRSTA     /* Device Reset Aserted */
-/* Q0 Rx desc FIFO parity error */
-#define E1000_ICS_RXD_FIFO_PAR0        E1000_ICR_RXD_FIFO_PAR0
-/* Q0 Tx desc FIFO parity error */
-#define E1000_ICS_TXD_FIFO_PAR0        E1000_ICR_TXD_FIFO_PAR0
-/* host arb read buffer parity error */
-#define E1000_ICS_HOST_ARB_PAR E1000_ICR_HOST_ARB_PAR
-/* packet buffer parity error */
-#define E1000_ICS_PB_PAR       E1000_ICR_PB_PAR
-/* Q1 Rx desc FIFO parity error */
-#define E1000_ICS_RXD_FIFO_PAR1        E1000_ICR_RXD_FIFO_PAR1
-/* Q1 Tx desc FIFO parity error */
-#define E1000_ICS_TXD_FIFO_PAR1        E1000_ICR_TXD_FIFO_PAR1
-#define E1000_ICS_DSW          E1000_ICR_DSW
-#define E1000_ICS_DOUTSYNC     E1000_ICR_DOUTSYNC /* NIC DMA out of sync */
-#define E1000_ICS_PHYINT       E1000_ICR_PHYINT
-#define E1000_ICS_EPRST                E1000_ICR_EPRST
 
 /* Extended Interrupt Cause Set */
 #define E1000_EICS_RX_QUEUE0   E1000_EICR_RX_QUEUE0 /* Rx Queue 0 Interrupt */
@@ -1008,13 +657,13 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_EITR_ITR_INT_MASK        0x0000FFFF
 /* E1000_EITR_CNT_IGNR is only for 82576 and newer */
 #define E1000_EITR_CNT_IGNR    0x80000000 /* Don't reset counters on write */
+#define E1000_EITR_INTERVAL 0x00007FFC
 
 /* Transmit Descriptor Control */
 #define E1000_TXDCTL_PTHRESH   0x0000003F /* TXDCTL Prefetch Threshold */
 #define E1000_TXDCTL_HTHRESH   0x00003F00 /* TXDCTL Host Threshold */
 #define E1000_TXDCTL_WTHRESH   0x003F0000 /* TXDCTL Writeback Threshold */
 #define E1000_TXDCTL_GRAN      0x01000000 /* TXDCTL Granularity */
-#define E1000_TXDCTL_LWTHRESH  0xFE000000 /* TXDCTL Low Threshold */
 #define E1000_TXDCTL_FULL_TX_DESC_WB   0x01010000 /* GRAN=1, WTHRESH=1 */
 #define E1000_TXDCTL_MAX_TX_DESC_PREFETCH 0x0100001F /* GRAN=1, PTHRESH=31 */
 /* Enable the counting of descriptors still to be processed. */
@@ -1041,8 +690,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_RAL_MAC_ADDR_LEN 4
 #define E1000_RAH_MAC_ADDR_LEN 2
 #define E1000_RAH_QUEUE_MASK_82575     0x000C0000
-#define E1000_RAH_POOL_MASK    0x03FC0000
-#define E1000_RAH_POOL_SHIFT   18
 #define E1000_RAH_POOL_1       0x00040000
 
 /* Error Codes */
@@ -1082,30 +729,21 @@ POSSIBILITY OF SUCH DAMAGE.
 
 /* Flow Control */
 #define E1000_FCRTH_RTH                0x0000FFF8 /* Mask Bits[15:3] for RTH */
-#define E1000_FCRTH_XFCE       0x80000000 /* External Flow Control Enable */
 #define E1000_FCRTL_RTL                0x0000FFF8 /* Mask Bits[15:3] for RTL */
 #define E1000_FCRTL_XONE       0x80000000 /* Enable XON frame transmission */
 
 /* Transmit Configuration Word */
 #define E1000_TXCW_FD          0x00000020 /* TXCW full duplex */
-#define E1000_TXCW_HD          0x00000040 /* TXCW half duplex */
 #define E1000_TXCW_PAUSE       0x00000080 /* TXCW sym pause request */
 #define E1000_TXCW_ASM_DIR     0x00000100 /* TXCW astm pause direction */
 #define E1000_TXCW_PAUSE_MASK  0x00000180 /* TXCW pause request mask */
-#define E1000_TXCW_RF          0x00003000 /* TXCW remote fault */
-#define E1000_TXCW_NP          0x00008000 /* TXCW next page */
-#define E1000_TXCW_CW          0x0000ffff /* TxConfigWord mask */
-#define E1000_TXCW_TXC         0x40000000 /* Transmit Config control */
 #define E1000_TXCW_ANE         0x80000000 /* Auto-neg enable */
 
 /* Receive Configuration Word */
 #define E1000_RXCW_CW          0x0000ffff /* RxConfigWord mask */
-#define E1000_RXCW_NC          0x04000000 /* Receive config no carrier */
 #define E1000_RXCW_IV          0x08000000 /* Receive config invalid */
-#define E1000_RXCW_CC          0x10000000 /* Receive config change */
 #define E1000_RXCW_C           0x20000000 /* Receive config */
 #define E1000_RXCW_SYNCH       0x40000000 /* Receive config synch */
-#define E1000_RXCW_ANC         0x80000000 /* Auto-neg complete */
 
 #define E1000_TSYNCTXCTL_VALID         0x00000001 /* Tx timestamp valid */
 #define E1000_TSYNCTXCTL_ENABLED       0x00000010 /* enable Tx timestamping */
@@ -1175,6 +813,17 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_MDICNFG_PHY_MASK         0x03E00000
 #define E1000_MDICNFG_PHY_SHIFT                21
 
+#define E1000_MEDIA_PORT_COPPER                        1
+#define E1000_MEDIA_PORT_OTHER                 2
+#define E1000_M88E1112_AUTO_COPPER_SGMII       0x2
+#define E1000_M88E1112_AUTO_COPPER_BASEX       0x3
+#define E1000_M88E1112_STATUS_LINK             0x0004 /* Interface Link Bit */
+#define E1000_M88E1112_MAC_CTRL_1              0x10
+#define E1000_M88E1112_MAC_CTRL_1_MODE_MASK    0x0380 /* Mode Select */
+#define E1000_M88E1112_MAC_CTRL_1_MODE_SHIFT   7
+#define E1000_M88E1112_PAGE_ADDR               0x16
+#define E1000_M88E1112_STATUS                  0x01
+
 #define E1000_THSTAT_LOW_EVENT         0x20000000 /* Low thermal threshold */
 #define E1000_THSTAT_MID_EVENT         0x00200000 /* Mid thermal threshold */
 #define E1000_THSTAT_HIGH_EVENT                0x00002000 /* High thermal threshold */
@@ -1191,7 +840,21 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_EEER_EEE_NEG             0x20000000 /* EEE capability nego */
 #define E1000_EEER_RX_LPI_STATUS       0x40000000 /* Rx in LPI state */
 #define E1000_EEER_TX_LPI_STATUS       0x80000000 /* Tx in LPI state */
+#define E1000_EEE_LP_ADV_ADDR_I350     0x040F     /* EEE LP Advertisement */
+#define E1000_M88E1543_PAGE_ADDR       0x16       /* Page Offset Register */
+#define E1000_M88E1543_EEE_CTRL_1      0x0
+#define E1000_M88E1543_EEE_CTRL_1_MS   0x0001     /* EEE Master/Slave */
+#define E1000_EEE_ADV_DEV_I354         7
+#define E1000_EEE_ADV_ADDR_I354                60
+#define E1000_EEE_ADV_100_SUPPORTED    (1 << 1)   /* 100BaseTx EEE Supported */
+#define E1000_EEE_ADV_1000_SUPPORTED   (1 << 2)   /* 1000BaseT EEE Supported */
+#define E1000_PCS_STATUS_DEV_I354      3
+#define E1000_PCS_STATUS_ADDR_I354     1
+#define E1000_PCS_STATUS_RX_LPI_RCVD   0x0400
+#define E1000_PCS_STATUS_TX_LPI_RCVD   0x0800
 #define E1000_EEE_SU_LPI_CLK_STP       0x00800000 /* EEE LPI Clock Stop */
+#define E1000_EEE_LP_ADV_DEV_I210      7          /* EEE LP Adv Device */
+#define E1000_EEE_LP_ADV_ADDR_I210     61         /* EEE LP Adv Register */
 /* PCI Express Control */
 #define E1000_GCR_RXD_NO_SNOOP         0x00000001
 #define E1000_GCR_RXDSCW_NO_SNOOP      0x00000002
@@ -1211,6 +874,8 @@ POSSIBILITY OF SUCH DAMAGE.
                                 E1000_GCR_TXDSCW_NO_SNOOP | \
                                 E1000_GCR_TXDSCR_NO_SNOOP)
 
+#define E1000_MMDAC_FUNC_DATA  0x4000 /* Data, no post increment */
+
 /* mPHY address control and data registers */
 #define E1000_MPHY_ADDR_CTL            0x0024 /* Address Control Reg */
 #define E1000_MPHY_ADDR_CTL_OFFSET_MASK        0xFFFF0000
@@ -1335,10 +1000,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_EECD_CS          0x00000002 /* NVM Chip Select */
 #define E1000_EECD_DI          0x00000004 /* NVM Data In */
 #define E1000_EECD_DO          0x00000008 /* NVM Data Out */
-#define E1000_EECD_FWE_MASK    0x00000030
-#define E1000_EECD_FWE_DIS     0x00000010 /* Disable FLASH writes */
-#define E1000_EECD_FWE_EN      0x00000020 /* Enable FLASH writes */
-#define E1000_EECD_FWE_SHIFT   4
 #define E1000_EECD_REQ         0x00000040 /* NVM Access Request */
 #define E1000_EECD_GNT         0x00000080 /* NVM Access Grant */
 #define E1000_EECD_PRES                0x00000100 /* NVM Present */
@@ -1356,14 +1017,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_EECD_AUTO_RD             0x00000200  /* NVM Auto Read done */
 #define E1000_EECD_SIZE_EX_MASK                0x00007800  /* NVM Size */
 #define E1000_EECD_SIZE_EX_SHIFT       11
-#define E1000_EECD_NVADDS              0x00018000 /* NVM Address Size */
-#define E1000_EECD_SELSHAD             0x00020000 /* Select Shadow RAM */
-#define E1000_EECD_INITSRAM            0x00040000 /* Initialize Shadow RAM */
 #define E1000_EECD_FLUPD               0x00080000 /* Update FLASH */
 #define E1000_EECD_AUPDEN              0x00100000 /* Ena Auto FLASH update */
-#define E1000_EECD_SHADV               0x00200000 /* Shadow RAM Data Valid */
 #define E1000_EECD_SEC1VAL             0x00400000 /* Sector One Valid */
-#define E1000_EECD_SECVAL_SHIFT                22
 #define E1000_EECD_SEC1VAL_VALID_MASK  (E1000_EECD_AUTO_RD | E1000_EECD_PRES)
 #define E1000_EECD_FLUPD_I210          0x00800000 /* Update FLASH */
 #define E1000_EECD_FLUDONE_I210                0x04000000 /* Update FLASH done */
@@ -1377,8 +1033,12 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_I210_FIFO_SEL_BMC2OS_TX  0x06
 #define E1000_I210_FIFO_SEL_BMC2OS_RX  0x01
 
-#define E1000_NVM_SWDPIN0      0x0001 /* SWDPIN 0 NVM Value */
-#define E1000_NVM_LED_LOGIC    0x0020 /* Led Logic Word */
+#define E1000_I210_FLASH_SECTOR_SIZE   0x1000 /* 4KB FLASH sector unit size */
+/* Secure FLASH mode requires removing MSb */
+#define E1000_I210_FW_PTR_MASK         0x7FFF
+/* Firmware code revision field word offset*/
+#define E1000_I210_FW_VER_OFFSET       328
+
 #define E1000_NVM_RW_REG_DATA  16  /* Offset to data in NVM read/write regs */
 #define E1000_NVM_RW_REG_DONE  2   /* Offset to READ/WRITE done bit */
 #define E1000_NVM_RW_REG_START 1   /* Start operation */
@@ -1393,20 +1053,40 @@ POSSIBILITY OF SUCH DAMAGE.
 #define NVM_VERSION                    0x0005
 #define NVM_SERDES_AMPLITUDE           0x0006 /* SERDES output amplitude */
 #define NVM_PHY_CLASS_WORD             0x0007
+#define E1000_I210_NVM_FW_MODULE_PTR   0x0010
+#define E1000_I350_NVM_FW_MODULE_PTR   0x0051
 #define NVM_FUTURE_INIT_WORD1          0x0019
-#define NVM_FUTURE_INIT_WORD2          0x001A
 #define NVM_ETRACK_WORD                        0x0042
+#define NVM_ETRACK_HIWORD              0x0043
 #define NVM_COMB_VER_OFF               0x0083
 #define NVM_COMB_VER_PTR               0x003d
 
 /* NVM version defines */
 #define NVM_MAJOR_MASK                 0xF000
-#define NVM_MINOR_MASK                 0x000F
+#define NVM_MINOR_MASK                 0x0FF0
+#define NVM_IMAGE_ID_MASK              0x000F
 #define NVM_COMB_VER_MASK              0x00FF
 #define NVM_MAJOR_SHIFT                        12
+#define NVM_MINOR_SHIFT                        4
 #define NVM_COMB_VER_SHFT              8
 #define NVM_VER_INVALID                        0xFFFF
 #define NVM_ETRACK_SHIFT               16
+#define NVM_ETRACK_VALID               0x8000
+#define NVM_NEW_DEC_MASK               0x0F00
+#define NVM_HEX_CONV                   16
+#define NVM_HEX_TENS                   10
+
+/* FW version defines */
+/* Offset of "Loader patch ptr" in Firmware Header */
+#define E1000_I350_NVM_FW_LOADER_PATCH_PTR_OFFSET      0x01
+/* Patch generation hour & minutes */
+#define E1000_I350_NVM_FW_VER_WORD1_OFFSET             0x04
+/* Patch generation month & day */
+#define E1000_I350_NVM_FW_VER_WORD2_OFFSET             0x05
+/* Patch generation year */
+#define E1000_I350_NVM_FW_VER_WORD3_OFFSET             0x06
+/* Patch major & minor numbers */
+#define E1000_I350_NVM_FW_VER_WORD4_OFFSET             0x07
 
 #define NVM_MAC_ADDR                   0x0000
 #define NVM_SUB_DEV_ID                 0x000B
@@ -1421,15 +1101,12 @@ POSSIBILITY OF SUCH DAMAGE.
 #define NVM_COMPAT_VALID_CSUM          0x0001
 #define NVM_FUTURE_INIT_WORD1_VALID_CSUM       0x0040
 
-#define NVM_INIT_CONTROL1_REG          0x000A
 #define NVM_INIT_CONTROL2_REG          0x000F
-#define NVM_SWDEF_PINS_CTRL_PORT_1     0x0010
 #define NVM_INIT_CONTROL3_PORT_B       0x0014
 #define NVM_INIT_3GIO_3                        0x001A
 #define NVM_SWDEF_PINS_CTRL_PORT_0     0x0020
 #define NVM_INIT_CONTROL3_PORT_A       0x0024
 #define NVM_CFG                                0x0012
-#define NVM_FLASH_VERSION              0x0032
 #define NVM_ALT_MAC_ADDR_PTR           0x0037
 #define NVM_CHECKSUM_REG               0x003F
 #define NVM_COMPATIBILITY_REG_3                0x0003
@@ -1455,9 +1132,7 @@ POSSIBILITY OF SUCH DAMAGE.
 #define NVM_WORD0F_PAUSE_MASK          0x3000
 #define NVM_WORD0F_PAUSE               0x1000
 #define NVM_WORD0F_ASM_DIR             0x2000
-#define NVM_WORD0F_ANE                 0x0800
 #define NVM_WORD0F_SWPDIO_EXT_MASK     0x00F0
-#define NVM_WORD0F_LPLU                        0x0001
 
 /* Mask bits for fields in Word 0x1a of the NVM */
 #define NVM_WORD1A_ASPM_MASK           0x000C
@@ -1471,7 +1146,7 @@ POSSIBILITY OF SUCH DAMAGE.
 /* For checksumming, the sum of all words in the NVM should equal 0xBABA. */
 #define NVM_SUM                                0xBABA
 
-#define NVM_MAC_ADDR_OFFSET            0
+/* PBA (printed board assembly) number words */
 #define NVM_PBA_OFFSET_0               8
 #define NVM_PBA_OFFSET_1               9
 #define NVM_PBA_PTR_GUARD              0xFAFA
@@ -1496,16 +1171,10 @@ POSSIBILITY OF SUCH DAMAGE.
 #define NVM_WRITE_OPCODE_SPI   0x02 /* NVM write opcode */
 #define NVM_A8_OPCODE_SPI      0x08 /* opcode bit-3 = address bit-8 */
 #define NVM_WREN_OPCODE_SPI    0x06 /* NVM set Write Enable latch */
-#define NVM_WRDI_OPCODE_SPI    0x04 /* NVM reset Write Enable latch */
 #define NVM_RDSR_OPCODE_SPI    0x05 /* NVM read Status register */
-#define NVM_WRSR_OPCODE_SPI    0x01 /* NVM write Status register */
 
 /* SPI NVM Status Register */
 #define NVM_STATUS_RDY_SPI     0x01
-#define NVM_STATUS_WEN_SPI     0x02
-#define NVM_STATUS_BP0_SPI     0x04
-#define NVM_STATUS_BP1_SPI     0x08
-#define NVM_STATUS_WPEN_SPI    0x80
 
 /* Word definitions for ID LED Settings */
 #define ID_LED_RESERVED_0000   0x0000
@@ -1551,6 +1220,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define PCIE_LINK_SPEED_5000           0x02
 #define PCIE_DEVICE_CONTROL2_16ms      0x0005
 
+#ifndef ETH_ADDR_LEN
+#define ETH_ADDR_LEN                   6
+#endif
 
 #define PHY_REVISION_MASK              0xFFFFFFF0
 #define MAX_PHY_REG_ADDRESS            0x1F  /* 5 bit address bus (0-0x1F) */
@@ -1564,8 +1236,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define M88E1000_I_PHY_ID      0x01410C30
 #define M88E1011_I_PHY_ID      0x01410C20
 #define IGP01E1000_I_PHY_ID    0x02A80380
-#define M88E1011_I_REV_4       0x04
 #define M88E1111_I_PHY_ID      0x01410CC0
+#define M88E1543_E_PHY_ID      0x01410EA0
+#define M88E1512_E_PHY_ID      0x01410DD0
 #define M88E1112_E_PHY_ID      0x01410C90
 #define I347AT4_E_PHY_ID       0x01410DC0
 #define M88E1340M_E_PHY_ID     0x01410DF0
@@ -1589,8 +1262,6 @@ POSSIBILITY OF SUCH DAMAGE.
 /* M88E1000 Specific Registers */
 #define M88E1000_PHY_SPEC_CTRL         0x10  /* PHY Specific Control Reg */
 #define M88E1000_PHY_SPEC_STATUS       0x11  /* PHY Specific Status Reg */
-#define M88E1000_INT_ENABLE            0x12  /* Interrupt Enable Reg */
-#define M88E1000_INT_STATUS            0x13  /* Interrupt Status Reg */
 #define M88E1000_EXT_PHY_SPEC_CTRL     0x14  /* Extended PHY Specific Cntrl */
 #define M88E1000_RX_ERR_CNTR           0x15  /* Receive Error Counter */
 
@@ -1601,11 +1272,7 @@ POSSIBILITY OF SUCH DAMAGE.
 #define M88E1000_PHY_VCO_REG_BIT11     0x800 /* improved BER performance */
 
 /* M88E1000 PHY Specific Control Register */
-#define M88E1000_PSCR_JABBER_DISABLE   0x0001 /* 1=Jabber Function disabled */
 #define M88E1000_PSCR_POLARITY_REVERSAL        0x0002 /* 1=Polarity Reverse enabled */
-#define M88E1000_PSCR_SQE_TEST         0x0004 /* 1=SQE Test enabled */
-/* 1=CLK125 low, 0=CLK125 toggling */
-#define M88E1000_PSCR_CLK125_DISABLE   0x0010
 /* MDI Crossover Mode bits 6:5 Manual MDI configuration */
 #define M88E1000_PSCR_MDI_MANUAL_MODE  0x0000
 #define M88E1000_PSCR_MDIX_MANUAL_MODE 0x0020  /* Manual MDIX configuration */
@@ -1613,19 +1280,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define M88E1000_PSCR_AUTO_X_1000T     0x0040
 /* Auto crossover enabled all speeds */
 #define M88E1000_PSCR_AUTO_X_MODE      0x0060
-/*
- * 1=Enable Extended 10BASE-T distance (Lower 10BASE-T Rx Threshold
- * 0=Normal 10BASE-T Rx Threshold
- */
-#define M88E1000_PSCR_EN_10BT_EXT_DIST 0x0080
-/* 1=5-bit interface in 100BASE-TX, 0=MII interface in 100BASE-TX */
-#define M88E1000_PSCR_MII_5BIT_ENABLE  0x0100
-#define M88E1000_PSCR_SCRAMBLER_DISABLE        0x0200 /* 1=Scrambler disable */
-#define M88E1000_PSCR_FORCE_LINK_GOOD  0x0400 /* 1=Force link good */
 #define M88E1000_PSCR_ASSERT_CRS_ON_TX 0x0800 /* 1=Assert CRS on Tx */
 
 /* M88E1000 PHY Specific Status Register */
-#define M88E1000_PSSR_JABBER           0x0001 /* 1=Jabber */
 #define M88E1000_PSSR_REV_POLARITY     0x0002 /* 1=Polarity reversed */
 #define M88E1000_PSSR_DOWNSHIFT                0x0020 /* 1=Downshifted */
 #define M88E1000_PSSR_MDIX             0x0040 /* 1=MDIX; 0=MDI */
@@ -1638,51 +1295,24 @@ POSSIBILITY OF SUCH DAMAGE.
 #define M88E1000_PSSR_CABLE_LENGTH     0x0380
 #define M88E1000_PSSR_LINK             0x0400 /* 1=Link up, 0=Link down */
 #define M88E1000_PSSR_SPD_DPLX_RESOLVED        0x0800 /* 1=Speed & Duplex resolved */
-#define M88E1000_PSSR_PAGE_RCVD                0x1000 /* 1=Page received */
 #define M88E1000_PSSR_DPLX             0x2000 /* 1=Duplex 0=Half Duplex */
 #define M88E1000_PSSR_SPEED            0xC000 /* Speed, bits 14:15 */
-#define M88E1000_PSSR_10MBS            0x0000 /* 00=10Mbs */
 #define M88E1000_PSSR_100MBS           0x4000 /* 01=100Mbs */
 #define M88E1000_PSSR_1000MBS          0x8000 /* 10=1000Mbs */
 
 #define M88E1000_PSSR_CABLE_LENGTH_SHIFT       7
 
-/* M88E1000 Extended PHY Specific Control Register */
-#define M88E1000_EPSCR_FIBER_LOOPBACK  0x4000 /* 1=Fiber loopback */
-/*
- * 1 = Lost lock detect enabled.
- * Will assert lost lock and bring
- * link down if idle not seen
- * within 1ms in 1000BASE-T
- */
-#define M88E1000_EPSCR_DOWN_NO_IDLE    0x8000
 /* Number of times we will attempt to autonegotiate before downshifting if we
  * are the master
  */
 #define M88E1000_EPSCR_MASTER_DOWNSHIFT_MASK   0x0C00
 #define M88E1000_EPSCR_MASTER_DOWNSHIFT_1X     0x0000
-#define M88E1000_EPSCR_MASTER_DOWNSHIFT_2X     0x0400
-#define M88E1000_EPSCR_MASTER_DOWNSHIFT_3X     0x0800
-#define M88E1000_EPSCR_MASTER_DOWNSHIFT_4X     0x0C00
 /* Number of times we will attempt to autonegotiate before downshifting if we
  * are the slave
  */
 #define M88E1000_EPSCR_SLAVE_DOWNSHIFT_MASK    0x0300
-#define M88E1000_EPSCR_SLAVE_DOWNSHIFT_DIS     0x0000
 #define M88E1000_EPSCR_SLAVE_DOWNSHIFT_1X      0x0100
-#define M88E1000_EPSCR_SLAVE_DOWNSHIFT_2X      0x0200
-#define M88E1000_EPSCR_SLAVE_DOWNSHIFT_3X      0x0300
-#define M88E1000_EPSCR_TX_CLK_2_5      0x0060 /* 2.5 MHz TX_CLK */
 #define M88E1000_EPSCR_TX_CLK_25       0x0070 /* 25  MHz TX_CLK */
-#define M88E1000_EPSCR_TX_CLK_0                0x0000 /* NO  TX_CLK */
-
-/* M88E1111 Specific Registers */
-#define M88E1111_PHY_PAGE_SELECT1      0x16  /* for registers 0-28 */
-#define M88E1111_PHY_PAGE_SELECT2      0x1D  /* for registers 30-31 */
-
-/* M88E1111 page select register mask */
-#define M88E1111_PHY_PAGE_SELECT_MASK1 0xFF
-#define M88E1111_PHY_PAGE_SELECT_MASK2 0x3F
 
 /* Intel I347AT4 Registers */
 #define I347AT4_PCDL           0x10 /* PHY Cable Diagnostics Length */
@@ -1713,14 +1343,7 @@ POSSIBILITY OF SUCH DAMAGE.
 
 /* M88EC018 Rev 2 specific DownShift settings */
 #define M88EC018_EPSCR_DOWNSHIFT_COUNTER_MASK  0x0E00
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_1X    0x0000
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_2X    0x0200
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_3X    0x0400
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_4X    0x0600
 #define M88EC018_EPSCR_DOWNSHIFT_COUNTER_5X    0x0800
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_6X    0x0A00
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_7X    0x0C00
-#define M88EC018_EPSCR_DOWNSHIFT_COUNTER_8X    0x0E00
 
 #define I82578_EPSCR_DOWNSHIFT_ENABLE          0x0020
 #define I82578_EPSCR_DOWNSHIFT_COUNTER_MASK    0x001C
@@ -1739,49 +1362,24 @@ POSSIBILITY OF SUCH DAMAGE.
 
 /* GG82563 Specific Registers */
 #define GG82563_PHY_SPEC_CTRL          GG82563_REG(0, 16) /* PHY Spec Cntrl */
-#define GG82563_PHY_SPEC_STATUS                GG82563_REG(0, 17) /* PHY Spec Status */
-#define GG82563_PHY_INT_ENABLE         GG82563_REG(0, 18) /* Interrupt Ena */
-#define GG82563_PHY_SPEC_STATUS_2      GG82563_REG(0, 19) /* PHY Spec Stat2 */
-#define GG82563_PHY_RX_ERR_CNTR                GG82563_REG(0, 21) /* Rx Err Counter */
 #define GG82563_PHY_PAGE_SELECT                GG82563_REG(0, 22) /* Page Select */
 #define GG82563_PHY_SPEC_CTRL_2                GG82563_REG(0, 26) /* PHY Spec Cntrl2 */
 #define GG82563_PHY_PAGE_SELECT_ALT    GG82563_REG(0, 29) /* Alt Page Select */
-/* Test Clock Control (use reg. 29 to select) */
-#define GG82563_PHY_TEST_CLK_CTRL      GG82563_REG(0, 30)
 
 /* MAC Specific Control Register */
 #define GG82563_PHY_MAC_SPEC_CTRL      GG82563_REG(2, 21)
-#define GG82563_PHY_MAC_SPEC_CTRL_2    GG82563_REG(2, 26) /* MAC Spec Ctrl 2 */
 
 #define GG82563_PHY_DSP_DISTANCE       GG82563_REG(5, 26) /* DSP Distance */
 
 /* Page 193 - Port Control Registers */
 /* Kumeran Mode Control */
 #define GG82563_PHY_KMRN_MODE_CTRL     GG82563_REG(193, 16)
-#define GG82563_PHY_PORT_RESET         GG82563_REG(193, 17) /* Port Reset */
-#define GG82563_PHY_REVISION_ID                GG82563_REG(193, 18) /* Revision ID */
-#define GG82563_PHY_DEVICE_ID          GG82563_REG(193, 19) /* Device ID */
 #define GG82563_PHY_PWR_MGMT_CTRL      GG82563_REG(193, 20) /* Pwr Mgt Ctrl */
-/* Rate Adaptation Control */
-#define GG82563_PHY_RATE_ADAPT_CTRL    GG82563_REG(193, 25)
 
 /* Page 194 - KMRN Registers */
-/* FIFO's Control/Status */
-#define GG82563_PHY_KMRN_FIFO_CTRL_STAT        GG82563_REG(194, 16)
-#define GG82563_PHY_KMRN_CTRL          GG82563_REG(194, 17) /* Control */
 #define GG82563_PHY_INBAND_CTRL                GG82563_REG(194, 18) /* Inband Ctrl */
-#define GG82563_PHY_KMRN_DIAGNOSTIC    GG82563_REG(194, 19) /* Diagnostic */
-#define GG82563_PHY_ACK_TIMEOUTS       GG82563_REG(194, 20) /* Ack Timeouts */
-#define GG82563_PHY_ADV_ABILITY                GG82563_REG(194, 21) /* Adver Ability */
-/* Link Partner Advertised Ability */
-#define GG82563_PHY_LINK_PARTNER_ADV_ABILITY   GG82563_REG(194, 23)
-#define GG82563_PHY_ADV_NEXT_PAGE      GG82563_REG(194, 24) /* Adver Next Pg */
-/* Link Partner Advertised Next page */
-#define GG82563_PHY_LINK_PARTNER_ADV_NEXT_PAGE GG82563_REG(194, 25)
-#define GG82563_PHY_KMRN_MISC          GG82563_REG(194, 26) /* Misc. */
 
 /* MDI Control */
-#define E1000_MDIC_DATA_MASK   0x0000FFFF
 #define E1000_MDIC_REG_MASK    0x001F0000
 #define E1000_MDIC_REG_SHIFT   16
 #define E1000_MDIC_PHY_MASK    0x03E00000
@@ -1789,7 +1387,6 @@ POSSIBILITY OF SUCH DAMAGE.
 #define E1000_MDIC_OP_WRITE    0x04000000
 #define E1000_MDIC_OP_READ     0x08000000
 #define E1000_MDIC_READY       0x10000000
-#define E1000_MDIC_INT_EN      0x20000000
 #define E1000_MDIC_ERROR       0x40000000
 #define E1000_MDIC_DEST                0x80000000
 
@@ -1890,4 +1487,7 @@ POSSIBILITY OF SUCH DAMAGE.
 #ifndef E1000_UNUSEDARG
 #define E1000_UNUSEDARG
 #endif /* E1000_UNUSEDARG */
+#ifndef ERROR_REPORT
+#define ERROR_REPORT(fmt)      do { } while (0)
+#endif /* ERROR_REPORT */
 #endif /* _E1000_DEFINES_H_ */