cregit-Linux how code gets into the kernel

Release 4.16 include/linux/if_vlan.h

Directory: include/linux
/*
 * VLAN         An implementation of 802.1Q VLAN tagging.
 *
 * Authors:     Ben Greear <greearb@candelatech.com>
 *
 *              This program is free software; you can redistribute it and/or
 *              modify it under the terms of the GNU General Public License
 *              as published by the Free Software Foundation; either version
 *              2 of the License, or (at your option) any later version.
 *
 */
#ifndef _LINUX_IF_VLAN_H_

#define _LINUX_IF_VLAN_H_

#include <linux/netdevice.h>
#include <linux/etherdevice.h>
#include <linux/rtnetlink.h>
#include <linux/bug.h>
#include <uapi/linux/if_vlan.h>


#define VLAN_HLEN	4		
/* The additional bytes required by VLAN
                                         * (in addition to the Ethernet header)
                                         */

#define VLAN_ETH_HLEN	18		
/* Total octets in header.       */

#define VLAN_ETH_ZLEN	64		
/* Min. octets in frame sans FCS */

/*
 * According to 802.3ac, the packet can be 4 bytes longer. --Klika Jan
 */

#define VLAN_ETH_DATA_LEN	1500	
/* Max. octets in payload        */

#define VLAN_ETH_FRAME_LEN	1518	
/* Max. octets in frame sans FCS */

/*
 *      struct vlan_hdr - vlan header
 *      @h_vlan_TCI: priority and VLAN ID
 *      @h_vlan_encapsulated_proto: packet type ID or len
 */

struct vlan_hdr {
	
__be16	h_vlan_TCI;
	
__be16	h_vlan_encapsulated_proto;
};

/**
 *      struct vlan_ethhdr - vlan ethernet header (ethhdr + vlan_hdr)
 *      @h_dest: destination ethernet address
 *      @h_source: source ethernet address
 *      @h_vlan_proto: ethernet protocol
 *      @h_vlan_TCI: priority and VLAN ID
 *      @h_vlan_encapsulated_proto: packet type ID or len
 */

struct vlan_ethhdr {
	
unsigned char	h_dest[ETH_ALEN];
	
unsigned char	h_source[ETH_ALEN];
	
__be16		h_vlan_proto;
	
__be16		h_vlan_TCI;
	
__be16		h_vlan_encapsulated_proto;
};

#include <linux/skbuff.h>


static inline struct vlan_ethhdr *vlan_eth_hdr(const struct sk_buff *skb) { return (struct vlan_ethhdr *)skb_mac_header(skb); }

Contributors

PersonTokensPropCommitsCommitProp
Arnaldo Carvalho de Melo26100.00%2100.00%
Total26100.00%2100.00%

#define VLAN_PRIO_MASK 0xe000 /* Priority Code Point */ #define VLAN_PRIO_SHIFT 13 #define VLAN_CFI_MASK 0x1000 /* Canonical Format Indicator */ #define VLAN_TAG_PRESENT VLAN_CFI_MASK #define VLAN_VID_MASK 0x0fff /* VLAN Identifier */ #define VLAN_N_VID 4096 /* found in socket.c */ extern void vlan_ioctl_set(int (*hook)(struct net *, void __user *));
static inline bool is_vlan_dev(const struct net_device *dev) { return dev->priv_flags & IFF_802_1Q_VLAN; }

Contributors

PersonTokensPropCommitsCommitProp
Neil Horman1890.00%133.33%
Jiri Pirko15.00%133.33%
Vlad Yasevich15.00%133.33%
Total20100.00%3100.00%

