1 /******************************************************************************
3 * Copyright(c) 2016 Realtek Corporation.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * The full GNU General Public License is included in this distribution in the
15 * file called LICENSE.
17 * Contact Information:
18 * wlanfae <wlanfae@realtek.com>
19 * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
20 * Hsinchu 300, Taiwan.
22 * Larry Finger <Larry.Finger@lwfinger.net>
24 *****************************************************************************/
25 #include "halmac_8822b_cfg.h"
26 #include "halmac_func_8822b.h"
29 static struct halmac_rqpn_ HALMAC_RQPN_SDIO_8822B[] = {
30 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
31 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
32 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
33 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
34 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
35 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
36 HALMAC_MAP2_NQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
37 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
38 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
39 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
40 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
41 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
42 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
46 static struct halmac_rqpn_ HALMAC_RQPN_PCIE_8822B[] = {
47 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
48 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
49 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
50 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
51 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
52 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
53 HALMAC_MAP2_NQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
54 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
55 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
56 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
57 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
58 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
59 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
62 /*USB 2 Bulkout RQPN Mapping*/
63 static struct halmac_rqpn_ HALMAC_RQPN_2BULKOUT_8822B[] = {
64 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
65 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
66 HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
67 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
68 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
69 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
70 HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
71 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
72 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
73 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
74 HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
75 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
76 HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
79 /*USB 3 Bulkout RQPN Mapping*/
80 static struct halmac_rqpn_ HALMAC_RQPN_3BULKOUT_8822B[] = {
81 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
82 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
83 HALMAC_MAP2_LQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
84 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
85 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
86 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
87 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
88 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_LQ,
89 HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
90 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
91 HALMAC_MAP2_LQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
92 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ,
93 HALMAC_MAP2_LQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
96 /*USB 4 Bulkout RQPN Mapping*/
97 static struct halmac_rqpn_ HALMAC_RQPN_4BULKOUT_8822B[] = {
98 /* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
99 {HALMAC_TRX_MODE_NORMAL, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
100 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
101 {HALMAC_TRX_MODE_TRXSHARE, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
102 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
103 {HALMAC_TRX_MODE_WMM, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
104 HALMAC_MAP2_NQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
105 {HALMAC_TRX_MODE_P2P, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ,
106 HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
107 {HALMAC_TRX_MODE_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
108 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
109 {HALMAC_TRX_MODE_DELAY_LOOPBACK, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ,
110 HALMAC_MAP2_LQ, HALMAC_MAP2_LQ, HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
114 static struct halmac_pg_num_ HALMAC_PG_NUM_SDIO_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, 32, 32, 32, 32, 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},
125 static struct halmac_pg_num_ HALMAC_PG_NUM_PCIE_8822B[] = {
126 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
127 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
128 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 64, 1},
129 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
130 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
131 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 640},
132 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 640},
135 /*USB 2 Bulkout Page Number*/
136 static struct halmac_pg_num_ HALMAC_PG_NUM_2BULKOUT_8822B[] = {
137 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
138 {HALMAC_TRX_MODE_NORMAL, 64, 64, 0, 0, 1},
139 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 0, 0, 1},
140 {HALMAC_TRX_MODE_WMM, 64, 64, 0, 0, 1},
141 {HALMAC_TRX_MODE_P2P, 64, 64, 0, 0, 1},
142 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 0, 0, 1024},
143 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 0, 0, 1024},
146 /*USB 3 Bulkout Page Number*/
147 static struct halmac_pg_num_ HALMAC_PG_NUM_3BULKOUT_8822B[] = {
148 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
149 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 0, 1},
150 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 0, 1},
151 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 0, 1},
152 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 0, 1},
153 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 0, 1024},
154 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 0, 1024},
157 /*USB 4 Bulkout Page Number*/
158 static struct halmac_pg_num_ HALMAC_PG_NUM_4BULKOUT_8822B[] = {
159 /* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
160 {HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
161 {HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 64, 1},
162 {HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
163 {HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
164 {HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 640},
165 {HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 640},
168 enum halmac_ret_status
169 halmac_txdma_queue_mapping_8822b(struct halmac_adapter *halmac_adapter,
170 enum halmac_trx_mode halmac_trx_mode)
173 void *driver_adapter = NULL;
174 struct halmac_rqpn_ *curr_rqpn_sel = NULL;
175 enum halmac_ret_status status;
176 struct halmac_api *halmac_api;
178 driver_adapter = halmac_adapter->driver_adapter;
179 halmac_api = (struct halmac_api *)halmac_adapter->halmac_api;
181 if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_SDIO) {
182 curr_rqpn_sel = HALMAC_RQPN_SDIO_8822B;
183 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_PCIE) {
184 curr_rqpn_sel = HALMAC_RQPN_PCIE_8822B;
185 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_USB) {
186 if (halmac_adapter->halmac_bulkout_num == 2) {
187 curr_rqpn_sel = HALMAC_RQPN_2BULKOUT_8822B;
188 } else if (halmac_adapter->halmac_bulkout_num == 3) {
189 curr_rqpn_sel = HALMAC_RQPN_3BULKOUT_8822B;
190 } else if (halmac_adapter->halmac_bulkout_num == 4) {
191 curr_rqpn_sel = HALMAC_RQPN_4BULKOUT_8822B;
193 pr_err("[ERR]interface not support\n");
194 return HALMAC_RET_NOT_SUPPORT;
197 return HALMAC_RET_NOT_SUPPORT;
200 status = halmac_rqpn_parser_88xx(halmac_adapter, halmac_trx_mode,
202 if (status != HALMAC_RET_SUCCESS)
206 value16 |= BIT_TXDMA_HIQ_MAP(
207 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_HI]);
208 value16 |= BIT_TXDMA_MGQ_MAP(
209 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_MG]);
210 value16 |= BIT_TXDMA_BKQ_MAP(
211 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_BK]);
212 value16 |= BIT_TXDMA_BEQ_MAP(
213 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_BE]);
214 value16 |= BIT_TXDMA_VIQ_MAP(
215 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_VI]);
216 value16 |= BIT_TXDMA_VOQ_MAP(
217 halmac_adapter->halmac_ptcl_queue[HALMAC_PTCL_QUEUE_VO]);
218 HALMAC_REG_WRITE_16(halmac_adapter, REG_TXDMA_PQ_MAP, value16);
220 return HALMAC_RET_SUCCESS;
223 enum halmac_ret_status
224 halmac_priority_queue_config_8822b(struct halmac_adapter *halmac_adapter,
225 enum halmac_trx_mode halmac_trx_mode)
227 u8 transfer_mode = 0;
230 enum halmac_ret_status status;
231 struct halmac_pg_num_ *curr_pg_num = NULL;
232 void *driver_adapter = NULL;
233 struct halmac_api *halmac_api;
235 driver_adapter = halmac_adapter->driver_adapter;
236 halmac_api = (struct halmac_api *)halmac_adapter->halmac_api;
238 if (halmac_adapter->txff_allocation.la_mode == HALMAC_LA_MODE_DISABLE) {
239 if (halmac_adapter->txff_allocation.rx_fifo_expanding_mode ==
240 HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE) {
241 halmac_adapter->txff_allocation.tx_fifo_pg_num =
242 HALMAC_TX_FIFO_SIZE_8822B >>
243 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
244 } else if (halmac_adapter->txff_allocation
245 .rx_fifo_expanding_mode ==
246 HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK) {
247 halmac_adapter->txff_allocation.tx_fifo_pg_num =
248 HALMAC_TX_FIFO_SIZE_EX_1_BLK_8822B >>
249 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
250 halmac_adapter->hw_config_info.tx_fifo_size =
251 HALMAC_TX_FIFO_SIZE_EX_1_BLK_8822B;
252 if (HALMAC_RX_FIFO_SIZE_EX_1_BLK_8822B <=
253 HALMAC_RX_FIFO_SIZE_EX_1_BLK_MAX_8822B)
254 halmac_adapter->hw_config_info.rx_fifo_size =
255 HALMAC_RX_FIFO_SIZE_EX_1_BLK_8822B;
257 halmac_adapter->hw_config_info.rx_fifo_size =
258 HALMAC_RX_FIFO_SIZE_EX_1_BLK_MAX_8822B;
260 halmac_adapter->txff_allocation.tx_fifo_pg_num =
261 HALMAC_TX_FIFO_SIZE_8822B >>
262 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
263 pr_err("[ERR]rx_fifo_expanding_mode = %d not support\n",
264 halmac_adapter->txff_allocation
265 .rx_fifo_expanding_mode);
268 halmac_adapter->txff_allocation.tx_fifo_pg_num =
269 HALMAC_TX_FIFO_SIZE_LA_8822B >>
270 HALMAC_TX_PAGE_SIZE_2_POWER_8822B;
272 halmac_adapter->txff_allocation.rsvd_pg_num =
273 (halmac_adapter->txff_allocation.rsvd_drv_pg_num +
274 HALMAC_RSVD_H2C_EXTRAINFO_PGNUM_8822B +
275 HALMAC_RSVD_H2C_QUEUE_PGNUM_8822B +
276 HALMAC_RSVD_CPU_INSTRUCTION_PGNUM_8822B +
277 HALMAC_RSVD_FW_TXBUFF_PGNUM_8822B);
278 if (halmac_adapter->txff_allocation.rsvd_pg_num >
279 halmac_adapter->txff_allocation.tx_fifo_pg_num)
280 return HALMAC_RET_CFG_TXFIFO_PAGE_FAIL;
282 halmac_adapter->txff_allocation.ac_q_pg_num =
283 halmac_adapter->txff_allocation.tx_fifo_pg_num -
284 halmac_adapter->txff_allocation.rsvd_pg_num;
285 halmac_adapter->txff_allocation.rsvd_pg_bndy =
286 halmac_adapter->txff_allocation.tx_fifo_pg_num -
287 halmac_adapter->txff_allocation.rsvd_pg_num;
288 halmac_adapter->txff_allocation.rsvd_fw_txbuff_pg_bndy =
289 halmac_adapter->txff_allocation.tx_fifo_pg_num -
290 HALMAC_RSVD_FW_TXBUFF_PGNUM_8822B;
291 halmac_adapter->txff_allocation.rsvd_cpu_instr_pg_bndy =
292 halmac_adapter->txff_allocation.rsvd_fw_txbuff_pg_bndy -
293 HALMAC_RSVD_CPU_INSTRUCTION_PGNUM_8822B;
294 halmac_adapter->txff_allocation.rsvd_h2c_queue_pg_bndy =
295 halmac_adapter->txff_allocation.rsvd_cpu_instr_pg_bndy -
296 HALMAC_RSVD_H2C_QUEUE_PGNUM_8822B;
297 halmac_adapter->txff_allocation.rsvd_h2c_extra_info_pg_bndy =
298 halmac_adapter->txff_allocation.rsvd_h2c_queue_pg_bndy -
299 HALMAC_RSVD_H2C_EXTRAINFO_PGNUM_8822B;
300 halmac_adapter->txff_allocation.rsvd_drv_pg_bndy =
301 halmac_adapter->txff_allocation.rsvd_h2c_extra_info_pg_bndy -
302 halmac_adapter->txff_allocation.rsvd_drv_pg_num;
304 if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_SDIO) {
305 curr_pg_num = HALMAC_PG_NUM_SDIO_8822B;
306 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_PCIE) {
307 curr_pg_num = HALMAC_PG_NUM_PCIE_8822B;
308 } else if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_USB) {
309 if (halmac_adapter->halmac_bulkout_num == 2) {
310 curr_pg_num = HALMAC_PG_NUM_2BULKOUT_8822B;
311 } else if (halmac_adapter->halmac_bulkout_num == 3) {
312 curr_pg_num = HALMAC_PG_NUM_3BULKOUT_8822B;
313 } else if (halmac_adapter->halmac_bulkout_num == 4) {
314 curr_pg_num = HALMAC_PG_NUM_4BULKOUT_8822B;
316 pr_err("[ERR]interface not support\n");
317 return HALMAC_RET_NOT_SUPPORT;
320 return HALMAC_RET_NOT_SUPPORT;
323 status = halmac_pg_num_parser_88xx(halmac_adapter, halmac_trx_mode,
325 if (status != HALMAC_RET_SUCCESS)
328 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_1,
329 halmac_adapter->txff_allocation.high_queue_pg_num);
330 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_2,
331 halmac_adapter->txff_allocation.low_queue_pg_num);
333 halmac_adapter, REG_FIFOPAGE_INFO_3,
334 halmac_adapter->txff_allocation.normal_queue_pg_num);
335 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_4,
336 halmac_adapter->txff_allocation.extra_queue_pg_num);
337 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_INFO_5,
338 halmac_adapter->txff_allocation.pub_queue_pg_num);
340 halmac_adapter->sdio_free_space.high_queue_number =
341 halmac_adapter->txff_allocation.high_queue_pg_num;
342 halmac_adapter->sdio_free_space.normal_queue_number =
343 halmac_adapter->txff_allocation.normal_queue_pg_num;
344 halmac_adapter->sdio_free_space.low_queue_number =
345 halmac_adapter->txff_allocation.low_queue_pg_num;
346 halmac_adapter->sdio_free_space.public_queue_number =
347 halmac_adapter->txff_allocation.pub_queue_pg_num;
348 halmac_adapter->sdio_free_space.extra_queue_number =
349 halmac_adapter->txff_allocation.extra_queue_pg_num;
352 halmac_adapter, REG_RQPN_CTRL_2,
353 HALMAC_REG_READ_32(halmac_adapter, REG_RQPN_CTRL_2) | BIT(31));
355 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_CTRL_2,
356 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
357 BIT_MASK_BCN_HEAD_1_V1));
358 HALMAC_REG_WRITE_16(halmac_adapter, REG_BCNQ_BDNY_V1,
359 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
360 BIT_MASK_BCNQ_PGBNDY_V1));
361 HALMAC_REG_WRITE_16(halmac_adapter, REG_FIFOPAGE_CTRL_2 + 2,
362 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
363 BIT_MASK_BCN_HEAD_1_V1));
364 HALMAC_REG_WRITE_16(halmac_adapter, REG_BCNQ1_BDNY_V1,
365 (u16)(halmac_adapter->txff_allocation.rsvd_pg_bndy &
366 BIT_MASK_BCNQ_PGBNDY_V1));
368 HALMAC_REG_WRITE_32(halmac_adapter, REG_RXFF_BNDY,
369 halmac_adapter->hw_config_info.rx_fifo_size -
370 HALMAC_C2H_PKT_BUF_8822B - 1);
372 if (halmac_adapter->halmac_interface == HALMAC_INTERFACE_USB) {
374 HALMAC_REG_READ_8(halmac_adapter, REG_AUTO_LLT_V1) &
375 ~(BIT_MASK_BLK_DESC_NUM << BIT_SHIFT_BLK_DESC_NUM));
376 value8 = (u8)(value8 | (HALMAC_BLK_DESC_NUM_8822B
377 << BIT_SHIFT_BLK_DESC_NUM));
378 HALMAC_REG_WRITE_8(halmac_adapter, REG_AUTO_LLT_V1, value8);
380 HALMAC_REG_WRITE_8(halmac_adapter, REG_AUTO_LLT_V1 + 3,
381 HALMAC_BLK_DESC_NUM_8822B);
382 HALMAC_REG_WRITE_8(halmac_adapter, REG_TXDMA_OFFSET_CHK + 1,
383 HALMAC_REG_READ_8(halmac_adapter,
384 REG_TXDMA_OFFSET_CHK + 1) |
389 halmac_adapter, REG_AUTO_LLT_V1,
390 (u8)(HALMAC_REG_READ_8(halmac_adapter, REG_AUTO_LLT_V1) |
391 BIT_AUTO_INIT_LLT_V1));
393 while (HALMAC_REG_READ_8(halmac_adapter, REG_AUTO_LLT_V1) &
394 BIT_AUTO_INIT_LLT_V1) {
397 return HALMAC_RET_INIT_LLT_FAIL;
400 if (halmac_trx_mode == HALMAC_TRX_MODE_DELAY_LOOPBACK) {
401 transfer_mode = HALMAC_TRNSFER_LOOPBACK_DELAY;
403 halmac_adapter, REG_WMAC_LBK_BUF_HD_V1,
404 (u16)halmac_adapter->txff_allocation.rsvd_pg_bndy);
405 } else if (halmac_trx_mode == HALMAC_TRX_MODE_LOOPBACK) {
406 transfer_mode = HALMAC_TRNSFER_LOOPBACK_DIRECT;
408 transfer_mode = HALMAC_TRNSFER_NORMAL;
411 HALMAC_REG_WRITE_8(halmac_adapter, REG_CR + 3, (u8)transfer_mode);
413 return HALMAC_RET_SUCCESS;