blob: 639e2544a804040c0497fcc08eb15658ae1c56af [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);
Patrick McHardyb3ce0322008-07-05 21:26:27 -070031int vlan_dev_change_flags(const struct net_device *dev, u32 flag, u32 mask);
Patrick McHardyc17d8872007-06-13 12:05:22 -070032void vlan_dev_get_realdev_name(const struct net_device *dev, char *result);
33void vlan_dev_get_vid(const struct net_device *dev, unsigned short *result);
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
Patrick McHardy07b5b172007-06-13 12:07:54 -070035int vlan_check_real_dev(struct net_device *real_dev, unsigned short vlan_id);
36void vlan_setup(struct net_device *dev);
37int register_vlan_dev(struct net_device *dev);
Patrick McHardyaf301512008-01-21 00:25:50 -080038void unregister_vlan_dev(struct net_device *dev);
Patrick McHardy07b5b172007-06-13 12:07:54 -070039
40int vlan_netlink_init(void);
41void vlan_netlink_fini(void);
42
43extern struct rtnl_link_ops vlan_link_ops;
44
Pavel Emelyanov802fb172008-04-02 00:08:01 -070045static inline int is_vlan_dev(struct net_device *dev)
46{
47 return dev->priv_flags & IFF_802_1Q_VLAN;
48}
49
Pavel Emelyanovd9ed0f02008-04-16 00:49:09 -070050extern int vlan_net_id;
51
Pavel Emelyanova59a8c12008-04-16 00:51:51 -070052struct proc_dir_entry;
53
Pavel Emelyanovd9ed0f02008-04-16 00:49:09 -070054struct vlan_net {
Pavel Emelyanova59a8c12008-04-16 00:51:51 -070055 /* /proc/net/vlan */
56 struct proc_dir_entry *proc_vlan_dir;
57 /* /proc/net/vlan/config */
58 struct proc_dir_entry *proc_vlan_conf;
Pavel Emelyanov7a17a2f2008-04-16 00:54:39 -070059 /* Determines interface naming scheme. */
60 unsigned short name_type;
Pavel Emelyanovd9ed0f02008-04-16 00:49:09 -070061};
62
Linus Torvalds1da177e2005-04-16 15:20:36 -070063#endif /* !(__BEN_VLAN_802_1Q_INC__) */