brcmu_utils.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. /*
  2. * Copyright (c) 2010 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 _BRCMU_UTILS_H_
  17. #define _BRCMU_UTILS_H_
  18. #include <linux/skbuff.h>
  19. /*
  20. * Spin at most 'us' microseconds while 'exp' is true.
  21. * Caller should explicitly test 'exp' when this completes
  22. * and take appropriate error action if 'exp' is still true.
  23. */
  24. #define SPINWAIT(exp, us) { \
  25. uint countdown = (us) + 9; \
  26. while ((exp) && (countdown >= 10)) {\
  27. udelay(10); \
  28. countdown -= 10; \
  29. } \
  30. }
  31. /* osl multi-precedence packet queue */
  32. #define PKTQ_LEN_DEFAULT 128 /* Max 128 packets */
  33. #define PKTQ_MAX_PREC 16 /* Maximum precedence levels */
  34. #define BCME_STRLEN 64 /* Max string length for BCM errors */
  35. /* the largest reasonable packet buffer driver uses for ethernet MTU in bytes */
  36. #define PKTBUFSZ 2048
  37. #ifndef setbit
  38. #ifndef NBBY /* the BSD family defines NBBY */
  39. #define NBBY 8 /* 8 bits per byte */
  40. #endif /* #ifndef NBBY */
  41. #define setbit(a, i) (((u8 *)a)[(i)/NBBY] |= 1<<((i)%NBBY))
  42. #define clrbit(a, i) (((u8 *)a)[(i)/NBBY] &= ~(1<<((i)%NBBY)))
  43. #define isset(a, i) (((const u8 *)a)[(i)/NBBY] & (1<<((i)%NBBY)))
  44. #define isclr(a, i) ((((const u8 *)a)[(i)/NBBY] & (1<<((i)%NBBY))) == 0)
  45. #endif /* setbit */
  46. #define NBITS(type) (sizeof(type) * 8)
  47. #define NBITVAL(nbits) (1 << (nbits))
  48. #define MAXBITVAL(nbits) ((1 << (nbits)) - 1)
  49. #define NBITMASK(nbits) MAXBITVAL(nbits)
  50. #define MAXNBVAL(nbyte) MAXBITVAL((nbyte) * 8)
  51. /* crc defines */
  52. #define CRC16_INIT_VALUE 0xffff /* Initial CRC16 checksum value */
  53. #define CRC16_GOOD_VALUE 0xf0b8 /* Good final CRC16 checksum value */
  54. /* 18-bytes of Ethernet address buffer length */
  55. #define ETHER_ADDR_STR_LEN 18
  56. struct pktq_prec {
  57. struct sk_buff *head; /* first packet to dequeue */
  58. struct sk_buff *tail; /* last packet to dequeue */
  59. u16 len; /* number of queued packets */
  60. u16 max; /* maximum number of queued packets */
  61. };
  62. /* multi-priority pkt queue */
  63. struct pktq {
  64. u16 num_prec; /* number of precedences in use */
  65. u16 hi_prec; /* rapid dequeue hint (>= highest non-empty prec) */
  66. u16 max; /* total max packets */
  67. u16 len; /* total number of packets */
  68. /*
  69. * q array must be last since # of elements can be either
  70. * PKTQ_MAX_PREC or 1
  71. */
  72. struct pktq_prec q[PKTQ_MAX_PREC];
  73. };
  74. /* operations on a specific precedence in packet queue */
  75. static inline int pktq_plen(struct pktq *pq, int prec)
  76. {
  77. return pq->q[prec].len;
  78. }
  79. static inline int pktq_pavail(struct pktq *pq, int prec)
  80. {
  81. return pq->q[prec].max - pq->q[prec].len;
  82. }
  83. static inline bool pktq_pfull(struct pktq *pq, int prec)
  84. {
  85. return pq->q[prec].len >= pq->q[prec].max;
  86. }
  87. static inline bool pktq_pempty(struct pktq *pq, int prec)
  88. {
  89. return pq->q[prec].len == 0;
  90. }
  91. static inline struct sk_buff *pktq_ppeek(struct pktq *pq, int prec)
  92. {
  93. return pq->q[prec].head;
  94. }
  95. static inline struct sk_buff *pktq_ppeek_tail(struct pktq *pq, int prec)
  96. {
  97. return pq->q[prec].tail;
  98. }
  99. extern struct sk_buff *brcmu_pktq_penq(struct pktq *pq, int prec,
  100. struct sk_buff *p);
  101. extern struct sk_buff *brcmu_pktq_penq_head(struct pktq *pq, int prec,
  102. struct sk_buff *p);
  103. extern struct sk_buff *brcmu_pktq_pdeq(struct pktq *pq, int prec);
  104. extern struct sk_buff *brcmu_pktq_pdeq_tail(struct pktq *pq, int prec);
  105. /* packet primitives */
  106. extern struct sk_buff *brcmu_pkt_buf_get_skb(uint len);
  107. extern void brcmu_pkt_buf_free_skb(struct sk_buff *skb);
  108. /* Empty the queue at particular precedence level */
  109. /* callback function fn(pkt, arg) returns true if pkt belongs to if */
  110. extern void brcmu_pktq_pflush(struct pktq *pq, int prec,
  111. bool dir, bool (*fn)(struct sk_buff *, void *), void *arg);
  112. /* operations on a set of precedences in packet queue */
  113. extern int brcmu_pktq_mlen(struct pktq *pq, uint prec_bmp);
  114. extern struct sk_buff *brcmu_pktq_mdeq(struct pktq *pq, uint prec_bmp,
  115. int *prec_out);
  116. /* operations on packet queue as a whole */
  117. static inline int pktq_len(struct pktq *pq)
  118. {
  119. return (int)pq->len;
  120. }
  121. static inline int pktq_max(struct pktq *pq)
  122. {
  123. return (int)pq->max;
  124. }
  125. static inline int pktq_avail(struct pktq *pq)
  126. {
  127. return (int)(pq->max - pq->len);
  128. }
  129. static inline bool pktq_full(struct pktq *pq)
  130. {
  131. return pq->len >= pq->max;
  132. }
  133. static inline bool pktq_empty(struct pktq *pq)
  134. {
  135. return pq->len == 0;
  136. }
  137. extern void brcmu_pktq_init(struct pktq *pq, int num_prec, int max_len);
  138. /* prec_out may be NULL if caller is not interested in return value */
  139. extern struct sk_buff *brcmu_pktq_peek_tail(struct pktq *pq, int *prec_out);
  140. extern void brcmu_pktq_flush(struct pktq *pq, bool dir,
  141. bool (*fn)(struct sk_buff *, void *), void *arg);
  142. /* externs */
  143. /* packet */
  144. extern uint brcmu_pktfrombuf(struct sk_buff *p,
  145. uint offset, int len, unsigned char *buf);
  146. extern uint brcmu_pkttotlen(struct sk_buff *p);
  147. /* ip address */
  148. struct ipv4_addr;
  149. #ifdef BCMDBG
  150. extern void brcmu_prpkt(const char *msg, struct sk_buff *p0);
  151. #else
  152. #define brcmu_prpkt(a, b)
  153. #endif /* BCMDBG */
  154. /* brcmu_format_flags() bit description structure */
  155. struct brcmu_bit_desc {
  156. u32 bit;
  157. const char *name;
  158. };
  159. /* tag_ID/length/value_buffer tuple */
  160. struct brcmu_tlv {
  161. u8 id;
  162. u8 len;
  163. u8 data[1];
  164. };
  165. /* externs */
  166. /* format/print */
  167. #if defined(BCMDBG)
  168. extern int brcmu_format_flags(const struct brcmu_bit_desc *bd, u32 flags,
  169. char *buf, int len);
  170. extern int brcmu_format_hex(char *str, const void *bytes, int len);
  171. #endif
  172. extern char *brcmu_chipname(uint chipid, char *buf, uint len);
  173. extern struct brcmu_tlv *brcmu_parse_tlvs(void *buf, int buflen,
  174. uint key);
  175. extern uint brcmu_mkiovar(char *name, char *data, uint datalen,
  176. char *buf, uint len);
  177. #endif /* _BRCMU_UTILS_H_ */