Print this page
    
2038 Add in I350 and ET2 support into igb
Reviewed by: Dan McDonald <danmcd@nexenta.com>
    
      
        | Split | 
	Close | 
      
      | Expand all | 
      | Collapse all | 
    
    
          --- old/usr/src/uts/common/io/igb/igb_82575.h
          +++ new/usr/src/uts/common/io/igb/igb_82575.h
   1    1  /*
   2    2   * CDDL HEADER START
   3    3   *
   4    4   * The contents of this file are subject to the terms of the
   5    5   * Common Development and Distribution License (the "License").
   6    6   * You may not use this file except in compliance with the License.
   7    7   *
   8    8   * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9    9   * or http://www.opensolaris.org/os/licensing.
  10   10   * See the License for the specific language governing permissions
  11   11   * and limitations under the License.
  12   12   *
  
    | 
      ↓ open down ↓ | 
    12 lines elided | 
    
      ↑ open up ↑ | 
  
  13   13   * When distributing Covered Code, include this CDDL HEADER in each
  14   14   * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15   15   * If applicable, add the following below this CDDL HEADER, with the
  16   16   * fields enclosed by brackets "[]" replaced with your own identifying
  17   17   * information: Portions Copyright [yyyy] [name of copyright owner]
  18   18   *
  19   19   * CDDL HEADER END
  20   20   */
  21   21  
  22   22  /*
  23      - * Copyright(c) 2007-2010 Intel Corporation. All rights reserved.
       23 + * Copyright (c) 2007-2012 Intel Corporation. All rights reserved.
  24   24   */
  25   25  
  26   26  /*
  27   27   * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
  28   28   */
  29   29  
  30   30  /* IntelVersion: 1.88.2.1 v3_3_14_3_BHSW1 */
  31   31  
  32   32  #ifndef _IGB_82575_H
  33   33  #define _IGB_82575_H
  34   34  
  35   35  #ifdef __cplusplus
  36   36  extern "C" {
  37   37  #endif
  38   38  
  39   39  #define ID_LED_DEFAULT_82575_SERDES     ((ID_LED_DEF1_DEF2 << 12) | \
  40   40                                          (ID_LED_DEF1_DEF2 <<  8) | \
  41   41                                          (ID_LED_DEF1_DEF2 <<  4) | \
  42   42                                          (ID_LED_OFF1_ON2))
  43   43  
  44   44  /*
  45   45   * Receive Address Register Count
  46   46   * Number of high/low register pairs in the RAR.  The RAR (Receive Address
  
    | 
      ↓ open down ↓ | 
    13 lines elided | 
    
      ↑ open up ↑ | 
  
  47   47   * Registers) holds the directed and multicast addresses that we monitor.
  48   48   * These entries are also used for MAC-based filtering.
  49   49   */
  50   50  /*
  51   51   * For 82576, there are an additional set of RARs that begin at an offset
  52   52   * separate from the first set of RARs.
  53   53   */
  54   54  #define E1000_RAR_ENTRIES_82575         16
  55   55  #define E1000_RAR_ENTRIES_82576         24
  56   56  #define E1000_RAR_ENTRIES_82580         24
       57 +#define E1000_RAR_ENTRIES_I350          32
  57   58  #define E1000_SW_SYNCH_MB               0x00000100
  58   59  #define E1000_STAT_DEV_RST_SET          0x00100000
  59   60  #define E1000_CTRL_DEV_RST              0x20000000
  60   61  
  61   62  #ifdef E1000_BIT_FIELDS
  62   63  struct e1000_adv_data_desc {
  63   64          __le64 buffer_addr;     /* Address of the descriptor's data buffer */
  64   65          union {
  65   66                  u32 data;
  66   67                  struct {
  67   68                          u32 datalen     :16;    /* Data buffer length */
  68   69                          u32 rsvd        :4;
  69   70                          u32 dtyp        :4;     /* Descriptor type */
  70   71                          u32 dcmd        :8;     /* Descriptor command */
  71   72                  } config;
  72   73          } lower;
  73   74          union {
  74   75                  u32 data;
  75   76                  struct {
  76   77                          u32 status      :4;     /* Descriptor status */
  77   78                          u32 idx         :4;
  78   79                          u32 popts       :6;     /* Packet Options */
  79   80                          u32 paylen      :18;    /* Payload length */
  80   81                  } options;
  81   82          } upper;
  82   83  };
  83   84  
  84   85  #define E1000_TXD_DTYP_ADV_C    0x2     /* Advanced Context Descriptor */
  85   86  #define E1000_TXD_DTYP_ADV_D    0x3     /* Advanced Data Descriptor */
  86   87  #define E1000_ADV_TXD_CMD_DEXT  0x20    /* Descriptor extension (0 = legacy) */
  87   88  #define E1000_ADV_TUCMD_IPV4    0x2     /* IP Packet Type: 1=IPv4 */
  88   89  #define E1000_ADV_TUCMD_IPV6    0x0     /* IP Packet Type: 0=IPv6 */
  89   90  #define E1000_ADV_TUCMD_L4T_UDP 0x0     /* L4 Packet TYPE of UDP */
  90   91  #define E1000_ADV_TUCMD_L4T_TCP 0x4     /* L4 Packet TYPE of TCP */
  91   92  #define E1000_ADV_TUCMD_MKRREQ  0x10    /* Indicates markers are required */
  92   93  #define E1000_ADV_DCMD_EOP      0x1     /* End of Packet */
  93   94  #define E1000_ADV_DCMD_IFCS     0x2     /* Insert FCS (Ethernet CRC) */
  94   95  #define E1000_ADV_DCMD_RS       0x8     /* Report Status */
  95   96  #define E1000_ADV_DCMD_VLE      0x40    /* Add VLAN tag */
  96   97  #define E1000_ADV_DCMD_TSE      0x80    /* TCP Seg enable */
  97   98  /* Extended Device Control */
  98   99  #define E1000_CTRL_EXT_NSICR    0x00000001 /* Disable Intr Clear all on read */
  99  100  
 100  101  struct e1000_adv_context_desc {
 101  102          union {
 102  103                  u32 ip_config;
 103  104                  struct {
 104  105                          u32 iplen       :9;
 105  106                          u32 maclen      :7;
 106  107                          u32 vlan_tag    :16;
 107  108                  } fields;
 108  109          } ip_setup;
 109  110          u32 seq_num;
 110  111          union {
 111  112                  u64 l4_config;
 112  113                  struct {
 113  114                          u32 mkrloc      :9;
 114  115                          u32 tucmd       :11;
 115  116                          u32 dtyp        :4;
 116  117                          u32 adv         :8;
 117  118                          u32 rsvd        :4;
 118  119                          u32 idx         :4;
 119  120                          u32 l4len       :8;
 120  121                          u32 mss         :16;
 121  122                  } fields;
 122  123          } l4_setup;
 123  124  };
 124  125  #endif
 125  126  
 126  127  /* SRRCTL bit definitions */
 127  128  #define E1000_SRRCTL_BSIZEPKT_SHIFT                     10 /* Shift _right_ */
 128  129  #define E1000_SRRCTL_BSIZEHDRSIZE_MASK                  0x00000F00
 129  130  #define E1000_SRRCTL_BSIZEHDRSIZE_SHIFT                 2 /* Shift _left_ */
 130  131  #define E1000_SRRCTL_DESCTYPE_LEGACY                    0x00000000
 131  132  #define E1000_SRRCTL_DESCTYPE_ADV_ONEBUF                0x02000000
 132  133  #define E1000_SRRCTL_DESCTYPE_HDR_SPLIT                 0x04000000
 133  134  #define E1000_SRRCTL_DESCTYPE_HDR_SPLIT_ALWAYS          0x0A000000
 134  135  #define E1000_SRRCTL_DESCTYPE_HDR_REPLICATION           0x06000000
 135  136  #define E1000_SRRCTL_DESCTYPE_HDR_REPLICATION_LARGE_PKT 0x08000000
 136  137  #define E1000_SRRCTL_DESCTYPE_MASK                      0x0E000000
 137  138  #define E1000_SRRCTL_TIMESTAMP                          0x40000000
 138  139  #define E1000_SRRCTL_DROP_EN                            0x80000000
 139  140  
 140  141  #define E1000_SRRCTL_BSIZEPKT_MASK      0x0000007F
 141  142  #define E1000_SRRCTL_BSIZEHDR_MASK      0x00003F00
 142  143  
 143  144  #define E1000_TX_HEAD_WB_ENABLE         0x1
 144  145  #define E1000_TX_SEQNUM_WB_ENABLE       0x2
 145  146  
 146  147  #define E1000_MRQC_ENABLE_RSS_4Q                0x00000002
 147  148  #define E1000_MRQC_ENABLE_VMDQ                  0x00000003
 148  149  #define E1000_MRQC_ENABLE_VMDQ_RSS_2Q           0x80000000
 149  150  #define E1000_MRQC_RSS_FIELD_IPV4_UDP           0x00400000
 150  151  #define E1000_MRQC_RSS_FIELD_IPV6_UDP           0x00800000
 151  152  #define E1000_MRQC_RSS_FIELD_IPV6_UDP_EX        0x01000000
 152  153  #define E1000_MRQC_ENABLE_RSS_8Q                0x00000002
 153  154  
 154  155  #define E1000_VMRCTL_MIRROR_PORT_SHIFT          8
 155  156  #define E1000_VMRCTL_MIRROR_DSTPORT_MASK (7 << E1000_VMRCTL_MIRROR_PORT_SHIFT)
 156  157  #define E1000_VMRCTL_POOL_MIRROR_ENABLE         (1 << 0)
 157  158  #define E1000_VMRCTL_UPLINK_MIRROR_ENABLE       (1 << 1)
 158  159  #define E1000_VMRCTL_DOWNLINK_MIRROR_ENABLE     (1 << 2)
 159  160  
 160  161  #define E1000_EICR_TX_QUEUE ( \
 161  162      E1000_EICR_TX_QUEUE0 |    \
 162  163      E1000_EICR_TX_QUEUE1 |    \
 163  164      E1000_EICR_TX_QUEUE2 |    \
 164  165      E1000_EICR_TX_QUEUE3)
 165  166  
 166  167  #define E1000_EICR_RX_QUEUE ( \
 167  168      E1000_EICR_RX_QUEUE0 |    \
 168  169      E1000_EICR_RX_QUEUE1 |    \
 169  170      E1000_EICR_RX_QUEUE2 |    \
 170  171      E1000_EICR_RX_QUEUE3)
 171  172  
 172  173  #define E1000_EIMS_RX_QUEUE E1000_EICR_RX_QUEUE
 173  174  #define E1000_EIMS_TX_QUEUE E1000_EICR_TX_QUEUE
 174  175  
 175  176  #define EIMS_ENABLE_MASK ( \
 176  177      E1000_EIMS_RX_QUEUE  | \
 177  178      E1000_EIMS_TX_QUEUE  | \
 178  179      E1000_EIMS_TCP_TIMER | \
 179  180      E1000_EIMS_OTHER)
 180  181  
 181  182  /* Immediate Interrupt Rx (A.K.A. Low Latency Interrupt) */
 182  183  #define E1000_IMIR_PORT_IM_EN   0x00010000      /* TCP port enable */
 183  184  #define E1000_IMIR_PORT_BP      0x00020000      /* TCP port check bypass */
 184  185  #define E1000_IMIREXT_SIZE_BP   0x00001000      /* Packet size bypass */
 185  186  #define E1000_IMIREXT_CTRL_URG  0x00002000      /* Check URG bit in header */
 186  187  #define E1000_IMIREXT_CTRL_ACK  0x00004000      /* Check ACK bit in header */
 187  188  #define E1000_IMIREXT_CTRL_PSH  0x00008000      /* Check PSH bit in header */
 188  189  #define E1000_IMIREXT_CTRL_RST  0x00010000      /* Check RST bit in header */
 189  190  #define E1000_IMIREXT_CTRL_SYN  0x00020000      /* Check SYN bit in header */
 190  191  #define E1000_IMIREXT_CTRL_FIN  0x00040000      /* Check FIN bit in header */
 191  192  #define E1000_IMIREXT_CTRL_BP   0x00080000      /* Bypass check of ctrl bits */
 192  193  
 193  194  /* Receive Descriptor - Advanced */
 194  195  union e1000_adv_rx_desc {
 195  196          struct {
 196  197                  __le64 pkt_addr;        /* Packet buffer address */
 197  198                  __le64 hdr_addr;        /* Header buffer address */
 198  199          } read;
 199  200          struct {
 200  201                  struct {
 201  202                          union {
 202  203                                  __le32 data;
 203  204                                  struct {
 204  205                                          /* RSS type, Packet type */
 205  206                                          __le16 pkt_info;
 206  207                                          /* Split Header, header buffer length */
 207  208                                          __le16 hdr_info;
 208  209                                  } hs_rss;
 209  210                          } lo_dword;
 210  211                          union {
 211  212                                  __le32 rss;     /* RSS Hash */
 212  213                                  struct {
 213  214                                          __le16 ip_id;   /* IP id */
 214  215                                          __le16 csum;    /* Packet Checksum */
 215  216                                  } csum_ip;
 216  217                          } hi_dword;
 217  218                  } lower;
 218  219                  struct {
 219  220                          __le32 status_error;    /* ext status/error */
 220  221                          __le16 length;          /* Packet length */
 221  222                          __le16 vlan;            /* VLAN tag */
 222  223                  } upper;
 223  224          } wb;           /* writeback */
 224  225  };
 225  226  
 226  227  #define E1000_RXDADV_RSSTYPE_MASK       0x0000000F
 227  228  #define E1000_RXDADV_RSSTYPE_SHIFT      12
 228  229  #define E1000_RXDADV_HDRBUFLEN_MASK     0x7FE0
 229  230  #define E1000_RXDADV_HDRBUFLEN_SHIFT    5
 230  231  #define E1000_RXDADV_SPLITHEADER_EN     0x00001000
 231  232  #define E1000_RXDADV_SPH                0x8000
 232  233  #define E1000_RXDADV_STAT_TS            0x10000 /* Pkt was time stamped */
 233  234  #define E1000_RXDADV_STAT_TSIP          0x08000 /* timestamp in packet */
 234  235  #define E1000_RXDADV_ERR_HBO            0x00800000
 235  236  
 236  237  /* RSS Hash results */
 237  238  #define E1000_RXDADV_RSSTYPE_NONE       0x00000000
 238  239  #define E1000_RXDADV_RSSTYPE_IPV4_TCP   0x00000001
 239  240  #define E1000_RXDADV_RSSTYPE_IPV4       0x00000002
 240  241  #define E1000_RXDADV_RSSTYPE_IPV6_TCP   0x00000003
 241  242  #define E1000_RXDADV_RSSTYPE_IPV6_EX    0x00000004
 242  243  #define E1000_RXDADV_RSSTYPE_IPV6       0x00000005
 243  244  #define E1000_RXDADV_RSSTYPE_IPV6_TCP_EX 0x00000006
 244  245  #define E1000_RXDADV_RSSTYPE_IPV4_UDP   0x00000007
 245  246  #define E1000_RXDADV_RSSTYPE_IPV6_UDP   0x00000008
 246  247  #define E1000_RXDADV_RSSTYPE_IPV6_UDP_EX 0x00000009
 247  248  
 248  249  /* RSS Packet Types as indicated in the receive descriptor */
 249  250  #define E1000_RXDADV_PKTTYPE_NONE       0x00000000
 250  251  #define E1000_RXDADV_PKTTYPE_IPV4       0x00000010 /* IPV4 hdr present */
 251  252  #define E1000_RXDADV_PKTTYPE_IPV4_EX    0x00000020 /* IPV4 hdr + extensions */
 252  253  #define E1000_RXDADV_PKTTYPE_IPV6       0x00000040 /* IPV6 hdr present */
 253  254  #define E1000_RXDADV_PKTTYPE_IPV6_EX    0x00000080 /* IPV6 hdr + extensions */
 254  255  #define E1000_RXDADV_PKTTYPE_TCP        0x00000100 /* TCP hdr present */
 255  256  #define E1000_RXDADV_PKTTYPE_UDP        0x00000200 /* UDP hdr present */
 256  257  #define E1000_RXDADV_PKTTYPE_SCTP       0x00000400 /* SCTP hdr present */
 257  258  #define E1000_RXDADV_PKTTYPE_NFS        0x00000800 /* NFS hdr present */
 258  259  
 259  260  #define E1000_RXDADV_PKTTYPE_IPSEC_ESP  0x00001000 /* IPSec ESP */
 260  261  #define E1000_RXDADV_PKTTYPE_IPSEC_AH   0x00002000 /* IPSec AH */
 261  262  #define E1000_RXDADV_PKTTYPE_LINKSEC    0x00004000 /* LinkSec Encap */
 262  263  #define E1000_RXDADV_PKTTYPE_ETQF       0x00008000 /* PKTTYPE is ETQF index */
 263  264  #define E1000_RXDADV_PKTTYPE_ETQF_MASK  0x00000070 /* ETQF has 8 indices */
 264  265  #define E1000_RXDADV_PKTTYPE_ETQF_SHIFT 4 /* Right-shift 4 bits */
 265  266  
 266  267  /* LinkSec results */
 267  268  /* Security Processing bit Indication */
 268  269  #define E1000_RXDADV_LNKSEC_STATUS_SECP         0x00020000
 269  270  #define E1000_RXDADV_LNKSEC_ERROR_BIT_MASK      0x18000000
 270  271  #define E1000_RXDADV_LNKSEC_ERROR_NO_SA_MATCH   0x08000000
 271  272  #define E1000_RXDADV_LNKSEC_ERROR_REPLAY_ERROR  0x10000000
 272  273  #define E1000_RXDADV_LNKSEC_ERROR_BAD_SIG       0x18000000
 273  274  
 274  275  #define E1000_RXDADV_IPSEC_STATUS_SECP          0x00020000
 275  276  #define E1000_RXDADV_IPSEC_ERROR_BIT_MASK       0x18000000
 276  277  #define E1000_RXDADV_IPSEC_ERROR_INVALID_PROTOCOL       0x08000000
 277  278  #define E1000_RXDADV_IPSEC_ERROR_INVALID_LENGTH         0x10000000
 278  279  #define E1000_RXDADV_IPSEC_ERROR_AUTHENTICATION_FAILED  0x18000000
 279  280  
 280  281  /* Transmit Descriptor - Advanced */
 281  282  union e1000_adv_tx_desc {
 282  283          struct {
 283  284                  __le64 buffer_addr;     /* Address of descriptor's data buf */
 284  285                  __le32 cmd_type_len;
 285  286                  __le32 olinfo_status;
 286  287          } read;
 287  288          struct {
 288  289                  __le64 rsvd;    /* Reserved */
 289  290                  __le32 nxtseq_seed;
 290  291                  __le32 status;
 291  292          } wb;
 292  293  };
 293  294  
 294  295  /* Adv Transmit Descriptor Config Masks */
 295  296  #define E1000_ADVTXD_DTYP_CTXT  0x00200000 /* Advanced Context Descriptor */
 296  297  #define E1000_ADVTXD_DTYP_DATA  0x00300000 /* Advanced Data Descriptor */
 297  298  #define E1000_ADVTXD_DCMD_EOP   0x01000000 /* End of Packet */
 298  299  #define E1000_ADVTXD_DCMD_IFCS  0x02000000 /* Insert FCS (Ethernet CRC) */
 299  300  #define E1000_ADVTXD_DCMD_RS    0x08000000 /* Report Status */
 300  301  #define E1000_ADVTXD_DCMD_DDTYP_ISCSI 0x10000000 /* DDP hdr type or iSCSI */
 301  302  #define E1000_ADVTXD_DCMD_DEXT  0x20000000 /* Descriptor extension (1=Adv) */
 302  303  #define E1000_ADVTXD_DCMD_VLE   0x40000000 /* VLAN pkt enable */
 303  304  #define E1000_ADVTXD_DCMD_TSE   0x80000000 /* TCP Seg enable */
 304  305  #define E1000_ADVTXD_MAC_LINKSEC 0x00040000 /* Apply LinkSec on packet */
 305  306  #define E1000_ADVTXD_MAC_TSTAMP 0x00080000 /* IEEE1588 Timestamp packet */
 306  307  #define E1000_ADVTXD_STAT_SN_CRC 0x00000002 /* NXTSEQ/SEED present in WB */
 307  308  #define E1000_ADVTXD_IDX_SHIFT  4       /* Adv desc Index shift */
 308  309  #define E1000_ADVTXD_POPTS_ISCO_1ST     0x00000000 /* 1st TSO of iSCSI PDU */
 309  310  #define E1000_ADVTXD_POPTS_ISCO_MDL     0x00000800 /* Middle TSO of iSCSI PDU */
 310  311  #define E1000_ADVTXD_POPTS_ISCO_LAST    0x00001000 /* Last TSO of iSCSI PDU */
 311  312  /* 1st&Last TSO-full iSCSI PDU */
 312  313  #define E1000_ADVTXD_POPTS_ISCO_FULL    0x00001800
 313  314  #define E1000_ADVTXD_POPTS_IPSEC        0x00000400 /* IPSec offload request */
 314  315  #define E1000_ADVTXD_PAYLEN_SHIFT       14      /* Adv desc PAYLEN shift */
 315  316  
 316  317  /* Context descriptors */
 317  318  struct e1000_adv_tx_context_desc {
 318  319          __le32 vlan_macip_lens;
 319  320          __le32 seqnum_seed;
 320  321          __le32 type_tucmd_mlhl;
 321  322          __le32 mss_l4len_idx;
 322  323  };
 323  324  
 324  325  #define E1000_ADVTXD_MACLEN_SHIFT       9 /* Adv ctxt desc mac len shift */
 325  326  #define E1000_ADVTXD_VLAN_SHIFT         16 /* Adv ctxt vlan tag shift */
 326  327  #define E1000_ADVTXD_TUCMD_IPV4         0x00000400 /* IP Packet Type: 1=IPv4 */
 327  328  #define E1000_ADVTXD_TUCMD_IPV6         0x00000000 /* IP Packet Type: 0=IPv6 */
 328  329  #define E1000_ADVTXD_TUCMD_L4T_UDP      0x00000000 /* L4 Packet TYPE of UDP */
 329  330  #define E1000_ADVTXD_TUCMD_L4T_TCP      0x00000800 /* L4 Packet TYPE of TCP */
 330  331  #define E1000_ADVTXD_TUCMD_L4T_SCTP     0x00001000 /* L4 Packet TYPE of SCTP */
 331  332  #define E1000_ADVTXD_TUCMD_IPSEC_TYPE_ESP       0x00002000 /* IPSec Type ESP */
 332  333  /* IPSec Encrypt Enable for ESP */
 333  334  #define E1000_ADVTXD_TUCMD_IPSEC_ENCRYPT_EN     0x00004000
 334  335  /* Req requires Markers and CRC */
 335  336  #define E1000_ADVTXD_TUCMD_MKRREQ       0x00002000
 336  337  #define E1000_ADVTXD_L4LEN_SHIFT        8       /* Adv ctxt L4LEN shift */
 337  338  #define E1000_ADVTXD_MSS_SHIFT          16      /* Adv ctxt MSS shift */
 338  339  /* Adv ctxt IPSec SA IDX mask */
 339  340  #define E1000_ADVTXD_IPSEC_SA_INDEX_MASK        0x000000FF
 340  341  /* Adv ctxt IPSec ESP len mask */
 341  342  #define E1000_ADVTXD_IPSEC_ESP_LEN_MASK         0x000000FF
 342  343  
 343  344  /* Additional Transmit Descriptor Control definitions */
 344  345  /* Enable specific Tx Queue */
 345  346  #define E1000_TXDCTL_QUEUE_ENABLE       0x02000000
 346  347  /* Tx Desc. write-back flushing */
 347  348  #define E1000_TXDCTL_SWFLSH             0x04000000
 348  349  /* Tx Queue Arbitration Priority 0=low, 1=high */
 349  350  #define E1000_TXDCTL_PRIORITY           0x08000000
 350  351  
 351  352  /* Additional Receive Descriptor Control definitions */
 352  353  /* Enable specific Rx Queue */
 353  354  #define E1000_RXDCTL_QUEUE_ENABLE       0x02000000
 354  355  /* Rx Desc. write-back flushing */
 355  356  #define E1000_RXDCTL_SWFLSH             0x04000000
 356  357  
 357  358  /* Direct Cache Access (DCA) definitions */
 358  359  #define E1000_DCA_CTRL_DCA_ENABLE       0x00000000      /* DCA Enable */
 359  360  #define E1000_DCA_CTRL_DCA_DISABLE      0x00000001      /* DCA Disable */
 360  361  
 361  362  #define E1000_DCA_CTRL_DCA_MODE_CB1     0x00    /* DCA Mode CB1 */
 362  363  #define E1000_DCA_CTRL_DCA_MODE_CB2     0x02    /* DCA Mode CB2 */
 363  364  
 364  365  #define E1000_DCA_RXCTRL_CPUID_MASK 0x0000001F  /* Rx CPUID Mask */
 365  366  #define E1000_DCA_RXCTRL_DESC_DCA_EN (1 << 5) /* DCA Rx Desc enable */
 366  367  #define E1000_DCA_RXCTRL_HEAD_DCA_EN (1 << 6) /* DCA Rx Desc header enable */
 367  368  #define E1000_DCA_RXCTRL_DATA_DCA_EN (1 << 7) /* DCA Rx Desc payload enable */
 368  369  
 369  370  #define E1000_DCA_TXCTRL_CPUID_MASK 0x0000001F  /* Tx CPUID Mask */
 370  371  #define E1000_DCA_TXCTRL_DESC_DCA_EN (1 << 5)   /* DCA Tx Desc enable */
 371  372  #define E1000_DCA_TXCTRL_TX_WB_RO_EN (1 << 11)  /* Tx Desc writeback RO bit */
 372  373  
 373  374  #define E1000_DCA_TXCTRL_CPUID_MASK_82576 0xFF000000 /* Tx CPUID Mask */
 374  375  #define E1000_DCA_RXCTRL_CPUID_MASK_82576 0xFF000000 /* Rx CPUID Mask */
 375  376  #define E1000_DCA_TXCTRL_CPUID_SHIFT_82576 24 /* Tx CPUID */
 376  377  #define E1000_DCA_RXCTRL_CPUID_SHIFT_82576 24 /* Rx CPUID */
 377  378  
 378  379  /* Additional interrupt register bit definitions */
 379  380  #define E1000_ICR_LSECPNS       0x00000020      /* PN threshold - server */
 380  381  #define E1000_IMS_LSECPNS       E1000_ICR_LSECPNS /* PN threshold - server */
 381  382  #define E1000_ICS_LSECPNS       E1000_ICR_LSECPNS /* PN threshold - server */
 382  383  
 383  384  /* ETQF register bit definitions */
 384  385  #define E1000_ETQF_FILTER_ENABLE        (1 << 26)
 385  386  #define E1000_ETQF_IMM_INT              (1 << 29)
 386  387  #define E1000_ETQF_1588                 (1 << 30)
 387  388  #define E1000_ETQF_QUEUE_ENABLE         (1 << 31)
 388  389  /*
 389  390   * ETQF filter list: one static filter per filter consumer. This is
 390  391   *              to avoid filter collisions later. Add new filters
 391  392   *              here!!
 392  393   *
 393  394   * Current filters:
 394  395   *    EAPOL 802.1x (0x888e): Filter 0
 395  396   */
 396  397  #define E1000_ETQF_FILTER_EAPOL         0
 397  398  
 398  399  #define E1000_FTQF_VF_BP                0x00008000
 399  400  #define E1000_FTQF_1588_TIME_STAMP      0x08000000
 400  401  #define E1000_FTQF_MASK                 0xF0000000
 401  402  #define E1000_FTQF_MASK_PROTO_BP        0x10000000
 402  403  #define E1000_FTQF_MASK_SOURCE_ADDR_BP  0x20000000
 403  404  #define E1000_FTQF_MASK_DEST_ADDR_BP    0x40000000
 404  405  #define E1000_FTQF_MASK_SOURCE_PORT_BP  0x80000000
 405  406  
 406  407  #define E1000_NVM_APME_82575            0x0400
 407  408  #define MAX_NUM_VFS                     8
 408  409  
 409  410  /* Per VF MAC spoof control */
 410  411  #define E1000_DTXSWC_MAC_SPOOF_MASK     0x000000FF
 411  412  /* Per VF VLAN spoof control */
 412  413  #define E1000_DTXSWC_VLAN_SPOOF_MASK    0x0000FF00
 413  414  #define E1000_DTXSWC_LLE_MASK           0x00FF0000 /* Per VF Local LB enables */
 414  415  #define E1000_DTXSWC_VLAN_SPOOF_SHIFT   8
 415  416  #define E1000_DTXSWC_LLE_SHIFT          16
 416  417  #define E1000_DTXSWC_VMDQ_LOOPBACK_EN   ((u32)1 << 31) /* global VF LB enable */
 417  418  
 418  419  /* Easy defines for setting default pool, would normally be left a zero */
 419  420  #define E1000_VT_CTL_DEFAULT_POOL_SHIFT 7
 420  421  #define E1000_VT_CTL_DEFAULT_POOL_MASK  (0x7 << E1000_VT_CTL_DEFAULT_POOL_SHIFT)
 421  422  
 422  423  /* Other useful VMD_CTL register defines */
 423  424  #define E1000_VT_CTL_IGNORE_MAC         (1 << 28)
 424  425  #define E1000_VT_CTL_DISABLE_DEF_POOL   (1 << 29)
 425  426  #define E1000_VT_CTL_VM_REPL_EN         (1 << 30)
 426  427  
 427  428  /* Per VM Offload register setup */
 428  429  #define E1000_VMOLR_RLPML_MASK  0x00003FFF /* Long Packet Maximum Length mask */
 429  430  #define E1000_VMOLR_LPE         0x00010000 /* Accept Long packet */
 430  431  #define E1000_VMOLR_RSSE        0x00020000 /* Enable RSS */
 431  432  #define E1000_VMOLR_AUPE        0x01000000 /* Accept untagged packets */
 432  433  #define E1000_VMOLR_ROMPE       0x02000000 /* Accept overflow multicast */
 433  434  #define E1000_VMOLR_ROPE        0x04000000 /* Accept overflow unicast */
 434  435  #define E1000_VMOLR_BAM         0x08000000 /* Accept Broadcast packets */
 435  436  #define E1000_VMOLR_MPME        0x10000000 /* Multicast promiscuous mode */
 436  437  #define E1000_VMOLR_STRVLAN     0x40000000 /* Vlan stripping enable */
 437  438  #define E1000_VMOLR_STRCRC      0x80000000 /* CRC stripping enable */
 438  439  
 439  440  #define E1000_VLVF_ARRAY_SIZE           32
 440  441  #define E1000_VLVF_VLANID_MASK          0x00000FFF
 441  442  #define E1000_VLVF_POOLSEL_SHIFT        12
 442  443  #define E1000_VLVF_POOLSEL_MASK         (0xFF << E1000_VLVF_POOLSEL_SHIFT)
 443  444  #define E1000_VLVF_LVLAN                0x00100000
 444  445  #define E1000_VLVF_VLANID_ENABLE        0x80000000
 445  446  
 446  447  #define E1000_VMVIR_VLANA_DEFAULT 0x40000000 /* Always use default VLAN */
 447  448  #define E1000_VMVIR_VLANA_NEVER   0x80000000 /* Never insert VLAN tag */
 448  449  #define E1000_VF_INIT_TIMEOUT   200 /* Number of retries to clear RSTI */
 449  450  
 450  451  #define E1000_IOVCTL            0x05BBC
 451  452  #define E1000_IOVCTL_REUSE_VFQ  0x00000001
 452  453  
 453  454  #define E1000_RPLOLR_STRVLAN    0x40000000
 454  455  #define E1000_RPLOLR_STRCRC     0x80000000
 455  456  
 456  457  #define E1000_DTXCTL_8023LL     0x0004
 457  458  #define E1000_DTXCTL_VLAN_ADDED 0x0008
 458  459  #define E1000_DTXCTL_OOS_ENABLE 0x0010
  
    | 
      ↓ open down ↓ | 
    392 lines elided | 
    
      ↑ open up ↑ | 
  
 459  460  #define E1000_DTXCTL_MDP_EN     0x0020
 460  461  #define E1000_DTXCTL_SPOOF_INT  0x0040
 461  462  
 462  463  #define ALL_QUEUES              0xFFFF
 463  464  
 464  465  /* RX packet buffer size defines */
 465  466  #define E1000_RXPBS_SIZE_MASK_82576     0x0000007F
 466  467  void e1000_vmdq_set_loopback_pf(struct e1000_hw *hw, bool enable);
 467  468  void e1000_vmdq_set_replication_pf(struct e1000_hw *hw, bool enable);
 468  469  u16 e1000_rxpbs_adjust_82580(u32 data);
      470 +s32 e1000_set_eee_i350(struct e1000_hw *hw);
 469  471  
 470  472  #ifdef __cplusplus
 471  473  }
 472  474  #endif
 473  475  
 474  476  #endif  /* _IGB_82575_H */
    
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX