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