#define skb_vlan_tag_present(__skb) ((__skb)->vlan_tci & VLAN_TAG_PRESENT) #define skb_vlan_tag_get(__skb) ((__skb)->vlan_tci & ~VLAN_TAG_PRESENT) #define skb_vlan_tag_get_id(__skb) ((__skb)->vlan_tci & VLAN_VID_MASK) #define skb_vlan_tag_get_prio(__skb) ((__skb)->vlan_tci & VLAN_PRIO_MASK) /** * struct vlan_pcpu_stats - VLAN percpu rx/tx stats * @rx_packets: number of received packets * @rx_bytes: number of received bytes * @rx_multicast: number of received multicast packets * @tx_packets: number of transmitted packets * @tx_bytes: number of transmitted bytes * @syncp: synchronization point for 64bit counters * @rx_errors: number of rx errors * @tx_dropped: number of tx drops */ struct vlan_pcpu_stats { u64 rx_packets; u64 rx_bytes; u64 rx_multicast; u64 tx_packets; u64 tx_bytes; struct u64_stats_sync syncp; u32 rx_errors; u32 tx_dropped; }; #if defined(CONFIG_VLAN_8021Q) || defined(CONFIG_VLAN_8021Q_MODULE) extern struct net_device *__vlan_find_dev_deep_rcu(struct net_device *real_dev, __be16 vlan_proto, u16 vlan_id); extern struct net_device *vlan_dev_real_dev(const struct net_device *dev); extern u16 vlan_dev_vlan_id(const struct net_device *dev); extern __be16 vlan_dev_vlan_proto(const struct net_device *dev); /** * struct vlan_priority_tci_mapping - vlan egress priority mappings * @priority: skb priority * @vlan_qos: vlan priority: (skb->priority << 13) & 0xE000 * @next: pointer to next struct */ struct vlan_priority_tci_mapping { u32 priority; u16 vlan_qos; struct vlan_priority_tci_mapping *next; }; struct proc_dir_entry; struct netpoll; /** * struct vlan_dev_priv - VLAN private device data * @nr_ingress_mappings: number of ingress priority mappings * @ingress_priority_map: ingress priority mappings * @nr_egress_mappings: number of egress priority mappings * @egress_priority_map: hash of egress priority mappings * @vlan_proto: VLAN encapsulation protocol * @vlan_id: VLAN identifier * @flags: device flags * @real_dev: underlying netdevice * @real_dev_addr: address of underlying netdevice * @dent: proc dir entry * @vlan_pcpu_stats: ptr to percpu rx stats */ struct vlan_dev_priv { unsigned int nr_ingress_mappings; u32 ingress_priority_map[8]; unsigned int nr_egress_mappings; struct vlan_priority_tci_mapping *egress_priority_map[16]; __be16 vlan_proto; u16 vlan_id; u16 flags; struct net_device *real_dev; unsigned char real_dev_addr[ETH_ALEN]; struct proc_dir_entry *dent; struct vlan_pcpu_stats __percpu *vlan_pcpu_stats; #ifdef CONFIG_NET_POLL_CONTROLLER struct netpoll *netpoll; #endif unsigned int nest_level; };
static inline struct vlan_dev_priv *vlan_dev_priv(const struct net_device *dev) { return netdev_priv(dev); }

Contributors

PersonTokensPropCommitsCommitProp
David S. Miller21100.00%1100.00%
Total21100.00%1100.00%


