wl_cfgnan.h 35 KB

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