xref: /OK3568_Linux_fs/external/rkwifibt/drivers/infineon/wl_cfgvendor.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 /*
2  * Linux cfg80211 Vendor Extension Code
3  *
4  * Portions of this code are copyright (c) 2021 Cypress Semiconductor Corporation
5  *
6  * Copyright (C) 1999-2017, Broadcom Corporation
7  *
8  *      Unless you and Broadcom execute a separate written software license
9  * agreement governing use of this software, this software is licensed to you
10  * under the terms of the GNU General Public License version 2 (the "GPL"),
11  * available at http://www.broadcom.com/licenses/GPLv2.php, with the
12  * following added to such license:
13  *
14  *      As a special exception, the copyright holders of this software give you
15  * permission to link this software with independent modules, and to copy and
16  * distribute the resulting executable under terms of your choice, provided that
17  * you also meet, for each linked independent module, the terms and conditions of
18  * the license of that module.  An independent module is a module which is not
19  * derived from this software.  The special exception does not apply to any
20  * modifications of the software.
21  *
22  *      Notwithstanding the above, under no circumstances may you combine this
23  * software in any way with any other Broadcom software provided under a license
24  * other than the GPL, without Broadcom's express prior written consent.
25  *
26  *
27  * <<Broadcom-WL-IPTag/Open:>>
28  *
29  * $Id: wl_cfgvendor.h 814814 2019-04-15 03:31:10Z $
30  */
31 
32 #ifndef _wl_cfgvendor_h_
33 #define _wl_cfgvendor_h_
34 
35 #define OUI_BRCM    0x001018
36 #define OUI_GOOGLE  0x001A11
37 #define BRCM_VENDOR_SUBCMD_PRIV_STR	1
38 #define ATTRIBUTE_U32_LEN                  (NLA_HDRLEN  + 4)
39 #define VENDOR_ID_OVERHEAD                 ATTRIBUTE_U32_LEN
40 #define VENDOR_SUBCMD_OVERHEAD             ATTRIBUTE_U32_LEN
41 #define VENDOR_DATA_OVERHEAD               (NLA_HDRLEN)
42 
43 enum brcm_vendor_attr {
44 	BRCM_ATTR_DRIVER_CMD		= 0,
45 	BRCM_ATTR_DRIVER_KEY_PMK	= 1,
46 	BRCM_ATTR_DRIVER_FEATURE_FLAGS	= 2,
47 	BRCM_ATTR_DRIVER_MAX		= 3
48 };
49 
50 enum brcm_wlan_vendor_features {
51 	BRCM_WLAN_VENDOR_FEATURE_KEY_MGMT_OFFLOAD	= 0,
52 	BRCM_WLAN_VENDOR_FEATURES_MAX			= 1
53 };
54 
55 #define SCAN_RESULTS_COMPLETE_FLAG_LEN       ATTRIBUTE_U32_LEN
56 #define SCAN_INDEX_HDR_LEN                   (NLA_HDRLEN)
57 #define SCAN_ID_HDR_LEN                      ATTRIBUTE_U32_LEN
58 #define SCAN_FLAGS_HDR_LEN                   ATTRIBUTE_U32_LEN
59 #define GSCAN_NUM_RESULTS_HDR_LEN            ATTRIBUTE_U32_LEN
60 #define GSCAN_CH_BUCKET_MASK_HDR_LEN         ATTRIBUTE_U32_LEN
61 #define GSCAN_RESULTS_HDR_LEN                (NLA_HDRLEN)
62 #define GSCAN_BATCH_RESULT_HDR_LEN  (SCAN_INDEX_HDR_LEN + SCAN_ID_HDR_LEN + \
63 									SCAN_FLAGS_HDR_LEN + \
64 							        GSCAN_NUM_RESULTS_HDR_LEN + \
65 								GSCAN_CH_BUCKET_MASK_HDR_LEN + \
66 									GSCAN_RESULTS_HDR_LEN)
67 
68 #define VENDOR_REPLY_OVERHEAD       (VENDOR_ID_OVERHEAD + \
69 									VENDOR_SUBCMD_OVERHEAD + \
70 									VENDOR_DATA_OVERHEAD)
71 
72 #define GSCAN_ATTR_SET1				10
73 #define GSCAN_ATTR_SET2				20
74 #define GSCAN_ATTR_SET3				30
75 #define GSCAN_ATTR_SET4				40
76 #define GSCAN_ATTR_SET5				50
77 #define GSCAN_ATTR_SET6				60
78 #define GSCAN_ATTR_SET7				70
79 #define GSCAN_ATTR_SET8				80
80 #define GSCAN_ATTR_SET9				90
81 #define GSCAN_ATTR_SET10			100
82 #define GSCAN_ATTR_SET11			110
83 #define GSCAN_ATTR_SET12			120
84 #define GSCAN_ATTR_SET13			130
85 #define GSCAN_ATTR_SET14			140
86 
87 #define NAN_SVC_INFO_LEN			255
88 #define NAN_SID_ENABLE_FLAG_INVALID	0xff
89 #define NAN_SID_BEACON_COUNT_INVALID	0xff
90 #define WL_NAN_DW_INTERVAL 512
91 
92 #define CFG80211_VENDOR_CMD_REPLY_SKB_SZ	100
93 #define CFG80211_VENDOR_EVT_SKB_SZ			2048
94 
95 typedef enum {
96 	/* don't use 0 as a valid subcommand */
97 	VENDOR_NL80211_SUBCMD_UNSPECIFIED,
98 
99 	/* define all vendor startup commands between 0x0 and 0x0FFF */
100 	VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,
101 	VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,
102 
103 	/* define all GScan related commands between 0x1000 and 0x10FF */
104 	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,
105 	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,
106 
107 	/* define all RTT related commands between 0x1100 and 0x11FF */
108 	ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,
109 	ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,
110 
111 	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,
112 	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,
113 
114 	ANDROID_NL80211_SUBCMD_TDLS_RANGE_START = 0x1300,
115 	ANDROID_NL80211_SUBCMD_TDLS_RANGE_END	= 0x13FF,
116 
117 	ANDROID_NL80211_SUBCMD_DEBUG_RANGE_START = 0x1400,
118 	ANDROID_NL80211_SUBCMD_DEBUG_RANGE_END	= 0x14FF,
119 
120 	/* define all NearbyDiscovery related commands between 0x1500 and 0x15FF */
121 	ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1500,
122 	ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x15FF,
123 
124 	/* define all wifi calling related commands between 0x1600 and 0x16FF */
125 	ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_START = 0x1600,
126 	ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_END	= 0x16FF,
127 
128 	/* define all NAN related commands between 0x1700 and 0x17FF */
129 	ANDROID_NL80211_SUBCMD_NAN_RANGE_START = 0x1700,
130 	ANDROID_NL80211_SUBCMD_NAN_RANGE_END   = 0x17FF,
131 
132 	/* define all packet filter related commands between 0x1800 and 0x18FF */
133 	ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START = 0x1800,
134 	ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_END   = 0x18FF,
135 
136 	/* define all tx power related commands between 0x1900 and 0x1910 */
137 	ANDROID_NL80211_SUBCMD_TX_POWER_RANGE_START = 0x1900,
138 	ANDROID_NL80211_SUBCMD_TX_POWER_RANGE_END   = 0x1910,
139 
140 	/* This is reserved for future usage */
141 
142 } ANDROID_VENDOR_SUB_COMMAND;
143 
144 enum andr_vendor_subcmd {
145 	GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,
146 	GSCAN_SUBCMD_SET_CONFIG,
147 	GSCAN_SUBCMD_SET_SCAN_CONFIG,
148 	GSCAN_SUBCMD_ENABLE_GSCAN,
149 	GSCAN_SUBCMD_GET_SCAN_RESULTS,
150 	GSCAN_SUBCMD_SCAN_RESULTS,
151 	GSCAN_SUBCMD_SET_HOTLIST,
152 	GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,
153 	GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,
154 	GSCAN_SUBCMD_GET_CHANNEL_LIST,
155 	/* ANDR_WIFI_XXX although not related to gscan are defined here */
156 	ANDR_WIFI_SUBCMD_GET_FEATURE_SET,
157 	ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,
158 	ANDR_WIFI_SUBCMD_SET_PNO_RANDOM_MAC_OUI,    /*0x100C*/
159 	ANDR_WIFI_NODFS_CHANNELS,
160 	ANDR_WIFI_SET_COUNTRY,
161 	GSCAN_SUBCMD_SET_EPNO_SSID,
162 	WIFI_SUBCMD_SET_SSID_WHITELIST,
163 	WIFI_SUBCMD_SET_LAZY_ROAM_PARAMS,
164 	WIFI_SUBCMD_ENABLE_LAZY_ROAM,
165 	WIFI_SUBCMD_SET_BSSID_PREF,
166 	WIFI_SUBCMD_SET_BSSID_BLACKLIST,
167 	GSCAN_SUBCMD_ANQPO_CONFIG,
168 	WIFI_SUBCMD_SET_RSSI_MONITOR,
169 	WIFI_SUBCMD_CONFIG_ND_OFFLOAD,
170 	WIFI_SUBCMD_CONFIG_TCPACK_SUP,
171 	WIFI_SUBCMD_FW_ROAM_POLICY,
172 	WIFI_SUBCMD_ROAM_CAPABILITY,
173 	WIFI_SUBCMD_SET_LATENCY_MODE,     /*0x101b*/
174 	RTT_SUBCMD_SET_CONFIG = ANDROID_NL80211_SUBCMD_RTT_RANGE_START,
175 	RTT_SUBCMD_CANCEL_CONFIG,
176 	RTT_SUBCMD_GETCAPABILITY,
177 	RTT_SUBCMD_GETAVAILCHANNEL,
178 	RTT_SUBCMD_SET_RESPONDER,
179 	RTT_SUBCMD_CANCEL_RESPONDER,
180 	LSTATS_SUBCMD_GET_INFO = ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START,
181 
182 	DEBUG_START_LOGGING = ANDROID_NL80211_SUBCMD_DEBUG_RANGE_START,
183 	DEBUG_TRIGGER_MEM_DUMP,
184 	DEBUG_GET_MEM_DUMP,
185 	DEBUG_GET_VER,
186 	DEBUG_GET_RING_STATUS,
187 	DEBUG_GET_RING_DATA,
188 	DEBUG_GET_FEATURE,
189 	DEBUG_RESET_LOGGING,
190 
191 	DEBUG_TRIGGER_DRIVER_MEM_DUMP,
192 	DEBUG_GET_DRIVER_MEM_DUMP,
193 	DEBUG_START_PKT_FATE_MONITORING,
194 	DEBUG_GET_TX_PKT_FATES,
195 	DEBUG_GET_RX_PKT_FATES,
196 	DEBUG_GET_WAKE_REASON_STATS,
197 	DEBUG_GET_FILE_DUMP_BUF,
198 	DEBUG_FILE_DUMP_DONE_IND,
199 	DEBUG_SET_HAL_START,
200 	DEBUG_SET_HAL_STOP,
201 
202 	WIFI_OFFLOAD_SUBCMD_START_MKEEP_ALIVE = ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_START,
203 	WIFI_OFFLOAD_SUBCMD_STOP_MKEEP_ALIVE,
204 
205 	NAN_WIFI_SUBCMD_ENABLE = ANDROID_NL80211_SUBCMD_NAN_RANGE_START,	 /* 0x1700 */
206 	NAN_WIFI_SUBCMD_DISABLE,						 /* 0x1701 */
207 	NAN_WIFI_SUBCMD_REQUEST_PUBLISH,					 /* 0x1702 */
208 	NAN_WIFI_SUBCMD_REQUEST_SUBSCRIBE,					 /* 0x1703 */
209 	NAN_WIFI_SUBCMD_CANCEL_PUBLISH,						 /* 0x1704 */
210 	NAN_WIFI_SUBCMD_CANCEL_SUBSCRIBE,					 /* 0x1705 */
211 	NAN_WIFI_SUBCMD_TRANSMIT,						 /* 0x1706 */
212 	NAN_WIFI_SUBCMD_CONFIG,							 /* 0x1707 */
213 	NAN_WIFI_SUBCMD_TCA,							 /* 0x1708 */
214 	NAN_WIFI_SUBCMD_STATS,							 /* 0x1709 */
215 	NAN_WIFI_SUBCMD_GET_CAPABILITIES,					 /* 0x170A */
216 	NAN_WIFI_SUBCMD_DATA_PATH_IFACE_CREATE,					 /* 0x170B */
217 	NAN_WIFI_SUBCMD_DATA_PATH_IFACE_DELETE,					 /* 0x170C */
218 	NAN_WIFI_SUBCMD_DATA_PATH_REQUEST,					 /* 0x170D */
219 	NAN_WIFI_SUBCMD_DATA_PATH_RESPONSE,					 /* 0x170E */
220 	NAN_WIFI_SUBCMD_DATA_PATH_END,						 /* 0x170F */
221 	NAN_WIFI_SUBCMD_DATA_PATH_SEC_INFO,					 /* 0x1710 */
222 	NAN_WIFI_SUBCMD_VERSION_INFO,						 /* 0x1711 */
223 	APF_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START,
224 	APF_SUBCMD_SET_FILTER,
225 	WIFI_SUBCMD_TX_POWER_SCENARIO = ANDROID_NL80211_SUBCMD_TX_POWER_RANGE_START, /*0x1900*/
226 	/* Add more sub commands here */
227 	VENDOR_SUBCMD_MAX
228 };
229 
230 enum gscan_attributes {
231     GSCAN_ATTRIBUTE_NUM_BUCKETS = GSCAN_ATTR_SET1,
232     GSCAN_ATTRIBUTE_BASE_PERIOD,
233     GSCAN_ATTRIBUTE_BUCKETS_BAND,
234     GSCAN_ATTRIBUTE_BUCKET_ID,
235     GSCAN_ATTRIBUTE_BUCKET_PERIOD,
236     GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS,
237     GSCAN_ATTRIBUTE_BUCKET_CHANNELS,
238     GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN,
239     GSCAN_ATTRIBUTE_REPORT_THRESHOLD,
240     GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE,
241     GSCAN_ATTRIBUTE_BAND = GSCAN_ATTRIBUTE_BUCKETS_BAND,
242 
243     GSCAN_ATTRIBUTE_ENABLE_FEATURE = GSCAN_ATTR_SET2,
244     GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE,
245     GSCAN_ATTRIBUTE_FLUSH_FEATURE,
246     GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS,
247     GSCAN_ATTRIBUTE_REPORT_EVENTS,
248     /* remaining reserved for additional attributes */
249     GSCAN_ATTRIBUTE_NUM_OF_RESULTS = GSCAN_ATTR_SET3,
250     GSCAN_ATTRIBUTE_FLUSH_RESULTS,
251     GSCAN_ATTRIBUTE_SCAN_RESULTS,                       /* flat array of wifi_scan_result */
252     GSCAN_ATTRIBUTE_SCAN_ID,                            /* indicates scan number */
253     GSCAN_ATTRIBUTE_SCAN_FLAGS,                         /* indicates if scan was aborted */
254     GSCAN_ATTRIBUTE_AP_FLAGS,                           /* flags on significant change event */
255     GSCAN_ATTRIBUTE_NUM_CHANNELS,
256     GSCAN_ATTRIBUTE_CHANNEL_LIST,
257     GSCAN_ATTRIBUTE_CH_BUCKET_BITMASK,
258 
259 	/* remaining reserved for additional attributes */
260 
261     GSCAN_ATTRIBUTE_SSID = GSCAN_ATTR_SET4,
262     GSCAN_ATTRIBUTE_BSSID,
263     GSCAN_ATTRIBUTE_CHANNEL,
264     GSCAN_ATTRIBUTE_RSSI,
265     GSCAN_ATTRIBUTE_TIMESTAMP,
266     GSCAN_ATTRIBUTE_RTT,
267     GSCAN_ATTRIBUTE_RTTSD,
268 
269     /* remaining reserved for additional attributes */
270 
271     GSCAN_ATTRIBUTE_HOTLIST_BSSIDS = GSCAN_ATTR_SET5,
272     GSCAN_ATTRIBUTE_RSSI_LOW,
273     GSCAN_ATTRIBUTE_RSSI_HIGH,
274     GSCAN_ATTRIBUTE_HOSTLIST_BSSID_ELEM,
275     GSCAN_ATTRIBUTE_HOTLIST_FLUSH,
276     GSCAN_ATTRIBUTE_HOTLIST_BSSID_COUNT,
277 
278     /* remaining reserved for additional attributes */
279     GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE = GSCAN_ATTR_SET6,
280     GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE,
281     GSCAN_ATTRIBUTE_MIN_BREACHING,
282     GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS,
283     GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH,
284 
285     /* EPNO */
286     GSCAN_ATTRIBUTE_EPNO_SSID_LIST = GSCAN_ATTR_SET7,
287     GSCAN_ATTRIBUTE_EPNO_SSID,
288     GSCAN_ATTRIBUTE_EPNO_SSID_LEN,
289     GSCAN_ATTRIBUTE_EPNO_RSSI,
290     GSCAN_ATTRIBUTE_EPNO_FLAGS,
291     GSCAN_ATTRIBUTE_EPNO_AUTH,
292     GSCAN_ATTRIBUTE_EPNO_SSID_NUM,
293     GSCAN_ATTRIBUTE_EPNO_FLUSH,
294 
295     /* Roam SSID Whitelist and BSSID pref */
296     GSCAN_ATTRIBUTE_WHITELIST_SSID = GSCAN_ATTR_SET8,
297     GSCAN_ATTRIBUTE_NUM_WL_SSID,
298     GSCAN_ATTRIBUTE_WL_SSID_LEN,
299     GSCAN_ATTRIBUTE_WL_SSID_FLUSH,
300     GSCAN_ATTRIBUTE_WHITELIST_SSID_ELEM,
301     GSCAN_ATTRIBUTE_NUM_BSSID,
302     GSCAN_ATTRIBUTE_BSSID_PREF_LIST,
303     GSCAN_ATTRIBUTE_BSSID_PREF_FLUSH,
304     GSCAN_ATTRIBUTE_BSSID_PREF,
305     GSCAN_ATTRIBUTE_RSSI_MODIFIER,
306 
307     /* Roam cfg */
308     GSCAN_ATTRIBUTE_A_BAND_BOOST_THRESHOLD = GSCAN_ATTR_SET9,
309     GSCAN_ATTRIBUTE_A_BAND_PENALTY_THRESHOLD,
310     GSCAN_ATTRIBUTE_A_BAND_BOOST_FACTOR,
311     GSCAN_ATTRIBUTE_A_BAND_PENALTY_FACTOR,
312     GSCAN_ATTRIBUTE_A_BAND_MAX_BOOST,
313     GSCAN_ATTRIBUTE_LAZY_ROAM_HYSTERESIS,
314     GSCAN_ATTRIBUTE_ALERT_ROAM_RSSI_TRIGGER,
315     GSCAN_ATTRIBUTE_LAZY_ROAM_ENABLE,
316 
317     /* BSSID blacklist */
318     GSCAN_ATTRIBUTE_BSSID_BLACKLIST_FLUSH = GSCAN_ATTR_SET10,
319     GSCAN_ATTRIBUTE_BLACKLIST_BSSID,
320 
321     GSCAN_ATTRIBUTE_ANQPO_HS_LIST = GSCAN_ATTR_SET11,
322     GSCAN_ATTRIBUTE_ANQPO_HS_LIST_SIZE,
323     GSCAN_ATTRIBUTE_ANQPO_HS_NETWORK_ID,
324     GSCAN_ATTRIBUTE_ANQPO_HS_NAI_REALM,
325     GSCAN_ATTRIBUTE_ANQPO_HS_ROAM_CONSORTIUM_ID,
326     GSCAN_ATTRIBUTE_ANQPO_HS_PLMN,
327 
328     /* Adaptive scan attributes */
329     GSCAN_ATTRIBUTE_BUCKET_STEP_COUNT = GSCAN_ATTR_SET12,
330     GSCAN_ATTRIBUTE_BUCKET_MAX_PERIOD,
331 
332     /* ePNO cfg */
333     GSCAN_ATTRIBUTE_EPNO_5G_RSSI_THR = GSCAN_ATTR_SET13,
334     GSCAN_ATTRIBUTE_EPNO_2G_RSSI_THR,
335     GSCAN_ATTRIBUTE_EPNO_INIT_SCORE_MAX,
336     GSCAN_ATTRIBUTE_EPNO_CUR_CONN_BONUS,
337     GSCAN_ATTRIBUTE_EPNO_SAME_NETWORK_BONUS,
338     GSCAN_ATTRIBUTE_EPNO_SECURE_BONUS,
339     GSCAN_ATTRIBUTE_EPNO_5G_BONUS,
340 
341     /* Android O Roaming features */
342     GSCAN_ATTRIBUTE_ROAM_STATE_SET = GSCAN_ATTR_SET14,
343 
344     GSCAN_ATTRIBUTE_MAX
345 };
346 
347 enum gscan_bucket_attributes {
348 	GSCAN_ATTRIBUTE_CH_BUCKET_1,
349 	GSCAN_ATTRIBUTE_CH_BUCKET_2,
350 	GSCAN_ATTRIBUTE_CH_BUCKET_3,
351 	GSCAN_ATTRIBUTE_CH_BUCKET_4,
352 	GSCAN_ATTRIBUTE_CH_BUCKET_5,
353 	GSCAN_ATTRIBUTE_CH_BUCKET_6,
354 	GSCAN_ATTRIBUTE_CH_BUCKET_7
355 };
356 
357 enum gscan_ch_attributes {
358 	GSCAN_ATTRIBUTE_CH_ID_1,
359 	GSCAN_ATTRIBUTE_CH_ID_2,
360 	GSCAN_ATTRIBUTE_CH_ID_3,
361 	GSCAN_ATTRIBUTE_CH_ID_4,
362 	GSCAN_ATTRIBUTE_CH_ID_5,
363 	GSCAN_ATTRIBUTE_CH_ID_6,
364 	GSCAN_ATTRIBUTE_CH_ID_7
365 };
366 
367 enum rtt_attributes {
368 	RTT_ATTRIBUTE_TARGET_CNT,
369 	RTT_ATTRIBUTE_TARGET_INFO,
370 	RTT_ATTRIBUTE_TARGET_MAC,
371 	RTT_ATTRIBUTE_TARGET_TYPE,
372 	RTT_ATTRIBUTE_TARGET_PEER,
373 	RTT_ATTRIBUTE_TARGET_CHAN,
374 	RTT_ATTRIBUTE_TARGET_PERIOD,
375 	RTT_ATTRIBUTE_TARGET_NUM_BURST,
376 	RTT_ATTRIBUTE_TARGET_NUM_FTM_BURST,
377 	RTT_ATTRIBUTE_TARGET_NUM_RETRY_FTM,
378 	RTT_ATTRIBUTE_TARGET_NUM_RETRY_FTMR,
379 	RTT_ATTRIBUTE_TARGET_LCI,
380 	RTT_ATTRIBUTE_TARGET_LCR,
381 	RTT_ATTRIBUTE_TARGET_BURST_DURATION,
382 	RTT_ATTRIBUTE_TARGET_PREAMBLE,
383 	RTT_ATTRIBUTE_TARGET_BW,
384 	RTT_ATTRIBUTE_RESULTS_COMPLETE = 30,
385 	RTT_ATTRIBUTE_RESULTS_PER_TARGET,
386 	RTT_ATTRIBUTE_RESULT_CNT,
387 	RTT_ATTRIBUTE_RESULT,
388 	RTT_ATTRIBUTE_RESULT_DETAIL
389 };
390 
391 enum wifi_rssi_monitor_attr {
392 	RSSI_MONITOR_ATTRIBUTE_MAX_RSSI,
393 	RSSI_MONITOR_ATTRIBUTE_MIN_RSSI,
394 	RSSI_MONITOR_ATTRIBUTE_START
395 };
396 
397 enum wifi_sae_key_attr {
398 	BRCM_SAE_KEY_ATTR_PEER_MAC,
399 	BRCM_SAE_KEY_ATTR_PMK,
400 	BRCM_SAE_KEY_ATTR_PMKID
401 };
402 
403 enum debug_attributes {
404 	DEBUG_ATTRIBUTE_GET_DRIVER,
405 	DEBUG_ATTRIBUTE_GET_FW,
406 	DEBUG_ATTRIBUTE_RING_ID,
407 	DEBUG_ATTRIBUTE_RING_NAME,
408 	DEBUG_ATTRIBUTE_RING_FLAGS,
409 	DEBUG_ATTRIBUTE_LOG_LEVEL,
410 	DEBUG_ATTRIBUTE_LOG_TIME_INTVAL,
411 	DEBUG_ATTRIBUTE_LOG_MIN_DATA_SIZE,
412 	DEBUG_ATTRIBUTE_DUMP_FILENAME,
413 	DEBUG_ATTRIBUTE_FW_DUMP_LEN,
414 	DEBUG_ATTRIBUTE_FW_DUMP_DATA,
415 	DEBUG_ATTRIBUTE_RING_DATA,
416 	DEBUG_ATTRIBUTE_RING_STATUS,
417 	DEBUG_ATTRIBUTE_RING_NUM,
418 	DEBUG_ATTRIBUTE_DRIVER_DUMP_LEN,
419 	DEBUG_ATTRIBUTE_DRIVER_DUMP_DATA,
420 	DEBUG_ATTRIBUTE_PKT_FATE_NUM,
421 	DEBUG_ATTRIBUTE_PKT_FATE_DATA
422 };
423 
424 typedef enum {
425 	DUMP_LEN_ATTR_INVALID,
426 	DUMP_LEN_ATTR_MEMDUMP,
427 	DUMP_LEN_ATTR_SSSR_C0_D11_BEFORE,
428 	DUMP_LEN_ATTR_SSSR_C0_D11_AFTER,
429 	DUMP_LEN_ATTR_SSSR_C1_D11_BEFORE,
430 	DUMP_LEN_ATTR_SSSR_C1_D11_AFTER,
431 	DUMP_LEN_ATTR_SSSR_DIG_BEFORE,
432 	DUMP_LEN_ATTR_SSSR_DIG_AFTER,
433 	DUMP_LEN_ATTR_TIMESTAMP,
434 	DUMP_LEN_ATTR_GENERAL_LOG,
435 	DUMP_LEN_ATTR_ECNTRS,
436 	DUMP_LEN_ATTR_SPECIAL_LOG,
437 	DUMP_LEN_ATTR_DHD_DUMP,
438 	DUMP_LEN_ATTR_EXT_TRAP,
439 	DUMP_LEN_ATTR_HEALTH_CHK,
440 	DUMP_LEN_ATTR_PRESERVE_LOG,
441 	DUMP_LEN_ATTR_COOKIE,
442 	DUMP_LEN_ATTR_FLOWRING_DUMP,
443 	DUMP_LEN_ATTR_PKTLOG,
444 	DUMP_FILENAME_ATTR_DEBUG_DUMP,
445 	DUMP_FILENAME_ATTR_MEM_DUMP,
446 	DUMP_FILENAME_ATTR_SSSR_CORE_0_BEFORE_DUMP,
447 	DUMP_FILENAME_ATTR_SSSR_CORE_0_AFTER_DUMP,
448 	DUMP_FILENAME_ATTR_SSSR_CORE_1_BEFORE_DUMP,
449 	DUMP_FILENAME_ATTR_SSSR_CORE_1_AFTER_DUMP,
450 	DUMP_FILENAME_ATTR_SSSR_DIG_BEFORE_DUMP,
451 	DUMP_FILENAME_ATTR_SSSR_DIG_AFTER_DUMP,
452 	DUMP_FILENAME_ATTR_PKTLOG_DUMP,
453 	DUMP_LEN_ATTR_STATUS_LOG,
454 	DUMP_LEN_ATTR_AXI_ERROR,
455 	DUMP_FILENAME_ATTR_AXI_ERROR_DUMP,
456 	DUMP_LEN_ATTR_RTT_LOG
457 } EWP_DUMP_EVENT_ATTRIBUTE;
458 
459 /* Attributes associated with DEBUG_GET_DUMP_BUF */
460 typedef enum {
461 	DUMP_BUF_ATTR_INVALID,
462 	DUMP_BUF_ATTR_MEMDUMP,
463 	DUMP_BUF_ATTR_SSSR_C0_D11_BEFORE,
464 	DUMP_BUF_ATTR_SSSR_C0_D11_AFTER,
465 	DUMP_BUF_ATTR_SSSR_C1_D11_BEFORE,
466 	DUMP_BUF_ATTR_SSSR_C1_D11_AFTER,
467 	DUMP_BUF_ATTR_SSSR_DIG_BEFORE,
468 	DUMP_BUF_ATTR_SSSR_DIG_AFTER,
469 	DUMP_BUF_ATTR_TIMESTAMP,
470 	DUMP_BUF_ATTR_GENERAL_LOG,
471 	DUMP_BUF_ATTR_ECNTRS,
472 	DUMP_BUF_ATTR_SPECIAL_LOG,
473 	DUMP_BUF_ATTR_DHD_DUMP,
474 	DUMP_BUF_ATTR_EXT_TRAP,
475 	DUMP_BUF_ATTR_HEALTH_CHK,
476 	DUMP_BUF_ATTR_PRESERVE_LOG,
477 	DUMP_BUF_ATTR_COOKIE,
478 	DUMP_BUF_ATTR_FLOWRING_DUMP,
479 	DUMP_BUF_ATTR_PKTLOG,
480 	DUMP_BUF_ATTR_STATUS_LOG,
481 	DUMP_BUF_ATTR_AXI_ERROR,
482 	DUMP_BUF_ATTR_RTT_LOG
483 } EWP_DUMP_CMD_ATTRIBUTE;
484 
485 enum mkeep_alive_attributes {
486 	MKEEP_ALIVE_ATTRIBUTE_ID,
487 	MKEEP_ALIVE_ATTRIBUTE_IP_PKT,
488 	MKEEP_ALIVE_ATTRIBUTE_IP_PKT_LEN,
489 	MKEEP_ALIVE_ATTRIBUTE_SRC_MAC_ADDR,
490 	MKEEP_ALIVE_ATTRIBUTE_DST_MAC_ADDR,
491 	MKEEP_ALIVE_ATTRIBUTE_PERIOD_MSEC
492 };
493 
494 typedef enum wl_vendor_event {
495 	BRCM_VENDOR_EVENT_UNSPEC		= 0,
496 	BRCM_VENDOR_EVENT_PRIV_STR		= 1,
497 	GOOGLE_GSCAN_SIGNIFICANT_EVENT		= 2,
498 	GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT	= 3,
499 	GOOGLE_GSCAN_BATCH_SCAN_EVENT		= 4,
500 	GOOGLE_SCAN_FULL_RESULTS_EVENT		= 5,
501 	GOOGLE_RTT_COMPLETE_EVENT		= 6,
502 	GOOGLE_SCAN_COMPLETE_EVENT		= 7,
503 	GOOGLE_GSCAN_GEOFENCE_LOST_EVENT	= 8,
504 	GOOGLE_SCAN_EPNO_EVENT			= 9,
505 	GOOGLE_DEBUG_RING_EVENT			= 10,
506 	GOOGLE_FW_DUMP_EVENT			= 11,
507 	GOOGLE_PNO_HOTSPOT_FOUND_EVENT		= 12,
508 	GOOGLE_RSSI_MONITOR_EVENT		= 13,
509 	GOOGLE_MKEEP_ALIVE_EVENT		= 14,
510 
511 	/*
512 	 * BRCM specific events should be placed after
513 	 * the Generic events so that enums don't mismatch
514 	 * between the DHD and HAL
515 	 */
516 	GOOGLE_NAN_EVENT_ENABLED		= 15,
517 	GOOGLE_NAN_EVENT_DISABLED		= 16,
518 	GOOGLE_NAN_EVENT_SUBSCRIBE_MATCH	= 17,
519 	GOOGLE_NAN_EVENT_REPLIED		= 18,
520 	GOOGLE_NAN_EVENT_PUBLISH_TERMINATED	= 19,
521 	GOOGLE_NAN_EVENT_SUBSCRIBE_TERMINATED	= 20,
522 	GOOGLE_NAN_EVENT_DE_EVENT		= 21,
523 	GOOGLE_NAN_EVENT_FOLLOWUP		= 22,
524 	GOOGLE_NAN_EVENT_TRANSMIT_FOLLOWUP_IND	= 23,
525 	GOOGLE_NAN_EVENT_DATA_REQUEST		= 24,
526 	GOOGLE_NAN_EVENT_DATA_CONFIRMATION	= 25,
527 	GOOGLE_NAN_EVENT_DATA_END		= 26,
528 	GOOGLE_NAN_EVENT_BEACON			= 27,
529 	GOOGLE_NAN_EVENT_SDF			= 28,
530 	GOOGLE_NAN_EVENT_TCA			= 29,
531 	GOOGLE_NAN_EVENT_SUBSCRIBE_UNMATCH	= 30,
532 	GOOGLE_NAN_EVENT_UNKNOWN		= 31,
533 	GOOGLE_ROAM_EVENT_START			= 32,
534 	BRCM_VENDOR_EVENT_HANGED                = 33,
535 	BRCM_VENDOR_EVENT_SAE_KEY               = 34,
536 	BRCM_VENDOR_EVENT_BEACON_RECV           = 35,
537 	BRCM_VENDOR_EVENT_PORT_AUTHORIZED       = 36,
538 	GOOGLE_FILE_DUMP_EVENT			= 37,
539 	BRCM_VENDOR_EVENT_CU			= 38,
540 	BRCM_VENDOR_EVENT_WIPS			= 39
541 } wl_vendor_event_t;
542 
543 enum andr_wifi_attr {
544 	ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET,
545 	ANDR_WIFI_ATTRIBUTE_FEATURE_SET,
546 	ANDR_WIFI_ATTRIBUTE_PNO_RANDOM_MAC_OUI,
547 	ANDR_WIFI_ATTRIBUTE_NODFS_SET,
548 	ANDR_WIFI_ATTRIBUTE_COUNTRY,
549 	ANDR_WIFI_ATTRIBUTE_ND_OFFLOAD_VALUE,
550 	ANDR_WIFI_ATTRIBUTE_TCPACK_SUP_VALUE,
551 	ANDR_WIFI_ATTRIBUTE_LATENCY_MODE,
552 	ANDR_WIFI_ATTRIBUTE_RANDOM_MAC,
553 	ANDR_WIFI_ATTRIBUTE_TX_POWER_SCENARIO
554 	//Add more attributes here
555 };
556 enum apf_attributes {
557 	APF_ATTRIBUTE_VERSION,
558 	APF_ATTRIBUTE_MAX_LEN,
559 	APF_ATTRIBUTE_PROGRAM,
560 	APF_ATTRIBUTE_PROGRAM_LEN
561 };
562 
563 typedef enum wl_vendor_gscan_attribute {
564 	ATTR_START_GSCAN,
565 	ATTR_STOP_GSCAN,
566 	ATTR_SET_SCAN_BATCH_CFG_ID, /* set batch scan params */
567 	ATTR_SET_SCAN_GEOFENCE_CFG_ID, /* set list of bssids to track */
568 	ATTR_SET_SCAN_SIGNIFICANT_CFG_ID, /* set list of bssids, rssi threshold etc.. */
569 	ATTR_SET_SCAN_CFG_ID, /* set common scan config params here */
570 	ATTR_GET_GSCAN_CAPABILITIES_ID,
571     /* Add more sub commands here */
572 	ATTR_GSCAN_MAX
573 } wl_vendor_gscan_attribute_t;
574 
575 typedef enum gscan_batch_attribute {
576 	ATTR_GSCAN_BATCH_BESTN,
577 	ATTR_GSCAN_BATCH_MSCAN,
578 	ATTR_GSCAN_BATCH_BUFFER_THRESHOLD
579 } gscan_batch_attribute_t;
580 
581 typedef enum gscan_geofence_attribute {
582 	ATTR_GSCAN_NUM_HOTLIST_BSSID,
583 	ATTR_GSCAN_HOTLIST_BSSID
584 } gscan_geofence_attribute_t;
585 
586 typedef enum gscan_complete_event {
587 	WIFI_SCAN_COMPLETE,
588 	WIFI_SCAN_THRESHOLD_NUM_SCANS,
589 	WIFI_SCAN_BUFFER_THR_BREACHED
590 } gscan_complete_event_t;
591 
592 #ifdef DHD_WAKE_STATUS
593 enum wake_stat_attributes {
594 	WAKE_STAT_ATTRIBUTE_TOTAL_CMD_EVENT,
595 	WAKE_STAT_ATTRIBUTE_CMD_EVENT_WAKE,
596 	WAKE_STAT_ATTRIBUTE_CMD_EVENT_COUNT,
597 	WAKE_STAT_ATTRIBUTE_CMD_EVENT_COUNT_USED,
598 	WAKE_STAT_ATTRIBUTE_TOTAL_DRIVER_FW,
599 	WAKE_STAT_ATTRIBUTE_DRIVER_FW_WAKE,
600 	WAKE_STAT_ATTRIBUTE_DRIVER_FW_COUNT,
601 	WAKE_STAT_ATTRIBUTE_DRIVER_FW_COUNT_USED,
602 	WAKE_STAT_ATTRIBUTE_TOTAL_RX_DATA_WAKE,
603 	WAKE_STAT_ATTRIBUTE_RX_UNICAST_COUNT,
604 	WAKE_STAT_ATTRIBUTE_RX_MULTICAST_COUNT,
605 	WAKE_STAT_ATTRIBUTE_RX_BROADCAST_COUNT,
606 	WAKE_STAT_ATTRIBUTE_RX_ICMP_PKT,
607 	WAKE_STAT_ATTRIBUTE_RX_ICMP6_PKT,
608 	WAKE_STAT_ATTRIBUTE_RX_ICMP6_RA,
609 	WAKE_STAT_ATTRIBUTE_RX_ICMP6_NA,
610 	WAKE_STAT_ATTRIBUTE_RX_ICMP6_NS,
611 	WAKE_STAT_ATTRIBUTE_IPV4_RX_MULTICAST_ADD_CNT,
612 	WAKE_STAT_ATTRIBUTE_IPV6_RX_MULTICAST_ADD_CNT,
613 	WAKE_STAT_ATTRIBUTE_OTHER_RX_MULTICAST_ADD_CNT
614 };
615 
616 typedef struct rx_data_cnt_details_t {
617 	int rx_unicast_cnt;		/* Total rx unicast packet which woke up host */
618 	int rx_multicast_cnt;   /* Total rx multicast packet which woke up host */
619 	int rx_broadcast_cnt;   /* Total rx broadcast packet which woke up host */
620 } RX_DATA_WAKE_CNT_DETAILS;
621 
622 typedef struct rx_wake_pkt_type_classification_t {
623 	int icmp_pkt;   /* wake icmp packet count */
624 	int icmp6_pkt;  /* wake icmp6 packet count */
625 	int icmp6_ra;   /* wake icmp6 RA packet count */
626 	int icmp6_na;   /* wake icmp6 NA packet count */
627 	int icmp6_ns;   /* wake icmp6 NS packet count */
628 } RX_WAKE_PKT_TYPE_CLASSFICATION;
629 
630 typedef struct rx_multicast_cnt_t {
631 	int ipv4_rx_multicast_addr_cnt; /* Rx wake packet was ipv4 multicast */
632 	int ipv6_rx_multicast_addr_cnt; /* Rx wake packet was ipv6 multicast */
633 	int other_rx_multicast_addr_cnt; /* Rx wake packet was non-ipv4 and non-ipv6 */
634 } RX_MULTICAST_WAKE_DATA_CNT;
635 
636 typedef struct wlan_driver_wake_reason_cnt_t {
637 	int total_cmd_event_wake;    /* Total count of cmd event wakes */
638 	int *cmd_event_wake_cnt;     /* Individual wake count array, each index a reason */
639 	int cmd_event_wake_cnt_sz;   /* Max number of cmd event wake reasons */
640 	int cmd_event_wake_cnt_used; /* Number of cmd event wake reasons specific to the driver */
641 	int total_driver_fw_local_wake;    /* Total count of drive/fw wakes, for local reasons */
642 	int *driver_fw_local_wake_cnt;     /* Individual wake count array, each index a reason */
643 	int driver_fw_local_wake_cnt_sz;   /* Max number of local driver/fw wake reasons */
644 	/* Number of local driver/fw wake reasons specific to the driver */
645 	int driver_fw_local_wake_cnt_used;
646 	int total_rx_data_wake;     /* total data rx packets, that woke up host */
647 	RX_DATA_WAKE_CNT_DETAILS rx_wake_details;
648 	RX_WAKE_PKT_TYPE_CLASSFICATION rx_wake_pkt_classification_info;
649 	RX_MULTICAST_WAKE_DATA_CNT rx_multicast_wake_pkt_info;
650 } WLAN_DRIVER_WAKE_REASON_CNT;
651 #endif /* DHD_WAKE_STATUS */
652 
653 #ifdef WL_WIPSEVT
654 #define BRCM_VENDOR_WIPS_EVENT_BUF_LEN	128
655 typedef enum wl_vendor_wips_attr_type {
656 	WIPS_ATTR_DEAUTH_CNT = 1,
657 	WPPS_ATTR_DEAUTH_BSSID
658 } wl_vendor_wips_attr_type_t;
659 #endif /* WL_WIPSEVT  */
660 
661 /* Chipset roaming capabilities */
662 typedef struct wifi_roaming_capabilities {
663 	u32 max_blacklist_size;
664 	u32 max_whitelist_size;
665 } wifi_roaming_capabilities_t;
666 
667 /* sync-up return code with wifi_hal.h in wifi_hal layer. */
668 typedef enum {
669 	WIFI_SUCCESS = 0,
670 	WIFI_ERROR_NONE = 0,
671 	WIFI_ERROR_UNKNOWN = -1,
672 	WIFI_ERROR_UNINITIALIZED = -2,
673 	WIFI_ERROR_NOT_SUPPORTED = -3,
674 	WIFI_ERROR_NOT_AVAILABLE = -4,              /* Not available right now, but try later */
675 	WIFI_ERROR_INVALID_ARGS = -5,
676 	WIFI_ERROR_INVALID_REQUEST_ID = -6,
677 	WIFI_ERROR_TIMED_OUT = -7,
678 	WIFI_ERROR_TOO_MANY_REQUESTS = -8,          /* Too many instances of this request */
679 	WIFI_ERROR_OUT_OF_MEMORY = -9,
680 	WIFI_ERROR_BUSY = -10
681 } wifi_error;
682 
683 /* Capture the BRCM_VENDOR_SUBCMD_PRIV_STRINGS* here */
684 #define BRCM_VENDOR_SCMD_CAPA	"cap"
685 #define MEMDUMP_PATH_LEN	128
686 
687 #if (LINUX_VERSION_CODE > KERNEL_VERSION(3, 13, 0)) || defined(WL_VENDOR_EXT_SUPPORT)
688 extern int wl_cfgvendor_attach(struct wiphy *wiphy, dhd_pub_t *dhd);
689 extern int wl_cfgvendor_detach(struct wiphy *wiphy);
690 extern int wl_cfgvendor_send_async_event(struct wiphy *wiphy,
691                   struct net_device *dev, int event_id, const void  *data, int len);
692 extern int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
693                 struct net_device *dev, void  *data, int len, wl_vendor_event_t event);
694 #else
wl_cfgvendor_attach(struct wiphy * wiphy,dhd_pub_t * dhd)695 static INLINE int wl_cfgvendor_attach(struct wiphy *wiphy,
696 		dhd_pub_t *dhd) { UNUSED_PARAMETER(wiphy); UNUSED_PARAMETER(dhd); return 0; }
wl_cfgvendor_detach(struct wiphy * wiphy)697 static INLINE int wl_cfgvendor_detach(struct wiphy *wiphy) { UNUSED_PARAMETER(wiphy); return 0; }
wl_cfgvendor_send_async_event(struct wiphy * wiphy,struct net_device * dev,int event_id,const void * data,int len)698 static INLINE int wl_cfgvendor_send_async_event(struct wiphy *wiphy,
699                   struct net_device *dev, int event_id, const void  *data, int len)
700 { return 0; }
wl_cfgvendor_send_hotlist_event(struct wiphy * wiphy,struct net_device * dev,void * data,int len,wl_vendor_event_t event)701 static INLINE int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
702 	struct net_device *dev, void  *data, int len, wl_vendor_event_t event)
703 { return 0; }
704 #endif /*  (LINUX_VERSION_CODE > KERNEL_VERSION(3, 13, 0)) || defined(WL_VENDOR_EXT_SUPPORT) */
705 
706 #if defined(WL_SUPP_EVENT) && ((LINUX_VERSION_CODE > KERNEL_VERSION(3, 13, 0)) || \
707 	defined(WL_VENDOR_EXT_SUPPORT))
708 extern int wl_cfgvendor_send_supp_eventstring(const char *func, const char *fmt, ...);
709 int wl_cfgvendor_notify_supp_event_str(const char *evt_name, const char *fmt, ...);
710 #define SUPP_LOG_LEN 256
711 #define PRINT_SUPP_LOG(fmt, ...) \
712 	 wl_cfgvendor_send_supp_eventstring(__func__, fmt, ##__VA_ARGS__);
713 #define SUPP_LOG(args)  PRINT_SUPP_LOG  args;
714 #define SUPP_EVT_LOG(evt_name, fmt, ...) \
715     wl_cfgvendor_notify_supp_event_str(evt_name, fmt, ##__VA_ARGS__);
716 #define SUPP_EVENT(args) SUPP_EVT_LOG args
717 #else
718 #define SUPP_LOG(x)
719 #define SUPP_EVENT(x)
720 #endif /* WL_SUPP_EVENT && (kernel > (3, 13, 0)) || WL_VENDOR_EXT_SUPPORT */
721 
722 #define COMPAT_ASSIGN_VALUE(normal_structure, member, value) \
723 	normal_structure.member = value;
724 
725 #if (defined(CONFIG_ARCH_MSM) && defined(SUPPORT_WDEV_CFG80211_VENDOR_EVENT_ALLOC)) || \
726 	LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)
727 #define CFG80211_VENDOR_EVENT_ALLOC(wiphy, wdev, len, type, kflags) \
728 	cfg80211_vendor_event_alloc(wiphy, wdev, len, type, kflags);
729 #else
730 #define CFG80211_VENDOR_EVENT_ALLOC(wiphy, wdev, len, type, kflags) \
731 	cfg80211_vendor_event_alloc(wiphy, len, type, kflags);
732 #endif /* (defined(CONFIG_ARCH_MSM) && defined(SUPPORT_WDEV_CFG80211_VENDOR_EVENT_ALLOC)) || */
733 	/* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0) */
734 
735 #ifdef WL_CFGVENDOR_SEND_HANG_EVENT
736 void wl_cfgvendor_send_hang_event(struct net_device *dev, u16 reason,
737 	char *string, int hang_info_cnt);
738 void wl_copy_hang_info_if_falure(struct net_device *dev, u16 reason, s32 ret);
739 #endif /* WL_CFGVENDOR_SEND_HANG_EVENT */
740 #endif /* _wl_cfgvendor_h_ */
741