proto.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. /*
  2. * Copyright (c) 2013 Broadcom Corporation
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
  11. * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
  13. * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef BRCMFMAC_PROTO_H
  17. #define BRCMFMAC_PROTO_H
  18. enum proto_addr_mode {
  19. ADDR_INDIRECT = 0,
  20. ADDR_DIRECT
  21. };
  22. struct brcmf_skb_reorder_data {
  23. u8 *reorder;
  24. };
  25. struct brcmf_proto {
  26. int (*hdrpull)(struct brcmf_pub *drvr, bool do_fws,
  27. struct sk_buff *skb, struct brcmf_if **ifp);
  28. int (*query_dcmd)(struct brcmf_pub *drvr, int ifidx, uint cmd,
  29. void *buf, uint len);
  30. int (*set_dcmd)(struct brcmf_pub *drvr, int ifidx, uint cmd, void *buf,
  31. uint len);
  32. int (*tx_queue_data)(struct brcmf_pub *drvr, int ifidx,
  33. struct sk_buff *skb);
  34. int (*txdata)(struct brcmf_pub *drvr, int ifidx, u8 offset,
  35. struct sk_buff *skb);
  36. void (*configure_addr_mode)(struct brcmf_pub *drvr, int ifidx,
  37. enum proto_addr_mode addr_mode);
  38. void (*delete_peer)(struct brcmf_pub *drvr, int ifidx,
  39. u8 peer[ETH_ALEN]);
  40. void (*add_tdls_peer)(struct brcmf_pub *drvr, int ifidx,
  41. u8 peer[ETH_ALEN]);
  42. void (*rxreorder)(struct brcmf_if *ifp, struct sk_buff *skb);
  43. void (*add_if)(struct brcmf_if *ifp);
  44. void (*del_if)(struct brcmf_if *ifp);
  45. void (*reset_if)(struct brcmf_if *ifp);
  46. int (*init_done)(struct brcmf_pub *drvr);
  47. void *pd;
  48. };
  49. int brcmf_proto_attach(struct brcmf_pub *drvr);
  50. void brcmf_proto_detach(struct brcmf_pub *drvr);
  51. static inline int brcmf_proto_hdrpull(struct brcmf_pub *drvr, bool do_fws,
  52. struct sk_buff *skb,
  53. struct brcmf_if **ifp)
  54. {
  55. struct brcmf_if *tmp = NULL;
  56. /* assure protocol is always called with
  57. * non-null initialized pointer.
  58. */
  59. if (ifp)
  60. *ifp = NULL;
  61. else
  62. ifp = &tmp;
  63. return drvr->proto->hdrpull(drvr, do_fws, skb, ifp);
  64. }
  65. static inline int brcmf_proto_query_dcmd(struct brcmf_pub *drvr, int ifidx,
  66. uint cmd, void *buf, uint len)
  67. {
  68. return drvr->proto->query_dcmd(drvr, ifidx, cmd, buf, len);
  69. }
  70. static inline int brcmf_proto_set_dcmd(struct brcmf_pub *drvr, int ifidx,
  71. uint cmd, void *buf, uint len)
  72. {
  73. return drvr->proto->set_dcmd(drvr, ifidx, cmd, buf, len);
  74. }
  75. static inline int brcmf_proto_tx_queue_data(struct brcmf_pub *drvr, int ifidx,
  76. struct sk_buff *skb)
  77. {
  78. return drvr->proto->tx_queue_data(drvr, ifidx, skb);
  79. }
  80. static inline int brcmf_proto_txdata(struct brcmf_pub *drvr, int ifidx,
  81. u8 offset, struct sk_buff *skb)
  82. {
  83. return drvr->proto->txdata(drvr, ifidx, offset, skb);
  84. }
  85. static inline void
  86. brcmf_proto_configure_addr_mode(struct brcmf_pub *drvr, int ifidx,
  87. enum proto_addr_mode addr_mode)
  88. {
  89. drvr->proto->configure_addr_mode(drvr, ifidx, addr_mode);
  90. }
  91. static inline void
  92. brcmf_proto_delete_peer(struct brcmf_pub *drvr, int ifidx, u8 peer[ETH_ALEN])
  93. {
  94. drvr->proto->delete_peer(drvr, ifidx, peer);
  95. }
  96. static inline void
  97. brcmf_proto_add_tdls_peer(struct brcmf_pub *drvr, int ifidx, u8 peer[ETH_ALEN])
  98. {
  99. drvr->proto->add_tdls_peer(drvr, ifidx, peer);
  100. }
  101. static inline bool brcmf_proto_is_reorder_skb(struct sk_buff *skb)
  102. {
  103. struct brcmf_skb_reorder_data *rd;
  104. rd = (struct brcmf_skb_reorder_data *)skb->cb;
  105. return !!rd->reorder;
  106. }
  107. static inline void
  108. brcmf_proto_rxreorder(struct brcmf_if *ifp, struct sk_buff *skb)
  109. {
  110. ifp->drvr->proto->rxreorder(ifp, skb);
  111. }
  112. static inline void
  113. brcmf_proto_add_if(struct brcmf_pub *drvr, struct brcmf_if *ifp)
  114. {
  115. if (!drvr->proto->add_if)
  116. return;
  117. drvr->proto->add_if(ifp);
  118. }
  119. static inline void
  120. brcmf_proto_del_if(struct brcmf_pub *drvr, struct brcmf_if *ifp)
  121. {
  122. if (!drvr->proto->del_if)
  123. return;
  124. drvr->proto->del_if(ifp);
  125. }
  126. static inline void
  127. brcmf_proto_reset_if(struct brcmf_pub *drvr, struct brcmf_if *ifp)
  128. {
  129. if (!drvr->proto->reset_if)
  130. return;
  131. drvr->proto->reset_if(ifp);
  132. }
  133. static inline int
  134. brcmf_proto_init_done(struct brcmf_pub *drvr)
  135. {
  136. if (!drvr->proto->init_done)
  137. return 0;
  138. return drvr->proto->init_done(drvr);
  139. }
  140. #endif /* BRCMFMAC_PROTO_H */