rx.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. /*
  2. * This file is part of wl1271
  3. *
  4. * Copyright (C) 1998-2009 Texas Instruments. All rights reserved.
  5. * Copyright (C) 2008-2009 Nokia Corporation
  6. *
  7. * Contact: Luciano Coelho <luciano.coelho@nokia.com>
  8. *
  9. * This program is free software; you can redistribute it and/or
  10. * modify it under the terms of the GNU General Public License
  11. * version 2 as published by the Free Software Foundation.
  12. *
  13. * This program is distributed in the hope that it will be useful, but
  14. * WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  21. * 02110-1301 USA
  22. *
  23. */
  24. #ifndef __RX_H__
  25. #define __RX_H__
  26. #include <linux/bitops.h>
  27. #define WL1271_RX_MAX_RSSI -30
  28. #define WL1271_RX_MIN_RSSI -95
  29. #define SHORT_PREAMBLE_BIT BIT(0)
  30. #define OFDM_RATE_BIT BIT(6)
  31. #define PBCC_RATE_BIT BIT(7)
  32. #define PLCP_HEADER_LENGTH 8
  33. #define RX_DESC_PACKETID_SHIFT 11
  34. #define RX_MAX_PACKET_ID 3
  35. #define RX_DESC_VALID_FCS 0x0001
  36. #define RX_DESC_MATCH_RXADDR1 0x0002
  37. #define RX_DESC_MCAST 0x0004
  38. #define RX_DESC_STAINTIM 0x0008
  39. #define RX_DESC_VIRTUAL_BM 0x0010
  40. #define RX_DESC_BCAST 0x0020
  41. #define RX_DESC_MATCH_SSID 0x0040
  42. #define RX_DESC_MATCH_BSSID 0x0080
  43. #define RX_DESC_ENCRYPTION_MASK 0x0300
  44. #define RX_DESC_MEASURMENT 0x0400
  45. #define RX_DESC_SEQNUM_MASK 0x1800
  46. #define RX_DESC_MIC_FAIL 0x2000
  47. #define RX_DESC_DECRYPT_FAIL 0x4000
  48. /*
  49. * RX Descriptor flags:
  50. *
  51. * Bits 0-1 - band
  52. * Bit 2 - STBC
  53. * Bit 3 - A-MPDU
  54. * Bit 4 - HT
  55. * Bits 5-7 - encryption
  56. */
  57. #define WL1271_RX_DESC_BAND_MASK 0x03
  58. #define WL1271_RX_DESC_ENCRYPT_MASK 0xE0
  59. #define WL1271_RX_DESC_BAND_BG 0x00
  60. #define WL1271_RX_DESC_BAND_J 0x01
  61. #define WL1271_RX_DESC_BAND_A 0x02
  62. #define WL1271_RX_DESC_STBC BIT(2)
  63. #define WL1271_RX_DESC_A_MPDU BIT(3)
  64. #define WL1271_RX_DESC_HT BIT(4)
  65. #define WL1271_RX_DESC_ENCRYPT_WEP 0x20
  66. #define WL1271_RX_DESC_ENCRYPT_TKIP 0x40
  67. #define WL1271_RX_DESC_ENCRYPT_AES 0x60
  68. #define WL1271_RX_DESC_ENCRYPT_GEM 0x80
  69. /*
  70. * RX Descriptor status
  71. *
  72. * Bits 0-2 - error code
  73. * Bits 3-5 - process_id tag (AP mode FW)
  74. * Bits 6-7 - reserved
  75. */
  76. #define WL1271_RX_DESC_STATUS_MASK 0x07
  77. #define WL1271_RX_DESC_SUCCESS 0x00
  78. #define WL1271_RX_DESC_DECRYPT_FAIL 0x01
  79. #define WL1271_RX_DESC_MIC_FAIL 0x02
  80. #define RX_MEM_BLOCK_MASK 0xFF
  81. #define RX_BUF_SIZE_MASK 0xFFF00
  82. #define RX_BUF_SIZE_SHIFT_DIV 6
  83. #define ALIGNED_RX_BUF_SIZE_MASK 0xFFFF00
  84. #define ALIGNED_RX_BUF_SIZE_SHIFT 8
  85. /* If set, the start of IP payload is not 4 bytes aligned */
  86. #define RX_BUF_UNALIGNED_PAYLOAD BIT(20)
  87. /* If set, the buffer was padded by the FW to be 4 bytes aligned */
  88. #define RX_BUF_PADDED_PAYLOAD BIT(30)
  89. /*
  90. * Account for the padding inserted by the FW in case of RX_ALIGNMENT
  91. * or for fixing alignment in case the packet wasn't aligned.
  92. */
  93. #define RX_BUF_ALIGN 2
  94. /* Describes the alignment state of a Rx buffer */
  95. enum wl_rx_buf_align {
  96. WLCORE_RX_BUF_ALIGNED,
  97. WLCORE_RX_BUF_UNALIGNED,
  98. WLCORE_RX_BUF_PADDED,
  99. };
  100. enum {
  101. WL12XX_RX_CLASS_UNKNOWN,
  102. WL12XX_RX_CLASS_MANAGEMENT,
  103. WL12XX_RX_CLASS_DATA,
  104. WL12XX_RX_CLASS_QOS_DATA,
  105. WL12XX_RX_CLASS_BCN_PRBRSP,
  106. WL12XX_RX_CLASS_EAPOL,
  107. WL12XX_RX_CLASS_BA_EVENT,
  108. WL12XX_RX_CLASS_AMSDU,
  109. WL12XX_RX_CLASS_LOGGER,
  110. };
  111. struct wl1271_rx_descriptor {
  112. __le16 length;
  113. u8 status;
  114. u8 flags;
  115. u8 rate;
  116. u8 channel;
  117. s8 rssi;
  118. u8 snr;
  119. __le32 timestamp;
  120. u8 packet_class;
  121. u8 hlid;
  122. u8 pad_len;
  123. u8 reserved;
  124. } __packed;
  125. int wlcore_rx(struct wl1271 *wl, struct wl_fw_status_1 *status);
  126. u8 wl1271_rate_to_idx(int rate, enum ieee80211_band band);
  127. int wl1271_rx_filter_enable(struct wl1271 *wl,
  128. int index, bool enable,
  129. struct wl12xx_rx_filter *filter);
  130. int wl1271_rx_filter_clear_all(struct wl1271 *wl);
  131. #endif