GNU Linux-libre 4.14.290-gnu1
[releases.git] / drivers / staging / rtlwifi / halmac / halmac_88xx / halmac_8822b / halmac_8822b_cfg.h
1 /******************************************************************************
2  *
3  * Copyright(c) 2016  Realtek Corporation.
4  *
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.
8  *
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
12  * more details.
13  *
14  * The full GNU General Public License is included in this distribution in the
15  * file called LICENSE.
16  *
17  * Contact Information:
18  * wlanfae <wlanfae@realtek.com>
19  * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
20  * Hsinchu 300, Taiwan.
21  *
22  * Larry Finger <Larry.Finger@lwfinger.net>
23  *
24  *****************************************************************************/
25 #ifndef _HALMAC_8822B_CFG_H_
26 #define _HALMAC_8822B_CFG_H_
27
28 #include "halmac_8822b_pwr_seq.h"
29 #include "halmac_api_8822b.h"
30 #include "halmac_api_8822b_usb.h"
31 #include "halmac_api_8822b_sdio.h"
32 #include "halmac_api_8822b_pcie.h"
33 #include "../../halmac_bit2.h"
34 #include "../../halmac_reg2.h"
35 #include "../../halmac_api.h"
36
37 #define HALMAC_TX_FIFO_SIZE_8822B 262144 /* 256k */
38 #define HALMAC_TX_FIFO_SIZE_LA_8822B 131072 /* 128k */
39 #define HALMAC_RX_FIFO_SIZE_8822B 24576 /* 24k */
40 #define HALMAC_TX_PAGE_SIZE_8822B 128 /* PageSize 128Byte */
41 #define HALMAC_TX_ALIGN_SIZE_8822B 8
42 #define HALMAC_TX_PAGE_SIZE_2_POWER_8822B 7 /* 128 = 2^7 */
43 #define HALMAC_SECURITY_CAM_ENTRY_NUM_8822B 64 /* CAM Entry size */
44 #define HALMAC_TX_AGG_ALIGNMENT_SIZE_8822B 8
45 #define HALMAC_TX_DESC_SIZE_8822B 48
46 #define HALMAC_RX_DESC_SIZE_8822B 24
47 #define HALMAC_RX_DESC_DUMMY_SIZE_MAX_8822B 120
48 #define HALMAC_C2H_PKT_BUF_8822B 256
49 #define HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE_MAX_8822B 80 /* align 8 Byte*/
50 #define HALMAC_RX_FIFO_EXPANDING_UNIT_8822B                                    \
51         (HALMAC_RX_DESC_SIZE_8822B + HALMAC_RX_DESC_DUMMY_SIZE_MAX_8822B +     \
52          HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE) /* align 8 Byte*/
53 #define HALMAC_RX_FIFO_EXPANDING_UNIT_MAX_8822B                                \
54         (HALMAC_RX_DESC_SIZE_8822B + HALMAC_RX_DESC_DUMMY_SIZE_MAX_8822B +     \
55          HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE_MAX_8822B) /* align 8 Byte*/
56
57 #define HALMAC_TX_FIFO_SIZE_EX_1_BLK_8822B 196608 /* 192k */
58 #define HALMAC_RX_FIFO_SIZE_EX_1_BLK_8822B                                     \
59         ((((HALMAC_RX_FIFO_EXPANDING_UNIT_8822B << 8) - 1) >> 10)              \
60          << 10) /* < 56k*/
61 #define HALMAC_RX_FIFO_SIZE_EX_1_BLK_MAX_8822B                                 \
62         ((((HALMAC_RX_FIFO_EXPANDING_UNIT_MAX_8822B << 8) - 1) >> 10)          \
63          << 10) /* 55k*/
64 #define HALMAC_TX_FIFO_SIZE_EX_2_BLK_8822B 131072 /* 128k */
65 #define HALMAC_RX_FIFO_SIZE_EX_2_BLK_8822B 155648 /* 152k */
66 #define HALMAC_TX_FIFO_SIZE_EX_3_BLK_8822B 65536 /* 64k */
67 #define HALMAC_RX_FIFO_SIZE_EX_3_BLK_8822B 221184 /* 216k */
68
69 /* TXFIFO LAYOUT
70  * HIGH_QUEUE
71  * NORMAL_QUEUE
72  * LOW_QUEUE
73  * EXTRA_QUEUE
74  * PUBLIC_QUEUE -- decided after all other queue are defined
75  * GAP_QUEUE -- Used to separate AC queue and Rsvd page
76  *
77  * RSVD_DRIVER -- Driver used rsvd page area
78  * RSVD_H2C_EXTRAINFO -- Extra Information for h2c
79  * RSVD_H2C_QUEUE -- h2c queue in rsvd page
80  * RSVD_CPU_INSTRUCTION -- extend fw code
81  * RSVD_FW_TXBUFF -- fw used this area to send packet
82  *
83  * Symbol: HALMAC_MODE_QUEUE_UNIT_CHIP, ex: HALMAC_LB_2BULKOUT_FWCMD_PGNUM_8822B
84  */
85 #define HALMAC_EXTRA_INFO_BUFF_SIZE_FULL_FIFO_8822B                            \
86         16384 /*16K, only used in init case*/
87
88 #define HALMAC_RSVD_DRV_PGNUM_8822B 16 /*2048*/
89 #define HALMAC_RSVD_H2C_EXTRAINFO_PGNUM_8822B 32 /*4096*/
90 #define HALMAC_RSVD_H2C_QUEUE_PGNUM_8822B 8 /*1024*/
91 #define HALMAC_RSVD_CPU_INSTRUCTION_PGNUM_8822B 0 /*0*/
92 #define HALMAC_RSVD_FW_TXBUFF_PGNUM_8822B 4 /*512*/
93
94 #define HALMAC_EFUSE_SIZE_8822B 1024 /* 0x400 */
95 #define HALMAC_BT_EFUSE_SIZE_8822B 128 /* 0x80 */
96 #define HALMAC_EEPROM_SIZE_8822B 0x300
97 #define HALMAC_CR_TRX_ENABLE_8822B                                             \
98         (BIT_HCI_TXDMA_EN | BIT_HCI_RXDMA_EN | BIT_TXDMA_EN | BIT_RXDMA_EN |   \
99          BIT_PROTOCOL_EN | BIT_SCHEDULE_EN | BIT_MACTXEN | BIT_MACRXEN)
100
101 #define HALMAC_BLK_DESC_NUM_8822B 0x3 /* Only for USB */
102
103 /* AMPDU max time (unit : 32us) */
104 #define HALMAC_AMPDU_MAX_TIME_8822B 0x70
105
106 /* Protect mode control */
107 #define HALMAC_PROT_RTS_LEN_TH_8822B 0xFF
108 #define HALMAC_PROT_RTS_TX_TIME_TH_8822B 0x08
109 #define HALMAC_PROT_MAX_AGG_PKT_LIMIT_8822B 0x20
110 #define HALMAC_PROT_RTS_MAX_AGG_PKT_LIMIT_8822B 0x20
111
112 /* Fast EDCA setting */
113 #define HALMAC_FAST_EDCA_VO_TH_8822B 0x06
114 #define HALMAC_FAST_EDCA_VI_TH_8822B 0x06
115 #define HALMAC_FAST_EDCA_BE_TH_8822B 0x06
116 #define HALMAC_FAST_EDCA_BK_TH_8822B 0x06
117
118 /* BAR setting */
119 #define HALMAC_BAR_RETRY_LIMIT_8822B 0x01
120 #define HALMAC_RA_TRY_RATE_AGG_LIMIT_8822B 0x08
121
122 enum halmac_normal_rxagg_th_to_8822b {
123         HALMAC_NORMAL_RXAGG_THRESHOLD_8822B = 0xFF,
124         HALMAC_NORMAL_RXAGG_TIMEOUT_8822B = 0x01,
125 };
126
127 enum halmac_loopback_rxagg_th_to_8822b {
128         HALMAC_LOOPBACK_RXAGG_THRESHOLD_8822B = 0xFF,
129         HALMAC_LOOPBACK_RXAGG_TIMEOUT_8822B = 0x01,
130 };
131
132 #endif