diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2016-05-17 16:26:30 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-05-17 16:26:30 -0700 | 
| commit | a7fd20d1c476af4563e66865213474a2f9f473a4 (patch) | |
| tree | fb1399e2f82842450245fb058a8fb23c52865f43 /drivers/net/ethernet/intel/i40evf/i40evf.h | |
| parent | b80fed9595513384424cd141923c9161c4b5021b (diff) | |
| parent | 917fa5353da05e8a0045b8acacba8d50400d5b12 (diff) | |
| download | linux-a7fd20d1c476af4563e66865213474a2f9f473a4.tar.bz2 | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next
Pull networking updates from David Miller:
 "Highlights:
   1) Support SPI based w5100 devices, from Akinobu Mita.
   2) Partial Segmentation Offload, from Alexander Duyck.
   3) Add GMAC4 support to stmmac driver, from Alexandre TORGUE.
   4) Allow cls_flower stats offload, from Amir Vadai.
   5) Implement bpf blinding, from Daniel Borkmann.
   6) Optimize _ASYNC_ bit twiddling on sockets, unless the socket is
      actually using FASYNC these atomics are superfluous.  From Eric
      Dumazet.
   7) Run TCP more preemptibly, also from Eric Dumazet.
   8) Support LED blinking, EEPROM dumps, and rxvlan offloading in mlx5e
      driver, from Gal Pressman.
   9) Allow creating ppp devices via rtnetlink, from Guillaume Nault.
  10) Improve BPF usage documentation, from Jesper Dangaard Brouer.
  11) Support tunneling offloads in qed, from Manish Chopra.
  12) aRFS offloading in mlx5e, from Maor Gottlieb.
  13) Add RFS and RPS support to SCTP protocol, from Marcelo Ricardo
      Leitner.
  14) Add MSG_EOR support to TCP, this allows controlling packet
      coalescing on application record boundaries for more accurate
      socket timestamp sampling.  From Martin KaFai Lau.
  15) Fix alignment of 64-bit netlink attributes across the board, from
      Nicolas Dichtel.
  16) Per-vlan stats in bridging, from Nikolay Aleksandrov.
  17) Several conversions of drivers to ethtool ksettings, from Philippe
      Reynes.
  18) Checksum neutral ILA in ipv6, from Tom Herbert.
  19) Factorize all of the various marvell dsa drivers into one, from
      Vivien Didelot
  20) Add VF support to qed driver, from Yuval Mintz"
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next: (1649 commits)
  Revert "phy dp83867: Fix compilation with CONFIG_OF_MDIO=m"
  Revert "phy dp83867: Make rgmii parameters optional"
  r8169: default to 64-bit DMA on recent PCIe chips
  phy dp83867: Make rgmii parameters optional
  phy dp83867: Fix compilation with CONFIG_OF_MDIO=m
  bpf: arm64: remove callee-save registers use for tmp registers
  asix: Fix offset calculation in asix_rx_fixup() causing slow transmissions
  switchdev: pass pointer to fib_info instead of copy
  net_sched: close another race condition in tcf_mirred_release()
  tipc: fix nametable publication field in nl compat
  drivers: net: Don't print unpopulated net_device name
  qed: add support for dcbx.
  ravb: Add missing free_irq() calls to ravb_close()
  qed: Remove a stray tab
  net: ethernet: fec-mpc52xx: use phy_ethtool_{get|set}_link_ksettings
  net: ethernet: fec-mpc52xx: use phydev from struct net_device
  bpf, doc: fix typo on bpf_asm descriptions
  stmmac: hardware TX COE doesn't work when force_thresh_dma_mode is set
  net: ethernet: fs-enet: use phy_ethtool_{get|set}_link_ksettings
  net: ethernet: fs-enet: use phydev from struct net_device
  ...
