Release 4.18 include/linux/if_macvlan.h
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_IF_MACVLAN_H
#define _LINUX_IF_MACVLAN_H
#include <linux/if_link.h>
#include <linux/if_vlan.h>
#include <linux/list.h>
#include <linux/netdevice.h>
#include <linux/netlink.h>
#include <net/netlink.h>
#include <linux/u64_stats_sync.h>
struct macvlan_port;
#define MACVLAN_MC_FILTER_BITS 8
#define MACVLAN_MC_FILTER_SZ (1 << MACVLAN_MC_FILTER_BITS)
struct macvlan_dev {
struct net_device *dev;
struct list_head list;
struct hlist_node hlist;
struct macvlan_port *port;
struct net_device *lowerdev;
void *accel_priv;
struct vlan_pcpu_stats __percpu *pcpu_stats;
DECLARE_BITMAP(mc_filter, MACVLAN_MC_FILTER_SZ);
netdev_features_t set_features;
enum macvlan_mode mode;
u16 flags;
int nest_level;
unsigned int macaddr_count;
#ifdef CONFIG_NET_POLL_CONTROLLER
struct netpoll *netpoll;
#endif
};
static inline void macvlan_count_rx(const struct macvlan_dev *vlan,
unsigned int len, bool success,
bool multicast)
{
if (likely(success)) {
struct vlan_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;
if (multicast)
pcpu_stats->rx_multicast++;
u64_stats_update_end(&pcpu_stats->syncp);
} else {
this_cpu_inc(vlan->pcpu_stats->rx_errors);
}
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Arnd Bergmann | 55 | 58.51% | 1 | 25.00% |
Eric Dumazet | 38 | 40.43% | 2 | 50.00% |
Li RongQing | 1 | 1.06% | 1 | 25.00% |
Total | 94 | 100.00% | 4 | 100.00% |
extern void macvlan_common_setup(struct net_device *dev);
extern int macvlan_common_newlink(struct net *src_net, struct net_device *dev,
struct nlattr *tb[], struct nlattr *data[],
struct netlink_ext_ack *extack);
extern void macvlan_dellink(struct net_device *dev, struct list_head *head);
extern int macvlan_link_register(struct rtnl_link_ops *ops);
#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;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Michal Kubeček | 30 | 100.00% | 1 | 100.00% |
Total | 30 | 100.00% | 1 | 100.00% |
#else
static inline struct net_device *
macvlan_dev_real_dev(const struct net_device *dev)
{
BUG();
return NULL;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Michal Kubeček | 21 | 100.00% | 1 | 100.00% |
Total | 21 | 100.00% | 1 | 100.00% |
#endif
static inline void *macvlan_accel_priv(struct net_device *dev)
{
struct macvlan_dev *macvlan = netdev_priv(dev);
return macvlan->accel_priv;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Alexander Duyck | 28 | 100.00% | 1 | 100.00% |
Total | 28 | 100.00% | 1 | 100.00% |
static inline bool macvlan_supports_dest_filter(struct net_device *dev)
{
struct macvlan_dev *macvlan = netdev_priv(dev);
return macvlan->mode == MACVLAN_MODE_PRIVATE ||
macvlan->mode == MACVLAN_MODE_VEPA ||
macvlan->mode == MACVLAN_MODE_BRIDGE;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Alexander Duyck | 41 | 100.00% | 1 | 100.00% |
Total | 41 | 100.00% | 1 | 100.00% |
static inline int macvlan_release_l2fw_offload(struct net_device *dev)
{
struct macvlan_dev *macvlan = netdev_priv(dev);
macvlan->accel_priv = NULL;
return dev_uc_add(macvlan->lowerdev, dev->dev_addr);
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Alexander Duyck | 40 | 100.00% | 1 | 100.00% |
Total | 40 | 100.00% | 1 | 100.00% |
#endif /* _LINUX_IF_MACVLAN_H */
Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Arnd Bergmann | 160 | 35.96% | 1 | 5.00% |
Alexander Duyck | 110 | 24.72% | 3 | 15.00% |
Michal Kubeček | 61 | 13.71% | 1 | 5.00% |
Eric Dumazet | 57 | 12.81% | 3 | 15.00% |
Herbert Xu | 10 | 2.25% | 1 | 5.00% |
Ding Tianhong | 10 | 2.25% | 1 | 5.00% |
Patrick McHardy | 9 | 2.02% | 1 | 5.00% |
Vlad Yasevich | 6 | 1.35% | 2 | 10.00% |
John Fastabend | 6 | 1.35% | 2 | 10.00% |
Li RongQing | 5 | 1.12% | 1 | 5.00% |
David Ahern | 5 | 1.12% | 1 | 5.00% |
Girish Moodalbail | 4 | 0.90% | 1 | 5.00% |
Greg Kroah-Hartman | 1 | 0.22% | 1 | 5.00% |
Tejun Heo | 1 | 0.22% | 1 | 5.00% |
Total | 445 | 100.00% | 20 | 100.00% |
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.