diff options
Diffstat (limited to 'include/linux/netdevice.h')
| -rw-r--r-- | include/linux/netdevice.h | 61 | 
1 files changed, 60 insertions, 1 deletions
| diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index d837dad24b4c..857f8abf7b91 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h @@ -535,6 +535,32 @@ static inline void napi_synchronize(const struct napi_struct *n)  		barrier();  } +/** + *	napi_if_scheduled_mark_missed - if napi is running, set the + *	NAPIF_STATE_MISSED + *	@n: NAPI context + * + * If napi is running, set the NAPIF_STATE_MISSED, and return true if + * NAPI is scheduled. + **/ +static inline bool napi_if_scheduled_mark_missed(struct napi_struct *n) +{ +	unsigned long val, new; + +	do { +		val = READ_ONCE(n->state); +		if (val & NAPIF_STATE_DISABLE) +			return true; + +		if (!(val & NAPIF_STATE_SCHED)) +			return false; + +		new = val | NAPIF_STATE_MISSED; +	} while (cmpxchg(&n->state, val, new) != val); + +	return true; +} +  enum netdev_queue_state_t {  	__QUEUE_STATE_DRV_XOFF,  	__QUEUE_STATE_STACK_XOFF, @@ -583,6 +609,9 @@ struct netdev_queue {  	/* Subordinate device that the queue has been assigned to */  	struct net_device	*sb_dev; +#ifdef CONFIG_XDP_SOCKETS +	struct xdp_umem         *umem; +#endif  /*   * write-mostly part   */ @@ -712,6 +741,9 @@ struct netdev_rx_queue {  	struct kobject			kobj;  	struct net_device		*dev;  	struct xdp_rxq_info		xdp_rxq; +#ifdef CONFIG_XDP_SOCKETS +	struct xdp_umem                 *umem; +#endif  } ____cacheline_aligned_in_smp;  /* @@ -1976,7 +2008,6 @@ struct net_device {  		struct pcpu_lstats __percpu		*lstats;  		struct pcpu_sw_netstats __percpu	*tstats;  		struct pcpu_dstats __percpu		*dstats; -		struct pcpu_vstats __percpu		*vstats;  	};  #if IS_ENABLED(CONFIG_GARP) @@ -2320,6 +2351,7 @@ static inline struct sk_buff *call_gro_receive_sk(gro_receive_sk_t cb,  struct packet_type {  	__be16			type;	/* This is really htons(ether_type). */ +	bool			ignore_outgoing;  	struct net_device	*dev;	/* NULL is wildcarded here	     */  	int			(*func) (struct sk_buff *,  					 struct net_device *, @@ -2358,6 +2390,12 @@ struct pcpu_sw_netstats {  	struct u64_stats_sync   syncp;  }; +struct pcpu_lstats { +	u64 packets; +	u64 bytes; +	struct u64_stats_sync syncp; +}; +  #define __netdev_alloc_pcpu_stats(type, gfp)				\  ({									\  	typeof(type) __percpu *pcpu_stats = alloc_percpu_gfp(type, gfp);\ @@ -3152,6 +3190,26 @@ static inline void netdev_tx_sent_queue(struct netdev_queue *dev_queue,  #endif  } +/* Variant of netdev_tx_sent_queue() for drivers that are aware + * that they should not test BQL status themselves. + * We do want to change __QUEUE_STATE_STACK_XOFF only for the last + * skb of a batch. + * Returns true if the doorbell must be used to kick the NIC. + */ +static inline bool __netdev_tx_sent_queue(struct netdev_queue *dev_queue, +					  unsigned int bytes, +					  bool xmit_more) +{ +	if (xmit_more) { +#ifdef CONFIG_BQL +		dql_queued(&dev_queue->dql, bytes); +#endif +		return netif_tx_queue_stopped(dev_queue); +	} +	netdev_tx_sent_queue(dev_queue, bytes); +	return true; +} +  /**   * 	netdev_sent_queue - report the number of bytes queued to hardware   * 	@dev: network device @@ -3607,6 +3665,7 @@ static __always_inline int ____dev_forward_skb(struct net_device *dev,  	return 0;  } +bool dev_nit_active(struct net_device *dev);  void dev_queue_xmit_nit(struct sk_buff *skb, struct net_device *dev);  extern int		netdev_budget; | 
