Module Name: src Committed By: skrll Date: Wed Dec 22 07:19:34 UTC 2021
Modified Files: src/sys/dev/pci: if_wmreg.h Log Message: In a close run thing use #define<tab> everywhere for consistency To generate a diff of this commit: cvs rdiff -u -r1.123 -r1.124 src/sys/dev/pci/if_wmreg.h Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/pci/if_wmreg.h diff -u src/sys/dev/pci/if_wmreg.h:1.123 src/sys/dev/pci/if_wmreg.h:1.124 --- src/sys/dev/pci/if_wmreg.h:1.123 Wed Dec 22 07:16:44 2021 +++ src/sys/dev/pci/if_wmreg.h Wed Dec 22 07:19:34 2021 @@ -1,4 +1,4 @@ -/* $NetBSD: if_wmreg.h,v 1.123 2021/12/22 07:16:44 skrll Exp $ */ +/* $NetBSD: if_wmreg.h,v 1.124 2021/12/22 07:19:34 skrll Exp $ */ /* * Copyright (c) 2001 Wasabi Systems, Inc. @@ -144,7 +144,7 @@ typedef union ext_rxdesc { } erx_ctx; } __packed ext_rxdesc_t; -#define EXTRXD_DD_MASK __BIT(0) +#define EXTRXD_DD_MASK __BIT(0) /* * erxc_rsshash is used for below 2 patterns @@ -156,57 +156,57 @@ typedef union ext_rxdesc { * (2) RSS Hash * when RXCSUM.PCSD bit is set */ -#define EXTRXC_IP_ID_MASK __BITS(15,0) -#define EXTRXC_FRAG_CSUM_MASK __BITS(31,16) -#define EXTRXC_IP_ID(rsshash) __SHIFTOUT(rsshash,ERXC_IP_ID_MASK) -#define EXTRXC_FRAG_CSUM(rsshash) __SHIFTOUT(rsshash,ERXC_FRAG_CSUM_MASK) +#define EXTRXC_IP_ID_MASK __BITS(15,0) +#define EXTRXC_FRAG_CSUM_MASK __BITS(31,16) +#define EXTRXC_IP_ID(rsshash) __SHIFTOUT(rsshash,ERXC_IP_ID_MASK) +#define EXTRXC_FRAG_CSUM(rsshash) __SHIFTOUT(rsshash,ERXC_FRAG_CSUM_MASK) /* macros for nrxc_mrq */ -#define EXTRXC_RSS_TYPE_MASK __BITS(3,0) +#define EXTRXC_RSS_TYPE_MASK __BITS(3,0) /* __BITS(7,4) is reserved */ -#define EXTRXC_QUEUE_MASK __BITS(12,8) +#define EXTRXC_QUEUE_MASK __BITS(12,8) /* __BITS(31,13) is reserved */ -#define EXTRXC_RSS_TYPE(mrq) __SHIFTOUT(mrq,EXTRXC_RSS_TYPE_MASK) -#define EXTRXC_QUEUE(mrq) __SHIFTOUT(mrq,EXTRXC_QUEUE_MASK) +#define EXTRXC_RSS_TYPE(mrq) __SHIFTOUT(mrq,EXTRXC_RSS_TYPE_MASK) +#define EXTRXC_QUEUE(mrq) __SHIFTOUT(mrq,EXTRXC_QUEUE_MASK) -#define EXTRXC_RSS_TYPE_NONE 0x0 /* No hash computation done. */ -#define EXTRXC_RSS_TYPE_TCP_IPV4 0x1 -#define EXTRXC_RSS_TYPE_IPV4 0x2 -#define EXTRXC_RSS_TYPE_TCP_IPV6 0x3 -#define EXTRXC_RSS_TYPE_IPV6_EX 0x4 -#define EXTRXC_RSS_TYPE_IPV6 0x5 +#define EXTRXC_RSS_TYPE_NONE 0x0 /* No hash computation done. */ +#define EXTRXC_RSS_TYPE_TCP_IPV4 0x1 +#define EXTRXC_RSS_TYPE_IPV4 0x2 +#define EXTRXC_RSS_TYPE_TCP_IPV6 0x3 +#define EXTRXC_RSS_TYPE_IPV6_EX 0x4 +#define EXTRXC_RSS_TYPE_IPV6 0x5 /*0x6:0xF is reserved. */ -#define EXTRXC_STATUS_MASK __BITS(19,0) -#define EXTRXC_ERROR_MASK __BITS(31,20) -#define EXTRXC_STATUS(err_stat) __SHIFTOUT(err_stat,EXTRXC_STATUS_MASK) -#define EXTRXC_ERROR(err_stat) __SHIFTOUT(err_stat,EXTRXC_ERROR_MASK) +#define EXTRXC_STATUS_MASK __BITS(19,0) +#define EXTRXC_ERROR_MASK __BITS(31,20) +#define EXTRXC_STATUS(err_stat) __SHIFTOUT(err_stat,EXTRXC_STATUS_MASK) +#define EXTRXC_ERROR(err_stat) __SHIFTOUT(err_stat,EXTRXC_ERROR_MASK) /* 3:0 is reserved. */ -#define EXTRXC_ERROR_CE __BIT(4) /* The same as WRX_ER_CE. */ -#define EXTRXC_ERROR_SE __BIT(5) /* The same as WRX_ER_SE. */ -#define EXTRXC_ERROR_SEQ __BIT(6) /* The same as WRX_ER_SEQ. */ +#define EXTRXC_ERROR_CE __BIT(4) /* The same as WRX_ER_CE. */ +#define EXTRXC_ERROR_SE __BIT(5) /* The same as WRX_ER_SE. */ +#define EXTRXC_ERROR_SEQ __BIT(6) /* The same as WRX_ER_SEQ. */ /* 7 is reserved. */ -#define EXTRXC_ERROR_CXE __BIT(8) /* The same as WRX_ER_CXE. */ -#define EXTRXC_ERROR_TCPE __BIT(9) /* The same as WRX_ER_TCPE. */ -#define EXTRXC_ERROR_IPE __BIT(10) /* The same as WRX_ER_IPE. */ -#define EXTRXC_ERROR_RXE __BIT(11) /* The same as WRX_ER_RXE. */ +#define EXTRXC_ERROR_CXE __BIT(8) /* The same as WRX_ER_CXE. */ +#define EXTRXC_ERROR_TCPE __BIT(9) /* The same as WRX_ER_TCPE. */ +#define EXTRXC_ERROR_IPE __BIT(10) /* The same as WRX_ER_IPE. */ +#define EXTRXC_ERROR_RXE __BIT(11) /* The same as WRX_ER_RXE. */ -#define EXTRXC_STATUS_DD __BIT(0) /* The same as WRX_ST_DD. */ -#define EXTRXC_STATUS_EOP __BIT(1) /* The same as WRX_ST_EOP. */ +#define EXTRXC_STATUS_DD __BIT(0) /* The same as WRX_ST_DD. */ +#define EXTRXC_STATUS_EOP __BIT(1) /* The same as WRX_ST_EOP. */ /* 2 is reserved. */ -#define EXTRXC_STATUS_VP __BIT(3) /* The same as WRX_ST_VP. */ -#define EXTRXC_STATUS_UDPCS __BIT(4) /* UDP checksum calculated on packet. */ -#define EXTRXC_STATUS_TCPCS __BIT(5) /* The same as WRX_ST_TCPCS. */ -#define EXTRXC_STATUS_IPCS __BIT(6) /* The same as WRX_ST_IPCS. */ +#define EXTRXC_STATUS_VP __BIT(3) /* The same as WRX_ST_VP. */ +#define EXTRXC_STATUS_UDPCS __BIT(4) /* UDP checksum calculated on packet. */ +#define EXTRXC_STATUS_TCPCS __BIT(5) /* The same as WRX_ST_TCPCS. */ +#define EXTRXC_STATUS_IPCS __BIT(6) /* The same as WRX_ST_IPCS. */ /* 7 is reserved. */ -#define EXTRXC_STATUS_TST __BIT(8) /* Time stamp taken. */ -#define EXTRXC_STATUS_IPIDV __BIT(9) /* IP identification valid. */ -#define EXTRXC_STATUS_UDPV __BIT(10) /* Valid UDP XSUM. */ +#define EXTRXC_STATUS_TST __BIT(8) /* Time stamp taken. */ +#define EXTRXC_STATUS_IPIDV __BIT(9) /* IP identification valid. */ +#define EXTRXC_STATUS_UDPV __BIT(10) /* Valid UDP XSUM. */ /* 14:11 is reserved. */ -#define EXTRXC_STATUS_ACK __BIT(15) /* ACK packet indication. */ -#define EXTRXC_STATUS_PKTTYPE_MASK __BITS(19,16) -#define EXTRXC_STATUS_PKTTYPE(status) __SHIFTOUT(status,EXTRXC_STATUS_PKTTYPE_MASK) +#define EXTRXC_STATUS_ACK __BIT(15) /* ACK packet indication. */ +#define EXTRXC_STATUS_PKTTYPE_MASK __BITS(19,16) +#define EXTRXC_STATUS_PKTTYPE(status) __SHIFTOUT(status,EXTRXC_STATUS_PKTTYPE_MASK) /* advanced RX descriptor for 82575 and newer */ typedef union nq_rxdesc { @@ -228,11 +228,11 @@ typedef union nq_rxdesc { } __packed nq_rxdesc_t; /* for nrxd_paddr macros */ -#define NQRXD_A0_MASK __BIT(0) -#define NQRXD_NSE_MASK __BIT(0) -#define NQRXD_ADDR_MASK __BITS(63,1) +#define NQRXD_A0_MASK __BIT(0) +#define NQRXD_NSE_MASK __BIT(0) +#define NQRXD_ADDR_MASK __BITS(63,1) /* for nrxd_haddr macros */ -#define NQRXD_DD_MASK __BIT(0) +#define NQRXD_DD_MASK __BIT(0) /* * nrxc_rsshash is used for below 2 patterns @@ -244,90 +244,90 @@ typedef union nq_rxdesc { * (2) RSS Hash * when RXCSUM.PCSD bit is set */ -#define NQRXC_IP_ID_MASK __BITS(15,0) -#define NQRXC_FRAG_CSUM_MASK __BITS(31,16) -#define NQRXC_IP_ID(rsshash) __SHIFTOUT(rsshash,NRXC_IP_ID_MASK) -#define NQRXC_FRAG_CSUM(rsshash) __SHIFTOUT(rsshash,NRXC_FRAG_CSUM_MASK) +#define NQRXC_IP_ID_MASK __BITS(15,0) +#define NQRXC_FRAG_CSUM_MASK __BITS(31,16) +#define NQRXC_IP_ID(rsshash) __SHIFTOUT(rsshash,NRXC_IP_ID_MASK) +#define NQRXC_FRAG_CSUM(rsshash) __SHIFTOUT(rsshash,NRXC_FRAG_CSUM_MASK) /* macros for nrxc_misc */ -#define NQRXC_RSS_TYPE_MASK __BITS(3,0) -#define NQRXC_PKT_TYPE_ID_MASK __BITS(11,4) -#define NQRXC_PKT_TYPE_ETQF_INDEX_MASK __BITS(11,4) -#define NQRXC_PKT_TYPE_ETQF_VALID_MASK __BIT(15) -#define NQRXC_PKT_TYPE_VLAN_MASK __BIT(16) -#define NQRXC_PKT_TYPE_MASK __BITS(16,4) +#define NQRXC_RSS_TYPE_MASK __BITS(3,0) +#define NQRXC_PKT_TYPE_ID_MASK __BITS(11,4) +#define NQRXC_PKT_TYPE_ETQF_INDEX_MASK __BITS(11,4) +#define NQRXC_PKT_TYPE_ETQF_VALID_MASK __BIT(15) +#define NQRXC_PKT_TYPE_VLAN_MASK __BIT(16) +#define NQRXC_PKT_TYPE_MASK __BITS(16,4) /* __BITS(18,17) is reserved */ -#define NQRXC_HDRLEN_HIGH_MASK __BITS(20,19) -#define NQRXC_HDRLEN_LOW_MASK __BITS(30,21) -#define NQRXC_SPH_MASK __BIT(31) +#define NQRXC_HDRLEN_HIGH_MASK __BITS(20,19) +#define NQRXC_HDRLEN_LOW_MASK __BITS(30,21) +#define NQRXC_SPH_MASK __BIT(31) -#define NQRXC_RSS_TYPE(misc) __SHIFTOUT(misc,NQRXC_RSS_TYPE_MASK) -#define NQRXC_PKT_TYPE_ID(pkttype) \ +#define NQRXC_RSS_TYPE(misc) __SHIFTOUT(misc,NQRXC_RSS_TYPE_MASK) +#define NQRXC_PKT_TYPE_ID(pkttype) \ __SHIFTOUT(pkttype,NQRXC_PKT_TYPE_ID_MASK) -#define NQRXC_PKT_TYPE(misc) __SHIFTOUT(misc,NQRXC_PKT_TYPE_MASK) -#define NQRXC_PKT_TYPE_ETQF_INDEX(pkttype) \ +#define NQRXC_PKT_TYPE(misc) __SHIFTOUT(misc,NQRXC_PKT_TYPE_MASK) +#define NQRXC_PKT_TYPE_ETQF_INDEX(pkttype) \ __SHIFTOUT(pkttype,NQRXC_PKT_TYPE_ETQF_INDEX_MASK) -#define NQRXC_PKT_TYPE_ETQF_VALID NQRXC_PKT_TYPE_ETQF_VALID_MASK -#define NQRXC_PKT_TYPE_VLAN NQRXC_PKT_TYPE_VLAN_MASK -#define NQRXC_HEADER_LEN(misc) (__SHIFTOUT(misc,NQRXC_HDRLEN_LOW_MASK) \ +#define NQRXC_PKT_TYPE_ETQF_VALID NQRXC_PKT_TYPE_ETQF_VALID_MASK +#define NQRXC_PKT_TYPE_VLAN NQRXC_PKT_TYPE_VLAN_MASK +#define NQRXC_HEADER_LEN(misc) (__SHIFTOUT(misc,NQRXC_HDRLEN_LOW_MASK) \ | __SHIFTOUT(misc,NQRXC_HDRLEN_HIGH_MASK) << 10) -#define NQRXC_SPH NQRXC_SPH_MASK +#define NQRXC_SPH NQRXC_SPH_MASK -#define NQRXC_RSS_TYPE_NONE 0x0 /* No hash computation done. */ -#define NQRXC_RSS_TYPE_TCP_IPV4 0x1 -#define NQRXC_RSS_TYPE_IPV4 0x2 -#define NQRXC_RSS_TYPE_TCP_IPV6 0x3 -#define NQRXC_RSS_TYPE_IPV6_EX 0x4 -#define NQRXC_RSS_TYPE_IPV6 0x5 -#define NQRXC_RSS_TYPE_TCP_IPV6_EX 0x6 -#define NQRXC_RSS_TYPE_UDP_IPV4 0x7 -#define NQRXC_RSS_TYPE_UDP_IPV6 0x8 -#define NQRXC_RSS_TYPE_UDP_IPV6_EX 0x9 +#define NQRXC_RSS_TYPE_NONE 0x0 /* No hash computation done. */ +#define NQRXC_RSS_TYPE_TCP_IPV4 0x1 +#define NQRXC_RSS_TYPE_IPV4 0x2 +#define NQRXC_RSS_TYPE_TCP_IPV6 0x3 +#define NQRXC_RSS_TYPE_IPV6_EX 0x4 +#define NQRXC_RSS_TYPE_IPV6 0x5 +#define NQRXC_RSS_TYPE_TCP_IPV6_EX 0x6 +#define NQRXC_RSS_TYPE_UDP_IPV4 0x7 +#define NQRXC_RSS_TYPE_UDP_IPV6 0x8 +#define NQRXC_RSS_TYPE_UDP_IPV6_EX 0x9 /*0xA:0xF is reserved. */ -#define NQRXC_PKT_TYPE_IPV4 __BIT(0) -#define NQRXC_PKT_TYPE_IPV4E __BIT(1) -#define NQRXC_PKT_TYPE_IPV6 __BIT(2) -#define NQRXC_PKT_TYPE_IPV6E __BIT(3) -#define NQRXC_PKT_TYPE_TCP __BIT(4) -#define NQRXC_PKT_TYPE_UDP __BIT(5) -#define NQRXC_PKT_TYPE_SCTP __BIT(6) -#define NQRXC_PKT_TYPE_NFS __BIT(7) - -#define NQRXC_STATUS_MASK __BITS(19,0) -#define NQRXC_ERROR_MASK __BITS(31,20) -#define NQRXC_STATUS(err_stat) __SHIFTOUT(err_stat,NQRXC_STATUS_MASK) -#define NQRXC_ERROR(err_stat) __SHIFTOUT(err_stat,NQRXC_ERROR_MASK) +#define NQRXC_PKT_TYPE_IPV4 __BIT(0) +#define NQRXC_PKT_TYPE_IPV4E __BIT(1) +#define NQRXC_PKT_TYPE_IPV6 __BIT(2) +#define NQRXC_PKT_TYPE_IPV6E __BIT(3) +#define NQRXC_PKT_TYPE_TCP __BIT(4) +#define NQRXC_PKT_TYPE_UDP __BIT(5) +#define NQRXC_PKT_TYPE_SCTP __BIT(6) +#define NQRXC_PKT_TYPE_NFS __BIT(7) + +#define NQRXC_STATUS_MASK __BITS(19,0) +#define NQRXC_ERROR_MASK __BITS(31,20) +#define NQRXC_STATUS(err_stat) __SHIFTOUT(err_stat,NQRXC_STATUS_MASK) +#define NQRXC_ERROR(err_stat) __SHIFTOUT(err_stat,NQRXC_ERROR_MASK) /* 2:0 is reserved. */ -#define NQRXC_ERROR_HB0 __BIT(3) /* Header Buffer Overflow. */ +#define NQRXC_ERROR_HB0 __BIT(3) /* Header Buffer Overflow. */ /* 6:4 is reserved. */ /* 8:7 is reserved. */ -#define NQRXC_ERROR_L4E __BIT(9) /* L4 error indication. */ -#define NQRXC_ERROR_IPE __BIT(10) /* The same as WRX_ER_IPE. */ -#define NQRXC_ERROR_RXE __BIT(11) /* The same as WRX_ER_RXE. */ +#define NQRXC_ERROR_L4E __BIT(9) /* L4 error indication. */ +#define NQRXC_ERROR_IPE __BIT(10) /* The same as WRX_ER_IPE. */ +#define NQRXC_ERROR_RXE __BIT(11) /* The same as WRX_ER_RXE. */ /* XXX Where is WRX_ER_CE, WRX_ER_SE, WRX_ER_SEQ, WRX_ER_CXE error? */ -#define NQRXC_STATUS_DD __BIT(0) /* The same as WRX_ST_DD. */ -#define NQRXC_STATUS_EOP __BIT(1) /* The same as WRX_ST_EOP. */ +#define NQRXC_STATUS_DD __BIT(0) /* The same as WRX_ST_DD. */ +#define NQRXC_STATUS_EOP __BIT(1) /* The same as WRX_ST_EOP. */ /* 2 is reserved */ -#define NQRXC_STATUS_VP __BIT(3) /* The same as WRX_ST_VP. */ -#define NQRXC_STATUS_UDPCS __BIT(4) /* UDP checksum or IP payload checksum. */ +#define NQRXC_STATUS_VP __BIT(3) /* The same as WRX_ST_VP. */ +#define NQRXC_STATUS_UDPCS __BIT(4) /* UDP checksum or IP payload checksum. */ /* XXX in I210 spec, this bit is the same as WRX_ST_BPDU(is "???" comment) */ -#define NQRXC_STATUS_L4I __BIT(5) /* L4 integrity check was done. */ -#define NQRXC_STATUS_IPCS __BIT(6) /* The same as WRX_ST_IPCS. */ -#define NQRXC_STATUS_PIF __BIT(7) /* The same as WRX_ST_PIF. */ +#define NQRXC_STATUS_L4I __BIT(5) /* L4 integrity check was done. */ +#define NQRXC_STATUS_IPCS __BIT(6) /* The same as WRX_ST_IPCS. */ +#define NQRXC_STATUS_PIF __BIT(7) /* The same as WRX_ST_PIF. */ /* 8 is reserved */ -#define NQRXC_STATUS_VEXT __BIT(9) /* First VLAN is found on a bouble VLAN packet. */ -#define NQRXC_STATUS_UDPV __BIT(10) /* The packet contains a valid checksum field in a first fragment UDP IPv4 packet. */ -#define NQRXC_STATUS_LLINT __BIT(11) /* The packet caused an immediate interrupt. */ -#define NQRXC_STATUS_STRIPCRC __BIT(12) /* Ethernet CRC is stripped. */ +#define NQRXC_STATUS_VEXT __BIT(9) /* First VLAN is found on a bouble VLAN packet. */ +#define NQRXC_STATUS_UDPV __BIT(10) /* The packet contains a valid checksum field in a first fragment UDP IPv4 packet. */ +#define NQRXC_STATUS_LLINT __BIT(11) /* The packet caused an immediate interrupt. */ +#define NQRXC_STATUS_STRIPCRC __BIT(12) /* Ethernet CRC is stripped. */ /* 14:13 is reserved */ -#define NQRXC_STATUS_TSIP __BIT(15) /* Timestamp in packet. */ -#define NQRXC_STATUS_TS __BIT(16) /* Time stamped packet. */ +#define NQRXC_STATUS_TSIP __BIT(15) /* Timestamp in packet. */ +#define NQRXC_STATUS_TS __BIT(16) /* Time stamped packet. */ /* 17 is reserved */ -#define NQRXC_STATUS_LB __BIT(18) /* Sent by a local virtual machine (VM to VM switch indication). */ -#define NQRXC_STATUS_MC __BIT(19) /* Packet received from Manageability Controller */ +#define NQRXC_STATUS_LB __BIT(18) /* Sent by a local virtual machine (VM to VM switch indication). */ +#define NQRXC_STATUS_MC __BIT(19) /* Packet received from Manageability Controller */ /* "MBC" in i350 spec */ /* @@ -406,13 +406,13 @@ struct livengood_tcpip_ctxdesc { */ #define WM_PCI_MMBA PCI_MAPREG_START /* registers for FLASH access on ICH8 */ -#define WM_ICH8_FLASH 0x0014 +#define WM_ICH8_FLASH 0x0014 -#define WM_PCI_LTR_CAP_LPT 0xa8 +#define WM_PCI_LTR_CAP_LPT 0xa8 /* XXX Only for PCH_SPT? */ -#define WM_PCI_DESCRING_STATUS 0xe4 -#define DESCRING_STATUS_FLUSH_REQ __BIT(8) +#define WM_PCI_DESCRING_STATUS 0xe4 +#define DESCRING_STATUS_FLUSH_REQ __BIT(8) /* * Wiseman Control/Status Registers. @@ -433,19 +433,19 @@ struct livengood_tcpip_ctxdesc { #define CTRL_SPEED_MASK CTRL_SPEED(3) #define CTRL_FRCSPD __BIT(11) /* force speed (Livengood) */ #define CTRL_FRCFDX __BIT(12) /* force full-duplex (Livengood) */ -#define CTRL_D_UD_EN __BIT(13) /* Dock/Undock enable */ -#define CTRL_D_UD_POL __BIT(14) /* Defined polarity of Dock/Undock indication in SDP[0] */ -#define CTRL_F_PHY_R __BIT(15) /* Reset both PHY ports, through PHYRST_N pin */ -#define CTRL_EXTLINK_EN __BIT(16) /* enable link status from external LINK_0 and LINK_1 pins */ -#define CTRL_LANPHYPC_OVERRIDE __BIT(16) /* SW control of LANPHYPC */ -#define CTRL_LANPHYPC_VALUE __BIT(17) /* SW value of LANPHYPC */ +#define CTRL_D_UD_EN __BIT(13) /* Dock/Undock enable */ +#define CTRL_D_UD_POL __BIT(14) /* Defined polarity of Dock/Undock indication in SDP[0] */ +#define CTRL_F_PHY_R __BIT(15) /* Reset both PHY ports, through PHYRST_N pin */ +#define CTRL_EXTLINK_EN __BIT(16) /* enable link status from external LINK_0 and LINK_1 pins */ +#define CTRL_LANPHYPC_OVERRIDE __BIT(16) /* SW control of LANPHYPC */ +#define CTRL_LANPHYPC_VALUE __BIT(17) /* SW value of LANPHYPC */ #define CTRL_SWDPINS_SHIFT 18 #define CTRL_SWDPINS_MASK 0x0f #define CTRL_SWDPIN(x) (1U << (CTRL_SWDPINS_SHIFT + (x))) #define CTRL_SWDPIO_SHIFT 22 #define CTRL_SWDPIO_MASK 0x0f #define CTRL_SWDPIO(x) (1U << (CTRL_SWDPIO_SHIFT + (x))) -#define CTRL_MEHE __BIT(19) /* Memory Error Handling Enable(I217)*/ +#define CTRL_MEHE __BIT(19) /* Memory Error Handling Enable(I217)*/ #define CTRL_RST __BIT(26) /* device reset */ #define CTRL_RFCE __BIT(27) /* Rx flow control enable */ #define CTRL_TFCE __BIT(28) /* Tx flow control enable */ @@ -485,10 +485,10 @@ struct livengood_tcpip_ctxdesc { #define STATUS_DEV_RST_SET __BIT(20) /* Device Reset Set */ /* Strapping Option Register (PCH_SPT and newer) */ -#define WMREG_STRAP 0x000c -#define STRAP_NVMSIZE __BITS(1, 6) -#define STRAP_FREQ __BITS(12, 13) -#define STRAP_SMBUSADDR __BITS(17, 23) +#define WMREG_STRAP 0x000c +#define STRAP_NVMSIZE __BITS(1, 6) +#define STRAP_FREQ __BITS(12, 13) +#define STRAP_SMBUSADDR __BITS(17, 23) #define WMREG_EECD 0x0010 /* EEPROM Control Register */ #define EECD_SK __BIT(0) /* clock */ @@ -509,8 +509,8 @@ struct livengood_tcpip_ctxdesc { #define EECD_EE_SIZE_EX_MASK __BITS(14,11) /* EEPROM size for new devices */ #define EECD_EE_TYPE __BIT(13) /* EEPROM type (0 = Microwire, 1 = SPI) */ -#define EECD_SEC1VAL __BIT(22) /* Sector One Valid */ -#define EECD_SEC1VAL_VALMASK (EECD_EE_AUTORD | EECD_EE_PRES) /* Valid Mask */ +#define EECD_SEC1VAL __BIT(22) /* Sector One Valid */ +#define EECD_SEC1VAL_VALMASK (EECD_EE_AUTORD | EECD_EE_PRES) /* Valid Mask */ #define WMREG_FEXTNVM6 0x0010 /* Future Extended NVM 6 */ #define FEXTNVM6_REQ_PLL_CLK __BIT(8) @@ -526,8 +526,8 @@ struct livengood_tcpip_ctxdesc { #define WMREG_CTRL_EXT 0x0018 /* Extended Device Control Register */ #define CTRL_EXT_NSICR __BIT(0) /* Non Interrupt clear on read */ #define CTRL_EXT_GPI_EN(x) (1U << (x)) /* gpin interrupt enable */ -#define CTRL_EXT_NVMVS __BITS(0, 1) /* NVM valid sector */ -#define CTRL_EXT_LPCD __BIT(2) /* LCD Power Cycle Done */ +#define CTRL_EXT_NVMVS __BITS(0, 1) /* NVM valid sector */ +#define CTRL_EXT_LPCD __BIT(2) /* LCD Power Cycle Done */ #define CTRL_EXT_SWDPINS_SHIFT 4 #define CTRL_EXT_SWDPINS_MASK 0x0d /* The bit order of the SW Definable pin is not 6543 but 3654! */ @@ -556,7 +556,7 @@ struct livengood_tcpip_ctxdesc { #define CTRL_EXT_LINK_MODE_TBI 0x00c00000 #define CTRL_EXT_LINK_MODE_PCIE_SERDES 0x00c00000 #define CTRL_EXT_EIAME __BIT(24) /* Extended Interrupt Auto Mask En */ -#define CTRL_EXT_I2C_ENA 0x02000000 /* I2C enable */ +#define CTRL_EXT_I2C_ENA 0x02000000 /* I2C enable */ #define CTRL_EXT_DRV_LOAD 0x10000000 #define CTRL_EXT_PBA __BIT(31) /* PBA Support */ @@ -575,21 +575,21 @@ struct livengood_tcpip_ctxdesc { #define MDIC_E __BIT(30) /* MDI error */ #define MDIC_DEST __BIT(31) /* Destination */ -#define WMREG_SCTL 0x0024 /* SerDes Control - RW */ +#define WMREG_SCTL 0x0024 /* SerDes Control - RW */ /* * These 4 macros are also used for other 8bit control registers on the * 82575 */ -#define SCTL_CTL_READY __BIT(31) -#define SCTL_CTL_DATA_MASK 0x000000ff -#define SCTL_CTL_ADDR_SHIFT 8 -#define SCTL_CTL_POLL_TIMEOUT 640 -#define SCTL_DISABLE_SERDES_LOOPBACK 0x0400 - -#define WMREG_FEXTNVM4 0x0024 /* Future Extended NVM 4 - RW */ -#define FEXTNVM4_BEACON_DURATION __BITS(2, 0) -#define FEXTNVM4_BEACON_DURATION_8US 0x7 -#define FEXTNVM4_BEACON_DURATION_16US 0x3 +#define SCTL_CTL_READY __BIT(31) +#define SCTL_CTL_DATA_MASK 0x000000ff +#define SCTL_CTL_ADDR_SHIFT 8 +#define SCTL_CTL_POLL_TIMEOUT 640 +#define SCTL_DISABLE_SERDES_LOOPBACK 0x0400 + +#define WMREG_FEXTNVM4 0x0024 /* Future Extended NVM 4 - RW */ +#define FEXTNVM4_BEACON_DURATION __BITS(2, 0) +#define FEXTNVM4_BEACON_DURATION_8US 0x7 +#define FEXTNVM4_BEACON_DURATION_16US 0x3 #define WMREG_FCAL 0x0028 /* Flow Control Address Low */ #define FCAL_CONST 0x00c28001 /* Flow Control MAC addr low */ @@ -653,9 +653,9 @@ struct livengood_tcpip_ctxdesc { #define WMREG_VET 0x0038 /* VLAN Ethertype */ #define WMREG_MDPHYA 0x003c /* PHY address - RW */ -#define WMREG_FEXTNVM3 0x003c /* Future Extended NVM 3 */ -#define FEXTNVM3_PHY_CFG_COUNTER_MASK __BITS(27, 26) -#define FEXTNVM3_PHY_CFG_COUNTER_50MS __BIT(27) +#define WMREG_FEXTNVM3 0x003c /* Future Extended NVM 3 */ +#define FEXTNVM3_PHY_CFG_COUNTER_MASK __BITS(27, 26) +#define FEXTNVM3_PHY_CFG_COUNTER_50MS __BIT(27) #define WMREG_RAL(x) (0x0040 + ((x) * 8)) /* Receive Address List */ #define WMREG_RAH(x) (WMREG_RAL(x) + 4) @@ -703,9 +703,9 @@ struct livengood_tcpip_ctxdesc { #define ICR_OTHER __BIT(24) /* 82574: Other interrupt */ #define ICR_INT __BIT(31) /* device generated an interrupt */ -#define WMREG_ITR 0x00c4 /* Interrupt Throttling Register */ -#define ITR_IVAL_MASK 0xffff /* Interval mask */ -#define ITR_IVAL_SHIFT 0 /* Interval shift */ +#define WMREG_ITR 0x00c4 /* Interrupt Throttling Register */ +#define ITR_IVAL_MASK 0xffff /* Interval mask */ +#define ITR_IVAL_SHIFT 0 /* Interval shift */ #define WMREG_ICS 0x00c8 /* Interrupt Cause Set Register */ /* See ICR bits. */ @@ -720,34 +720,34 @@ struct livengood_tcpip_ctxdesc { #define WMREG_EIAC_82574_MSIX_MASK (ICR_RXQ(0) | ICR_RXQ(1) \ | ICR_TXQ(0) | ICR_TXQ(1) | ICR_OTHER) -#define WMREG_FEXTNVM7 0x00e4 /* Future Extended NVM 7 */ -#define FEXTNVM7_SIDE_CLK_UNGATE __BIT(2) -#define FEXTNVM7_DIS_SMB_PERST __BIT(5) -#define FEXTNVM7_DIS_PB_READ __BIT(18) - -#define WMREG_IVAR 0x00e4 /* Interrupt Vector Allocation Register */ -#define WMREG_IVAR0 0x01700 /* Interrupt Vector Allocation */ -#define IVAR_ALLOC_MASK __BITS(0, 6) /* Bit 5 and 6 are reserved */ -#define IVAR_VALID __BIT(7) +#define WMREG_FEXTNVM7 0x00e4 /* Future Extended NVM 7 */ +#define FEXTNVM7_SIDE_CLK_UNGATE __BIT(2) +#define FEXTNVM7_DIS_SMB_PERST __BIT(5) +#define FEXTNVM7_DIS_PB_READ __BIT(18) + +#define WMREG_IVAR 0x00e4 /* Interrupt Vector Allocation Register */ +#define WMREG_IVAR0 0x01700 /* Interrupt Vector Allocation */ +#define IVAR_ALLOC_MASK __BITS(0, 6) /* Bit 5 and 6 are reserved */ +#define IVAR_VALID __BIT(7) /* IVAR definitions for 82580 and newer */ -#define WMREG_IVAR_Q(x) (WMREG_IVAR0 + ((x) / 2) * 4) -#define IVAR_TX_MASK_Q(x) (0x000000ffUL << (((x) % 2) == 0 ? 8 : 24)) -#define IVAR_RX_MASK_Q(x) (0x000000ffUL << (((x) % 2) == 0 ? 0 : 16)) +#define WMREG_IVAR_Q(x) (WMREG_IVAR0 + ((x) / 2) * 4) +#define IVAR_TX_MASK_Q(x) (0x000000ffUL << (((x) % 2) == 0 ? 8 : 24)) +#define IVAR_RX_MASK_Q(x) (0x000000ffUL << (((x) % 2) == 0 ? 0 : 16)) /* IVAR definitions for 82576 */ -#define WMREG_IVAR_Q_82576(x) (WMREG_IVAR0 + ((x) & 0x7) * 4) -#define IVAR_TX_MASK_Q_82576(x) (0x000000ffUL << (((x) / 8) == 0 ? 8 : 24)) -#define IVAR_RX_MASK_Q_82576(x) (0x000000ffUL << (((x) / 8) == 0 ? 0 : 16)) +#define WMREG_IVAR_Q_82576(x) (WMREG_IVAR0 + ((x) & 0x7) * 4) +#define IVAR_TX_MASK_Q_82576(x) (0x000000ffUL << (((x) / 8) == 0 ? 8 : 24)) +#define IVAR_RX_MASK_Q_82576(x) (0x000000ffUL << (((x) / 8) == 0 ? 0 : 16)) /* IVAR definitions for 82574 */ -#define IVAR_ALLOC_MASK_82574 __BITS(0, 2) -#define IVAR_VALID_82574 __BIT(3) -#define IVAR_TX_MASK_Q_82574(x) (0x0000000fUL << ((x) == 0 ? 8 : 12)) -#define IVAR_RX_MASK_Q_82574(x) (0x0000000fUL << ((x) == 0 ? 0 : 4)) -#define IVAR_OTHER_MASK __BITS(16, 19) -#define IVAR_INT_ON_ALL_WB __BIT(31) - -#define WMREG_IVAR_MISC 0x01740 /* IVAR for other causes */ -#define IVAR_MISC_TCPTIMER __BITS(0, 7) -#define IVAR_MISC_OTHER __BITS(8, 15) +#define IVAR_ALLOC_MASK_82574 __BITS(0, 2) +#define IVAR_VALID_82574 __BIT(3) +#define IVAR_TX_MASK_Q_82574(x) (0x0000000fUL << ((x) == 0 ? 8 : 12)) +#define IVAR_RX_MASK_Q_82574(x) (0x0000000fUL << ((x) == 0 ? 0 : 4)) +#define IVAR_OTHER_MASK __BITS(16, 19) +#define IVAR_INT_ON_ALL_WB __BIT(31) + +#define WMREG_IVAR_MISC 0x01740 /* IVAR for other causes */ +#define IVAR_MISC_TCPTIMER __BITS(0, 7) +#define IVAR_MISC_OTHER __BITS(8, 15) #define WMREG_SVCR 0x00f0 #define SVCR_OFF_EN __BIT(0) @@ -779,10 +779,10 @@ struct livengood_tcpip_ctxdesc { #define RCTL_RDMTS_1_4 RCTL_RDMTS(1) #define RCTL_RDMTS_1_8 RCTL_RDMTS(2) #define RCTL_RDMTS_MASK RCTL_RDMTS(3) -#define RCTL_DTYP_MASK __BITS(11,10) /* descriptor type. 82574 only */ -#define RCTL_DTYP(x) __SHIFTIN(x,RCTL_DTYP_MASK) -#define RCTL_DTYP_ONEBUF RCTL_DTYP(0) /* use one buffer(not split header). */ -#define RCTL_DTYP_SPH RCTL_DTYP(1) /* split header buffer. */ +#define RCTL_DTYP_MASK __BITS(11,10) /* descriptor type. 82574 only */ +#define RCTL_DTYP(x) __SHIFTIN(x,RCTL_DTYP_MASK) +#define RCTL_DTYP_ONEBUF RCTL_DTYP(0) /* use one buffer(not split header). */ +#define RCTL_DTYP_SPH RCTL_DTYP(1) /* split header buffer. */ /* RCTL_DTYP(2) and RCTL_DTYP(3) are reserved. */ #define RCTL_MO __BITS(13, 12) /* multicast offset */ #define RCTL_BAM __BIT(15) /* broadcast accept mode */ @@ -803,7 +803,7 @@ struct livengood_tcpip_ctxdesc { #define WMREG_RDTR 0x2820 #define RDTR_FPD __BIT(31) /* flush partial descriptor */ -#define WMREG_LTRC 0x01a0 /* Latency Tolerance Reportiong Control */ +#define WMREG_LTRC 0x01a0 /* Latency Tolerance Reportiong Control */ #define WMREG_OLD_RDBAL0 0x0110 /* Receive Descriptor Base Low (ring 0) */ #define WMREG_RDBAL(x) \ @@ -823,18 +823,18 @@ struct livengood_tcpip_ctxdesc { #define WMREG_SRRCTL(x) \ ((x) < 4 ? (0x0280c + ((x) * 0x100)) : \ (0x0c00c + ((x) * 0x40))) /* additional recv control used in 82575 ... */ -#define SRRCTL_BSIZEPKT_MASK 0x0000007f -#define SRRCTL_BSIZEPKT_SHIFT 10 /* Shift _right_ */ -#define SRRCTL_BSIZEHDRSIZE_MASK 0x00000f00 -#define SRRCTL_BSIZEHDRSIZE_SHIFT 2 /* Shift _left_ */ -#define SRRCTL_DESCTYPE_LEGACY 0x00000000 -#define SRRCTL_DESCTYPE_ADV_ONEBUF (1U << 25) -#define SRRCTL_DESCTYPE_HDR_SPLIT (2U << 25) -#define SRRCTL_DESCTYPE_HDR_REPLICATION (3U << 25) -#define SRRCTL_DESCTYPE_HDR_REPLICATION_LARGE_PKT (4U << 25) -#define SRRCTL_DESCTYPE_HDR_SPLIT_ALWAYS (5U << 25) /* 82575 only */ -#define SRRCTL_DESCTYPE_MASK (7U << 25) -#define SRRCTL_DROP_EN 0x80000000 +#define SRRCTL_BSIZEPKT_MASK 0x0000007f +#define SRRCTL_BSIZEPKT_SHIFT 10 /* Shift _right_ */ +#define SRRCTL_BSIZEHDRSIZE_MASK 0x00000f00 +#define SRRCTL_BSIZEHDRSIZE_SHIFT 2 /* Shift _left_ */ +#define SRRCTL_DESCTYPE_LEGACY 0x00000000 +#define SRRCTL_DESCTYPE_ADV_ONEBUF (1U << 25) +#define SRRCTL_DESCTYPE_HDR_SPLIT (2U << 25) +#define SRRCTL_DESCTYPE_HDR_REPLICATION (3U << 25) +#define SRRCTL_DESCTYPE_HDR_REPLICATION_LARGE_PKT (4U << 25) +#define SRRCTL_DESCTYPE_HDR_SPLIT_ALWAYS (5U << 25) /* 82575 only */ +#define SRRCTL_DESCTYPE_MASK (7U << 25) +#define SRRCTL_DROP_EN 0x80000000 #define WMREG_OLD_RDH0 0x0120 /* Receive Descriptor Head (ring 0) */ #define WMREG_RDH(x) \ @@ -854,8 +854,8 @@ struct livengood_tcpip_ctxdesc { #define RXDCTL_WTHRESH(x) ((x) << 16) /* write back threshold */ #define RXDCTL_GRAN __BIT(24) /* 0 = cacheline, 1 = descriptor */ /* flags used starting with 82575 ... */ -#define RXDCTL_QUEUE_ENABLE 0x02000000 /* Enable specific Tx Queue */ -#define RXDCTL_SWFLSH 0x04000000 /* Rx Desc. write-back flushing */ +#define RXDCTL_QUEUE_ENABLE 0x02000000 /* Enable specific Tx Queue */ +#define RXDCTL_SWFLSH 0x04000000 /* Rx Desc. write-back flushing */ #define WMREG_OLD_RDTR1 0x0130 /* Receive Delay Timer (ring 1) */ #define WMREG_OLD_RDBA1_LO 0x0138 /* Receive Descriptor Base Low (ring 1) */ @@ -952,7 +952,7 @@ struct livengood_tcpip_ctxdesc { (0x0e010 + ((x) * 0x40))) #define WMREG_OLD_TDT 0x0438 /* Transmit Descriptor Tail */ -#define WMREG_TDT(x) \ +#define WMREG_TDT(x) \ ((x) < 4 ? (0x03818 + ((x) * 0x100)) : \ (0x0e018 + ((x) * 0x40))) @@ -965,10 +965,10 @@ struct livengood_tcpip_ctxdesc { #define WMREG_LEDCTL 0x0e00 /* LED Control - RW */ #define WMREG_MDICNFG 0x0e04 /* MDC/MDIO Configuration Register */ -#define MDICNFG_PHY_SHIFT 21 -#define MDICNFG_PHY_MASK __BITS(25, 21) -#define MDICNFG_COM_MDIO __BIT(30) -#define MDICNFG_DEST __BIT(31) +#define MDICNFG_PHY_SHIFT 21 +#define MDICNFG_PHY_MASK __BITS(25, 21) +#define MDICNFG_COM_MDIO __BIT(30) +#define MDICNFG_DEST __BIT(31) #define WM_MC_TABSIZE 128 #define WM_ICH8_MC_TABSIZE 32 @@ -981,29 +981,29 @@ struct livengood_tcpip_ctxdesc { #define PHPM_NOND0A_GBE_DIS __BIT(3) /* Disable 1G in non-D0a */ #define PHPM_GO_LINK_D __BIT(5) /* Go Link Disconnect */ -#define WMREG_EEER 0x0e30 /* Energy Efficiency Ethernet "EEE" */ -#define EEER_TX_LPI_EN 0x00010000 /* EEER Tx LPI Enable */ -#define EEER_RX_LPI_EN 0x00020000 /* EEER Rx LPI Enable */ -#define EEER_LPI_FC 0x00040000 /* EEER Ena on Flow Cntrl */ -#define EEER_EEER_NEG 0x20000000 /* EEER capability nego */ -#define EEER_EEER_RX_LPI_STATUS 0x40000000 /* EEER Rx in LPI state */ -#define EEER_EEER_TX_LPI_STATUS 0x80000000 /* EEER Tx in LPI state */ -#define WMREG_EEE_SU 0x0e34 /* EEE Setup */ -#define WMREG_IPCNFG 0x0e38 /* Internal PHY Configuration */ -#define IPCNFG_10BASE_TE 0x00000002 /* IPCNFG 10BASE-Te low power op. */ -#define IPCNFG_EEE_100M_AN 0x00000004 /* IPCNFG EEE Ena 100M AN */ -#define IPCNFG_EEE_1G_AN 0x00000008 /* IPCNFG EEE Ena 1G AN */ - -#define WMREG_EXTCNFCTR 0x0f00 /* Extended Configuration Control */ -#define EXTCNFCTR_PCIE_WRITE_ENABLE 0x00000001 -#define EXTCNFCTR_OEM_WRITE_ENABLE 0x00000008 -#define EXTCNFCTR_MDIO_SW_OWNERSHIP 0x00000020 -#define EXTCNFCTR_MDIO_HW_OWNERSHIP 0x00000040 -#define EXTCNFCTR_GATE_PHY_CFG 0x00000080 -#define EXTCNFCTR_EXT_CNF_POINTER 0x0fff0000 +#define WMREG_EEER 0x0e30 /* Energy Efficiency Ethernet "EEE" */ +#define EEER_TX_LPI_EN 0x00010000 /* EEER Tx LPI Enable */ +#define EEER_RX_LPI_EN 0x00020000 /* EEER Rx LPI Enable */ +#define EEER_LPI_FC 0x00040000 /* EEER Ena on Flow Cntrl */ +#define EEER_EEER_NEG 0x20000000 /* EEER capability nego */ +#define EEER_EEER_RX_LPI_STATUS 0x40000000 /* EEER Rx in LPI state */ +#define EEER_EEER_TX_LPI_STATUS 0x80000000 /* EEER Tx in LPI state */ +#define WMREG_EEE_SU 0x0e34 /* EEE Setup */ +#define WMREG_IPCNFG 0x0e38 /* Internal PHY Configuration */ +#define IPCNFG_10BASE_TE 0x00000002 /* IPCNFG 10BASE-Te low power op. */ +#define IPCNFG_EEE_100M_AN 0x00000004 /* IPCNFG EEE Ena 100M AN */ +#define IPCNFG_EEE_1G_AN 0x00000008 /* IPCNFG EEE Ena 1G AN */ + +#define WMREG_EXTCNFCTR 0x0f00 /* Extended Configuration Control */ +#define EXTCNFCTR_PCIE_WRITE_ENABLE 0x00000001 +#define EXTCNFCTR_OEM_WRITE_ENABLE 0x00000008 +#define EXTCNFCTR_MDIO_SW_OWNERSHIP 0x00000020 +#define EXTCNFCTR_MDIO_HW_OWNERSHIP 0x00000040 +#define EXTCNFCTR_GATE_PHY_CFG 0x00000080 +#define EXTCNFCTR_EXT_CNF_POINTER 0x0fff0000 -#define WMREG_EXTCNFSIZE 0x0f08 /* Extended Configuration Size */ -#define EXTCNFSIZE_LENGTH __BITS(23, 16) +#define WMREG_EXTCNFSIZE 0x0f08 /* Extended Configuration Size */ +#define EXTCNFSIZE_LENGTH __BITS(23, 16) #define WMREG_PHY_CTRL 0x0f10 /* PHY control */ #define PHY_CTRL_SPD_EN (1 << 0) @@ -1044,64 +1044,64 @@ struct livengood_tcpip_ctxdesc { #define PBECCSTS_UNCORR_ERR_CNT_MASK 0x0000ff00 #define PBECCSTS_UNCORR_ECC_ENABLE 0x00010000 -#define WMREG_EEMNGCTL 0x1010 /* MNG EEprom Control */ -#define EEMNGCTL_CFGDONE_0 0x040000 /* MNG config cycle done */ -#define EEMNGCTL_CFGDONE_1 0x080000 /* 2nd port */ - -#define WMREG_I2CCMD 0x1028 /* SFPI2C Command Register - RW */ -#define I2CCMD_REG_ADDR_SHIFT 16 -#define I2CCMD_REG_ADDR 0x00ff0000 -#define I2CCMD_PHY_ADDR_SHIFT 24 -#define I2CCMD_PHY_ADDR 0x07000000 -#define I2CCMD_OPCODE_READ 0x08000000 -#define I2CCMD_OPCODE_WRITE 0x00000000 -#define I2CCMD_RESET 0x10000000 -#define I2CCMD_READY 0x20000000 -#define I2CCMD_INTERRUPT_ENA 0x40000000 -#define I2CCMD_ERROR 0x80000000 -#define MAX_SGMII_PHY_REG_ADDR 255 -#define I2CCMD_PHY_TIMEOUT 200 +#define WMREG_EEMNGCTL 0x1010 /* MNG EEprom Control */ +#define EEMNGCTL_CFGDONE_0 0x040000 /* MNG config cycle done */ +#define EEMNGCTL_CFGDONE_1 0x080000 /* 2nd port */ + +#define WMREG_I2CCMD 0x1028 /* SFPI2C Command Register - RW */ +#define I2CCMD_REG_ADDR_SHIFT 16 +#define I2CCMD_REG_ADDR 0x00ff0000 +#define I2CCMD_PHY_ADDR_SHIFT 24 +#define I2CCMD_PHY_ADDR 0x07000000 +#define I2CCMD_OPCODE_READ 0x08000000 +#define I2CCMD_OPCODE_WRITE 0x00000000 +#define I2CCMD_RESET 0x10000000 +#define I2CCMD_READY 0x20000000 +#define I2CCMD_INTERRUPT_ENA 0x40000000 +#define I2CCMD_ERROR 0x80000000 +#define MAX_SGMII_PHY_REG_ADDR 255 +#define I2CCMD_PHY_TIMEOUT 200 #define WMREG_EEWR 0x102c /* EEPROM write */ -#define WMREG_PBA_ECC 0x01100 /* PBA ECC */ -#define PBA_ECC_COUNTER_MASK 0xfff00000 /* ECC counter mask */ -#define PBA_ECC_COUNTER_SHIFT 20 /* ECC counter shift value */ +#define WMREG_PBA_ECC 0x01100 /* PBA ECC */ +#define PBA_ECC_COUNTER_MASK 0xfff00000 /* ECC counter mask */ +#define PBA_ECC_COUNTER_SHIFT 20 /* ECC counter shift value */ #define PBA_ECC_CORR_EN 0x00000001 /* Enable ECC error correction */ #define PBA_ECC_STAT_CLR 0x00000002 /* Clear ECC error counter */ #define PBA_ECC_INT_EN 0x00000004 /* Enable ICR bit 5 on ECC error */ -#define WMREG_GPIE 0x01514 /* General Purpose Interrupt Enable */ -#define GPIE_NSICR __BIT(0) /* Non Selective Interrupt Clear */ -#define GPIE_MULTI_MSIX __BIT(4) /* Multiple MSIX */ -#define GPIE_EIAME __BIT(30) /* Extended Interrupt Auto Mask Ena. */ -#define GPIE_PBA __BIT(31) /* PBA support */ - -#define WMREG_EICS 0x01520 /* Ext. Interrupt Cause Set - WO */ -#define WMREG_EIMS 0x01524 /* Ext. Interrupt Mask Set/Read - RW */ -#define WMREG_EIMC 0x01528 /* Ext. Interrupt Mask Clear - WO */ -#define WMREG_EIAC 0x0152c /* Ext. Interrupt Auto Clear - RW */ -#define WMREG_EIAM 0x01530 /* Ext. Interrupt Ack Auto Clear Mask - RW */ - -#define WMREG_EICR 0x01580 /* Ext. Interrupt Cause Read - R/clr */ - -#define WMREG_MSIXBM(x) (0x1600 + (x) * 4) /* MSI-X Allocation */ - -#define EITR_RX_QUEUE(x) __BIT(0+(x)) /* Rx Queue x Interrupt x=[0-3] */ -#define EITR_TX_QUEUE(x) __BIT(8+(x)) /* Tx Queue x Interrupt x=[0-3] */ -#define EITR_TCP_TIMER 0x40000000 /* TCP Timer */ -#define EITR_OTHER 0x80000000 /* Interrupt Cause Active */ - -#define WMREG_EITR(x) (0x01680 + (0x4 * (x))) -#define EITR_ITR_INT_MASK __BITS(14,2) -#define EITR_COUNTER_MASK_82575 __BITS(31,16) -#define EITR_CNT_INGR __BIT(31) /* does not overwrite counter */ +#define WMREG_GPIE 0x01514 /* General Purpose Interrupt Enable */ +#define GPIE_NSICR __BIT(0) /* Non Selective Interrupt Clear */ +#define GPIE_MULTI_MSIX __BIT(4) /* Multiple MSIX */ +#define GPIE_EIAME __BIT(30) /* Extended Interrupt Auto Mask Ena. */ +#define GPIE_PBA __BIT(31) /* PBA support */ + +#define WMREG_EICS 0x01520 /* Ext. Interrupt Cause Set - WO */ +#define WMREG_EIMS 0x01524 /* Ext. Interrupt Mask Set/Read - RW */ +#define WMREG_EIMC 0x01528 /* Ext. Interrupt Mask Clear - WO */ +#define WMREG_EIAC 0x0152c /* Ext. Interrupt Auto Clear - RW */ +#define WMREG_EIAM 0x01530 /* Ext. Interrupt Ack Auto Clear Mask - RW */ + +#define WMREG_EICR 0x01580 /* Ext. Interrupt Cause Read - R/clr */ + +#define WMREG_MSIXBM(x) (0x1600 + (x) * 4) /* MSI-X Allocation */ + +#define EITR_RX_QUEUE(x) __BIT(0+(x)) /* Rx Queue x Interrupt x=[0-3] */ +#define EITR_TX_QUEUE(x) __BIT(8+(x)) /* Tx Queue x Interrupt x=[0-3] */ +#define EITR_TCP_TIMER 0x40000000 /* TCP Timer */ +#define EITR_OTHER 0x80000000 /* Interrupt Cause Active */ + +#define WMREG_EITR(x) (0x01680 + (0x4 * (x))) +#define EITR_ITR_INT_MASK __BITS(14,2) +#define EITR_COUNTER_MASK_82575 __BITS(31,16) +#define EITR_CNT_INGR __BIT(31) /* does not overwrite counter */ -#define WMREG_EITR_82574(x) (0x000e8 + (0x4 * (x))) -#define EITR_ITR_INT_MASK_82574 __BITS(15, 0) +#define WMREG_EITR_82574(x) (0x000e8 + (0x4 * (x))) +#define EITR_ITR_INT_MASK_82574 __BITS(15, 0) #define WMREG_RXPBS 0x2404 /* Rx Packet Buffer Size */ -#define RXPBS_SIZE_MASK_82576 0x0000007f +#define RXPBS_SIZE_MASK_82576 0x0000007f #define WMREG_RDFH 0x2410 /* Receive Data FIFO Head */ #define WMREG_RDFT 0x2418 /* Receive Data FIFO Tail */ @@ -1112,7 +1112,7 @@ struct livengood_tcpip_ctxdesc { #define WMREG_TXDMAC 0x3000 /* Transfer DMA Control */ #define TXDMAC_DPP __BIT(0) /* disable packet prefetch */ -#define WMREG_KABGTXD 0x3004 /* AFE and Gap Transmit Ref Data */ +#define WMREG_KABGTXD 0x3004 /* AFE and Gap Transmit Ref Data */ #define KABGTXD_BGSQLBIAS 0x00050000 #define WMREG_TDFH 0x3410 /* Transmit Data FIFO Head */ @@ -1127,11 +1127,11 @@ struct livengood_tcpip_ctxdesc { #define TXDCTL_HTHRESH(x) ((x) << 8) /* host threshold */ #define TXDCTL_WTHRESH(x) ((x) << 16) /* write back threshold */ /* flags used starting with 82575 ... */ -#define TXDCTL_COUNT_DESC __BIT(22) /* Enable the counting of desc. +#define TXDCTL_COUNT_DESC __BIT(22) /* Enable the counting of desc. still to be processed. */ -#define TXDCTL_QUEUE_ENABLE 0x02000000 /* Enable specific Tx Queue */ -#define TXDCTL_SWFLSH 0x04000000 /* Tx Desc. write-back flushing */ -#define TXDCTL_PRIORITY 0x08000000 +#define TXDCTL_QUEUE_ENABLE 0x02000000 /* Enable specific Tx Queue */ +#define TXDCTL_SWFLSH 0x04000000 /* Tx Desc. write-back flushing */ +#define TXDCTL_PRIORITY 0x08000000 #define WMREG_TADV 0x382c /* Transmit Absolute Interrupt Delay Timer */ #define WMREG_TSPMT 0x3830 /* TCP Segmentation Pad and Minimum @@ -1156,9 +1156,9 @@ struct livengood_tcpip_ctxdesc { #define WMREG_XOFFRXC 0x4050 /* XOFF Rx Count - R/clr */ #define WMREG_XOFFTXC 0x4054 /* XOFF Tx Count - R/clr */ #define WMREG_FCRUC 0x4058 /* Flow Control Rx Unsupported Count - R/clr */ -#define WMREG_RNBC 0x40a0 /* Receive No Buffers Count */ -#define WMREG_TLPIC 0x4148 /* EEE Tx LPI Count */ -#define WMREG_RLPIC 0x414c /* EEE Rx LPI Count */ +#define WMREG_RNBC 0x40a0 /* Receive No Buffers Count */ +#define WMREG_TLPIC 0x4148 /* EEE Tx LPI Count */ +#define WMREG_RLPIC 0x414c /* EEE Rx LPI Count */ #define WMREG_PCS_CFG 0x4200 /* PCS Configuration */ #define PCS_CFG_PCS_EN __BIT(3) @@ -1183,13 +1183,13 @@ struct livengood_tcpip_ctxdesc { #define PCS_LCTL_LINK_OK_FIX_EN __BIT(25) /* Link OK Fix Enable */ #define WMREG_PCS_LSTS 0x420c /* PCS Link Status */ -#define PCS_LSTS_LINKOK __BIT(0) -#define PCS_LSTS_SPEED __BITS(2, 1) -#define PCS_LSTS_SPEED_10 0 -#define PCS_LSTS_SPEED_100 1 -#define PCS_LSTS_SPEED_1000 2 -#define PCS_LSTS_FDX __BIT(3) -#define PCS_LSTS_AN_COMP __BIT(16) +#define PCS_LSTS_LINKOK __BIT(0) +#define PCS_LSTS_SPEED __BITS(2, 1) +#define PCS_LSTS_SPEED_10 0 +#define PCS_LSTS_SPEED_100 1 +#define PCS_LSTS_SPEED_1000 2 +#define PCS_LSTS_FDX __BIT(3) +#define PCS_LSTS_AN_COMP __BIT(16) #define WMREG_PCS_ANADV 0x4218 /* AN Advertsement */ #define WMREG_PCS_LPAB 0x421c /* Link Partnet Ability */ @@ -1204,46 +1204,46 @@ struct livengood_tcpip_ctxdesc { #define RXCSUM_IPPCSE __BIT(12) /* IP payload checksum enable */ #define RXCSUM_PCSD __BIT(13) /* packet checksum disabled */ -#define WMREG_RLPML 0x5004 /* Rx Long Packet Max Length */ +#define WMREG_RLPML 0x5004 /* Rx Long Packet Max Length */ -#define WMREG_RFCTL 0x5008 /* Receive Filter Control */ -#define WMREG_RFCTL_NFSWDIS __BIT(6) /* NFS Write Disable */ -#define WMREG_RFCTL_NFSRDIS __BIT(7) /* NFS Read Disable */ -#define WMREG_RFCTL_ACKDIS __BIT(12) /* ACK Accelerate Disable */ -#define WMREG_RFCTL_ACKD_DIS __BIT(13) /* ACK data Disable */ -#define WMREG_RFCTL_EXSTEN __BIT(15) /* Extended status Enable. 82574 only. */ -#define WMREG_RFCTL_IPV6EXDIS __BIT(16) /* IPv6 Extension Header Disable */ -#define WMREG_RFCTL_NEWIPV6EXDIS __BIT(17) /* New IPv6 Extension Header */ +#define WMREG_RFCTL 0x5008 /* Receive Filter Control */ +#define WMREG_RFCTL_NFSWDIS __BIT(6) /* NFS Write Disable */ +#define WMREG_RFCTL_NFSRDIS __BIT(7) /* NFS Read Disable */ +#define WMREG_RFCTL_ACKDIS __BIT(12) /* ACK Accelerate Disable */ +#define WMREG_RFCTL_ACKD_DIS __BIT(13) /* ACK data Disable */ +#define WMREG_RFCTL_EXSTEN __BIT(15) /* Extended status Enable. 82574 only. */ +#define WMREG_RFCTL_IPV6EXDIS __BIT(16) /* IPv6 Extension Header Disable */ +#define WMREG_RFCTL_NEWIPV6EXDIS __BIT(17) /* New IPv6 Extension Header */ #define WMREG_WUC 0x5800 /* Wakeup Control */ #define WUC_APME 0x00000001 /* APM Enable */ #define WUC_PME_EN 0x00000002 /* PME Enable */ -#define WUC_PME_STATUS 0x00000004 /* PME Status */ -#define WUC_APMPME 0x00000008 /* Assert PME on APM Wakeup */ -#define WUC_PHY_WAKE 0x00000100 /* if PHY supports wakeup */ +#define WUC_PME_STATUS 0x00000004 /* PME Status */ +#define WUC_APMPME 0x00000008 /* Assert PME on APM Wakeup */ +#define WUC_PHY_WAKE 0x00000100 /* if PHY supports wakeup */ #define WMREG_WUFC 0x5808 /* Wakeup Filter Control */ -#define WUFC_LNKC __BIT(0) /* Link Status Change Wakeup Enable */ -#define WUFC_MAG __BIT(1) /* Magic Packet Wakeup Enable */ -#define WUFC_EX __BIT(2) /* Directed Exact Wakeup Enable */ -#define WUFC_MC __BIT(3) /* Directed Multicast Wakeup En */ -#define WUFC_BC __BIT(4) /* Broadcast Wakeup Enable */ -#define WUFC_ARPDIR __BIT(5) /* ARP Request Packet Wakeup En */ -#define WUFC_IPV4 __BIT(6) /* Directed IPv4 Packet Wakeup En */ -#define WUFC_IPV6 __BIT(7) /* Directed IPv6 Packet Wakeup En */ -#define WUFC_NS __BIT(9) /* NS Wakeup En */ -#define WUFC_NSDIR __BIT(10) /* NS Directed En */ -#define WUFC_ARP __BIT(11) /* ARP request En */ -#define WUFC_FLEX_HQ __BIT(14) /* Flex Filters Host Queueing En */ -#define WUFC_NOTCO __BIT(15) /* ? */ -#define WUFC_FLX __BITS(23, 16) /* Flexible Filter [0-7] En */ -#define WUFC_FLXACT __BITS(27, 24) /* Flexible Filter [0-3] Action */ -#define WUFC_FW_RST_WK __BIT(31) /* Wake on Firmware Reset Assert En */ +#define WUFC_LNKC __BIT(0) /* Link Status Change Wakeup Enable */ +#define WUFC_MAG __BIT(1) /* Magic Packet Wakeup Enable */ +#define WUFC_EX __BIT(2) /* Directed Exact Wakeup Enable */ +#define WUFC_MC __BIT(3) /* Directed Multicast Wakeup En */ +#define WUFC_BC __BIT(4) /* Broadcast Wakeup Enable */ +#define WUFC_ARPDIR __BIT(5) /* ARP Request Packet Wakeup En */ +#define WUFC_IPV4 __BIT(6) /* Directed IPv4 Packet Wakeup En */ +#define WUFC_IPV6 __BIT(7) /* Directed IPv6 Packet Wakeup En */ +#define WUFC_NS __BIT(9) /* NS Wakeup En */ +#define WUFC_NSDIR __BIT(10) /* NS Directed En */ +#define WUFC_ARP __BIT(11) /* ARP request En */ +#define WUFC_FLEX_HQ __BIT(14) /* Flex Filters Host Queueing En */ +#define WUFC_NOTCO __BIT(15) /* ? */ +#define WUFC_FLX __BITS(23, 16) /* Flexible Filter [0-7] En */ +#define WUFC_FLXACT __BITS(27, 24) /* Flexible Filter [0-3] Action */ +#define WUFC_FW_RST_WK __BIT(31) /* Wake on Firmware Reset Assert En */ #define WMREG_WUS 0x5810 /* Wakeup Status (R/W1C) */ /* Bit 30-24 and 15-12 are reserved */ -#define WUS_MNG __BIT(8) /* Manageability event */ -#define WUS_FLAGS "\20" \ +#define WUS_MNG __BIT(8) /* Manageability event */ +#define WUS_FLAGS "\20" \ "\1LINKC" "\2MAG" "\3EX" "\4MC" \ "\5BC" "\6ARPDIR" "\7IPV4" "\10IPV6" \ "\11MNG" "\12NS" "\13NSDIR" "\14ARP" \ @@ -1251,55 +1251,55 @@ struct livengood_tcpip_ctxdesc { "\25FLX4" "\26FLX5" "\27FLX6" "\30FLX7" \ "\40FW_RST_WK" -#define WMREG_MRQC 0x5818 /* Multiple Receive Queues Command */ -#define MRQC_DISABLE_RSS 0x00000000 -#define MRQC_ENABLE_RSS_MQ_82574 __BIT(0) /* enable RSS for 82574 */ -#define MRQC_ENABLE_RSS_MQ __BIT(1) /* enable hardware max RSS without VMDq */ -#define MRQC_ENABLE_RSS_VMDQ __BITS(1, 0) /* enable RSS with VMDq */ -#define MRQC_DEFQ_MASK __BITS(5, 3) +#define WMREG_MRQC 0x5818 /* Multiple Receive Queues Command */ +#define MRQC_DISABLE_RSS 0x00000000 +#define MRQC_ENABLE_RSS_MQ_82574 __BIT(0) /* enable RSS for 82574 */ +#define MRQC_ENABLE_RSS_MQ __BIT(1) /* enable hardware max RSS without VMDq */ +#define MRQC_ENABLE_RSS_VMDQ __BITS(1, 0) /* enable RSS with VMDq */ +#define MRQC_DEFQ_MASK __BITS(5, 3) /* * Defines the default queue in non VMDq * mode according to value of the Multiple Receive * Queues Enable field. */ -#define MRQC_DEFQ_NOT_RSS_FLT __SHFTIN(__BIT(1), MRQC_DEFQ_MASK) +#define MRQC_DEFQ_NOT_RSS_FLT __SHFTIN(__BIT(1), MRQC_DEFQ_MASK) /* * the destination of all packets * not forwarded by RSS or filters */ -#define MRQC_DEFQ_NOT_MAC_ETH __SHFTIN(__BITS(1, 0), MRQC_DEFQ_MASK) +#define MRQC_DEFQ_NOT_MAC_ETH __SHFTIN(__BITS(1, 0), MRQC_DEFQ_MASK) /* * Def_Q field is ignored. Queueing * decision of all packets not forwarded * by MAC address and Ether-type filters * is according to VT_CTL.DEF_PL field. */ -#define MRQC_DEFQ_IGNORED1 __SHFTIN(__BIT(2), MRQC_DEFQ_MASK) +#define MRQC_DEFQ_IGNORED1 __SHFTIN(__BIT(2), MRQC_DEFQ_MASK) /* Def_Q field is ignored */ -#define MRQC_DEFQ_IGNORED2 __SHFTIN(__BIT(2)|__BIT(0), MRQC_DEFQ_MASK) +#define MRQC_DEFQ_IGNORED2 __SHFTIN(__BIT(2)|__BIT(0), MRQC_DEFQ_MASK) /* Def_Q field is ignored */ -#define MRQC_DEFQ_VMDQ __SHFTIN(__BITS(2, 1), MRQC_DEFQ_MASK) +#define MRQC_DEFQ_VMDQ __SHFTIN(__BITS(2, 1), MRQC_DEFQ_MASK) /* for VMDq mode */ -#define MRQC_RSS_FIELD_IPV4_TCP __BIT(16) -#define MRQC_RSS_FIELD_IPV4 __BIT(17) -#define MRQC_RSS_FIELD_IPV6_TCP_EX __BIT(18) -#define MRQC_RSS_FIELD_IPV6_EX __BIT(19) -#define MRQC_RSS_FIELD_IPV6 __BIT(20) -#define MRQC_RSS_FIELD_IPV6_TCP __BIT(21) -#define MRQC_RSS_FIELD_IPV4_UDP __BIT(22) -#define MRQC_RSS_FIELD_IPV6_UDP __BIT(23) -#define MRQC_RSS_FIELD_IPV6_UDP_EX __BIT(24) - -#define WMREG_RETA_Q(x) (0x5c00 + ((x) >> 2) * 4) /* Redirection Table */ -#define RETA_NUM_ENTRIES 128 -#define RETA_ENTRY_MASK_Q(x) (0x000000ffUL << (((x) % 4) * 8)) /* Redirection Table */ -#define RETA_ENT_QINDEX_MASK __BITS(3,0) /*queue index for 82580 and newer */ -#define RETA_ENT_QINDEX0_MASK_82575 __BITS(3,2) /*queue index for pool0 */ -#define RETA_ENT_QINDEX1_MASK_82575 __BITS(7,6) /*queue index for pool1 and regular RSS */ -#define RETA_ENT_QINDEX_MASK_82574 __BIT(7) /*queue index for 82574 */ +#define MRQC_RSS_FIELD_IPV4_TCP __BIT(16) +#define MRQC_RSS_FIELD_IPV4 __BIT(17) +#define MRQC_RSS_FIELD_IPV6_TCP_EX __BIT(18) +#define MRQC_RSS_FIELD_IPV6_EX __BIT(19) +#define MRQC_RSS_FIELD_IPV6 __BIT(20) +#define MRQC_RSS_FIELD_IPV6_TCP __BIT(21) +#define MRQC_RSS_FIELD_IPV4_UDP __BIT(22) +#define MRQC_RSS_FIELD_IPV6_UDP __BIT(23) +#define MRQC_RSS_FIELD_IPV6_UDP_EX __BIT(24) + +#define WMREG_RETA_Q(x) (0x5c00 + ((x) >> 2) * 4) /* Redirection Table */ +#define RETA_NUM_ENTRIES 128 +#define RETA_ENTRY_MASK_Q(x) (0x000000ffUL << (((x) % 4) * 8)) /* Redirection Table */ +#define RETA_ENT_QINDEX_MASK __BITS(3,0) /*queue index for 82580 and newer */ +#define RETA_ENT_QINDEX0_MASK_82575 __BITS(3,2) /*queue index for pool0 */ +#define RETA_ENT_QINDEX1_MASK_82575 __BITS(7,6) /*queue index for pool1 and regular RSS */ +#define RETA_ENT_QINDEX_MASK_82574 __BIT(7) /*queue index for 82574 */ -#define WMREG_RSSRK(x) (0x5c80 + (x) * 4) /* RSS Random Key Register */ -#define RSSRK_NUM_REGS 10 +#define WMREG_RSSRK(x) (0x5c80 + (x) * 4) /* RSS Random Key Register */ +#define RSSRK_NUM_REGS 10 #define WMREG_MANC 0x5820 /* Management Control */ #define MANC_SMBUS_EN 0x00000001 @@ -1313,35 +1313,35 @@ struct livengood_tcpip_ctxdesc { #define MANC_EN_MNG2HOST 0x00200000 #define WMREG_MANC2H 0x5860 /* Management Control To Host - RW */ -#define MANC2H_PORT_623 (1 << 5) -#define MANC2H_PORT_624 (1 << 6) +#define MANC2H_PORT_623 (1 << 5) +#define MANC2H_PORT_624 (1 << 6) -#define WMREG_GCR 0x5b00 /* PCIe Control */ -#define GCR_RXD_NO_SNOOP 0x00000001 -#define GCR_RXDSCW_NO_SNOOP 0x00000002 -#define GCR_RXDSCR_NO_SNOOP 0x00000004 -#define GCR_TXD_NO_SNOOP 0x00000008 -#define GCR_TXDSCW_NO_SNOOP 0x00000010 -#define GCR_TXDSCR_NO_SNOOP 0x00000020 -#define GCR_CMPL_TMOUT_MASK 0x0000f000 -#define GCR_CMPL_TMOUT_10MS 0x00001000 -#define GCR_CMPL_TMOUT_RESEND 0x00010000 -#define GCR_CAP_VER2 0x00040000 -#define GCR_L1_ACT_WITHOUT_L0S_RX 0x08000000 -#define GCR_NO_SNOOP_ALL (GCR_RXD_NO_SNOOP | \ +#define WMREG_GCR 0x5b00 /* PCIe Control */ +#define GCR_RXD_NO_SNOOP 0x00000001 +#define GCR_RXDSCW_NO_SNOOP 0x00000002 +#define GCR_RXDSCR_NO_SNOOP 0x00000004 +#define GCR_TXD_NO_SNOOP 0x00000008 +#define GCR_TXDSCW_NO_SNOOP 0x00000010 +#define GCR_TXDSCR_NO_SNOOP 0x00000020 +#define GCR_CMPL_TMOUT_MASK 0x0000f000 +#define GCR_CMPL_TMOUT_10MS 0x00001000 +#define GCR_CMPL_TMOUT_RESEND 0x00010000 +#define GCR_CAP_VER2 0x00040000 +#define GCR_L1_ACT_WITHOUT_L0S_RX 0x08000000 +#define GCR_NO_SNOOP_ALL (GCR_RXD_NO_SNOOP | \ GCR_RXDSCW_NO_SNOOP | \ GCR_RXDSCR_NO_SNOOP | \ GCR_TXD_NO_SNOOP | \ GCR_TXDSCW_NO_SNOOP | \ GCR_TXDSCR_NO_SNOOP) -#define WMREG_FACTPS 0x5b30 /* Function Active and Power State to MNG */ -#define FACTPS_MNGCG 0x20000000 -#define FACTPS_LFS 0x40000000 /* LAN Function Select */ - -#define WMREG_GIOCTL 0x5b44 /* GIO Analog Control Register */ -#define WMREG_CCMCTL 0x5b48 /* CCM Control Register */ -#define WMREG_SCCTL 0x5b4c /* PCIc PLL Configuration Register */ +#define WMREG_FACTPS 0x5b30 /* Function Active and Power State to MNG */ +#define FACTPS_MNGCG 0x20000000 +#define FACTPS_LFS 0x40000000 /* LAN Function Select */ + +#define WMREG_GIOCTL 0x5b44 /* GIO Analog Control Register */ +#define WMREG_CCMCTL 0x5b48 /* CCM Control Register */ +#define WMREG_SCCTL 0x5b4c /* PCIc PLL Configuration Register */ #define WMREG_SWSM 0x5b50 /* SW Semaphore */ #define SWSM_SMBI 0x00000001 /* Driver Semaphore bit */ @@ -1350,20 +1350,20 @@ struct livengood_tcpip_ctxdesc { #define SWSM_DRV_LOAD 0x00000008 /* Driver Loaded Bit */ /* Intel driver defines H2ME register at 0x5b50 */ #define WMREG_H2ME 0x5b50 /* SW Semaphore */ -#define H2ME_ULP __BIT(11) -#define H2ME_ENFORCE_SETTINGS __BIT(12) +#define H2ME_ULP __BIT(11) +#define H2ME_ENFORCE_SETTINGS __BIT(12) #define WMREG_FWSM 0x5b54 /* FW Semaphore */ #define FWSM_MODE __BITS(1, 3) #define MNG_ICH_IAMT_MODE 0x2 /* PT mode? */ #define MNG_IAMT_MODE 0x3 -#define FWSM_RSPCIPHY __BIT(6) /* Reset PHY on PCI reset */ -#define FWSM_WLOCK_MAC __BITS(7, 9) -#define FWSM_ULP_CFG_DONE __BIT(10) -#define FWSM_FW_VALID __BIT(15) /* FW established a valid mode */ +#define FWSM_RSPCIPHY __BIT(6) /* Reset PHY on PCI reset */ +#define FWSM_WLOCK_MAC __BITS(7, 9) +#define FWSM_ULP_CFG_DONE __BIT(10) +#define FWSM_FW_VALID __BIT(15) /* FW established a valid mode */ #define WMREG_SWSM2 0x5b58 /* SW Semaphore 2 */ -#define SWSM2_LOCK 0x00000002 /* Secondary driver semaphore bit */ +#define SWSM2_LOCK 0x00000002 /* Secondary driver semaphore bit */ #define WMREG_SW_FW_SYNC 0x5b5c /* software-firmware semaphore */ #define SWFW_EEP_SM 0x0001 /* eeprom access */ @@ -1375,23 +1375,23 @@ struct livengood_tcpip_ctxdesc { #define SWFW_SOFT_SHIFT 0 /* software semaphores */ #define SWFW_FIRM_SHIFT 16 /* firmware semaphores */ -#define WMREG_GCR2 0x5b64 /* 3GPIO Control Register 2 */ -#define WMREG_FEXTNVM9 0x5bb4 /* Future Extended NVM 9 */ -#define FEXTNVM9_IOSFSB_CLKGATE_DIS __BIT(11) -#define FEXTNVM9_IOSFSB_CLKREQ_DIS __BIT(12) -#define WMREG_FEXTNVM11 0x5bbc /* Future Extended NVM 11 */ -#define FEXTNVM11_DIS_MULRFIX __BIT(13) /* Disable MULR fix */ - -#define WMREG_FFLT_DBG 0x05F04 /* Debug Register */ - -#define WMREG_CRC_OFFSET 0x5f50 -#define WMREG_PCH_RAICC(x) (WMREG_CRC_OFFSET + (x) * 4) - -#define WMREG_EEC 0x12010 -#define EEC_FLASH_DETECTED __BIT(19) /* FLASH */ -#define EEC_FLUPD __BIT(23) /* Update FLASH */ +#define WMREG_GCR2 0x5b64 /* 3GPIO Control Register 2 */ +#define WMREG_FEXTNVM9 0x5bb4 /* Future Extended NVM 9 */ +#define FEXTNVM9_IOSFSB_CLKGATE_DIS __BIT(11) +#define FEXTNVM9_IOSFSB_CLKREQ_DIS __BIT(12) +#define WMREG_FEXTNVM11 0x5bbc /* Future Extended NVM 11 */ +#define FEXTNVM11_DIS_MULRFIX __BIT(13) /* Disable MULR fix */ + +#define WMREG_FFLT_DBG 0x05F04 /* Debug Register */ + +#define WMREG_CRC_OFFSET 0x5f50 +#define WMREG_PCH_RAICC(x) (WMREG_CRC_OFFSET + (x) * 4) + +#define WMREG_EEC 0x12010 +#define EEC_FLASH_DETECTED __BIT(19) /* FLASH */ +#define EEC_FLUPD __BIT(23) /* Update FLASH */ -#define WMREG_EEARBC_I210 0x12024 +#define WMREG_EEARBC_I210 0x12024 /* * NVM related values. @@ -1416,34 +1416,34 @@ struct livengood_tcpip_ctxdesc { #define SPI_SR_BP1 0x08 #define SPI_SR_WPEN 0x80 -#define NVM_CHECKSUM 0xBABA -#define NVM_SIZE 0x0040 -#define NVM_WORD_SIZE_BASE_SHIFT 6 +#define NVM_CHECKSUM 0xBABA +#define NVM_SIZE 0x0040 +#define NVM_WORD_SIZE_BASE_SHIFT 6 #define NVM_OFF_MACADDR 0x0000 /* MAC address offset 0 */ #define NVM_OFF_MACADDR1 0x0001 /* MAC address offset 1 */ #define NVM_OFF_MACADDR2 0x0002 /* MAC address offset 2 */ -#define NVM_OFF_COMPAT 0x0003 -#define NVM_OFF_ID_LED_SETTINGS 0x0004 -#define NVM_OFF_VERSION 0x0005 +#define NVM_OFF_COMPAT 0x0003 +#define NVM_OFF_ID_LED_SETTINGS 0x0004 +#define NVM_OFF_VERSION 0x0005 #define NVM_OFF_CFG1 0x000a /* config word 1 */ #define NVM_OFF_CFG2 0x000f /* config word 2 */ #define NVM_OFF_EEPROM_SIZE 0x0012 /* NVM SIZE */ #define NVM_OFF_CFG4 0x0013 /* config word 4 */ #define NVM_OFF_CFG3_PORTB 0x0014 /* config word 3 */ -#define NVM_OFF_FUTURE_INIT_WORD1 0x0019 +#define NVM_OFF_FUTURE_INIT_WORD1 0x0019 #define NVM_OFF_INIT_3GIO_3 0x001a /* PCIe Initial Configuration Word 3 */ #define NVM_OFF_K1_CONFIG 0x001b /* NVM K1 Config */ #define NVM_OFF_LED_1_CFG 0x001c #define NVM_OFF_LED_0_2_CFG 0x001f #define NVM_OFF_SWDPIN 0x0020 /* SWD Pins (Cordova) */ #define NVM_OFF_CFG3_PORTA 0x0024 /* config word 3 */ -#define NVM_OFF_ALT_MAC_ADDR_PTR 0x0037 /* to the alternative MAC addresses */ -#define NVM_OFF_COMB_VER_PTR 0x003d -#define NVM_OFF_IMAGE_UID0 0x0042 -#define NVM_OFF_IMAGE_UID1 0x0043 +#define NVM_OFF_ALT_MAC_ADDR_PTR 0x0037 /* to the alternative MAC addresses */ +#define NVM_OFF_COMB_VER_PTR 0x003d +#define NVM_OFF_IMAGE_UID0 0x0042 +#define NVM_OFF_IMAGE_UID1 0x0043 -#define NVM_COMPAT_VALID_CHECKSUM 0x0001 +#define NVM_COMPAT_VALID_CHECKSUM 0x0001 #define NVM_CFG1_LVDID __BIT(0) #define NVM_CFG1_LSSID __BIT(1) @@ -1484,7 +1484,7 @@ struct livengood_tcpip_ctxdesc { #define NVM_COMPAT_MAS_EN(x) __BIT(x) /* Media Auto Sense Enable */ #define NVM_COMPAT_SERDES_FORCE_MODE __BIT(14) /* Don't use autonego */ -#define NVM_FUTURE_INIT_WORD1_VALID_CHECKSUM 0x0040 +#define NVM_FUTURE_INIT_WORD1_VALID_CHECKSUM 0x0040 #define NVM_K1_CONFIG_ENABLE 0x01 @@ -1492,12 +1492,12 @@ struct livengood_tcpip_ctxdesc { #define NVM_SWDPIN_SWDPIN_SHIFT 0 #define NVM_SWDPIN_SWDPIO_SHIFT 8 -#define NVM_3GIO_3_ASPM_MASK (0x3 << 2) /* Active State PM Support */ +#define NVM_3GIO_3_ASPM_MASK (0x3 << 2) /* Active State PM Support */ -#define NVM_CFG3_PORTA_EXT_MDIO __BIT(2) /* External MDIO Interface */ -#define NVM_CFG3_PORTA_COM_MDIO __BIT(3) /* MDIO Interface is shared */ -#define NVM_CFG3_APME __BIT(10) /* APM Enable */ -#define NVM_CFG3_ILOS __BIT(13) /* Invert loss of signal */ +#define NVM_CFG3_PORTA_EXT_MDIO __BIT(2) /* External MDIO Interface */ +#define NVM_CFG3_PORTA_COM_MDIO __BIT(3) /* MDIO Interface is shared */ +#define NVM_CFG3_APME __BIT(10) /* APM Enable */ +#define NVM_CFG3_ILOS __BIT(13) /* Invert loss of signal */ #define NVM_OFF_MACADDR_82571(x) (3 * (x)) @@ -1505,137 +1505,137 @@ struct livengood_tcpip_ctxdesc { * EEPROM Partitioning. See Table 6-1, "EEPROM Top Level Partitioning" * in 82580's datasheet. */ -#define NVM_OFF_LAN_FUNC_82580(x) ((x) ? (0x40 + (0x40 * (x))) : 0) +#define NVM_OFF_LAN_FUNC_82580(x) ((x) ? (0x40 + (0x40 * (x))) : 0) -#define NVM_COMBO_VER_OFF 0x0083 +#define NVM_COMBO_VER_OFF 0x0083 -#define NVM_MAJOR_MASK 0xf000 -#define NVM_MAJOR_SHIFT 12 -#define NVM_MINOR_MASK 0x0ff0 -#define NVM_MINOR_SHIFT 4 -#define NVM_BUILD_MASK 0x000f -#define NVM_UID_VALID 0x8000 +#define NVM_MAJOR_MASK 0xf000 +#define NVM_MAJOR_SHIFT 12 +#define NVM_MINOR_MASK 0x0ff0 +#define NVM_MINOR_SHIFT 4 +#define NVM_BUILD_MASK 0x000f +#define NVM_UID_VALID 0x8000 /* iNVM Registers for i21[01] */ -#define WM_INVM_DATA_REG(reg) (0x12120 + 4*(reg)) -#define INVM_SIZE 64 /* Number of INVM Data Registers */ +#define WM_INVM_DATA_REG(reg) (0x12120 + 4*(reg)) +#define INVM_SIZE 64 /* Number of INVM Data Registers */ /* iNVM default value */ -#define NVM_INIT_CTRL_2_DEFAULT_I211 0x7243 -#define NVM_INIT_CTRL_4_DEFAULT_I211 0x00c1 -#define NVM_LED_1_CFG_DEFAULT_I211 0x0184 -#define NVM_LED_0_2_CFG_DEFAULT_I211 0x200c -#define NVM_RESERVED_WORD 0xffff - -#define INVM_DWORD_TO_RECORD_TYPE(dword) ((dword) & 0x7) -#define INVM_DWORD_TO_WORD_ADDRESS(dword) (((dword) & 0x0000FE00) >> 9) -#define INVM_DWORD_TO_WORD_DATA(dword) (((dword) & 0xFFFF0000) >> 16) - -#define INVM_UNINITIALIZED_STRUCTURE 0x0 -#define INVM_WORD_AUTOLOAD_STRUCTURE 0x1 -#define INVM_CSR_AUTOLOAD_STRUCTURE 0x2 -#define INVM_PHY_REGISTER_AUTOLOAD_STRUCTURE 0x3 -#define INVM_RSA_KEY_SHA256_STRUCTURE 0x4 -#define INVM_INVALIDATED_STRUCTURE 0xf - -#define INVM_RSA_KEY_SHA256_DATA_SIZE_IN_DWORDS 8 -#define INVM_CSR_AUTOLOAD_DATA_SIZE_IN_DWORDS 1 - -#define INVM_DEFAULT_AL 0x202f -#define INVM_AUTOLOAD 0x0a -#define INVM_PLL_WO_VAL 0x0010 +#define NVM_INIT_CTRL_2_DEFAULT_I211 0x7243 +#define NVM_INIT_CTRL_4_DEFAULT_I211 0x00c1 +#define NVM_LED_1_CFG_DEFAULT_I211 0x0184 +#define NVM_LED_0_2_CFG_DEFAULT_I211 0x200c +#define NVM_RESERVED_WORD 0xffff + +#define INVM_DWORD_TO_RECORD_TYPE(dword) ((dword) & 0x7) +#define INVM_DWORD_TO_WORD_ADDRESS(dword) (((dword) & 0x0000FE00) >> 9) +#define INVM_DWORD_TO_WORD_DATA(dword) (((dword) & 0xFFFF0000) >> 16) + +#define INVM_UNINITIALIZED_STRUCTURE 0x0 +#define INVM_WORD_AUTOLOAD_STRUCTURE 0x1 +#define INVM_CSR_AUTOLOAD_STRUCTURE 0x2 +#define INVM_PHY_REGISTER_AUTOLOAD_STRUCTURE 0x3 +#define INVM_RSA_KEY_SHA256_STRUCTURE 0x4 +#define INVM_INVALIDATED_STRUCTURE 0xf + +#define INVM_RSA_KEY_SHA256_DATA_SIZE_IN_DWORDS 8 +#define INVM_CSR_AUTOLOAD_DATA_SIZE_IN_DWORDS 1 + +#define INVM_DEFAULT_AL 0x202f +#define INVM_AUTOLOAD 0x0a +#define INVM_PLL_WO_VAL 0x0010 /* Version and Image Type field */ -#define INVM_VER_1 __BITS(12,3) -#define INVM_VER_2 __BITS(22,13) -#define INVM_IMGTYPE __BITS(28,23) -#define INVM_MINOR __BITS(3,0) -#define INVM_MAJOR __BITS(9,4) +#define INVM_VER_1 __BITS(12,3) +#define INVM_VER_2 __BITS(22,13) +#define INVM_IMGTYPE __BITS(28,23) +#define INVM_MINOR __BITS(3,0) +#define INVM_MAJOR __BITS(9,4) /* Word definitions for ID LED Settings */ -#define ID_LED_RESERVED_FFFF 0xffff +#define ID_LED_RESERVED_FFFF 0xffff /* ich8 flash control */ -#define ICH_FLASH_COMMAND_TIMEOUT 5000 /* 5000 uSecs - adjusted */ -#define ICH_FLASH_ERASE_TIMEOUT 3000000 /* Up to 3 seconds - worst case */ -#define ICH_FLASH_CYCLE_REPEAT_COUNT 10 /* 10 cycles */ -#define ICH_FLASH_SEG_SIZE_256 256 -#define ICH_FLASH_SEG_SIZE_4K 4096 -#define ICH_FLASH_SEG_SIZE_64K 65536 - -#define ICH_CYCLE_READ 0x0 -#define ICH_CYCLE_RESERVED 0x1 -#define ICH_CYCLE_WRITE 0x2 -#define ICH_CYCLE_ERASE 0x3 - -#define ICH_FLASH_GFPREG 0x0000 -#define ICH_FLASH_HSFSTS 0x0004 /* Flash Status Register */ -#define HSFSTS_DONE 0x0001 /* Flash Cycle Done */ -#define HSFSTS_ERR 0x0002 /* Flash Cycle Error */ -#define HSFSTS_DAEL 0x0004 /* Direct Access error Log */ -#define HSFSTS_ERSZ_MASK 0x0018 /* Block/Sector Erase Size */ -#define HSFSTS_ERSZ_SHIFT 3 -#define HSFSTS_FLINPRO 0x0020 /* flash SPI cycle in Progress */ -#define HSFSTS_FLDVAL 0x4000 /* Flash Descriptor Valid */ -#define HSFSTS_FLLK 0x8000 /* Flash Configuration Lock-Down */ -#define ICH_FLASH_HSFCTL 0x0006 /* Flash control Register */ -#define HSFCTL_GO 0x0001 /* Flash Cycle Go */ -#define HSFCTL_CYCLE_MASK 0x0006 /* Flash Cycle */ -#define HSFCTL_CYCLE_SHIFT 1 -#define HSFCTL_BCOUNT_MASK 0x0300 /* Data Byte Count */ -#define HSFCTL_BCOUNT_SHIFT 8 -#define ICH_FLASH_FADDR 0x0008 -#define ICH_FLASH_FDATA0 0x0010 -#define ICH_FLASH_FRACC 0x0050 -#define ICH_FLASH_FREG0 0x0054 -#define ICH_FLASH_FREG1 0x0058 -#define ICH_FLASH_FREG2 0x005c -#define ICH_FLASH_FREG3 0x0060 -#define ICH_FLASH_FPR0 0x0074 -#define ICH_FLASH_FPR1 0x0078 -#define ICH_FLASH_SSFSTS 0x0090 -#define ICH_FLASH_SSFCTL 0x0092 -#define ICH_FLASH_PREOP 0x0094 -#define ICH_FLASH_OPTYPE 0x0096 -#define ICH_FLASH_OPMENU 0x0098 - -#define ICH_FLASH_REG_MAPSIZE 0x00a0 -#define ICH_FLASH_SECTOR_SIZE 4096 -#define ICH_GFPREG_BASE_MASK 0x1fff -#define ICH_FLASH_LINEAR_ADDR_MASK 0x00ffffff - -#define ICH_NVM_SIG_WORD 0x13 -#define ICH_NVM_SIG_MASK 0xc000 -#define ICH_NVM_VALID_SIG_MASK 0xc0 -#define ICH_NVM_SIG_VALUE 0x80 +#define ICH_FLASH_COMMAND_TIMEOUT 5000 /* 5000 uSecs - adjusted */ +#define ICH_FLASH_ERASE_TIMEOUT 3000000 /* Up to 3 seconds - worst case */ +#define ICH_FLASH_CYCLE_REPEAT_COUNT 10 /* 10 cycles */ +#define ICH_FLASH_SEG_SIZE_256 256 +#define ICH_FLASH_SEG_SIZE_4K 4096 +#define ICH_FLASH_SEG_SIZE_64K 65536 + +#define ICH_CYCLE_READ 0x0 +#define ICH_CYCLE_RESERVED 0x1 +#define ICH_CYCLE_WRITE 0x2 +#define ICH_CYCLE_ERASE 0x3 + +#define ICH_FLASH_GFPREG 0x0000 +#define ICH_FLASH_HSFSTS 0x0004 /* Flash Status Register */ +#define HSFSTS_DONE 0x0001 /* Flash Cycle Done */ +#define HSFSTS_ERR 0x0002 /* Flash Cycle Error */ +#define HSFSTS_DAEL 0x0004 /* Direct Access error Log */ +#define HSFSTS_ERSZ_MASK 0x0018 /* Block/Sector Erase Size */ +#define HSFSTS_ERSZ_SHIFT 3 +#define HSFSTS_FLINPRO 0x0020 /* flash SPI cycle in Progress */ +#define HSFSTS_FLDVAL 0x4000 /* Flash Descriptor Valid */ +#define HSFSTS_FLLK 0x8000 /* Flash Configuration Lock-Down */ +#define ICH_FLASH_HSFCTL 0x0006 /* Flash control Register */ +#define HSFCTL_GO 0x0001 /* Flash Cycle Go */ +#define HSFCTL_CYCLE_MASK 0x0006 /* Flash Cycle */ +#define HSFCTL_CYCLE_SHIFT 1 +#define HSFCTL_BCOUNT_MASK 0x0300 /* Data Byte Count */ +#define HSFCTL_BCOUNT_SHIFT 8 +#define ICH_FLASH_FADDR 0x0008 +#define ICH_FLASH_FDATA0 0x0010 +#define ICH_FLASH_FRACC 0x0050 +#define ICH_FLASH_FREG0 0x0054 +#define ICH_FLASH_FREG1 0x0058 +#define ICH_FLASH_FREG2 0x005c +#define ICH_FLASH_FREG3 0x0060 +#define ICH_FLASH_FPR0 0x0074 +#define ICH_FLASH_FPR1 0x0078 +#define ICH_FLASH_SSFSTS 0x0090 +#define ICH_FLASH_SSFCTL 0x0092 +#define ICH_FLASH_PREOP 0x0094 +#define ICH_FLASH_OPTYPE 0x0096 +#define ICH_FLASH_OPMENU 0x0098 + +#define ICH_FLASH_REG_MAPSIZE 0x00a0 +#define ICH_FLASH_SECTOR_SIZE 4096 +#define ICH_GFPREG_BASE_MASK 0x1fff +#define ICH_FLASH_LINEAR_ADDR_MASK 0x00ffffff + +#define ICH_NVM_SIG_WORD 0x13 +#define ICH_NVM_SIG_MASK 0xc000 +#define ICH_NVM_VALID_SIG_MASK 0xc0 +#define ICH_NVM_SIG_VALUE 0x80 -#define NVM_SIZE_MULTIPLIER 4096 /* multiplier for NVMS field */ -#define WM_PCH_SPT_FLASHOFFSET 0xe000 /* offset of NVM access regs(PCH_SPT)*/ +#define NVM_SIZE_MULTIPLIER 4096 /* multiplier for NVMS field */ +#define WM_PCH_SPT_FLASHOFFSET 0xe000 /* offset of NVM access regs(PCH_SPT)*/ /* for PCI express Capability registers */ #define WM_PCIE_DCSR2_16MS 0x00000005 /* SFF SFP ROM data */ -#define SFF_SFP_ID_OFF 0x00 -#define SFF_SFP_ID_UNKNOWN 0x00 /* Unknown */ -#define SFF_SFP_ID_SFF 0x02 /* Module soldered to motherboard */ -#define SFF_SFP_ID_SFP 0x03 /* SFP transceiver */ - -#define SFF_SFP_ETH_FLAGS_OFF 0x06 -#define SFF_SFP_ETH_FLAGS_1000SX 0x01 -#define SFF_SFP_ETH_FLAGS_1000LX 0x02 -#define SFF_SFP_ETH_FLAGS_1000CX 0x04 -#define SFF_SFP_ETH_FLAGS_1000T 0x08 -#define SFF_SFP_ETH_FLAGS_100LX 0x10 -#define SFF_SFP_ETH_FLAGS_100FX 0x20 +#define SFF_SFP_ID_OFF 0x00 +#define SFF_SFP_ID_UNKNOWN 0x00 /* Unknown */ +#define SFF_SFP_ID_SFF 0x02 /* Module soldered to motherboard */ +#define SFF_SFP_ID_SFP 0x03 /* SFP transceiver */ + +#define SFF_SFP_ETH_FLAGS_OFF 0x06 +#define SFF_SFP_ETH_FLAGS_1000SX 0x01 +#define SFF_SFP_ETH_FLAGS_1000LX 0x02 +#define SFF_SFP_ETH_FLAGS_1000CX 0x04 +#define SFF_SFP_ETH_FLAGS_1000T 0x08 +#define SFF_SFP_ETH_FLAGS_100LX 0x10 +#define SFF_SFP_ETH_FLAGS_100FX 0x20 /* I21[01] PHY related definitions */ -#define GS40G_PAGE_SELECT 0x16 -#define GS40G_PAGE_SHIFT 16 -#define GS40G_OFFSET_MASK 0xffff -#define GS40G_PHY_PLL_FREQ_PAGE 0xfc0000 -#define GS40G_PHY_PLL_FREQ_REG 0x000e -#define GS40G_PHY_PLL_UNCONF 0xff +#define GS40G_PAGE_SELECT 0x16 +#define GS40G_PAGE_SHIFT 16 +#define GS40G_OFFSET_MASK 0xffff +#define GS40G_PHY_PLL_FREQ_PAGE 0xfc0000 +#define GS40G_PHY_PLL_FREQ_REG 0x000e +#define GS40G_PHY_PLL_UNCONF 0xff /* advanced TX descriptor for 82575 and newer */ typedef union nq_txdesc { @@ -1665,32 +1665,32 @@ typedef union nq_txdesc { #define NQTX_DTYP_C (2U << 20) /* context */ #define NQTX_DTYP_D (3U << 20) /* data */ -#define NQTXD_FIELDS_IDX_SHIFT 4 /* context index shift */ -#define NQTXD_FIELDS_IDX_MASK 0xf -#define NQTXD_FIELDS_PAYLEN_SHIFT 14 /* payload len shift */ -#define NQTXD_FIELDS_PAYLEN_MASK 0x3ffff - -#define NQTXD_FIELDS_IXSM __BIT(8) /* do IP checksum */ -#define NQTXD_FIELDS_TUXSM __BIT(9) /* do TCP/UDP checksum */ - -#define NQTXC_VLLEN_IPLEN_SHIFT 0 /* IP header len */ -#define NQTXC_VLLEN_IPLEN_MASK 0x1ff -#define NQTXC_VLLEN_MACLEN_SHIFT 9 /* MAC header len */ -#define NQTXC_VLLEN_MACLEN_MASK 0x7f -#define NQTXC_VLLEN_VLAN_SHIFT 16 /* vlan number */ -#define NQTXC_VLLEN_VLAN_MASK 0xffff - -#define NQTXC_CMD_MKRLOC_SHIFT 0 /* IP checksum offset */ -#define NQTXC_CMD_MKRLOC_MASK 0x1ff -#define NQTXC_CMD_SNAP __BIT(9) -#define NQTXC_CMD_IPV_MASK __BIT(10) -#define NQTXC_CMD_IP4 __SHIFTIN(1, NQTXC_CMD_IPV_MASK) -#define NQTXC_CMD_IP6 __SHIFTIN(0, NQTXC_CMD_IPV_MASK) -#define NQTXC_CMD_TCP __BIT(11) -#define NQTXC_CMD_UDP (0U << 11) -#define NQTXC_MSSIDX_IDX_SHIFT 4 /* context index shift */ -#define NQTXC_MSSIDX_IDX_MASK 0xf -#define NQTXC_MSSIDX_L4LEN_SHIFT 8 /* L4 header len shift */ -#define NQTXC_MSSIDX_L4LEN_MASK 0xff -#define NQTXC_MSSIDX_MSS_SHIFT 16 /* MSS */ -#define NQTXC_MSSIDX_MSS_MASK 0xffff +#define NQTXD_FIELDS_IDX_SHIFT 4 /* context index shift */ +#define NQTXD_FIELDS_IDX_MASK 0xf +#define NQTXD_FIELDS_PAYLEN_SHIFT 14 /* payload len shift */ +#define NQTXD_FIELDS_PAYLEN_MASK 0x3ffff + +#define NQTXD_FIELDS_IXSM __BIT(8) /* do IP checksum */ +#define NQTXD_FIELDS_TUXSM __BIT(9) /* do TCP/UDP checksum */ + +#define NQTXC_VLLEN_IPLEN_SHIFT 0 /* IP header len */ +#define NQTXC_VLLEN_IPLEN_MASK 0x1ff +#define NQTXC_VLLEN_MACLEN_SHIFT 9 /* MAC header len */ +#define NQTXC_VLLEN_MACLEN_MASK 0x7f +#define NQTXC_VLLEN_VLAN_SHIFT 16 /* vlan number */ +#define NQTXC_VLLEN_VLAN_MASK 0xffff + +#define NQTXC_CMD_MKRLOC_SHIFT 0 /* IP checksum offset */ +#define NQTXC_CMD_MKRLOC_MASK 0x1ff +#define NQTXC_CMD_SNAP __BIT(9) +#define NQTXC_CMD_IPV_MASK __BIT(10) +#define NQTXC_CMD_IP4 __SHIFTIN(1, NQTXC_CMD_IPV_MASK) +#define NQTXC_CMD_IP6 __SHIFTIN(0, NQTXC_CMD_IPV_MASK) +#define NQTXC_CMD_TCP __BIT(11) +#define NQTXC_CMD_UDP (0U << 11) +#define NQTXC_MSSIDX_IDX_SHIFT 4 /* context index shift */ +#define NQTXC_MSSIDX_IDX_MASK 0xf +#define NQTXC_MSSIDX_L4LEN_SHIFT 8 /* L4 header len shift */ +#define NQTXC_MSSIDX_L4LEN_MASK 0xff +#define NQTXC_MSSIDX_MSS_SHIFT 16 /* MSS */ +#define NQTXC_MSSIDX_MSS_MASK 0xffff