xref: /openbmc/qemu/hw/net/igb_regs.h (revision 2431f4f1)
13a977deeSAkihiko Odaki /* SPDX-License-Identifier: GPL-2.0 */
23a977deeSAkihiko Odaki /*
33a977deeSAkihiko Odaki  * This is copied + edited from kernel header files in
43a977deeSAkihiko Odaki  * drivers/net/ethernet/intel/igb
53a977deeSAkihiko Odaki  */
63a977deeSAkihiko Odaki 
73a977deeSAkihiko Odaki #ifndef HW_IGB_REGS_H_
83a977deeSAkihiko Odaki #define HW_IGB_REGS_H_
93a977deeSAkihiko Odaki 
103a977deeSAkihiko Odaki #include "e1000x_regs.h"
113a977deeSAkihiko Odaki 
123a977deeSAkihiko Odaki /* from igb/e1000_hw.h */
133a977deeSAkihiko Odaki 
143a977deeSAkihiko Odaki #define E1000_DEV_ID_82576                 0x10C9
153a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_FIBER           0x10E6
163a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_SERDES          0x10E7
173a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_QUAD_COPPER             0x10E8
183a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_QUAD_COPPER_ET2 0x1526
193a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_NS                      0x150A
203a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_NS_SERDES               0x1518
213a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_SERDES_QUAD             0x150D
223a977deeSAkihiko Odaki 
233a977deeSAkihiko Odaki /* Context Descriptor */
243a977deeSAkihiko Odaki struct e1000_adv_tx_context_desc {
253a977deeSAkihiko Odaki     uint32_t vlan_macip_lens;
263a977deeSAkihiko Odaki     uint32_t seqnum_seed;
273a977deeSAkihiko Odaki     uint32_t type_tucmd_mlhl;
283a977deeSAkihiko Odaki     uint32_t mss_l4len_idx;
293a977deeSAkihiko Odaki };
303a977deeSAkihiko Odaki 
313a977deeSAkihiko Odaki /* Advanced Transmit Descriptor */
323a977deeSAkihiko Odaki union e1000_adv_tx_desc {
333a977deeSAkihiko Odaki     struct {
343a977deeSAkihiko Odaki         uint64_t buffer_addr;     /* Address of descriptor's data buffer */
353a977deeSAkihiko Odaki         uint32_t cmd_type_len;
363a977deeSAkihiko Odaki         uint32_t olinfo_status;
373a977deeSAkihiko Odaki     } read;
383a977deeSAkihiko Odaki     struct {
393a977deeSAkihiko Odaki         uint64_t rsvd;            /* Reserved */
403a977deeSAkihiko Odaki         uint32_t nxtseq_seed;
413a977deeSAkihiko Odaki         uint32_t status;
423a977deeSAkihiko Odaki     } wb;
433a977deeSAkihiko Odaki };
443a977deeSAkihiko Odaki 
453a977deeSAkihiko Odaki #define E1000_ADVTXD_POTS_IXSM  0x00000100 /* Insert TCP/UDP Checksum */
463a977deeSAkihiko Odaki #define E1000_ADVTXD_POTS_TXSM  0x00000200 /* Insert TCP/UDP Checksum */
473a977deeSAkihiko Odaki 
483a977deeSAkihiko Odaki #define E1000_TXD_POPTS_IXSM 0x00000001 /* Insert IP checksum */
493a977deeSAkihiko Odaki #define E1000_TXD_POPTS_TXSM 0x00000002 /* Insert TCP/UDP checksum */
503a977deeSAkihiko Odaki 
513a977deeSAkihiko Odaki /* Receive Descriptor - Advanced */
523a977deeSAkihiko Odaki union e1000_adv_rx_desc {
533a977deeSAkihiko Odaki     struct {
543a977deeSAkihiko Odaki         uint64_t pkt_addr;                /* Packet Buffer Address */
553a977deeSAkihiko Odaki         uint64_t hdr_addr;                /* Header Buffer Address */
563a977deeSAkihiko Odaki     } read;
573a977deeSAkihiko Odaki     struct {
583a977deeSAkihiko Odaki         struct {
593a977deeSAkihiko Odaki             struct {
603a977deeSAkihiko Odaki                 uint16_t pkt_info;        /* RSS Type, Packet Type */
613a977deeSAkihiko Odaki                 uint16_t hdr_info;        /* Split Head, Buffer Length */
623a977deeSAkihiko Odaki             } lo_dword;
633a977deeSAkihiko Odaki             union {
643a977deeSAkihiko Odaki                 uint32_t rss;             /* RSS Hash */
653a977deeSAkihiko Odaki                 struct {
663a977deeSAkihiko Odaki                         uint16_t ip_id;   /* IP Id */
673a977deeSAkihiko Odaki                         uint16_t csum;    /* Packet Checksum */
683a977deeSAkihiko Odaki                 } csum_ip;
693a977deeSAkihiko Odaki             } hi_dword;
703a977deeSAkihiko Odaki         } lower;
713a977deeSAkihiko Odaki         struct {
723a977deeSAkihiko Odaki             uint32_t status_error;        /* Ext Status/Error */
733a977deeSAkihiko Odaki             uint16_t length;              /* Packet Length */
743a977deeSAkihiko Odaki             uint16_t vlan;                /* VLAN tag */
753a977deeSAkihiko Odaki         } upper;
763a977deeSAkihiko Odaki     } wb;  /* writeback */
773a977deeSAkihiko Odaki };
783a977deeSAkihiko Odaki 
793a977deeSAkihiko Odaki /* from igb/e1000_phy.h */
803a977deeSAkihiko Odaki 
813a977deeSAkihiko Odaki /* IGP01E1000 Specific Registers */
823a977deeSAkihiko Odaki #define IGP01E1000_PHY_PORT_CONFIG        0x10 /* Port Config */
833a977deeSAkihiko Odaki #define IGP01E1000_PHY_PORT_STATUS        0x11 /* Status */
843a977deeSAkihiko Odaki #define IGP01E1000_PHY_PORT_CTRL          0x12 /* Control */
853a977deeSAkihiko Odaki #define IGP01E1000_PHY_LINK_HEALTH        0x13 /* PHY Link Health */
863a977deeSAkihiko Odaki #define IGP02E1000_PHY_POWER_MGMT         0x19 /* Power Management */
873a977deeSAkihiko Odaki #define IGP01E1000_PHY_PAGE_SELECT        0x1F /* Page Select */
883a977deeSAkihiko Odaki #define IGP01E1000_PHY_PCS_INIT_REG       0x00B4
893a977deeSAkihiko Odaki #define IGP01E1000_PHY_POLARITY_MASK      0x0078
903a977deeSAkihiko Odaki #define IGP01E1000_PSCR_AUTO_MDIX         0x1000
913a977deeSAkihiko Odaki #define IGP01E1000_PSCR_FORCE_MDI_MDIX    0x2000 /* 0=MDI, 1=MDIX */
923a977deeSAkihiko Odaki #define IGP01E1000_PSCFR_SMART_SPEED      0x0080
933a977deeSAkihiko Odaki 
943a977deeSAkihiko Odaki /* Enable flexible speed on link-up */
953a977deeSAkihiko Odaki #define IGP02E1000_PM_D0_LPLU             0x0002 /* For D0a states */
963a977deeSAkihiko Odaki #define IGP02E1000_PM_D3_LPLU             0x0004 /* For all other states */
973a977deeSAkihiko Odaki #define IGP01E1000_PLHR_SS_DOWNGRADE      0x8000
983a977deeSAkihiko Odaki #define IGP01E1000_PSSR_POLARITY_REVERSED 0x0002
993a977deeSAkihiko Odaki #define IGP01E1000_PSSR_MDIX              0x0800
1003a977deeSAkihiko Odaki #define IGP01E1000_PSSR_SPEED_MASK        0xC000
1013a977deeSAkihiko Odaki #define IGP01E1000_PSSR_SPEED_1000MBPS    0xC000
1023a977deeSAkihiko Odaki #define IGP02E1000_PHY_CHANNEL_NUM        4
1033a977deeSAkihiko Odaki #define IGP02E1000_PHY_AGC_A              0x11B1
1043a977deeSAkihiko Odaki #define IGP02E1000_PHY_AGC_B              0x12B1
1053a977deeSAkihiko Odaki #define IGP02E1000_PHY_AGC_C              0x14B1
1063a977deeSAkihiko Odaki #define IGP02E1000_PHY_AGC_D              0x18B1
1073a977deeSAkihiko Odaki #define IGP02E1000_AGC_LENGTH_SHIFT       9   /* Course - 15:13, Fine - 12:9 */
1083a977deeSAkihiko Odaki #define IGP02E1000_AGC_LENGTH_MASK        0x7F
1093a977deeSAkihiko Odaki #define IGP02E1000_AGC_RANGE              15
1103a977deeSAkihiko Odaki 
1113a977deeSAkihiko Odaki /* from igb/igb.h */
1123a977deeSAkihiko Odaki 
1133a977deeSAkihiko Odaki #define E1000_PCS_CFG_IGN_SD     1
1143a977deeSAkihiko Odaki 
1153a977deeSAkihiko Odaki /* Interrupt defines */
1163a977deeSAkihiko Odaki #define IGB_START_ITR            648 /* ~6000 ints/sec */
1173a977deeSAkihiko Odaki #define IGB_4K_ITR               980
1183a977deeSAkihiko Odaki #define IGB_20K_ITR              196
1193a977deeSAkihiko Odaki #define IGB_70K_ITR              56
1203a977deeSAkihiko Odaki 
1213a977deeSAkihiko Odaki /* TX/RX descriptor defines */
1223a977deeSAkihiko Odaki #define IGB_DEFAULT_TXD          256
1233a977deeSAkihiko Odaki #define IGB_DEFAULT_TX_WORK      128
1243a977deeSAkihiko Odaki #define IGB_MIN_TXD              80
1253a977deeSAkihiko Odaki #define IGB_MAX_TXD              4096
1263a977deeSAkihiko Odaki 
1273a977deeSAkihiko Odaki #define IGB_DEFAULT_RXD          256
1283a977deeSAkihiko Odaki #define IGB_MIN_RXD              80
1293a977deeSAkihiko Odaki #define IGB_MAX_RXD              4096
1303a977deeSAkihiko Odaki 
1313a977deeSAkihiko Odaki #define IGB_DEFAULT_ITR           3 /* dynamic */
1323a977deeSAkihiko Odaki #define IGB_MAX_ITR_USECS         10000
1333a977deeSAkihiko Odaki #define IGB_MIN_ITR_USECS         10
1343a977deeSAkihiko Odaki #define NON_Q_VECTORS             1
1353a977deeSAkihiko Odaki #define MAX_Q_VECTORS             8
1363a977deeSAkihiko Odaki #define MAX_MSIX_ENTRIES          10
1373a977deeSAkihiko Odaki 
1383a977deeSAkihiko Odaki /* Transmit and receive queues */
1393a977deeSAkihiko Odaki #define IGB_MAX_RX_QUEUES          8
1403a977deeSAkihiko Odaki #define IGB_MAX_RX_QUEUES_82575    4
1413a977deeSAkihiko Odaki #define IGB_MAX_RX_QUEUES_I211     2
1423a977deeSAkihiko Odaki #define IGB_MAX_TX_QUEUES          8
1433a977deeSAkihiko Odaki #define IGB_MAX_VF_MC_ENTRIES      30
1443a977deeSAkihiko Odaki #define IGB_MAX_VF_FUNCTIONS       8
1453a977deeSAkihiko Odaki #define IGB_MAX_VFTA_ENTRIES       128
1463a977deeSAkihiko Odaki #define IGB_82576_VF_DEV_ID        0x10CA
1473a977deeSAkihiko Odaki #define IGB_I350_VF_DEV_ID         0x1520
1483a977deeSAkihiko Odaki 
1494847dabfSAkihiko Odaki /* VLAN info */
1504847dabfSAkihiko Odaki #define IGB_TX_FLAGS_VLAN_MASK     0xffff0000
1514847dabfSAkihiko Odaki #define IGB_TX_FLAGS_VLAN_SHIFT    16
1524847dabfSAkihiko Odaki 
1533a977deeSAkihiko Odaki /* from igb/e1000_82575.h */
1543a977deeSAkihiko Odaki 
1553a977deeSAkihiko Odaki #define E1000_MRQC_ENABLE_RSS_MQ            0x00000002
1563a977deeSAkihiko Odaki #define E1000_MRQC_ENABLE_VMDQ              0x00000003
1573a977deeSAkihiko Odaki #define E1000_MRQC_RSS_FIELD_IPV4_UDP       0x00400000
1583a977deeSAkihiko Odaki #define E1000_MRQC_ENABLE_VMDQ_RSS_MQ       0x00000005
1593a977deeSAkihiko Odaki #define E1000_MRQC_RSS_FIELD_IPV6_UDP       0x00800000
1603a977deeSAkihiko Odaki #define E1000_MRQC_RSS_FIELD_IPV6_UDP_EX    0x01000000
1613a977deeSAkihiko Odaki 
1624847dabfSAkihiko Odaki /* Adv Transmit Descriptor Config Masks */
1634847dabfSAkihiko Odaki #define E1000_ADVTXD_MAC_TSTAMP   0x00080000 /* IEEE1588 Timestamp packet */
1644847dabfSAkihiko Odaki #define E1000_ADVTXD_DTYP_CTXT    0x00200000 /* Advanced Context Descriptor */
1654847dabfSAkihiko Odaki #define E1000_ADVTXD_DTYP_DATA    0x00300000 /* Advanced Data Descriptor */
1664847dabfSAkihiko Odaki #define E1000_ADVTXD_DCMD_EOP     0x01000000 /* End of Packet */
1674847dabfSAkihiko Odaki #define E1000_ADVTXD_DCMD_IFCS    0x02000000 /* Insert FCS (Ethernet CRC) */
1684847dabfSAkihiko Odaki #define E1000_ADVTXD_DCMD_RS      0x08000000 /* Report Status */
1694847dabfSAkihiko Odaki #define E1000_ADVTXD_DCMD_DEXT    0x20000000 /* Descriptor extension (1=Adv) */
1704847dabfSAkihiko Odaki #define E1000_ADVTXD_DCMD_VLE     0x40000000 /* VLAN pkt enable */
1714847dabfSAkihiko Odaki #define E1000_ADVTXD_DCMD_TSE     0x80000000 /* TCP Seg enable */
1724847dabfSAkihiko Odaki #define E1000_ADVTXD_PAYLEN_SHIFT    14 /* Adv desc PAYLEN shift */
1734847dabfSAkihiko Odaki 
1744847dabfSAkihiko Odaki #define E1000_ADVTXD_MACLEN_SHIFT    9  /* Adv ctxt desc mac len shift */
1754847dabfSAkihiko Odaki #define E1000_ADVTXD_TUCMD_L4T_UDP 0x00000000  /* L4 Packet TYPE of UDP */
1764847dabfSAkihiko Odaki #define E1000_ADVTXD_TUCMD_IPV4    0x00000400  /* IP Packet Type: 1=IPv4 */
1774847dabfSAkihiko Odaki #define E1000_ADVTXD_TUCMD_L4T_TCP 0x00000800  /* L4 Packet TYPE of TCP */
1784847dabfSAkihiko Odaki #define E1000_ADVTXD_TUCMD_L4T_SCTP 0x00001000 /* L4 packet TYPE of SCTP */
1794847dabfSAkihiko Odaki /* IPSec Encrypt Enable for ESP */
1804847dabfSAkihiko Odaki #define E1000_ADVTXD_L4LEN_SHIFT     8  /* Adv ctxt L4LEN shift */
1814847dabfSAkihiko Odaki #define E1000_ADVTXD_MSS_SHIFT      16  /* Adv ctxt MSS shift */
1824847dabfSAkihiko Odaki /* Adv ctxt IPSec SA IDX mask */
1834847dabfSAkihiko Odaki /* Adv ctxt IPSec ESP len mask */
1844847dabfSAkihiko Odaki 
1853269ebb3SSriram Yagnaraman /* Additional Transmit Descriptor Control definitions */
1863269ebb3SSriram Yagnaraman #define E1000_TXDCTL_QUEUE_ENABLE  0x02000000 /* Enable specific Tx Queue */
1873269ebb3SSriram Yagnaraman 
1883a977deeSAkihiko Odaki /* Additional Receive Descriptor Control definitions */
1893a977deeSAkihiko Odaki #define E1000_RXDCTL_QUEUE_ENABLE  0x02000000 /* Enable specific Rx Queue */
1903a977deeSAkihiko Odaki 
1913a977deeSAkihiko Odaki /* Direct Cache Access (DCA) definitions */
1923a977deeSAkihiko Odaki #define E1000_DCA_CTRL_DCA_MODE_DISABLE 0x01 /* DCA Disable */
1933a977deeSAkihiko Odaki #define E1000_DCA_CTRL_DCA_MODE_CB2     0x02 /* DCA Mode CB2 */
1943a977deeSAkihiko Odaki 
1953a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_CPUID_MASK 0x0000001F /* Rx CPUID Mask */
1963a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_DESC_DCA_EN BIT(5) /* DCA Rx Desc enable */
1973a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_HEAD_DCA_EN BIT(6) /* DCA Rx Desc header enable */
1983a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_DATA_DCA_EN BIT(7) /* DCA Rx Desc payload enable */
1993a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_DESC_RRO_EN BIT(9) /* DCA Rx rd Desc Relax Order */
2003a977deeSAkihiko Odaki 
2013a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_CPUID_MASK 0x0000001F /* Tx CPUID Mask */
2023a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_DESC_DCA_EN BIT(5) /* DCA Tx Desc enable */
2033a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_DESC_RRO_EN BIT(9) /* Tx rd Desc Relax Order */
2043a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_TX_WB_RO_EN BIT(11) /* Tx Desc writeback RO bit */
2053a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_DATA_RRO_EN BIT(13) /* Tx rd data Relax Order */
2063a977deeSAkihiko Odaki 
2073a977deeSAkihiko Odaki /* Additional DCA related definitions, note change in position of CPUID */
2083a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_CPUID_MASK_82576 0xFF000000 /* Tx CPUID Mask */
2093a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_CPUID_MASK_82576 0xFF000000 /* Rx CPUID Mask */
2103a977deeSAkihiko Odaki #define E1000_DCA_TXCTRL_CPUID_SHIFT 24 /* Tx CPUID now in the last byte */
2113a977deeSAkihiko Odaki #define E1000_DCA_RXCTRL_CPUID_SHIFT 24 /* Rx CPUID now in the last byte */
2123a977deeSAkihiko Odaki 
2133a9926d9SAkihiko Odaki /* ETQF register bit definitions */
2143a9926d9SAkihiko Odaki #define E1000_ETQF_FILTER_ENABLE   BIT(26)
2153a9926d9SAkihiko Odaki #define E1000_ETQF_1588            BIT(30)
2163a9926d9SAkihiko Odaki #define E1000_ETQF_IMM_INT         BIT(29)
2173a9926d9SAkihiko Odaki #define E1000_ETQF_QUEUE_ENABLE    BIT(31)
2183a9926d9SAkihiko Odaki #define E1000_ETQF_QUEUE_SHIFT     16
2193a9926d9SAkihiko Odaki #define E1000_ETQF_QUEUE_MASK      0x00070000
2203a9926d9SAkihiko Odaki #define E1000_ETQF_ETYPE_MASK      0x0000FFFF
2213a9926d9SAkihiko Odaki 
2223a977deeSAkihiko Odaki #define E1000_DTXSWC_MAC_SPOOF_MASK   0x000000FF /* Per VF MAC spoof control */
2233a977deeSAkihiko Odaki #define E1000_DTXSWC_VLAN_SPOOF_MASK  0x0000FF00 /* Per VF VLAN spoof control */
2243a977deeSAkihiko Odaki #define E1000_DTXSWC_LLE_MASK         0x00FF0000 /* Per VF Local LB enables */
2253a977deeSAkihiko Odaki #define E1000_DTXSWC_VLAN_SPOOF_SHIFT 8
2263a977deeSAkihiko Odaki #define E1000_DTXSWC_VMDQ_LOOPBACK_EN BIT(31)  /* global VF LB enable */
2273a977deeSAkihiko Odaki 
2283a977deeSAkihiko Odaki /* Easy defines for setting default pool, would normally be left a zero */
2293a977deeSAkihiko Odaki #define E1000_VT_CTL_DEFAULT_POOL_SHIFT 7
2303a977deeSAkihiko Odaki #define E1000_VT_CTL_DEFAULT_POOL_MASK  (0x7 << E1000_VT_CTL_DEFAULT_POOL_SHIFT)
2313a977deeSAkihiko Odaki 
2323a977deeSAkihiko Odaki /* Other useful VMD_CTL register defines */
2333a977deeSAkihiko Odaki #define E1000_VT_CTL_IGNORE_MAC         BIT(28)
2343a977deeSAkihiko Odaki #define E1000_VT_CTL_DISABLE_DEF_POOL   BIT(29)
2353a977deeSAkihiko Odaki #define E1000_VT_CTL_VM_REPL_EN         BIT(30)
2363a977deeSAkihiko Odaki 
2373a977deeSAkihiko Odaki /* Per VM Offload register setup */
2383a977deeSAkihiko Odaki #define E1000_VMOLR_RLPML_MASK 0x00003FFF /* Long Packet Maximum Length mask */
2393a977deeSAkihiko Odaki #define E1000_VMOLR_LPE        0x00010000 /* Accept Long packet */
2403a977deeSAkihiko Odaki #define E1000_VMOLR_RSSE       0x00020000 /* Enable RSS */
2413a977deeSAkihiko Odaki #define E1000_VMOLR_AUPE       0x01000000 /* Accept untagged packets */
2423a977deeSAkihiko Odaki #define E1000_VMOLR_ROMPE      0x02000000 /* Accept overflow multicast */
2433a977deeSAkihiko Odaki #define E1000_VMOLR_ROPE       0x04000000 /* Accept overflow unicast */
2443a977deeSAkihiko Odaki #define E1000_VMOLR_BAM        0x08000000 /* Accept Broadcast packets */
2453a977deeSAkihiko Odaki #define E1000_VMOLR_MPME       0x10000000 /* Multicast promiscuous mode */
2463a977deeSAkihiko Odaki #define E1000_VMOLR_STRVLAN    0x40000000 /* Vlan stripping enable */
2473a977deeSAkihiko Odaki #define E1000_VMOLR_STRCRC     0x80000000 /* CRC stripping enable */
2483a977deeSAkihiko Odaki 
2493a977deeSAkihiko Odaki #define E1000_DVMOLR_HIDEVLAN  0x20000000 /* Hide vlan enable */
2503a977deeSAkihiko Odaki #define E1000_DVMOLR_STRVLAN   0x40000000 /* Vlan stripping enable */
2513a977deeSAkihiko Odaki #define E1000_DVMOLR_STRCRC    0x80000000 /* CRC stripping enable */
2523a977deeSAkihiko Odaki 
2533a977deeSAkihiko Odaki #define E1000_VLVF_ARRAY_SIZE     32
2543a977deeSAkihiko Odaki #define E1000_VLVF_VLANID_MASK    0x00000FFF
2553a977deeSAkihiko Odaki #define E1000_VLVF_POOLSEL_SHIFT  12
2563a977deeSAkihiko Odaki #define E1000_VLVF_POOLSEL_MASK   (0xFF << E1000_VLVF_POOLSEL_SHIFT)
2573a977deeSAkihiko Odaki #define E1000_VLVF_LVLAN          0x00100000
2583a977deeSAkihiko Odaki #define E1000_VLVF_VLANID_ENABLE  0x80000000
2593a977deeSAkihiko Odaki 
2603a977deeSAkihiko Odaki #define E1000_VMVIR_VLANA_DEFAULT      0x40000000 /* Always use default VLAN */
2613a977deeSAkihiko Odaki #define E1000_VMVIR_VLANA_NEVER        0x80000000 /* Never insert VLAN tag */
2623a977deeSAkihiko Odaki 
2633a977deeSAkihiko Odaki #define E1000_IOVCTL 0x05BBC
2643a977deeSAkihiko Odaki #define E1000_IOVCTL_REUSE_VFQ 0x00000001
2653a977deeSAkihiko Odaki 
2663a977deeSAkihiko Odaki #define E1000_RPLOLR_STRVLAN   0x40000000
2673a977deeSAkihiko Odaki #define E1000_RPLOLR_STRCRC    0x80000000
2683a977deeSAkihiko Odaki 
2693a977deeSAkihiko Odaki #define E1000_DTXCTL_8023LL     0x0004
2703a977deeSAkihiko Odaki #define E1000_DTXCTL_VLAN_ADDED 0x0008
2713a977deeSAkihiko Odaki #define E1000_DTXCTL_OOS_ENABLE 0x0010
2723a977deeSAkihiko Odaki #define E1000_DTXCTL_MDP_EN     0x0020
2733a977deeSAkihiko Odaki #define E1000_DTXCTL_SPOOF_INT  0x0040
2743a977deeSAkihiko Odaki 
2753a977deeSAkihiko Odaki /* from igb/e1000_defines.h */
2763a977deeSAkihiko Odaki 
2772e68546aSSriram Yagnaraman /* Physical Func Reset Done Indication */
2782e68546aSSriram Yagnaraman #define E1000_CTRL_EXT_PFRSTD   0x00004000
2792e68546aSSriram Yagnaraman 
2803a977deeSAkihiko Odaki #define E1000_IVAR_VALID     0x80
2813a977deeSAkihiko Odaki #define E1000_GPIE_NSICR     0x00000001
2823a977deeSAkihiko Odaki #define E1000_GPIE_MSIX_MODE 0x00000010
2833a977deeSAkihiko Odaki #define E1000_GPIE_EIAME     0x40000000
2843a977deeSAkihiko Odaki #define E1000_GPIE_PBA       0x80000000
2853a977deeSAkihiko Odaki 
2863a977deeSAkihiko Odaki /* Transmit Control */
2873a977deeSAkihiko Odaki #define E1000_TCTL_EN     0x00000002    /* enable tx */
2883a977deeSAkihiko Odaki #define E1000_TCTL_PSP    0x00000008    /* pad short packets */
2893a977deeSAkihiko Odaki #define E1000_TCTL_CT     0x00000ff0    /* collision threshold */
2903a977deeSAkihiko Odaki #define E1000_TCTL_COLD   0x003ff000    /* collision distance */
2913a977deeSAkihiko Odaki #define E1000_TCTL_RTLC   0x01000000    /* Re-transmit on late collision */
2923a977deeSAkihiko Odaki 
2933a977deeSAkihiko Odaki /* Collision related configuration parameters */
2943a977deeSAkihiko Odaki #define E1000_COLLISION_THRESHOLD       15
2953a977deeSAkihiko Odaki #define E1000_CT_SHIFT                  4
2963a977deeSAkihiko Odaki #define E1000_COLLISION_DISTANCE        63
2973a977deeSAkihiko Odaki #define E1000_COLD_SHIFT                12
2983a977deeSAkihiko Odaki 
2993a977deeSAkihiko Odaki #define E1000_RAH_POOL_MASK 0x03FC0000
3003a977deeSAkihiko Odaki #define E1000_RAH_POOL_1 0x00040000
3013a977deeSAkihiko Odaki 
3023a977deeSAkihiko Odaki #define E1000_ICR_VMMB         0x00000100 /* VM MB event */
3033a977deeSAkihiko Odaki #define E1000_ICR_TS           0x00080000 /* Time Sync Interrupt */
3043a977deeSAkihiko Odaki #define E1000_ICR_DRSTA        0x40000000 /* Device Reset Asserted */
3053a977deeSAkihiko Odaki /* If this bit asserted, the driver should claim the interrupt */
3063a977deeSAkihiko Odaki #define E1000_ICR_INT_ASSERTED 0x80000000
3073a977deeSAkihiko Odaki /* LAN connected device generates an interrupt */
3083a977deeSAkihiko Odaki #define E1000_ICR_DOUTSYNC     0x10000000 /* NIC DMA out of sync */
3093a977deeSAkihiko Odaki 
3103a977deeSAkihiko Odaki /* Extended Interrupt Cause Read */
3113a977deeSAkihiko Odaki #define E1000_EICR_RX_QUEUE0    0x00000001 /* Rx Queue 0 Interrupt */
3123a977deeSAkihiko Odaki #define E1000_EICR_RX_QUEUE1    0x00000002 /* Rx Queue 1 Interrupt */
3133a977deeSAkihiko Odaki #define E1000_EICR_RX_QUEUE2    0x00000004 /* Rx Queue 2 Interrupt */
3143a977deeSAkihiko Odaki #define E1000_EICR_RX_QUEUE3    0x00000008 /* Rx Queue 3 Interrupt */
3153a977deeSAkihiko Odaki #define E1000_EICR_TX_QUEUE0    0x00000100 /* Tx Queue 0 Interrupt */
3163a977deeSAkihiko Odaki #define E1000_EICR_TX_QUEUE1    0x00000200 /* Tx Queue 1 Interrupt */
3173a977deeSAkihiko Odaki #define E1000_EICR_TX_QUEUE2    0x00000400 /* Tx Queue 2 Interrupt */
3183a977deeSAkihiko Odaki #define E1000_EICR_TX_QUEUE3    0x00000800 /* Tx Queue 3 Interrupt */
3193a977deeSAkihiko Odaki #define E1000_EICR_OTHER        0x80000000 /* Interrupt Cause Active */
3203a977deeSAkihiko Odaki 
3213a977deeSAkihiko Odaki /* Extended Interrupt Cause Set */
3223a977deeSAkihiko Odaki /* E1000_EITR_CNT_IGNR is only for 82576 and newer */
3233a977deeSAkihiko Odaki #define E1000_EITR_CNT_IGNR     0x80000000 /* Don't reset counters on write */
3243a977deeSAkihiko Odaki 
3253dfc616eSAkihiko Odaki #define E1000_TSYNCTXCTL_VALID    0x00000001 /* tx timestamp valid */
3263dfc616eSAkihiko Odaki #define E1000_TSYNCTXCTL_ENABLED  0x00000010 /* enable tx timestampping */
3273dfc616eSAkihiko Odaki 
3283a977deeSAkihiko Odaki /* PCI Express Control */
3293a977deeSAkihiko Odaki #define E1000_GCR_CMPL_TMOUT_MASK       0x0000F000
3303a977deeSAkihiko Odaki #define E1000_GCR_CMPL_TMOUT_10ms       0x00001000
3313a977deeSAkihiko Odaki #define E1000_GCR_CMPL_TMOUT_RESEND     0x00010000
3323a977deeSAkihiko Odaki #define E1000_GCR_CAP_VER2              0x00040000
3333a977deeSAkihiko Odaki 
3343a977deeSAkihiko Odaki #define PHY_REVISION_MASK      0xFFFFFFF0
3353a977deeSAkihiko Odaki #define MAX_PHY_REG_ADDRESS    0x1F  /* 5 bit address bus (0-0x1F) */
3363a977deeSAkihiko Odaki #define MAX_PHY_MULTI_PAGE_REG 0xF
3373a977deeSAkihiko Odaki 
3383a977deeSAkihiko Odaki #define IGP03E1000_E_PHY_ID 0x02A80390
3393a977deeSAkihiko Odaki 
3403a977deeSAkihiko Odaki /* from igb/e1000_mbox.h */
3413a977deeSAkihiko Odaki 
3423a977deeSAkihiko Odaki #define E1000_P2VMAILBOX_STS  0x00000001 /* Initiate message send to VF */
3433a977deeSAkihiko Odaki #define E1000_P2VMAILBOX_ACK  0x00000002 /* Ack message recv'd from VF */
3443a977deeSAkihiko Odaki #define E1000_P2VMAILBOX_VFU  0x00000004 /* VF owns the mailbox buffer */
3453a977deeSAkihiko Odaki #define E1000_P2VMAILBOX_PFU  0x00000008 /* PF owns the mailbox buffer */
3463a977deeSAkihiko Odaki #define E1000_P2VMAILBOX_RVFU 0x00000010 /* Reset VFU - used when VF stuck */
3473a977deeSAkihiko Odaki 
3483a977deeSAkihiko Odaki #define E1000_MBVFICR_VFREQ_MASK 0x000000FF /* bits for VF messages */
3493a977deeSAkihiko Odaki #define E1000_MBVFICR_VFREQ_VF1  0x00000001 /* bit for VF 1 message */
3503a977deeSAkihiko Odaki #define E1000_MBVFICR_VFACK_MASK 0x00FF0000 /* bits for VF acks */
3513a977deeSAkihiko Odaki #define E1000_MBVFICR_VFACK_VF1  0x00010000 /* bit for VF 1 ack */
3523a977deeSAkihiko Odaki 
3533a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_SIZE 16 /* 16 32 bit words - 64 bytes */
3543a977deeSAkihiko Odaki 
3553a977deeSAkihiko Odaki /*
3563a977deeSAkihiko Odaki  * If it's a E1000_VF_* msg then it originates in the VF and is sent to the
3573a977deeSAkihiko Odaki  * PF.  The reverse is true if it is E1000_PF_*.
3583a977deeSAkihiko Odaki  * Message ACK's are the value or'd with 0xF0000000
3593a977deeSAkihiko Odaki  */
3603a977deeSAkihiko Odaki /* Messages below or'd with this are the ACK */
3613a977deeSAkihiko Odaki #define E1000_VT_MSGTYPE_ACK 0x80000000
3623a977deeSAkihiko Odaki /* Messages below or'd with this are the NACK */
3633a977deeSAkihiko Odaki #define E1000_VT_MSGTYPE_NACK 0x40000000
3643a977deeSAkihiko Odaki /* Indicates that VF is still clear to send requests */
3653a977deeSAkihiko Odaki #define E1000_VT_MSGTYPE_CTS 0x20000000
3663a977deeSAkihiko Odaki #define E1000_VT_MSGINFO_SHIFT 16
367*2431f4f1SMichael Tokarev /* bits 23:16 are used for extra info for certain messages */
3683a977deeSAkihiko Odaki #define E1000_VT_MSGINFO_MASK (0xFF << E1000_VT_MSGINFO_SHIFT)
3693a977deeSAkihiko Odaki 
3703a977deeSAkihiko Odaki #define E1000_VF_RESET                 0x01 /* VF requests reset */
3713a977deeSAkihiko Odaki #define E1000_VF_SET_MAC_ADDR          0x02 /* VF requests to set MAC addr */
3723a977deeSAkihiko Odaki /* VF requests to clear all unicast MAC filters */
3733a977deeSAkihiko Odaki #define E1000_VF_MAC_FILTER_CLR        (0x01 << E1000_VT_MSGINFO_SHIFT)
3743a977deeSAkihiko Odaki /* VF requests to add unicast MAC filter */
3753a977deeSAkihiko Odaki #define E1000_VF_MAC_FILTER_ADD        (0x02 << E1000_VT_MSGINFO_SHIFT)
3763a977deeSAkihiko Odaki #define E1000_VF_SET_MULTICAST         0x03 /* VF requests to set MC addr */
3773a977deeSAkihiko Odaki #define E1000_VF_SET_VLAN              0x04 /* VF requests to set VLAN */
3783a977deeSAkihiko Odaki #define E1000_VF_SET_LPE               0x05 /* VF requests to set VMOLR.LPE */
3793a977deeSAkihiko Odaki #define E1000_VF_SET_PROMISC           0x06 /*VF requests to clear VMOLR.ROPE/MPME*/
3803a977deeSAkihiko Odaki #define E1000_VF_SET_PROMISC_MULTICAST (0x02 << E1000_VT_MSGINFO_SHIFT)
3813a977deeSAkihiko Odaki 
3823a977deeSAkihiko Odaki #define E1000_PF_CONTROL_MSG 0x0100 /* PF control message */
3833a977deeSAkihiko Odaki 
3843a977deeSAkihiko Odaki /* from igb/e1000_regs.h */
3853a977deeSAkihiko Odaki 
3863a977deeSAkihiko Odaki #define E1000_EICR      0x01580  /* Ext. Interrupt Cause Read - R/clr */
3873a977deeSAkihiko Odaki #define E1000_EITR(_n)  (0x01680 + (0x4 * (_n)))
3883a977deeSAkihiko Odaki #define E1000_EICS      0x01520  /* Ext. Interrupt Cause Set - W0 */
3893a977deeSAkihiko Odaki #define E1000_EIMS      0x01524  /* Ext. Interrupt Mask Set/Read - RW */
3903a977deeSAkihiko Odaki #define E1000_EIMC      0x01528  /* Ext. Interrupt Mask Clear - WO */
3913a977deeSAkihiko Odaki #define E1000_EIAC      0x0152C  /* Ext. Interrupt Auto Clear - RW */
3923a977deeSAkihiko Odaki #define E1000_EIAM      0x01530  /* Ext. Interrupt Ack Auto Clear Mask - RW */
3933a977deeSAkihiko Odaki #define E1000_GPIE      0x01514  /* General Purpose Interrupt Enable; RW */
3943a977deeSAkihiko Odaki #define E1000_IVAR0     0x01700  /* Interrupt Vector Allocation Register - RW */
3953a977deeSAkihiko Odaki #define E1000_IVAR_MISC 0x01740  /* Interrupt Vector Allocation Register (last) - RW */
3963a977deeSAkihiko Odaki #define E1000_FRTIMER   0x01048  /* Free Running Timer - RW */
3973a977deeSAkihiko Odaki #define E1000_FCRTV     0x02460  /* Flow Control Refresh Timer Value - RW */
3983a977deeSAkihiko Odaki 
3993a9926d9SAkihiko Odaki #define E1000_TSYNCRXCFG 0x05F50 /* Time Sync Rx Configuration - RW */
4003a9926d9SAkihiko Odaki 
4013a9926d9SAkihiko Odaki /* Filtering Registers */
4023a9926d9SAkihiko Odaki #define E1000_SAQF(_n) (0x5980 + 4 * (_n))
4033a9926d9SAkihiko Odaki #define E1000_DAQF(_n) (0x59A0 + 4 * (_n))
4043a9926d9SAkihiko Odaki #define E1000_SPQF(_n) (0x59C0 + 4 * (_n))
4053a9926d9SAkihiko Odaki #define E1000_FTQF(_n) (0x59E0 + 4 * (_n))
4063a9926d9SAkihiko Odaki #define E1000_SAQF0 E1000_SAQF(0)
4073a9926d9SAkihiko Odaki #define E1000_DAQF0 E1000_DAQF(0)
4083a9926d9SAkihiko Odaki #define E1000_SPQF0 E1000_SPQF(0)
4093a9926d9SAkihiko Odaki #define E1000_FTQF0 E1000_FTQF(0)
4103a9926d9SAkihiko Odaki #define E1000_SYNQF(_n) (0x055FC + (4 * (_n))) /* SYN Packet Queue Fltr */
4113a9926d9SAkihiko Odaki #define E1000_ETQF(_n)  (0x05CB0 + (4 * (_n))) /* EType Queue Fltr */
4123a9926d9SAkihiko Odaki 
4133a977deeSAkihiko Odaki #define E1000_RQDPC(_n) (0x0C030 + ((_n) * 0x40))
4143a977deeSAkihiko Odaki 
4153a977deeSAkihiko Odaki #define E1000_RXPBS 0x02404  /* Rx Packet Buffer Size - RW */
4163a977deeSAkihiko Odaki #define E1000_TXPBS 0x03404  /* Tx Packet Buffer Size - RW */
4173a977deeSAkihiko Odaki 
4183a977deeSAkihiko Odaki #define E1000_DTXCTL 0x03590  /* DMA TX Control - RW */
4193a977deeSAkihiko Odaki 
4203a977deeSAkihiko Odaki #define E1000_HTCBDPC     0x04124  /* Host TX Circuit Breaker Dropped Count */
4213a977deeSAkihiko Odaki #define E1000_RLPML       0x05004  /* RX Long Packet Max Length */
4223a977deeSAkihiko Odaki #define E1000_RA2         0x054E0  /* 2nd half of Rx address array - RW Array */
4233a977deeSAkihiko Odaki #define E1000_PSRTYPE(_i) (0x05480 + ((_i) * 4))
4243a977deeSAkihiko Odaki #define E1000_VT_CTL   0x0581C  /* VMDq Control - RW */
4253a977deeSAkihiko Odaki 
4263a977deeSAkihiko Odaki /* VT Registers */
4273a977deeSAkihiko Odaki #define E1000_MBVFICR   0x00C80 /* Mailbox VF Cause - RWC */
4283a977deeSAkihiko Odaki #define E1000_MBVFIMR   0x00C84 /* Mailbox VF int Mask - RW */
4293a977deeSAkihiko Odaki #define E1000_VFLRE     0x00C88 /* VF Register Events - RWC */
4303a977deeSAkihiko Odaki #define E1000_VFRE      0x00C8C /* VF Receive Enables */
4313a977deeSAkihiko Odaki #define E1000_VFTE      0x00C90 /* VF Transmit Enables */
4323a977deeSAkihiko Odaki #define E1000_QDE       0x02408 /* Queue Drop Enable - RW */
4333a977deeSAkihiko Odaki #define E1000_DTXSWC    0x03500 /* DMA Tx Switch Control - RW */
4343a977deeSAkihiko Odaki #define E1000_WVBR      0x03554 /* VM Wrong Behavior - RWS */
4353a977deeSAkihiko Odaki #define E1000_RPLOLR    0x05AF0 /* Replication Offload - RW */
4363a977deeSAkihiko Odaki #define E1000_UTA       0x0A000 /* Unicast Table Array - RW */
4373a977deeSAkihiko Odaki #define E1000_IOVTCL    0x05BBC /* IOV Control Register */
4383a977deeSAkihiko Odaki #define E1000_TXSWC     0x05ACC /* Tx Switch Control */
4393a977deeSAkihiko Odaki #define E1000_LVMMC     0x03548 /* Last VM Misbehavior cause */
4403a977deeSAkihiko Odaki /* These act per VF so an array friendly macro is used */
4413a977deeSAkihiko Odaki #define E1000_P2VMAILBOX(_n)   (0x00C00 + (4 * (_n)))
4423a977deeSAkihiko Odaki #define E1000_VMBMEM(_n)       (0x00800 + (64 * (_n)))
4433a977deeSAkihiko Odaki #define E1000_VMOLR(_n)        (0x05AD0 + (4 * (_n)))
4443a977deeSAkihiko Odaki #define E1000_DVMOLR(_n)       (0x0C038 + (64 * (_n)))
4453a977deeSAkihiko Odaki #define E1000_VLVF(_n)         (0x05D00 + (4 * (_n))) /* VLAN VM Filter */
4463a977deeSAkihiko Odaki #define E1000_VMVIR(_n)        (0x03700 + (4 * (_n)))
4473a977deeSAkihiko Odaki 
4483a977deeSAkihiko Odaki /* from igbvf/defines.h */
4493a977deeSAkihiko Odaki 
4503a977deeSAkihiko Odaki /* SRRCTL bit definitions */
4513a977deeSAkihiko Odaki #define E1000_SRRCTL_BSIZEPKT_SHIFT            10 /* Shift _right_ */
4523a977deeSAkihiko Odaki #define E1000_SRRCTL_BSIZEHDRSIZE_MASK         0x00000F00
4533a977deeSAkihiko Odaki #define E1000_SRRCTL_BSIZEHDRSIZE_SHIFT        2  /* Shift _left_ */
4543a977deeSAkihiko Odaki #define E1000_SRRCTL_DESCTYPE_ADV_ONEBUF       0x02000000
455560cf339STomasz Dzieciol #define E1000_SRRCTL_DESCTYPE_HDR_SPLIT        0x04000000
4563a977deeSAkihiko Odaki #define E1000_SRRCTL_DESCTYPE_HDR_SPLIT_ALWAYS 0x0A000000
4573a977deeSAkihiko Odaki #define E1000_SRRCTL_DESCTYPE_MASK             0x0E000000
4583a977deeSAkihiko Odaki #define E1000_SRRCTL_DROP_EN                   0x80000000
4593a977deeSAkihiko Odaki 
4603a977deeSAkihiko Odaki #define E1000_SRRCTL_BSIZEPKT_MASK             0x0000007F
4613a977deeSAkihiko Odaki #define E1000_SRRCTL_BSIZEHDR_MASK             0x00003F00
4623a977deeSAkihiko Odaki 
4633a977deeSAkihiko Odaki /* from igbvf/mbox.h */
4643a977deeSAkihiko Odaki 
4653a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_REQ      0x00000001 /* Request for PF Ready bit */
4663a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_ACK      0x00000002 /* Ack PF message received */
4673a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_VFU      0x00000004 /* VF owns the mailbox buffer */
4683a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_PFU      0x00000008 /* PF owns the mailbox buffer */
4693a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_PFSTS    0x00000010 /* PF wrote a message in the MB */
4703a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_PFACK    0x00000020 /* PF ack the previous VF msg */
4713a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_RSTI     0x00000040 /* PF has reset indication */
4723a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_RSTD     0x00000080 /* PF has indicated reset done */
4733a977deeSAkihiko Odaki #define E1000_V2PMAILBOX_R2C_BITS 0x000000B0 /* All read to clear bits */
4743a977deeSAkihiko Odaki 
4753a977deeSAkihiko Odaki #define E1000_VFMAILBOX_SIZE      16 /* 16 32 bit words - 64 bytes */
4763a977deeSAkihiko Odaki 
4773a977deeSAkihiko Odaki /*
4783a977deeSAkihiko Odaki  * If it's a E1000_VF_* msg then it originates in the VF and is sent to the
4793a977deeSAkihiko Odaki  * PF.  The reverse is true if it is E1000_PF_*.
4803a977deeSAkihiko Odaki  * Message ACK's are the value or'd with 0xF0000000
4813a977deeSAkihiko Odaki  */
4823a977deeSAkihiko Odaki /* Messages below or'd with this are the ACK */
4833a977deeSAkihiko Odaki #define E1000_VT_MSGTYPE_ACK      0x80000000
4843a977deeSAkihiko Odaki /* Messages below or'd with this are the NACK */
4853a977deeSAkihiko Odaki #define E1000_VT_MSGTYPE_NACK     0x40000000
4863a977deeSAkihiko Odaki /* Indicates that VF is still clear to send requests */
4873a977deeSAkihiko Odaki #define E1000_VT_MSGTYPE_CTS      0x20000000
4883a977deeSAkihiko Odaki 
4893a977deeSAkihiko Odaki /* We have a total wait time of 1s for vf mailbox posted messages */
4903a977deeSAkihiko Odaki #define E1000_VF_MBX_INIT_TIMEOUT 2000 /* retry count for mbx timeout */
4913a977deeSAkihiko Odaki #define E1000_VF_MBX_INIT_DELAY   500  /* usec delay between retries */
4923a977deeSAkihiko Odaki 
4933a977deeSAkihiko Odaki #define E1000_VT_MSGINFO_SHIFT    16
494*2431f4f1SMichael Tokarev /* bits 23:16 are used for extra info for certain messages */
4953a977deeSAkihiko Odaki #define E1000_VT_MSGINFO_MASK     (0xFF << E1000_VT_MSGINFO_SHIFT)
4963a977deeSAkihiko Odaki 
4973a977deeSAkihiko Odaki #define E1000_VF_RESET            0x01 /* VF requests reset */
4983a977deeSAkihiko Odaki #define E1000_VF_SET_MAC_ADDR     0x02 /* VF requests PF to set MAC addr */
4993a977deeSAkihiko Odaki /* VF requests PF to clear all unicast MAC filters */
5003a977deeSAkihiko Odaki #define E1000_VF_MAC_FILTER_CLR   (0x01 << E1000_VT_MSGINFO_SHIFT)
5013a977deeSAkihiko Odaki /* VF requests PF to add unicast MAC filter */
5023a977deeSAkihiko Odaki #define E1000_VF_MAC_FILTER_ADD   (0x02 << E1000_VT_MSGINFO_SHIFT)
5033a977deeSAkihiko Odaki #define E1000_VF_SET_MULTICAST    0x03 /* VF requests PF to set MC addr */
5043a977deeSAkihiko Odaki #define E1000_VF_SET_VLAN         0x04 /* VF requests PF to set VLAN */
5053a977deeSAkihiko Odaki #define E1000_VF_SET_LPE          0x05 /* VF requests PF to set VMOLR.LPE */
5063a977deeSAkihiko Odaki 
5073a977deeSAkihiko Odaki #define E1000_PF_CONTROL_MSG      0x0100 /* PF control message */
5083a977deeSAkihiko Odaki 
5093a977deeSAkihiko Odaki /* from igbvf/regs.h */
5103a977deeSAkihiko Odaki 
5113a977deeSAkihiko Odaki /* Statistics registers */
5123a977deeSAkihiko Odaki #define E1000_VFGPRC   0x00F10
5133a977deeSAkihiko Odaki #define E1000_VFGORC   0x00F18
5143a977deeSAkihiko Odaki #define E1000_VFMPRC   0x00F3C
5153a977deeSAkihiko Odaki #define E1000_VFGPTC   0x00F14
5163a977deeSAkihiko Odaki #define E1000_VFGOTC   0x00F34
5173a977deeSAkihiko Odaki #define E1000_VFGOTLBC 0x00F50
5183a977deeSAkihiko Odaki #define E1000_VFGPTLBC 0x00F44
5193a977deeSAkihiko Odaki #define E1000_VFGORLBC 0x00F48
5203a977deeSAkihiko Odaki #define E1000_VFGPRLBC 0x00F40
5213a977deeSAkihiko Odaki 
5223a977deeSAkihiko Odaki /* These act per VF so an array friendly macro is used */
5233a977deeSAkihiko Odaki #define E1000_V2PMAILBOX(_n) (0x00C40 + (4 * (_n)))
5243a977deeSAkihiko Odaki #define E1000_VMBMEM(_n)     (0x00800 + (64 * (_n)))
5253a977deeSAkihiko Odaki 
5263a977deeSAkihiko Odaki /* from igbvf/vf.h */
5273a977deeSAkihiko Odaki 
5283a977deeSAkihiko Odaki #define E1000_DEV_ID_82576_VF 0x10CA
5293a977deeSAkihiko Odaki 
5303a977deeSAkihiko Odaki /* new */
5313a977deeSAkihiko Odaki 
5323a977deeSAkihiko Odaki /* Receive Registers */
5333a977deeSAkihiko Odaki 
5343a977deeSAkihiko Odaki /* RX Descriptor Base Low; RW */
5353a977deeSAkihiko Odaki #define E1000_RDBAL(_n)    (0x0C000 + (0x40  * (_n)))
5363a977deeSAkihiko Odaki #define E1000_RDBAL_A(_n)  (0x02800 + (0x100 * (_n)))
5373a977deeSAkihiko Odaki 
5383a977deeSAkihiko Odaki /* RX Descriptor Base High; RW */
5393a977deeSAkihiko Odaki #define E1000_RDBAH(_n)    (0x0C004 + (0x40  * (_n)))
5403a977deeSAkihiko Odaki #define E1000_RDBAH_A(_n)  (0x02804 + (0x100 * (_n)))
5413a977deeSAkihiko Odaki 
5423a977deeSAkihiko Odaki /* RX Descriptor Ring Length; RW */
5433a977deeSAkihiko Odaki #define E1000_RDLEN(_n)    (0x0C008 + (0x40  * (_n)))
5443a977deeSAkihiko Odaki #define E1000_RDLEN_A(_n)  (0x02808 + (0x100 * (_n)))
5453a977deeSAkihiko Odaki 
5463a977deeSAkihiko Odaki /* Split and Replication Receive Control; RW */
5473a977deeSAkihiko Odaki #define E1000_SRRCTL(_n)   (0x0C00C + (0x40  * (_n)))
5483a977deeSAkihiko Odaki #define E1000_SRRCTL_A(_n) (0x0280C + (0x100 * (_n)))
5493a977deeSAkihiko Odaki 
5503a977deeSAkihiko Odaki /* RX Descriptor Head; RW */
5513a977deeSAkihiko Odaki #define E1000_RDH(_n)      (0x0C010 + (0x40  * (_n)))
5523a977deeSAkihiko Odaki #define E1000_RDH_A(_n)    (0x02810 + (0x100 * (_n)))
5533a977deeSAkihiko Odaki 
5543a977deeSAkihiko Odaki /* RX DCA Control; RW */
5553a977deeSAkihiko Odaki #define E1000_RXCTL(_n)    (0x0C014 + (0x40  * (_n)))
5563a977deeSAkihiko Odaki #define E1000_RXCTL_A(_n)  (0x02814 + (0x100 * (_n)))
5573a977deeSAkihiko Odaki 
5583a977deeSAkihiko Odaki /* RX Descriptor Tail; RW */
5593a977deeSAkihiko Odaki #define E1000_RDT(_n)      (0x0C018 + (0x40  * (_n)))
5603a977deeSAkihiko Odaki #define E1000_RDT_A(_n)    (0x02818 + (0x100 * (_n)))
5613a977deeSAkihiko Odaki 
5623a977deeSAkihiko Odaki /* RX Descriptor Control; RW */
5633a977deeSAkihiko Odaki #define E1000_RXDCTL(_n)   (0x0C028 + (0x40  * (_n)))
5643a977deeSAkihiko Odaki #define E1000_RXDCTL_A(_n) (0x02828 + (0x100 * (_n)))
5653a977deeSAkihiko Odaki 
5663a977deeSAkihiko Odaki /* RX Queue Drop Packet Count; RC */
5673a977deeSAkihiko Odaki #define E1000_RQDPC_A(_n)  (0x02830 + (0x100 * (_n)))
5683a977deeSAkihiko Odaki 
5693a977deeSAkihiko Odaki /* Transmit Registers */
5703a977deeSAkihiko Odaki 
5713a977deeSAkihiko Odaki /* TX Descriptor Base Low; RW */
5723a977deeSAkihiko Odaki #define E1000_TDBAL(_n)    (0x0E000 + (0x40  * (_n)))
5733a977deeSAkihiko Odaki #define E1000_TDBAL_A(_n)  (0x03800 + (0x100 * (_n)))
5743a977deeSAkihiko Odaki 
5753a977deeSAkihiko Odaki /* TX Descriptor Base High; RW */
5763a977deeSAkihiko Odaki #define E1000_TDBAH(_n)    (0x0E004 + (0x40  * (_n)))
5773a977deeSAkihiko Odaki #define E1000_TDBAH_A(_n)  (0x03804 + (0x100 * (_n)))
5783a977deeSAkihiko Odaki 
5793a977deeSAkihiko Odaki /* TX Descriptor Ring Length; RW */
5803a977deeSAkihiko Odaki #define E1000_TDLEN(_n)    (0x0E008 + (0x40  * (_n)))
5813a977deeSAkihiko Odaki #define E1000_TDLEN_A(_n)  (0x03808 + (0x100 * (_n)))
5823a977deeSAkihiko Odaki 
5833a977deeSAkihiko Odaki /* TX Descriptor Head; RW */
5843a977deeSAkihiko Odaki #define E1000_TDH(_n)      (0x0E010 + (0x40  * (_n)))
5853a977deeSAkihiko Odaki #define E1000_TDH_A(_n)    (0x03810 + (0x100 * (_n)))
5863a977deeSAkihiko Odaki 
5873a977deeSAkihiko Odaki /* TX DCA Control; RW */
5883a977deeSAkihiko Odaki #define E1000_TXCTL(_n)    (0x0E014 + (0x40  * (_n)))
5893a977deeSAkihiko Odaki #define E1000_TXCTL_A(_n)  (0x03814 + (0x100 * (_n)))
5903a977deeSAkihiko Odaki 
5913a977deeSAkihiko Odaki /* TX Descriptor Tail; RW */
5923a977deeSAkihiko Odaki #define E1000_TDT(_n)      (0x0E018 + (0x40  * (_n)))
5933a977deeSAkihiko Odaki #define E1000_TDT_A(_n)    (0x03818 + (0x100 * (_n)))
5943a977deeSAkihiko Odaki 
5953a977deeSAkihiko Odaki /* TX Descriptor Control; RW */
5963a977deeSAkihiko Odaki #define E1000_TXDCTL(_n)   (0x0E028 + (0x40  * (_n)))
5973a977deeSAkihiko Odaki #define E1000_TXDCTL_A(_n) (0x03828 + (0x100 * (_n)))
5983a977deeSAkihiko Odaki 
5993a977deeSAkihiko Odaki /* TX Descriptor Completion Write–Back Address Low; RW */
6003a977deeSAkihiko Odaki #define E1000_TDWBAL(_n)   (0x0E038 + (0x40  * (_n)))
6013a977deeSAkihiko Odaki #define E1000_TDWBAL_A(_n) (0x03838 + (0x100 * (_n)))
6023a977deeSAkihiko Odaki 
6033a977deeSAkihiko Odaki /* TX Descriptor Completion Write–Back Address High; RW */
6043a977deeSAkihiko Odaki #define E1000_TDWBAH(_n)   (0x0E03C + (0x40  * (_n)))
6053a977deeSAkihiko Odaki #define E1000_TDWBAH_A(_n) (0x0383C + (0x100 * (_n)))
6063a977deeSAkihiko Odaki 
6073a977deeSAkihiko Odaki #define E1000_MTA_A        0x0200
6083a977deeSAkihiko Odaki 
6093a977deeSAkihiko Odaki #define E1000_XDBAL_MASK (~(BIT(5) - 1)) /* TDBAL and RDBAL Registers Mask */
6103a977deeSAkihiko Odaki 
6113a977deeSAkihiko Odaki #define E1000_ICR_MACSEC   0x00000020 /* MACSec */
6123a977deeSAkihiko Odaki #define E1000_ICR_RX0      0x00000040 /* Receiver Overrun */
6133a977deeSAkihiko Odaki #define E1000_ICR_GPI_SDP0 0x00000800 /* General Purpose, SDP0 pin */
6143a977deeSAkihiko Odaki #define E1000_ICR_GPI_SDP1 0x00001000 /* General Purpose, SDP1 pin */
6153a977deeSAkihiko Odaki #define E1000_ICR_GPI_SDP2 0x00002000 /* General Purpose, SDP2 pin */
6163a977deeSAkihiko Odaki #define E1000_ICR_GPI_SDP3 0x00004000 /* General Purpose, SDP3 pin */
6173a977deeSAkihiko Odaki #define E1000_ICR_PTRAP    0x00008000 /* Probe Trap */
6183a977deeSAkihiko Odaki #define E1000_ICR_MNG      0x00040000 /* Management Event */
6193a977deeSAkihiko Odaki #define E1000_ICR_OMED     0x00100000 /* Other Media Energy Detected */
6203a977deeSAkihiko Odaki #define E1000_ICR_FER      0x00400000 /* Fatal Error */
6213a977deeSAkihiko Odaki #define E1000_ICR_NFER     0x00800000 /* Non Fatal Error */
6223a977deeSAkihiko Odaki #define E1000_ICR_CSRTO    0x01000000 /* CSR access Time Out Indication */
6233a977deeSAkihiko Odaki #define E1000_ICR_SCE      0x02000000 /* Storm Control Event */
6243a977deeSAkihiko Odaki #define E1000_ICR_SW_WD    0x04000000 /* Software Watchdog */
6253a977deeSAkihiko Odaki 
6263a977deeSAkihiko Odaki /* Extended Interrupts */
6273a977deeSAkihiko Odaki 
6283a977deeSAkihiko Odaki #define E1000_EICR_MSIX_MASK   0x01FFFFFF /* Bits used in MSI-X mode */
6293a977deeSAkihiko Odaki #define E1000_EICR_LEGACY_MASK 0x4000FFFF /* Bits used in non MSI-X mode */
6303a977deeSAkihiko Odaki 
6313a977deeSAkihiko Odaki /* Mirror VF Control (only RST bit); RW */
6323a977deeSAkihiko Odaki #define E1000_PVTCTRL(_n) (0x10000 + (_n) * 0x100)
6333a977deeSAkihiko Odaki 
6343a977deeSAkihiko Odaki /* Mirror Good Packets Received Count; RO */
6353a977deeSAkihiko Odaki #define E1000_PVFGPRC(_n) (0x10010 + (_n) * 0x100)
6363a977deeSAkihiko Odaki 
6373a977deeSAkihiko Odaki /* Mirror Good Packets Transmitted Count; RO */
6383a977deeSAkihiko Odaki #define E1000_PVFGPTC(_n) (0x10014 + (_n) * 0x100)
6393a977deeSAkihiko Odaki 
6403a977deeSAkihiko Odaki /* Mirror Good Octets Received Count; RO */
6413a977deeSAkihiko Odaki #define E1000_PVFGORC(_n) (0x10018 + (_n) * 0x100)
6423a977deeSAkihiko Odaki 
6433a977deeSAkihiko Odaki /* Mirror Extended Interrupt Cause Set; WO */
6443a977deeSAkihiko Odaki #define E1000_PVTEICS(_n) (0x10020 + (_n) * 0x100)
6453a977deeSAkihiko Odaki 
6463a977deeSAkihiko Odaki /* Mirror Extended Interrupt Mask Set/Read; RW */
6473a977deeSAkihiko Odaki #define E1000_PVTEIMS(_n) (0x10024 + (_n) * 0x100)
6483a977deeSAkihiko Odaki 
6493a977deeSAkihiko Odaki /* Mirror Extended Interrupt Mask Clear; WO */
6503a977deeSAkihiko Odaki #define E1000_PVTEIMC(_n) (0x10028 + (_n) * 0x100)
6513a977deeSAkihiko Odaki 
6523a977deeSAkihiko Odaki /* Mirror Extended Interrupt Auto Clear; RW */
6533a977deeSAkihiko Odaki #define E1000_PVTEIAC(_n) (0x1002C + (_n) * 0x100)
6543a977deeSAkihiko Odaki 
6553a977deeSAkihiko Odaki /* Mirror Extended Interrupt Auto Mask Enable; RW */
6563a977deeSAkihiko Odaki #define E1000_PVTEIAM(_n) (0x10030 + (_n) * 0x100)
6573a977deeSAkihiko Odaki 
6583a977deeSAkihiko Odaki /* Mirror Good Octets Transmitted Count; RO */
6593a977deeSAkihiko Odaki #define E1000_PVFGOTC(_n) (0x10034 + (_n) * 0x100)
6603a977deeSAkihiko Odaki 
6613a977deeSAkihiko Odaki /* Mirror Multicast Packets Received Count; RO */
6623a977deeSAkihiko Odaki #define E1000_PVFMPRC(_n) (0x1003C + (_n) * 0x100)
6633a977deeSAkihiko Odaki 
6643a977deeSAkihiko Odaki /* Mirror Good RX Packets loopback Count; RO */
6653a977deeSAkihiko Odaki #define E1000_PVFGPRLBC(_n) (0x10040 + (_n) * 0x100)
6663a977deeSAkihiko Odaki 
6673a977deeSAkihiko Odaki /* Mirror Good TX packets loopback Count; RO */
6683a977deeSAkihiko Odaki #define E1000_PVFGPTLBC(_n) (0x10044 + (_n) * 0x100)
6693a977deeSAkihiko Odaki 
6703a977deeSAkihiko Odaki /* Mirror Good RX Octets loopback Count; RO */
6713a977deeSAkihiko Odaki #define E1000_PVFGORLBC(_n) (0x10048 + (_n) * 0x100)
6723a977deeSAkihiko Odaki 
6733a977deeSAkihiko Odaki /* Mirror Good TX Octets loopback Count; RO */
6743a977deeSAkihiko Odaki #define E1000_PVFGOTLBC(_n) (0x10050 + (_n) * 0x100)
6753a977deeSAkihiko Odaki 
6763a977deeSAkihiko Odaki /* Mirror Extended Interrupt Cause Set; RC/W1C */
6773a977deeSAkihiko Odaki #define E1000_PVTEICR(_n) (0x10080 + (_n) * 0x100)
6783a977deeSAkihiko Odaki 
6793a977deeSAkihiko Odaki /*
6803a977deeSAkihiko Odaki  * These are fake addresses that, according to the specification, the device
6813a977deeSAkihiko Odaki  * is not using. They are used to distinguish between the PF and the VFs
6823a977deeSAkihiko Odaki  * accessing their VTIVAR register (which is the same address, 0x1700)
6833a977deeSAkihiko Odaki  */
6843a977deeSAkihiko Odaki #define E1000_VTIVAR      0x11700
6853a977deeSAkihiko Odaki #define E1000_VTIVAR_MISC 0x11720
6863a977deeSAkihiko Odaki 
6873a977deeSAkihiko Odaki #define E1000_RSS_QUEUE(reta, hash) (E1000_RETA_VAL(reta, hash) & 0x0F)
6883a977deeSAkihiko Odaki 
689abc9a29dSAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV4UDP 7
690abc9a29dSAkihiko Odaki #define E1000_MRQ_RSS_TYPE_IPV6UDP 8
691abc9a29dSAkihiko Odaki 
6923a977deeSAkihiko Odaki #define E1000_STATUS_IOV_MODE 0x00040000
6933a977deeSAkihiko Odaki 
6943a977deeSAkihiko Odaki #define E1000_STATUS_NUM_VFS_SHIFT 14
6953a977deeSAkihiko Odaki 
696ec82ad7cSTomasz Dzieciol #define E1000_ADVRXD_PKT_IP4  BIT(0)
697ec82ad7cSTomasz Dzieciol #define E1000_ADVRXD_PKT_IP6  BIT(2)
6981c4e67a5STomasz Dzieciol #define E1000_ADVRXD_PKT_IP6E BIT(3)
699ec82ad7cSTomasz Dzieciol #define E1000_ADVRXD_PKT_TCP  BIT(4)
700ec82ad7cSTomasz Dzieciol #define E1000_ADVRXD_PKT_UDP  BIT(5)
701ec82ad7cSTomasz Dzieciol #define E1000_ADVRXD_PKT_SCTP BIT(6)
702ed447c60SAkihiko Odaki 
703560cf339STomasz Dzieciol #define IGB_MAX_PS_BUFFERS 2
704560cf339STomasz Dzieciol 
705560cf339STomasz Dzieciol #define E1000_ADVRXD_HDR_LEN_OFFSET    (21 - 16)
706560cf339STomasz Dzieciol #define E1000_ADVRXD_ADV_HDR_LEN_MASK  ((BIT(10) - 1) << \
707560cf339STomasz Dzieciol                                         E1000_ADVRXD_HDR_LEN_OFFSET)
708560cf339STomasz Dzieciol #define E1000_ADVRXD_HDR_SPH           BIT(15)
709560cf339STomasz Dzieciol #define E1000_ADVRXD_ST_ERR_HBO_OFFSET BIT(3 + 20)
710560cf339STomasz Dzieciol 
igb_ivar_entry_rx(uint8_t i)7113a977deeSAkihiko Odaki static inline uint8_t igb_ivar_entry_rx(uint8_t i)
7123a977deeSAkihiko Odaki {
7133a977deeSAkihiko Odaki     return i < 8 ? i * 4 : (i - 8) * 4 + 2;
7143a977deeSAkihiko Odaki }
7153a977deeSAkihiko Odaki 
igb_ivar_entry_tx(uint8_t i)7163a977deeSAkihiko Odaki static inline uint8_t igb_ivar_entry_tx(uint8_t i)
7173a977deeSAkihiko Odaki {
7183a977deeSAkihiko Odaki     return i < 8 ? i * 4 + 1 : (i - 8) * 4 + 3;
7193a977deeSAkihiko Odaki }
7203a977deeSAkihiko Odaki 
7213a977deeSAkihiko Odaki #endif
722