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