rtl871x_mp.h 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2007 - 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. * Modifications for inclusion into the Linux staging tree are
  19. * Copyright(c) 2010 Larry Finger. All rights reserved.
  20. *
  21. * Contact information:
  22. * WLAN FAE <wlanfae@realtek.com>
  23. * Larry Finger <Larry.Finger@lwfinger.net>
  24. *
  25. ******************************************************************************/
  26. #ifndef __RTL871X_MP_H_
  27. #define __RTL871X_MP_H_
  28. #define MPT_NOOP 0
  29. #define MPT_READ_MAC_1BYTE 1
  30. #define MPT_READ_MAC_2BYTE 2
  31. #define MPT_READ_MAC_4BYTE 3
  32. #define MPT_WRITE_MAC_1BYTE 4
  33. #define MPT_WRITE_MAC_2BYTE 5
  34. #define MPT_WRITE_MAC_4BYTE 6
  35. #define MPT_READ_BB_CCK 7
  36. #define MPT_WRITE_BB_CCK 8
  37. #define MPT_READ_BB_OFDM 9
  38. #define MPT_WRITE_BB_OFDM 10
  39. #define MPT_READ_RF 11
  40. #define MPT_WRITE_RF 12
  41. #define MPT_READ_EEPROM_1BYTE 13
  42. #define MPT_WRITE_EEPROM_1BYTE 14
  43. #define MPT_READ_EEPROM_2BYTE 15
  44. #define MPT_WRITE_EEPROM_2BYTE 16
  45. #define MPT_SET_CSTHRESHOLD 21
  46. #define MPT_SET_INITGAIN 22
  47. #define MPT_SWITCH_BAND 23
  48. #define MPT_SWITCH_CHANNEL 24
  49. #define MPT_SET_DATARATE 25
  50. #define MPT_SWITCH_ANTENNA 26
  51. #define MPT_SET_TX_POWER 27
  52. #define MPT_SET_CONT_TX 28
  53. #define MPT_SET_SINGLE_CARRIER 29
  54. #define MPT_SET_CARRIER_SUPPRESSION 30
  55. #define MPT_GET_RATE_TABLE 31
  56. #define MPT_READ_TSSI 32
  57. #define MPT_GET_THERMAL_METER 33
  58. #define MAX_MP_XMITBUF_SZ 2048
  59. #define NR_MP_XMITFRAME 8
  60. struct mp_xmit_frame {
  61. struct list_head list;
  62. struct pkt_attrib attrib;
  63. _pkt *pkt;
  64. int frame_tag;
  65. struct _adapter *padapter;
  66. u8 *mem_addr;
  67. u16 sz[8];
  68. struct urb *pxmit_urb[8];
  69. u8 bpending[8];
  70. u8 last[8];
  71. };
  72. struct mp_wiparam {
  73. u32 bcompleted;
  74. u32 act_type;
  75. u32 io_offset;
  76. u32 io_value;
  77. };
  78. struct mp_priv {
  79. struct _adapter *papdater;
  80. /*OID cmd handler*/
  81. struct mp_wiparam workparam;
  82. u8 act_in_progress;
  83. /*Tx Section*/
  84. u8 TID;
  85. u32 tx_pktcount;
  86. /*Rx Section*/
  87. u32 rx_pktcount;
  88. u32 rx_crcerrpktcount;
  89. u32 rx_pktloss;
  90. struct recv_stat rxstat;
  91. /*RF/BB relative*/
  92. u32 curr_ch;
  93. u32 curr_rateidx;
  94. u8 curr_bandwidth;
  95. u8 curr_modem;
  96. u8 curr_txpoweridx;
  97. u32 curr_crystalcap;
  98. u16 antenna_tx;
  99. u16 antenna_rx;
  100. u8 curr_rfpath;
  101. u8 check_mp_pkt;
  102. uint ForcedDataRate;
  103. struct wlan_network mp_network;
  104. unsigned char network_macaddr[6];
  105. /*Testing Flag*/
  106. u32 mode;/*0 for normal type packet,
  107. * 1 for loopback packet (16bytes TXCMD)*/
  108. sint prev_fw_state;
  109. u8 *pallocated_mp_xmitframe_buf;
  110. u8 *pmp_xmtframe_buf;
  111. struct __queue free_mp_xmitqueue;
  112. u32 free_mp_xmitframe_cnt;
  113. };
  114. struct IOCMD_STRUCT {
  115. u8 cmdclass;
  116. u16 value;
  117. u8 index;
  118. };
  119. struct rf_reg_param {
  120. u32 path;
  121. u32 offset;
  122. u32 value;
  123. };
  124. struct bb_reg_param {
  125. u32 offset;
  126. u32 value;
  127. };
  128. /* ======================================================================= */
  129. #define LOWER true
  130. #define RAISE false
  131. #define IOCMD_CTRL_REG 0x10250370
  132. #define IOCMD_DATA_REG 0x10250374
  133. #define IOCMD_GET_THERMAL_METER 0xFD000028
  134. #define IOCMD_CLASS_BB_RF 0xF0
  135. #define IOCMD_BB_READ_IDX 0x00
  136. #define IOCMD_BB_WRITE_IDX 0x01
  137. #define IOCMD_RF_READ_IDX 0x02
  138. #define IOCMD_RF_WRIT_IDX 0x03
  139. #define BB_REG_BASE_ADDR 0x800
  140. #define RF_PATH_A 0
  141. #define RF_PATH_B 1
  142. #define RF_PATH_C 2
  143. #define RF_PATH_D 3
  144. #define MAX_RF_PATH_NUMS 2
  145. #define _2MAC_MODE_ 0
  146. #define _LOOPBOOK_MODE_ 1
  147. /* MP set force data rate base on the definition. */
  148. enum {
  149. /* CCK rate. */
  150. MPT_RATE_1M, /* 0 */
  151. MPT_RATE_2M,
  152. MPT_RATE_55M,
  153. MPT_RATE_11M, /* 3 */
  154. /* OFDM rate. */
  155. MPT_RATE_6M, /* 4 */
  156. MPT_RATE_9M,
  157. MPT_RATE_12M,
  158. MPT_RATE_18M,
  159. MPT_RATE_24M,
  160. MPT_RATE_36M,
  161. MPT_RATE_48M,
  162. MPT_RATE_54M, /* 11 */
  163. /* HT rate. */
  164. MPT_RATE_MCS0, /* 12 */
  165. MPT_RATE_MCS1,
  166. MPT_RATE_MCS2,
  167. MPT_RATE_MCS3,
  168. MPT_RATE_MCS4,
  169. MPT_RATE_MCS5,
  170. MPT_RATE_MCS6,
  171. MPT_RATE_MCS7, /* 19 */
  172. MPT_RATE_MCS8,
  173. MPT_RATE_MCS9,
  174. MPT_RATE_MCS10,
  175. MPT_RATE_MCS11,
  176. MPT_RATE_MCS12,
  177. MPT_RATE_MCS13,
  178. MPT_RATE_MCS14,
  179. MPT_RATE_MCS15, /* 27 */
  180. MPT_RATE_LAST
  181. };
  182. /* Represent Channel Width in HT Capabilities */
  183. enum HT_CHANNEL_WIDTH {
  184. HT_CHANNEL_WIDTH_20 = 0,
  185. HT_CHANNEL_WIDTH_40 = 1,
  186. };
  187. #define MAX_TX_PWR_INDEX_N_MODE 64 /* 0x3F */
  188. enum POWER_MODE {
  189. POWER_LOW = 0,
  190. POWER_NORMAL
  191. };
  192. #define RX_PKT_BROADCAST 1
  193. #define RX_PKT_DEST_ADDR 2
  194. #define RX_PKT_PHY_MATCH 3
  195. #define RPTMaxCount 0x000FFFFF
  196. /* parameter 1 : BitMask
  197. * bit 0 : OFDM PPDU
  198. * bit 1 : OFDM False Alarm
  199. * bit 2 : OFDM MPDU OK
  200. * bit 3 : OFDM MPDU Fail
  201. * bit 4 : CCK PPDU
  202. * bit 5 : CCK False Alarm
  203. * bit 6 : CCK MPDU ok
  204. * bit 7 : CCK MPDU fail
  205. * bit 8 : HT PPDU counter
  206. * bit 9 : HT false alarm
  207. * bit 10 : HT MPDU total
  208. * bit 11 : HT MPDU OK
  209. * bit 12 : HT MPDU fail
  210. * bit 15 : RX full drop
  211. */
  212. enum RXPHY_BITMASK {
  213. OFDM_PPDU_BIT = 0,
  214. OFDM_MPDU_OK_BIT,
  215. OFDM_MPDU_FAIL_BIT,
  216. CCK_PPDU_BIT,
  217. CCK_MPDU_OK_BIT,
  218. CCK_MPDU_FAIL_BIT,
  219. HT_PPDU_BIT,
  220. HT_MPDU_BIT,
  221. HT_MPDU_OK_BIT,
  222. HT_MPDU_FAIL_BIT,
  223. };
  224. enum ENCRY_CTRL_STATE {
  225. HW_CONTROL, /*hw encryption& decryption*/
  226. SW_CONTROL, /*sw encryption& decryption*/
  227. HW_ENCRY_SW_DECRY, /*hw encryption & sw decryption*/
  228. SW_ENCRY_HW_DECRY /*sw encryption & hw decryption*/
  229. };
  230. /* Bandwidth Offset */
  231. #define HAL_PRIME_CHNL_OFFSET_DONT_CARE 0
  232. #define HAL_PRIME_CHNL_OFFSET_LOWER 1
  233. #define HAL_PRIME_CHNL_OFFSET_UPPER 2
  234. /*=======================================================================*/
  235. void mp871xinit(struct _adapter *padapter);
  236. void mp871xdeinit(struct _adapter *padapter);
  237. u32 r8712_bb_reg_read(struct _adapter *Adapter, u16 offset);
  238. u8 r8712_bb_reg_write(struct _adapter *Adapter, u16 offset, u32 value);
  239. u32 r8712_rf_reg_read(struct _adapter *Adapter, u8 path, u8 offset);
  240. u8 r8712_rf_reg_write(struct _adapter *Adapter, u8 path,
  241. u8 offset, u32 value);
  242. u32 r8712_get_bb_reg(struct _adapter *Adapter, u16 offset, u32 bitmask);
  243. u8 r8712_set_bb_reg(struct _adapter *Adapter, u16 offset,
  244. u32 bitmask, u32 value);
  245. u32 r8712_get_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
  246. u32 bitmask);
  247. u8 r8712_set_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
  248. u32 bitmask, u32 value);
  249. void r8712_SetChannel(struct _adapter *pAdapter);
  250. void r8712_SetTxPower(struct _adapter *pAdapte);
  251. void r8712_SetTxAGCOffset(struct _adapter *pAdapter, u32 ulTxAGCOffset);
  252. void r8712_SetDataRate(struct _adapter *pAdapter);
  253. void r8712_SwitchBandwidth(struct _adapter *pAdapter);
  254. void r8712_SwitchAntenna(struct _adapter *pAdapter);
  255. void r8712_GetThermalMeter(struct _adapter *pAdapter, u32 *value);
  256. void r8712_SetContinuousTx(struct _adapter *pAdapter, u8 bStart);
  257. void r8712_SetSingleCarrierTx(struct _adapter *pAdapter, u8 bStart);
  258. void r8712_SetSingleToneTx(struct _adapter *pAdapter, u8 bStart);
  259. void r8712_SetCarrierSuppressionTx(struct _adapter *pAdapter, u8 bStart);
  260. void r8712_ResetPhyRxPktCount(struct _adapter *pAdapter);
  261. u32 r8712_GetPhyRxPktReceived(struct _adapter *pAdapter);
  262. u32 r8712_GetPhyRxPktCRC32Error(struct _adapter *pAdapter);
  263. #endif /*__RTL871X_MP_H_*/