vlan.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #ifndef __BEN_VLAN_802_1Q_INC__
  2. #define __BEN_VLAN_802_1Q_INC__
  3. #include <linux/if_vlan.h>
  4. #define VLAN_GRP_HASH_SHIFT 5
  5. #define VLAN_GRP_HASH_SIZE (1 << VLAN_GRP_HASH_SHIFT)
  6. #define VLAN_GRP_HASH_MASK (VLAN_GRP_HASH_SIZE - 1)
  7. /* Find a VLAN device by the MAC address of its Ethernet device, and
  8. * it's VLAN ID. The default configuration is to have VLAN's scope
  9. * to be box-wide, so the MAC will be ignored. The mac will only be
  10. * looked at if we are configured to have a separate set of VLANs per
  11. * each MAC addressable interface. Note that this latter option does
  12. * NOT follow the spec for VLANs, but may be useful for doing very
  13. * large quantities of VLAN MUX/DEMUX onto FrameRelay or ATM PVCs.
  14. *
  15. * Must be invoked with rcu_read_lock (ie preempt disabled)
  16. * or with RTNL.
  17. */
  18. struct net_device *__find_vlan_dev(struct net_device *real_dev,
  19. unsigned short VID); /* vlan.c */
  20. /* found in vlan_dev.c */
  21. int vlan_skb_recv(struct sk_buff *skb, struct net_device *dev,
  22. struct packet_type *ptype, struct net_device *orig_dev);
  23. void vlan_dev_set_ingress_priority(const struct net_device *dev,
  24. u32 skb_prio, short vlan_prio);
  25. int vlan_dev_set_egress_priority(const struct net_device *dev,
  26. u32 skb_prio, short vlan_prio);
  27. int vlan_dev_change_flags(const struct net_device *dev, u32 flag, u32 mask);
  28. void vlan_dev_get_realdev_name(const struct net_device *dev, char *result);
  29. void vlan_dev_get_vid(const struct net_device *dev, unsigned short *result);
  30. int vlan_check_real_dev(struct net_device *real_dev, unsigned short vlan_id);
  31. void vlan_setup(struct net_device *dev);
  32. int register_vlan_dev(struct net_device *dev);
  33. void unregister_vlan_dev(struct net_device *dev);
  34. static inline u32 vlan_get_ingress_priority(struct net_device *dev,
  35. unsigned short vlan_tag)
  36. {
  37. struct vlan_dev_info *vip = vlan_dev_info(dev);
  38. return vip->ingress_priority_map[(vlan_tag >> 13) & 0x7];
  39. }
  40. #ifdef CONFIG_VLAN_8021Q_GVRP
  41. extern int vlan_gvrp_request_join(const struct net_device *dev);
  42. extern void vlan_gvrp_request_leave(const struct net_device *dev);
  43. extern int vlan_gvrp_init_applicant(struct net_device *dev);
  44. extern void vlan_gvrp_uninit_applicant(struct net_device *dev);
  45. extern int vlan_gvrp_init(void);
  46. extern void vlan_gvrp_uninit(void);
  47. #else
  48. static inline int vlan_gvrp_request_join(const struct net_device *dev) { return 0; }
  49. static inline void vlan_gvrp_request_leave(const struct net_device *dev) {}
  50. static inline int vlan_gvrp_init_applicant(struct net_device *dev) { return 0; }
  51. static inline void vlan_gvrp_uninit_applicant(struct net_device *dev) {}
  52. static inline int vlan_gvrp_init(void) { return 0; }
  53. static inline void vlan_gvrp_uninit(void) {}
  54. #endif
  55. int vlan_netlink_init(void);
  56. void vlan_netlink_fini(void);
  57. extern struct rtnl_link_ops vlan_link_ops;
  58. static inline int is_vlan_dev(struct net_device *dev)
  59. {
  60. return dev->priv_flags & IFF_802_1Q_VLAN;
  61. }
  62. extern int vlan_net_id;
  63. struct proc_dir_entry;
  64. struct vlan_net {
  65. /* /proc/net/vlan */
  66. struct proc_dir_entry *proc_vlan_dir;
  67. /* /proc/net/vlan/config */
  68. struct proc_dir_entry *proc_vlan_conf;
  69. /* Determines interface naming scheme. */
  70. unsigned short name_type;
  71. };
  72. #endif /* !(__BEN_VLAN_802_1Q_INC__) */