diff options
Diffstat (limited to 'drivers/net/netdevsim/netdevsim.h')
| -rw-r--r-- | drivers/net/netdevsim/netdevsim.h | 71 | 
1 files changed, 61 insertions, 10 deletions
| diff --git a/drivers/net/netdevsim/netdevsim.h b/drivers/net/netdevsim/netdevsim.h index 8ca50b72c328..384c254fafc5 100644 --- a/drivers/net/netdevsim/netdevsim.h +++ b/drivers/net/netdevsim/netdevsim.h @@ -18,6 +18,7 @@  #include <linux/list.h>  #include <linux/netdevice.h>  #include <linux/u64_stats_sync.h> +#include <net/xdp.h>  #define DRV_NAME	"netdevsim" @@ -26,9 +27,46 @@  #define NSIM_EA(extack, msg)	NL_SET_ERR_MSG_MOD((extack), msg)  struct bpf_prog; +struct bpf_offload_dev;  struct dentry;  struct nsim_vf_config; +struct netdevsim_shared_dev { +	unsigned int refcnt; +	u32 switch_id; + +	struct dentry *ddir; + +	struct bpf_offload_dev *bpf_dev; + +	struct dentry *ddir_bpf_bound_progs; +	u32 prog_id_gen; + +	struct list_head bpf_bound_progs; +	struct list_head bpf_bound_maps; +}; + +#define NSIM_IPSEC_MAX_SA_COUNT		33 +#define NSIM_IPSEC_VALID		BIT(31) + +struct nsim_sa { +	struct xfrm_state *xs; +	__be32 ipaddr[4]; +	u32 key[4]; +	u32 salt; +	bool used; +	bool crypt; +	bool rx; +}; + +struct nsim_ipsec { +	struct nsim_sa sa[NSIM_IPSEC_MAX_SA_COUNT]; +	struct dentry *pfile; +	u32 count; +	u32 tx; +	u32 ok; +}; +  struct netdevsim {  	struct net_device *netdev; @@ -37,6 +75,7 @@ struct netdevsim {  	struct u64_stats_sync syncp;  	struct device dev; +	struct netdevsim_shared_dev *sdev;  	struct dentry *ddir; @@ -46,16 +85,11 @@ struct netdevsim {  	struct bpf_prog	*bpf_offloaded;  	u32 bpf_offloaded_id; -	u32 xdp_flags; -	int xdp_prog_mode; -	struct bpf_prog	*xdp_prog; - -	u32 prog_id_gen; +	struct xdp_attachment_info xdp; +	struct xdp_attachment_info xdp_hw;  	bool bpf_bind_accept;  	u32 bpf_bind_verifier_delay; -	struct dentry *ddir_bpf_bound_progs; -	struct list_head bpf_bound_progs;  	bool bpf_tc_accept;  	bool bpf_tc_non_bound_accept; @@ -63,14 +97,12 @@ struct netdevsim {  	bool bpf_xdpoffload_accept;  	bool bpf_map_accept; -	struct list_head bpf_bound_maps;  #if IS_ENABLED(CONFIG_NET_DEVLINK)  	struct devlink *devlink;  #endif +	struct nsim_ipsec ipsec;  }; -extern struct dentry *nsim_ddir; -  #ifdef CONFIG_BPF_SYSCALL  int nsim_bpf_init(struct netdevsim *ns);  void nsim_bpf_uninit(struct netdevsim *ns); @@ -148,6 +180,25 @@ static inline void nsim_devlink_exit(void)  }  #endif +#if IS_ENABLED(CONFIG_XFRM_OFFLOAD) +void nsim_ipsec_init(struct netdevsim *ns); +void nsim_ipsec_teardown(struct netdevsim *ns); +bool nsim_ipsec_tx(struct netdevsim *ns, struct sk_buff *skb); +#else +static inline void nsim_ipsec_init(struct netdevsim *ns) +{ +} + +static inline void nsim_ipsec_teardown(struct netdevsim *ns) +{ +} + +static inline bool nsim_ipsec_tx(struct netdevsim *ns, struct sk_buff *skb) +{ +	return true; +} +#endif +  static inline struct netdevsim *to_nsim(struct device *ptr)  {  	return container_of(ptr, struct netdevsim, dev); | 
