diff options
Diffstat (limited to 'include/linux/netdevice.h')
| -rw-r--r-- | include/linux/netdevice.h | 51 | 
1 files changed, 50 insertions, 1 deletions
| diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index ca5ab98053c8..dc1d9ed33b31 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;  /* @@ -1730,6 +1762,8 @@ enum netdev_priv_flags {   *			switch driver and used to set the phys state of the   *			switch port.   * + *	@wol_enabled:	Wake-on-LAN is enabled + *   *	FIXME: cleanup struct net_device such that network protocol info   *	moves out.   */ @@ -1974,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) @@ -2014,6 +2047,7 @@ struct net_device {  	struct lock_class_key	*qdisc_tx_busylock;  	struct lock_class_key	*qdisc_running_key;  	bool			proto_down; +	unsigned		wol_enabled:1;  };  #define to_net_dev(d) container_of(d, struct net_device, dev) @@ -2317,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 *, @@ -2355,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);\ @@ -2455,6 +2496,13 @@ struct netdev_notifier_info {  	struct netlink_ext_ack	*extack;  }; +struct netdev_notifier_info_ext { +	struct netdev_notifier_info info; /* must be first */ +	union { +		u32 mtu; +	} ext; +}; +  struct netdev_notifier_change_info {  	struct netdev_notifier_info info; /* must be first */  	unsigned int flags_changed; @@ -3597,6 +3645,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; | 
