hc
2024-05-09 b9d5c334faa47a75f1f28e72d203fc0334e8471d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
/******************************************************************************
 *
 * Copyright(c) 2019 Realtek Corporation.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
 * more details.
 *
 *****************************************************************************/
#ifndef _RTL8723F_HAL_H_
#define _RTL8723F_HAL_H_
 
#include <osdep_service.h>        /* BIT(x) */
#include <drv_types.h>            /* PADAPTER */
#include "../hal/halmac/halmac_api.h"    /* MAC REG definition */
 
#define MAX_RECVBUF_SZ        16384    /* 16KB (RX_FIFO_SIZE_8723F), TX: 32KB */
 
/*
 * MAC Register definition
 */
#define REG_LEDCFG0        REG_LED_CFG_8723F    /* rtw_mp.c */
#define MSR            (REG_CR_8723F + 2)    /* rtw_mp.c & hal_com.c */
#define MSR1            REG_CR_EXT_8723F    /* rtw_mp.c & hal_com.c */
#define REG_C2HEVT_MSG_NORMAL    0x1A0            /* hal_com.c */
#define REG_C2HEVT_CLEAR    0x1AF            /* hal_com.c */
#define REG_BCN_CTRL_1        REG_BCN_CTRL_CLINT0_8723F    /* hal_com.c */
 
#define REG_WOWLAN_WAKE_REASON    0x01C7 /* hal_com.c */
#define REG_GPIO_PIN_CTRL_2         REG_GPIO_EXT_CTRL_8723F    /* hal_com.c */
#define REG_FIFOPAGE                 REG_FIFOPAGE_INFO_8723F /* hal_com.c */
#define REG_RXPKTBUF_CTRL             REG_PKTBUF_DBG_CTRL_8723F /* hal_com.c */
#define REG_WKFMCAM_NUM             REG_WKFMCAM_CMD_8723F /* hal_com.c */
#define REG_RSV_CTRL                 REG_REG_ACCESS_CTRL_8723F /* hal_com.c */
#define REG_CAMCMD                    REG_KEYCAMCMD_8723F /* hal_com.c */
#define REG_CAMWRITE                REG_KEYCAM_WD_8723F /* hal_com.c */
 
#define BIT_AUTO_SYNC_BY_TBTT         BIT_EN_TSFAUTO_SYNC_8723F /* hal_com.c */
#define BIT_DIS_ATIM_ROOT_8723F      23 /* REG_HIQ_NO_LMT_EN_V2[23], disable ATIM ROOT */
#define BIT_SECCAM_POLLING_8723F    BIT_KEYCAM_POLLING_8723F /* rtl8723f_ops.c */
#define BIT_GET_NETYPE2                BIT_GET_P2_NETSTATE_8723F /* hal_halmac.c */
#define BIT_GET_NETYPE3                BIT_GET_P3_NETSTATE_8723F /* hal_halmac.c */
#define BIT_GET_NETYPE4                BIT_GET_P4_NETSTATE_8723F /* hal_halmac.c */
 
#ifdef CONFIG_WOW_PATTERN_IN_TXFIFO
/* todo: 8723F , need to check in the future */
#define REG_TXBUF_WKCAM_OFFSET 0x1B4 //BIT_TXBUF_WKCAM_OFFSET [24:12]
#define REG_PKT_BUFF_ACCESS_CTRL     0x106 /* hal_com.c */
#endif
 
/* RXERR_RPT, for rtw_mp.c */
#define RXERR_TYPE_OFDM_PPDU        0
#define RXERR_TYPE_OFDM_FALSE_ALARM    2
#define RXERR_TYPE_OFDM_MPDU_OK        0
#define RXERR_TYPE_OFDM_MPDU_FAIL    1
#define RXERR_TYPE_CCK_PPDU        3
#define RXERR_TYPE_CCK_FALSE_ALARM    5
#define RXERR_TYPE_CCK_MPDU_OK        3
#define RXERR_TYPE_CCK_MPDU_FAIL    4
#define RXERR_TYPE_HT_PPDU        8
#define RXERR_TYPE_HT_FALSE_ALARM    9
#define RXERR_TYPE_HT_MPDU_TOTAL    6
#define RXERR_TYPE_HT_MPDU_OK        6
#define RXERR_TYPE_HT_MPDU_FAIL        7
#define RXERR_TYPE_RX_FULL_DROP        10
 
#define RXERR_COUNTER_MASK        BIT_MASK_RPT_COUNTER_8723F
#define RXERR_RPT_RST            BIT_RXERR_RPT_RST_8723F
#define _RXERR_RPT_SEL(type)        (BIT_RXERR_RPT_SEL_V1_3_0_8723F(type) \
                   | ((type & 0x10) ? BIT_RXERR_RPT_SEL_V1_4_8723F : 0))
 
/*
 * BB Register definition
 */
#define rPMAC_Reset            0x100    /* hal_mp.c */
 
