proto.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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, int *fwerr);
  30. int (*set_dcmd)(struct brcmf_pub *drvr, int ifidx, uint cmd, void *buf,
  31. uint len, int *fwerr);
  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 (*debugfs_create)(struct brcmf_pub *drvr);
  48. void *pd;
  49. };
  50. int brcmf_proto_attach(struct brcmf_pub *drvr);
  51. void brcmf_proto_detach(struct brcmf_pub *drvr);
  52. static inline int brcmf_proto_hdrpull(struct brcmf_pub *drvr, bool do_fws,
  53. struct sk_buff *skb,
  54. struct brcmf_if **ifp)
  55. {
  56. struct brcmf_if *tmp = NULL;
  57. /* assure protocol is always called with
  58. * non-null initialized pointer.
  59. */
  60. if (ifp)
  61. *ifp = NULL;
  62. else
  63. ifp = &tmp;
  64. return drvr->proto->hdrpull(drvr, do_fws, skb, ifp);
  65. }
  66. static inline int brcmf_proto_query_dcmd(struct brcmf_pub *drvr, int ifidx,
  67. uint cmd, void *buf, uint len,
  68. int *fwerr)
  69. {
  70. return drvr->proto->query_dcmd(drvr, ifidx, cmd, buf, len,fwerr);
  71. }
  72. static inline int brcmf_proto_set_dcmd(struct brcmf_pub *drvr, int ifidx,
  73. uint cmd, void *buf, uint len,
  74. int *fwerr)
  75. {
  76. return drvr->proto->set_dcmd(drvr, ifidx, cmd, buf, len, fwerr);
  77. }
  78. static inline int brcmf_proto_tx_queue_data(struct brcmf_pub *drvr, int ifidx,
  79. struct sk_buff *skb)
  80. {
  81. return drvr->proto->tx_queue_data(drvr, ifidx, skb);
  82. }
  83. static inline int brcmf_proto_txdata(struct brcmf_pub *drvr, int ifidx,
  84. u8 offset, struct sk_buff *skb)
  85. {
  86. return drvr->proto->txdata(drvr, ifidx, offset, skb);
  87. }
  88. static inline void
  89. brcmf_proto_configure_addr_mode(struct brcmf_pub *drvr, int ifidx,
  90. enum proto_addr_mode addr_mode)
  91. {
  92. drvr->proto->configure_addr_mode(drvr, ifidx, addr_mode);
  93. }
  94. static inline void
  95. brcmf_proto_delete_peer(struct brcmf_pub *drvr, int ifidx, u8 peer[ETH_ALEN])
  96. {
  97. drvr->proto->delete_peer(drvr, ifidx, peer);
  98. }
  99. static inline void
  100. brcmf_proto_add_tdls_peer(struct brcmf_pub *drvr, int ifidx, u8 peer[ETH_ALEN])
  101. {
  102. drvr->proto->add_tdls_peer(drvr, ifidx, peer);
  103. }
  104. static inline bool brcmf_proto_is_reorder_skb(struct sk_buff *skb)
  105. {
  106. struct brcmf_skb_reorder_data *rd;
  107. rd = (struct brcmf_skb_reorder_data *)skb->cb;
  108. return !!rd->reorder;
  109. }
  110. static inline void
  111. brcmf_proto_rxreorder(struct brcmf_if *ifp, struct sk_buff *skb)
  112. {
  113. ifp->drvr->proto->rxreorder(ifp, skb);
  114. }
  115. static inline void
  116. brcmf_proto_add_if(struct brcmf_pub *drvr, struct brcmf_if *ifp)
  117. {
  118. if (!drvr->proto->add_if)
  119. return;
  120. drvr->proto->add_if(ifp);
  121. }
  122. static inline void
  123. brcmf_proto_del_if(struct brcmf_pub *drvr, struct brcmf_if *ifp)
  124. {
  125. if (!drvr->proto->del_if)
  126. return;
  127. drvr->proto->del_if(ifp);
  128. }
  129. static inline void
  130. brcmf_proto_reset_if(struct brcmf_pub *drvr, struct brcmf_if *ifp)
  131. {
  132. if (!drvr->proto->reset_if)
  133. return;
  134. drvr->proto->reset_if(ifp);
  135. }
  136. static inline int
  137. brcmf_proto_init_done(struct brcmf_pub *drvr)
  138. {
  139. if (!drvr->proto->init_done)
  140. return 0;
  141. return drvr->proto->init_done(drvr);
  142. }
  143. static inline void
  144. brcmf_proto_debugfs_create(struct brcmf_pub *drvr)
  145. {
  146. drvr->proto->debugfs_create(drvr);
  147. }
  148. #endif /* BRCMFMAC_PROTO_H */