Files
linux-apfs/include/linux/if_macvlan.h
T

108 lines
2.9 KiB
C
Raw Normal View History

2007-07-14 18:55:06 -07:00
#ifndef _LINUX_IF_MACVLAN_H
#define _LINUX_IF_MACVLAN_H
2010-01-30 12:23:40 +00: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 00:54:21 +00:00
#include <linux/u64_stats_sync.h>
2010-01-30 12:23:40 +00:00
2010-02-18 05:46:50 +00:00
#if defined(CONFIG_MACVTAP) || defined(CONFIG_MACVTAP_MODULE)
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 12:23:40 +00:00
struct macvlan_port;
struct macvtap_queue;
/**
2010-11-10 21:14:04 +00:00
* struct macvlan_pcpu_stats - MACVLAN percpu stats
2010-01-30 12:23:40 +00:00
* @rx_packets: number of received packets
* @rx_bytes: number of received bytes
2010-06-24 00:54:21 +00:00
* @rx_multicast: number of received multicast packets
2010-11-10 21:14:04 +00:00
* @tx_packets: number of transmitted packets
* @tx_bytes: number of transmitted bytes
2010-06-24 00:54:21 +00:00
* @syncp: synchronization point for 64bit counters
2010-11-10 21:14:04 +00:00
* @rx_errors: number of rx errors
* @tx_dropped: number of tx dropped packets
2010-01-30 12:23:40 +00:00
*/
2010-11-10 21:14:04 +00:00
struct macvlan_pcpu_stats {
2010-06-24 00:54:21 +00:00
u64 rx_packets;
u64 rx_bytes;
u64 rx_multicast;
2010-11-10 21:14:04 +00:00
u64 tx_packets;
u64 tx_bytes;
2010-06-24 00:54:21 +00:00
struct u64_stats_sync syncp;
2010-11-10 21:14:04 +00:00
u32 rx_errors;
u32 tx_dropped;
2010-01-30 12:23:40 +00: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.
*/
#define MAX_MACVTAP_QUEUES (NR_CPUS < 16 ? NR_CPUS : 16)
2010-01-30 12:23:40 +00:00
struct macvlan_dev {
struct net_device *dev;
struct list_head list;
struct hlist_node hlist;
struct macvlan_port *port;
struct net_device *lowerdev;
2010-11-10 21:14:04 +00:00
struct macvlan_pcpu_stats __percpu *pcpu_stats;
2010-01-30 12:23:40 +00:00
enum macvlan_mode mode;
int (*receive)(struct sk_buff *skb);
int (*forward)(struct net_device *dev, struct sk_buff *skb);
struct macvtap_queue *taps[MAX_MACVTAP_QUEUES];
int numvtaps;
2010-01-30 12:23:40 +00:00
};
static inline void macvlan_count_rx(const struct macvlan_dev *vlan,
unsigned int len, bool success,
bool multicast)
{
if (likely(success)) {
2010-11-10 21:14:04 +00: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 12:23:40 +00:00
if (multicast)
2010-11-10 21:14:04 +00:00
pcpu_stats->rx_multicast++;
u64_stats_update_end(&pcpu_stats->syncp);
2010-01-30 12:23:40 +00:00
} else {
2010-11-10 21:14:04 +00:00
this_cpu_inc(vlan->pcpu_stats->rx_errors);
2010-01-30 12:23:40 +00:00
}
}
2010-07-21 21:44:31 +00:00
extern void macvlan_common_setup(struct net_device *dev);
2010-01-30 12:23:40 +00: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);
2007-07-14 18:55:06 -07:00
#endif /* _LINUX_IF_MACVLAN_H */