#define    rFPGA0_RFMOD            0x800
#define rFPGA0_TxInfo            0x804
#define rOFDMCCKEN_Jaguar        0x808    /* hal_mp.c */
#define rFPGA0_TxGainStage        0x80C    /* phydm only */
#define rFPGA0_XA_HSSIParameter1    0x820    /* hal_mp.c */
#define rFPGA0_XA_HSSIParameter2    0x824    /* hal_mp.c */
#define rFPGA0_XB_HSSIParameter1    0x828    /* hal_mp.c */
#define rFPGA0_XB_HSSIParameter2    0x82C    /* hal_mp.c */
#define rTxAGC_B_Rate18_06        0x830
#define rTxAGC_B_Rate54_24        0x834
#define rTxAGC_B_CCK1_55_Mcs32        0x838
#define rCCAonSec_Jaguar        0x838    /* hal_mp.c */
#define rTxAGC_B_Mcs03_Mcs00        0x83C
#define rTxAGC_B_Mcs07_Mcs04        0x848
#define rTxAGC_B_Mcs11_Mcs08        0x84C
#define rFPGA0_XA_RFInterfaceOE        0x860
#define rFPGA0_XB_RFInterfaceOE        0x864
#define rTxAGC_B_Mcs15_Mcs12        0x868
#define rTxAGC_B_CCK11_A_CCK2_11    0x86C
#define rFPGA0_XAB_RFInterfaceSW    0x870
#define rFPGA0_XAB_RFParameter        0x878
#define rFPGA0_AnalogParameter4        0x88C    /* hal_mp.c & phydm */
#define rFPGA0_XB_LSSIReadBack        0x8A4    /* phydm */
#define rHSSIRead_Jaguar        0x8B0    /* RF read addr (rtl8723f_phy.c) */
 
#define rC_TxScale_Jaguar2        0x181C  /* Pah_C TX scaling factor (hal_mp.c) */
#define rC_IGI_Jaguar2            0x1850    /* Initial Gain for path-C (hal_mp.c) */
 
#define rFPGA1_TxInfo            0x90C    /* hal_mp.c */
#define rSingleTone_ContTx_Jaguar    0x914    /* hal_mp.c */
/* TX BeamForming */
#define REG_BB_TX_PATH_SEL_1_8723F    0x93C    /* rtl8723f_phy.c */
#define REG_BB_TX_PATH_SEL_2_8723F    0x940    /* rtl8723f_phy.c */
 
/* TX BeamForming */
#define REG_BB_TXBF_ANT_SET_BF1_8723F    0x19AC    /* rtl8723f_phy.c */
#define REG_BB_TXBF_ANT_SET_BF0_8723F    0x19B4    /* rtl8723f_phy.c */
 
#define rCCK0_System            0xA00
#define rCCK0_AFESetting        0xA04
 
#define rCCK0_DSPParameter2        0xA1C
#define rCCK0_TxFilter1            0xA20
#define rCCK0_TxFilter2            0xA24
#define rCCK0_DebugPort            0xA28
#define rCCK0_FalseAlarmReport        0xA2C
 
#define rD_TxScale_Jaguar2        0x1A1C  /* Path_D TX scaling factor (hal_mp.c) */
#define rD_IGI_Jaguar2            0x1A50    /* Initial Gain for path-D (hal_mp.c) */
 
#define rOFDM0_TRxPathEnable        0xC04
#define rOFDM0_TRMuxPar            0xC08
#define rA_TxScale_Jaguar        0xC1C    /* Pah_A TX scaling factor (hal_mp.c) */
#define rOFDM0_RxDetector1        0xC30    /* rtw_mp.c */
#define rOFDM0_ECCAThreshold        0xC4C    /* phydm only */
#define rOFDM0_XAAGCCore1        0xC50    /* phydm only */
#define rA_IGI_Jaguar            0xC50    /* Initial Gain for path-A (hal_mp.c) */
#define rOFDM0_XBAGCCore1        0xC58    /* phydm only */
#define rOFDM0_XATxIQImbalance        0xC80    /* phydm only */
#define rA_LSSIWrite_Jaguar        0xC90    /* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
 
#define rOFDM1_LSTF            0xD00
#define rOFDM1_TRxPathEnable        0xD04    /* hal_mp.c */
#define rA_PIRead_Jaguar        0xD04    /* RF readback with PI (rtl8723f_phy.c) */
#define rA_SIRead_Jaguar        0xD08    /* RF readback with SI (rtl8723f_phy.c) */
#define rB_PIRead_Jaguar        0xD44    /* RF readback with PI (rtl8723f_phy.c) */
#define rB_SIRead_Jaguar        0xD48    /* RF readback with SI (rtl8723f_phy.c) */
 
