net: wireless: rockchip_wlan: add rtl8723cs support
[firefly-linux-kernel-4.4.55.git] / drivers / net / wireless / rockchip_wlan / rtl8723cs / include / hal_com_h2c.h
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_CUSTOMER_STR_REQ = 0x06,
36         H2C_AP_OFFLOAD = 0x08,
37         H2C_BCN_RSVDPAGE = 0x09,
38         H2C_PROBERSP_RSVDPAGE = 0x0A,
39         H2C_FCS_RSVDPAGE = 0x10,
40         H2C_FCS_INFO = 0x11,
41         H2C_AP_WOW_GPIO_CTRL = 0x13,
42 #ifdef CONFIG_MCC_MODE
43         H2C_MCC_UPDATE_PARAM = 0x15,
44         H2C_MCC_MACID_BITMAP = 0x16,
45         H2C_MCC_LOCATION = 0x10,
46         H2C_MCC_CTRL = 0x18,
47         H2C_MCC_NOA_PARAM = 0x19,
48         H2C_MCC_IQK_PARAM = 0x1A,
49 #endif /* CONFIG_MCC_MODE */
50         H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,
51
52         /* PoweSave Class: 001 */
53         H2C_SET_PWR_MODE = 0x20,
54         H2C_PS_TUNING_PARA = 0x21,
55         H2C_PS_TUNING_PARA2 = 0x22,
56         H2C_P2P_LPS_PARAM = 0x23,
57         H2C_P2P_PS_OFFLOAD = 0x24,
58         H2C_PS_SCAN_ENABLE = 0x25,
59         H2C_SAP_PS_ = 0x26,
60         H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */
61         H2C_FWLPS_IN_IPS_ = 0x28,
62 #ifdef CONFIG_LPS_POFF
63         H2C_LPS_POFF_CTRL = 0x29,
64         H2C_LPS_POFF_PARAM = 0x2A,
65 #endif
66 #ifdef CONFIG_LPS_PG
67         H2C_LPS_PG_INFO = 0x2B,
68 #endif
69
70 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
71         H2C_DEFAULT_PORT_ID = 0x2C,
72 #endif
73         /* Dynamic Mechanism Class: 010 */
74         H2C_MACID_CFG = 0x40,
75         H2C_TXBF = 0x41,
76         H2C_RSSI_SETTING = 0x42,
77         H2C_AP_REQ_TXRPT = 0x43,
78         H2C_INIT_RATE_COLLECT = 0x44,
79         H2C_IQ_CALIBRATION      = 0x45,
80
81         H2C_RA_MASK_3SS = 0x46,/* for 8814A */
82         H2C_RA_PARA_ADJUST = 0x47,/* CONFIG_RA_DBG_CMD */
83         H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */
84
85         H2C_FW_TRACE_EN = 0x49,
86
87         /* BT Class: 011 */
88         H2C_B_TYPE_TDMA = 0x60,
89         H2C_BT_INFO = 0x61,
90         H2C_FORCE_BT_TXPWR = 0x62,
91         H2C_BT_IGNORE_WLANACT = 0x63,
92         H2C_DAC_SWING_VALUE = 0x64,
93         H2C_ANT_SEL_RSV = 0x65,
94         H2C_WL_OPMODE = 0x66,
95         H2C_BT_MP_OPER = 0x67,
96         H2C_BT_CONTROL = 0x68,
97         H2C_BT_WIFI_CTRL = 0x69,
98         H2C_BT_FW_PATCH = 0x6A,
99 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
100         H2C_BTC_WL_PORT_ID = 0x71,
101 #endif
102         /* WOWLAN Class: 100 */
103         H2C_WOWLAN = 0x80,
104         H2C_REMOTE_WAKE_CTRL = 0x81,
105         H2C_AOAC_GLOBAL_INFO = 0x82,
106         H2C_AOAC_RSVD_PAGE = 0x83,
107         H2C_AOAC_RSVD_PAGE2 = 0x84,
108         H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,
109         H2C_D0_SCAN_OFFLOAD_INFO = 0x86,
110         H2C_CHNL_SWITCH_OFFLOAD = 0x87,
111         H2C_AOAC_RSVDPAGE3 = 0x88,
112         H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
113         H2C_P2P_OFFLOAD = 0x8B,
114
115         H2C_RESET_TSF = 0xC0,
116         H2C_BCNHWSEQ = 0xC5,
117         H2C_CUSTOMER_STR_W1 = 0xC6,
118         H2C_CUSTOMER_STR_W2 = 0xC7,
119         H2C_CUSTOMER_STR_W3 = 0xC8,
120         H2C_MAXID,
121 };
122
123 #define H2C_INACTIVE_PS_LEN             3
124 #define H2C_RSVDPAGE_LOC_LEN            5
125 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
126 #define H2C_DEFAULT_PORT_ID_LEN         2
127 #define H2C_MEDIA_STATUS_RPT_LEN                4
128 #else
129 #define H2C_MEDIA_STATUS_RPT_LEN                3
130 #endif
131 #define H2C_KEEP_ALIVE_CTRL_LEN 2
132 #define H2C_DISCON_DECISION_LEN         3
133 #define H2C_AP_OFFLOAD_LEN              3
134 #define H2C_AP_WOW_GPIO_CTRL_LEN        4
135 #define H2C_AP_PS_LEN                   2
136 #define H2C_PWRMODE_LEN                 7
137 #define H2C_PSTUNEPARAM_LEN                     4
138 #define H2C_MACID_CFG_LEN               7
139 #define H2C_BTMP_OPER_LEN                       5
140 #define H2C_WOWLAN_LEN                  5
141 #define H2C_REMOTE_WAKE_CTRL_LEN        3
142 #define H2C_AOAC_GLOBAL_INFO_LEN        2
143 #define H2C_AOAC_RSVDPAGE_LOC_LEN       7
144 #define H2C_SCAN_OFFLOAD_CTRL_LEN       4
145 #define H2C_BT_FW_PATCH_LEN                     6
146 #define H2C_RSSI_SETTING_LEN            4
147 #define H2C_AP_REQ_TXRPT_LEN            3
148 #define H2C_FORCE_BT_TXPWR_LEN          3
149 #define H2C_BCN_RSVDPAGE_LEN            5
150 #define H2C_PROBERSP_RSVDPAGE_LEN       5
151 #define H2C_P2PRSVDPAGE_LOC_LEN 5
152 #define H2C_P2P_OFFLOAD_LEN     3
153 #ifdef CONFIG_MCC_MODE
154         #define H2C_MCC_CTRL_LEN                        7
155         #define H2C_MCC_LOCATION_LEN            3
156         #define H2C_MCC_MACID_BITMAP_LEN        6
157         #define H2C_MCC_UPDATE_INFO_LEN         4
158         #define H2C_MCC_NOA_PARAM_LEN           4
159         #define H2C_MCC_IQK_PARAM_LEN           7
160 #endif /* CONFIG_MCC_MODE */
161 #ifdef CONFIG_LPS_PG
162         #define H2C_LPS_PG_INFO_LEN             2
163         #define H2C_LPSPG_LEN                   16
164 #endif
165 #ifdef CONFIG_LPS_POFF
166         #define H2C_LPS_POFF_CTRL_LEN           1
167         #define H2C_LPS_POFF_PARAM_LEN          5
168 #endif
169
170 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
171 #define H2C_BTC_WL_PORT_ID_LEN  1
172 #endif
173 #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)
174 #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])
175 #define cpIpAddr(des, src)                                      ((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3])
176
177
178 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
179 /*
180 * ARP packet
181 *
182 * LLC Header */
183 #define GET_ARP_PKT_LLC_TYPE(__pHeader)                                 ReadLE2Byte(((u8 *)(__pHeader)) + 6)
184
185 /* ARP element */
186 #define GET_ARP_PKT_OPERATION(__pHeader)                                ReadLE2Byte(((u8 *)(__pHeader)) + 6)
187 #define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)    cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+8)
188 #define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)             cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14)
189 #define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)    cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+18)
190 #define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)     cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24)
191
192 #define SET_ARP_PKT_HW(__pHeader, __Value)                                      WriteLE2Byte(((u8 *)(__pHeader)) + 0, __Value)
193 #define SET_ARP_PKT_PROTOCOL(__pHeader, __Value)                        WriteLE2Byte(((u8 *)(__pHeader)) + 2, __Value)
194 #define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value)                     WriteLE1Byte(((u8 *)(__pHeader)) + 4, __Value)
195 #define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value)       WriteLE1Byte(((u8 *)(__pHeader)) + 5, __Value)
196 #define SET_ARP_PKT_OPERATION(__pHeader, __Value)                       WriteLE2Byte(((u8 *)(__pHeader)) + 6, __Value)
197 #define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)    cp_mac_addr(((u8 *)(__pHeader))+8, (u8 *)(_val))
198 #define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)             cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val))
199 #define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)    cp_mac_addr(((u8 *)(__pHeader))+18, (u8 *)(_val))
200 #define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)             cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val))
201
202 #define FW_WOWLAN_FUN_EN                                BIT(0)
203 #define FW_WOWLAN_PATTERN_MATCH                 BIT(1)
204 #define FW_WOWLAN_MAGIC_PKT                             BIT(2)
205 #define FW_WOWLAN_UNICAST                               BIT(3)
206 #define FW_WOWLAN_ALL_PKT_DROP                  BIT(4)
207 #define FW_WOWLAN_GPIO_ACTIVE                   BIT(5)
208 #define FW_WOWLAN_REKEY_WAKEUP                  BIT(6)
209 #define FW_WOWLAN_DEAUTH_WAKEUP                 BIT(7)
210
211 #define FW_WOWLAN_GPIO_WAKEUP_EN                BIT(0)
212 #define FW_FW_PARSE_MAGIC_PKT                   BIT(1)
213
214 #define FW_REMOTE_WAKE_CTRL_EN                  BIT(0)
215 #define FW_REALWOWLAN_EN                                BIT(5)
216
217 #define FW_WOWLAN_KEEP_ALIVE_EN                 BIT(0)
218 #define FW_ADOPT_USER                                   BIT(1)
219 #define FW_WOWLAN_KEEP_ALIVE_PKT_TYPE   BIT(2)
220
221 #define FW_REMOTE_WAKE_CTRL_EN                  BIT(0)
222 #define FW_ARP_EN                                               BIT(1)
223 #define FW_REALWOWLAN_EN                                BIT(5)
224 #define FW_WOW_FW_UNICAST_EN                    BIT(7)
225
226 #endif /* CONFIG_WOWLAN */
227
228 /* _RSVDPAGE_LOC_CMD_0x00 */
229 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
230 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)                      SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
231 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
232 #define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
233 #define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
234
235 /* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */
236 #define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value)                       SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
237 #define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 1, 1, (__Value))
238 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 2, 1, (__Value))
239 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 3, 1, (__Value))
240 #define SET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd, __Value)                         SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 4, 4, (__Value))
241 #define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value)                        SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
242 #define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 2, 0, 8, (__Value))
243 #define SET_H2CCMD_MSRRPT_PARM_PORT_NUM(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 3, 0, 3, (__Value))
244
245 #define GET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd)                LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 0, 1)
246 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd)              LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 2, 1)
247 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd) LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 3, 1)
248 #define GET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd)                  LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 4, 4)
249
250 #define H2C_MSR_ROLE_RSVD       0
251 #define H2C_MSR_ROLE_STA        1
252 #define H2C_MSR_ROLE_AP         2
253 #define H2C_MSR_ROLE_GC         3
254 #define H2C_MSR_ROLE_GO         4
255 #define H2C_MSR_ROLE_TDLS       5
256 #define H2C_MSR_ROLE_ADHOC      6
257 #define H2C_MSR_ROLE_MAX        7
258
259 extern const char *const _h2c_msr_role_str[];
260 #define h2c_msr_role_str(role) (((role) >= H2C_MSR_ROLE_MAX) ? _h2c_msr_role_str[H2C_MSR_ROLE_MAX] : _h2c_msr_role_str[(role)])
261
262 #define H2C_MSR_FMT "%s %s%s"
263 #define H2C_MSR_ARG(h2c_msr) \
264         GET_H2CCMD_MSRRPT_PARM_OPMODE((h2c_msr)) ? " C" : "", \
265         h2c_msr_role_str(GET_H2CCMD_MSRRPT_PARM_ROLE((h2c_msr))), \
266         GET_H2CCMD_MSRRPT_PARM_MIRACAST((h2c_msr)) ? (GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK((h2c_msr)) ? " MSINK" : " MSRC") : ""
267
268 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);
269 s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid);
270 s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end);
271
272 /* _KEEP_ALIVE_CMD_0x03 */
273 #define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
274 #define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)             SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
275 #define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)          SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
276 #define SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(__pH2CCmd, __Value)          SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 3, __Value)
277 #define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
278
279 /* _DISCONNECT_DECISION_CMD_0x04 */
280 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)               SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
281 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
282 #define SET_H2CCMD_DISCONDECISION_PORT_NUM(__pH2CCmd, __Value)                  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 3, __Value)
283 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
284 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
285
286 #ifdef CONFIG_RTW_CUSTOMER_STR
287 #define RTW_CUSTOMER_STR_LEN 16
288 #define RTW_CUSTOMER_STR_FMT "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x"
289 #define RTW_CUSTOMER_STR_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
290         ((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9], ((u8 *)(x))[10], ((u8 *)(x))[11], \
291         ((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15]
292
293 /* H2C_CUSTOMER_STR_REQ  0x06 */
294 #define H2C_CUSTOMER_STR_REQ_LEN 1
295 #define SET_H2CCMD_CUSTOMER_STR_REQ_EN(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
296 s32 rtw_hal_h2c_customer_str_req(_adapter *adapter);
297 s32 rtw_hal_customer_str_read(_adapter *adapter, u8 *cs);
298
299 /* H2C_CUSTOMER_STR_W1 0xC6 */
300 #define H2C_CUSTOMER_STR_W1_LEN 7
301 #define SET_H2CCMD_CUSTOMER_STR_W1_EN(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
302 #define H2CCMD_CUSTOMER_STR_W1_BYTE0(__pH2CCmd)                         (((u8 *)(__pH2CCmd)) + 1)
303
304 /* H2C_CUSTOMER_STR_W2 0xC7 */
305 #define H2C_CUSTOMER_STR_W2_LEN 7
306 #define SET_H2CCMD_CUSTOMER_STR_W2_EN(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
307 #define H2CCMD_CUSTOMER_STR_W2_BYTE6(__pH2CCmd)                         (((u8 *)(__pH2CCmd)) + 1)
308
309 /* H2C_CUSTOMER_STR_W3 0xC8 */
310 #define H2C_CUSTOMER_STR_W3_LEN 5
311 #define SET_H2CCMD_CUSTOMER_STR_W3_EN(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
312 #define H2CCMD_CUSTOMER_STR_W3_BYTE12(__pH2CCmd)                        (((u8 *)(__pH2CCmd)) + 1)
313 s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs);
314 s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
315 #endif /* CONFIG_RTW_CUSTOMER_STR */
316
317 /* _AP_Offload 0x08 */
318 #define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
319 /* _BCN_RsvdPage        0x09 */
320 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value)               SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
321 /* _Probersp_RsvdPage 0x0a */
322 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
323 /* _Probersp_RsvdPage 0x13 */
324 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
325 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value)          SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
326 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
327 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
328 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value)              SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
329 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
330 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
331 /* _AP_PS 0x26 */
332 #define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
333 #define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value)         SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
334 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
335 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
336
337 #ifdef CONFIG_LPS_POFF
338 /*PARTIAL OFF Control 0x29*/
339 #define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \
340         SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
341 /*PARTIAL OFF PARAM   0x2A*/
342 #define SET_H2CCMD_LPS_POFF_PARAM_RDVLD(__pH2CCmd, __Value) \
343         SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
344 #define SET_H2CCMD_LPS_POFF_PARAM_WRVLD(__pH2CCmd, __Value) \
345         SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
346 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDL(__pH2CCmd, __Value) \
347         SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
348 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDH(__pH2CCmd, __Value) \
349         SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
350 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDL(__pH2CCmd, __Value) \
351         SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
352 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDH(__pH2CCmd, __Value) \
353         SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
354 #endif
355
356 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
357 /* DEFAULT PORT ID 0x2C*/
358 #define SET_H2CCMD_DFTPID_PORT_ID(__pH2CCmd, __Value)                   SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 8, (__Value))
359 #define SET_H2CCMD_DFTPID_MAC_ID(__pH2CCmd, __Value)                    SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
360 #endif
361
362 #ifdef CONFIG_MCC_MODE
363 /* MCC LOC CMD 0x10 */
364 #define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
365
366 /* MCC MAC ID CMD 0x16 */
367 #define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
368 #define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
369
370 /* MCC INFO CMD 0x18 */
371 #define SET_H2CCMD_MCC_CTRL_ORDER(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
372 #define SET_H2CCMD_MCC_CTRL_TOTALNUM(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
373 #define SET_H2CCMD_MCC_CTRL_CHIDX(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
374 #define SET_H2CCMD_MCC_CTRL_BW(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
375 #define SET_H2CCMD_MCC_CTRL_BW40SC(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 3, __Value)
376 #define SET_H2CCMD_MCC_CTRL_BW80SC(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 5, 3, __Value)
377 #define SET_H2CCMD_MCC_CTRL_DURATION(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
378 #define SET_H2CCMD_MCC_CTRL_ROLE(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)
379 #define SET_H2CCMD_MCC_CTRL_INCURCH(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
380 #define SET_H2CCMD_MCC_CTRL_RSVD0(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
381 #define SET_H2CCMD_MCC_CTRL_RSVD1(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
382 #define SET_H2CCMD_MCC_CTRL_RFETYPE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 4, __Value)
383 #define SET_H2CCMD_MCC_CTRL_DISTXNULL(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 4, 1, __Value)
384 #define SET_H2CCMD_MCC_CTRL_C2HRPT(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value)
385 #define SET_H2CCMD_MCC_CTRL_CHSCAN(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
386
387 /* MCC NoA CMD 0x19 */
388 #define SET_H2CCMD_MCC_NOA_FW_EN(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
389 #define SET_H2CCMD_MCC_NOA_TSF_SYNC_OFFSET(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
390 #define SET_H2CCMD_MCC_NOA_START_TIME(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
391 #define SET_H2CCMD_MCC_NOA_INTERVAL(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
392 #define SET_H2CCMD_MCC_EARLY_TIME(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
393
394 /* MCC IQK CMD 0x1A */
395 #define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
396 #define SET_H2CCMD_MCC_IQK_ORDER(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 4, __Value)
397 #define SET_H2CCMD_MCC_IQK_PATH(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 2, __Value)
398 #define SET_H2CCMD_MCC_IQK_RX_L(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
399 #define SET_H2CCMD_MCC_IQK_RX_M1(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
400 #define SET_H2CCMD_MCC_IQK_RX_M2(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 6, __Value)
401 #define SET_H2CCMD_MCC_IQK_RX_H(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 4, __Value)
402 #define SET_H2CCMD_MCC_IQK_TX_L(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
403 #define SET_H2CCMD_MCC_IQK_TX_M1(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 3, __Value)
404 #define SET_H2CCMD_MCC_IQK_TX_M2(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 3, 5, __Value)
405 #define SET_H2CCMD_MCC_IQK_TX_H(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 6, __Value)
406 #endif /* CONFIG_MCC_MODE */
407
408 /* CHNL SWITCH OPER OFFLOAD 0x1C */
409 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
410 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(__pH2CCmd, __Value)       SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 2, __Value)
411 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 2, 3, __Value)
412 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value)
413 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value)
414
415 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
416 #define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
417 #endif
418
419 /* _WoWLAN PARAM_CMD_0x80 */
420 #define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)                       SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
421 #define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
422 #define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)          SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
423 #define SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
424 #define SET_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value)                      SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
425 #define SET_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value)                       SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
426 #define SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
427 #define SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
428 #define SET_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value)                           SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 7, __Value)
429 #define SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 7, 1, __Value)
430 #define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
431 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value)             SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value)
432 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value)          SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 1, 7, __Value)
433 #define SET_H2CCMD_WOWLAN_LOWPR_RX(__pH2CCmd, __Value)                          SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value)
434 #define SET_H2CCMD_WOWLAN_CHANGE_UNIT(__pH2CCmd, __Value)               SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
435 /* _REMOTE_WAKEUP_CMD_0x81 */
436 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
437 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
438 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
439 #define SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
440 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
441 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
442 #define SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 1, __Value)
443 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 2, 1, __Value)
444 #define SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(__pH2CCmd, __Value) \
445         SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 3, 1, __Value)
446
447 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
448 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 1, __Value)
449
450 /* AOAC_GLOBAL_INFO_0x82 */
451 #define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
452 #define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
453
454 /* AOAC_RSVDPAGE_LOC_0x83 */
455 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
456 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
457 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value)           SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
458 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
459 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value)               SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
460 #ifdef CONFIG_GTK_OL
461 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
462 #endif /* CONFIG_GTK_OL */
463
464 /* AOAC_RSVDPAGE_2_0x84 */
465
466 /* AOAC_RSVDPAGE_3_0x88 */
467 #ifdef CONFIG_PNO_SUPPORT
468 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value)               SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
469 #endif
470 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT(__pH2CCmd, __Value) \
471         SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 8, __Value)
472
473 #ifdef CONFIG_PNO_SUPPORT
474 /* D0_Scan_Offload_Info_0x86 */
475 #define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value)                  SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value)
476 #define SET_H2CCMD_AOAC_NLO_IPS_EN(__pH2CCmd, __Value)                  SET_BITS_TO_LE_1BYTE((__pH2CCmd), 4, 1, __Value)
477 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value)   SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
478 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
479 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
480 #endif /* CONFIG_PNO_SUPPORT */
481
482 #ifdef CONFIG_P2P_WOWLAN
483 /* P2P_RsvdPage_0x8a */
484 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(__pH2CCmd, __Value)                     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
485 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(__pH2CCmd, __Value)                               SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
486 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(__pH2CCmd, __Value)                        SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
487 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(__pH2CCmd, __Value)              SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
488 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(__pH2CCmd, __Value)  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
489 #endif /* CONFIG_P2P_WOWLAN */
490
491 #ifdef CONFIG_LPS_PG
492 #define SET_H2CCMD_LPSPG_SEC_CAM_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*SecurityCAM_En*/
493 #define SET_H2CCMD_LPSPG_MBID_CAM_EN(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)/*BSSIDCAM_En*/
494 #define SET_H2CCMD_LPSPG_PMC_CAM_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)/*PatternMatchCAM_En*/
495 #define SET_H2CCMD_LPSPG_MACID_SEARCH_EN(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)/*MACIDSearch_En*/
496 #define SET_H2CCMD_LPSPG_TXSC_EN(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)/*TXSC_En*/
497 #define SET_H2CCMD_LPSPG_MU_RATE_TB_EN(__pH2CCmd, __Value)      SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)/*MURateTable_En*/
498 #define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)/*Loc_LPS_PG*/
499 #endif
500
501 /* ---------------------------------------------------------------------------------------------------------
502  * -------------------------------------------    Structure    --------------------------------------------------
503  * --------------------------------------------------------------------------------------------------------- */
504 typedef struct _RSVDPAGE_LOC {
505         u8 LocProbeRsp;
506         u8 LocPsPoll;
507         u8 LocNullData;
508         u8 LocQosNull;
509         u8 LocBTQosNull;
510 #ifdef CONFIG_WOWLAN
511         u8 LocRemoteCtrlInfo;
512         u8 LocArpRsp;
513         u8 LocNbrAdv;
514         u8 LocGTKRsp;
515         u8 LocGTKInfo;
516         u8 LocProbeReq;
517         u8 LocNetList;
518 #ifdef CONFIG_GTK_OL
519         u8 LocGTKEXTMEM;
520 #endif /* CONFIG_GTK_OL */
521         u8 LocAOACReport;
522 #ifdef CONFIG_PNO_SUPPORT
523         u8 LocPNOInfo;
524         u8 LocScanInfo;
525         u8 LocSSIDInfo;
526         u8 LocProbePacket;
527 #endif /* CONFIG_PNO_SUPPORT */
528 #endif /* CONFIG_WOWLAN  */
529         u8 LocApOffloadBCN;
530 #ifdef CONFIG_P2P_WOWLAN
531         u8 LocP2PBeacon;
532         u8 LocP2PProbeRsp;
533         u8 LocNegoRsp;
534         u8 LocInviteRsp;
535         u8 LocPDRsp;
536 #endif /* CONFIG_P2P_WOWLAN */
537 } RSVDPAGE_LOC, *PRSVDPAGE_LOC;
538
539 #endif
540 void dump_TX_FIFO(PADAPTER padapter, u8 page_num, u16 page_size);
541 u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid);
542 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
543         /* WOW command function */
544         void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable);
545         #ifdef CONFIG_P2P_WOWLAN
546                 /* H2C 0x8A */
547                 u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc);
548                 /* H2C 0x8B */
549                 u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter);
550         #endif /* CONFIG_P2P_WOWLAN */
551 #endif