1 /* SPDX-License-Identifier: GPL-2.0 */
2 /******************************************************************************
3  *
4  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5  *
6  ******************************************************************************/
7 #ifndef __HAL_COM_PHYCFG_H__
8 #define __HAL_COM_PHYCFG_H__
9 
10 #define		PathA		0x0	/*  Useless */
11 #define		PathB		0x1
12 #define		PathC		0x2
13 #define		PathD		0x3
14 
15 enum RATE_SECTION {
16 	CCK = 0,
17 	OFDM,
18 	HT_MCS0_MCS7,
19 	HT_MCS8_MCS15,
20 	HT_MCS16_MCS23,
21 	HT_MCS24_MCS31,
22 	VHT_1SSMCS0_1SSMCS9,
23 	VHT_2SSMCS0_2SSMCS9,
24 	VHT_3SSMCS0_3SSMCS9,
25 	VHT_4SSMCS0_4SSMCS9,
26 };
27 
28 enum RF_TX_NUM {
29 	RF_1TX = 0,
30 	RF_2TX,
31 	RF_3TX,
32 	RF_4TX,
33 	RF_MAX_TX_NUM,
34 	RF_TX_NUM_NONIMPLEMENT,
35 };
36 
37 #define MAX_POWER_INDEX			0x3F
38 
39 enum _REGULATION_TXPWR_LMT {
40 	TXPWR_LMT_FCC = 0,
41 	TXPWR_LMT_MKK,
42 	TXPWR_LMT_ETSI,
43 	TXPWR_LMT_WW,
44 	TXPWR_LMT_MAX_REGULATION_NUM,
45 };
46 
47 /*------------------------------Define structure----------------------------*/
48 struct bb_register_def {
49 	u32 rfintfs;			/*  set software control: */
50 					/* 	0x870~0x877[8 bytes] */
51 
52 	u32 rfintfo;			/*  output data: */
53 					/* 	0x860~0x86f [16 bytes] */
54 
55 	u32 rfintfe;			/*  output enable: */
56 					/* 	0x860~0x86f [16 bytes] */
57 
58 	u32 rf3wireOffset;		/*  LSSI data: */
59 					/* 	0x840~0x84f [16 bytes] */
60 
61 	u32 rfHSSIPara2;		/*  wire parameter control2 : */
62 					/* 	0x824~0x827, 0x82c~0x82f,
63 					 *	0x834~0x837, 0x83c~0x83f
64 					 */
65 	u32 rfLSSIReadBack;		/* LSSI RF readback data SI mode */
66 					/* 	0x8a0~0x8af [16 bytes] */
67 
68 	u32 rfLSSIReadBackPi;		/* LSSI RF readback data PI mode
69 					 *	0x8b8-8bc for Path A and B */
70 
71 };
72 
73 u8
74 PHY_GetTxPowerByRateBase(
75 struct adapter *	Adapter,
76 u8 		Band,
77 u8 		RfPath,
78 u8 		TxNum,
79 enum RATE_SECTION	RateSection
80 	);
81 
82 u8
83 PHY_GetRateSectionIndexOfTxPowerByRate(
84 struct adapter *padapter,
85 u32 		RegAddr,
86 u32 		BitMask
87 	);
88 
89 void
90 PHY_GetRateValuesOfTxPowerByRate(
91 struct adapter *padapter,
92 u32 		RegAddr,
93 u32 		BitMask,
94 u32 		Value,
95 	u8*		RateIndex,
96 	s8*		PwrByRateVal,
97 	u8*		RateNum
98 	);
99 
100 u8
101 PHY_GetRateIndexOfTxPowerByRate(
102 u8 Rate
103 	);
104 
105 void
106 PHY_SetTxPowerIndexByRateSection(
107 struct adapter *	padapter,
108 u8 		RFPath,
109 u8 		Channel,
110 u8 		RateSection
111 	);
112 
113 s8
114 PHY_GetTxPowerByRate(
115 struct adapter *padapter,
116 u8 	Band,
117 u8 	RFPath,
118 u8 	TxNum,
119 u8 	RateIndex
120 	);
121 
122 void
123 PHY_SetTxPowerByRate(
124 struct adapter *padapter,
125 u8 	Band,
126 u8 	RFPath,
127 u8 	TxNum,
128 u8 	Rate,
129 s8			Value
130 	);
131 
132 void
133 PHY_SetTxPowerLevelByPath(
134 struct adapter *Adapter,
135 u8 	channel,
136 u8 	path
137 	);
138 
139 void
140 PHY_SetTxPowerIndexByRateArray(
141 struct adapter *	padapter,
142 u8 		RFPath,
143 enum CHANNEL_WIDTH	BandWidth,
144 u8 		Channel,
145 u8*			Rates,
146 u8 		RateArraySize
147 	);
148 
149 void
150 PHY_InitTxPowerByRate(
151 struct adapter *padapter
152 	);
153 
154 void
155 PHY_StoreTxPowerByRate(
156 struct adapter *padapter,
157 u32 		Band,
158 u32 		RfPath,
159 u32 		TxNum,
160 u32 		RegAddr,
161 u32 		BitMask,
162 u32 		Data
163 	);
164 
165 void
166 PHY_TxPowerByRateConfiguration(
167 	struct adapter *		padapter
168 	);
169 
170 u8
171 PHY_GetTxPowerIndexBase(
172 struct adapter *	padapter,
173 u8 		RFPath,
174 u8 		Rate,
175 enum CHANNEL_WIDTH	BandWidth,
176 u8 		Channel,
177 	bool		*bIn24G
178 	);
179 
180 s8 phy_get_tx_pwr_lmt (struct adapter *adapter, u32 RegPwrTblSel,
181 			enum BAND_TYPE Band, enum CHANNEL_WIDTH Bandwidth,
182 u8 		RfPath,
183 u8 		DataRate,
184 u8 		Channel
185 	);
186 
187 void
188 PHY_SetTxPowerLimit(
189 struct adapter *		Adapter,
190 u8 			*Regulation,
191 u8 			*Band,
192 u8 			*Bandwidth,
193 u8 			*RateSection,
194 u8 			*RfPath,
195 u8 			*Channel,
196 u8 			*PowerLimit
197 	);
198 
199 void
200 PHY_ConvertTxPowerLimitToPowerIndex(
201 struct adapter *		Adapter
202 	);
203 
204 void
205 PHY_InitTxPowerLimit(
206 struct adapter *		Adapter
207 	);
208 
209 s8
210 PHY_GetTxPowerTrackingOffset(
211 	struct adapter *padapter,
212 	u8 	Rate,
213 	u8 	RFPath
214 	);
215 
216 u8
217 PHY_GetTxPowerIndex(
218 struct adapter *		padapter,
219 u8 			RFPath,
220 u8 			Rate,
221 enum CHANNEL_WIDTH		BandWidth,
222 u8 			Channel
223 	);
224 
225 void
226 PHY_SetTxPowerIndex(
227 struct adapter *	padapter,
228 u32 			PowerIndex,
229 u8 		RFPath,
230 u8 		Rate
231 	);
232 
233 void
234 Hal_ChannelPlanToRegulation(
235 struct adapter *	Adapter,
236 u16 			ChannelPlan
237 	);
238 
239 #define MAX_PARA_FILE_BUF_LEN	25600
240 
241 #define LOAD_MAC_PARA_FILE				BIT0
242 #define LOAD_BB_PARA_FILE					BIT1
243 #define LOAD_BB_PG_PARA_FILE				BIT2
244 #define LOAD_BB_MP_PARA_FILE				BIT3
245 #define LOAD_RF_PARA_FILE					BIT4
246 #define LOAD_RF_TXPWR_TRACK_PARA_FILE	BIT5
247 #define LOAD_RF_TXPWR_LMT_PARA_FILE		BIT6
248 
249 int phy_ConfigMACWithParaFile(struct adapter *Adapter, char*pFileName);
250 
251 int phy_ConfigBBWithParaFile(struct adapter *Adapter, char*pFileName, u32 ConfigType);
252 
253 int phy_ConfigBBWithPgParaFile(struct adapter *Adapter, char*pFileName);
254 
255 int phy_ConfigBBWithMpParaFile(struct adapter *Adapter, char*pFileName);
256 
257 int PHY_ConfigRFWithParaFile(struct adapter *Adapter, char*pFileName, u8 eRFPath);
258 
259 int PHY_ConfigRFWithTxPwrTrackParaFile(struct adapter *Adapter, char*pFileName);
260 
261 int PHY_ConfigRFWithPowerLimitTableParaFile(struct adapter *Adapter, char*pFileName);
262 
263 void phy_free_filebuf(struct adapter *padapter);
264 
265 #endif /* __HAL_COMMON_H__ */
266