#define rTxAGC_A_Rate18_06        0xE00
#define rTxAGC_A_Rate54_24        0xE04
#define rTxAGC_A_CCK1_Mcs32        0xE08
#define rTxAGC_A_Mcs03_Mcs00        0xE10
#define rTxAGC_A_Mcs07_Mcs04        0xE14
#define rTxAGC_A_Mcs11_Mcs08        0xE18
#define rTxAGC_A_Mcs15_Mcs12        0xE1C
#define rB_TxScale_Jaguar        0xE1C    /* Path_B TX scaling factor (hal_mp.c) */
#define rB_IGI_Jaguar            0xE50    /* Initial Gain for path-B (hal_mp.c) */
#define rB_LSSIWrite_Jaguar        0xE90    /* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
/* RFE */
#define rA_RFE_Pinmux_Jaguar        0xCB0    /* hal_mp.c */
#define rB_RFE_Pinmux_Jaguar        0xEB0    /* Path_B RFE control pinmux */
#define rA_RFE_Inv_Jaguar        0xCB4    /* Path_A RFE cotrol */  
#define rB_RFE_Inv_Jaguar        0xEB4    /* Path_B RFE control */
#define rA_RFE_Jaguar            0xCB8     /* Path_A RFE cotrol */  
#define rB_RFE_Jaguar            0xEB8    /* Path_B RFE control */
#define rA_RFE_Inverse_Jaguar        0xCBC    /* Path_A RFE control inverse */
#define rB_RFE_Inverse_Jaguar        0xEBC    /* Path_B RFE control inverse */
#define r_ANTSEL_SW_Jaguar        0x900    /* ANTSEL SW Control */
#define bMask_RFEInv_Jaguar        0x3FF00000
#define bMask_AntselPathFollow_Jaguar    0x00030000
 
#define rC_RFE_Pinmux_Jaguar        0x18B4    /* Path_C RFE cotrol pinmux*/
#define rD_RFE_Pinmux_Jaguar        0x1AB4    /* Path_D RFE cotrol pinmux*/
#define rA_RFE_Sel_Jaguar2        0x1990
 
/* Page1(0x100) */
#define bBBResetB            0x100
 
/* Page8(0x800) */
#define bCCKEn                0x1000000
#define bOFDMEn                0x2000000
/* Reg 0x80C rFPGA0_TxGainStage */
#define bXBTxAGC            0xF00
#define bXCTxAGC            0xF000
#define bXDTxAGC            0xF0000
 
/* PageA(0xA00) */
#define bCCKBBMode            0x3
 
#define bCCKScramble            0x8
#define bCCKTxRate            0x3000
 
/* General */
#define bMaskByte0        0xFF        /* mp, rtw_odm.c & phydm */
#define bMaskByte1        0xFF00        /* hal_mp.c & phydm */
#define bMaskByte2        0xFF0000    /* hal_mp.c & phydm */
#define bMaskByte3        0xFF000000    /* hal_mp.c & phydm */
#define bMaskHWord        0xFFFF0000    /* hal_com.c, rtw_mp.c */
#define bMaskLWord        0x0000FFFF    /* mp, hal_com.c & phydm */
#define bMaskDWord        0xFFFFFFFF    /* mp, hal, rtw_odm.c & phydm */
 
#define bEnable            0x1        /* hal_mp.c, rtw_mp.c */
#define bDisable        0x0        /* rtw_mp.c */
 
#define MAX_STALL_TIME        50        /* unit: us, hal_com_phycfg.c */
 
#define Rx_Smooth_Factor    20        /* phydm only */
 
/*
 * RF Register definition
 */
#define RF_AC            0x00
#define RF_AC_Jaguar        0x00    /* hal_mp.c */
#define RF_CHNLBW        0x18    /* rtl8723f_phy.c */
#define RF_ModeTableAddr    0x30    /* rtl8723f_phy.c */
#define RF_ModeTableData0    0x31    /* rtl8723f_phy.c */
#define RF_ModeTableData1    0x32    /* rtl8723f_phy.c */
#define RF_0x52            0x52
#define RF_WeLut_Jaguar        0xEF    /* rtl8723f_phy.c */
 
/* rtw_lps_state_chk() @hal_com.c */
#define BIT_PWRBIT_OW_EN    BIT_WMAC_TCR_PWRMGT_CTL_8723F
 
 
/* 
* Structure 
*/
struct qinfo_8723f {
   u32 head:8;
   u32 pkt_num:7;
   u32 tail:8;
   u32 ac:2;
   u32 macid:7;
};
 
struct bcn_qinfo_8723f {
   u16 head:8;
   u16 pkt_num:8;
};
 
 
/* 
* General Functions 
*/
void rtl8723f_init_hal_spec(PADAPTER);                /* hal/hal_com.c */
 
#ifdef CONFIG_MP_INCLUDED
/* MP Functions */
#include <rtw_mp.h>        /* struct mp_priv */
void rtl8723f_prepare_mp_txdesc(PADAPTER, struct mp_priv *);    /* rtw_mp.c */
void rtl8723f_mp_config_rfpath(PADAPTER);            /* hal_mp.c */
#endif
void hw_var_set_dl_rsvd_page(PADAPTER adapter, u8 mstatus);
 
#ifdef CONFIG_USB_HCI
#include <rtl8723fu_hal.h>
#elif defined(CONFIG_SDIO_HCI)
#include <rtl8723fs_hal.h>
#endif
 
#endif /* _RTL8723F_HAL_H_ */