blob: 5229a72c7ea15ed421f6649ac55b5e66da5a9c28 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __BEN_VLAN_802_1Q_INC__
2#define __BEN_VLAN_802_1Q_INC__
3
4#include <linux/if_vlan.h>
5
Linus Torvalds1da177e2005-04-16 15:20:36 -07006#define VLAN_GRP_HASH_SHIFT 5
7#define VLAN_GRP_HASH_SIZE (1 << VLAN_GRP_HASH_SHIFT)
8#define VLAN_GRP_HASH_MASK (VLAN_GRP_HASH_SIZE - 1)
9
10/* Find a VLAN device by the MAC address of its Ethernet device, and
11 * it's VLAN ID. The default configuration is to have VLAN's scope
12 * to be box-wide, so the MAC will be ignored. The mac will only be
13 * looked at if we are configured to have a separate set of VLANs per
14 * each MAC addressable interface. Note that this latter option does
15 * NOT follow the spec for VLANs, but may be useful for doing very
16 * large quantities of VLAN MUX/DEMUX onto FrameRelay or ATM PVCs.
17 *
18 * Must be invoked with rcu_read_lock (ie preempt disabled)
19 * or with RTNL.
20 */
Patrick McHardy2029cc22008-01-21 00:26:41 -080021struct net_device *__find_vlan_dev(struct net_device *real_dev,
Linus Torvalds1da177e2005-04-16 15:20:36 -070022 unsigned short VID); /* vlan.c */
23
24/* found in vlan_dev.c */
Linus Torvalds1da177e2005-04-16 15:20:36 -070025int vlan_skb_recv(struct sk_buff *skb, struct net_device *dev,
YOSHIFUJI Hideaki122952f2007-02-09 23:24:25 +090026 struct packet_type *ptype, struct net_device *orig_dev);
Patrick McHardyc17d8872007-06-13 12:05:22 -070027void vlan_dev_set_ingress_priority(const struct net_device *dev,
28 u32 skb_prio, short vlan_prio);
29int vlan_dev_set_egress_priority(const struct net_device *dev,
30 u32 skb_prio, short vlan_prio);
31int vlan_dev_set_vlan_flag(const struct net_device *dev,
32 u32 flag, short flag_val);
33void vlan_dev_get_realdev_name(const struct net_device *dev, char *result);
34void vlan_dev_get_vid(const struct net_device *dev, unsigned short *result);
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
Patrick McHardy07b5b172007-06-13 12:07:54 -070036int vlan_check_real_dev(struct net_device *real_dev, unsigned short vlan_id);
37void vlan_setup(struct net_device *dev);
38int register_vlan_dev(struct net_device *dev);
Patrick McHardyaf301512008-01-21 00:25:50 -080039void unregister_vlan_dev(struct net_device *dev);
Patrick McHardy07b5b172007-06-13 12:07:54 -070040
41int vlan_netlink_init(void);
42void vlan_netlink_fini(void);
43
44extern struct rtnl_link_ops vlan_link_ops;
45
Pavel Emelyanov802fb172008-04-02 00:08:01 -070046static inline int is_vlan_dev(struct net_device *dev)
47{
48 return dev->priv_flags & IFF_802_1Q_VLAN;
49}
50
Pavel Emelyanovd9ed0f02008-04-16 00:49:09 -070051extern int vlan_net_id;
52
Pavel Emelyanova59a8c12008-04-16 00:51:51 -070053struct proc_dir_entry;
54
Pavel Emelyanovd9ed0f02008-04-16 00:49:09 -070055struct vlan_net {
Pavel Emelyanova59a8c12008-04-16 00:51:51 -070056 /* /proc/net/vlan */
57 struct proc_dir_entry *proc_vlan_dir;
58 /* /proc/net/vlan/config */
59 struct proc_dir_entry *proc_vlan_conf;
Pavel Emelyanov7a17a2f2008-04-16 00:54:39 -070060 /* Determines interface naming scheme. */
61 unsigned short name_type;
Pavel Emelyanovd9ed0f02008-04-16 00:49:09 -070062};
63
Linus Torvalds1da177e2005-04-16 15:20:36 -070064#endif /* !(__BEN_VLAN_802_1Q_INC__) */