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