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