1 /******************************************************************************
3 * Copyright(c) 2007 - 2010 Realtek Corporation. All rights reserved.
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.
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
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
18 * Modifications for inclusion into the Linux staging tree are
19 * Copyright(c) 2010 Larry Finger. All rights reserved.
21 * Contact information:
22 * WLAN FAE <wlanfae@realtek.com>
23 * Larry Finger <Larry.Finger@lwfinger.net>
25 ******************************************************************************/
26 #ifndef __RTL871X_MP_H_
27 #define __RTL871X_MP_H_
30 #define MPT_READ_MAC_1BYTE 1
31 #define MPT_READ_MAC_2BYTE 2
32 #define MPT_READ_MAC_4BYTE 3
33 #define MPT_WRITE_MAC_1BYTE 4
34 #define MPT_WRITE_MAC_2BYTE 5
35 #define MPT_WRITE_MAC_4BYTE 6
36 #define MPT_READ_BB_CCK 7
37 #define MPT_WRITE_BB_CCK 8
38 #define MPT_READ_BB_OFDM 9
39 #define MPT_WRITE_BB_OFDM 10
40 #define MPT_READ_RF 11
41 #define MPT_WRITE_RF 12
42 #define MPT_READ_EEPROM_1BYTE 13
43 #define MPT_WRITE_EEPROM_1BYTE 14
44 #define MPT_READ_EEPROM_2BYTE 15
45 #define MPT_WRITE_EEPROM_2BYTE 16
46 #define MPT_SET_CSTHRESHOLD 21
47 #define MPT_SET_INITGAIN 22
48 #define MPT_SWITCH_BAND 23
49 #define MPT_SWITCH_CHANNEL 24
50 #define MPT_SET_DATARATE 25
51 #define MPT_SWITCH_ANTENNA 26
52 #define MPT_SET_TX_POWER 27
53 #define MPT_SET_CONT_TX 28
54 #define MPT_SET_SINGLE_CARRIER 29
55 #define MPT_SET_CARRIER_SUPPRESSION 30
56 #define MPT_GET_RATE_TABLE 31
57 #define MPT_READ_TSSI 32
58 #define MPT_GET_THERMAL_METER 33
59 #define MAX_MP_XMITBUF_SZ 2048
60 #define NR_MP_XMITFRAME 8
62 struct mp_xmit_frame
{
63 struct list_head list
;
64 struct pkt_attrib attrib
;
67 struct _adapter
*padapter
;
70 struct urb
*pxmit_urb
[8];
83 struct _adapter
*papdater
;
85 struct mp_wiparam workparam
;
92 u32 rx_crcerrpktcount
;
94 struct recv_stat rxstat
;
107 struct wlan_network mp_network
;
108 unsigned char network_macaddr
[6];
110 u32 mode
;/*0 for normal type packet,
111 * 1 for loopback packet (16bytes TXCMD)*/
113 u8
*pallocated_mp_xmitframe_buf
;
114 u8
*pmp_xmtframe_buf
;
115 struct __queue free_mp_xmitqueue
;
116 u32 free_mp_xmitframe_cnt
;
119 struct IOCMD_STRUCT
{
125 struct rf_reg_param
{
131 struct bb_reg_param
{
135 /* ======================================================================= */
139 #define IOCMD_CTRL_REG 0x10250370
140 #define IOCMD_DATA_REG 0x10250374
141 #define IOCMD_GET_THERMAL_METER 0xFD000028
142 #define IOCMD_CLASS_BB_RF 0xF0
143 #define IOCMD_BB_READ_IDX 0x00
144 #define IOCMD_BB_WRITE_IDX 0x01
145 #define IOCMD_RF_READ_IDX 0x02
146 #define IOCMD_RF_WRIT_IDX 0x03
147 #define BB_REG_BASE_ADDR 0x800
152 #define MAX_RF_PATH_NUMS 2
153 #define _2MAC_MODE_ 0
154 #define _LOOPBOOK_MODE_ 1
156 /* MP set force data rate base on the definition. */
162 MPT_RATE_11M
, /* 3 */
172 MPT_RATE_54M
, /* 11 */
175 MPT_RATE_MCS0
, /* 12 */
182 MPT_RATE_MCS7
, /* 19 */
190 MPT_RATE_MCS15
, /* 27 */
194 /* Represent Channel Width in HT Capabilities */
195 enum HT_CHANNEL_WIDTH
{
196 HT_CHANNEL_WIDTH_20
= 0,
197 HT_CHANNEL_WIDTH_40
= 1,
200 #define MAX_TX_PWR_INDEX_N_MODE 64 /* 0x3F */
207 #define RX_PKT_BROADCAST 1
208 #define RX_PKT_DEST_ADDR 2
209 #define RX_PKT_PHY_MATCH 3
211 #define RPTMaxCount 0x000FFFFF;
213 /* parameter 1 : BitMask
215 * bit 1 : OFDM False Alarm
216 * bit 2 : OFDM MPDU OK
217 * bit 3 : OFDM MPDU Fail
219 * bit 5 : CCK False Alarm
220 * bit 6 : CCK MPDU ok
221 * bit 7 : CCK MPDU fail
222 * bit 8 : HT PPDU counter
223 * bit 9 : HT false alarm
224 * bit 10 : HT MPDU total
225 * bit 11 : HT MPDU OK
226 * bit 12 : HT MPDU fail
227 * bit 15 : RX full drop
242 enum ENCRY_CTRL_STATE
{
243 HW_CONTROL
, /*hw encryption& decryption*/
244 SW_CONTROL
, /*sw encryption& decryption*/
245 HW_ENCRY_SW_DECRY
, /*hw encryption & sw decryption*/
246 SW_ENCRY_HW_DECRY
/*sw encryption & hw decryption*/
249 /* Bandwidth Offset */
250 #define HAL_PRIME_CHNL_OFFSET_DONT_CARE 0
251 #define HAL_PRIME_CHNL_OFFSET_LOWER 1
252 #define HAL_PRIME_CHNL_OFFSET_UPPER 2
253 /*=======================================================================*/
254 void mp871xinit(struct _adapter
*padapter
);
255 void mp871xdeinit(struct _adapter
*padapter
);
256 u32
r8712_bb_reg_read(struct _adapter
*Adapter
, u16 offset
);
257 u8
r8712_bb_reg_write(struct _adapter
*Adapter
, u16 offset
, u32 value
);
258 u32
r8712_rf_reg_read(struct _adapter
*Adapter
, u8 path
, u8 offset
);
259 u8
r8712_rf_reg_write(struct _adapter
*Adapter
, u8 path
,
260 u8 offset
, u32 value
);
261 u32
r8712_get_bb_reg(struct _adapter
*Adapter
, u16 offset
, u32 bitmask
);
262 u8
r8712_set_bb_reg(struct _adapter
*Adapter
, u16 offset
,
263 u32 bitmask
, u32 value
);
264 u32
r8712_get_rf_reg(struct _adapter
*Adapter
, u8 path
, u8 offset
,
266 u8
r8712_set_rf_reg(struct _adapter
*Adapter
, u8 path
, u8 offset
,
267 u32 bitmask
, u32 value
);
269 void r8712_SetChannel(struct _adapter
*pAdapter
);
270 void r8712_SetTxPower(struct _adapter
*pAdapte
);
271 void r8712_SetTxAGCOffset(struct _adapter
*pAdapter
, u32 ulTxAGCOffset
);
272 void r8712_SetDataRate(struct _adapter
*pAdapter
);
273 void r8712_SwitchBandwidth(struct _adapter
*pAdapter
);
274 void r8712_SwitchAntenna(struct _adapter
*pAdapter
);
275 void r8712_SetCrystalCap(struct _adapter
*pAdapter
);
276 void r8712_GetThermalMeter(struct _adapter
*pAdapter
, u32
*value
);
277 void r8712_SetContinuousTx(struct _adapter
*pAdapter
, u8 bStart
);
278 void r8712_SetSingleCarrierTx(struct _adapter
*pAdapter
, u8 bStart
);
279 void r8712_SetSingleToneTx(struct _adapter
*pAdapter
, u8 bStart
);
280 void r8712_SetCarrierSuppressionTx(struct _adapter
*pAdapter
, u8 bStart
);
281 void r8712_ResetPhyRxPktCount(struct _adapter
*pAdapter
);
282 u32
r8712_GetPhyRxPktReceived(struct _adapter
*pAdapter
);
283 u32
r8712_GetPhyRxPktCRC32Error(struct _adapter
*pAdapter
);
285 #endif /*__RTL871X_MP_H_*/