1 // SPDX-License-Identifier: GPL-2.0
2 /******************************************************************************
4 * Copyright(c) 2016 Realtek Corporation.
7 * wlanfae <wlanfae@realtek.com>
8 * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
11 * Larry Finger <Larry.Finger@lwfinger.net>
13 *****************************************************************************/
14 #include "halmac_8822b_cfg.h"
15 #include "halmac_func_8822b.h"
18 static struct halmac_rqpn_ HALMAC_RQPN_SDIO_8822B[] = {
19 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
20 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
21 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
22 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
23 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
24 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
25 HALMAC_MAP2_NQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
26 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
27 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
28 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
29 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
30 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
31 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
35 static struct halmac_rqpn_ HALMAC_RQPN_PCIE_8822B[] = {
36 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
37 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
38 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
39 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
40 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
41 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
42 HALMAC_MAP2_NQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
43 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
44 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
45 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
46 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
47 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
48 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
51 /*USB 2 Bulkout RQPN Mapping*/
52 static struct halmac_rqpn_ HALMAC_RQPN_2BULKOUT_8822B[] = {
53 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
54 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
55 HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
56 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
57 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
58 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
59 HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
60 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
61 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
62 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
63 HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
64 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
65 HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
68 /*USB 3 Bulkout RQPN Mapping*/
69 static struct halmac_rqpn_ HALMAC_RQPN_3BULKOUT_8822B[] = {
70 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
71 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
72 HALMAC_MAP2_LQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
73 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
74 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
75 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
76 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
77 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_LQ,
78 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
79 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
80 HALMAC_MAP2_LQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
81 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
82 HALMAC_MAP2_LQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
85 /*USB 4 Bulkout RQPN Mapping*/
86 static struct halmac_rqpn_ HALMAC_RQPN_4BULKOUT_8822B[] = {
87 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
88 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
89 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
90 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
91 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
92 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
93 HALMAC_MAP2_NQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
94 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
95 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
96 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
97 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
98 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
99 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
103 static struct halmac_pg_num_ HALMAC_PG_NUM_SDIO_8822B[] = {
104 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
105 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
106 {HALMAC_TRX_MODE_TRXSHARE, 32, 32, 32, 32, 1},
107 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
108 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
109 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 640},
110 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 640},
114 static struct halmac_pg_num_ HALMAC_PG_NUM_PCIE_8822B[] = {
115 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
116 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
117 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 64, 1},
118 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
119 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
120 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 640},
121 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 640},
124 /*USB 2 Bulkout Page Number*/
125 static struct halmac_pg_num_ HALMAC_PG_NUM_2BULKOUT_8822B[] = {
126 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
127 {HALMAC_TRX_MODE_NORMAL, 64, 64, 0, 0, 1},
128 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 0, 0, 1},
129 {HALMAC_TRX_MODE_WMM, 64, 64, 0, 0, 1},
130 {HALMAC_TRX_MODE_P2P, 64, 64, 0, 0, 1},
131 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 0, 0, 1024},
132 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 0, 0, 1024},
135 /*USB 3 Bulkout Page Number*/
136 static struct halmac_pg_num_ HALMAC_PG_NUM_3BULKOUT_8822B[] = {
137 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
138 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 0, 1},
139 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 0, 1},
140 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 0, 1},
141 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 0, 1},
142 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 0, 1024},
143 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 0, 1024},
146 /*USB 4 Bulkout Page Number*/
147 static struct halmac_pg_num_ HALMAC_PG_NUM_4BULKOUT_8822B[] = {
148 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
149 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
150 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 64, 1},
151 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
152 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
153 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 640},
154 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 640},
157 enum halmac_ret_status
158 halmac_txdma_queue_mapping_8822b(struct halmac_adapter *halmac_adapter,
159 enum halmac_trx_mode halmac_trx_mode)
162 void *driver_adapter = NULL;
163 struct halmac_rqpn_ *curr_rqpn_sel = NULL;
164 enum halmac_ret_status status;
165 struct halmac_api *halmac_api;
167 driver_adapter = halmac_adapter->driver_adapter;
168 halmac_api = (struct halmac_api *)halmac_adapter->halmac_api;
170 if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_SDIO) {
171 curr_rqpn_sel = HALMAC_RQPN_SDIO_8822B;
172 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_PCIE) {
173 curr_rqpn_sel = HALMAC_RQPN_PCIE_8822B;
174 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_USB) {
175 if (halmac_adapter->halmac_bulkout_num == 2) {
176 curr_rqpn_sel = HALMAC_RQPN_2BULKOUT_8822B;
177 } else if (halmac_adapter->halmac_bulkout_num == 3) {
178 curr_rqpn_sel = HALMAC_RQPN_3BULKOUT_8822B;
179 } else if (halmac_adapter->halmac_bulkout_num == 4) {
180 curr_rqpn_sel = HALMAC_RQPN_4BULKOUT_8822B;
182 pr_err("[ERR]interface not support\n");
183 return HALMAC_RET_NOT_SUPPORT;
186 return HALMAC_RET_NOT_SUPPORT;
189 status = halmac_rqpn_parser_88xx(halmac_adapter, halmac_trx_mode,
191 if (status != HALMAC_RET_SUCCESS)
195 value16 |= BIT_TXDMA_HIQ_MAP(
196 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_HI]);
197 value16 |= BIT_TXDMA_MGQ_MAP(
198 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_MG]);
199 value16 |= BIT_TXDMA_BKQ_MAP(
200 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_BK]);
201 value16 |= BIT_TXDMA_BEQ_MAP(
202 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_BE]);
203 value16 |= BIT_TXDMA_VIQ_MAP(
204 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_VI]);
205 value16 |= BIT_TXDMA_VOQ_MAP(
206 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_VO]);
207 HALMAC_REG_WRITE_16(halmac_adapter, REG_TXDMA_PQ_MAP, value16);
209 return HALMAC_RET_SUCCESS;
212 enum halmac_ret_status
213 halmac_priority_queue_config_8822b(struct halmac_adapter *halmac_adapter,
214 enum halmac_trx_mode halmac_trx_mode)
216 u8 transfer_mode = 0;
219 enum halmac_ret_status status;
220 struct halmac_pg_num_ *curr_pg_num = NULL;
221 void *driver_adapter = NULL;
222 struct halmac_api *halmac_api;
224 driver_adapter = halmac_adapter->driver_adapter;
225 halmac_api = (struct halmac_api *)halmac_adapter->halmac_api;
227 if (halmac_adapter->txff_allocation.la_mode == HALMAC_LA_MODE_DISABLE) {
228 if (halmac_adapter->txff_allocation.rx_fifo_expanding_mode ==
229 HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE) {
230 halmac_adapter->txff_allocation.tx_fifo_pg_num =
231 HALMAC_TX_FIFO_SIZE_8822B >>
232 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
233 } else if (halmac_adapter->txff_allocation
234 .rx_fifo_expanding_mode ==
235 HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK) {
236 halmac_adapter->txff_allocation.tx_fifo_pg_num =
237 HALMAC_TX_FIFO_SIZE_EX_1_BLK_8822B >>
238 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
239 halmac_adapter->hw_config_info.tx_fifo_size =
240 HALMAC_TX_FIFO_SIZE_EX_1_BLK_8822B;
241 if (HALMAC_RX_FIFO_SIZE_EX_1_BLK_8822B <=
242 HALMAC_RX_FIFO_SIZE_EX_1_BLK_MAX_8822B)
243 halmac_adapter->hw_config_info.rx_fifo_size =
244 HALMAC_RX_FIFO_SIZE_EX_1_BLK_8822B;
246 halmac_adapter->hw_config_info.rx_fifo_size =
247 HALMAC_RX_FIFO_SIZE_EX_1_BLK_MAX_8822B;
249 halmac_adapter->txff_allocation.tx_fifo_pg_num =
250 HALMAC_TX_FIFO_SIZE_8822B >>
251 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
252 pr_err("[ERR]rx_fifo_expanding_mode = %d not support\n",
253 halmac_adapter->txff_allocation
254 .rx_fifo_expanding_mode);
257 halmac_adapter->txff_allocation.tx_fifo_pg_num =
258 HALMAC_TX_FIFO_SIZE_LA_8822B >>
259 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
261 halmac_adapter->txff_allocation.rsvd_pg_num =
262 (halmac_adapter->txff_allocation.rsvd_drv_pg_num +
263 HALMAC_RSVD_H2C_EXTRAINFO_PGNUM_8822B +
264 HALMAC_RSVD_H2C_QUEUE_PGNUM_8822B +
265 HALMAC_RSVD_CPU_INSTRUCTION_PGNUM_8822B +
266 HALMAC_RSVD_FW_TXBUFF_PGNUM_8822B);
267 if (halmac_adapter->txff_allocation.rsvd_pg_num >
268 halmac_adapter->txff_allocation.tx_fifo_pg_num)
269 return HALMAC_RET_CFG_TXFIFO_PAGE_FAIL;
271 halmac_adapter->txff_allocation.ac_q_pg_num =
272 halmac_adapter->txff_allocation.tx_fifo_pg_num -
273 halmac_adapter->txff_allocation.rsvd_pg_num;
274 halmac_adapter->txff_allocation.rsvd_pg_bndy =
275 halmac_adapter->txff_allocation.tx_fifo_pg_num -
276 halmac_adapter->txff_allocation.rsvd_pg_num;
277 halmac_adapter->txff_allocation.rsvd_fw_txbuff_pg_bndy =
278 halmac_adapter->txff_allocation.tx_fifo_pg_num -
279 HALMAC_RSVD_FW_TXBUFF_PGNUM_8822B;
280 halmac_adapter->txff_allocation.rsvd_cpu_instr_pg_bndy =
281 halmac_adapter->txff_allocation.rsvd_fw_txbuff_pg_bndy -
282 HALMAC_RSVD_CPU_INSTRUCTION_PGNUM_8822B;
283 halmac_adapter->txff_allocation.rsvd_h2c_queue_pg_bndy =
284 halmac_adapter->txff_allocation.rsvd_cpu_instr_pg_bndy -
285 HALMAC_RSVD_H2C_QUEUE_PGNUM_8822B;
286 halmac_adapter->txff_allocation.rsvd_h2c_extra_info_pg_bndy =
287 halmac_adapter->txff_allocation.rsvd_h2c_queue_pg_bndy -
288 HALMAC_RSVD_H2C_EXTRAINFO_PGNUM_8822B;
289 halmac_adapter->txff_allocation.rsvd_drv_pg_bndy =
290 halmac_adapter->txff_allocation.rsvd_h2c_extra_info_pg_bndy -
291 halmac_adapter->txff_allocation.rsvd_drv_pg_num;
293 if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_SDIO) {
294 curr_pg_num = HALMAC_PG_NUM_SDIO_8822B;
295 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_PCIE) {
296 curr_pg_num = HALMAC_PG_NUM_PCIE_8822B;
297 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_USB) {
298 if (halmac_adapter->halmac_bulkout_num == 2) {
299 curr_pg_num = HALMAC_PG_NUM_2BULKOUT_8822B;
300 } else if (halmac_adapter->halmac_bulkout_num == 3) {
301 curr_pg_num = HALMAC_PG_NUM_3BULKOUT_8822B;
302 } else if (halmac_adapter->halmac_bulkout_num == 4) {
303 curr_pg_num = HALMAC_PG_NUM_4BULKOUT_8822B;
305 pr_err("[ERR]interface not support\n");
306 return HALMAC_RET_NOT_SUPPORT;
309 return HALMAC_RET_NOT_SUPPORT;
312 status = halmac_pg_num_parser_88xx(halmac_adapter, halmac_trx_mode,
314 if (status != HALMAC_RET_SUCCESS)
317 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_1,
318 halmac_adapter->txff_allocation.high_queue_pg_num);
319 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_2,
320 halmac_adapter->txff_allocation.low_queue_pg_num);
322 halmac_adapter, REG_FIFOPAGE_INFO_3,
323 halmac_adapter->txff_allocation.normal_queue_pg_num);
324 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_4,
325 halmac_adapter->txff_allocation.extra_queue_pg_num);
326 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_5,
327 halmac_adapter->txff_allocation.pub_queue_pg_num);
329 halmac_adapter->sdio_free_space.high_queue_number =
330 halmac_adapter->txff_allocation.high_queue_pg_num;
331 halmac_adapter->sdio_free_space.normal_queue_number =
332 halmac_adapter->txff_allocation.normal_queue_pg_num;
333 halmac_adapter->sdio_free_space.low_queue_number =
334 halmac_adapter->txff_allocation.low_queue_pg_num;
335 halmac_adapter->sdio_free_space.public_queue_number =
336 halmac_adapter->txff_allocation.pub_queue_pg_num;
337 halmac_adapter->sdio_free_space.extra_queue_number =
338 halmac_adapter->txff_allocation.extra_queue_pg_num;
341 halmac_adapter, REG_RQPN_CTRL_2,
342 HALMAC_REG_READ_32(halmac_adapter, REG_RQPN_CTRL_2) | BIT(31));
344 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_CTRL_2,
345 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
346 BIT_MASK_BCN_HEAD_1_V1));
347 HALMAC_REG_WRITE_16(halmac_adapter, REG_BCNQ_BDNY_V1,
348 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
349 BIT_MASK_BCNQ_PGBNDY_V1));
350 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_CTRL_2 + 2,
351 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
352 BIT_MASK_BCN_HEAD_1_V1));
353 HALMAC_REG_WRITE_16(halmac_adapter, REG_BCNQ1_BDNY_V1,
354 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
355 BIT_MASK_BCNQ_PGBNDY_V1));
357 HALMAC_REG_WRITE_32(halmac_adapter, REG_RXFF_BNDY,
358 halmac_adapter->hw_config_info.rx_fifo_size -
359 HALMAC_C2H_PKT_BUF_8822B - 1);
361 if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_USB) {
363 HALMAC_REG_READ_8(halmac_adapter, REG_AUTO_LLT_V1) &
364 ~(BIT_MASK_BLK_DESC_NUM << BIT_SHIFT_BLK_DESC_NUM));
365 value8 = (u8)(value8 | (HALMAC_BLK_DESC_NUM_8822B
366 << BIT_SHIFT_BLK_DESC_NUM));
367 HALMAC_REG_WRITE_8(halmac_adapter, REG_AUTO_LLT_V1, value8);
369 HALMAC_REG_WRITE_8(halmac_adapter, REG_AUTO_LLT_V1 + 3,
370 HALMAC_BLK_DESC_NUM_8822B);
371 HALMAC_REG_WRITE_8(halmac_adapter, REG_TXDMA_OFFSET_CHK + 1,
372 HALMAC_REG_READ_8(halmac_adapter,
373 REG_TXDMA_OFFSET_CHK + 1) |
378 halmac_adapter, REG_AUTO_LLT_V1,
379 (u8)(HALMAC_REG_READ_8(halmac_adapter, REG_AUTO_LLT_V1) |
380 BIT_AUTO_INIT_LLT_V1));
382 while (HALMAC_REG_READ_8(halmac_adapter, REG_AUTO_LLT_V1) &
383 BIT_AUTO_INIT_LLT_V1) {
386 return HALMAC_RET_INIT_LLT_FAIL;
389 if (halmac_trx_mode == HALMAC_TRX_MODE_DELAY_LOOPBACK) {
390 transfer_mode = HALMAC_TRNSFER_LOOPBACK_DELAY;
392 halmac_adapter, REG_WMAC_LBK_BUF_HD_V1,
393 (u16)halmac_adapter->txff_allocation.rsvd_pg_bndy);
394 } else if (halmac_trx_mode == HALMAC_TRX_MODE_LOOPBACK) {
395 transfer_mode = HALMAC_TRNSFER_LOOPBACK_DIRECT;
397 transfer_mode = HALMAC_TRNSFER_NORMAL;
400 HALMAC_REG_WRITE_8(halmac_adapter, REG_CR + 3, (u8)transfer_mode);
402 return HALMAC_RET_SUCCESS;