static inline u16 vlan_dev_get_egress_qos_mask(struct net_device *dev, u32 skprio) { struct vlan_priority_tci_mapping *mp; smp_rmb(); /* coupled with smp_wmb() in vlan_dev_set_egress_priority() */ mp = vlan_dev_priv(dev)->egress_priority_map[(skprio & 0xF)]; while (mp) { if (mp->priority == skprio) { return mp->vlan_qos; /* This should already be shifted * to mask correctly with the * VLAN's TCI */ } mp = mp->next; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
David S. Miller6185.92%150.00%
Eyal Perry1014.08%150.00%
Total71100.00%2100.00%

extern bool vlan_do_receive(struct sk_buff **skb); extern int vlan_vid_add(struct net_device *dev, __be16 proto, u16 vid); extern void vlan_vid_del(struct net_device *dev, __be16 proto, u16 vid); extern int vlan_vids_add_by_dev(struct net_device *dev, const struct net_device *by_dev); extern void vlan_vids_del_by_dev(struct net_device *dev, const struct net_device *by_dev); extern bool vlan_uses_dev(const struct net_device *dev);
static inline int vlan_get_encap_level(struct net_device *dev) { BUG_ON(!is_vlan_dev(dev)); return vlan_dev_priv(dev)->nest_level; }

Contributors

PersonTokensPropCommitsCommitProp
Vlad Yasevich29100.00%1100.00%
Total29100.00%1100.00%

#else
static inline struct net_device * __vlan_find_dev_deep_rcu(struct net_device *real_dev, __be16 vlan_proto, u16 vlan_id) { return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko1982.61%133.33%
Patrick McHardy313.04%133.33%
Ding Tianhong14.35%133.33%
Total23100.00%3100.00%


static inline struct net_device *vlan_dev_real_dev(const struct net_device *dev) { BUG(); return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Patrick McHardy21100.00%1100.00%
Total21100.00%1100.00%


static inline u16 vlan_dev_vlan_id(const struct net_device *dev) { BUG(); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Ding Tianhong1263.16%150.00%
Patrick McHardy736.84%150.00%
Total19100.00%2100.00%


static inline __be16 vlan_dev_vlan_proto(const struct net_device *dev) { BUG(); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Patrick McHardy1263.16%150.00%
Ding Tianhong736.84%150.00%
Total19100.00%2100.00%


static inline u16 vlan_dev_get_egress_qos_mask(struct net_device *dev, u32 skprio) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eyal Perry18100.00%1100.00%
Total18100.00%1100.00%


static inline bool vlan_do_receive(struct sk_buff **skb) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
Patrick McHardy850.00%133.33%
Jesse Gross743.75%133.33%
Jiri Pirko16.25%133.33%
Total16100.00%3100.00%


static inline int vlan_vid_add(struct net_device *dev, __be16 proto, u16 vid) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko1780.95%150.00%
Patrick McHardy419.05%150.00%
Total21100.00%2100.00%


static inline void vlan_vid_del(struct net_device *dev, __be16 proto, u16 vid) { }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko1376.47%150.00%
Patrick McHardy423.53%150.00%
Total17100.00%2100.00%


static inline int vlan_vids_add_by_dev(struct net_device *dev, const struct net_device *by_dev) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko21100.00%1100.00%
Total21100.00%1100.00%


static inline void vlan_vids_del_by_dev(struct net_device *dev, const struct net_device *by_dev) { }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko17100.00%1100.00%
Total17100.00%1100.00%


static inline bool vlan_uses_dev(const struct net_device *dev) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko16100.00%1100.00%
Total16100.00%1100.00%


static inline int vlan_get_encap_level(struct net_device *dev) { BUG(); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Vlad Yasevich18100.00%1100.00%
Total18100.00%1100.00%

#endif /** * eth_type_vlan - check for valid vlan ether type. * @ethertype: ether type to check * * Returns true if the ether type is a vlan ether type. */
static inline bool eth_type_vlan(__be16 ethertype) { switch (ethertype) { case htons(ETH_P_8021Q): case htons(ETH_P_8021AD): return true; default: return false; } }

Contributors

PersonTokensPropCommitsCommitProp
Eric Garver35100.00%1100.00%
Total35100.00%1100.00%


static inline bool vlan_hw_offload_capable(netdev_features_t features, __be16 proto) { if (proto == htons(ETH_P_8021Q) && features & NETIF_F_HW_VLAN_CTAG_TX) return true; if (proto == htons(ETH_P_8021AD) && features & NETIF_F_HW_VLAN_STAG_TX) return true; return false; }

Contributors

PersonTokensPropCommitsCommitProp
Patrick McHardy48100.00%2100.00%
Total48100.00%2100.00%

/** * __vlan_insert_inner_tag - inner VLAN tag inserting * @skb: skbuff to tag * @vlan_proto: VLAN encapsulation protocol * @vlan_tci: VLAN TCI to insert * @mac_len: MAC header length including outer vlan headers * * Inserts the VLAN tag into @skb as part of the payload at offset mac_len * Returns error if skb_cow_head failes. * * Does not change skb->protocol so this function can be used during receive. */
static inline int __vlan_insert_inner_tag(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci, unsigned int mac_len) { struct vlan_ethhdr *veth; if (skb_cow_head(skb, VLAN_HLEN) < 0) return -ENOMEM; skb_push(skb, VLAN_HLEN); /* Move the mac header sans proto to the beginning of the new header. */ if (likely(mac_len > ETH_TLEN)) memmove(skb->data, skb->data + VLAN_HLEN, mac_len - ETH_TLEN); skb->mac_header -= VLAN_HLEN; veth = (struct vlan_ethhdr *)(skb->data + mac_len - ETH_HLEN); /* first, the ethernet type */ if (likely(mac_len >= ETH_TLEN)) { /* h_vlan_encapsulated_proto should already be populated, and * skb->data has space for h_vlan_proto */ veth->h_vlan_proto = vlan_proto; } else { /* h_vlan_encapsulated_proto should not be populated, and * skb->data has no space for h_vlan_proto */ veth->h_vlan_encapsulated_proto = skb->protocol; } /* now, the TCI */ veth->h_vlan_TCI = htons(vlan_tci); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Shmulik Hen6041.96%111.11%
Toshiaki Makita5941.26%222.22%
Patrick McHardy117.69%333.33%
Jiri Pirko74.90%222.22%
Jarek Poplawski64.20%111.11%
Total143100.00%9100.00%

/** * __vlan_insert_tag - regular VLAN tag inserting * @skb: skbuff to tag * @vlan_proto: VLAN encapsulation protocol * @vlan_tci: VLAN TCI to insert * * Inserts the VLAN tag into @skb as part of the payload * Returns error if skb_cow_head failes. * * Does not change skb->protocol so this function can be used during receive. */
static inline int __vlan_insert_tag(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci) { return __vlan_insert_inner_tag(skb, vlan_proto, vlan_tci, ETH_HLEN); }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita2583.33%150.00%
Jiri Pirko516.67%150.00%
Total30100.00%2100.00%

/** * vlan_insert_inner_tag - inner VLAN tag inserting * @skb: skbuff to tag * @vlan_proto: VLAN encapsulation protocol * @vlan_tci: VLAN TCI to insert * @mac_len: MAC header length including outer vlan headers * * Inserts the VLAN tag into @skb as part of the payload at offset mac_len * Returns a VLAN tagged skb. If a new skb is created, @skb is freed. * * Following the skb_unshare() example, in case of error, the calling function * doesn't have to worry about freeing the original skb. * * Does not change skb->protocol so this function can be used during receive. */
static inline struct sk_buff *vlan_insert_inner_tag(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci, unsigned int mac_len) { int err; err = __vlan_insert_inner_tag(skb, vlan_proto, vlan_tci, mac_len); if (err) { dev_kfree_skb_any(skb); return NULL; } return skb; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko4477.19%266.67%
Toshiaki Makita1322.81%133.33%
Total57100.00%3100.00%

/** * vlan_insert_tag - regular VLAN tag inserting * @skb: skbuff to tag * @vlan_proto: VLAN encapsulation protocol * @vlan_tci: VLAN TCI to insert * * Inserts the VLAN tag into @skb as part of the payload * Returns a VLAN tagged skb. If a new skb is created, @skb is freed. * * Following the skb_unshare() example, in case of error, the calling function * doesn't have to worry about freeing the original skb. * * Does not change skb->protocol so this function can be used during receive. */
static inline struct sk_buff *vlan_insert_tag(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci) { return vlan_insert_inner_tag(skb, vlan_proto, vlan_tci, ETH_HLEN); }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita32100.00%1100.00%
Total32100.00%1100.00%

/** * vlan_insert_tag_set_proto - regular VLAN tag inserting * @skb: skbuff to tag * @vlan_proto: VLAN encapsulation protocol * @vlan_tci: VLAN TCI to insert * * Inserts the VLAN tag into @skb as part of the payload * Returns a VLAN tagged skb. If a new skb is created, @skb is freed. * * Following the skb_unshare() example, in case of error, the calling function * doesn't have to worry about freeing the original skb. */
static inline struct sk_buff *vlan_insert_tag_set_proto(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci) { skb = vlan_insert_tag(skb, vlan_proto, vlan_tci); if (skb) skb->protocol = vlan_proto; return skb; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko2965.91%250.00%
Shmulik Hen920.45%125.00%
Patrick McHardy613.64%125.00%
Total44100.00%4100.00%

/* * __vlan_hwaccel_push_inside - pushes vlan tag to the payload * @skb: skbuff to tag * * Pushes the VLAN tag from @skb->vlan_tci inside to the payload. * * Following the skb_unshare() example, in case of error, the calling function * doesn't have to worry about freeing the original skb. */
static inline struct sk_buff *__vlan_hwaccel_push_inside(struct sk_buff *skb) { skb = vlan_insert_tag_set_proto(skb, skb->vlan_proto, skb_vlan_tag_get(skb)); if (likely(skb)) skb->vlan_tci = 0; return skb; }

Contributors

PersonTokensPropCommitsCommitProp
Jiri Pirko46100.00%2100.00%
Total46100.00%2100.00%

/** * __vlan_hwaccel_put_tag - hardware accelerated VLAN inserting * @skb: skbuff to tag * @vlan_proto: VLAN encapsulation protocol * @vlan_tci: VLAN TCI to insert * * Puts the VLAN TCI in @skb->vlan_tci and lets the device do the rest */
static inline void __vlan_hwaccel_put_tag(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci) { skb->vlan_proto = vlan_proto; skb->vlan_tci = VLAN_TAG_PRESENT | vlan_tci; }

Contributors

PersonTokensPropCommitsCommitProp
Shmulik Hen1650.00%116.67%
Patrick McHardy1340.62%350.00%
Eric Dumazet26.25%116.67%
Jiri Pirko13.12%116.67%
Total32100.00%6100.00%

/** * __vlan_get_tag - get the VLAN ID that is part of the payload * @skb: skbuff to query * @vlan_tci: buffer to store value * * Returns error if the skb is not of VLAN type */
static inline int __vlan_get_tag(const struct sk_buff *skb, u16 *vlan_tci) { struct vlan_ethhdr *veth = (struct vlan_ethhdr *)skb->data; if (!eth_type_vlan(veth->h_vlan_proto)) return -EINVAL; *vlan_tci = ntohs(veth->h_vlan_TCI); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Shmulik Hen4882.76%120.00%
Patrick McHardy813.79%360.00%
Eric Garver23.45%120.00%
Total58100.00%5100.00%

/** * __vlan_hwaccel_get_tag - get the VLAN ID that is in @skb->cb[] * @skb: skbuff to query * @vlan_tci: buffer to store value * * Returns error if @skb->vlan_tci is not set correctly */
static inline int __vlan_hwaccel_get_tag(const struct sk_buff *skb, u16 *vlan_tci) { if (skb_vlan_tag_present(skb)) { *vlan_tci = skb_vlan_tag_get(skb); return 0; } else { *vlan_tci = 0; return -EINVAL; } }

Contributors

PersonTokensPropCommitsCommitProp
Shmulik Hen3775.51%116.67%
Patrick McHardy816.33%350.00%
Eric Dumazet24.08%116.67%
Jiri Pirko24.08%116.67%
Total49100.00%6100.00%

#define HAVE_VLAN_GET_TAG /** * vlan_get_tag - get the VLAN ID from the skb * @skb: skbuff to query * @vlan_tci: buffer to store value * * Returns error if the skb is not VLAN tagged */
static inline int vlan_get_tag(const struct sk_buff *skb, u16 *vlan_tci) { if (skb->dev->features & NETIF_F_HW_VLAN_CTAG_TX) { return __vlan_hwaccel_get_tag(skb, vlan_tci); } else { return __vlan_get_tag(skb, vlan_tci); } }

Contributors

PersonTokensPropCommitsCommitProp
Shmulik Hen4287.50%125.00%
Patrick McHardy612.50%375.00%
Total48100.00%4100.00%

/** * vlan_get_protocol - get protocol EtherType. * @skb: skbuff to query * @type: first vlan protocol * @depth: buffer to store length of eth and vlan tags in bytes * * Returns the EtherType of the packet, regardless of whether it is * vlan encapsulated (normal or hardware accelerated) or not. */
static inline __be16 __vlan_get_protocol(struct sk_buff *skb, __be16 type, int *depth) { unsigned int vlan_depth = skb->mac_len; /* if type is 802.1Q/AD then the header should already be * present at mac_len - VLAN_HLEN (if mac_len > 0), or at * ETH_HLEN otherwise */ if (eth_type_vlan(type)) { if (vlan_depth) { if (WARN_ON(vlan_depth < VLAN_HLEN)) return 0; vlan_depth -= VLAN_HLEN; } else { vlan_depth = ETH_HLEN; } do { struct vlan_hdr *vh; if (unlikely(!pskb_may_pull(skb, vlan_depth + VLAN_HLEN))) return 0; vh = (struct vlan_hdr *)(skb->data + vlan_depth); type = vh->h_vlan_encapsulated_proto; vlan_depth += VLAN_HLEN; } while (eth_type_vlan(type)); } if (depth) *depth = vlan_depth; return type; }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita10072.99%133.33%
Hao Zheng3525.55%133.33%
Eric Garver21.46%133.33%
Total137100.00%3100.00%

/** * vlan_get_protocol - get protocol EtherType. * @skb: skbuff to query * * Returns the EtherType of the packet, regardless of whether it is * vlan encapsulated (normal or hardware accelerated) or not. */
static inline __be16 vlan_get_protocol(struct sk_buff *skb) { return __vlan_get_protocol(skb, skb->protocol, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita2083.33%150.00%
Hao Zheng416.67%150.00%
Total24100.00%2100.00%


static inline void vlan_set_encap_proto(struct sk_buff *skb, struct vlan_hdr *vhdr) { __be16 proto; unsigned short *rawp; /* * Was a VLAN packet, grab the encapsulated protocol, which the layer * three protocols care about. */ proto = vhdr->h_vlan_encapsulated_proto; if (eth_proto_is_802_3(proto)) { skb->protocol = proto; return; } rawp = (unsigned short *)(vhdr + 1); if (*rawp == 0xFFFF) /* * This is a magic hack to spot IPX packets. Older Novell * breaks the protocol design and runs IPX over 802.3 without * an 802.2 LLC layer. We look for FFFF which isn't a used * 802.2 SSAP/DSAP. This won't work for fault tolerant netware * but does for the rest. */ skb->protocol = htons(ETH_P_802_3); else /* * Real 802.2 LLC */ skb->protocol = htons(ETH_P_802_2); }

Contributors

PersonTokensPropCommitsCommitProp
Pravin B Shelar7887.64%133.33%
Américo Wang1011.24%133.33%
Alexander Duyck11.12%133.33%
Total89100.00%3100.00%

/** * skb_vlan_tagged - check if skb is vlan tagged. * @skb: skbuff to query * * Returns true if the skb is tagged, regardless of whether it is hardware * accelerated or not. */
static inline bool skb_vlan_tagged(const struct sk_buff *skb) { if (!skb_vlan_tag_present(skb) && likely(!eth_type_vlan(skb->protocol))) return false; return true; }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita3694.74%150.00%
Eric Garver25.26%150.00%
Total38100.00%2100.00%

/** * skb_vlan_tagged_multi - check if skb is vlan tagged with multiple headers. * @skb: skbuff to query * * Returns true if the skb is tagged with multiple vlan headers, regardless * of whether it is hardware accelerated or not. */
static inline bool skb_vlan_tagged_multi(const struct sk_buff *skb) { __be16 protocol = skb->protocol; if (!skb_vlan_tag_present(skb)) { struct vlan_ethhdr *veh; if (likely(!eth_type_vlan(protocol))) return false; veh = (struct vlan_ethhdr *)skb->data; protocol = veh->h_vlan_encapsulated_proto; } if (!eth_type_vlan(protocol)) return false; return true; }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita7695.00%150.00%
Eric Garver45.00%150.00%
Total80100.00%2100.00%

/** * vlan_features_check - drop unsafe features for skb with multiple tags. * @skb: skbuff to query * @features: features to be checked * * Returns features without unsafe ones if the skb has multiple tags. */
static inline netdev_features_t vlan_features_check(const struct sk_buff *skb, netdev_features_t features) { if (skb_vlan_tagged_multi(skb)) { /* In the case of multi-tagged packets, use a direct mask * instead of using netdev_interesect_features(), to make * sure that only devices supporting NETIF_F_HW_CSUM will * have checksum offloading support. */ features &= NETIF_F_SG | NETIF_F_HIGHDMA | NETIF_F_HW_CSUM | NETIF_F_FRAGLIST | NETIF_F_HW_VLAN_CTAG_TX | NETIF_F_HW_VLAN_STAG_TX; } return features; }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita3683.72%133.33%
Vlad Yasevich613.95%133.33%
Tom Herbert12.33%133.33%
Total43100.00%3100.00%

/** * compare_vlan_header - Compare two vlan headers * @h1: Pointer to vlan header * @h2: Pointer to vlan header * * Compare two vlan headers, returns 0 if equal. * * Please note that alignment of h1 & h2 are only guaranteed to be 16 bits. */
static inline unsigned long compare_vlan_header(const struct vlan_hdr *h1, const struct vlan_hdr *h2) { #if defined(CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS) return *(u32 *)h1 ^ *(u32 *)h2; #else return ((__force u32)h1->h_vlan_TCI ^ (__force u32)h2->h_vlan_TCI) | ((__force u32)h1->h_vlan_encapsulated_proto ^ (__force u32)h2->h_vlan_encapsulated_proto); #endif }

Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita82100.00%1100.00%
Total82100.00%1100.00%

#endif /* !(_LINUX_IF_VLAN_H_) */

Overall Contributors

PersonTokensPropCommitsCommitProp
Toshiaki Makita48924.68%68.33%
Jiri Pirko32516.41%1216.67%
Patrick McHardy22911.56%1419.44%
Shmulik Hen21510.85%11.39%
David S. Miller1879.44%22.78%
Pravin B Shelar783.94%11.39%
Linus Torvalds723.63%11.39%
Vlad Yasevich582.93%34.17%
Eric Garver462.32%11.39%
Hao Zheng391.97%11.39%
Ding Tianhong321.62%22.78%
Hannes Frederic Sowa311.56%11.39%
Eyal Perry301.51%11.39%
Arnaldo Carvalho de Melo291.46%22.78%
Eric Dumazet271.36%22.78%
Neil Horman180.91%11.39%
Jesse Gross160.81%34.17%
Américo Wang100.50%11.39%
Stephen Hemminger80.40%22.78%
Hadar Hen Zion70.35%11.39%
Jarek Poplawski60.30%11.39%
Florian Zumbiehl50.25%11.39%
Eric W. Biedermann40.20%11.39%
Al Viro30.15%11.39%
Alexey Dobriyan30.15%22.78%
David Howells30.15%11.39%
Vivien Didelot30.15%11.39%
Paul Gortmaker30.15%11.39%
Olaf Hering10.05%11.39%
Herbert Xu10.05%11.39%
Alexander Duyck10.05%11.39%
Joe Perches10.05%11.39%
Tom Herbert10.05%11.39%
Total1981100.00%72100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.