scb.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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 _BRCM_SCB_H_
  17. #define _BRCM_SCB_H_
  18. #include <linux/if_ether.h>
  19. #include <brcmu_utils.h>
  20. #include <defs.h>
  21. #include "types.h"
  22. #define AMPDU_TX_BA_MAX_WSIZE 64 /* max Tx ba window size (in pdu) */
  23. #define AMPDU_MAX_SCB_TID NUMPRIO
  24. /* scb flags */
  25. #define SCB_WMECAP 0x0040
  26. #define SCB_HTCAP 0x10000 /* HT (MIMO) capable device */
  27. #define SCB_IS40 0x80000 /* 40MHz capable */
  28. #define SCB_STBCCAP 0x40000000 /* STBC Capable */
  29. #define SCB_MAGIC 0xbeefcafe
  30. /* structure to store per-tid state for the ampdu initiator */
  31. struct scb_ampdu_tid_ini {
  32. u8 tid; /* initiator tid for easy lookup */
  33. /* tx retry count; indexed by seq modulo */
  34. u8 txretry[AMPDU_TX_BA_MAX_WSIZE];
  35. struct scb *scb; /* backptr for easy lookup */
  36. u8 ba_wsize; /* negotiated ba window size (in pdu) */
  37. };
  38. struct scb_ampdu {
  39. struct scb *scb; /* back pointer for easy reference */
  40. u8 mpdu_density; /* mpdu density */
  41. u8 max_pdu; /* max pdus allowed in ampdu */
  42. u8 release; /* # of mpdus released at a time */
  43. u16 min_len; /* min mpdu len to support the density */
  44. u32 max_rx_ampdu_bytes; /* max ampdu rcv length; 8k, 16k, 32k, 64k */
  45. /*
  46. * This could easily be a ini[] pointer and we keep this info in wl
  47. * itself instead of having mac80211 hold it for us. Also could be made
  48. * dynamic per tid instead of static.
  49. */
  50. /* initiator info - per tid (NUMPRIO): */
  51. struct scb_ampdu_tid_ini ini[AMPDU_MAX_SCB_TID];
  52. };
  53. /* station control block - one per remote MAC address */
  54. struct scb {
  55. u32 magic;
  56. u32 flags; /* various bit flags as defined below */
  57. u32 flags2; /* various bit flags2 as defined below */
  58. u8 state; /* current state bitfield of auth/assoc process */
  59. u8 ea[ETH_ALEN]; /* station address */
  60. uint fragresid[NUMPRIO];/* #bytes unused in frag buffer per prio */
  61. u16 seqctl[NUMPRIO]; /* seqctl of last received frame (for dups) */
  62. /* seqctl of last received frame (for dups) for non-QoS data and
  63. * management */
  64. u16 seqctl_nonqos;
  65. u16 seqnum[NUMPRIO];/* WME: driver maintained sw seqnum per priority */
  66. struct scb_ampdu scb_ampdu; /* AMPDU state including per tid info */
  67. };
  68. #endif /* _BRCM_SCB_H_ */