2007-07-15 09:55:06 +08:00
|
|
|
#ifndef _LINUX_IF_MACVLAN_H
|
|
|
|
#define _LINUX_IF_MACVLAN_H
|
|
|
|
|
2010-01-30 20:23:40 +08:00
|
|
|
#include <linux/if_link.h>
|
|
|
|
#include <linux/list.h>
|
|
|
|
#include <linux/netdevice.h>
|
|
|
|
#include <linux/netlink.h>
|
|
|
|
#include <net/netlink.h>
|
2010-06-24 08:54:21 +08:00
|
|
|
#include <linux/u64_stats_sync.h>
|
2010-01-30 20:23:40 +08:00
|
|
|
|
2013-06-06 07:54:35 +08:00
|
|
|
#if IS_ENABLED(CONFIG_MACVTAP)
|
2010-02-18 13:46:50 +08:00
|
|
|
struct socket *macvtap_get_socket(struct file *);
|
|
|
|
#else
|
|
|
|
#include <linux/err.h>
|
|
|
|
#include <linux/errno.h>
|
|
|
|
struct file;
|
|
|
|
struct socket;
|
|
|
|
static inline struct socket *macvtap_get_socket(struct file *f)
|
|
|
|
{
|
|
|
|
return ERR_PTR(-EINVAL);
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_MACVTAP */
|
|
|
|
|
2010-01-30 20:23:40 +08:00
|
|
|
struct macvlan_port;
|
|
|
|
struct macvtap_queue;
|
|
|
|
|
|
|
|
/**
|
2010-11-11 05:14:04 +08:00
|
|
|
* struct macvlan_pcpu_stats - MACVLAN percpu stats
|
2010-01-30 20:23:40 +08:00
|
|
|
* @rx_packets: number of received packets
|
|
|
|
* @rx_bytes: number of received bytes
|
2010-06-24 08:54:21 +08:00
|
|
|
* @rx_multicast: number of received multicast packets
|
2010-11-11 05:14:04 +08:00
|
|
|
* @tx_packets: number of transmitted packets
|
|
|
|
* @tx_bytes: number of transmitted bytes
|
2010-06-24 08:54:21 +08:00
|
|
|
* @syncp: synchronization point for 64bit counters
|
2010-11-11 05:14:04 +08:00
|
|
|
* @rx_errors: number of rx errors
|
|
|
|
* @tx_dropped: number of tx dropped packets
|
2010-01-30 20:23:40 +08:00
|
|
|
*/
|
2010-11-11 05:14:04 +08:00
|
|
|
struct macvlan_pcpu_stats {
|
2010-06-24 08:54:21 +08:00
|
|
|
u64 rx_packets;
|
|
|
|
u64 rx_bytes;
|
|
|
|
u64 rx_multicast;
|
2010-11-11 05:14:04 +08:00
|
|
|
u64 tx_packets;
|
|
|
|
u64 tx_bytes;
|
2010-06-24 08:54:21 +08:00
|
|
|
struct u64_stats_sync syncp;
|
2010-11-11 05:14:04 +08:00
|
|
|
u32 rx_errors;
|
|
|
|
u32 tx_dropped;
|
2010-01-30 20:23:40 +08:00
|
|
|
};
|
|
|
|
|
2010-08-04 14:15:59 +08:00
|
|
|
/*
|
|
|
|
* Maximum times a macvtap device can be opened. This can be used to
|
|
|
|
* configure the number of receive queue, e.g. for multiqueue virtio.
|
|
|
|
*/
|
2013-06-06 07:54:37 +08:00
|
|
|
#define MAX_MACVTAP_QUEUES 16
|
2010-08-04 14:15:59 +08:00
|
|
|
|
2013-02-06 04:22:50 +08:00
|
|
|
#define MACVLAN_MC_FILTER_BITS 8
|
|
|
|
#define MACVLAN_MC_FILTER_SZ (1 << MACVLAN_MC_FILTER_BITS)
|
|
|
|
|
2010-01-30 20:23:40 +08:00
|
|
|
struct macvlan_dev {
|
|
|
|
struct net_device *dev;
|
|
|
|
struct list_head list;
|
|
|
|
struct hlist_node hlist;
|
|
|
|
struct macvlan_port *port;
|
|
|
|
struct net_device *lowerdev;
|
2013-11-07 01:54:46 +08:00
|
|
|
void *fwd_priv;
|
2010-11-11 05:14:04 +08:00
|
|
|
struct macvlan_pcpu_stats __percpu *pcpu_stats;
|
2013-02-06 04:22:50 +08:00
|
|
|
|
|
|
|
DECLARE_BITMAP(mc_filter, MACVLAN_MC_FILTER_SZ);
|
|
|
|
|
2013-06-26 04:04:21 +08:00
|
|
|
netdev_features_t set_features;
|
2010-01-30 20:23:40 +08:00
|
|
|
enum macvlan_mode mode;
|
2012-04-15 14:44:37 +08:00
|
|
|
u16 flags;
|
2010-01-30 20:23:40 +08:00
|
|
|
int (*receive)(struct sk_buff *skb);
|
|
|
|
int (*forward)(struct net_device *dev, struct sk_buff *skb);
|
2013-06-06 07:54:39 +08:00
|
|
|
/* This array tracks active taps. */
|
2013-06-13 14:23:35 +08:00
|
|
|
struct macvtap_queue __rcu *taps[MAX_MACVTAP_QUEUES];
|
2013-06-06 07:54:39 +08:00
|
|
|
/* This list tracks all taps (both enabled and disabled) */
|
|
|
|
struct list_head queue_list;
|
2010-08-04 14:15:59 +08:00
|
|
|
int numvtaps;
|
2013-06-06 07:54:39 +08:00
|
|
|
int numqueues;
|
2013-06-26 04:04:21 +08:00
|
|
|
netdev_features_t tap_features;
|
2011-10-20 12:29:24 +08:00
|
|
|
int minor;
|
2010-01-30 20:23:40 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline void macvlan_count_rx(const struct macvlan_dev *vlan,
|
|
|
|
unsigned int len, bool success,
|
|
|
|
bool multicast)
|
|
|
|
{
|
|
|
|
if (likely(success)) {
|
2010-11-11 05:14:04 +08:00
|
|
|
struct macvlan_pcpu_stats *pcpu_stats;
|
|
|
|
|
|
|
|
pcpu_stats = this_cpu_ptr(vlan->pcpu_stats);
|
|
|
|
u64_stats_update_begin(&pcpu_stats->syncp);
|
|
|
|
pcpu_stats->rx_packets++;
|
|
|
|
pcpu_stats->rx_bytes += len;
|
2010-01-30 20:23:40 +08:00
|
|
|
if (multicast)
|
2010-11-11 05:14:04 +08:00
|
|
|
pcpu_stats->rx_multicast++;
|
|
|
|
u64_stats_update_end(&pcpu_stats->syncp);
|
2010-01-30 20:23:40 +08:00
|
|
|
} else {
|
2010-11-11 05:14:04 +08:00
|
|
|
this_cpu_inc(vlan->pcpu_stats->rx_errors);
|
2010-01-30 20:23:40 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-22 05:44:31 +08:00
|
|
|
extern void macvlan_common_setup(struct net_device *dev);
|
|
|
|
|
2010-01-30 20:23:40 +08:00
|
|
|
extern int macvlan_common_newlink(struct net *src_net, struct net_device *dev,
|
|
|
|
struct nlattr *tb[], struct nlattr *data[],
|
|
|
|
int (*receive)(struct sk_buff *skb),
|
|
|
|
int (*forward)(struct net_device *dev,
|
|
|
|
struct sk_buff *skb));
|
|
|
|
|
|
|
|
extern void macvlan_count_rx(const struct macvlan_dev *vlan,
|
|
|
|
unsigned int len, bool success,
|
|
|
|
bool multicast);
|
|
|
|
|
|
|
|
extern void macvlan_dellink(struct net_device *dev, struct list_head *head);
|
|
|
|
|
|
|
|
extern int macvlan_link_register(struct rtnl_link_ops *ops);
|
|
|
|
|
|
|
|
extern netdev_tx_t macvlan_start_xmit(struct sk_buff *skb,
|
|
|
|
struct net_device *dev);
|
|
|
|
|
2013-11-15 13:18:40 +08:00
|
|
|
#if IS_ENABLED(CONFIG_MACVLAN)
|
|
|
|
static inline struct net_device *
|
|
|
|
macvlan_dev_real_dev(const struct net_device *dev)
|
|
|
|
{
|
|
|
|
struct macvlan_dev *macvlan = netdev_priv(dev);
|
|
|
|
|
|
|
|
return macvlan->lowerdev;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
static inline struct net_device *
|
|
|
|
macvlan_dev_real_dev(const struct net_device *dev)
|
|
|
|
{
|
|
|
|
BUG();
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2007-07-15 09:55:06 +08:00
|
|
|
#endif /* _LINUX_IF_MACVLAN_H */
|