Diffstat (limited to 'drivers/net/ethernet/intel/i40evf/i40evf.h')
| -rw-r--r-- | drivers/net/ethernet/intel/i40evf/i40evf.h | 49 | 
1 files changed, 33 insertions, 16 deletions
| diff --git a/drivers/net/ethernet/intel/i40evf/i40evf.h b/drivers/net/ethernet/intel/i40evf/i40evf.h index e657eccd232c..76ed97db28e2 100644 --- a/drivers/net/ethernet/intel/i40evf/i40evf.h +++ b/drivers/net/ethernet/intel/i40evf/i40evf.h @@ -67,8 +67,6 @@ struct i40e_vsi {  	u16 rx_itr_setting;  	u16 tx_itr_setting;  	u16 qs_handle; -	u8 *rss_hkey_user; /* User configured hash keys */ -	u8 *rss_lut_user;  /* User configured lookup table entries */  };  /* How many Rx Buffers do we bundle into one write to the hardware ? */ @@ -82,9 +80,6 @@ struct i40e_vsi {  #define I40EVF_REQ_DESCRIPTOR_MULTIPLE  32  /* Supported Rx Buffer Sizes */ -#define I40EVF_RXBUFFER_64    64     /* Used for packet split */ -#define I40EVF_RXBUFFER_128   128    /* Used for packet split */ -#define I40EVF_RXBUFFER_256   256    /* Used for packet split */  #define I40EVF_RXBUFFER_2048  2048  #define I40EVF_MAX_RXBUFFER   16384  /* largest size for single descriptor */  #define I40EVF_MAX_AQ_BUF_SIZE    4096 @@ -210,9 +205,6 @@ struct i40evf_adapter {  	u32 flags;  #define I40EVF_FLAG_RX_CSUM_ENABLED              BIT(0) -#define I40EVF_FLAG_RX_1BUF_CAPABLE              BIT(1) -#define I40EVF_FLAG_RX_PS_CAPABLE                BIT(2) -#define I40EVF_FLAG_RX_PS_ENABLED                BIT(3)  #define I40EVF_FLAG_IMIR_ENABLED                 BIT(5)  #define I40EVF_FLAG_MQ_CAPABLE                   BIT(6)  #define I40EVF_FLAG_NEED_LINK_UPDATE             BIT(7) @@ -222,6 +214,8 @@ struct i40evf_adapter {  #define I40EVF_FLAG_WB_ON_ITR_CAPABLE		BIT(11)  #define I40EVF_FLAG_OUTER_UDP_CSUM_CAPABLE	BIT(12)  #define I40EVF_FLAG_ADDR_SET_BY_PF		BIT(13) +#define I40EVF_FLAG_PROMISC_ON			BIT(15) +#define I40EVF_FLAG_ALLMULTI_ON			BIT(16)  /* duplicates for common code */  #define I40E_FLAG_FDIR_ATR_ENABLED		 0  #define I40E_FLAG_DCB_ENABLED			 0 @@ -239,8 +233,17 @@ struct i40evf_adapter {  #define I40EVF_FLAG_AQ_CONFIGURE_QUEUES		BIT(6)  #define I40EVF_FLAG_AQ_MAP_VECTORS		BIT(7)  #define I40EVF_FLAG_AQ_HANDLE_RESET		BIT(8) -#define I40EVF_FLAG_AQ_CONFIGURE_RSS		BIT(9) +#define I40EVF_FLAG_AQ_CONFIGURE_RSS		BIT(9)	/* direct AQ config */  #define I40EVF_FLAG_AQ_GET_CONFIG		BIT(10) +/* Newer style, RSS done by the PF so we can ignore hardware vagaries. */ +#define I40EVF_FLAG_AQ_GET_HENA			BIT(11) +#define I40EVF_FLAG_AQ_SET_HENA			BIT(12) +#define I40EVF_FLAG_AQ_SET_RSS_KEY		BIT(13) +#define I40EVF_FLAG_AQ_SET_RSS_LUT		BIT(14) +#define I40EVF_FLAG_AQ_REQUEST_PROMISC		BIT(15) +#define I40EVF_FLAG_AQ_RELEASE_PROMISC		BIT(16) +#define I40EVF_FLAG_AQ_REQUEST_ALLMULTI		BIT(17) +#define I40EVF_FLAG_AQ_RELEASE_ALLMULTI		BIT(18)  	/* OS defined structs */  	struct net_device *netdev; @@ -256,10 +259,18 @@ struct i40evf_adapter {  	bool netdev_registered;  	bool link_up;  	enum i40e_virtchnl_ops current_op; -#define CLIENT_ENABLED(_a) ((_a)->vf_res->vf_offload_flags & \ -			    I40E_VIRTCHNL_VF_OFFLOAD_IWARP) +#define CLIENT_ENABLED(_a) ((_a)->vf_res ? \ +			    (_a)->vf_res->vf_offload_flags & \ +				I40E_VIRTCHNL_VF_OFFLOAD_IWARP : \ +			    0) +/* RSS by the PF should be preferred over RSS via other methods. */ +#define RSS_PF(_a) ((_a)->vf_res->vf_offload_flags & \ +		    I40E_VIRTCHNL_VF_OFFLOAD_RSS_PF)  #define RSS_AQ(_a) ((_a)->vf_res->vf_offload_flags & \  		    I40E_VIRTCHNL_VF_OFFLOAD_RSS_AQ) +#define RSS_REG(_a) (!((_a)->vf_res->vf_offload_flags & \ +		       (I40E_VIRTCHNL_VF_OFFLOAD_RSS_AQ | \ +			I40E_VIRTCHNL_VF_OFFLOAD_RSS_PF)))  #define VLAN_ALLOWED(_a) ((_a)->vf_res->vf_offload_flags & \  			  I40E_VIRTCHNL_VF_OFFLOAD_VLAN)  	struct i40e_virtchnl_vf_resource *vf_res; /* incl. all VSIs */ @@ -271,11 +282,16 @@ struct i40evf_adapter {  	struct i40e_eth_stats current_stats;  	struct i40e_vsi vsi;  	u32 aq_wait_count; +	/* RSS stuff */ +	u64 hena; +	u16 rss_key_size; +	u16 rss_lut_size; +	u8 *rss_key; +	u8 *rss_lut;  };  /* Ethtool Private Flags */ -#define I40EVF_PRIV_FLAGS_PS		BIT(0)  /* needed by i40evf_ethtool.c */  extern char i40evf_driver_name[]; @@ -314,11 +330,12 @@ void i40evf_del_vlans(struct i40evf_adapter *adapter);  void i40evf_set_promiscuous(struct i40evf_adapter *adapter, int flags);  void i40evf_request_stats(struct i40evf_adapter *adapter);  void i40evf_request_reset(struct i40evf_adapter *adapter); +void i40evf_get_hena(struct i40evf_adapter *adapter); +void i40evf_set_hena(struct i40evf_adapter *adapter); +void i40evf_set_rss_key(struct i40evf_adapter *adapter); +void i40evf_set_rss_lut(struct i40evf_adapter *adapter);  void i40evf_virtchnl_completion(struct i40evf_adapter *adapter,  				enum i40e_virtchnl_ops v_opcode,  				i40e_status v_retval, u8 *msg, u16 msglen); -int i40evf_config_rss(struct i40e_vsi *vsi, const u8 *seed, u8 *lut, -		      u16 lut_size); -int i40evf_get_rss(struct i40e_vsi *vsi, const u8 *seed, u8 *lut, -		   u16 lut_size); +int i40evf_config_rss(struct i40evf_adapter *adapter);  #endif /* _I40EVF_H_ */ |