Merge tag 'efi-next' of git://git.kernel.org/pub/scm/linux/kernel/git/mfleming/efi...
[firefly-linux-kernel-4.4.55.git] / drivers / staging / rtl8192e / rtl8192e / r8192E_phyreg.h
1 /******************************************************************************
2  * Copyright(c) 2008 - 2010 Realtek Corporation. All rights reserved.
3  *
4  * This program is distributed in the hope that it will be useful, but WITHOUT
5  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
7  * more details.
8  *
9  * You should have received a copy of the GNU General Public License along with
10  * this program; if not, write to the Free Software Foundation, Inc.,
11  * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
12  *
13  * The full GNU General Public License is included in this distribution in the
14  * file called LICENSE.
15  *
16  * Contact Information:
17  * wlanfae <wlanfae@realtek.com>
18 ******************************************************************************/
19 #ifndef _R819XU_PHYREG_H
20 #define _R819XU_PHYREG_H
21
22
23 #define RF_DATA                 0x1d4
24
25 #define rPMAC_Reset             0x100
26 #define rPMAC_TxStart           0x104
27 #define rPMAC_TxLegacySIG       0x108
28 #define rPMAC_TxHTSIG1          0x10c
29 #define rPMAC_TxHTSIG2          0x110
30 #define rPMAC_PHYDebug          0x114
31 #define rPMAC_TxPacketNum       0x118
32 #define rPMAC_TxIdle            0x11c
33 #define rPMAC_TxMACHeader0      0x120
34 #define rPMAC_TxMACHeader1      0x124
35 #define rPMAC_TxMACHeader2      0x128
36 #define rPMAC_TxMACHeader3      0x12c
37 #define rPMAC_TxMACHeader4      0x130
38 #define rPMAC_TxMACHeader5      0x134
39 #define rPMAC_TxDataType        0x138
40 #define rPMAC_TxRandomSeed      0x13c
41 #define rPMAC_CCKPLCPPreamble   0x140
42 #define rPMAC_CCKPLCPHeader     0x144
43 #define rPMAC_CCKCRC16          0x148
44 #define rPMAC_OFDMRxCRC32OK     0x170
45 #define rPMAC_OFDMRxCRC32Er     0x174
46 #define rPMAC_OFDMRxParityEr    0x178
47 #define rPMAC_OFDMRxCRC8Er      0x17c
48 #define rPMAC_CCKCRxRC16Er      0x180
49 #define rPMAC_CCKCRxRC32Er      0x184
50 #define rPMAC_CCKCRxRC32OK      0x188
51 #define rPMAC_TxStatus          0x18c
52
53 #define MCS_TXAGC               0x340
54 #define CCK_TXAGC               0x348
55
56 /* Mac block on/off control register */
57 #define MacBlkCtrl                      0x403
58
59 #define rFPGA0_RFMOD                    0x800 /* RF mode & CCK TxSC */
60 #define rFPGA0_TxInfo                   0x804
61 #define rFPGA0_PSDFunction              0x808
62 #define rFPGA0_TxGainStage              0x80c
63 #define rFPGA0_RFTiming1                0x810
64 #define rFPGA0_RFTiming2                0x814
65 #define rFPGA0_XA_HSSIParameter1        0x820
66 #define rFPGA0_XA_HSSIParameter2        0x824
67 #define rFPGA0_XB_HSSIParameter1        0x828
68 #define rFPGA0_XB_HSSIParameter2        0x82c
69 #define rFPGA0_XC_HSSIParameter1        0x830
70 #define rFPGA0_XC_HSSIParameter2        0x834
71 #define rFPGA0_XD_HSSIParameter1        0x838
72 #define rFPGA0_XD_HSSIParameter2        0x83c
73 #define rFPGA0_XA_LSSIParameter         0x840
74 #define rFPGA0_XB_LSSIParameter         0x844
75 #define rFPGA0_XC_LSSIParameter         0x848
76 #define rFPGA0_XD_LSSIParameter         0x84c
77 #define rFPGA0_RFWakeUpParameter        0x850
78 #define rFPGA0_RFSleepUpParameter       0x854
79 #define rFPGA0_XAB_SwitchControl        0x858
80 #define rFPGA0_XCD_SwitchControl        0x85c
81 #define rFPGA0_XA_RFInterfaceOE         0x860
82 #define rFPGA0_XB_RFInterfaceOE         0x864
83 #define rFPGA0_XC_RFInterfaceOE         0x868
84 #define rFPGA0_XD_RFInterfaceOE         0x86c
85 #define rFPGA0_XAB_RFInterfaceSW        0x870
86 #define rFPGA0_XCD_RFInterfaceSW        0x874
87 #define rFPGA0_XAB_RFParameter          0x878
88 #define rFPGA0_XCD_RFParameter          0x87c
89 #define rFPGA0_AnalogParameter1         0x880
90 #define rFPGA0_AnalogParameter2         0x884
91 #define rFPGA0_AnalogParameter3         0x888
92 #define rFPGA0_AnalogParameter4         0x88c
93 #define rFPGA0_XA_LSSIReadBack          0x8a0
94 #define rFPGA0_XB_LSSIReadBack          0x8a4
95 #define rFPGA0_XC_LSSIReadBack          0x8a8
96 #define rFPGA0_XD_LSSIReadBack          0x8ac
97 #define rFPGA0_PSDReport                0x8b4
98 #define rFPGA0_XAB_RFInterfaceRB        0x8e0
99 #define rFPGA0_XCD_RFInterfaceRB        0x8e4
100
101 /* Page 9 - RF mode & OFDM TxSC */
102 #define rFPGA1_RFMOD                    0x900
103 #define rFPGA1_TxBlock                  0x904
104 #define rFPGA1_DebugSelect              0x908
105 #define rFPGA1_TxInfo                   0x90c
106
107 #define rCCK0_System                    0xa00
108 #define rCCK0_AFESetting                0xa04
109 #define rCCK0_CCA                       0xa08
110 /* AGC default value, saturation level */
111 #define rCCK0_RxAGC1                    0xa0c
112 #define rCCK0_RxAGC2                    0xa10 /* AGC & DAGC */
113 #define rCCK0_RxHP                      0xa14
114 /* Timing recovery & channel estimation threshold */
115 #define rCCK0_DSPParameter1             0xa18
116 #define rCCK0_DSPParameter2             0xa1c /* SQ threshold */
117 #define rCCK0_TxFilter1                 0xa20
118 #define rCCK0_TxFilter2                 0xa24
119 #define rCCK0_DebugPort                 0xa28 /* Debug port and TX filter 3 */
120 #define rCCK0_FalseAlarmReport          0xa2c
121 #define rCCK0_TRSSIReport               0xa50
122 #define rCCK0_RxReport                  0xa54
123 #define rCCK0_FACounterLower            0xa5c
124 #define rCCK0_FACounterUpper            0xa58
125
126 #define rOFDM0_LSTF                     0xc00
127 #define rOFDM0_TRxPathEnable            0xc04
128 #define rOFDM0_TRMuxPar                 0xc08
129 #define rOFDM0_TRSWIsolation            0xc0c
130 /* RxIQ DC offset, Rx digital filter, DC notch filter */
131 #define rOFDM0_XARxAFE                  0xc10
132 #define rOFDM0_XARxIQImbalance          0xc14 /* RxIQ imbalance matrix */
133 #define rOFDM0_XBRxAFE                  0xc18
134 #define rOFDM0_XBRxIQImbalance          0xc1c
135 #define rOFDM0_XCRxAFE                  0xc20
136 #define rOFDM0_XCRxIQImbalance          0xc24
137 #define rOFDM0_XDRxAFE                  0xc28
138 #define rOFDM0_XDRxIQImbalance          0xc2c
139 #define rOFDM0_RxDetector1              0xc30 /* PD, BW & SBD */
140 #define rOFDM0_RxDetector2              0xc34 /* SBD */
141 #define rOFDM0_RxDetector3              0xc38 /* Frame Sync */
142 /* PD, SBD, Frame Sync & Short-GI */
143 #define rOFDM0_RxDetector4              0xc3c
144 #define rOFDM0_RxDSP                    0xc40 /* Rx Sync Path */
145 #define rOFDM0_CFOandDAGC               0xc44 /* CFO & DAGC */
146 #define rOFDM0_CCADropThreshold         0xc48
147 #define rOFDM0_ECCAThreshold            0xc4c /* Energy CCA */
148 #define rOFDM0_XAAGCCore1               0xc50
149 #define rOFDM0_XAAGCCore2               0xc54
150 #define rOFDM0_XBAGCCore1               0xc58
151 #define rOFDM0_XBAGCCore2               0xc5c
152 #define rOFDM0_XCAGCCore1               0xc60
153 #define rOFDM0_XCAGCCore2               0xc64
154 #define rOFDM0_XDAGCCore1               0xc68
155 #define rOFDM0_XDAGCCore2               0xc6c
156 #define rOFDM0_AGCParameter1            0xc70
157 #define rOFDM0_AGCParameter2            0xc74
158 #define rOFDM0_AGCRSSITable             0xc78
159 #define rOFDM0_HTSTFAGC                 0xc7c
160 #define rOFDM0_XATxIQImbalance          0xc80
161 #define rOFDM0_XATxAFE                  0xc84
162 #define rOFDM0_XBTxIQImbalance          0xc88
163 #define rOFDM0_XBTxAFE                  0xc8c
164 #define rOFDM0_XCTxIQImbalance          0xc90
165 #define rOFDM0_XCTxAFE                  0xc94
166 #define rOFDM0_XDTxIQImbalance          0xc98
167 #define rOFDM0_XDTxAFE                  0xc9c
168 #define rOFDM0_RxHPParameter            0xce0
169 #define rOFDM0_TxPseudoNoiseWgt         0xce4
170 #define rOFDM0_FrameSync                0xcf0
171 #define rOFDM0_DFSReport                0xcf4
172 #define rOFDM0_TxCoeff1                 0xca4
173 #define rOFDM0_TxCoeff2                 0xca8
174 #define rOFDM0_TxCoeff3                 0xcac
175 #define rOFDM0_TxCoeff4                 0xcb0
176 #define rOFDM0_TxCoeff5                 0xcb4
177 #define rOFDM0_TxCoeff6                 0xcb8
178
179
180 #define rOFDM1_LSTF                     0xd00
181 #define rOFDM1_TRxPathEnable            0xd04
182 #define rOFDM1_CFO                      0xd08
183 #define rOFDM1_CSI1                     0xd10
184 #define rOFDM1_SBD                      0xd14
185 #define rOFDM1_CSI2                     0xd18
186 #define rOFDM1_CFOTracking              0xd2c
187 #define rOFDM1_TRxMesaure1              0xd34
188 #define rOFDM1_IntfDet                  0xd3c
189 #define rOFDM1_PseudoNoiseStateAB       0xd50
190 #define rOFDM1_PseudoNoiseStateCD       0xd54
191 #define rOFDM1_RxPseudoNoiseWgt         0xd58
192 #define rOFDM_PHYCounter1               0xda0 /* cca, parity fail */
193 #define rOFDM_PHYCounter2               0xda4 /* rate illegal, crc8 fail */
194 #define rOFDM_PHYCounter3               0xda8 /* MCS not supported */
195 #define rOFDM_ShortCFOAB                0xdac
196 #define rOFDM_ShortCFOCD                0xdb0
197 #define rOFDM_LongCFOAB                 0xdb4
198 #define rOFDM_LongCFOCD                 0xdb8
199 #define rOFDM_TailCFOAB                 0xdbc
200 #define rOFDM_TailCFOCD                 0xdc0
201 #define rOFDM_PWMeasure1                0xdc4
202 #define rOFDM_PWMeasure2                0xdc8
203 #define rOFDM_BWReport                  0xdcc
204 #define rOFDM_AGCReport                 0xdd0
205 #define rOFDM_RxSNR                     0xdd4
206 #define rOFDM_RxEVMCSI                  0xdd8
207 #define rOFDM_SIGReport                 0xddc
208
209 #define rTxAGC_Rate18_06                0xe00
210 #define rTxAGC_Rate54_24                0xe04
211 #define rTxAGC_CCK_Mcs32                0xe08
212 #define rTxAGC_Mcs03_Mcs00              0xe10
213 #define rTxAGC_Mcs07_Mcs04              0xe14
214 #define rTxAGC_Mcs11_Mcs08              0xe18
215 #define rTxAGC_Mcs15_Mcs12              0xe1c
216
217
218 #define rZebra1_HSSIEnable              0x0
219 #define rZebra1_TRxEnable1              0x1
220 #define rZebra1_TRxEnable2              0x2
221 #define rZebra1_AGC                     0x4
222 #define rZebra1_ChargePump              0x5
223 #define rZebra1_Channel                 0x7
224 #define rZebra1_TxGain                  0x8
225 #define rZebra1_TxLPF                   0x9
226 #define rZebra1_RxLPF                   0xb
227 #define rZebra1_RxHPFCorner             0xc
228
229 /* Zebra 4 */
230 #define rGlobalCtrl                     0
231 #define rRTL8256_TxLPF                  19
232 #define rRTL8256_RxLPF                  11
233
234 /* RTL8258 */
235 #define rRTL8258_TxLPF                  0x11
236 #define rRTL8258_RxLPF                  0x13
237 #define rRTL8258_RSSILPF                0xa
238
239 /* Bit Mask - Page 1*/
240 #define bBBResetB                       0x100
241 #define bGlobalResetB                   0x200
242 #define bOFDMTxStart                    0x4
243 #define bCCKTxStart                     0x8
244 #define bCRC32Debug                     0x100
245 #define bPMACLoopback                   0x10
246 #define bTxLSIG                         0xffffff
247 #define bOFDMTxRate                     0xf
248 #define bOFDMTxReserved                 0x10
249 #define bOFDMTxLength                   0x1ffe0
250 #define bOFDMTxParity                   0x20000
251 #define bTxHTSIG1                       0xffffff
252 #define bTxHTMCSRate                    0x7f
253 #define bTxHTBW 0x80
254 #define bTxHTLength                     0xffff00
255 #define bTxHTSIG2                       0xffffff
256 #define bTxHTSmoothing                  0x1
257 #define bTxHTSounding                   0x2
258 #define bTxHTReserved                   0x4
259 #define bTxHTAggreation                 0x8
260 #define bTxHTSTBC                       0x30
261 #define bTxHTAdvanceCoding              0x40
262 #define bTxHTShortGI                    0x80
263 #define bTxHTNumberHT_LTF               0x300
264 #define bTxHTCRC8                       0x3fc00
265 #define bCounterReset                   0x10000
266 #define bNumOfOFDMTx                    0xffff
267 #define bNumOfCCKTx                     0xffff0000
268 #define bTxIdleInterval                 0xffff
269 #define bOFDMService                    0xffff0000
270 #define bTxMACHeader                    0xffffffff
271 #define bTxDataInit                     0xff
272 #define bTxHTMode                       0x100
273 #define bTxDataType                     0x30000
274 #define bTxRandomSeed                   0xffffffff
275 #define bCCKTxPreamble                  0x1
276 #define bCCKTxSFD                       0xffff0000
277 #define bCCKTxSIG                       0xff
278 #define bCCKTxService                   0xff00
279 #define bCCKLengthExt                   0x8000
280 #define bCCKTxLength                    0xffff0000
281 #define bCCKTxCRC16                     0xffff
282 #define bCCKTxStatus                    0x1
283 #define bOFDMTxStatus                   0x2
284 /* Bit Mask - Page 8 */
285 #define bRFMOD                          0x1
286 #define bJapanMode                      0x2
287 #define bCCKTxSC                        0x30
288 #define bCCKEn                          0x1000000
289 #define bOFDMEn                         0x2000000
290 #define bOFDMRxADCPhase                 0x10000
291 #define bOFDMTxDACPhase                 0x40000
292 #define bXATxAGC                        0x3f
293 #define bXBTxAGC                        0xf00
294 #define bXCTxAGC                        0xf000
295 #define bXDTxAGC                        0xf0000
296 #define bPAStart                        0xf0000000
297 #define bTRStart                        0x00f00000
298 #define bRFStart                        0x0000f000
299 #define bBBStart                        0x000000f0
300 #define bBBCCKStart                     0x0000000f
301 /* Bit Mask - rFPGA0_RFTiming2 */
302 #define bPAEnd                          0xf
303 #define bTREnd                          0x0f000000
304 #define bRFEnd                          0x000f0000
305 /* T2R */
306 #define bCCAMask                        0x000000f0
307 #define bR2RCCAMask                     0x00000f00
308 #define bHSSI_R2TDelay                  0xf8000000
309 #define bHSSI_T2RDelay                  0xf80000
310 /* Channel gain at continue TX. */
311 #define bContTxHSSI                     0x400
312 #define bIGFromCCK                      0x200
313 #define bAGCAddress                     0x3f
314 #define bRxHPTx                         0x7000
315 #define bRxHPT2R                        0x38000
316 #define bRxHPCCKIni                     0xc0000
317 #define bAGCTxCode                      0xc00000
318 #define bAGCRxCode                      0x300000
319 #define b3WireDataLength                0x800
320 #define b3WireAddressLength             0x400
321 #define b3WireRFPowerDown               0x1
322 /*#define bHWSISelect                   0x8 */
323 #define b5GPAPEPolarity                 0x40000000
324 #define b2GPAPEPolarity                 0x80000000
325 #define bRFSW_TxDefaultAnt              0x3
326 #define bRFSW_TxOptionAnt               0x30
327 #define bRFSW_RxDefaultAnt              0x300
328 #define bRFSW_RxOptionAnt               0x3000
329 #define bRFSI_3WireData                 0x1
330 #define bRFSI_3WireClock                0x2
331 #define bRFSI_3WireLoad                 0x4
332 #define bRFSI_3WireRW                   0x8
333 /* 3-wire total control */
334 #define bRFSI_3Wire                     0xf
335 #define bRFSI_RFENV                     0x10
336 #define bRFSI_TRSW                      0x20
337 #define bRFSI_TRSWB                     0x40
338 #define bRFSI_ANTSW                     0x100
339 #define bRFSI_ANTSWB                    0x200
340 #define bRFSI_PAPE                      0x400
341 #define bRFSI_PAPE5G                    0x800
342 #define bBandSelect                     0x1
343 #define bHTSIG2_GI                      0x80
344 #define bHTSIG2_Smoothing               0x01
345 #define bHTSIG2_Sounding                0x02
346 #define bHTSIG2_Aggreaton               0x08
347 #define bHTSIG2_STBC                    0x30
348 #define bHTSIG2_AdvCoding               0x40
349 #define bHTSIG2_NumOfHTLTF              0x300
350 #define bHTSIG2_CRC8                    0x3fc
351 #define bHTSIG1_MCS                     0x7f
352 #define bHTSIG1_BandWidth               0x80
353 #define bHTSIG1_HTLength                0xffff
354 #define bLSIG_Rate                      0xf
355 #define bLSIG_Reserved                  0x10
356 #define bLSIG_Length                    0x1fffe
357 #define bLSIG_Parity                    0x20
358 #define bCCKRxPhase                     0x4
359 #define bLSSIReadAddress                0x3f000000 /* LSSI "read" address */
360 #define bLSSIReadEdge                   0x80000000 /* LSSI "read" edge signal */
361 #define bLSSIReadBackData               0xfff
362 #define bLSSIReadOKFlag                 0x1000
363 #define bCCKSampleRate                  0x8 /* 0: 44 MHz, 1: 88MHz */
364
365 #define bRegulator0Standby              0x1
366 #define bRegulatorPLLStandby            0x2
367 #define bRegulator1Standby              0x4
368 #define bPLLPowerUp                     0x8
369 #define bDPLLPowerUp                    0x10
370 #define bDA10PowerUp                    0x20
371 #define bAD7PowerUp                     0x200
372 #define bDA6PowerUp                     0x2000
373 #define bXtalPowerUp                    0x4000
374 #define b40MDClkPowerUP                 0x8000
375 #define bDA6DebugMode                   0x20000
376 #define bDA6Swing                       0x380000
377 #define bADClkPhase                     0x4000000
378 #define b80MClkDelay                    0x18000000
379 #define bAFEWatchDogEnable              0x20000000
380 #define bXtalCap                        0x0f000000
381 #define bXtalCap01                      0xc0000000
382 #define bXtalCap23                      0x3
383 #define bXtalCap92x                     0x0f000000
384 #define bIntDifClkEnable                0x400
385 #define bExtSigClkEnable                0x800
386 #define bBandgapMbiasPowerUp            0x10000
387 #define bAD11SHGain                     0xc0000
388 #define bAD11InputRange                 0x700000
389 #define bAD11OPCurrent                  0x3800000
390 #define bIPathLoopback                  0x4000000
391 #define bQPathLoopback                  0x8000000
392 #define bAFELoopback                    0x10000000
393 #define bDA10Swing                      0x7e0
394 #define bDA10Reverse                    0x800
395 #define bDAClkSource                    0x1000
396 #define bAD7InputRange                  0x6000
397 #define bAD7Gain                        0x38000
398 #define bAD7OutputCMMode                0x40000
399 #define bAD7InputCMMode                 0x380000
400 #define bAD7Current                     0xc00000
401 #define bRegulatorAdjust                0x7000000
402 #define bAD11PowerUpAtTx                0x1
403 #define bDA10PSAtTx                     0x10
404 #define bAD11PowerUpAtRx                0x100
405 #define bDA10PSAtRx                     0x1000
406
407 #define bCCKRxAGCFormat                 0x200
408
409 #define bPSDFFTSamplepPoint             0xc000
410 #define bPSDAverageNum                  0x3000
411 #define bIQPathControl                  0xc00
412 #define bPSDFreq                        0x3ff
413 #define bPSDAntennaPath                 0x30
414 #define bPSDIQSwitch                    0x40
415 #define bPSDRxTrigger                   0x400000
416 #define bPSDTxTrigger                   0x80000000
417 #define bPSDSineToneScale               0x7f000000
418 #define bPSDReport                      0xffff
419
420 /* Page 8 */
421 #define bOFDMTxSC                       0x30000000
422 #define bCCKTxOn                        0x1
423 #define bOFDMTxOn                       0x2
424 /* Reset debug page and also HWord, LWord */
425 #define bDebugPage                      0xfff
426 /* Reset debug page and LWord */
427 #define bDebugItem                      0xff
428 #define bAntL                           0x10
429 #define bAntNonHT                       0x100
430 #define bAntHT1                         0x1000
431 #define bAntHT2                         0x10000
432 #define bAntHT1S1                       0x100000
433 #define bAntNonHTS1                     0x1000000
434
435 /* Page a */
436 #define bCCKBBMode                      0x3
437 #define bCCKTxPowerSaving               0x80
438 #define bCCKRxPowerSaving               0x40
439 #define bCCKSideBand                    0x10
440 #define bCCKScramble                    0x8
441 #define bCCKAntDiversity                0x8000
442 #define bCCKCarrierRecovery             0x4000
443 #define bCCKTxRate                      0x3000
444 #define bCCKDCCancel                    0x0800
445 #define bCCKISICancel                   0x0400
446 #define bCCKMatchFilter                 0x0200
447 #define bCCKEqualizer                   0x0100
448 #define bCCKPreambleDetect              0x800000
449 #define bCCKFastFalseCCA                0x400000
450 #define bCCKChEstStart                  0x300000
451 #define bCCKCCACount                    0x080000
452 #define bCCKcs_lim                      0x070000
453 #define bCCKBistMode                    0x80000000
454 #define bCCKCCAMask                     0x40000000
455 #define bCCKTxDACPhase                  0x4
456 #define bCCKRxADCPhase                  0x20000000 /* r_rx_clk */
457 #define bCCKr_cp_mode0                  0x0100
458 #define bCCKTxDCOffset                  0xf0
459 #define bCCKRxDCOffset                  0xf
460 #define bCCKCCAMode                     0xc000
461 #define bCCKFalseCS_lim                 0x3f00
462 #define bCCKCS_ratio                    0xc00000
463 #define bCCKCorgBit_sel                 0x300000
464 #define bCCKPD_lim                      0x0f0000
465 #define bCCKNewCCA                      0x80000000
466 #define bCCKRxHPofIG                    0x8000
467 #define bCCKRxIG                        0x7f00
468 #define bCCKLNAPolarity                 0x800000
469 #define bCCKRx1stGain                   0x7f0000
470 /* CCK Rx Initial gain polarity */
471 #define bCCKRFExtend                    0x20000000
472 #define bCCKRxAGCSatLevel               0x1f000000
473 #define bCCKRxAGCSatCount               0xe0
474 /* AGCSAmp_dly */
475 #define bCCKRxRFSettle                  0x1f
476 #define bCCKFixedRxAGC                  0x8000
477 /*#define bCCKRxAGCFormat               0x4000  remove to HSSI register 0x824 */
478 #define bCCKAntennaPolarity             0x2000
479 #define bCCKTxFilterType                0x0c00
480 #define bCCKRxAGCReportType             0x0300
481 #define bCCKRxDAGCEn                    0x80000000
482 #define bCCKRxDAGCPeriod                0x20000000
483 #define bCCKRxDAGCSatLevel              0x1f000000
484 #define bCCKTimingRecovery              0x800000
485 #define bCCKTxC0                        0x3f0000
486 #define bCCKTxC1                        0x3f000000
487 #define bCCKTxC2                        0x3f
488 #define bCCKTxC3                        0x3f00
489 #define bCCKTxC4                        0x3f0000
490 #define bCCKTxC5                        0x3f000000
491 #define bCCKTxC6                        0x3f
492 #define bCCKTxC7                        0x3f00
493 #define bCCKDebugPort                   0xff0000
494 #define bCCKDACDebug                    0x0f000000
495 #define bCCKFalseAlarmEnable            0x8000
496 #define bCCKFalseAlarmRead              0x4000
497 #define bCCKTRSSI                       0x7f
498 #define bCCKRxAGCReport                 0xfe
499 #define bCCKRxReport_AntSel             0x80000000
500 #define bCCKRxReport_MFOff              0x40000000
501 #define bCCKRxRxReport_SQLoss           0x20000000
502 #define bCCKRxReport_Pktloss            0x10000000
503 #define bCCKRxReport_Lockedbit          0x08000000
504 #define bCCKRxReport_RateError          0x04000000
505 #define bCCKRxReport_RxRate             0x03000000
506 #define bCCKRxFACounterLower            0xff
507 #define bCCKRxFACounterUpper            0xff000000
508 #define bCCKRxHPAGCStart                0xe000
509 #define bCCKRxHPAGCFinal                0x1c00
510
511 #define bCCKRxFalseAlarmEnable          0x8000
512 #define bCCKFACounterFreeze             0x4000
513
514 #define bCCKTxPathSel                   0x10000000
515 #define bCCKDefaultRxPath               0xc000000
516 #define bCCKOptionRxPath                0x3000000
517
518 /* Page c */
519 #define bNumOfSTF                       0x3
520 #define bShift_L                        0xc0
521 #define bGI_TH                          0xc
522 #define bRxPathA                        0x1
523 #define bRxPathB                        0x2
524 #define bRxPathC                        0x4
525 #define bRxPathD                        0x8
526 #define bTxPathA                        0x1
527 #define bTxPathB                        0x2
528 #define bTxPathC                        0x4
529 #define bTxPathD                        0x8
530 #define bTRSSIFreq                      0x200
531 #define bADCBackoff                     0x3000
532 #define bDFIRBackoff                    0xc000
533 #define bTRSSILatchPhase                0x10000
534 #define bRxIDCOffset                    0xff
535 #define bRxQDCOffset                    0xff00
536 #define bRxDFIRMode                     0x1800000
537 #define bRxDCNFType                     0xe000000
538 #define bRXIQImb_A                      0x3ff
539 #define bRXIQImb_B                      0xfc00
540 #define bRXIQImb_C                      0x3f0000
541 #define bRXIQImb_D                      0xffc00000
542 #define bDC_dc_Notch                    0x60000
543 #define bRxNBINotch                     0x1f000000
544 #define bPD_TH                          0xf
545 #define bPD_TH_Opt2                     0xc000
546 #define bPWED_TH                        0x700
547 #define bIfMF_Win_L                     0x800
548 #define bPD_Option                      0x1000
549 #define bMF_Win_L                       0xe000
550 #define bBW_Search_L                    0x30000
551 #define bwin_enh_L                      0xc0000
552 #define bBW_TH                          0x700000
553 #define bED_TH2                         0x3800000
554 #define bBW_option                      0x4000000
555 #define bRatio_TH                       0x18000000
556 #define bWindow_L                       0xe0000000
557 #define bSBD_Option                     0x1
558 #define bFrame_TH                       0x1c
559 #define bFS_Option                      0x60
560 #define bDC_Slope_check                 0x80
561 #define bFGuard_Counter_DC_L            0xe00
562 #define bFrame_Weight_Short             0x7000
563 #define bSub_Tune                       0xe00000
564 #define bFrame_DC_Length                0xe000000
565 #define bSBD_start_offset               0x30000000
566 #define bFrame_TH_2                     0x7
567 #define bFrame_GI2_TH                   0x38
568 #define bGI2_Sync_en                    0x40
569 #define bSarch_Short_Early              0x300
570 #define bSarch_Short_Late               0xc00
571 #define bSarch_GI2_Late                 0x70000
572 #define bCFOAntSum                      0x1
573 #define bCFOAcc                         0x2
574 #define bCFOStartOffset                 0xc
575 #define bCFOLookBack                    0x70
576 #define bCFOSumWeight                   0x80
577 #define bDAGCEnable                     0x10000
578 #define bTXIQImb_A                      0x3ff
579 #define bTXIQImb_B                      0xfc00
580 #define bTXIQImb_C                      0x3f0000
581 #define bTXIQImb_D                      0xffc00000
582 #define bTxIDCOffset                    0xff
583 #define bTxQDCOffset                    0xff00
584 #define bTxDFIRMode                     0x10000
585 #define bTxPesudoNoiseOn                0x4000000
586 #define bTxPesudoNoise_A                0xff
587 #define bTxPesudoNoise_B                0xff00
588 #define bTxPesudoNoise_C                0xff0000
589 #define bTxPesudoNoise_D                0xff000000
590 #define bCCADropOption                  0x20000
591 #define bCCADropThres                   0xfff00000
592 #define bEDCCA_H                        0xf
593 #define bEDCCA_L                        0xf0
594 #define bLambda_ED                      0x300
595 #define bRxInitialGain                  0x7f
596 #define bRxAntDivEn                     0x80
597 #define bRxAGCAddressForLNA             0x7f00
598 #define bRxHighPowerFlow                0x8000
599 #define bRxAGCFreezeThres               0xc0000
600 #define bRxFreezeStep_AGC1              0x300000
601 #define bRxFreezeStep_AGC2              0xc00000
602 #define bRxFreezeStep_AGC3              0x3000000
603 #define bRxFreezeStep_AGC0              0xc000000
604 #define bRxRssi_Cmp_En                  0x10000000
605 #define bRxQuickAGCEn                   0x20000000
606 #define bRxAGCFreezeThresMode           0x40000000
607 #define bRxOverFlowCheckType            0x80000000
608 #define bRxAGCShift                     0x7f
609 #define bTRSW_Tri_Only                  0x80
610 #define bPowerThres                     0x300
611 #define bRxAGCEn                        0x1
612 #define bRxAGCTogetherEn                0x2
613 #define bRxAGCMin                       0x4
614 #define bRxHP_Ini                       0x7
615 #define bRxHP_TRLNA                     0x70
616 #define bRxHP_RSSI                      0x700
617 #define bRxHP_BBP1                      0x7000
618 #define bRxHP_BBP2                      0x70000
619 #define bRxHP_BBP3                      0x700000
620 /* The threshold for high power */
621 #define bRSSI_H                         0x7f0000
622 /* The threshold for ant diversity */
623 #define bRSSI_Gen                       0x7f000000
624 #define bRxSettle_TRSW                  0x7
625 #define bRxSettle_LNA                   0x38
626 #define bRxSettle_RSSI                  0x1c0
627 #define bRxSettle_BBP                   0xe00
628 #define bRxSettle_RxHP                  0x7000
629 #define bRxSettle_AntSW_RSSI            0x38000
630 #define bRxSettle_AntSW                 0xc0000
631 #define bRxProcessTime_DAGC             0x300000
632 #define bRxSettle_HSSI                  0x400000
633 #define bRxProcessTime_BBPPW            0x800000
634 #define bRxAntennaPowerShift            0x3000000
635 #define bRSSITableSelect                0xc000000
636 #define bRxHP_Final                     0x7000000
637 #define bRxHTSettle_BBP                 0x7
638 #define bRxHTSettle_HSSI                0x8
639 #define bRxHTSettle_RxHP                0x70
640 #define bRxHTSettle_BBPPW               0x80
641 #define bRxHTSettle_Idle                0x300
642 #define bRxHTSettle_Reserved            0x1c00
643 #define bRxHTRxHPEn                     0x8000
644 #define bRxHTAGCFreezeThres             0x30000
645 #define bRxHTAGCTogetherEn              0x40000
646 #define bRxHTAGCMin                     0x80000
647 #define bRxHTAGCEn                      0x100000
648 #define bRxHTDAGCEn                     0x200000
649 #define bRxHTRxHP_BBP                   0x1c00000
650 #define bRxHTRxHP_Final                 0xe0000000
651 #define bRxPWRatioTH                    0x3
652 #define bRxPWRatioEn                    0x4
653 #define bRxMFHold                       0x3800
654 #define bRxPD_Delay_TH1                 0x38
655 #define bRxPD_Delay_TH2                 0x1c0
656 #define bRxPD_DC_COUNT_MAX              0x600
657 /*#define bRxMF_Hold                    0x3800*/
658 #define bRxPD_Delay_TH                  0x8000
659 #define bRxProcess_Delay                0xf0000
660 #define bRxSearchrange_GI2_Early        0x700000
661 #define bRxFrame_Guard_Counter_L        0x3800000
662 #define bRxSGI_Guard_L                  0xc000000
663 #define bRxSGI_Search_L                 0x30000000
664 #define bRxSGI_TH                       0xc0000000
665 #define bDFSCnt0                        0xff
666 #define bDFSCnt1                        0xff00
667 #define bDFSFlag                        0xf0000
668
669 #define bMFWeightSum            0x300000
670 #define bMinIdxTH               0x7f000000
671
672 #define bDAFormat               0x40000
673
674 #define bTxChEmuEnable          0x01000000
675
676 #define bTRSWIsolation_A        0x7f
677 #define bTRSWIsolation_B        0x7f00
678 #define bTRSWIsolation_C        0x7f0000
679 #define bTRSWIsolation_D        0x7f000000
680
681 #define bExtLNAGain             0x7c00
682
683 /* Page d */
684 #define bSTBCEn                 0x4
685 #define bAntennaMapping         0x10
686 #define bNss                    0x20
687 #define bCFOAntSumD             0x200
688 #define bPHYCounterReset        0x8000000
689 #define bCFOReportGet           0x4000000
690 #define bOFDMContinueTx         0x10000000
691 #define bOFDMSingleCarrier      0x20000000
692 #define bOFDMSingleTone         0x40000000
693 /* #define bRxPath1             0x01
694  * #define bRxPath2             0x02
695  * #define bRxPath3             0x04
696  * #define bRxPath4             0x08
697  * #define bTxPath1             0x10
698  * #define bTxPath2             0x20
699 */
700 #define bHTDetect               0x100
701 #define bCFOEn                  0x10000
702 #define bCFOValue               0xfff00000
703 #define bSigTone_Re             0x3f
704 #define bSigTone_Im             0x7f00
705 #define bCounter_CCA            0xffff
706 #define bCounter_ParityFail     0xffff0000
707 #define bCounter_RateIllegal    0xffff
708 #define bCounter_CRC8Fail       0xffff0000
709 #define bCounter_MCSNoSupport   0xffff
710 #define bCounter_FastSync       0xffff
711 #define bShortCFO               0xfff
712 #define bShortCFOTLength        12 /* total */
713 #define bShortCFOFLength        11 /* fraction */
714 #define bLongCFO                0x7ff
715 #define bLongCFOTLength         11
716 #define bLongCFOFLength         11
717 #define bTailCFO                0x1fff
718 #define bTailCFOTLength         13
719 #define bTailCFOFLength         12
720
721 #define bmax_en_pwdB            0xffff
722 #define bCC_power_dB            0xffff0000
723 #define bnoise_pwdB             0xffff
724 #define bPowerMeasTLength       10
725 #define bPowerMeasFLength       3
726 #define bRx_HT_BW               0x1
727 #define bRxSC                   0x6
728 #define bRx_HT                  0x8
729
730 #define bNB_intf_det_on         0x1
731 #define bIntf_win_len_cfg       0x30
732 #define bNB_Intf_TH_cfg         0x1c0
733
734 #define bRFGain                 0x3f
735 #define bTableSel               0x40
736 #define bTRSW                   0x80
737
738 #define bRxSNR_A                0xff
739 #define bRxSNR_B                0xff00
740 #define bRxSNR_C                0xff0000
741 #define bRxSNR_D                0xff000000
742 #define bSNREVMTLength          8
743 #define bSNREVMFLength          1
744
745 #define bCSI1st                 0xff
746 #define bCSI2nd                 0xff00
747 #define bRxEVM1st               0xff0000
748 #define bRxEVM2nd               0xff000000
749
750 #define bSIGEVM                 0xff
751 #define bPWDB                   0xff00
752 #define bSGIEN                  0x10000
753
754 #define bSFactorQAM1            0xf
755 #define bSFactorQAM2            0xf0
756 #define bSFactorQAM3            0xf00
757 #define bSFactorQAM4            0xf000
758 #define bSFactorQAM5            0xf0000
759 #define bSFactorQAM6            0xf0000
760 #define bSFactorQAM7            0xf00000
761 #define bSFactorQAM8            0xf000000
762 #define bSFactorQAM9            0xf0000000
763 #define bCSIScheme              0x100000
764
765 #define bNoiseLvlTopSet         0x3
766 #define bChSmooth               0x4
767 #define bChSmoothCfg1           0x38
768 #define bChSmoothCfg2           0x1c0
769 #define bChSmoothCfg3           0xe00
770 #define bChSmoothCfg4           0x7000
771 #define bMRCMode                0x800000
772 #define bTHEVMCfg               0x7000000
773
774 #define bLoopFitType            0x1
775 #define bUpdCFO                 0x40
776 #define bUpdCFOOffData          0x80
777 #define bAdvUpdCFO              0x100
778 #define bAdvTimeCtrl            0x800
779 #define bUpdClko                0x1000
780 #define bFC                     0x6000
781 #define bTrackingMode           0x8000
782 #define bPhCmpEnable            0x10000
783 #define bUpdClkoLTF             0x20000
784 #define bComChCFO               0x40000
785 #define bCSIEstiMode            0x80000
786 #define bAdvUpdEqz              0x100000
787 #define bUChCfg                 0x7000000
788 #define bUpdEqz                 0x8000000
789
790 /* Page e */
791 #define bTxAGCRate18_06         0x7f7f7f7f
792 #define bTxAGCRate54_24         0x7f7f7f7f
793 #define bTxAGCRateMCS32         0x7f
794 #define bTxAGCRateCCK           0x7f00
795 #define bTxAGCRateMCS3_MCS0     0x7f7f7f7f
796 #define bTxAGCRateMCS7_MCS4     0x7f7f7f7f
797 #define bTxAGCRateMCS11_MCS8    0x7f7f7f7f
798 #define bTxAGCRateMCS15_MCS12   0x7f7f7f7f
799
800 #define bRxPesudoNoiseOn        0x20000000 /* Rx Pseduo noise */
801 #define bRxPesudoNoise_A        0xff
802 #define bRxPesudoNoise_B        0xff00
803 #define bRxPesudoNoise_C        0xff0000
804 #define bRxPesudoNoise_D        0xff000000
805 #define bPesudoNoiseState_A     0xffff
806 #define bPesudoNoiseState_B     0xffff0000
807 #define bPesudoNoiseState_C     0xffff
808 #define bPesudoNoiseState_D     0xffff0000
809
810 /* RF Zebra 1 */
811 #define bZebra1_HSSIEnable      0x8
812 #define bZebra1_TRxControl      0xc00
813 #define bZebra1_TRxGainSetting  0x07f
814 #define bZebra1_RxCorner        0xc00
815 #define bZebra1_TxChargePump    0x38
816 #define bZebra1_RxChargePump    0x7
817 #define bZebra1_ChannelNum      0xf80
818 #define bZebra1_TxLPFBW 0x400
819 #define bZebra1_RxLPFBW 0x600
820
821 /* Zebra4 */
822 #define bRTL8256RegModeCtrl1    0x100
823 #define bRTL8256RegModeCtrl0    0x40
824 #define bRTL8256_TxLPFBW        0x18
825 #define bRTL8256_RxLPFBW        0x600
826
827 /* RTL8258 */
828 #define bRTL8258_TxLPFBW        0xc
829 #define bRTL8258_RxLPFBW        0xc00
830 #define bRTL8258_RSSILPFBW      0xc0
831
832 /* byte enable for sb_write */
833 #define bByte0  0x1
834 #define bByte1  0x2
835 #define bByte2  0x4
836 #define bByte3  0x8
837 #define bWord0  0x3
838 #define bWord1  0xc
839 #define bDWord  0xf
840
841 /* for PutRegsetting & GetRegSetting BitMask */
842 #define bMaskByte0      0xff
843 #define bMaskByte1      0xff00
844 #define bMaskByte2      0xff0000
845 #define bMaskByte3      0xff000000
846 #define bMaskHWord      0xffff0000
847 #define bMaskLWord      0x0000ffff
848 #define bMaskDWord      0xffffffff
849
850 /* for PutRFRegsetting & GetRFRegSetting BitMask */
851 #define bMask12Bits     0xfff
852
853 #define bEnable         0x1
854 #define bDisable        0x0
855
856 #define LeftAntenna     0x0
857 #define RightAntenna    0x1
858
859 #define tCheckTxStatus          500 /* 500 ms */
860 #define tUpdateRxCounter        100 /* 100 ms */
861
862 #define rateCCK         0
863 #define rateOFDM        1
864 #define rateHT          2
865
866 #define bPMAC_End       0x1ff /* define Register-End */
867 #define bFPGAPHY0_End   0x8ff
868 #define bFPGAPHY1_End   0x9ff
869 #define bCCKPHY0_End    0xaff
870 #define bOFDMPHY0_End   0xcff
871 #define bOFDMPHY1_End   0xdff
872
873
874 #define bPMACControl    0x0
875 #define bWMACControl    0x1
876 #define bWNICControl    0x2
877
878 #define PathA   0x0
879 #define PathB   0x1
880 #define PathC   0x2
881 #define PathD   0x3
882
883 #define rRTL8256RxMixerPole     0xb
884 #define bZebraRxMixerPole       0x6
885 #define rRTL8256TxBBOPBias      0x9
886 #define bRTL8256TxBBOPBias      0x400
887 #define rRTL8256TxBBBW          19
888 #define bRTL8256TxBBBW          0x18
889
890 #endif