xref: /OK3568_Linux_fs/kernel/drivers/net/wireless/rockchip_wlan/rtl8822be/include/hal_com_h2c.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 /******************************************************************************
2  *
3  * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
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  * You should have received a copy of the GNU General Public License along with
15  * this program; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
17  *
18  *
19  ******************************************************************************/
20 #ifndef __COMMON_H2C_H__
21 #define __COMMON_H2C_H__
22 
23 /* ---------------------------------------------------------------------------------------------------------
24  * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
25  * ---------------------------------------------------------------------------------------------------------
26  * 88e, 8723b, 8812, 8821, 92e use the same FW code base */
27 enum h2c_cmd {
28 	/* Common Class: 000 */
29 	H2C_RSVD_PAGE = 0x00,
30 	H2C_MEDIA_STATUS_RPT = 0x01,
31 	H2C_SCAN_ENABLE = 0x02,
32 	H2C_KEEP_ALIVE = 0x03,
33 	H2C_DISCON_DECISION = 0x04,
34 	H2C_PSD_OFFLOAD = 0x05,
35 	H2C_AP_OFFLOAD = 0x08,
36 	H2C_BCN_RSVDPAGE = 0x09,
37 	H2C_PROBERSP_RSVDPAGE = 0x0A,
38 	H2C_FCS_RSVDPAGE = 0x10,
39 	H2C_FCS_INFO = 0x11,
40 	H2C_AP_WOW_GPIO_CTRL = 0x13,
41 #ifdef CONFIG_MCC_MODE
42 	H2C_MCC_UPDATE_PARAM = 0x15,
43 	H2C_MCC_MACID_BITMAP = 0x16,
44 	H2C_MCC_LOCATION = 0x10,
45 	H2C_MCC_INFO = 0x18,
46 	H2C_MCC_NOA_PARAM = 0x19,
47 	H2C_MCC_IQK_PARAM = 0x1A,
48 #endif /* CONFIG_MCC_MODE */
49 	H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,
50 
51 	/* PoweSave Class: 001 */
52 	H2C_SET_PWR_MODE = 0x20,
53 	H2C_PS_TUNING_PARA = 0x21,
54 	H2C_PS_TUNING_PARA2 = 0x22,
55 	H2C_P2P_LPS_PARAM = 0x23,
56 	H2C_P2P_PS_OFFLOAD = 0x24,
57 	H2C_PS_SCAN_ENABLE = 0x25,
58 	H2C_SAP_PS_ = 0x26,
59 	H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */
60 	H2C_FWLPS_IN_IPS_ = 0x28,
61 #ifdef CONFIG_LPS_POFF
62 	H2C_LPS_POFF_CTRL = 0x29,
63 	H2C_LPS_POFF_PARAM = 0x2A,
64 #endif
65 #ifdef CONFIG_LPS_PG
66 	H2C_LPS_PG_INFO = 0x2B,
67 #endif
68 	/* Dynamic Mechanism Class: 010 */
69 	H2C_MACID_CFG = 0x40,
70 	H2C_TXBF = 0x41,
71 	H2C_RSSI_SETTING = 0x42,
72 	H2C_AP_REQ_TXRPT = 0x43,
73 	H2C_INIT_RATE_COLLECT = 0x44,
74 	H2C_IQ_CALIBRATION	= 0x45,
75 
76 	H2C_RA_MASK_3SS = 0x46,/* for 8814A */
77 	H2C_RA_PARA_ADJUST = 0x47,/* CONFIG_RA_DBG_CMD */
78 	H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */
79 
80 	H2C_FW_TRACE_EN = 0x49,
81 
82 	/* BT Class: 011 */
83 	H2C_B_TYPE_TDMA = 0x60,
84 	H2C_BT_INFO = 0x61,
85 	H2C_FORCE_BT_TXPWR = 0x62,
86 	H2C_BT_IGNORE_WLANACT = 0x63,
87 	H2C_DAC_SWING_VALUE = 0x64,
88 	H2C_ANT_SEL_RSV = 0x65,
89 	H2C_WL_OPMODE = 0x66,
90 	H2C_BT_MP_OPER = 0x67,
91 	H2C_BT_CONTROL = 0x68,
92 	H2C_BT_WIFI_CTRL = 0x69,
93 	H2C_BT_FW_PATCH = 0x6A,
94 	H2C_BTC_WL_PORT_ID = 0x71,
95 
96 	/* WOWLAN Class: 100 */
97 	H2C_WOWLAN = 0x80,
98 	H2C_REMOTE_WAKE_CTRL = 0x81,
99 	H2C_AOAC_GLOBAL_INFO = 0x82,
100 	H2C_AOAC_RSVD_PAGE = 0x83,
101 	H2C_AOAC_RSVD_PAGE2 = 0x84,
102 	H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,
103 	H2C_D0_SCAN_OFFLOAD_INFO = 0x86,
104 	H2C_CHNL_SWITCH_OFFLOAD = 0x87,
105 	H2C_AOAC_RSVDPAGE3 = 0x88,
106 	H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
107 	H2C_P2P_OFFLOAD = 0x8B,
108 
109 	H2C_RESET_TSF = 0xC0,
110 	H2C_BCNHWSEQ = 0xC5,
111 	H2C_MAXID,
112 };
113 
114 #define H2C_INACTIVE_PS_LEN		3
115 #define H2C_RSVDPAGE_LOC_LEN		5
116 #define H2C_MEDIA_STATUS_RPT_LEN		3
117 #define H2C_KEEP_ALIVE_CTRL_LEN	2
118 #define H2C_DISCON_DECISION_LEN		3
119 #define H2C_AP_OFFLOAD_LEN		3
120 #define H2C_AP_WOW_GPIO_CTRL_LEN	4
121 #define H2C_AP_PS_LEN			2
122 #define H2C_PWRMODE_LEN			7
123 #define H2C_PSTUNEPARAM_LEN			4
124 #define H2C_MACID_CFG_LEN		7
125 #define H2C_BTMP_OPER_LEN			5
126 #define H2C_WOWLAN_LEN			5
127 #define H2C_REMOTE_WAKE_CTRL_LEN	3
128 #define H2C_AOAC_GLOBAL_INFO_LEN	2
129 #define H2C_AOAC_RSVDPAGE_LOC_LEN	7
130 #define H2C_SCAN_OFFLOAD_CTRL_LEN	4
131 #define H2C_BT_FW_PATCH_LEN			6
132 #define H2C_RSSI_SETTING_LEN		4
133 #define H2C_AP_REQ_TXRPT_LEN		3
134 #define H2C_FORCE_BT_TXPWR_LEN		3
135 #define H2C_BCN_RSVDPAGE_LEN		5
136 #define H2C_PROBERSP_RSVDPAGE_LEN	5
137 #define H2C_P2PRSVDPAGE_LOC_LEN	5
138 #define H2C_P2P_OFFLOAD_LEN	3
139 #ifdef CONFIG_MCC_MODE
140 	#define H2C_MCC_INFO_LEN			7
141 	#define H2C_MCC_LOCATION_LEN		3
142 	#define H2C_MCC_MACID_BITMAP_LEN	6
143 	#define H2C_MCC_UPDATE_INFO_LEN		4
144 	#define H2C_MCC_NOA_PARAM_LEN		4
145 	#define H2C_MCC_IQK_PARAM_LEN		7
146 #endif /* CONFIG_MCC_MODE */
147 #ifdef CONFIG_LPS_PG
148 	#define H2C_LPS_PG_INFO_LEN		2
149 	#define H2C_LPSPG_LEN			16
150 #endif
151 #ifdef CONFIG_LPS_POFF
152 	#define H2C_LPS_POFF_CTRL_LEN		1
153 	#define H2C_LPS_POFF_PARAM_LEN		5
154 #endif
155 #define H2C_BTC_WL_PORT_ID_LEN	1
156 
157 #define eqMacAddr(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)
158 #define cpMacAddr(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])
159 #define cpIpAddr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3])
160 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
161 	/*
162 	* ARP packet
163 	*
164 	* LLC Header */
165 	#define GET_ARP_PKT_LLC_TYPE(__pHeader)					ReadLE2Byte(((u8 *)(__pHeader)) + 6)
166 
167 	/* ARP element */
168 	#define GET_ARP_PKT_OPERATION(__pHeader)				ReadLE2Byte(((u8 *)(__pHeader)) + 6)
169 	#define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cpMacAddr((u8 *)(_val), ((u8 *)(__pHeader))+8)
170 	#define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14)
171 	#define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cpMacAddr((u8 *)(_val), ((u8 *)(__pHeader))+18)
172 	#define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)	cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24)
173 
174 	#define SET_ARP_PKT_HW(__pHeader, __Value)					WriteLE2Byte(((u8 *)(__pHeader)) + 0, __Value)
175 	#define SET_ARP_PKT_PROTOCOL(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 2, __Value)
176 	#define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value)			WriteLE1Byte(((u8 *)(__pHeader)) + 4, __Value)
177 	#define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value)	WriteLE1Byte(((u8 *)(__pHeader)) + 5, __Value)
178 	#define SET_ARP_PKT_OPERATION(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 6, __Value)
179 	#define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cpMacAddr(((u8 *)(__pHeader))+8, (u8 *)(_val))
180 	#define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val))
181 	#define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cpMacAddr(((u8 *)(__pHeader))+18, (u8 *)(_val))
182 	#define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val))
183 
184 	#define FW_WOWLAN_FUN_EN				BIT(0)
185 	#define FW_WOWLAN_PATTERN_MATCH			BIT(1)
186 	#define FW_WOWLAN_MAGIC_PKT				BIT(2)
187 	#define FW_WOWLAN_UNICAST				BIT(3)
188 	#define FW_WOWLAN_ALL_PKT_DROP			BIT(4)
189 	#define FW_WOWLAN_GPIO_ACTIVE			BIT(5)
190 	#define FW_WOWLAN_REKEY_WAKEUP			BIT(6)
191 	#define FW_WOWLAN_DEAUTH_WAKEUP			BIT(7)
192 
193 	#define FW_WOWLAN_GPIO_WAKEUP_EN		BIT(0)
194 	#define FW_FW_PARSE_MAGIC_PKT			BIT(1)
195 
196 	#define FW_REMOTE_WAKE_CTRL_EN			BIT(0)
197 	#define FW_REALWOWLAN_EN				BIT(5)
198 
199 	#define FW_WOWLAN_KEEP_ALIVE_EN			BIT(0)
200 	#define FW_ADOPT_USER					BIT(1)
201 	#define FW_WOWLAN_KEEP_ALIVE_PKT_TYPE	BIT(2)
202 
203 	#define FW_REMOTE_WAKE_CTRL_EN			BIT(0)
204 	#define FW_ARP_EN						BIT(1)
205 	#define FW_REALWOWLAN_EN				BIT(5)
206 	#define FW_WOW_FW_UNICAST_EN			BIT(7)
207 
208 #endif /* CONFIG_WOWLAN */
209 
210 /* _RSVDPAGE_LOC_CMD_0x00 */
211 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
212 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
213 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
214 #define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
215 #define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
216 
217 /* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */
218 #define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
219 #define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 1, 1, (__Value))
220 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 2, 1, (__Value))
221 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 3, 1, (__Value))
222 #define SET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 4, 4, (__Value))
223 #define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
224 #define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 2, 0, 8, (__Value))
225 
226 #define GET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 0, 1)
227 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 2, 1)
228 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd)	LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 3, 1)
229 #define GET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd)			LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 4, 4)
230 
231 #define H2C_MSR_ROLE_RSVD	0
232 #define H2C_MSR_ROLE_STA	1
233 #define H2C_MSR_ROLE_AP		2
234 #define H2C_MSR_ROLE_GC		3
235 #define H2C_MSR_ROLE_GO		4
236 #define H2C_MSR_ROLE_TDLS	5
237 #define H2C_MSR_ROLE_ADHOC	6
238 #define H2C_MSR_ROLE_MAX	7
239 
240 extern const char *const _h2c_msr_role_str[];
241 #define h2c_msr_role_str(role) (((role) >= H2C_MSR_ROLE_MAX) ? _h2c_msr_role_str[H2C_MSR_ROLE_MAX] : _h2c_msr_role_str[(role)])
242 
243 #define H2C_MSR_FMT "%s %s%s"
244 #define H2C_MSR_ARG(h2c_msr) \
245 	GET_H2CCMD_MSRRPT_PARM_OPMODE((h2c_msr)) ? " C" : "", \
246 	h2c_msr_role_str(GET_H2CCMD_MSRRPT_PARM_ROLE((h2c_msr))), \
247 	GET_H2CCMD_MSRRPT_PARM_MIRACAST((h2c_msr)) ? (GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK((h2c_msr)) ? " MSINK" : " MSRC") : ""
248 
249 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);
250 s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid);
251 s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end);
252 
253 /* _KEEP_ALIVE_CMD_0x03 */
254 #define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
255 #define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
256 #define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
257 #define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
258 
259 /* _DISCONNECT_DECISION_CMD_0x04 */
260 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
261 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
262 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
263 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
264 
265 /* _AP_Offload 0x08 */
266 #define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
267 /* _BCN_RsvdPage	0x09 */
268 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
269 /* _Probersp_RsvdPage 0x0a */
270 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
271 /* _Probersp_RsvdPage 0x13 */
272 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
273 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
274 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
275 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
276 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
277 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
278 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
279 /* _AP_PS 0x26 */
280 #define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
281 #define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
282 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
283 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
284 
285 #ifdef CONFIG_LPS_POFF
286 /*PARTIAL OFF Control 0x29*/
287 #define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \
288 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
289 /*PARTIAL OFF PARAM   0x2A*/
290 #define SET_H2CCMD_LPS_POFF_PARAM_RDVLD(__pH2CCmd, __Value) \
291 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
292 #define SET_H2CCMD_LPS_POFF_PARAM_WRVLD(__pH2CCmd, __Value) \
293 	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
294 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDL(__pH2CCmd, __Value) \
295 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
296 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDH(__pH2CCmd, __Value) \
297 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
298 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDL(__pH2CCmd, __Value) \
299 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
300 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDH(__pH2CCmd, __Value) \
301 	SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
302 #endif
303 
304 #ifdef CONFIG_MCC_MODE
305 	/* MCC LOC CMD 0x10 */
306 	#define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
307 
308 	/* MCC MAC ID CMD 0x16 */
309 	#define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
310 	#define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
311 
312 	/* MCC INFO CMD 0x18 */
313 	#define SET_H2CCMD_MCC_INFO_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
314 	#define SET_H2CCMD_MCC_INFO_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
315 	#define SET_H2CCMD_MCC_INFO_CHIDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
316 	#define SET_H2CCMD_MCC_INFO_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
317 	#define SET_H2CCMD_MCC_INFO_BW40SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 3, __Value)
318 	#define SET_H2CCMD_MCC_INFO_BW80SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 5, 3, __Value)
319 	#define SET_H2CCMD_MCC_INFO_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
320 	#define SET_H2CCMD_MCC_INFO_ROLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)
321 	#define SET_H2CCMD_MCC_INFO_INCURCH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
322 	#define SET_H2CCMD_MCC_INFO_RSVD0(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
323 	#define SET_H2CCMD_MCC_INFO_RSVD1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
324 	#define SET_H2CCMD_MCC_INFO_RFETYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 4, __Value)
325 	#define SET_H2CCMD_MCC_INFO_DISTXNULL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 4, 1, __Value)
326 	#define SET_H2CCMD_MCC_INFO_C2HRPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value)
327 	#define SET_H2CCMD_MCC_INFO_CHSCAN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
328 
329 	/* MCC NoA CMD 0x19 */
330 	#define SET_H2CCMD_MCC_NOA_FW_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
331 	#define SET_H2CCMD_MCC_NOA_TSF_SYNC_OFFSET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
332 	#define SET_H2CCMD_MCC_NOA_START_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
333 	#define SET_H2CCMD_MCC_NOA_INTERVAL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
334 	#define SET_H2CCMD_MCC_EARLY_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
335 
336 	/* MCC IQK CMD 0x1A */
337 	#define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
338 	#define SET_H2CCMD_MCC_IQK_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 2, __Value)
339 	#define SET_H2CCMD_MCC_IQK_RX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
340 	#define SET_H2CCMD_MCC_IQK_RX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
341 	#define SET_H2CCMD_MCC_IQK_RX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 6, __Value)
342 	#define SET_H2CCMD_MCC_IQK_RX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 4, __Value)
343 	#define SET_H2CCMD_MCC_IQK_TX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
344 	#define SET_H2CCMD_MCC_IQK_TX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 3, __Value)
345 	#define SET_H2CCMD_MCC_IQK_TX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 3, 5, __Value)
346 	#define SET_H2CCMD_MCC_IQK_TX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 6, __Value)
347 #endif /* CONFIG_MCC_MODE */
348 
349 /* CHNL SWITCH OPER OFFLOAD 0x1C */
350 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
351 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 2, __Value)
352 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 2, 3, __Value)
353 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value)
354 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value)
355 
356 #ifdef CONFIG_BT_COEXIST
357 #define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
358 #endif
359 
360 /* _WoWLAN PARAM_CMD_0x80 */
361 #define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
362 #define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
363 #define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
364 #define SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
365 #define SET_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
366 #define SET_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
367 #define SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
368 #define SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
369 #define SET_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 7, __Value)
370 #define SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 7, 1, __Value)
371 #define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
372 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value)
373 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 1, 7, __Value)
374 #define SET_H2CCMD_WOWLAN_LOWPR_RX(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value)
375 #define SET_H2CCMD_WOWLAN_CHANGE_UNIT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
376 /* _REMOTE_WAKEUP_CMD_0x81 */
377 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
378 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
379 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
380 #define SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
381 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
382 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
383 #define SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 1, __Value)
384 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 2, 1, __Value)
385 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
386 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 1, __Value)
387 
388 /* AOAC_GLOBAL_INFO_0x82 */
389 #define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
390 #define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
391 
392 /* AOAC_RSVDPAGE_LOC_0x83 */
393 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
394 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
395 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
396 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
397 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
398 #ifdef CONFIG_GTK_OL
399 	#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
400 #endif /* CONFIG_GTK_OL */
401 #ifdef CONFIG_PNO_SUPPORT
402 	#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
403 #endif
404 
405 #ifdef CONFIG_PNO_SUPPORT
406 	/* D0_Scan_Offload_Info_0x86 */
407 	#define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value)
408 	#define SET_H2CCMD_AOAC_NLO_IPS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 4, 1, __Value)
409 	#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
410 	#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
411 	#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
412 #endif /* CONFIG_PNO_SUPPORT */
413 
414 #ifdef CONFIG_P2P_WOWLAN
415 	/* P2P_RsvdPage_0x8a */
416 	#define SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
417 	#define SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
418 	#define SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
419 	#define SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
420 	#define SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
421 #endif /* CONFIG_P2P_WOWLAN */
422 
423 #ifdef CONFIG_LPS_PG
424 	#define SET_H2CCMD_LPSPG_SEC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*SecurityCAM_En*/
425 	#define SET_H2CCMD_LPSPG_MBID_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)/*BSSIDCAM_En*/
426 	#define SET_H2CCMD_LPSPG_PMC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)/*PatternMatchCAM_En*/
427 	#define SET_H2CCMD_LPSPG_MACID_SEARCH_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)/*MACIDSearch_En*/
428 	#define SET_H2CCMD_LPSPG_TXSC_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)/*TXSC_En*/
429 	#define SET_H2CCMD_LPSPG_MU_RATE_TB_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)/*MURateTable_En*/
430 	#define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)/*Loc_LPS_PG*/
431 #endif
432 
433 /* ---------------------------------------------------------------------------------------------------------
434  * -------------------------------------------    Structure    --------------------------------------------------
435  * --------------------------------------------------------------------------------------------------------- */
436 typedef struct _RSVDPAGE_LOC {
437 	u8 LocProbeRsp;
438 	u8 LocPsPoll;
439 	u8 LocNullData;
440 	u8 LocQosNull;
441 	u8 LocBTQosNull;
442 #ifdef CONFIG_WOWLAN
443 	u8 LocRemoteCtrlInfo;
444 	u8 LocArpRsp;
445 	u8 LocNbrAdv;
446 	u8 LocGTKRsp;
447 	u8 LocGTKInfo;
448 	u8 LocProbeReq;
449 	u8 LocNetList;
450 #ifdef CONFIG_GTK_OL
451 	u8 LocGTKEXTMEM;
452 #endif /* CONFIG_GTK_OL */
453 #ifdef CONFIG_PNO_SUPPORT
454 	u8 LocPNOInfo;
455 	u8 LocScanInfo;
456 	u8 LocSSIDInfo;
457 	u8 LocProbePacket;
458 #endif /* CONFIG_PNO_SUPPORT */
459 #endif /* CONFIG_WOWLAN	 */
460 	u8 LocApOffloadBCN;
461 #ifdef CONFIG_P2P_WOWLAN
462 	u8 LocP2PBeacon;
463 	u8 LocP2PProbeRsp;
464 	u8 LocNegoRsp;
465 	u8 LocInviteRsp;
466 	u8 LocPDRsp;
467 #endif /* CONFIG_P2P_WOWLAN */
468 } RSVDPAGE_LOC, *PRSVDPAGE_LOC;
469 
470 #endif
471 void dump_TX_FIFO(PADAPTER padapter, u8 page_num, u16 page_size);
472 u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid);
473 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
474 	/* WOW command function */
475 	void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable);
476 	#ifdef CONFIG_P2P_WOWLAN
477 		/* H2C 0x8A */
478 		u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc);
479 		/* H2C 0x8B */
480 		u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter);
481 	#endif /* CONFIG_P2P_WOWLAN */
482 #endif
483