Merge remote-tracking branch 'staging/staging-next'
[deliverable/linux.git] / drivers / staging / rtl8712 / rtl871x_mp.h
CommitLineData
0e54f609
AB
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 *
b4f6209d
AB
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>
0e54f609
AB
24 *
25 ******************************************************************************/
2865d42c
LF
26#ifndef __RTL871X_MP_H_
27#define __RTL871X_MP_H_
28
2865d42c
LF
29#define MPT_NOOP 0
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
61
62struct mp_xmit_frame {
63 struct list_head list;
64 struct pkt_attrib attrib;
65 _pkt *pkt;
66 int frame_tag;
67 struct _adapter *padapter;
68 u8 *mem_addr;
69 u16 sz[8];
70 struct urb *pxmit_urb[8];
71 u8 bpending[8];
72 u8 last[8];
2865d42c
LF
73};
74
75struct mp_wiparam {
76 u32 bcompleted;
77 u32 act_type;
78 u32 io_offset;
79 u32 io_value;
80};
81
82struct mp_priv {
83 struct _adapter *papdater;
84 /*OID cmd handler*/
85 struct mp_wiparam workparam;
86 u8 act_in_progress;
87 /*Tx Section*/
88 u8 TID;
89 u32 tx_pktcount;
90 /*Rx Section*/
91 u32 rx_pktcount;
92 u32 rx_crcerrpktcount;
93 u32 rx_pktloss;
94 struct recv_stat rxstat;
95 /*RF/BB relative*/
96 u32 curr_ch;
97 u32 curr_rateidx;
98 u8 curr_bandwidth;
99 u8 curr_modem;
100 u8 curr_txpoweridx;
101 u32 curr_crystalcap;
102 u16 antenna_tx;
103 u16 antenna_rx;
104 u8 curr_rfpath;
105 u8 check_mp_pkt;
106 uint ForcedDataRate;
107 struct wlan_network mp_network;
108 unsigned char network_macaddr[6];
109 /*Testing Flag*/
110 u32 mode;/*0 for normal type packet,
bef611a9
RB
111 * 1 for loopback packet (16bytes TXCMD)
112 */
2865d42c
LF
113 sint prev_fw_state;
114 u8 *pallocated_mp_xmitframe_buf;
115 u8 *pmp_xmtframe_buf;
116 struct __queue free_mp_xmitqueue;
117 u32 free_mp_xmitframe_cnt;
118};
119
120struct IOCMD_STRUCT {
121 u8 cmdclass;
122 u16 value;
123 u8 index;
124};
125
126struct rf_reg_param {
127 u32 path;
128 u32 offset;
129 u32 value;
130};
131
132struct bb_reg_param {
133 u32 offset;
134 u32 value;
135};
136/* ======================================================================= */
137
138#define LOWER true
139#define RAISE false
140#define IOCMD_CTRL_REG 0x10250370
141#define IOCMD_DATA_REG 0x10250374
142#define IOCMD_GET_THERMAL_METER 0xFD000028
143#define IOCMD_CLASS_BB_RF 0xF0
144#define IOCMD_BB_READ_IDX 0x00
145#define IOCMD_BB_WRITE_IDX 0x01
146#define IOCMD_RF_READ_IDX 0x02
147#define IOCMD_RF_WRIT_IDX 0x03
148#define BB_REG_BASE_ADDR 0x800
149#define RF_PATH_A 0
150#define RF_PATH_B 1
151#define RF_PATH_C 2
152#define RF_PATH_D 3
153#define MAX_RF_PATH_NUMS 2
154#define _2MAC_MODE_ 0
155#define _LOOPBOOK_MODE_ 1
156
157/* MP set force data rate base on the definition. */
158enum {
159 /* CCK rate. */
160 MPT_RATE_1M, /* 0 */
161 MPT_RATE_2M,
162 MPT_RATE_55M,
163 MPT_RATE_11M, /* 3 */
164
165 /* OFDM rate. */
166 MPT_RATE_6M, /* 4 */
167 MPT_RATE_9M,
168 MPT_RATE_12M,
169 MPT_RATE_18M,
170 MPT_RATE_24M,
171 MPT_RATE_36M,
172 MPT_RATE_48M,
173 MPT_RATE_54M, /* 11 */
174
175 /* HT rate. */
176 MPT_RATE_MCS0, /* 12 */
177 MPT_RATE_MCS1,
178 MPT_RATE_MCS2,
179 MPT_RATE_MCS3,
180 MPT_RATE_MCS4,
181 MPT_RATE_MCS5,
182 MPT_RATE_MCS6,
183 MPT_RATE_MCS7, /* 19 */
184 MPT_RATE_MCS8,
185 MPT_RATE_MCS9,
186 MPT_RATE_MCS10,
187 MPT_RATE_MCS11,
188 MPT_RATE_MCS12,
189 MPT_RATE_MCS13,
190 MPT_RATE_MCS14,
191 MPT_RATE_MCS15, /* 27 */
192 MPT_RATE_LAST
193};
194
195/* Represent Channel Width in HT Capabilities */
196enum HT_CHANNEL_WIDTH {
197 HT_CHANNEL_WIDTH_20 = 0,
198 HT_CHANNEL_WIDTH_40 = 1,
199};
200
201#define MAX_TX_PWR_INDEX_N_MODE 64 /* 0x3F */
202
203enum POWER_MODE {
204 POWER_LOW = 0,
205 POWER_NORMAL
206};
207
208#define RX_PKT_BROADCAST 1
209#define RX_PKT_DEST_ADDR 2
210#define RX_PKT_PHY_MATCH 3
211
a2955b14 212#define RPTMaxCount 0x000FFFFF
2865d42c
LF
213
214/* parameter 1 : BitMask
215 * bit 0 : OFDM PPDU
216 * bit 1 : OFDM False Alarm
217 * bit 2 : OFDM MPDU OK
218 * bit 3 : OFDM MPDU Fail
219 * bit 4 : CCK PPDU
220 * bit 5 : CCK False Alarm
221 * bit 6 : CCK MPDU ok
222 * bit 7 : CCK MPDU fail
223 * bit 8 : HT PPDU counter
224 * bit 9 : HT false alarm
225 * bit 10 : HT MPDU total
226 * bit 11 : HT MPDU OK
227 * bit 12 : HT MPDU fail
228 * bit 15 : RX full drop
229 */
230enum RXPHY_BITMASK {
231 OFDM_PPDU_BIT = 0,
232 OFDM_MPDU_OK_BIT,
233 OFDM_MPDU_FAIL_BIT,
234 CCK_PPDU_BIT,
235 CCK_MPDU_OK_BIT,
236 CCK_MPDU_FAIL_BIT,
237 HT_PPDU_BIT,
238 HT_MPDU_BIT,
239 HT_MPDU_OK_BIT,
240 HT_MPDU_FAIL_BIT,
241};
242
243enum ENCRY_CTRL_STATE {
244 HW_CONTROL, /*hw encryption& decryption*/
245 SW_CONTROL, /*sw encryption& decryption*/
246 HW_ENCRY_SW_DECRY, /*hw encryption & sw decryption*/
247 SW_ENCRY_HW_DECRY /*sw encryption & hw decryption*/
248};
249
250/* Bandwidth Offset */
251#define HAL_PRIME_CHNL_OFFSET_DONT_CARE 0
252#define HAL_PRIME_CHNL_OFFSET_LOWER 1
253#define HAL_PRIME_CHNL_OFFSET_UPPER 2
254/*=======================================================================*/
255void mp871xinit(struct _adapter *padapter);
256void mp871xdeinit(struct _adapter *padapter);
257u32 r8712_bb_reg_read(struct _adapter *Adapter, u16 offset);
258u8 r8712_bb_reg_write(struct _adapter *Adapter, u16 offset, u32 value);
259u32 r8712_rf_reg_read(struct _adapter *Adapter, u8 path, u8 offset);
260u8 r8712_rf_reg_write(struct _adapter *Adapter, u8 path,
261 u8 offset, u32 value);
262u32 r8712_get_bb_reg(struct _adapter *Adapter, u16 offset, u32 bitmask);
263u8 r8712_set_bb_reg(struct _adapter *Adapter, u16 offset,
264 u32 bitmask, u32 value);
265u32 r8712_get_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
266 u32 bitmask);
267u8 r8712_set_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
268 u32 bitmask, u32 value);
269
270void r8712_SetChannel(struct _adapter *pAdapter);
271void r8712_SetTxPower(struct _adapter *pAdapte);
272void r8712_SetTxAGCOffset(struct _adapter *pAdapter, u32 ulTxAGCOffset);
273void r8712_SetDataRate(struct _adapter *pAdapter);
274void r8712_SwitchBandwidth(struct _adapter *pAdapter);
275void r8712_SwitchAntenna(struct _adapter *pAdapter);
2865d42c
LF
276void r8712_GetThermalMeter(struct _adapter *pAdapter, u32 *value);
277void r8712_SetContinuousTx(struct _adapter *pAdapter, u8 bStart);
278void r8712_SetSingleCarrierTx(struct _adapter *pAdapter, u8 bStart);
279void r8712_SetSingleToneTx(struct _adapter *pAdapter, u8 bStart);
280void r8712_SetCarrierSuppressionTx(struct _adapter *pAdapter, u8 bStart);
281void r8712_ResetPhyRxPktCount(struct _adapter *pAdapter);
282u32 r8712_GetPhyRxPktReceived(struct _adapter *pAdapter);
283u32 r8712_GetPhyRxPktCRC32Error(struct _adapter *pAdapter);
284
285#endif /*__RTL871X_MP_H_*/
286
This page took 0.518142 seconds and 5 git commands to generate.