1 // SPDX-License-Identifier: GPL-2.0
2 /******************************************************************************
3  *
4  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5  *
6  ******************************************************************************/
7 #include <osdep_service.h>
8 #include <drv_types.h>
9 
10 #include <hal_intf.h>
11 #include <hal_com.h>
12 #include <rtl8188e_hal.h>
13 
14 #define _HAL_INIT_C_
15 
dump_chip_info(struct HAL_VERSION chip_vers)16 void dump_chip_info(struct HAL_VERSION	chip_vers)
17 {
18 	uint cnt = 0;
19 	char buf[128];
20 
21 	cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188E_");
22 	cnt += sprintf((buf + cnt), "%s_", chip_vers.ChipType == NORMAL_CHIP ?
23 		       "Normal_Chip" : "Test_Chip");
24 	cnt += sprintf((buf + cnt), "%s_", chip_vers.VendorType == CHIP_VENDOR_TSMC ?
25 		       "TSMC" : "UMC");
26 	if (chip_vers.CUTVersion == A_CUT_VERSION)
27 		cnt += sprintf((buf + cnt), "A_CUT_");
28 	else if (chip_vers.CUTVersion == B_CUT_VERSION)
29 		cnt += sprintf((buf + cnt), "B_CUT_");
30 	else if (chip_vers.CUTVersion == C_CUT_VERSION)
31 		cnt += sprintf((buf + cnt), "C_CUT_");
32 	else if (chip_vers.CUTVersion == D_CUT_VERSION)
33 		cnt += sprintf((buf + cnt), "D_CUT_");
34 	else if (chip_vers.CUTVersion == E_CUT_VERSION)
35 		cnt += sprintf((buf + cnt), "E_CUT_");
36 	else
37 		cnt += sprintf((buf + cnt), "UNKNOWN_CUT(%d)_",
38 			       chip_vers.CUTVersion);
39 	cnt += sprintf((buf + cnt), "1T1R_");
40 	cnt += sprintf((buf + cnt), "RomVer(0)\n");
41 
42 	pr_info("%s", buf);
43 }
44 
45 #define	CHAN_PLAN_HW	0x80
46 
47 /* return the final channel plan decision */
hal_com_get_channel_plan(u8 hw_channel_plan,u8 sw_channel_plan,u8 def_channel_plan,bool load_fail)48 u8 hal_com_get_channel_plan(u8 hw_channel_plan, u8 sw_channel_plan,
49 			    u8 def_channel_plan, bool load_fail)
50 {
51 	u8 sw_cfg;
52 	u8 chnlplan;
53 
54 	sw_cfg = true;
55 	if (!load_fail) {
56 		if (!rtw_is_channel_plan_valid(sw_channel_plan))
57 			sw_cfg = false;
58 		if (hw_channel_plan & CHAN_PLAN_HW)
59 			sw_cfg = false;
60 	}
61 
62 	if (sw_cfg)
63 		chnlplan = sw_channel_plan;
64 	else
65 		chnlplan = hw_channel_plan & (~CHAN_PLAN_HW);
66 
67 	if (!rtw_is_channel_plan_valid(chnlplan))
68 		chnlplan = def_channel_plan;
69 
70 	return chnlplan;
71 }
72 
MRateToHwRate(u8 rate)73 u8 MRateToHwRate(u8 rate)
74 {
75 	u8 ret = DESC_RATE1M;
76 
77 	switch (rate) {
78 		/*  CCK and OFDM non-HT rates */
79 	case IEEE80211_CCK_RATE_1MB:
80 		ret = DESC_RATE1M;
81 		break;
82 	case IEEE80211_CCK_RATE_2MB:
83 		ret = DESC_RATE2M;
84 		break;
85 	case IEEE80211_CCK_RATE_5MB:
86 		ret = DESC_RATE5_5M;
87 		break;
88 	case IEEE80211_CCK_RATE_11MB:
89 		ret = DESC_RATE11M;
90 		break;
91 	case IEEE80211_OFDM_RATE_6MB:
92 		ret = DESC_RATE6M;
93 		break;
94 	case IEEE80211_OFDM_RATE_9MB:
95 		ret = DESC_RATE9M;
96 		break;
97 	case IEEE80211_OFDM_RATE_12MB:
98 		ret = DESC_RATE12M;
99 		break;
100 	case IEEE80211_OFDM_RATE_18MB:
101 		ret = DESC_RATE18M;
102 		break;
103 	case IEEE80211_OFDM_RATE_24MB:
104 		ret = DESC_RATE24M;
105 		break;
106 	case IEEE80211_OFDM_RATE_36MB:
107 		ret = DESC_RATE36M;
108 		break;
109 	case IEEE80211_OFDM_RATE_48MB:
110 		ret = DESC_RATE48M;
111 		break;
112 	case IEEE80211_OFDM_RATE_54MB:
113 		ret = DESC_RATE54M;
114 		break;
115 	default:
116 		break;
117 	}
118 	return ret;
119 }
120 
hal_set_brate_cfg(u8 * brates,u16 * rate_cfg)121 void hal_set_brate_cfg(u8 *brates, u16 *rate_cfg)
122 {
123 	u8 i, is_brate, brate;
124 
125 	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
126 		is_brate = brates[i] & IEEE80211_BASIC_RATE_MASK;
127 		brate = brates[i] & 0x7f;
128 
129 		if (is_brate) {
130 			switch (brate) {
131 			case IEEE80211_CCK_RATE_1MB:
132 				*rate_cfg |= RATE_1M;
133 				break;
134 			case IEEE80211_CCK_RATE_2MB:
135 				*rate_cfg |= RATE_2M;
136 				break;
137 			case IEEE80211_CCK_RATE_5MB:
138 				*rate_cfg |= RATE_5_5M;
139 				break;
140 			case IEEE80211_CCK_RATE_11MB:
141 				*rate_cfg |= RATE_11M;
142 				break;
143 			case IEEE80211_OFDM_RATE_6MB:
144 				*rate_cfg |= RATE_6M;
145 				break;
146 			case IEEE80211_OFDM_RATE_9MB:
147 				*rate_cfg |= RATE_9M;
148 				break;
149 			case IEEE80211_OFDM_RATE_12MB:
150 				*rate_cfg |= RATE_12M;
151 				break;
152 			case IEEE80211_OFDM_RATE_18MB:
153 				*rate_cfg |= RATE_18M;
154 				break;
155 			case IEEE80211_OFDM_RATE_24MB:
156 				*rate_cfg |= RATE_24M;
157 				break;
158 			case IEEE80211_OFDM_RATE_36MB:
159 				*rate_cfg |= RATE_36M;
160 				break;
161 			case IEEE80211_OFDM_RATE_48MB:
162 				*rate_cfg |= RATE_48M;
163 				break;
164 			case IEEE80211_OFDM_RATE_54MB:
165 				*rate_cfg |= RATE_54M;
166 				break;
167 			}
168 		}
169 	}
170 }
171 
one_out_pipe(struct adapter * adapter)172 static void one_out_pipe(struct adapter *adapter)
173 {
174 	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(adapter);
175 
176 	pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
177 	pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];/* VI */
178 	pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[0];/* BE */
179 	pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[0];/* BK */
180 
181 	pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
182 	pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
183 	pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
184 	pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
185 }
186 
two_out_pipe(struct adapter * adapter,bool wifi_cfg)187 static void two_out_pipe(struct adapter *adapter, bool wifi_cfg)
188 {
189 	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(adapter);
190 
191 	if (wifi_cfg) {
192 		/*
193 		 * WMM
194 		 * BK, BE, VI, VO, BCN, CMD, MGT, HIGH, HCCA
195 		 *  0,  1,  0,  1,   0,   0,   0,    0,    0
196 		 * 0:H, 1:L
197 		 */
198 		pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[1];/* VO */
199 		pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];/* VI */
200 		pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[1];/* BE */
201 		pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[0];/* BK */
202 
203 		pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
204 		pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
205 		pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
206 		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
207 	} else {
208 		/*
209 		 * typical setting
210 		 * BK, BE, VI, VO, BCN, CMD, MGT, HIGH, HCCA
211 		 *  1,  1,  0,  0,   0,   0,   0,    0,    0
212 		 * 0:H, 1:L
213 		 */
214 		pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
215 		pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];/* VI */
216 		pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[1];/* BE */
217 		pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1];/* BK */
218 
219 		pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
220 		pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
221 		pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
222 		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
223 	}
224 }
225 
three_out_pipe(struct adapter * adapter,bool wifi_cfg)226 static void three_out_pipe(struct adapter *adapter, bool wifi_cfg)
227 {
228 	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(adapter);
229 
230 	if (wifi_cfg) {
231 		/*
232 		 * for WMM
233 		 * BK, BE, VI, VO, BCN, CMD, MGT, HIGH, HCCA
234 		 *  1,  2,  1,  0,   0,   0,   0,    0,    0
235 		 * 0:H, 1:N, 2:L
236 		 */
237 		pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
238 		pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1];/* VI */
239 		pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2];/* BE */
240 		pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1];/* BK */
241 
242 		pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
243 		pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
244 		pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
245 		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
246 	} else {
247 		/*
248 		 * typical setting
249 		 * BK, BE, VI, VO, BCN, CMD, MGT, HIGH, HCCA
250 		 *  2,  2,  1,  0,   0,   0,   0,    0,    0
251 		 * 0:H, 1:N, 2:L
252 		 */
253 		pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
254 		pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1];/* VI */
255 		pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2];/* BE */
256 		pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[2];/* BK */
257 
258 		pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
259 		pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
260 		pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
261 		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
262 	}
263 }
264 
hal_mapping_out_pipe(struct adapter * adapter,u8 numoutpipe)265 bool hal_mapping_out_pipe(struct adapter *adapter, u8 numoutpipe)
266 {
267 	struct registry_priv *pregistrypriv = &adapter->registrypriv;
268 	bool wifi_cfg = (pregistrypriv->wifi_spec) ? true : false;
269 	bool result = true;
270 
271 	switch (numoutpipe) {
272 	case 1:
273 		one_out_pipe(adapter);
274 		break;
275 	case 2:
276 		two_out_pipe(adapter, wifi_cfg);
277 		break;
278 	case 3:
279 		three_out_pipe(adapter, wifi_cfg);
280 		break;
281 	default:
282 		result = false;
283 	}
284 	return result;
285 }
286