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