diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/8021q/vlan.c | 4 | ||||
-rw-r--r-- | net/8021q/vlan.h | 50 | ||||
-rw-r--r-- | net/8021q/vlan_core.c | 12 | ||||
-rw-r--r-- | net/8021q/vlan_dev.c | 5 |
4 files changed, 62 insertions, 9 deletions
diff --git a/net/8021q/vlan.c b/net/8021q/vlan.c index 8141e2dc510b..7a2625d2f9a0 100644 --- a/net/8021q/vlan.c +++ b/net/8021q/vlan.c | |||
@@ -543,7 +543,6 @@ static struct notifier_block vlan_notifier_block __read_mostly = { | |||
543 | static int vlan_ioctl_handler(struct net *net, void __user *arg) | 543 | static int vlan_ioctl_handler(struct net *net, void __user *arg) |
544 | { | 544 | { |
545 | int err; | 545 | int err; |
546 | unsigned short vid = 0; | ||
547 | struct vlan_ioctl_args args; | 546 | struct vlan_ioctl_args args; |
548 | struct net_device *dev = NULL; | 547 | struct net_device *dev = NULL; |
549 | 548 | ||
@@ -644,8 +643,7 @@ static int vlan_ioctl_handler(struct net *net, void __user *arg) | |||
644 | 643 | ||
645 | case GET_VLAN_VID_CMD: | 644 | case GET_VLAN_VID_CMD: |
646 | err = 0; | 645 | err = 0; |
647 | vlan_dev_get_vid(dev, &vid); | 646 | args.u.VID = vlan_dev_vlan_id(dev); |
648 | args.u.VID = vid; | ||
649 | if (copy_to_user(arg, &args, | 647 | if (copy_to_user(arg, &args, |
650 | sizeof(struct vlan_ioctl_args))) | 648 | sizeof(struct vlan_ioctl_args))) |
651 | err = -EFAULT; | 649 | err = -EFAULT; |
diff --git a/net/8021q/vlan.h b/net/8021q/vlan.h index 7cc1a97c42fc..14c421e033f2 100644 --- a/net/8021q/vlan.h +++ b/net/8021q/vlan.h | |||
@@ -3,6 +3,55 @@ | |||
3 | 3 | ||
4 | #include <linux/if_vlan.h> | 4 | #include <linux/if_vlan.h> |
5 | 5 | ||
6 | |||
7 | /** | ||
8 | * struct vlan_priority_tci_mapping - vlan egress priority mappings | ||
9 | * @priority: skb priority | ||
10 | * @vlan_qos: vlan priority: (skb->priority << 13) & 0xE000 | ||
11 | * @next: pointer to next struct | ||
12 | */ | ||
13 | struct vlan_priority_tci_mapping { | ||
14 | u32 priority; | ||
15 | unsigned short vlan_qos; | ||
16 | struct vlan_priority_tci_mapping *next; | ||
17 | }; | ||
18 | |||
19 | /** | ||
20 | * struct vlan_dev_info - VLAN private device data | ||
21 | * @nr_ingress_mappings: number of ingress priority mappings | ||
22 | * @ingress_priority_map: ingress priority mappings | ||
23 | * @nr_egress_mappings: number of egress priority mappings | ||
24 | * @egress_priority_map: hash of egress priority mappings | ||
25 | * @vlan_id: VLAN identifier | ||
26 | * @flags: device flags | ||
27 | * @real_dev: underlying netdevice | ||
28 | * @real_dev_addr: address of underlying netdevice | ||
29 | * @dent: proc dir entry | ||
30 | * @cnt_inc_headroom_on_tx: statistic - number of skb expansions on TX | ||
31 | * @cnt_encap_on_xmit: statistic - number of skb encapsulations on TX | ||
32 | */ | ||
33 | struct vlan_dev_info { | ||
34 | unsigned int nr_ingress_mappings; | ||
35 | u32 ingress_priority_map[8]; | ||
36 | unsigned int nr_egress_mappings; | ||
37 | struct vlan_priority_tci_mapping *egress_priority_map[16]; | ||
38 | |||
39 | unsigned short vlan_id; | ||
40 | unsigned short flags; | ||
41 | |||
42 | struct net_device *real_dev; | ||
43 | unsigned char real_dev_addr[ETH_ALEN]; | ||
44 | |||
45 | struct proc_dir_entry *dent; | ||
46 | unsigned long cnt_inc_headroom_on_tx; | ||
47 | unsigned long cnt_encap_on_xmit; | ||
48 | }; | ||
49 | |||
50 | static inline struct vlan_dev_info *vlan_dev_info(const struct net_device *dev) | ||
51 | { | ||
52 | return netdev_priv(dev); | ||
53 | } | ||
54 | |||
6 | #define VLAN_GRP_HASH_SHIFT 5 | 55 | #define VLAN_GRP_HASH_SHIFT 5 |
7 | #define VLAN_GRP_HASH_SIZE (1 << VLAN_GRP_HASH_SHIFT) | 56 | #define VLAN_GRP_HASH_SIZE (1 << VLAN_GRP_HASH_SHIFT) |
8 | #define VLAN_GRP_HASH_MASK (VLAN_GRP_HASH_SIZE - 1) | 57 | #define VLAN_GRP_HASH_MASK (VLAN_GRP_HASH_SIZE - 1) |
@@ -30,7 +79,6 @@ int vlan_dev_set_egress_priority(const struct net_device *dev, | |||
30 | u32 skb_prio, short vlan_prio); | 79 | u32 skb_prio, short vlan_prio); |
31 | int vlan_dev_change_flags(const struct net_device *dev, u32 flag, u32 mask); | 80 | int vlan_dev_change_flags(const struct net_device *dev, u32 flag, u32 mask); |
32 | void vlan_dev_get_realdev_name(const struct net_device *dev, char *result); | 81 | void vlan_dev_get_realdev_name(const struct net_device *dev, char *result); |
33 | void vlan_dev_get_vid(const struct net_device *dev, unsigned short *result); | ||
34 | 82 | ||
35 | int vlan_check_real_dev(struct net_device *real_dev, unsigned short vlan_id); | 83 | int vlan_check_real_dev(struct net_device *real_dev, unsigned short vlan_id); |
36 | void vlan_setup(struct net_device *dev); | 84 | void vlan_setup(struct net_device *dev); |
diff --git a/net/8021q/vlan_core.c b/net/8021q/vlan_core.c index 85c94edb000f..f980b9154cc3 100644 --- a/net/8021q/vlan_core.c +++ b/net/8021q/vlan_core.c | |||
@@ -46,3 +46,15 @@ int __vlan_hwaccel_rx(struct sk_buff *skb, struct vlan_group *grp, | |||
46 | return (polling ? netif_receive_skb(skb) : netif_rx(skb)); | 46 | return (polling ? netif_receive_skb(skb) : netif_rx(skb)); |
47 | } | 47 | } |
48 | EXPORT_SYMBOL(__vlan_hwaccel_rx); | 48 | EXPORT_SYMBOL(__vlan_hwaccel_rx); |
49 | |||
50 | struct net_device *vlan_dev_real_dev(const struct net_device *dev) | ||
51 | { | ||
52 | return vlan_dev_info(dev)->real_dev; | ||
53 | } | ||
54 | EXPORT_SYMBOL_GPL(vlan_dev_real_dev); | ||
55 | |||
56 | u16 vlan_dev_vlan_id(const struct net_device *dev) | ||
57 | { | ||
58 | return vlan_dev_info(dev)->vlan_id; | ||
59 | } | ||
60 | EXPORT_SYMBOL_GPL(vlan_dev_vlan_id); | ||
diff --git a/net/8021q/vlan_dev.c b/net/8021q/vlan_dev.c index 722697d31e4f..2aab294c5744 100644 --- a/net/8021q/vlan_dev.c +++ b/net/8021q/vlan_dev.c | |||
@@ -531,11 +531,6 @@ void vlan_dev_get_realdev_name(const struct net_device *dev, char *result) | |||
531 | strncpy(result, vlan_dev_info(dev)->real_dev->name, 23); | 531 | strncpy(result, vlan_dev_info(dev)->real_dev->name, 23); |
532 | } | 532 | } |
533 | 533 | ||
534 | void vlan_dev_get_vid(const struct net_device *dev, unsigned short *result) | ||
535 | { | ||
536 | *result = vlan_dev_info(dev)->vlan_id; | ||
537 | } | ||
538 | |||
539 | static int vlan_dev_open(struct net_device *dev) | 534 | static int vlan_dev_open(struct net_device *dev) |
540 | { | 535 | { |
541 | struct vlan_dev_info *vlan = vlan_dev_info(dev); | 536 | struct vlan_dev_info *vlan = vlan_dev_info(dev); |