xref: /OK3568_Linux_fs/external/rkwifibt/drivers/bcmdhd/wl_cfgnan.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Neighbor Awareness Networking
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 #ifndef _wl_cfgnan_h_
25*4882a593Smuzhiyun #define _wl_cfgnan_h_
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun /* NAN structs versioning b/w DHD and HAL
28*4882a593Smuzhiyun * define new version if any change in any of the shared structs
29*4882a593Smuzhiyun */
30*4882a593Smuzhiyun #define NAN_HAL_VERSION_1	0x2
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #define NAN_EVENT_BUFFER_SIZE_LARGE	1024u
33*4882a593Smuzhiyun 
34*4882a593Smuzhiyun #define NAN_RANGE_EXT_CANCEL_SUPPORT_VER 2
35*4882a593Smuzhiyun #define WL_NAN_IOV_BATCH_VERSION	0x8000
36*4882a593Smuzhiyun #define WL_NAN_AVAIL_REPEAT_INTVL	0x0200
37*4882a593Smuzhiyun #define WL_NAN_AVAIL_START_INTVL	160
38*4882a593Smuzhiyun #define WL_NAN_AVAIL_DURATION_INTVL	336
39*4882a593Smuzhiyun #define NAN_IOCTL_BUF_SIZE		256u
40*4882a593Smuzhiyun #define NAN_IOCTL_BUF_SIZE_MED		512u
41*4882a593Smuzhiyun #define NAN_IOCTL_BUF_SIZE_LARGE	1024u
42*4882a593Smuzhiyun #define NAN_EVENT_NAME_MAX_LEN		40u
43*4882a593Smuzhiyun #define NAN_RTT_IOVAR_BUF_SIZE		1024u
44*4882a593Smuzhiyun #define WL_NAN_EVENT_CLEAR_BIT		32
45*4882a593Smuzhiyun #define NAN_EVENT_MASK_ALL			0x7fffffff
46*4882a593Smuzhiyun #define NAN_MAX_AWAKE_DW_INTERVAL	5
47*4882a593Smuzhiyun #define NAN_MAXIMUM_ID_NUMBER 255
48*4882a593Smuzhiyun #define NAN_MAXIMUM_MASTER_PREFERENCE 254
49*4882a593Smuzhiyun #define NAN_ID_RESERVED	0
50*4882a593Smuzhiyun #define NAN_ID_MIN	1
51*4882a593Smuzhiyun #define NAN_ID_MAX	255
52*4882a593Smuzhiyun #define NAN_DEF_SOCIAL_CHAN_2G	6
53*4882a593Smuzhiyun #define NAN_DEF_SOCIAL_CHAN_5G	149
54*4882a593Smuzhiyun #define NAN_DEF_SEC_SOCIAL_CHAN_5G	44
55*4882a593Smuzhiyun #define NAN_MAX_SOCIAL_CHANNELS	3
56*4882a593Smuzhiyun /* Keeping RSSI threshold value to be -70dBm */
57*4882a593Smuzhiyun #define NAN_DEF_RSSI_NOTIF_THRESH -70
58*4882a593Smuzhiyun /* Keeping default RSSI mid value to be -70dBm */
59*4882a593Smuzhiyun #define NAN_DEF_RSSI_MID -75
60*4882a593Smuzhiyun /* Keeping default RSSI close value to be -60dBm */
61*4882a593Smuzhiyun #define NAN_DEF_RSSI_CLOSE -60
62*4882a593Smuzhiyun #define WL_AVAIL_BIT_MAP	"1111111111111111111111111111111100000000000000000000000000000000"
63*4882a593Smuzhiyun #define WL_5G_AVAIL_BIT_MAP	"0000000011111111111111111111111111111111000000000000000000000000"
64*4882a593Smuzhiyun #define WL_AVAIL_CHANNEL_2G	6
65*4882a593Smuzhiyun #define WL_AVAIL_BANDWIDTH_2G	WL_CHANSPEC_BW_20
66*4882a593Smuzhiyun #define WL_AVAIL_CHANNEL_5G	149
67*4882a593Smuzhiyun #define WL_AVAIL_BANDWIDTH_5G	WL_CHANSPEC_BW_80
68*4882a593Smuzhiyun #define NAN_RANGING_PERIOD WL_AVAIL_PERIOD_1024
69*4882a593Smuzhiyun #define NAN_SYNC_DEF_AWAKE_DW	1
70*4882a593Smuzhiyun #define NAN_RNG_TERM_FLAG_NONE	0
71*4882a593Smuzhiyun 
72*4882a593Smuzhiyun #define NAN_BLOOM_LENGTH_DEFAULT        240u
73*4882a593Smuzhiyun #define NAN_SRF_MAX_MAC (NAN_BLOOM_LENGTH_DEFAULT / ETHER_ADDR_LEN)
74*4882a593Smuzhiyun #define NAN_SRF_CTRL_FIELD_LEN 1u
75*4882a593Smuzhiyun 
76*4882a593Smuzhiyun #define MAX_IF_ADD_WAIT_TIME	1000
77*4882a593Smuzhiyun #define NAN_DP_ROLE_INITIATOR  0x0001
78*4882a593Smuzhiyun #define NAN_DP_ROLE_RESPONDER  0x0002
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun #define WL_NAN_OBUF_DATA_OFFSET  (OFFSETOF(bcm_iov_batch_buf_t, cmds[0]) + \
81*4882a593Smuzhiyun 		OFFSETOF(bcm_iov_batch_subcmd_t, data[0]))
82*4882a593Smuzhiyun #define NAN_INVALID_ROLE(role)	(role > WL_NAN_ROLE_ANCHOR_MASTER)
83*4882a593Smuzhiyun #define NAN_INVALID_CHANSPEC(chanspec)	((chanspec == INVCHANSPEC) || \
84*4882a593Smuzhiyun 	(chanspec == 0))
85*4882a593Smuzhiyun #define NAN_INVALID_EVENT(num)	((num < WL_NAN_EVENT_START) || \
86*4882a593Smuzhiyun 	(num >= WL_NAN_EVENT_INVALID))
87*4882a593Smuzhiyun #define NAN_INVALID_PROXD_EVENT(num)	(num != WLC_E_PROXD_NAN_EVENT)
88*4882a593Smuzhiyun #define NAN_EVENT_BIT(event) (1U << (event - WL_NAN_EVENT_START))
89*4882a593Smuzhiyun #define NAN_EVENT_MAP(event) ((event) - WL_NAN_EVENT_START)
90*4882a593Smuzhiyun #define NAME_TO_STR(name) #name
91*4882a593Smuzhiyun #define NAN_ID_CTRL_SIZE ((NAN_MAXIMUM_ID_NUMBER/8) + 1)
92*4882a593Smuzhiyun 
93*4882a593Smuzhiyun #define tolower(c) bcm_tolower(c)
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun #define NMR2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5], (a)[6], (a)[7]
96*4882a593Smuzhiyun #define NMRSTR "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x"
97*4882a593Smuzhiyun 
98*4882a593Smuzhiyun #define NAN_DBG_ENTER() {WL_DBG(("Enter\n"));}
99*4882a593Smuzhiyun #define NAN_DBG_EXIT() {WL_DBG(("Exit\n"));}
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun /* Service Control Type length */
102*4882a593Smuzhiyun #define NAN_SVC_CONTROL_TYPE_MASK	((1 << NAN_SVC_CONTROL_TYPE_LEN) - 1)
103*4882a593Smuzhiyun 
104*4882a593Smuzhiyun #ifndef strtoul
105*4882a593Smuzhiyun #define strtoul(nptr, endptr, base) bcm_strtoul((nptr), (endptr), (base))
106*4882a593Smuzhiyun #endif
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun #define NAN_MAC_ADDR_LEN 6u
109*4882a593Smuzhiyun #define NAN_DP_MAX_APP_INFO_LEN	512u
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun #define NAN_SDE_CF_DP_REQUIRED      (1 << 2)
112*4882a593Smuzhiyun #define NAN_SDE_CF_DP_TYPE      (1 << 3)
113*4882a593Smuzhiyun #define NAN_SDE_CF_MULTICAST_TYPE   (1 << 4)
114*4882a593Smuzhiyun #define NAN_SDE_CF_SECURITY_REQUIRED    (1 << 6)
115*4882a593Smuzhiyun #define NAN_SDE_CF_RANGING_REQUIRED (1 << 7)
116*4882a593Smuzhiyun #define NAN_SDE_CF_RANGE_PRESENT    (1 << 8)
117*4882a593Smuzhiyun 
118*4882a593Smuzhiyun #define CHECK_BIT(m, n) ((m >> n) & 1)? 1 : 0
119*4882a593Smuzhiyun #define WL_NAN_EVENT_DIC_MAC_ADDR_BIT	0
120*4882a593Smuzhiyun #define WL_NAN_EVENT_START_EVENT	1
121*4882a593Smuzhiyun #define WL_NAN_EVENT_JOIN_EVENT		2
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun /* Disabling svc specific(as per part of sub & pub calls) events based on below bits */
124*4882a593Smuzhiyun #define WL_NAN_EVENT_SUPPRESS_TERMINATE_BIT	0
125*4882a593Smuzhiyun #define WL_NAN_EVENT_SUPPRESS_MATCH_EXP_BIT	1
126*4882a593Smuzhiyun #define WL_NAN_EVENT_SUPPRESS_RECEIVE_BIT	2
127*4882a593Smuzhiyun #define WL_NAN_EVENT_SUPPRESS_REPLIED_BIT	3
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun /* Disabling tranmsit followup events based on below bit */
130*4882a593Smuzhiyun #define WL_NAN_EVENT_SUPPRESS_FOLLOWUP_RECEIVE_BIT	0
131*4882a593Smuzhiyun 
132*4882a593Smuzhiyun #define C2S(x)  case x: id2str = #x
133*4882a593Smuzhiyun #define NAN_BLOOM_LENGTH_DEFAULT	240u
134*4882a593Smuzhiyun #define NAN_SRF_MAX_MAC			(NAN_BLOOM_LENGTH_DEFAULT / ETHER_ADDR_LEN)
135*4882a593Smuzhiyun #define NAN_MAX_PMK_LEN			32u
136*4882a593Smuzhiyun #define NAN_ERROR_STR_LEN		255u
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun /* NAN related Capabilities */
139*4882a593Smuzhiyun #define MAX_CONCURRENT_NAN_CLUSTERS		1u
140*4882a593Smuzhiyun #define MAX_PUBLISHES				8u
141*4882a593Smuzhiyun #define MAX_SUBSCRIBES				8u
142*4882a593Smuzhiyun #define MAX_SVC_NAME_LEN			255u
143*4882a593Smuzhiyun #define MAX_MATCH_FILTER_LEN			255u
144*4882a593Smuzhiyun #define MAX_TOTAL_MATCH_FILTER_LEN		510u
145*4882a593Smuzhiyun #define	NAN_MAX_SERVICE_SPECIFIC_INFO_LEN	255u
146*4882a593Smuzhiyun #define NAN_MAX_NDI				3u
147*4882a593Smuzhiyun #define MAX_NDP_SESSIONS			5u
148*4882a593Smuzhiyun #define MAX_APP_INFO_LEN			255u
149*4882a593Smuzhiyun #define	MAX_QUEUED_TX_FOLLOUP_MSGS		10u
150*4882a593Smuzhiyun #define	MAX_SDEA_SVC_INFO_LEN			255u
151*4882a593Smuzhiyun #define	MAX_SUBSCRIBE_ADDRESS			10u
152*4882a593Smuzhiyun #define	CIPHER_SUITE_SUPPORTED			1u
153*4882a593Smuzhiyun #define	MAX_SCID_LEN				0u
154*4882a593Smuzhiyun #define	IS_NDP_SECURITY_SUPPORTED		true
155*4882a593Smuzhiyun #define	NDP_SUPPORTED_BANDS			2u
156*4882a593Smuzhiyun #define NAN_MAX_RANGING_INST			8u
157*4882a593Smuzhiyun #define NAN_MAX_RANGING_SSN_ALLOWED		1u
158*4882a593Smuzhiyun #define NAN_MAX_SVC_INST			(MAX_PUBLISHES + MAX_SUBSCRIBES)
159*4882a593Smuzhiyun #define NAN_SVC_INST_SIZE			32u
160*4882a593Smuzhiyun #define NAN_START_STOP_TIMEOUT			5000u
161*4882a593Smuzhiyun #define NAN_MAX_NDP_PEER			8u
162*4882a593Smuzhiyun #define NAN_DISABLE_CMD_DELAY			530u
163*4882a593Smuzhiyun #define NAN_WAKELOCK_TIMEOUT			(NAN_DISABLE_CMD_DELAY + 100u)
164*4882a593Smuzhiyun 
165*4882a593Smuzhiyun #define NAN_NMI_RAND_PVT_CMD_VENDOR		(1 << 31)
166*4882a593Smuzhiyun #define NAN_NMI_RAND_CLUSTER_MERGE_ENAB		(1 << 30)
167*4882a593Smuzhiyun #define NAN_NMI_RAND_AUTODAM_LWT_MODE_ENAB	(1 << 29)
168*4882a593Smuzhiyun 
169*4882a593Smuzhiyun #ifdef WL_NAN_DEBUG
170*4882a593Smuzhiyun #define NAN_MUTEX_LOCK() {WL_DBG(("Mutex Lock: Enter: %s\n", __FUNCTION__)); \
171*4882a593Smuzhiyun 	mutex_lock(&cfg->nancfg->nan_sync);}
172*4882a593Smuzhiyun #define NAN_MUTEX_UNLOCK() {mutex_unlock(&cfg->nancfg->nan_sync); \
173*4882a593Smuzhiyun 	WL_DBG(("Mutex Unlock: Exit: %s\n", __FUNCTION__));}
174*4882a593Smuzhiyun #else
175*4882a593Smuzhiyun #define NAN_MUTEX_LOCK() {mutex_lock(&cfg->nancfg->nan_sync);}
176*4882a593Smuzhiyun #define NAN_MUTEX_UNLOCK() {mutex_unlock(&cfg->nancfg->nan_sync);}
177*4882a593Smuzhiyun #endif /* WL_NAN_DEBUG */
178*4882a593Smuzhiyun #define	NAN_ATTR_SUPPORT_2G_CONFIG		(1<<0)
179*4882a593Smuzhiyun #define	NAN_ATTR_SYNC_DISC_2G_BEACON_CONFIG	(1<<1)
180*4882a593Smuzhiyun #define	NAN_ATTR_SDF_2G_SUPPORT_CONFIG		(1<<2)
181*4882a593Smuzhiyun #define	NAN_ATTR_SUPPORT_5G_CONFIG		(1<<3)
182*4882a593Smuzhiyun #define	NAN_ATTR_SYNC_DISC_5G_BEACON_CONFIG	(1<<4)
183*4882a593Smuzhiyun #define	NAN_ATTR_SDF_5G_SUPPORT_CONFIG		(1<<5)
184*4882a593Smuzhiyun #define	NAN_ATTR_2G_DW_CONFIG			(1<<6)
185*4882a593Smuzhiyun #define	NAN_ATTR_5G_DW_CONFIG			(1<<7)
186*4882a593Smuzhiyun #define	NAN_ATTR_2G_CHAN_CONFIG			(1<<8)
187*4882a593Smuzhiyun #define	NAN_ATTR_5G_CHAN_CONFIG			(1<<9)
188*4882a593Smuzhiyun #define	NAN_ATTR_2G_DWELL_TIME_CONFIG		(1<<10)
189*4882a593Smuzhiyun #define	NAN_ATTR_5G_DWELL_TIME_CONFIG		(1<<11)
190*4882a593Smuzhiyun #define	NAN_ATTR_2G_SCAN_PERIOD_CONFIG		(1<<12)
191*4882a593Smuzhiyun #define	NAN_ATTR_5G_SCAN_PERIOD_CONFIG		(1<<13)
192*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_CLOSE_CONFIG		(1<<14)
193*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_MIDDLE_2G_CONFIG		(1<<15)
194*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_PROXIMITY_2G_CONFIG	(1<<16)
195*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_CLOSE_5G_CONFIG		(1<<17)
196*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_MIDDLE_5G_CONFIG		(1<<18)
197*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_PROXIMITY_5G_CONFIG	(1<<19)
198*4882a593Smuzhiyun #define	NAN_ATTR_RSSI_WINDOW_SIZE_CONFIG	(1<<20)
199*4882a593Smuzhiyun #define	NAN_ATTR_HOP_COUNT_LIMIT_CONFIG		(1<<21)
200*4882a593Smuzhiyun #define	NAN_ATTR_SID_BEACON_CONFIG		(1<<22)
201*4882a593Smuzhiyun #define	NAN_ATTR_HOP_COUNT_FORCE_CONFIG		(1<<23)
202*4882a593Smuzhiyun #define	NAN_ATTR_RAND_FACTOR_CONFIG		(1<<24)
203*4882a593Smuzhiyun #define	NAN_ATTR_CLUSTER_VAL_CONFIG		(1<<25)
204*4882a593Smuzhiyun #define	NAN_ATTR_IF_ADDR_CONFIG			(1<<26)
205*4882a593Smuzhiyun #define	NAN_ATTR_OUI_CONFIG			(1<<27)
206*4882a593Smuzhiyun #define	NAN_ATTR_SUB_SID_BEACON_CONFIG		(1<<28)
207*4882a593Smuzhiyun #define NAN_ATTR_DISC_BEACON_INTERVAL		(1<<29)
208*4882a593Smuzhiyun #define NAN_IOVAR_NAME_SIZE	4u
209*4882a593Smuzhiyun #define NAN_XTLV_ID_LEN_SIZE OFFSETOF(bcm_xtlv_t, data)
210*4882a593Smuzhiyun #define NAN_RANGING_INDICATE_CONTINUOUS_MASK   0x01
211*4882a593Smuzhiyun #define NAN_RANGE_REQ_CMD 0
212*4882a593Smuzhiyun #define NAN_RNG_REQ_ACCEPTED_BY_HOST    1
213*4882a593Smuzhiyun #define NAN_RNG_REQ_REJECTED_BY_HOST    0
214*4882a593Smuzhiyun 
215*4882a593Smuzhiyun #define NAN_RNG_REQ_ACCEPTED_BY_PEER	0
216*4882a593Smuzhiyun #define NAN_RNG_REQ_REJECTED_BY_PEER	1
217*4882a593Smuzhiyun 
218*4882a593Smuzhiyun #define NAN_RNG_GEOFENCE_MAX_RETRY_CNT	3u
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun #define NAN_MAX_CHANNEL_INFO_SUPPORTED	4u
221*4882a593Smuzhiyun /*
222*4882a593Smuzhiyun * Discovery Beacon Interval config,
223*4882a593Smuzhiyun * Default value is 128 msec in 2G DW and 176 msec in 2G/5G DW.
224*4882a593Smuzhiyun */
225*4882a593Smuzhiyun #define NAN_DISC_BCN_INTERVAL_2G_DEF 128u
226*4882a593Smuzhiyun #define NAN_DISC_BCN_INTERVAL_5G_DEF 176u
227*4882a593Smuzhiyun 
228*4882a593Smuzhiyun typedef uint32 nan_data_path_id;
229*4882a593Smuzhiyun 
230*4882a593Smuzhiyun typedef enum nan_range_status {
231*4882a593Smuzhiyun 	NAN_RANGING_INVALID = 0,
232*4882a593Smuzhiyun 	NAN_RANGING_REQUIRED = 1,
233*4882a593Smuzhiyun 	NAN_RANGING_SETUP_IN_PROGRESS = 2,
234*4882a593Smuzhiyun 	NAN_RANGING_SESSION_IN_PROGRESS = 3
235*4882a593Smuzhiyun } nan_range_status_t;
236*4882a593Smuzhiyun 
237*4882a593Smuzhiyun typedef enum nan_range_role {
238*4882a593Smuzhiyun 	NAN_RANGING_ROLE_INVALID = 0,
239*4882a593Smuzhiyun 	NAN_RANGING_ROLE_INITIATOR = 1,
240*4882a593Smuzhiyun 	NAN_RANGING_ROLE_RESPONDER = 2
241*4882a593Smuzhiyun } nan_range_role_t;
242*4882a593Smuzhiyun 
243*4882a593Smuzhiyun typedef struct nan_svc_inst {
244*4882a593Smuzhiyun 	uint8  inst_id;      /* publisher/subscriber id */
245*4882a593Smuzhiyun 	uint8  inst_type;    /* publisher/subscriber */
246*4882a593Smuzhiyun } nan_svc_inst_t;
247*4882a593Smuzhiyun 
248*4882a593Smuzhiyun /* Range Status Flag bits for svc info */
249*4882a593Smuzhiyun #define SVC_RANGE_REP_EVENT_ONCE 0x01
250*4882a593Smuzhiyun 
251*4882a593Smuzhiyun /* Range Status Flag bits for svc info */
252*4882a593Smuzhiyun #define SVC_RANGE_REP_EVENT_ONCE 0x01
253*4882a593Smuzhiyun 
254*4882a593Smuzhiyun #define NAN_RANGING_SETUP_IS_IN_PROG(status) \
255*4882a593Smuzhiyun 	((status) == NAN_RANGING_SETUP_IN_PROGRESS)
256*4882a593Smuzhiyun 
257*4882a593Smuzhiyun #define NAN_RANGING_IS_IN_PROG(status) \
258*4882a593Smuzhiyun 	(((status) == NAN_RANGING_SETUP_IN_PROGRESS) || \
259*4882a593Smuzhiyun 	((status) == NAN_RANGING_SESSION_IN_PROGRESS))
260*4882a593Smuzhiyun 
261*4882a593Smuzhiyun typedef struct nan_svc_info {
262*4882a593Smuzhiyun 	bool valid;
263*4882a593Smuzhiyun 	nan_data_path_id ndp_id[NAN_MAX_SVC_INST];
264*4882a593Smuzhiyun 	uint8 svc_hash[WL_NAN_SVC_HASH_LEN];        /* service hash */
265*4882a593Smuzhiyun 	uint8 svc_id;
266*4882a593Smuzhiyun 	uint8 ranging_required;
267*4882a593Smuzhiyun 	uint8 ranging_ind;
268*4882a593Smuzhiyun 	uint8 status;
269*4882a593Smuzhiyun 	uint32 ranging_interval;
270*4882a593Smuzhiyun 	uint32 ingress_limit;
271*4882a593Smuzhiyun 	uint32 egress_limit;
272*4882a593Smuzhiyun 	uint32 flags;
273*4882a593Smuzhiyun 	uint8 tx_match_filter[MAX_MATCH_FILTER_LEN];        /* TX match filter */
274*4882a593Smuzhiyun 	uint8 tx_match_filter_len;
275*4882a593Smuzhiyun 	uint8 svc_range_status; /* For managing any svc range status flags */
276*4882a593Smuzhiyun } nan_svc_info_t;
277*4882a593Smuzhiyun 
278*4882a593Smuzhiyun /* NAN Peer DP state */
279*4882a593Smuzhiyun typedef enum {
280*4882a593Smuzhiyun 	NAN_PEER_DP_NOT_CONNECTED = 0,
281*4882a593Smuzhiyun 	NAN_PEER_DP_CONNECTING = 1,
282*4882a593Smuzhiyun 	NAN_PEER_DP_CONNECTED = 2
283*4882a593Smuzhiyun } nan_peer_dp_state_t;
284*4882a593Smuzhiyun 
285*4882a593Smuzhiyun typedef struct nan_ndp_peer {
286*4882a593Smuzhiyun 	uint8 peer_dp_state;
287*4882a593Smuzhiyun 	uint8 dp_count;
288*4882a593Smuzhiyun 	struct ether_addr peer_addr;
289*4882a593Smuzhiyun } nan_ndp_peer_t;
290*4882a593Smuzhiyun 
291*4882a593Smuzhiyun #define INVALID_DISTANCE		0xFFFFFFFF
292*4882a593Smuzhiyun #define NAN_RTT_FTM_SSN_RETRIES		2
293*4882a593Smuzhiyun 
294*4882a593Smuzhiyun typedef struct nan_ranging_inst {
295*4882a593Smuzhiyun 	uint8 range_id;
296*4882a593Smuzhiyun 	nan_range_status_t range_status;
297*4882a593Smuzhiyun 	struct ether_addr peer_addr;
298*4882a593Smuzhiyun 	int range_type;
299*4882a593Smuzhiyun 	uint8 num_svc_ctx;
300*4882a593Smuzhiyun 	nan_svc_info_t *svc_idx[MAX_SUBSCRIBES];
301*4882a593Smuzhiyun 	uint32 prev_distance_mm;
302*4882a593Smuzhiyun 	nan_range_role_t range_role;
303*4882a593Smuzhiyun 	bool in_use;
304*4882a593Smuzhiyun 	uint8 geof_retry_count;
305*4882a593Smuzhiyun 	uint8 ftm_ssn_retry_count;
306*4882a593Smuzhiyun 	bool role_concurrency_status;
307*4882a593Smuzhiyun } nan_ranging_inst_t;
308*4882a593Smuzhiyun 
309*4882a593Smuzhiyun #define DUMP_NAN_RTT_INST(inst) { printf("svc instance ID %d", (inst)->svc_inst_id); \
310*4882a593Smuzhiyun 	printf("Range ID %d", (inst)->range_id); \
311*4882a593Smuzhiyun 	printf("range_status %d", (inst)->range_status); \
312*4882a593Smuzhiyun 	printf("Range Type %d", (inst)->range_type); \
313*4882a593Smuzhiyun 	printf("Peer MAC "MACDBG"\n", MAC2STRDBG((inst)->peer_addr.octet)); \
314*4882a593Smuzhiyun 	}
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun #define DUMP_NAN_RTT_RPT(rpt) { printf("Range ID %d", (rpt)->rng_id); \
317*4882a593Smuzhiyun 	printf("Distance in MM %d", (rpt)->dist_mm); \
318*4882a593Smuzhiyun 	printf("range_indication %d", (rpt)->indication); \
319*4882a593Smuzhiyun 	printf("Peer MAC "MACDBG"\n", MAC2STRDBG((rpt)->peer_m_addr.octet)); \
320*4882a593Smuzhiyun 	}
321*4882a593Smuzhiyun /*
322*4882a593Smuzhiyun  * Data request Initiator/Responder
323*4882a593Smuzhiyun  * app/service related info
324*4882a593Smuzhiyun  */
325*4882a593Smuzhiyun typedef struct nan_data_path_app_info {
326*4882a593Smuzhiyun 	uint16 ndp_app_info_len;
327*4882a593Smuzhiyun 	uint8 ndp_app_info[NAN_DP_MAX_APP_INFO_LEN];
328*4882a593Smuzhiyun } nan_data_path_app_info_t;
329*4882a593Smuzhiyun 
330*4882a593Smuzhiyun /* QoS configuration */
331*4882a593Smuzhiyun typedef enum {
332*4882a593Smuzhiyun 	NAN_DP_CONFIG_NO_QOS = 0,
333*4882a593Smuzhiyun 	NAN_DP_CONFIG_QOS
334*4882a593Smuzhiyun } nan_data_path_qos_cfg_t;
335*4882a593Smuzhiyun 
336*4882a593Smuzhiyun /* Data request Responder's response */
337*4882a593Smuzhiyun typedef enum {
338*4882a593Smuzhiyun 	NAN_DP_REQUEST_ACCEPT = 0,
339*4882a593Smuzhiyun 	NAN_DP_REQUEST_REJECT
340*4882a593Smuzhiyun } nan_data_path_response_code_t;
341*4882a593Smuzhiyun 
342*4882a593Smuzhiyun /* NAN DP security Configuration */
343*4882a593Smuzhiyun typedef enum {
344*4882a593Smuzhiyun 	NAN_DP_CONFIG_NO_SECURITY = 0,
345*4882a593Smuzhiyun 	NAN_DP_CONFIG_SECURITY
346*4882a593Smuzhiyun } nan_data_path_security_cfg_status_t;
347*4882a593Smuzhiyun 
348*4882a593Smuzhiyun /* NAN Security Key Input Type */
349*4882a593Smuzhiyun typedef enum {
350*4882a593Smuzhiyun 	NAN_SECURITY_KEY_INPUT_PMK = 1,
351*4882a593Smuzhiyun 	NAN_SECURITY_KEY_INPUT_PASSPHRASE
352*4882a593Smuzhiyun } nan_security_key_input_type;
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun /* Configuration params of Data request Initiator/Responder */
355*4882a593Smuzhiyun typedef struct nan_data_path_cfg {
356*4882a593Smuzhiyun 	/* Status Indicating Security/No Security */
357*4882a593Smuzhiyun 	nan_data_path_security_cfg_status_t security_cfg;
358*4882a593Smuzhiyun 	nan_data_path_qos_cfg_t qos_cfg;
359*4882a593Smuzhiyun } nan_data_path_cfg_t;
360*4882a593Smuzhiyun 
361*4882a593Smuzhiyun enum nan_dp_states {
362*4882a593Smuzhiyun 	NAN_DP_STATE_DISABLED = 0,
363*4882a593Smuzhiyun 	NAN_DP_STATE_ENABLED = 1
364*4882a593Smuzhiyun };
365*4882a593Smuzhiyun 
366*4882a593Smuzhiyun enum {
367*4882a593Smuzhiyun 	SRF_TYPE_BLOOM_FILTER = 0,
368*4882a593Smuzhiyun 	SRF_TYPE_SEQ_MAC_ADDR = 1
369*4882a593Smuzhiyun };
370*4882a593Smuzhiyun 
371*4882a593Smuzhiyun /* NAN Match indication type */
372*4882a593Smuzhiyun typedef enum {
373*4882a593Smuzhiyun     NAN_MATCH_ALG_MATCH_ONCE		= 0,
374*4882a593Smuzhiyun     NAN_MATCH_ALG_MATCH_CONTINUOUS	= 1,
375*4882a593Smuzhiyun     NAN_MATCH_ALG_MATCH_NEVER		= 2
376*4882a593Smuzhiyun } nan_match_alg;
377*4882a593Smuzhiyun 
378*4882a593Smuzhiyun typedef struct nan_str_data {
379*4882a593Smuzhiyun 	uint32 dlen;
380*4882a593Smuzhiyun 	uint8 *data;
381*4882a593Smuzhiyun } nan_str_data_t;
382*4882a593Smuzhiyun 
383*4882a593Smuzhiyun typedef struct nan_mac_list {
384*4882a593Smuzhiyun 	uint32 num_mac_addr;
385*4882a593Smuzhiyun 	uint8 *list;
386*4882a593Smuzhiyun } nan_mac_list_t;
387*4882a593Smuzhiyun 
388*4882a593Smuzhiyun typedef struct nan_channel_info {
389*4882a593Smuzhiyun 	uint32 channel;
390*4882a593Smuzhiyun 	uint32 bandwidth;
391*4882a593Smuzhiyun 	uint32 nss;
392*4882a593Smuzhiyun } nan_channel_info_t;
393*4882a593Smuzhiyun 
394*4882a593Smuzhiyun typedef struct nan_ndl_sched_info {
395*4882a593Smuzhiyun 	uint32 num_channels;
396*4882a593Smuzhiyun 	nan_channel_info_t channel_info[NAN_MAX_CHANNEL_INFO_SUPPORTED];
397*4882a593Smuzhiyun } nan_ndl_sched_info_t;
398*4882a593Smuzhiyun 
399*4882a593Smuzhiyun typedef struct wl_nan_sid_beacon_tune {
400*4882a593Smuzhiyun 	uint8 sid_enable;	/* flag for sending service id in beacon */
401*4882a593Smuzhiyun 	uint8 sid_count;	/* Limit for number of SIDs to be included in Beacons */
402*4882a593Smuzhiyun 	uint8 sub_sid_enable;	/* flag for sending subscribe service id in beacon */
403*4882a593Smuzhiyun 	uint8 sub_sid_count;	/* Limit for number of SUb SIDs to be included in Beacons */
404*4882a593Smuzhiyun } wl_nan_sid_beacon_ctrl_t;
405*4882a593Smuzhiyun 
406*4882a593Smuzhiyun typedef struct nan_avail_cmd_data {
407*4882a593Smuzhiyun 	chanspec_t chanspec[NAN_MAX_SOCIAL_CHANNELS];    /* channel */
408*4882a593Smuzhiyun 	uint32 bmap;            /* bitmap */
409*4882a593Smuzhiyun 	uint8 duration;
410*4882a593Smuzhiyun 	uint8 avail_period;
411*4882a593Smuzhiyun 	/* peer mac address reqd for ranging avail type */
412*4882a593Smuzhiyun 	struct ether_addr peer_nmi;
413*4882a593Smuzhiyun 	bool no_config_avail;
414*4882a593Smuzhiyun } nan_avail_cmd_data;
415*4882a593Smuzhiyun 
416*4882a593Smuzhiyun typedef struct nan_discover_cmd_data {
417*4882a593Smuzhiyun 	nan_str_data_t svc_info;        /* service information */
418*4882a593Smuzhiyun 	nan_str_data_t sde_svc_info;	/* extended service information */
419*4882a593Smuzhiyun 	nan_str_data_t svc_hash;        /* service hash */
420*4882a593Smuzhiyun 	nan_str_data_t rx_match;        /* matching filter rx */
421*4882a593Smuzhiyun 	nan_str_data_t tx_match;        /* matching filter tx */
422*4882a593Smuzhiyun 	nan_str_data_t key;        /* Security key information */
423*4882a593Smuzhiyun 	nan_str_data_t scid;        /* security context information */
424*4882a593Smuzhiyun 	nan_data_path_cfg_t ndp_cfg;
425*4882a593Smuzhiyun 	struct ether_addr mac_addr;     /* mac address */
426*4882a593Smuzhiyun 	nan_mac_list_t mac_list;   /* mac list */
427*4882a593Smuzhiyun 	wl_nan_instance_id_t pub_id;    /* publisher id */
428*4882a593Smuzhiyun 	wl_nan_instance_id_t sub_id;    /* subscriber id */
429*4882a593Smuzhiyun 	wl_nan_instance_id_t local_id;  /* Local id */
430*4882a593Smuzhiyun 	wl_nan_instance_id_t remote_id; /* Remote id */
431*4882a593Smuzhiyun 	uint32 status;
432*4882a593Smuzhiyun 	uint32 ttl;             /* time to live */
433*4882a593Smuzhiyun 	uint32 period;          /* publish period */
434*4882a593Smuzhiyun 	uint32 flags;           /* Flag bits */
435*4882a593Smuzhiyun 	bool sde_control_config; /* whether sde_control present */
436*4882a593Smuzhiyun 	uint16 sde_control_flag;
437*4882a593Smuzhiyun 	uint16 token; /* transmit fup token id */
438*4882a593Smuzhiyun 	uint8 csid;	/* cipher suite type */
439*4882a593Smuzhiyun 	nan_security_key_input_type key_type;	/* cipher suite type */
440*4882a593Smuzhiyun 	uint8 priority;         /* Priority of Transmit */
441*4882a593Smuzhiyun 	uint8 life_count;       /* life count of the instance */
442*4882a593Smuzhiyun 	uint8 srf_type;         /* SRF type */
443*4882a593Smuzhiyun 	uint8 srf_include;      /* SRF include */
444*4882a593Smuzhiyun 	uint8 use_srf;          /* use SRF */
445*4882a593Smuzhiyun 	uint8 recv_ind_flag;    /* Receive Indication Flag */
446*4882a593Smuzhiyun 	uint8 disc_ind_cfg;	/* Discovery Ind cfg */
447*4882a593Smuzhiyun 	uint8 ranging_indication;
448*4882a593Smuzhiyun 	uint32 ranging_intvl_msec; /* ranging interval in msec */
449*4882a593Smuzhiyun 	uint32 ingress_limit;
450*4882a593Smuzhiyun 	uint32 egress_limit;
451*4882a593Smuzhiyun 	bool response;
452*4882a593Smuzhiyun 	uint8 service_responder_policy;
453*4882a593Smuzhiyun 	bool svc_update;
454*4882a593Smuzhiyun } nan_discover_cmd_data_t;
455*4882a593Smuzhiyun 
456*4882a593Smuzhiyun typedef struct nan_datapath_cmd_data {
457*4882a593Smuzhiyun 	nan_avail_cmd_data avail_params;	/* Avail config params */
458*4882a593Smuzhiyun 	nan_str_data_t svc_hash;        /* service hash */
459*4882a593Smuzhiyun 	nan_str_data_t svc_info;        /* service information */
460*4882a593Smuzhiyun 	nan_str_data_t key;        /* security key information */
461*4882a593Smuzhiyun 	nan_data_path_response_code_t rsp_code;
462*4882a593Smuzhiyun 	nan_data_path_id ndp_instance_id;
463*4882a593Smuzhiyun 	nan_data_path_cfg_t ndp_cfg;
464*4882a593Smuzhiyun 	wl_nan_instance_id_t pub_id;    /* publisher id */
465*4882a593Smuzhiyun 	nan_security_key_input_type key_type;	/* cipher suite type */
466*4882a593Smuzhiyun 	struct ether_addr if_addr;      /* if addr */
467*4882a593Smuzhiyun 	struct ether_addr mac_addr;     /* mac address */
468*4882a593Smuzhiyun 	chanspec_t chanspec[NAN_MAX_SOCIAL_CHANNELS];    /* channel */
469*4882a593Smuzhiyun 	uint32 status;
470*4882a593Smuzhiyun 	uint32 bmap;            /* bitmap */
471*4882a593Smuzhiyun 	uint16 service_instance_id;
472*4882a593Smuzhiyun 	uint16 sde_control_flag;
473*4882a593Smuzhiyun 	uint8 csid;	/* cipher suite type */
474*4882a593Smuzhiyun 	uint8 peer_disc_mac_addr[ETHER_ADDR_LEN];
475*4882a593Smuzhiyun 	uint8 peer_ndi_mac_addr[ETHER_ADDR_LEN];
476*4882a593Smuzhiyun 	uint8 num_ndp_instances;
477*4882a593Smuzhiyun 	uint8 duration;
478*4882a593Smuzhiyun 	char ndp_iface[IFNAMSIZ+1];
479*4882a593Smuzhiyun } nan_datapath_cmd_data_t;
480*4882a593Smuzhiyun 
481*4882a593Smuzhiyun typedef struct nan_rssi_cmd_data {
482*4882a593Smuzhiyun 	int8 rssi_middle_2dot4g_val;
483*4882a593Smuzhiyun 	int8 rssi_close_2dot4g_val;
484*4882a593Smuzhiyun 	int8 rssi_proximity_2dot4g_val;
485*4882a593Smuzhiyun 	int8 rssi_proximity_5g_val;
486*4882a593Smuzhiyun 	int8 rssi_middle_5g_val;
487*4882a593Smuzhiyun 	int8 rssi_close_5g_val;
488*4882a593Smuzhiyun 	uint16 rssi_window_size; /* Window size over which rssi calculated */
489*4882a593Smuzhiyun } nan_rssi_cmd_data_t;
490*4882a593Smuzhiyun 
491*4882a593Smuzhiyun typedef struct election_metrics {
492*4882a593Smuzhiyun 	uint8 random_factor;    /* Configured random factor */
493*4882a593Smuzhiyun 	uint8 master_pref;     /* configured master preference */
494*4882a593Smuzhiyun } election_metrics_t;
495*4882a593Smuzhiyun 
496*4882a593Smuzhiyun typedef struct nan_awake_dws {
497*4882a593Smuzhiyun 	uint8 dw_interval_2g;   /* 2G DW interval */
498*4882a593Smuzhiyun 	uint8 dw_interval_5g;   /* 5G DW interval */
499*4882a593Smuzhiyun } nan_awake_dws_t;
500*4882a593Smuzhiyun 
501*4882a593Smuzhiyun typedef struct nan_config_cmd_data {
502*4882a593Smuzhiyun 	nan_rssi_cmd_data_t rssi_attr;	/* RSSI related data */
503*4882a593Smuzhiyun 	election_metrics_t metrics;
504*4882a593Smuzhiyun 	nan_awake_dws_t awake_dws;	/* Awake DWs */
505*4882a593Smuzhiyun 	nan_avail_cmd_data avail_params;	/* Avail config params */
506*4882a593Smuzhiyun 	nan_str_data_t p2p_info;        /* p2p information */
507*4882a593Smuzhiyun 	nan_str_data_t scid;        /* security context information */
508*4882a593Smuzhiyun 	struct ether_addr clus_id;      /* cluster id */
509*4882a593Smuzhiyun 	struct ether_addr mac_addr;     /* mac address */
510*4882a593Smuzhiyun 	wl_nan_sid_beacon_ctrl_t sid_beacon;    /* sending service id in beacon */
511*4882a593Smuzhiyun 	chanspec_t chanspec[NAN_MAX_SOCIAL_CHANNELS];    /* channel */
512*4882a593Smuzhiyun 	uint32 status;
513*4882a593Smuzhiyun 	uint32 bmap;            /* bitmap */
514*4882a593Smuzhiyun 	uint32 nan_oui;         /* configured nan oui */
515*4882a593Smuzhiyun 	uint32 warmup_time;     /* Warm up time */
516*4882a593Smuzhiyun 	uint8 duration;
517*4882a593Smuzhiyun 	uint8 hop_count_limit;  /* hop count limit */
518*4882a593Smuzhiyun 	uint8 support_5g;       /* To decide dual band support */
519*4882a593Smuzhiyun 	uint8 support_2g;       /* To decide dual band support */
520*4882a593Smuzhiyun 	uint8 beacon_2g_val;
521*4882a593Smuzhiyun 	uint8 beacon_5g_val;
522*4882a593Smuzhiyun 	uint8 sdf_2g_val;
523*4882a593Smuzhiyun 	uint8 sdf_5g_val;
524*4882a593Smuzhiyun 	uint8 dwell_time[NAN_MAX_SOCIAL_CHANNELS];
525*4882a593Smuzhiyun 	uint8 scan_period[NAN_MAX_SOCIAL_CHANNELS];
526*4882a593Smuzhiyun 	uint8 config_cluster_val;
527*4882a593Smuzhiyun 	uint8 disc_ind_cfg;	/* Discovery Ind cfg */
528*4882a593Smuzhiyun 	uint8 csid;	/* cipher suite type */
529*4882a593Smuzhiyun 	uint32 nmi_rand_intvl; /* nmi randomization interval */
530*4882a593Smuzhiyun 	uint32 use_ndpe_attr;
531*4882a593Smuzhiyun 	uint8 enable_merge;
532*4882a593Smuzhiyun 	uint16 cluster_low;
533*4882a593Smuzhiyun 	uint16 cluster_high;
534*4882a593Smuzhiyun 	wl_nan_disc_bcn_interval_t disc_bcn_interval;
535*4882a593Smuzhiyun 	uint32 dw_early_termination;
536*4882a593Smuzhiyun } nan_config_cmd_data_t;
537*4882a593Smuzhiyun 
538*4882a593Smuzhiyun typedef struct nan_event_hdr {
539*4882a593Smuzhiyun 	uint32 flags;							/* future use */
540*4882a593Smuzhiyun 	uint16 event_subtype;
541*4882a593Smuzhiyun } nan_event_hdr_t;
542*4882a593Smuzhiyun 
543*4882a593Smuzhiyun typedef struct nan_event_data {
544*4882a593Smuzhiyun 	uint8 svc_name[WL_NAN_SVC_HASH_LEN];    /* service name */
545*4882a593Smuzhiyun 	uint8 enabled;        /* NAN Enabled */
546*4882a593Smuzhiyun 	uint8 nan_de_evt_type;  /* DE event type */
547*4882a593Smuzhiyun 	uint8 status;           /* status */
548*4882a593Smuzhiyun 	uint8 ndp_id;           /* data path instance id */
549*4882a593Smuzhiyun 	uint8 security;         /* data path security */
550*4882a593Smuzhiyun 	uint8 type;
551*4882a593Smuzhiyun 	uint8 attr_num;
552*4882a593Smuzhiyun 	uint8 reason;          /* reason */
553*4882a593Smuzhiyun 	wl_nan_instance_id_t pub_id;          /* publisher id */
554*4882a593Smuzhiyun 	wl_nan_instance_id_t sub_id;          /* subscriber id */
555*4882a593Smuzhiyun 	wl_nan_instance_id_t local_inst_id;   /* local instance id */
556*4882a593Smuzhiyun 	wl_nan_instance_id_t requestor_id;    /* Requestor instance id */
557*4882a593Smuzhiyun 	int publish_rssi;	/* discovery rssi value */
558*4882a593Smuzhiyun 	int sub_rssi;	/* Sub rssi value */
559*4882a593Smuzhiyun 	int fup_rssi;		/* followup rssi */
560*4882a593Smuzhiyun 	uint16 attr_list_len;  /* sizeof attributes attached to payload */
561*4882a593Smuzhiyun 	nan_str_data_t svc_info;        /* service info */
562*4882a593Smuzhiyun 	nan_str_data_t vend_info;       /* vendor info */
563*4882a593Smuzhiyun 	nan_str_data_t sde_svc_info;	/* extended service information */
564*4882a593Smuzhiyun 	nan_str_data_t tx_match_filter;	/* tx match filter */
565*4882a593Smuzhiyun 	nan_str_data_t rx_match_filter;	/* rx match filter */
566*4882a593Smuzhiyun 	struct ether_addr local_nmi;      /* local nmi */
567*4882a593Smuzhiyun 	struct ether_addr clus_id;        /* cluster id */
568*4882a593Smuzhiyun 	struct ether_addr remote_nmi;     /* remote nmi */
569*4882a593Smuzhiyun 	struct ether_addr initiator_ndi;        /* initiator_ndi */
570*4882a593Smuzhiyun 	struct ether_addr responder_ndi;        /* responder_ndi */
571*4882a593Smuzhiyun 	uint16 token; /* transmit fup token id */
572*4882a593Smuzhiyun 	uint8 peer_cipher_suite; /* peer cipher suite type */
573*4882a593Smuzhiyun 	nan_str_data_t scid;        /* security context information */
574*4882a593Smuzhiyun 	char nan_reason[NAN_ERROR_STR_LEN]; /* Describe the NAN reason type */
575*4882a593Smuzhiyun 	uint16 sde_control_flag;
576*4882a593Smuzhiyun 	uint8 ranging_result_present;
577*4882a593Smuzhiyun 	uint32 range_measurement_cm;
578*4882a593Smuzhiyun 	uint32 ranging_ind;
579*4882a593Smuzhiyun 	uint8 rng_id;
580*4882a593Smuzhiyun } nan_event_data_t;
581*4882a593Smuzhiyun 
582*4882a593Smuzhiyun /*
583*4882a593Smuzhiyun  *   Various NAN Protocol Response code
584*4882a593Smuzhiyun */
585*4882a593Smuzhiyun typedef enum {
586*4882a593Smuzhiyun 	/* NAN Protocol Response Codes */
587*4882a593Smuzhiyun 	NAN_STATUS_SUCCESS = 0,
588*4882a593Smuzhiyun 	/*  NAN Discovery Engine/Host driver failures */
589*4882a593Smuzhiyun 	NAN_STATUS_INTERNAL_FAILURE = 1,
590*4882a593Smuzhiyun 	/*  NAN OTA failures */
591*4882a593Smuzhiyun 	NAN_STATUS_PROTOCOL_FAILURE = 2,
592*4882a593Smuzhiyun 	/* if the publish/subscribe id is invalid */
593*4882a593Smuzhiyun 	NAN_STATUS_INVALID_PUBLISH_SUBSCRIBE_ID = 3,
594*4882a593Smuzhiyun 	/* If we run out of resources allocated */
595*4882a593Smuzhiyun 	NAN_STATUS_NO_RESOURCE_AVAILABLE = 4,
596*4882a593Smuzhiyun 	/* if invalid params are passed */
597*4882a593Smuzhiyun 	NAN_STATUS_INVALID_PARAM = 5,
598*4882a593Smuzhiyun 	/*  if the requestor instance id is invalid */
599*4882a593Smuzhiyun 	NAN_STATUS_INVALID_REQUESTOR_INSTANCE_ID = 6,
600*4882a593Smuzhiyun 	/*  if the ndp id is invalid */
601*4882a593Smuzhiyun 	NAN_STATUS_INVALID_NDP_ID = 7,
602*4882a593Smuzhiyun 	/* if NAN is enabled when wifi is turned off */
603*4882a593Smuzhiyun 	NAN_STATUS_NAN_NOT_ALLOWED = 8,
604*4882a593Smuzhiyun 	/* if over the air ack is not received */
605*4882a593Smuzhiyun 	NAN_STATUS_NO_OTA_ACK = 9,
606*4882a593Smuzhiyun 	/* If NAN is already enabled and we are try to re-enable the same */
607*4882a593Smuzhiyun 	NAN_STATUS_ALREADY_ENABLED = 10,
608*4882a593Smuzhiyun 	/* If followup message internal queue is full */
609*4882a593Smuzhiyun 	NAN_STATUS_FOLLOWUP_QUEUE_FULL = 11,
610*4882a593Smuzhiyun 	/* Unsupported concurrency session enabled, NAN disabled notified */
611*4882a593Smuzhiyun 	NAN_STATUS_UNSUPPORTED_CONCURRENCY_NAN_DISABLED = 12
612*4882a593Smuzhiyun } nan_status_type_t;
613*4882a593Smuzhiyun 
614*4882a593Smuzhiyun typedef struct {
615*4882a593Smuzhiyun 	nan_status_type_t status;
616*4882a593Smuzhiyun 	char nan_reason[NAN_ERROR_STR_LEN]; /* Describe the NAN reason type */
617*4882a593Smuzhiyun } nan_hal_status_t;
618*4882a593Smuzhiyun 
619*4882a593Smuzhiyun typedef struct nan_parse_event_ctx {
620*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg;
621*4882a593Smuzhiyun 	nan_event_data_t *nan_evt_data;
622*4882a593Smuzhiyun } nan_parse_event_ctx_t;
623*4882a593Smuzhiyun 
624*4882a593Smuzhiyun /* Capabilities info supported by FW */
625*4882a593Smuzhiyun typedef struct nan_hal_capabilities {
626*4882a593Smuzhiyun 	uint32 max_concurrent_nan_clusters;
627*4882a593Smuzhiyun 	uint32 max_publishes;
628*4882a593Smuzhiyun 	uint32 max_subscribes;
629*4882a593Smuzhiyun 	uint32 max_service_name_len;
630*4882a593Smuzhiyun 	uint32 max_match_filter_len;
631*4882a593Smuzhiyun 	uint32 max_total_match_filter_len;
632*4882a593Smuzhiyun 	uint32 max_service_specific_info_len;
633*4882a593Smuzhiyun 	uint32 max_vsa_data_len;
634*4882a593Smuzhiyun 	uint32 max_mesh_data_len;
635*4882a593Smuzhiyun 	uint32 max_ndi_interfaces;
636*4882a593Smuzhiyun 	uint32 max_ndp_sessions;
637*4882a593Smuzhiyun 	uint32 max_app_info_len;
638*4882a593Smuzhiyun 	uint32 max_queued_transmit_followup_msgs;
639*4882a593Smuzhiyun 	uint32 ndp_supported_bands;
640*4882a593Smuzhiyun 	uint32 cipher_suites_supported;
641*4882a593Smuzhiyun 	uint32 max_scid_len;
642*4882a593Smuzhiyun 	bool is_ndp_security_supported;
643*4882a593Smuzhiyun 	uint32 max_sdea_service_specific_info_len;
644*4882a593Smuzhiyun 	uint32 max_subscribe_address;
645*4882a593Smuzhiyun 	uint32 ndpe_attr_supported;
646*4882a593Smuzhiyun } nan_hal_capabilities_t;
647*4882a593Smuzhiyun 
648*4882a593Smuzhiyun typedef struct _nan_hal_resp {
649*4882a593Smuzhiyun 	uint16 instance_id;
650*4882a593Smuzhiyun 	uint16 subcmd;
651*4882a593Smuzhiyun 	int32 status;
652*4882a593Smuzhiyun 	int32 value;
653*4882a593Smuzhiyun 	/* Identifier for the instance of the NDP */
654*4882a593Smuzhiyun 	uint16 ndp_instance_id;
655*4882a593Smuzhiyun 	/* Publisher NMI */
656*4882a593Smuzhiyun 	uint8 pub_nmi[NAN_MAC_ADDR_LEN];
657*4882a593Smuzhiyun 	/* SVC_HASH */
658*4882a593Smuzhiyun 	uint8 svc_hash[WL_NAN_SVC_HASH_LEN];
659*4882a593Smuzhiyun 	char nan_reason[NAN_ERROR_STR_LEN]; /* Describe the NAN reason type */
660*4882a593Smuzhiyun 	char pad[3];
661*4882a593Smuzhiyun 	nan_hal_capabilities_t capabilities;
662*4882a593Smuzhiyun } nan_hal_resp_t;
663*4882a593Smuzhiyun 
664*4882a593Smuzhiyun typedef struct wl_nan_iov {
665*4882a593Smuzhiyun 	uint16 nan_iov_len;
666*4882a593Smuzhiyun 	uint8 *nan_iov_buf;
667*4882a593Smuzhiyun } wl_nan_iov_t;
668*4882a593Smuzhiyun 
669*4882a593Smuzhiyun #ifdef WL_NAN_DISC_CACHE
670*4882a593Smuzhiyun 
671*4882a593Smuzhiyun #define NAN_MAX_CACHE_DISC_RESULT 16
672*4882a593Smuzhiyun typedef struct {
673*4882a593Smuzhiyun 	bool valid;
674*4882a593Smuzhiyun 	wl_nan_instance_id_t pub_id;
675*4882a593Smuzhiyun 	wl_nan_instance_id_t sub_id;
676*4882a593Smuzhiyun 	uint8 svc_hash[WL_NAN_SVC_HASH_LEN];
677*4882a593Smuzhiyun 	struct ether_addr peer;
678*4882a593Smuzhiyun 	int8 publish_rssi;
679*4882a593Smuzhiyun 	uint8 peer_cipher_suite;
680*4882a593Smuzhiyun 	uint8 security;
681*4882a593Smuzhiyun 	nan_str_data_t svc_info;        /* service info */
682*4882a593Smuzhiyun 	nan_str_data_t vend_info;       /* vendor info */
683*4882a593Smuzhiyun 	nan_str_data_t sde_svc_info;	/* extended service information */
684*4882a593Smuzhiyun 	nan_str_data_t tx_match_filter; /* tx match filter */
685*4882a593Smuzhiyun 	uint16 sde_control_flag;
686*4882a593Smuzhiyun } nan_disc_result_cache;
687*4882a593Smuzhiyun 
688*4882a593Smuzhiyun typedef struct nan_datapath_sec_info {
689*4882a593Smuzhiyun 	nan_data_path_id ndp_instance_id;
690*4882a593Smuzhiyun 	wl_nan_instance_id_t pub_id;    /* publisher id */
691*4882a593Smuzhiyun 	struct ether_addr mac_addr;     /* mac address */
692*4882a593Smuzhiyun } nan_datapath_sec_info_cmd_data_t;
693*4882a593Smuzhiyun #endif /* WL_NAN_DISC_CACHE */
694*4882a593Smuzhiyun 
695*4882a593Smuzhiyun typedef enum {
696*4882a593Smuzhiyun 	NAN_RANGING_AUTO_RESPONSE_ENABLE = 0,
697*4882a593Smuzhiyun 	NAN_RANGING_AUTO_RESPONSE_DISABLE
698*4882a593Smuzhiyun } NanRangingAutoResponseCfg;
699*4882a593Smuzhiyun 
700*4882a593Smuzhiyun typedef struct wl_ndi_data
701*4882a593Smuzhiyun {
702*4882a593Smuzhiyun 	u8 ifname[IFNAMSIZ];
703*4882a593Smuzhiyun 	u8 in_use;
704*4882a593Smuzhiyun 	u8 created;
705*4882a593Smuzhiyun 	struct net_device *nan_ndev;
706*4882a593Smuzhiyun } wl_ndi_data_t;
707*4882a593Smuzhiyun 
708*4882a593Smuzhiyun typedef struct wl_nancfg
709*4882a593Smuzhiyun {
710*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg;
711*4882a593Smuzhiyun 	bool nan_enable;
712*4882a593Smuzhiyun 	nan_svc_inst_t nan_inst_ctrl[NAN_ID_CTRL_SIZE];
713*4882a593Smuzhiyun 	struct ether_addr initiator_ndi;
714*4882a593Smuzhiyun 	uint8 nan_dp_state;
715*4882a593Smuzhiyun 	bool nan_init_state; /* nan initialization state */
716*4882a593Smuzhiyun 	wait_queue_head_t ndp_if_change_event;
717*4882a593Smuzhiyun 	uint8 support_5g;
718*4882a593Smuzhiyun 	u8 nan_nmi_mac[ETH_ALEN];
719*4882a593Smuzhiyun 	u8 nan_dp_count;
720*4882a593Smuzhiyun 	struct delayed_work	nan_disable;
721*4882a593Smuzhiyun 	int nan_disc_count;
722*4882a593Smuzhiyun 	nan_disc_result_cache *nan_disc_cache;
723*4882a593Smuzhiyun 	nan_svc_info_t svc_info[NAN_MAX_SVC_INST];
724*4882a593Smuzhiyun 	nan_ranging_inst_t nan_ranging_info[NAN_MAX_RANGING_INST];
725*4882a593Smuzhiyun 	wl_nan_ver_t version;
726*4882a593Smuzhiyun 	struct mutex nan_sync;
727*4882a593Smuzhiyun 	uint8 svc_inst_id_mask[NAN_SVC_INST_SIZE];
728*4882a593Smuzhiyun 	uint8 inst_id_start;
729*4882a593Smuzhiyun 	/* wait queue and condition variable for nan event */
730*4882a593Smuzhiyun 	bool nan_event_recvd;
731*4882a593Smuzhiyun 	wait_queue_head_t nan_event_wait;
732*4882a593Smuzhiyun 	bool notify_user;
733*4882a593Smuzhiyun 	bool mac_rand;
734*4882a593Smuzhiyun 	uint8 max_ndp_count;       /* Max no. of NDPs */
735*4882a593Smuzhiyun 	nan_ndp_peer_t *nan_ndp_peer_info;
736*4882a593Smuzhiyun 	nan_data_path_id ndp_id[NAN_MAX_NDP_PEER];
737*4882a593Smuzhiyun 	uint8 ndpe_enabled;
738*4882a593Smuzhiyun 	uint8 max_ndi_supported;
739*4882a593Smuzhiyun 	wl_ndi_data_t *ndi;
740*4882a593Smuzhiyun 	bool ranging_enable;
741*4882a593Smuzhiyun } wl_nancfg_t;
742*4882a593Smuzhiyun 
743*4882a593Smuzhiyun bool wl_cfgnan_is_enabled(struct bcm_cfg80211 *cfg);
744*4882a593Smuzhiyun int wl_cfgnan_check_nan_disable_pending(struct bcm_cfg80211 *cfg,
745*4882a593Smuzhiyun bool force_disable, bool is_sync_reqd);
746*4882a593Smuzhiyun int wl_cfgnan_start_handler(struct net_device *ndev,
747*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_config_cmd_data_t *cmd_data, uint32 nan_attr_mask);
748*4882a593Smuzhiyun int wl_cfgnan_stop_handler(struct net_device *ndev, struct bcm_cfg80211 *cfg);
749*4882a593Smuzhiyun void wl_cfgnan_delayed_disable(struct work_struct *work);
750*4882a593Smuzhiyun int wl_cfgnan_config_handler(struct net_device *ndev,
751*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_config_cmd_data_t *cmd_data, uint32 nan_attr_mask);
752*4882a593Smuzhiyun int wl_cfgnan_support_handler(struct net_device *ndev,
753*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_config_cmd_data_t *cmd_data);
754*4882a593Smuzhiyun int wl_cfgnan_status_handler(struct net_device *ndev,
755*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_config_cmd_data_t *cmd_data);
756*4882a593Smuzhiyun int wl_cfgnan_publish_handler(struct net_device *ndev,
757*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_discover_cmd_data_t *cmd_data);
758*4882a593Smuzhiyun int wl_cfgnan_subscribe_handler(struct net_device *ndev,
759*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_discover_cmd_data_t *cmd_data);
760*4882a593Smuzhiyun int wl_cfgnan_cancel_pub_handler(struct net_device *ndev,
761*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_discover_cmd_data_t *cmd_data);
762*4882a593Smuzhiyun int wl_cfgnan_cancel_sub_handler(struct net_device *ndev,
763*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_discover_cmd_data_t *cmd_data);
764*4882a593Smuzhiyun int wl_cfgnan_transmit_handler(struct net_device *ndev,
765*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_discover_cmd_data_t *cmd_data);
766*4882a593Smuzhiyun s32 wl_cfgnan_notify_nan_status(struct bcm_cfg80211 *cfg,
767*4882a593Smuzhiyun 	bcm_struct_cfgdev *cfgdev, const wl_event_msg_t *e, void *data);
768*4882a593Smuzhiyun int wl_cfgnan_generate_inst_id(struct bcm_cfg80211 *cfg, uint8 *p_inst_id);
769*4882a593Smuzhiyun int wl_cfgnan_remove_inst_id(struct bcm_cfg80211 *cfg, uint8 inst_id);
770*4882a593Smuzhiyun int wl_cfgnan_get_capablities_handler(struct net_device *ndev,
771*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_hal_capabilities_t *capabilities);
772*4882a593Smuzhiyun int wl_cfgnan_data_path_iface_create_delete_handler(struct net_device *ndev,
773*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, char *ifname, uint16 type, uint8 busstate);
774*4882a593Smuzhiyun int wl_cfgnan_data_path_request_handler(struct net_device *ndev,
775*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_datapath_cmd_data_t *cmd_data,
776*4882a593Smuzhiyun 	uint8 *ndp_instance_id);
777*4882a593Smuzhiyun int wl_cfgnan_data_path_response_handler(struct net_device *ndev,
778*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_datapath_cmd_data_t *cmd_data);
779*4882a593Smuzhiyun int wl_cfgnan_data_path_end_handler(struct net_device *ndev,
780*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, nan_data_path_id ndp_instance_id,
781*4882a593Smuzhiyun 	int *status);
782*4882a593Smuzhiyun const char * nan_event_to_str(u16 cmd);
783*4882a593Smuzhiyun 
784*4882a593Smuzhiyun #ifdef WL_NAN_DISC_CACHE
785*4882a593Smuzhiyun int wl_cfgnan_sec_info_handler(struct bcm_cfg80211 *cfg,
786*4882a593Smuzhiyun 	nan_datapath_sec_info_cmd_data_t *cmd_data, nan_hal_resp_t *nan_req_resp);
787*4882a593Smuzhiyun /* ranging quest and response iovar handler */
788*4882a593Smuzhiyun #endif /* WL_NAN_DISC_CACHE */
789*4882a593Smuzhiyun bool wl_cfgnan_is_dp_active(struct net_device *ndev);
790*4882a593Smuzhiyun bool wl_cfgnan_data_dp_exists_with_peer(struct bcm_cfg80211 *cfg,
791*4882a593Smuzhiyun 	struct ether_addr *peer_addr);
792*4882a593Smuzhiyun s32 wl_cfgnan_delete_ndp(struct bcm_cfg80211 *cfg, struct net_device *nan_ndev);
793*4882a593Smuzhiyun int wl_cfgnan_set_enable_merge(struct net_device *ndev,
794*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, uint8 enable, uint32 *status);
795*4882a593Smuzhiyun int wl_cfgnan_attach(struct bcm_cfg80211 *cfg);
796*4882a593Smuzhiyun void wl_cfgnan_detach(struct bcm_cfg80211 *cfg);
797*4882a593Smuzhiyun int wl_cfgnan_get_status(struct net_device *ndev, wl_nan_conf_status_t *nan_status);
798*4882a593Smuzhiyun 
799*4882a593Smuzhiyun #ifdef RTT_SUPPORT
800*4882a593Smuzhiyun int wl_cfgnan_trigger_ranging(struct net_device *ndev,
801*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, void *event_data, nan_svc_info_t *svc,
802*4882a593Smuzhiyun 	uint8 range_req, bool accept_req);
803*4882a593Smuzhiyun nan_ranging_inst_t *wl_cfgnan_get_ranging_inst(struct bcm_cfg80211 *cfg,
804*4882a593Smuzhiyun 	struct ether_addr *peer, nan_range_role_t range_role);
805*4882a593Smuzhiyun nan_ranging_inst_t* wl_cfgnan_check_for_ranging(struct bcm_cfg80211 *cfg,
806*4882a593Smuzhiyun 	struct ether_addr *peer);
807*4882a593Smuzhiyun int wl_cfgnan_trigger_geofencing_ranging(struct net_device *dev,
808*4882a593Smuzhiyun 	struct ether_addr *peer_addr);
809*4882a593Smuzhiyun int wl_cfgnan_suspend_geofence_rng_session(struct net_device *ndev,
810*4882a593Smuzhiyun 	struct ether_addr *peer, int suspend_reason, u8 cancel_flags);
811*4882a593Smuzhiyun void wl_cfgnan_suspend_all_geofence_rng_sessions(struct net_device *ndev,
812*4882a593Smuzhiyun 	int suspend_reason, u8 cancel_flags);
813*4882a593Smuzhiyun int wl_cfgnan_terminate_directed_rtt_sessions(struct net_device *ndev, struct bcm_cfg80211 *cfg);
814*4882a593Smuzhiyun void wl_cfgnan_reset_geofence_ranging(struct bcm_cfg80211 *cfg,
815*4882a593Smuzhiyun 	nan_ranging_inst_t * rng_inst, int sched_reason, bool need_rtt_mutex);
816*4882a593Smuzhiyun void wl_cfgnan_reset_geofence_ranging_for_cur_target(dhd_pub_t *dhd, int sched_reason);
817*4882a593Smuzhiyun void wl_cfgnan_process_range_report(struct bcm_cfg80211 *cfg,
818*4882a593Smuzhiyun 	wl_nan_ev_rng_rpt_ind_t *range_res, int rtt_status);
819*4882a593Smuzhiyun int wl_cfgnan_cancel_ranging(struct net_device *ndev,
820*4882a593Smuzhiyun 	struct bcm_cfg80211 *cfg, uint8 *range_id, uint8 flags, uint32 *status);
821*4882a593Smuzhiyun bool wl_cfgnan_ranging_allowed(struct bcm_cfg80211 *cfg);
822*4882a593Smuzhiyun uint8 wl_cfgnan_cancel_rng_responders(struct net_device *ndev);
823*4882a593Smuzhiyun bool wl_cfgnan_check_role_concurrency(struct bcm_cfg80211 *cfg,
824*4882a593Smuzhiyun 	struct ether_addr *peer_addr);
825*4882a593Smuzhiyun bool wl_cfgnan_update_geofence_target_idx(struct bcm_cfg80211 *cfg);
826*4882a593Smuzhiyun bool wl_cfgnan_ranging_is_in_prog_for_peer(struct bcm_cfg80211 *cfg,
827*4882a593Smuzhiyun 	struct ether_addr *peer_addr);
828*4882a593Smuzhiyun #endif /* RTT_SUPPORT */
829*4882a593Smuzhiyun 
830*4882a593Smuzhiyun typedef enum {
831*4882a593Smuzhiyun 	NAN_ATTRIBUTE_HEADER                            = 100,
832*4882a593Smuzhiyun 	NAN_ATTRIBUTE_HANDLE                            = 101,
833*4882a593Smuzhiyun 	NAN_ATTRIBUTE_TRANSAC_ID                        = 102,
834*4882a593Smuzhiyun 
835*4882a593Smuzhiyun 	/* NAN Enable request attributes */
836*4882a593Smuzhiyun 	NAN_ATTRIBUTE_2G_SUPPORT                        = 103,
837*4882a593Smuzhiyun 	NAN_ATTRIBUTE_5G_SUPPORT                        = 104,
838*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CLUSTER_LOW                       = 105,
839*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CLUSTER_HIGH                      = 106,
840*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SID_BEACON                        = 107,
841*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SYNC_DISC_2G_BEACON               = 108,
842*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SYNC_DISC_5G_BEACON               = 109,
843*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDF_2G_SUPPORT                    = 110,
844*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDF_5G_SUPPORT                    = 111,
845*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_CLOSE                        = 112,
846*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_MIDDLE                       = 113,
847*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_PROXIMITY                    = 114,
848*4882a593Smuzhiyun 	NAN_ATTRIBUTE_HOP_COUNT_LIMIT                   = 115,
849*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANDOM_TIME                       = 116,
850*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MASTER_PREF                       = 117,
851*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PERIODIC_SCAN_INTERVAL            = 118,
852*4882a593Smuzhiyun 
853*4882a593Smuzhiyun 	/* Nan Publish/Subscribe request attributes */
854*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PUBLISH_ID                        = 119,
855*4882a593Smuzhiyun 	NAN_ATTRIBUTE_TTL                               = 120,
856*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PERIOD                            = 121,
857*4882a593Smuzhiyun 	NAN_ATTRIBUTE_REPLIED_EVENT_FLAG                = 122,
858*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PUBLISH_TYPE                      = 123,
859*4882a593Smuzhiyun 	NAN_ATTRIBUTE_TX_TYPE                           = 124,
860*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PUBLISH_COUNT                     = 125,
861*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SERVICE_NAME_LEN                  = 126,
862*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SERVICE_NAME                      = 127,
863*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SERVICE_SPECIFIC_INFO_LEN         = 128,
864*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SERVICE_SPECIFIC_INFO             = 129,
865*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RX_MATCH_FILTER_LEN               = 130,
866*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RX_MATCH_FILTER                   = 131,
867*4882a593Smuzhiyun 	NAN_ATTRIBUTE_TX_MATCH_FILTER_LEN               = 132,
868*4882a593Smuzhiyun 	NAN_ATTRIBUTE_TX_MATCH_FILTER                   = 133,
869*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SUBSCRIBE_ID                      = 134,
870*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SUBSCRIBE_TYPE                    = 135,
871*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SERVICERESPONSEFILTER             = 136,
872*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SERVICERESPONSEINCLUDE            = 137,
873*4882a593Smuzhiyun 	NAN_ATTRIBUTE_USESERVICERESPONSEFILTER          = 138,
874*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SSIREQUIREDFORMATCHINDICATION     = 139,
875*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SUBSCRIBE_MATCH                   = 140,
876*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SUBSCRIBE_COUNT                   = 141,
877*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MAC_ADDR                          = 142,
878*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MAC_ADDR_LIST                     = 143,
879*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MAC_ADDR_LIST_NUM_ENTRIES         = 144,
880*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PUBLISH_MATCH                     = 145,
881*4882a593Smuzhiyun 
882*4882a593Smuzhiyun 	/* Nan Event attributes */
883*4882a593Smuzhiyun 	NAN_ATTRIBUTE_ENABLE_STATUS                     = 146,
884*4882a593Smuzhiyun 	NAN_ATTRIBUTE_JOIN_STATUS                       = 147,
885*4882a593Smuzhiyun 	NAN_ATTRIBUTE_ROLE                              = 148,
886*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MASTER_RANK                       = 149,
887*4882a593Smuzhiyun 	NAN_ATTRIBUTE_ANCHOR_MASTER_RANK                = 150,
888*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CNT_PEND_TXFRM                    = 151,
889*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CNT_BCN_TX                        = 152,
890*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CNT_BCN_RX                        = 153,
891*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CNT_SVC_DISC_TX                   = 154,
892*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CNT_SVC_DISC_RX                   = 155,
893*4882a593Smuzhiyun 	NAN_ATTRIBUTE_AMBTT                             = 156,
894*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CLUSTER_ID                        = 157,
895*4882a593Smuzhiyun 	NAN_ATTRIBUTE_INST_ID                           = 158,
896*4882a593Smuzhiyun 	NAN_ATTRIBUTE_OUI                               = 159,
897*4882a593Smuzhiyun 	NAN_ATTRIBUTE_STATUS                            = 160,
898*4882a593Smuzhiyun 	NAN_ATTRIBUTE_DE_EVENT_TYPE                     = 161,
899*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MERGE                             = 162,
900*4882a593Smuzhiyun 	NAN_ATTRIBUTE_IFACE                             = 163,
901*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CHANNEL                           = 164,
902*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PEER_ID                           = 165,
903*4882a593Smuzhiyun 	NAN_ATTRIBUTE_NDP_ID                            = 167,
904*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SECURITY                          = 168,
905*4882a593Smuzhiyun 	NAN_ATTRIBUTE_QOS                               = 169,
906*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSP_CODE                          = 170,
907*4882a593Smuzhiyun 	NAN_ATTRIBUTE_INST_COUNT                        = 171,
908*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PEER_DISC_MAC_ADDR                = 172,
909*4882a593Smuzhiyun 	NAN_ATTRIBUTE_PEER_NDI_MAC_ADDR                 = 173,
910*4882a593Smuzhiyun 	NAN_ATTRIBUTE_IF_ADDR                           = 174,
911*4882a593Smuzhiyun 	NAN_ATTRIBUTE_WARMUP_TIME                       = 175,
912*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RECV_IND_CFG                      = 176,
913*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_CLOSE_5G                     = 177,
914*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_MIDDLE_5G                    = 178,
915*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_PROXIMITY_5G                 = 179,
916*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CONNMAP                           = 180,
917*4882a593Smuzhiyun 	NAN_ATTRIBUTE_24G_CHANNEL                       = 181,
918*4882a593Smuzhiyun 	NAN_ATTRIBUTE_5G_CHANNEL                        = 182,
919*4882a593Smuzhiyun 	NAN_ATTRIBUTE_DWELL_TIME                        = 183,
920*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SCAN_PERIOD                       = 184,
921*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_WINDOW_SIZE			= 185,
922*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CONF_CLUSTER_VAL			= 186,
923*4882a593Smuzhiyun 	NAN_ATTRIBUTE_AVAIL_BIT_MAP                     = 187,
924*4882a593Smuzhiyun 	NAN_ATTRIBUTE_ENTRY_CONTROL			= 188,
925*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CIPHER_SUITE_TYPE                 = 189,
926*4882a593Smuzhiyun 	NAN_ATTRIBUTE_KEY_TYPE                          = 190,
927*4882a593Smuzhiyun 	NAN_ATTRIBUTE_KEY_LEN                           = 191,
928*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SCID                              = 192,
929*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SCID_LEN                          = 193,
930*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDE_CONTROL_CONFIG_DP             = 194,
931*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDE_CONTROL_SECURITY		= 195,
932*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDE_CONTROL_DP_TYPE		= 196,
933*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDE_CONTROL_RANGE_SUPPORT		= 197,
934*4882a593Smuzhiyun 	NAN_ATTRIBUTE_NO_CONFIG_AVAIL			= 198,
935*4882a593Smuzhiyun 	NAN_ATTRIBUTE_2G_AWAKE_DW			= 199,
936*4882a593Smuzhiyun 	NAN_ATTRIBUTE_5G_AWAKE_DW			= 200,
937*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANGING_INTERVAL			= 201,
938*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANGING_INDICATION		= 202,
939*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANGING_INGRESS_LIMIT		= 203,
940*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANGING_EGRESS_LIMIT		= 204,
941*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANGING_AUTO_ACCEPT		= 205,
942*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANGING_RESULT			= 206,
943*4882a593Smuzhiyun 	NAN_ATTRIBUTE_DISC_IND_CFG			= 207,
944*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RSSI_THRESHOLD_FLAG		= 208,
945*4882a593Smuzhiyun 	NAN_ATTRIBUTE_KEY_DATA                          = 209,
946*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDEA_SERVICE_SPECIFIC_INFO_LEN    = 210,
947*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SDEA_SERVICE_SPECIFIC_INFO        = 211,
948*4882a593Smuzhiyun 	NAN_ATTRIBUTE_REASON				= 212,
949*4882a593Smuzhiyun 	NAN_ATTRIBUTE_DWELL_TIME_5G                     = 215,
950*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SCAN_PERIOD_5G                    = 216,
951*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SVC_RESPONDER_POLICY              = 217,
952*4882a593Smuzhiyun 	NAN_ATTRIBUTE_EVENT_MASK			= 218,
953*4882a593Smuzhiyun 	NAN_ATTRIBUTE_SUB_SID_BEACON                    = 219,
954*4882a593Smuzhiyun 	NAN_ATTRIBUTE_RANDOMIZATION_INTERVAL            = 220,
955*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CMD_RESP_DATA			= 221,
956*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CMD_USE_NDPE			= 222,
957*4882a593Smuzhiyun 	NAN_ATTRIBUTE_ENABLE_MERGE			= 223,
958*4882a593Smuzhiyun 	NAN_ATTRIBUTE_DISCOVERY_BEACON_INTERVAL		= 224,
959*4882a593Smuzhiyun 	NAN_ATTRIBUTE_NSS				= 225,
960*4882a593Smuzhiyun 	NAN_ATTRIBUTE_ENABLE_RANGING			= 226,
961*4882a593Smuzhiyun 	NAN_ATTRIBUTE_DW_EARLY_TERM			= 227,
962*4882a593Smuzhiyun 	NAN_ATTRIBUTE_CHANNEL_INFO			= 228,
963*4882a593Smuzhiyun 	NAN_ATTRIBUTE_NUM_CHANNELS			= 229,
964*4882a593Smuzhiyun 	NAN_ATTRIBUTE_INSTANT_MODE_ENABLE		= 230,
965*4882a593Smuzhiyun 	NAN_ATTRIBUTE_INSTANT_COMM_CHAN			= 231,
966*4882a593Smuzhiyun 	NAN_ATTRIBUTE_MAX				= 232
967*4882a593Smuzhiyun } NAN_ATTRIBUTE;
968*4882a593Smuzhiyun 
969*4882a593Smuzhiyun enum geofence_suspend_reason {
970*4882a593Smuzhiyun 	RTT_GEO_SUSPN_HOST_DIR_RTT_TRIG = 0,
971*4882a593Smuzhiyun 	RTT_GEO_SUSPN_PEER_RTT_TRIGGER = 1,
972*4882a593Smuzhiyun 	RTT_GEO_SUSPN_HOST_NDP_TRIGGER = 2,
973*4882a593Smuzhiyun 	RTT_GEO_SUSPN_PEER_NDP_TRIGGER = 3,
974*4882a593Smuzhiyun 	RTT_GEO_SUSPN_RANGE_RES_REPORTED = 4
975*4882a593Smuzhiyun };
976*4882a593Smuzhiyun #endif	/* _wl_cfgnan_h_ */
977