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