xref: /OK3568_Linux_fs/external/rkwifibt/drivers/rtl8189fs/include/hal_com_h2c.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 /******************************************************************************
2  *
3  * Copyright(c) 2007 - 2017 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  *****************************************************************************/
15 #ifndef __COMMON_H2C_H__
16 #define __COMMON_H2C_H__
17 
18 /* ---------------------------------------------------------------------------------------------------------
19  * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
20  * ---------------------------------------------------------------------------------------------------------
21  * 88e, 8723b, 8812, 8821, 92e use the same FW code base */
22 enum h2c_cmd {
23 	/* Common Class: 000 */
24 	H2C_RSVD_PAGE = 0x00,
25 	H2C_MEDIA_STATUS_RPT = 0x01,
26 	H2C_SCAN_ENABLE = 0x02,
27 	H2C_KEEP_ALIVE = 0x03,
28 	H2C_DISCON_DECISION = 0x04,
29 	H2C_PSD_OFFLOAD = 0x05,
30 	H2C_CUSTOMER_STR_REQ = 0x06,
31 	H2C_TXPWR_IDX_OFFLOAD = 0x07,
32 	H2C_AP_OFFLOAD = 0x08,
33 	H2C_BCN_RSVDPAGE = 0x09,
34 	H2C_PROBERSP_RSVDPAGE = 0x0A,
35 	H2C_FCS_RSVDPAGE = 0x10,
36 	H2C_FCS_INFO = 0x11,
37 	H2C_AP_WOW_GPIO_CTRL = 0x13,
38 #ifdef CONFIG_MCC_MODE
39 	H2C_MCC_RQT_TSF = 0x15,
40 	H2C_MCC_MACID_BITMAP = 0x16,
41 	H2C_MCC_LOCATION = 0x10,
42 	H2C_MCC_CTRL_V2 = 0x17,
43 	H2C_MCC_CTRL = 0x18,
44 	H2C_MCC_TIME_SETTING = 0x19,
45 	H2C_MCC_IQK_PARAM = 0x1A,
46 #endif /* CONFIG_MCC_MODE */
47 	H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,
48 	H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D,
49 
50 	/* PoweSave Class: 001 */
51 	H2C_SET_PWR_MODE = 0x20,
52 	H2C_PS_TUNING_PARA = 0x21,
53 	H2C_PS_TUNING_PARA2 = 0x22,
54 	H2C_P2P_LPS_PARAM = 0x23,
55 	H2C_P2P_PS_OFFLOAD = 0x24,
56 	H2C_PS_SCAN_ENABLE = 0x25,
57 	H2C_SAP_PS_ = 0x26,
58 	H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */
59 	H2C_FWLPS_IN_IPS_ = 0x28,
60 #ifdef CONFIG_LPS_POFF
61 	H2C_LPS_POFF_CTRL = 0x29,
62 	H2C_LPS_POFF_PARAM = 0x2A,
63 #endif
64 #ifdef CONFIG_LPS_PG
65 	H2C_LPS_PG_INFO = 0x2B,
66 #endif
67 
68 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
69 	H2C_DEFAULT_PORT_ID = 0x2C,
70 #endif
71 	/* Dynamic Mechanism Class: 010 */
72 	H2C_MACID_CFG = 0x40,
73 	H2C_TXBF = 0x41,
74 	H2C_RSSI_SETTING = 0x42,
75 	H2C_AP_REQ_TXRPT = 0x43,
76 	H2C_INIT_RATE_COLLECT = 0x44,
77 	H2C_IQ_CALIBRATION	= 0x45,
78 
79 	H2C_RA_MASK_3SS = 0x46,/* for 8814A */
80 	H2C_RA_PARA_ADJUST = 0x47,/* CONFIG_RA_DBG_CMD */
81 	H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */
82 
83 	H2C_FW_TRACE_EN = 0x49,
84 #ifdef RTW_PER_CMD_SUPPORT_FW
85 	H2C_REQ_PER_RPT = 0x4e,
86 #endif
87 	/* BT Class: 011 */
88 	H2C_B_TYPE_TDMA = 0x60,
89 	H2C_BT_INFO = 0x61,
90 	H2C_FORCE_BT_TXPWR = 0x62,
91 	H2C_BT_IGNORE_WLANACT = 0x63,
92 	H2C_DAC_SWING_VALUE = 0x64,
93 	H2C_ANT_SEL_RSV = 0x65,
94 	H2C_WL_OPMODE = 0x66,
95 	H2C_BT_MP_OPER = 0x67,
96 	H2C_BT_CONTROL = 0x68,
97 	H2C_BT_WIFI_CTRL = 0x69,
98 	H2C_BT_FW_PATCH = 0x6A,
99 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
100 	H2C_BTC_WL_PORT_ID = 0x71,
101 #endif
102 	/* WOWLAN Class: 100 */
103 	H2C_WOWLAN = 0x80,
104 	H2C_REMOTE_WAKE_CTRL = 0x81,
105 	H2C_AOAC_GLOBAL_INFO = 0x82,
106 	H2C_AOAC_RSVD_PAGE = 0x83,
107 	H2C_AOAC_RSVD_PAGE2 = 0x84,
108 	H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,
109 	H2C_D0_SCAN_OFFLOAD_INFO = 0x86,
110 	H2C_CHNL_SWITCH_OFFLOAD = 0x87,
111 	H2C_AOAC_RSVDPAGE3 = 0x88,
112 	H2C_GPIO_CUSTOM = 0x89,
113 	H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
114 	H2C_P2P_OFFLOAD = 0x8B,
115 #ifdef CONFIG_FW_HANDLE_TXBCN
116 	H2C_FW_BCN_OFFLOAD = 0xBA,
117 #endif
118 	H2C_RESET_TSF = 0xC0,
119 #ifdef CONFIG_FW_CORRECT_BCN
120 	H2C_BCNHWSEQ = 0xC5,
121 #endif
122 	H2C_CUSTOMER_STR_W1 = 0xC6,
123 	H2C_CUSTOMER_STR_W2 = 0xC7,
124 	H2C_CUSTOMER_STR_W3 = 0xC8,
125 	H2C_BT_UNKNOWN_DEVICE_WA = 0xD1,
126 #ifdef DBG_FW_DEBUG_MSG_PKT
127 	H2C_FW_DBG_MSG_PKT = 0xE1,
128 #endif /*DBG_FW_DEBUG_MSG_PKT*/
129 	H2C_MAXID,
130 };
131 
132 #define H2C_INACTIVE_PS_LEN		4
133 #define H2C_RSVDPAGE_LOC_LEN		5
134 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
135 #define H2C_DEFAULT_PORT_ID_LEN		2
136 #define H2C_MEDIA_STATUS_RPT_LEN		4
137 #else
138 #define H2C_MEDIA_STATUS_RPT_LEN		3
139 #endif
140 #define H2C_GPIO_CUSTOM_LEN		3
141 #define H2C_KEEP_ALIVE_CTRL_LEN	2
142 #define H2C_DISCON_DECISION_LEN		3
143 #define H2C_AP_OFFLOAD_LEN		3
144 #define H2C_AP_WOW_GPIO_CTRL_LEN	4
145 #define H2C_AP_PS_LEN			2
146 #define H2C_PWRMODE_LEN			7
147 #define H2C_PSTUNEPARAM_LEN			4
148 #define H2C_MACID_CFG_LEN		7
149 #define H2C_BTMP_OPER_LEN			5
150 #define H2C_WOWLAN_LEN			7
151 #define H2C_REMOTE_WAKE_CTRL_LEN	3
152 #define H2C_AOAC_GLOBAL_INFO_LEN	2
153 #define H2C_AOAC_RSVDPAGE_LOC_LEN	7
154 #define H2C_SCAN_OFFLOAD_CTRL_LEN	4
155 #define H2C_BT_FW_PATCH_LEN			6
156 #define H2C_RSSI_SETTING_LEN		4
157 #define H2C_AP_REQ_TXRPT_LEN		3
158 #define H2C_FORCE_BT_TXPWR_LEN		3
159 #define H2C_BCN_RSVDPAGE_LEN		5
160 #define H2C_PROBERSP_RSVDPAGE_LEN	5
161 #define H2C_P2PRSVDPAGE_LOC_LEN	5
162 #define H2C_P2P_OFFLOAD_LEN	3
163 #ifdef CONFIG_MCC_MODE
164 	#define H2C_MCC_CTRL_LEN			7
165 #ifdef CONFIG_MCC_MODE_V2
166 	#define H2C_MCC_LOCATION_LEN		7
167 #else
168 	#define H2C_MCC_LOCATION_LEN		3
169 #endif
170 	#define H2C_MCC_MACID_BITMAP_LEN	6
171 	#define H2C_MCC_RQT_TSF_LEN		1
172 	#define H2C_MCC_TIME_SETTING_LEN		6
173 	#define H2C_MCC_IQK_PARAM_LEN		7
174 #endif /* CONFIG_MCC_MODE */
175 #ifdef CONFIG_LPS_PG
176 #ifdef CONFIG_RTL8822C
177 	#define H2C_LPS_PG_INFO_LEN		4
178 #else
179 	#define H2C_LPS_PG_INFO_LEN		2
180 #endif
181 	#define H2C_LPSPG_LEN			16
182 #endif
183 #ifdef CONFIG_LPS_POFF
184 	#define H2C_LPS_POFF_CTRL_LEN		1
185 	#define H2C_LPS_POFF_PARAM_LEN		5
186 #endif
187 
188 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
189 #define H2C_BTC_WL_PORT_ID_LEN	1
190 #endif
191 
192 #ifdef DBG_FW_DEBUG_MSG_PKT
193 	#define H2C_FW_DBG_MSG_PKT_LEN	2
194 #endif /*DBG_FW_DEBUG_MSG_PKT*/
195 
196 #define H2C_SINGLE_CHANNELSWITCH_V2_LEN 2
197 #define H2C_BT_UNKNOWN_DEVICE_WA_LEN 1
198 
199 #define eq_mac_addr(a, b)						(((a)[0] == (b)[0] && (a)[1] == (b)[1] && (a)[2] == (b)[2] && (a)[3] == (b)[3] && (a)[4] == (b)[4] && (a)[5] == (b)[5]) ? 1 : 0)
200 #define cp_mac_addr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3], (des)[4] = (src)[4], (des)[5] = (src)[5])
201 #define cpIpAddr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3])
202 
203 
204 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
205 #define FW_WOWLAN_FUN_EN				BIT(0)
206 #define FW_WOWLAN_PATTERN_MATCH			BIT(1)
207 #define FW_WOWLAN_MAGIC_PKT				BIT(2)
208 #define FW_WOWLAN_UNICAST				BIT(3)
209 #define FW_WOWLAN_ALL_PKT_DROP			BIT(4)
210 #define FW_WOWLAN_GPIO_ACTIVE			BIT(5)
211 #define FW_WOWLAN_REKEY_WAKEUP			BIT(6)
212 #define FW_WOWLAN_DEAUTH_WAKEUP			BIT(7)
213 
214 #define FW_WOWLAN_GPIO_WAKEUP_EN		BIT(0)
215 #define FW_FW_PARSE_MAGIC_PKT			BIT(1)
216 
217 #define FW_REMOTE_WAKE_CTRL_EN			BIT(0)
218 #define FW_REALWOWLAN_EN				BIT(5)
219 
220 #define FW_WOWLAN_KEEP_ALIVE_EN			BIT(0)
221 #define FW_ADOPT_USER					BIT(1)
222 #define FW_WOWLAN_KEEP_ALIVE_PKT_TYPE	BIT(2)
223 
224 #define FW_REMOTE_WAKE_CTRL_EN			BIT(0)
225 #define FW_ARP_EN						BIT(1)
226 #define FW_REALWOWLAN_EN				BIT(5)
227 #define FW_WOW_FW_UNICAST_EN			BIT(7)
228 
229 #define FW_IPS_DISABLE_BBRF		BIT(0)
230 #define FW_IPS_WRC				BIT(1)
231 
232 #endif /* CONFIG_WOWLAN */
233 
234 /* _RSVDPAGE_LOC_CMD_0x00 */
235 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
236 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
237 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
238 #define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
239 #define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
240 
241 /* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */
242 #define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
243 #define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 1, 1, (__Value))
244 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 2, 1, (__Value))
245 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 3, 1, (__Value))
246 #define SET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 4, 4, (__Value))
247 #define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
248 #define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 2, 0, 8, (__Value))
249 #define SET_H2CCMD_MSRRPT_PARM_PORT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 3, 0, 3, (__Value))
250 
251 #define GET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 0, 1)
252 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 2, 1)
253 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd)	LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 3, 1)
254 #define GET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd)			LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 4, 4)
255 
256 #define H2C_MSR_ROLE_RSVD	0
257 #define H2C_MSR_ROLE_STA	1
258 #define H2C_MSR_ROLE_AP		2
259 #define H2C_MSR_ROLE_GC		3
260 #define H2C_MSR_ROLE_GO		4
261 #define H2C_MSR_ROLE_TDLS	5
262 #define H2C_MSR_ROLE_ADHOC	6
263 #define H2C_MSR_ROLE_MESH	7
264 #define H2C_MSR_ROLE_MAX	8
265 
266 extern const char *const _h2c_msr_role_str[];
267 #define h2c_msr_role_str(role) (((role) >= H2C_MSR_ROLE_MAX) ? _h2c_msr_role_str[H2C_MSR_ROLE_MAX] : _h2c_msr_role_str[(role)])
268 
269 #define H2C_MSR_FMT "%s %s%s"
270 #define H2C_MSR_ARG(h2c_msr) \
271 	GET_H2CCMD_MSRRPT_PARM_OPMODE((h2c_msr)) ? " C" : "", \
272 	h2c_msr_role_str(GET_H2CCMD_MSRRPT_PARM_ROLE((h2c_msr))), \
273 	GET_H2CCMD_MSRRPT_PARM_MIRACAST((h2c_msr)) ? (GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK((h2c_msr)) ? " MSINK" : " MSRC") : ""
274 
275 s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, bool macid_ind, u8 macid_end);
276 s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid);
277 s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end);
278 
279 /* _KEEP_ALIVE_CMD_0x03 */
280 #define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
281 #define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
282 #define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
283 #define SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 3, __Value)
284 #define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
285 
286 /* _DISCONNECT_DECISION_CMD_0x04 */
287 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
288 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
289 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_BCN_FAIL_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
290 #define SET_H2CCMD_DISCONDECISION_PARM_DISCONNECT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
291 #define SET_H2CCMD_DISCONDECISION_PORT_NUM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 3, __Value)
292 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
293 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
294 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_OK_BCN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
295 
296 #ifdef CONFIG_RTW_CUSTOMER_STR
297 #define RTW_CUSTOMER_STR_LEN 16
298 #define RTW_CUSTOMER_STR_FMT "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x"
299 #define RTW_CUSTOMER_STR_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
300 	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9], ((u8 *)(x))[10], ((u8 *)(x))[11], \
301 	((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15]
302 
303 /* H2C_CUSTOMER_STR_REQ  0x06 */
304 #define H2C_CUSTOMER_STR_REQ_LEN 1
305 #define SET_H2CCMD_CUSTOMER_STR_REQ_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
306 s32 rtw_hal_h2c_customer_str_req(_adapter *adapter);
307 s32 rtw_hal_customer_str_read(_adapter *adapter, u8 *cs);
308 
309 /* H2C_CUSTOMER_STR_W1 0xC6 */
310 #define H2C_CUSTOMER_STR_W1_LEN 7
311 #define SET_H2CCMD_CUSTOMER_STR_W1_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
312 #define H2CCMD_CUSTOMER_STR_W1_BYTE0(__pH2CCmd)				(((u8 *)(__pH2CCmd)) + 1)
313 
314 /* H2C_CUSTOMER_STR_W2 0xC7 */
315 #define H2C_CUSTOMER_STR_W2_LEN 7
316 #define SET_H2CCMD_CUSTOMER_STR_W2_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
317 #define H2CCMD_CUSTOMER_STR_W2_BYTE6(__pH2CCmd)				(((u8 *)(__pH2CCmd)) + 1)
318 
319 /* H2C_CUSTOMER_STR_W3 0xC8 */
320 #define H2C_CUSTOMER_STR_W3_LEN 5
321 #define SET_H2CCMD_CUSTOMER_STR_W3_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
322 #define H2CCMD_CUSTOMER_STR_W3_BYTE12(__pH2CCmd)			(((u8 *)(__pH2CCmd)) + 1)
323 s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs);
324 s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
325 #endif /* CONFIG_RTW_CUSTOMER_STR */
326 
327 #ifdef CONFIG_FW_OFFLOAD_SET_TXPWR_IDX
328 #define H2C_TXPWR_IDX_OFFLOAD_LEN 4
329 #define SET_H2CCMD_TXPWR_IDX_CCK(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
330 #define SET_H2CCMD_TXPWR_IDX_OFDM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd + 1, 0, 8, __Value)
331 #define SET_H2CCMD_TXPWR_IDX_HT1SS(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd + 2, 0, 8, __Value)
332 #define SET_H2CCMD_TXPWR_IDX_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd + 3, 0, 1, __Value)
333 #endif
334 
335 /* _AP_Offload 0x08 */
336 #define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
337 /* _BCN_RsvdPage	0x09 */
338 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
339 /* _Probersp_RsvdPage 0x0a */
340 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
341 /* _Probersp_RsvdPage 0x13 */
342 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
343 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
344 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
345 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
346 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
347 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
348 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
349 /* _AP_PS 0x26 */
350 #define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
351 #define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
352 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
353 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
354 
355 /* INACTIVE_PS 0x27, duration unit is TBTT */
356 #define SET_H2CCMD_INACTIVE_PS_EN(__pH2CCmd, __Value) \
357 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
358 #define SET_H2CCMD_INACTIVE_IGNORE_PS(__pH2CCmd, __Value) \
359 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
360 #define SET_H2CCMD_INACTIVE_PERIOD_SCAN_EN(__pH2CCmd, __Value) \
361 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
362 #define SET_H2CCMD_INACTIVE_DISBBRF(__pH2CCmd, __Value) \
363 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
364 #define SET_H2CCMD_INACTIVE_PORT_NUM(__pH2CCmd, __Value) \
365 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 3, __Value)
366 #define SET_H2CCMD_INACTIVE_PS_FREQ(__pH2CCmd, __Value) \
367 	SET_BITS_TO_LE_1BYTE(__pH2CCmd + 1, 0, 8, __Value)
368 #define SET_H2CCMD_INACTIVE_PS_DURATION(__pH2CCmd, __Value) \
369 	SET_BITS_TO_LE_1BYTE(__pH2CCmd + 2, 0, 8, __Value)
370 #define SET_H2CCMD_INACTIVE_PS_PERIOD_SCAN_TIME(__pH2CCmd, __Value) \
371 	SET_BITS_TO_LE_1BYTE(__pH2CCmd + 3, 0, 8, __Value)
372 
373 #ifdef CONFIG_LPS_POFF
374 /*PARTIAL OFF Control 0x29*/
375 #define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \
376 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
377 /*PARTIAL OFF PARAM   0x2A*/
378 #define SET_H2CCMD_LPS_POFF_PARAM_RDVLD(__pH2CCmd, __Value) \
379 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
380 #define SET_H2CCMD_LPS_POFF_PARAM_WRVLD(__pH2CCmd, __Value) \
381 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
382 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDL(__pH2CCmd, __Value) \
383 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
384 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDH(__pH2CCmd, __Value) \
385 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
386 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDL(__pH2CCmd, __Value) \
387 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
388 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDH(__pH2CCmd, __Value) \
389 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
390 #endif
391 
392 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
393 /* DEFAULT PORT ID 0x2C*/
394 #define SET_H2CCMD_DFTPID_PORT_ID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 8, (__Value))
395 #define SET_H2CCMD_DFTPID_MAC_ID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
396 #endif
397 
398 #ifdef CONFIG_MCC_MODE
399 /* MCC LOC CMD 0x10 */
400 #define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
401 #define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 0, 1, __Value)
402 #define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 4, 4, __Value)
403 #define SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 4, 0, 8, __Value)
404 
405 /* MCC RQT TSF 0x15 */
406 #define SET_H2CCMD_MCC_RQT_TSFX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
407 #define SET_H2CCMD_MCC_RQT_TSFY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
408 
409 /* MCC MAC ID CMD 0x16 */
410 #define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
411 #define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
412 
413 /* NEW MCC CTRL CMD 0x17 */
414 #define SET_H2CCMD_MCC_CTRL_V2_ORDER(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
415 #define SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
416 #define SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
417 #define SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 4, __Value)
418 #define SET_H2CCMD_MCC_CTRL_V2_BW(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 4, __Value)
419 #define SET_H2CCMD_MCC_CTRL_V2_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
420 #define SET_H2CCMD_MCC_CTRL_V2_ROLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)
421 #define SET_H2CCMD_MCC_CTRL_V2_INCURCH(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
422 #define SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
423 #define SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
424 #define SET_H2CCMD_MCC_CTRL_V2_C2HRPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 6, 2, __Value)
425 #define SET_H2CCMD_MCC_CTRL_V2_TSFX(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 4, __Value)
426 #define SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 4, 4, __Value)
427 #define SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
428 
429 
430 /* MCC CTRL CMD 0x18 */
431 #define SET_H2CCMD_MCC_CTRL_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
432 #define SET_H2CCMD_MCC_CTRL_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
433 #define SET_H2CCMD_MCC_CTRL_CHIDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
434 #define SET_H2CCMD_MCC_CTRL_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
435 #define SET_H2CCMD_MCC_CTRL_BW40SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 3, __Value)
436 #define SET_H2CCMD_MCC_CTRL_BW80SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 5, 3, __Value)
437 #define SET_H2CCMD_MCC_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
438 #define SET_H2CCMD_MCC_CTRL_ROLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)
439 #define SET_H2CCMD_MCC_CTRL_INCURCH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
440 #define SET_H2CCMD_MCC_CTRL_RSVD0(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
441 #define SET_H2CCMD_MCC_CTRL_RSVD1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
442 #define SET_H2CCMD_MCC_CTRL_RFETYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 4, __Value)
443 #define SET_H2CCMD_MCC_CTRL_DISTXNULL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 4, 1, __Value)
444 #define SET_H2CCMD_MCC_CTRL_C2HRPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value)
445 #define SET_H2CCMD_MCC_CTRL_CHSCAN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
446 
447 /* MCC Time CMD 0x19 */
448 #define SET_H2CCMD_MCC_TIME_SETTING_FW_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
449 #define SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
450 #define SET_H2CCMD_MCC_TIME_SETTING_START_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
451 #define SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
452 #define SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
453 #define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 4, __Value)
454 #define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
455 #define  SET_H2CCMD_MCC_TIME_SETTING_UPDATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 1, __Value)
456 #define  SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 1, 7, __Value)
457 
458 /* MCC IQK CMD 0x1A */
459 #define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
460 #define SET_H2CCMD_MCC_IQK_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 4, __Value)
461 #define SET_H2CCMD_MCC_IQK_PATH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 2, __Value)
462 #define SET_H2CCMD_MCC_IQK_RX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
463 #define SET_H2CCMD_MCC_IQK_RX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
464 #define SET_H2CCMD_MCC_IQK_RX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 6, __Value)
465 #define SET_H2CCMD_MCC_IQK_RX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 4, __Value)
466 #define SET_H2CCMD_MCC_IQK_TX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
467 #define SET_H2CCMD_MCC_IQK_TX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 3, __Value)
468 #define SET_H2CCMD_MCC_IQK_TX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 3, 5, __Value)
469 #define SET_H2CCMD_MCC_IQK_TX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 6, __Value)
470 #endif /* CONFIG_MCC_MODE */
471 
472 /* CHNL SWITCH OPER OFFLOAD 0x1C */
473 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
474 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 2, __Value)
475 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 2, 3, __Value)
476 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value)
477 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value)
478 
479 /* H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D */
480 #define SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
481 #define SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 4, __Value)
482 #define SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 4, 4, __Value)
483 
484 
485 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
486 #define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
487 #endif
488 
489 /* _WoWLAN PARAM_CMD_0x80 */
490 #define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
491 #define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
492 #define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
493 #define SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
494 #define SET_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
495 #define SET_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
496 #define SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
497 #define SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
498 #define SET_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 7, __Value)
499 #define SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 7, 1, __Value)
500 #define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
501 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value)
502 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 1, 7, __Value)
503 #define SET_H2CCMD_WOWLAN_DISABLE_UPHY(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value)
504 #define SET_H2CCMD_WOWLAN_HST2DEV_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 1, 1, __Value)
505 #define SET_H2CCMD_WOWLAN_GPIO_DURATION_MS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
506 #define SET_H2CCMD_WOWLAN_CHANGE_UNIT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
507 #define SET_H2CCMD_WOWLAN_UNIT_FOR_UPHY_DISABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
508 #define SET_H2CCMD_WOWLAN_TAKE_PDN_UPHY_DIS_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
509 #define SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
510 #define SET_H2CCMD_WOWLAN_DEV2HST_EN(__pH2CCmd, __Value) 	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 7, 1, __Value)
511 #define SET_H2CCMD_WOWLAN_TIME_FOR_UPHY_DISABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
512 #define SET_H2CCMD_WOWLAN_RISE_HST2DEV(__pH2CCmd, __Value) 	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 2, 1, __Value)
513 
514 /* _REMOTE_WAKEUP_CMD_0x81 */
515 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
516 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
517 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
518 #define SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
519 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
520 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
521 #define SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 1, __Value)
522 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 2, 1, __Value)
523 #define SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(__pH2CCmd, __Value) \
524 	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 3, 1, __Value)
525 
526 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
527 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 1, __Value)
528 
529 /* AOAC_GLOBAL_INFO_0x82 */
530 #define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
531 #define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
532 
533 /* AOAC_RSVDPAGE_LOC_0x83 */
534 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
535 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
536 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
537 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
538 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
539 #ifdef CONFIG_GTK_OL
540 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
541 #endif /* CONFIG_GTK_OL */
542 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NDP_INFO(__pH2CCmd, __Value) \
543 	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 8, __Value)
544 
545 /* AOAC_RSVDPAGE_2_0x84 */
546 
547 /* AOAC_RSVDPAGE_3_0x88 */
548 #ifdef CONFIG_PNO_SUPPORT
549 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
550 #endif
551 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT(__pH2CCmd, __Value) \
552 	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 8, __Value)
553 
554 #ifdef CONFIG_PNO_SUPPORT
555 /* D0_Scan_Offload_Info_0x86 */
556 #define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value)
557 #define SET_H2CCMD_AOAC_NLO_IPS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 4, 1, __Value)
558 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
559 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
560 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
561 #endif /* CONFIG_PNO_SUPPORT */
562 
563 /* _GPIO_CUSTOM_CMD_0x89 */
564 #define SET_H2CCMD_CUSTOMERID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
565 #define SET_H2CCMD_SPECIAL_WAKE_REASON(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
566 #define SET_H2CCMD_CUSTOM_WAKE_REASON(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
567 
568 #ifdef CONFIG_P2P_WOWLAN
569 /* P2P_RsvdPage_0x8a */
570 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
571 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
572 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
573 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
574 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
575 #endif /* CONFIG_P2P_WOWLAN */
576 
577 #ifdef CONFIG_LPS_PG
578 #define SET_H2CCMD_LPSPG_SEC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*SecurityCAM_En*/
579 #define SET_H2CCMD_LPSPG_MBID_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)/*BSSIDCAM_En*/
580 #define SET_H2CCMD_LPSPG_PMC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)/*PatternMatchCAM_En*/
581 #define SET_H2CCMD_LPSPG_MACID_SEARCH_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)/*MACIDSearch_En*/
582 #define SET_H2CCMD_LPSPG_TXSC_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)/*TXSC_En*/
583 #define SET_H2CCMD_LPSPG_MU_RATE_TB_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)/*MURateTable_En*/
584 #define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)/*Loc_LPS_PG*/
585 #define SET_H2CCMD_LPSPG_DPK_INFO_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)/*Loc_LPS_PG_DPK_info*/
586 #define SET_H2CCMD_LPSPG_IQK_INFO_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 0, 8, __Value)/*Loc_IQK_result*/
587 #endif
588 
589 /* BT_UNKNOWN_DEVICE_WA_0xD1 */
590 #define SET_H2CCMD_BT_UNKNOWN_DEVICE_WA_HANG_CHK_EN(__pH2CCmd, __Value) \
591 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
592 #define SET_H2CCMD_BT_UNKNOWN_DEVICE_WA_FORCE_IB_EN(__pH2CCmd, __Value) \
593 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
594 #define SET_H2CCMD_BT_UNKNOWN_DEVICE_WA_HWID_CHK_EN(__pH2CCmd, __Value) \
595 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
596 #define SET_H2CCMD_BT_UNKNOWN_DEVICE_WA_ONE_TIME_CHK(__pH2CCmd, __Value) \
597 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
598 
599 #ifdef DBG_FW_DEBUG_MSG_PKT
600 #define SET_H2CCMD_FW_DBG_MSG_PKT_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*sniffer_dbg_en*/
601 #define SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) /*loc_debug_packet*/
602 #endif /*DBG_FW_DEBUG_MSG_PKT*/
603 
604 #ifdef DBG_RSVD_PAGE_CFG
605 #define RSVD_PAGE_CFG(ops, v1, v2, v3)	\
606 	RTW_INFO("=== [RSVD][%s]-NeedPage:%d, TotalPageNum:%d TotalPacketLen:%d ===\n",	\
607 		ops, v1, v2, v3)
608 #else
609 #define RSVD_PAGE_CFG(ops, v1, v2, v3) do {} while (0)
610 #endif
611 
612 /* ---------------------------------------------------------------------------------------------------------
613  * -------------------------------------------    Structure    --------------------------------------------------
614  * --------------------------------------------------------------------------------------------------------- */
615 typedef struct _RSVDPAGE_LOC {
616 	u8 LocProbeRsp;
617 	u8 LocPsPoll;
618 	u8 LocNullData;
619 	u8 LocQosNull;
620 	u8 LocBTQosNull;
621 #ifdef CONFIG_WOWLAN
622 	u8 LocRemoteCtrlInfo;
623 	u8 LocArpRsp;
624 	u8 LocNbrAdv;
625 	u8 LocGTKRsp;
626 	u8 LocGTKInfo;
627 	u8 LocProbeReq;
628 	u8 LocNetList;
629 #ifdef CONFIG_GTK_OL
630 	u8 LocGTKEXTMEM;
631 #endif /* CONFIG_GTK_OL */
632 	u8 LocNDPInfo;
633 	u8 LocAOACReport;
634 #ifdef CONFIG_PNO_SUPPORT
635 	u8 LocPNOInfo;
636 	u8 LocScanInfo;
637 	u8 LocSSIDInfo;
638 	u8 LocProbePacket;
639 #endif /* CONFIG_PNO_SUPPORT */
640 #endif /* CONFIG_WOWLAN	 */
641 	u8 LocApOffloadBCN;
642 #ifdef CONFIG_P2P_WOWLAN
643 	u8 LocP2PBeacon;
644 	u8 LocP2PProbeRsp;
645 	u8 LocNegoRsp;
646 	u8 LocInviteRsp;
647 	u8 LocPDRsp;
648 #endif /* CONFIG_P2P_WOWLAN */
649 #ifdef DBG_FW_DEBUG_MSG_PKT
650 	u8 loc_fw_dbg_msg_pkt;
651 #endif /*DBG_FW_DEBUG_MSG_PKT*/
652 } RSVDPAGE_LOC, *PRSVDPAGE_LOC;
653 
654 struct rsvd_page_cache_t {
655 	char *name;
656 	u8 loc;
657 	u8 page_num;
658 	u8 *data;
659 	u32 size;
660 };
661 
662 bool rsvd_page_cache_update_all(struct rsvd_page_cache_t *cache, u8 loc
663 	, u8 txdesc_len, u32 page_size, u8 *info, u32 info_len);
664 bool rsvd_page_cache_update_data(struct rsvd_page_cache_t *cache, u8 *info
665 	, u32 info_len);
666 void rsvd_page_cache_free_data(struct rsvd_page_cache_t *cache);
667 void rsvd_page_cache_free(struct rsvd_page_cache_t *cache);
668 
669 #endif
670 #ifdef CONFIG_WOWLAN
671 void dump_TX_FIFO(PADAPTER padapter, u8 page_num, u16 page_size);
672 #endif
673 u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid);
674 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
675 	/* WOW command function */
676 	void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable);
677 	#ifdef CONFIG_P2P_WOWLAN
678 		/* H2C 0x8A */
679 		u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc);
680 		/* H2C 0x8B */
681 		u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter);
682 	#endif /* CONFIG_P2P_WOWLAN */
683 #endif
684 
685 #ifdef RTW_PER_CMD_SUPPORT_FW
686 u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
687 			       u8 rpt_type, u32 macid_bitmap);
688 #endif
689