1 /******************************************************************************
3 * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
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.
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
14 ******************************************************************************/
15 #ifndef __COMMON_H2C_H__
16 #define __COMMON_H2C_H__
19 /* H2C CMD DEFINITION ------------------------------------------------ */
21 /* 88e, 8723b, 8812, 8821, 92e use the same FW code base */
23 /* Common Class: 000 */
25 H2C_MEDIA_STATUS_RPT = 0x01,
26 H2C_SCAN_ENABLE = 0x02,
27 H2C_KEEP_ALIVE = 0x03,
28 H2C_DISCON_DECISION = 0x04,
29 H2C_PSD_OFFLOAD = 0x05,
30 H2C_AP_OFFLOAD = 0x08,
31 H2C_BCN_RSVDPAGE = 0x09,
32 H2C_PROBERSP_RSVDPAGE = 0x0A,
33 H2C_FCS_RSVDPAGE = 0x10,
35 H2C_AP_WOW_GPIO_CTRL = 0x13,
37 /* PoweSave Class: 001 */
38 H2C_SET_PWR_MODE = 0x20,
39 H2C_PS_TUNING_PARA = 0x21,
40 H2C_PS_TUNING_PARA2 = 0x22,
41 H2C_P2P_LPS_PARAM = 0x23,
42 H2C_P2P_PS_OFFLOAD = 0x24,
43 H2C_PS_SCAN_ENABLE = 0x25,
45 H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */
46 H2C_FWLPS_IN_IPS_ = 0x28,
48 /* Dynamic Mechanism Class: 010 */
51 H2C_RSSI_SETTING = 0x42,
52 H2C_AP_REQ_TXRPT = 0x43,
53 H2C_INIT_RATE_COLLECT = 0x44,
56 H2C_B_TYPE_TDMA = 0x60,
58 H2C_FORCE_BT_TXPWR = 0x62,
59 H2C_BT_IGNORE_WLANACT = 0x63,
60 H2C_DAC_SWING_VALUE = 0x64,
61 H2C_ANT_SEL_RSV = 0x65,
63 H2C_BT_MP_OPER = 0x67,
64 H2C_BT_CONTROL = 0x68,
65 H2C_BT_WIFI_CTRL = 0x69,
66 H2C_BT_FW_PATCH = 0x6A,
68 /* WOWLAN Class: 100 */
70 H2C_REMOTE_WAKE_CTRL = 0x81,
71 H2C_AOAC_GLOBAL_INFO = 0x82,
72 H2C_AOAC_RSVD_PAGE = 0x83,
73 H2C_AOAC_RSVD_PAGE2 = 0x84,
74 H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,
75 H2C_D0_SCAN_OFFLOAD_INFO = 0x86,
76 H2C_CHNL_SWITCH_OFFLOAD = 0x87,
77 H2C_AOAC_RSVDPAGE3 = 0x88,
83 #define H2C_RSVDPAGE_LOC_LEN 5
84 #define H2C_MEDIA_STATUS_RPT_LEN 3
85 #define H2C_KEEP_ALIVE_CTRL_LEN 2
86 #define H2C_DISCON_DECISION_LEN 3
87 #define H2C_AP_OFFLOAD_LEN 3
88 #define H2C_AP_WOW_GPIO_CTRL_LEN 4
89 #define H2C_AP_PS_LEN 2
90 #define H2C_PWRMODE_LEN 7
91 #define H2C_PSTUNEPARAM_LEN 4
92 #define H2C_MACID_CFG_LEN 7
93 #define H2C_BTMP_OPER_LEN 4
94 #define H2C_WOWLAN_LEN 4
95 #define H2C_REMOTE_WAKE_CTRL_LEN 3
96 #define H2C_AOAC_GLOBAL_INFO_LEN 2
97 #define H2C_AOAC_RSVDPAGE_LOC_LEN 7
98 #define H2C_SCAN_OFFLOAD_CTRL_LEN 4
99 #define H2C_BT_FW_PATCH_LEN 6
100 #define H2C_RSSI_SETTING_LEN 4
101 #define H2C_AP_REQ_TXRPT_LEN 2
102 #define H2C_FORCE_BT_TXPWR_LEN 3
103 #define H2C_BCN_RSVDPAGE_LEN 5
104 #define H2C_PROBERSP_RSVDPAGE_LEN 5
107 #define eqMacAddr(a, b) (((a)[0]==(b)[0] && (a)[1]==(b)[1] && (a)[2]==(b)[2] && (a)[3]==(b)[3] && (a)[4]==(b)[4] && (a)[5]==(b)[5]) ? 1:0)
108 #define cpMacAddr(des, src) ((des)[0]=(src)[0], (des)[1]=(src)[1], (des)[2]=(src)[2], (des)[3]=(src)[3], (des)[4]=(src)[4], (des)[5]=(src)[5])
109 #define cpIpAddr(des, src) ((des)[0]=(src)[0], (des)[1]=(src)[1], (des)[2]=(src)[2], (des)[3]=(src)[3])
115 #define GET_ARP_PKT_LLC_TYPE(__pHeader) ReadEF2Byte(((u8 *)(__pHeader)) + 6)
118 #define GET_ARP_PKT_OPERATION(__pHeader) ReadEF2Byte(((u8 *)(__pHeader)) + 6)
119 #define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val) cpMacAddr((u8 *)(_val), ((u8 *)(__pHeader))+8)
120 #define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val) cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14)
121 #define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val) cpMacAddr((u8 *)(_val), ((u8 *)(__pHeader))+18)
122 #define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val) cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24)
124 #define SET_ARP_PKT_HW(__pHeader, __Value) WRITEEF2BYTE(((u8 *)(__pHeader)) + 0, __Value)
125 #define SET_ARP_PKT_PROTOCOL(__pHeader, __Value) WRITEEF2BYTE(((u8 *)(__pHeader)) + 2, __Value)
126 #define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value) WRITEEF1BYTE(((u8 *)(__pHeader)) + 4, __Value)
127 #define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value) WRITEEF1BYTE(((u8 *)(__pHeader)) + 5, __Value)
128 #define SET_ARP_PKT_OPERATION(__pHeader, __Value) WRITEEF2BYTE(((u8 *)(__pHeader)) + 6, __Value)
129 #define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val) cpMacAddr(((u8 *)(__pHeader))+8, (u8 *)(_val))
130 #define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val) cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val))
131 #define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val) cpMacAddr(((u8 *)(__pHeader))+18, (u8 *)(_val))
132 #define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val) cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val))
134 #define FW_WOWLAN_FUN_EN BIT(0)
135 #define FW_WOWLAN_PATTERN_MATCH BIT(1)
136 #define FW_WOWLAN_MAGIC_PKT BIT(2)
137 #define FW_WOWLAN_UNICAST BIT(3)
138 #define FW_WOWLAN_ALL_PKT_DROP BIT(4)
139 #define FW_WOWLAN_GPIO_ACTIVE BIT(5)
140 #define FW_WOWLAN_REKEY_WAKEUP BIT(6)
141 #define FW_WOWLAN_DEAUTH_WAKEUP BIT(7)
143 #define FW_WOWLAN_GPIO_WAKEUP_EN BIT(0)
144 #define FW_FW_PARSE_MAGIC_PKT BIT(1)
146 #define FW_REMOTE_WAKE_CTRL_EN BIT(0)
147 #define FW_REALWOWLAN_EN BIT(5)
149 #define FW_WOWLAN_KEEP_ALIVE_EN BIT(0)
150 #define FW_ADOPT_USER BIT(1)
151 #define FW_WOWLAN_KEEP_ALIVE_PKT_TYPE BIT(2)
153 #define FW_REMOTE_WAKE_CTRL_EN BIT(0)
154 #define FW_ARP_EN BIT(1)
155 #define FW_REALWOWLAN_EN BIT(5)
156 #define FW_WOW_FW_UNICAST_EN BIT(7)
158 #endif /* CONFIG_WOWLAN */
160 /* _RSVDPAGE_LOC_CMD_0x00 */
161 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd, 0, 8, __Value)
162 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+1, 0, 8, __Value)
163 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+2, 0, 8, __Value)
164 #define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+3, 0, 8, __Value)
165 #define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+4, 0, 8, __Value)
167 /* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */
168 #define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
169 #define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
170 #define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd+1, 0, 8, __Value)
171 #define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd+2, 0, 8, __Value)
173 /* _KEEP_ALIVE_CMD_0x03 */
174 #define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
175 #define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
176 #define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
177 #define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd+1, 0, 8, __Value)
179 /* _DISCONNECT_DECISION_CMD_0x04 */
180 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
181 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
182 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd+1, 0, 8, __Value)
183 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd+2, 0, 8, __Value)
185 #ifdef CONFIG_AP_WOWLAN
186 /* _AP_Offload 0x08 */
187 #define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd, 0, 8, __Value)
188 /* _BCN_RsvdPage 0x09 */
189 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd, 0, 8, __Value)
190 /* _Probersp_RsvdPage 0x0a */
191 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd, 0, 8, __Value)
192 /* _Probersp_RsvdPage 0x13 */
193 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
194 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
195 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
196 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
197 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
198 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+1, 0, 8, __Value)
199 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+2, 0, 8, __Value)
201 #define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
202 #define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
203 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
204 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+1, 0, 8, __Value)
207 /* _WoWLAN PARAM_CMD_0x80 */
208 #define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
209 #define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
210 #define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
211 #define SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
212 #define SET_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
213 #define SET_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
214 #define SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
215 #define SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
216 #define SET_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 7, __Value)
217 #define SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 7, 1, __Value)
218 #define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+2, 0, 8, __Value)
219 /* define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value) */
220 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+3, 0, 8, __Value)
222 /* _REMOTE_WAKEUP_CMD_0x81 */
223 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
224 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
225 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
226 #define SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
227 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
228 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
229 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
231 /* AOAC_GLOBAL_INFO_0x82 */
232 #define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd, 0, 8, __Value)
233 #define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+1, 0, 8, __Value)
235 /* AOAC_RSVDPAGE_LOC_0x83 */
236 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd), 0, 8, __Value)
237 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+1, 0, 8, __Value)
238 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+2, 0, 8, __Value)
239 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+3, 0, 8, __Value)
240 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+4, 0, 8, __Value)
242 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+5, 0, 8, __Value)
243 #endif /* CONFIG_GTK_OL */
244 #ifdef CONFIG_PNO_SUPPORT
245 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd), 0, 8, __Value)
248 #ifdef CONFIG_PNO_SUPPORT
249 /* D0_Scan_Offload_Info_0x86 */
250 #define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value)
251 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+1, 0, 8, __Value)
252 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+2, 0, 8, __Value)
253 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE_8BIT((__pH2CCmd)+3, 0, 8, __Value)
254 #endif /* CONFIG_PNO_SUPPORT */
257 /* Structure -------------------------------------------------- */
259 typedef struct _RSVDPAGE_LOC {
266 u8 LocRemoteCtrlInfo;
275 #endif /* CONFIG_GTK_OL */
276 #ifdef CONFIG_PNO_SUPPORT
281 #endif /* CONFIG_PNO_SUPPORT */
282 #endif /* CONFIG_WOWLAN */
283 #ifdef CONFIG_AP_WOWLAN
285 #endif /* CONFIG_AP_WOWLAN */
286 } RSVDPAGE_LOC, *PRSVDPAGE_LOC;
289 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
290 void rtw_get_current_ip_address(struct adapter *padapter, u8 *pcurrentip);
291 void rtw_get_sec_iv(struct adapter *padapter, u8*pcur_dot11txpn, u8 *StaAddr);
292 void rtw_set_sec_pn(struct adapter *padapter);