mrp.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. #ifndef _NET_MRP_H
  2. #define _NET_MRP_H
  3. #define MRP_END_MARK 0x0
  4. struct mrp_pdu_hdr {
  5. u8 version;
  6. };
  7. struct mrp_msg_hdr {
  8. u8 attrtype;
  9. u8 attrlen;
  10. };
  11. struct mrp_vecattr_hdr {
  12. __be16 lenflags;
  13. unsigned char firstattrvalue[];
  14. #define MRP_VECATTR_HDR_LEN_MASK cpu_to_be16(0x1FFF)
  15. #define MRP_VECATTR_HDR_FLAG_LA cpu_to_be16(0x2000)
  16. };
  17. enum mrp_vecattr_event {
  18. MRP_VECATTR_EVENT_NEW,
  19. MRP_VECATTR_EVENT_JOIN_IN,
  20. MRP_VECATTR_EVENT_IN,
  21. MRP_VECATTR_EVENT_JOIN_MT,
  22. MRP_VECATTR_EVENT_MT,
  23. MRP_VECATTR_EVENT_LV,
  24. __MRP_VECATTR_EVENT_MAX
  25. };
  26. struct mrp_skb_cb {
  27. struct mrp_msg_hdr *mh;
  28. struct mrp_vecattr_hdr *vah;
  29. unsigned char attrvalue[];
  30. };
  31. static inline struct mrp_skb_cb *mrp_cb(struct sk_buff *skb)
  32. {
  33. BUILD_BUG_ON(sizeof(struct mrp_skb_cb) >
  34. FIELD_SIZEOF(struct sk_buff, cb));
  35. return (struct mrp_skb_cb *)skb->cb;
  36. }
  37. enum mrp_applicant_state {
  38. MRP_APPLICANT_INVALID,
  39. MRP_APPLICANT_VO,
  40. MRP_APPLICANT_VP,
  41. MRP_APPLICANT_VN,
  42. MRP_APPLICANT_AN,
  43. MRP_APPLICANT_AA,
  44. MRP_APPLICANT_QA,
  45. MRP_APPLICANT_LA,
  46. MRP_APPLICANT_AO,
  47. MRP_APPLICANT_QO,
  48. MRP_APPLICANT_AP,
  49. MRP_APPLICANT_QP,
  50. __MRP_APPLICANT_MAX
  51. };
  52. #define MRP_APPLICANT_MAX (__MRP_APPLICANT_MAX - 1)
  53. enum mrp_event {
  54. MRP_EVENT_NEW,
  55. MRP_EVENT_JOIN,
  56. MRP_EVENT_LV,
  57. MRP_EVENT_TX,
  58. MRP_EVENT_R_NEW,
  59. MRP_EVENT_R_JOIN_IN,
  60. MRP_EVENT_R_IN,
  61. MRP_EVENT_R_JOIN_MT,
  62. MRP_EVENT_R_MT,
  63. MRP_EVENT_R_LV,
  64. MRP_EVENT_R_LA,
  65. MRP_EVENT_REDECLARE,
  66. MRP_EVENT_PERIODIC,
  67. __MRP_EVENT_MAX
  68. };
  69. #define MRP_EVENT_MAX (__MRP_EVENT_MAX - 1)
  70. enum mrp_tx_action {
  71. MRP_TX_ACTION_NONE,
  72. MRP_TX_ACTION_S_NEW,
  73. MRP_TX_ACTION_S_JOIN_IN,
  74. MRP_TX_ACTION_S_JOIN_IN_OPTIONAL,
  75. MRP_TX_ACTION_S_IN_OPTIONAL,
  76. MRP_TX_ACTION_S_LV,
  77. };
  78. struct mrp_attr {
  79. struct rb_node node;
  80. enum mrp_applicant_state state;
  81. u8 type;
  82. u8 len;
  83. unsigned char value[];
  84. };
  85. enum mrp_applications {
  86. MRP_APPLICATION_MVRP,
  87. __MRP_APPLICATION_MAX
  88. };
  89. #define MRP_APPLICATION_MAX (__MRP_APPLICATION_MAX - 1)
  90. struct mrp_application {
  91. enum mrp_applications type;
  92. unsigned int maxattr;
  93. struct packet_type pkttype;
  94. unsigned char group_address[ETH_ALEN];
  95. u8 version;
  96. };
  97. struct mrp_applicant {
  98. struct mrp_application *app;
  99. struct net_device *dev;
  100. struct timer_list join_timer;
  101. struct timer_list periodic_timer;
  102. spinlock_t lock;
  103. struct sk_buff_head queue;
  104. struct sk_buff *pdu;
  105. struct rb_root mad;
  106. struct rcu_head rcu;
  107. };
  108. struct mrp_port {
  109. struct mrp_applicant __rcu *applicants[MRP_APPLICATION_MAX + 1];
  110. struct rcu_head rcu;
  111. };
  112. int mrp_register_application(struct mrp_application *app);
  113. void mrp_unregister_application(struct mrp_application *app);
  114. int mrp_init_applicant(struct net_device *dev, struct mrp_application *app);
  115. void mrp_uninit_applicant(struct net_device *dev, struct mrp_application *app);
  116. int mrp_request_join(const struct net_device *dev,
  117. const struct mrp_application *app,
  118. const void *value, u8 len, u8 type);
  119. void mrp_request_leave(const struct net_device *dev,
  120. const struct mrp_application *app,
  121. const void *value, u8 len, u8 type);
  122. #endif /* _NET_MRP_H */