rx.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  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 NUM_RX_PKT_DESC_MOD_MASK 7
  36. #define RX_DESC_VALID_FCS 0x0001
  37. #define RX_DESC_MATCH_RXADDR1 0x0002
  38. #define RX_DESC_MCAST 0x0004
  39. #define RX_DESC_STAINTIM 0x0008
  40. #define RX_DESC_VIRTUAL_BM 0x0010
  41. #define RX_DESC_BCAST 0x0020
  42. #define RX_DESC_MATCH_SSID 0x0040
  43. #define RX_DESC_MATCH_BSSID 0x0080
  44. #define RX_DESC_ENCRYPTION_MASK 0x0300
  45. #define RX_DESC_MEASURMENT 0x0400
  46. #define RX_DESC_SEQNUM_MASK 0x1800
  47. #define RX_DESC_MIC_FAIL 0x2000
  48. #define RX_DESC_DECRYPT_FAIL 0x4000
  49. /*
  50. * RX Descriptor flags:
  51. *
  52. * Bits 0-1 - band
  53. * Bit 2 - STBC
  54. * Bit 3 - A-MPDU
  55. * Bit 4 - HT
  56. * Bits 5-7 - encryption
  57. */
  58. #define WL1271_RX_DESC_BAND_MASK 0x03
  59. #define WL1271_RX_DESC_ENCRYPT_MASK 0xE0
  60. #define WL1271_RX_DESC_BAND_BG 0x00
  61. #define WL1271_RX_DESC_BAND_J 0x01
  62. #define WL1271_RX_DESC_BAND_A 0x02
  63. #define WL1271_RX_DESC_STBC BIT(2)
  64. #define WL1271_RX_DESC_A_MPDU BIT(3)
  65. #define WL1271_RX_DESC_HT BIT(4)
  66. #define WL1271_RX_DESC_ENCRYPT_WEP 0x20
  67. #define WL1271_RX_DESC_ENCRYPT_TKIP 0x40
  68. #define WL1271_RX_DESC_ENCRYPT_AES 0x60
  69. #define WL1271_RX_DESC_ENCRYPT_GEM 0x80
  70. /*
  71. * RX Descriptor status
  72. *
  73. * Bits 0-2 - error code
  74. * Bits 3-5 - process_id tag (AP mode FW)
  75. * Bits 6-7 - reserved
  76. */
  77. #define WL1271_RX_DESC_STATUS_MASK 0x03
  78. #define WL1271_RX_DESC_SUCCESS 0x00
  79. #define WL1271_RX_DESC_DECRYPT_FAIL 0x01
  80. #define WL1271_RX_DESC_MIC_FAIL 0x02
  81. #define WL1271_RX_DESC_DRIVER_RX_Q_FAIL 0x03
  82. #define RX_MEM_BLOCK_MASK 0xFF
  83. #define RX_BUF_SIZE_MASK 0xFFF00
  84. #define RX_BUF_SIZE_SHIFT_DIV 6
  85. /* If set, the start of IP payload is not 4 bytes aligned */
  86. #define RX_BUF_UNALIGNED_PAYLOAD BIT(20)
  87. enum {
  88. WL12XX_RX_CLASS_UNKNOWN,
  89. WL12XX_RX_CLASS_MANAGEMENT,
  90. WL12XX_RX_CLASS_DATA,
  91. WL12XX_RX_CLASS_QOS_DATA,
  92. WL12XX_RX_CLASS_BCN_PRBRSP,
  93. WL12XX_RX_CLASS_EAPOL,
  94. WL12XX_RX_CLASS_BA_EVENT,
  95. WL12XX_RX_CLASS_AMSDU,
  96. WL12XX_RX_CLASS_LOGGER,
  97. };
  98. struct wl1271_rx_descriptor {
  99. __le16 length;
  100. u8 status;
  101. u8 flags;
  102. u8 rate;
  103. u8 channel;
  104. s8 rssi;
  105. u8 snr;
  106. __le32 timestamp;
  107. u8 packet_class;
  108. u8 hlid;
  109. u8 pad_len;
  110. u8 reserved;
  111. } __packed;
  112. void wl12xx_rx(struct wl1271 *wl, struct wl12xx_fw_status *status);
  113. u8 wl1271_rate_to_idx(int rate, enum ieee80211_band band);
  114. #endif