mac.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2009-2010 Realtek Corporation. All rights reserved.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of version 2 of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. *
  14. * You should have received a copy of the GNU General Public License along with
  15. * this program; if not, write to the Free Software Foundation, Inc.,
  16. * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
  17. *
  18. * The full GNU General Public License is included in this distribution in the
  19. * file called LICENSE.
  20. *
  21. * Contact Information:
  22. * wlanfae <wlanfae@realtek.com>
  23. * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
  24. * Hsinchu 300, Taiwan.
  25. *
  26. * Larry Finger <Larry.Finger@lwfinger.net>
  27. *
  28. *****************************************************************************/
  29. #ifndef __RTL92C_MAC_H__
  30. #define __RTL92C_MAC_H__
  31. #define LLT_LAST_ENTRY_OF_TX_PKT_BUFFER 255
  32. #define DRIVER_EARLY_INT_TIME 0x05
  33. #define BCN_DMA_ATIME_INT_TIME 0x02
  34. void rtl92c_read_chip_version(struct ieee80211_hw *hw);
  35. bool rtl92c_llt_write(struct ieee80211_hw *hw, u32 address, u32 data);
  36. bool rtl92c_init_llt_table(struct ieee80211_hw *hw, u32 boundary);
  37. void rtl92c_set_key(struct ieee80211_hw *hw, u32 key_index,
  38. u8 *p_macaddr, bool is_group, u8 enc_algo,
  39. bool is_wepkey, bool clear_all);
  40. void rtl92c_enable_interrupt(struct ieee80211_hw *hw);
  41. void rtl92c_disable_interrupt(struct ieee80211_hw *hw);
  42. void rtl92c_set_qos(struct ieee80211_hw *hw, int aci);
  43. /*---------------------------------------------------------------
  44. * Hardware init functions
  45. *---------------------------------------------------------------*/
  46. void rtl92c_set_mac_addr(struct ieee80211_hw *hw, const u8 *addr);
  47. void rtl92c_init_interrupt(struct ieee80211_hw *hw);
  48. void rtl92c_init_driver_info_size(struct ieee80211_hw *hw, u8 size);
  49. int rtl92c_set_network_type(struct ieee80211_hw *hw, enum nl80211_iftype type);
  50. void rtl92c_init_network_type(struct ieee80211_hw *hw);
  51. void rtl92c_init_adaptive_ctrl(struct ieee80211_hw *hw);
  52. void rtl92c_init_rate_fallback(struct ieee80211_hw *hw);
  53. void rtl92c_init_edca_param(struct ieee80211_hw *hw,
  54. u16 queue,
  55. u16 txop,
  56. u8 ecwmax,
  57. u8 ecwmin,
  58. u8 aifs);
  59. void rtl92c_init_edca(struct ieee80211_hw *hw);
  60. void rtl92c_init_ampdu_aggregation(struct ieee80211_hw *hw);
  61. void rtl92c_init_beacon_max_error(struct ieee80211_hw *hw, bool infra_mode);
  62. void rtl92c_init_rdg_setting(struct ieee80211_hw *hw);
  63. void rtl92c_init_retry_function(struct ieee80211_hw *hw);
  64. void rtl92c_init_beacon_parameters(struct ieee80211_hw *hw,
  65. enum version_8192c version);
  66. void rtl92c_disable_fast_edca(struct ieee80211_hw *hw);
  67. void rtl92c_set_min_space(struct ieee80211_hw *hw, bool is2T);
  68. /* For filter */
  69. u16 rtl92c_get_mgt_filter(struct ieee80211_hw *hw);
  70. void rtl92c_set_mgt_filter(struct ieee80211_hw *hw, u16 filter);
  71. u16 rtl92c_get_ctrl_filter(struct ieee80211_hw *hw);
  72. void rtl92c_set_ctrl_filter(struct ieee80211_hw *hw, u16 filter);
  73. u16 rtl92c_get_data_filter(struct ieee80211_hw *hw);
  74. void rtl92c_set_data_filter(struct ieee80211_hw *hw, u16 filter);
  75. u32 rtl92c_get_txdma_status(struct ieee80211_hw *hw);
  76. #define RX_HAL_IS_CCK_RATE(_pdesc)\
  77. (GET_RX_DESC_RX_MCS(_pdesc) == DESC92C_RATE1M ||\
  78. GET_RX_DESC_RX_MCS(_pdesc) == DESC92C_RATE2M ||\
  79. GET_RX_DESC_RX_MCS(_pdesc) == DESC92C_RATE5_5M ||\
  80. GET_RX_DESC_RX_MCS(_pdesc) == DESC92C_RATE11M)
  81. struct rx_fwinfo_92c {
  82. u8 gain_trsw[4];
  83. u8 pwdb_all;
  84. u8 cfosho[4];
  85. u8 cfotail[4];
  86. char rxevm[2];
  87. char rxsnr[4];
  88. u8 pdsnr[2];
  89. u8 csi_current[2];
  90. u8 csi_target[2];
  91. u8 sigevm;
  92. u8 max_ex_pwr;
  93. u8 ex_intf_flag:1;
  94. u8 sgi_en:1;
  95. u8 rxsc:2;
  96. u8 reserve:4;
  97. } __packed;
  98. struct rx_desc_92c {
  99. u32 length:14;
  100. u32 crc32:1;
  101. u32 icverror:1;
  102. u32 drv_infosize:4;
  103. u32 security:3;
  104. u32 qos:1;
  105. u32 shift:2;
  106. u32 phystatus:1;
  107. u32 swdec:1;
  108. u32 lastseg:1;
  109. u32 firstseg:1;
  110. u32 eor:1;
  111. u32 own:1;
  112. u32 macid:5; /* word 1 */
  113. u32 tid:4;
  114. u32 hwrsvd:5;
  115. u32 paggr:1;
  116. u32 faggr:1;
  117. u32 a1_fit:4;
  118. u32 a2_fit:4;
  119. u32 pam:1;
  120. u32 pwr:1;
  121. u32 moredata:1;
  122. u32 morefrag:1;
  123. u32 type:2;
  124. u32 mc:1;
  125. u32 bc:1;
  126. u32 seq:12; /* word 2 */
  127. u32 frag:4;
  128. u32 nextpktlen:14;
  129. u32 nextind:1;
  130. u32 rsvd:1;
  131. u32 rxmcs:6; /* word 3 */
  132. u32 rxht:1;
  133. u32 amsdu:1;
  134. u32 splcp:1;
  135. u32 bandwidth:1;
  136. u32 htc:1;
  137. u32 tcpchk_rpt:1;
  138. u32 ipcchk_rpt:1;
  139. u32 tcpchk_valid:1;
  140. u32 hwpcerr:1;
  141. u32 hwpcind:1;
  142. u32 iv0:16;
  143. u32 iv1; /* word 4 */
  144. u32 tsfl; /* word 5 */
  145. u32 bufferaddress; /* word 6 */
  146. u32 bufferaddress64; /* word 7 */
  147. } __packed;
  148. enum rtl_desc_qsel rtl92c_map_hwqueue_to_fwqueue(u16 fc,
  149. unsigned int
  150. skb_queue);
  151. void rtl92c_translate_rx_signal_stuff(struct ieee80211_hw *hw,
  152. struct sk_buff *skb,
  153. struct rtl_stats *pstats,
  154. struct rx_desc_92c *pdesc,
  155. struct rx_fwinfo_92c *p_drvinfo);
  156. /*---------------------------------------------------------------
  157. * Card disable functions
  158. *---------------------------------------------------------------*/
  159. #endif