blob: 5239ee4e3b82046f6d9c61ae3cb9bfe2791a3a69 [file] [log] [blame]
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07001/*
2 * P2P - Internal definitions for P2P module
3 * Copyright (c) 2009-2010, Atheros Communications
4 *
Dmitry Shmidtc5ec7f52012-03-06 16:33:24 -08005 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07007 */
8
9#ifndef P2P_I_H
10#define P2P_I_H
11
12#include "utils/list.h"
Sunil8cd6f4d2022-06-28 18:40:46 +000013#include "drivers/driver.h"
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070014#include "p2p.h"
Jimmy Chen6d7e3902018-11-20 10:15:16 +080015#include "ap/ap_config.h"
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070016
Dmitry Shmidt413dde72014-04-11 10:23:22 -070017#define P2P_GO_NEG_CNF_MAX_RETRY_COUNT 1
18
Dmitry Shmidta3dc3092015-06-23 11:21:28 -070019/*
20 * A threshold (in seconds) to prefer a direct Probe Response frame from a P2P
21 * Device over the P2P Client Info received from a GO.
22 */
23#define P2P_DEV_GROUP_CLIENT_RESP_THRESHOLD 1
24
Dmitry Shmidtcf32e602014-01-28 10:57:39 -080025enum p2p_role_indication;
26
Dmitry Shmidt216983b2015-02-06 10:50:36 -080027/*
28 * To force Service Instances to fit within a single P2P Tag, MAX_SVC_ADV_LEN
29 * must equal 248 or less. Must have a minimum size of 19.
30 */
31#define MAX_SVC_ADV_LEN 600
32#define MAX_SVC_ADV_IE_LEN (9 + MAX_SVC_ADV_LEN + (5 * (MAX_SVC_ADV_LEN / 240)))
33
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070034enum p2p_go_state {
35 UNKNOWN_GO,
36 LOCAL_GO,
37 REMOTE_GO
38};
39
40/**
41 * struct p2p_device - P2P Device data (internal to P2P module)
42 */
43struct p2p_device {
44 struct dl_list list;
Dmitry Shmidtfb79edc2014-01-10 10:45:54 -080045 struct os_reltime last_seen;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070046 int listen_freq;
Dmitry Shmidtcf32e602014-01-28 10:57:39 -080047 int oob_go_neg_freq;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070048 enum p2p_wps_method wps_method;
Dmitry Shmidtcf32e602014-01-28 10:57:39 -080049 u16 oob_pw_id;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070050
51 struct p2p_peer_info info;
52
53 /*
54 * If the peer was discovered based on an interface address (e.g., GO
55 * from Beacon/Probe Response), the interface address is stored here.
56 * p2p_device_addr must still be set in such a case to the unique
57 * identifier for the P2P Device.
Dmitry Shmidtd80a4012015-11-05 16:35:40 -080058 *
59 * This field is also used during P2PS PD to store the intended GO
60 * address of the peer.
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070061 */
62 u8 interface_addr[ETH_ALEN];
63
64 /*
65 * P2P Device Address of the GO in whose group this P2P Device is a
66 * client.
67 */
68 u8 member_in_go_dev[ETH_ALEN];
69
70 /*
71 * P2P Interface Address of the GO in whose group this P2P Device is a
72 * client.
73 */
74 u8 member_in_go_iface[ETH_ALEN];
75
76 int go_neg_req_sent;
77 enum p2p_go_state go_state;
78 u8 dialog_token;
Dmitry Shmidt9cdf1b92013-02-27 12:58:50 -080079 u8 tie_breaker;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070080 u8 intended_addr[ETH_ALEN];
81
82 char country[3];
83 struct p2p_channels channels;
84 int oper_freq;
Dmitry Shmidt9d9e6022015-04-23 10:34:55 -070085 u8 oper_ssid[SSID_MAX_LEN];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070086 size_t oper_ssid_len;
87
88 /**
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080089 * req_config_methods - Pending provision discovery methods
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070090 */
91 u16 req_config_methods;
92
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080093 /**
94 * wps_prov_info - Stored provisioning WPS config method
95 *
96 * This is used to store pending WPS config method between Provisioning
97 * Discovery and connection to a running group.
98 */
99 u16 wps_prov_info;
100
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700101#define P2P_DEV_PROBE_REQ_ONLY BIT(0)
102#define P2P_DEV_REPORTED BIT(1)
103#define P2P_DEV_NOT_YET_READY BIT(2)
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700104#define P2P_DEV_PD_PEER_DISPLAY BIT(5)
105#define P2P_DEV_PD_PEER_KEYPAD BIT(6)
106#define P2P_DEV_USER_REJECTED BIT(7)
107#define P2P_DEV_PEER_WAITING_RESPONSE BIT(8)
108#define P2P_DEV_PREFER_PERSISTENT_GROUP BIT(9)
109#define P2P_DEV_WAIT_GO_NEG_RESPONSE BIT(10)
110#define P2P_DEV_WAIT_GO_NEG_CONFIRM BIT(11)
111#define P2P_DEV_GROUP_CLIENT_ONLY BIT(12)
112#define P2P_DEV_FORCE_FREQ BIT(13)
113#define P2P_DEV_PD_FOR_JOIN BIT(14)
114#define P2P_DEV_REPORTED_ONCE BIT(15)
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800115#define P2P_DEV_PREFER_PERSISTENT_RECONN BIT(16)
Dmitry Shmidt04949592012-07-19 12:16:46 -0700116#define P2P_DEV_PD_BEFORE_GO_NEG BIT(17)
Dmitry Shmidt7a5e50a2013-03-05 12:37:16 -0800117#define P2P_DEV_NO_PREF_CHAN BIT(18)
Dmitry Shmidt3c479372014-02-04 10:50:36 -0800118#define P2P_DEV_WAIT_INV_REQ_ACK BIT(19)
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800119#define P2P_DEV_P2PS_REPORTED BIT(20)
120#define P2P_DEV_PD_PEER_P2PS BIT(21)
Dmitry Shmidta3dc3092015-06-23 11:21:28 -0700121#define P2P_DEV_LAST_SEEN_AS_GROUP_CLIENT BIT(22)
122
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700123 unsigned int flags;
124
125 int status; /* enum p2p_status_code */
126 unsigned int wait_count;
127 unsigned int connect_reqs;
128 unsigned int invitation_reqs;
Dmitry Shmidt6c0da2b2015-01-05 13:08:17 -0800129 unsigned int sd_reqs;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700130
131 u16 ext_listen_period;
132 u16 ext_listen_interval;
133
134 u8 go_timeout;
135 u8 client_timeout;
Dmitry Shmidt413dde72014-04-11 10:23:22 -0700136
137 /**
138 * go_neg_conf_sent - Number of GO Negotiation Confirmation retries
139 */
140 u8 go_neg_conf_sent;
141
142 /**
143 * freq - Frquency on which the GO Negotiation Confirmation is sent
144 */
145 int go_neg_conf_freq;
146
147 /**
148 * go_neg_conf - GO Negotiation Confirmation frame
149 */
150 struct wpabuf *go_neg_conf;
151
Dmitry Shmidt13ca8d82014-02-20 10:18:40 -0800152 int sd_pending_bcast_queries;
Sunil Ravi38ad1ed2023-01-17 23:58:31 +0000153 bool support_6ghz;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700154};
155
156struct p2p_sd_query {
157 struct p2p_sd_query *next;
158 u8 peer[ETH_ALEN];
159 int for_all_peers;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700160 int wsd; /* Wi-Fi Display Service Discovery Request */
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700161 struct wpabuf *tlvs;
162};
163
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700164/**
165 * struct p2p_data - P2P module data (internal to P2P module)
166 */
167struct p2p_data {
168 /**
169 * cfg - P2P module configuration
170 *
171 * This is included in the same memory allocation with the
172 * struct p2p_data and as such, must not be freed separately.
173 */
174 struct p2p_config *cfg;
175
176 /**
177 * state - The current P2P state
178 */
179 enum p2p_state {
180 /**
181 * P2P_IDLE - Idle
182 */
183 P2P_IDLE,
184
185 /**
186 * P2P_SEARCH - Search (Device Discovery)
187 */
188 P2P_SEARCH,
189
190 /**
191 * P2P_CONNECT - Trying to start GO Negotiation
192 */
193 P2P_CONNECT,
194
195 /**
196 * P2P_CONNECT_LISTEN - Listen during GO Negotiation start
197 */
198 P2P_CONNECT_LISTEN,
199
200 /**
201 * P2P_GO_NEG - In GO Negotiation
202 */
203 P2P_GO_NEG,
204
205 /**
206 * P2P_LISTEN_ONLY - Listen only
207 */
208 P2P_LISTEN_ONLY,
209
210 /**
211 * P2P_WAIT_PEER_CONNECT - Waiting peer in List for GO Neg
212 */
213 P2P_WAIT_PEER_CONNECT,
214
215 /**
216 * P2P_WAIT_PEER_IDLE - Waiting peer idle for GO Neg
217 */
218 P2P_WAIT_PEER_IDLE,
219
220 /**
221 * P2P_SD_DURING_FIND - Service Discovery during find
222 */
223 P2P_SD_DURING_FIND,
224
225 /**
226 * P2P_PROVISIONING - Provisioning (during group formation)
227 */
228 P2P_PROVISIONING,
229
230 /**
231 * P2P_PD_DURING_FIND - Provision Discovery during find
232 */
233 P2P_PD_DURING_FIND,
234
235 /**
236 * P2P_INVITE - Trying to start Invite
237 */
238 P2P_INVITE,
239
240 /**
241 * P2P_INVITE_LISTEN - Listen during Invite
242 */
243 P2P_INVITE_LISTEN,
244 } state;
245
246 /**
247 * min_disc_int - minDiscoverableInterval
248 */
249 int min_disc_int;
250
251 /**
252 * max_disc_int - maxDiscoverableInterval
253 */
254 int max_disc_int;
255
256 /**
Dmitry Shmidtd5e49232012-12-03 15:08:10 -0800257 * max_disc_tu - Maximum number of TUs for discoverable interval
258 */
259 int max_disc_tu;
260
261 /**
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700262 * devices - List of known P2P Device peers
263 */
264 struct dl_list devices;
265
266 /**
267 * go_neg_peer - Pointer to GO Negotiation peer
268 */
269 struct p2p_device *go_neg_peer;
270
271 /**
272 * invite_peer - Pointer to Invite peer
273 */
274 struct p2p_device *invite_peer;
275
Dmitry Shmidt6c0da2b2015-01-05 13:08:17 -0800276 /**
277 * last_p2p_find_oper - Pointer to last pre-find operation peer
278 */
279 struct p2p_device *last_p2p_find_oper;
280
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700281 const u8 *invite_go_dev_addr;
282 u8 invite_go_dev_addr_buf[ETH_ALEN];
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800283 int invite_dev_pw_id;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700284
Dmitry Shmidt6c0da2b2015-01-05 13:08:17 -0800285 unsigned int retry_invite_req:1;
286 unsigned int retry_invite_req_sent:1;
287
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700288 /**
289 * sd_peer - Pointer to Service Discovery peer
290 */
291 struct p2p_device *sd_peer;
292
293 /**
294 * sd_query - Pointer to Service Discovery query
295 */
296 struct p2p_sd_query *sd_query;
297
Dmitry Shmidt13ca8d82014-02-20 10:18:40 -0800298 /**
299 * num_p2p_sd_queries - Total number of broadcast SD queries present in
300 * the list
301 */
302 int num_p2p_sd_queries;
303
Dmitry Shmidtde47be72016-01-07 12:52:55 -0800304 /**
305 * sd_query_no_ack - The first peer (Dev Addr) that did not ACK SD Query
306 *
307 * This is used to track the first peer that did not ACK an SD Query
308 * within a single P2P Search iteration. All zeros address means no such
309 * peer was yet seen. This information is used to allow a new Listen and
310 * Search phases to be once every pending SD Query has been sent once to
311 * each peer instead of looping all pending attempts continuously until
312 * running out of retry maximums.
313 */
314 u8 sd_query_no_ack[ETH_ALEN];
315
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700316 /* GO Negotiation data */
317
318 /**
319 * intended_addr - Local Intended P2P Interface Address
320 *
321 * This address is used during group owner negotiation as the Intended
322 * P2P Interface Address and the group interface will be created with
323 * address as the local address in case of successfully completed
324 * negotiation.
325 */
326 u8 intended_addr[ETH_ALEN];
327
328 /**
329 * go_intent - Local GO Intent to be used during GO Negotiation
330 */
331 u8 go_intent;
332
333 /**
334 * next_tie_breaker - Next tie-breaker value to use in GO Negotiation
335 */
336 u8 next_tie_breaker;
337
338 /**
339 * ssid - Selected SSID for GO Negotiation (if local end will be GO)
340 */
Dmitry Shmidt9d9e6022015-04-23 10:34:55 -0700341 u8 ssid[SSID_MAX_LEN];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700342
343 /**
344 * ssid_len - ssid length in octets
345 */
346 size_t ssid_len;
347
348 /**
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800349 * ssid_set - Whether SSID is already set for GO Negotiation
350 */
351 int ssid_set;
352
353 /**
Jimmy Chen6d7e3902018-11-20 10:15:16 +0800354 * passphrase - WPA2-Personal passphrase for GO Negotiation (if local end will be GO)
355 */
356 char passphrase[MAX_PASSPHRASE_LEN + 1];
357
358 /**
359 * passphrase_set - Whether passphrase is already set for GO Negotiation
360 */
361 int passphrase_set;
362
363 /**
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700364 * Regulatory class for own operational channel
365 */
366 u8 op_reg_class;
367
368 /**
369 * op_channel - Own operational channel
370 */
371 u8 op_channel;
372
373 /**
374 * channels - Own supported regulatory classes and channels
375 *
376 * List of supposerted channels per regulatory class. The regulatory
377 * classes are defined in IEEE Std 802.11-2007 Annex J and the
378 * numbering of the clases depends on the configured country code.
379 */
380 struct p2p_channels channels;
381
Dmitry Shmidt68d0e3e2013-10-28 17:59:21 -0700382 struct wpa_freq_range_list no_go_freq;
383
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700384 enum p2p_pending_action_state {
385 P2P_NO_PENDING_ACTION,
386 P2P_PENDING_GO_NEG_REQUEST,
387 P2P_PENDING_GO_NEG_RESPONSE,
388 P2P_PENDING_GO_NEG_RESPONSE_FAILURE,
389 P2P_PENDING_GO_NEG_CONFIRM,
390 P2P_PENDING_SD,
391 P2P_PENDING_PD,
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800392 P2P_PENDING_PD_RESPONSE,
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700393 P2P_PENDING_INVITATION_REQUEST,
394 P2P_PENDING_INVITATION_RESPONSE,
395 P2P_PENDING_DEV_DISC_REQUEST,
396 P2P_PENDING_DEV_DISC_RESPONSE,
397 P2P_PENDING_GO_DISC_REQ
398 } pending_action_state;
399
400 unsigned int pending_listen_freq;
401 unsigned int pending_listen_sec;
402 unsigned int pending_listen_usec;
Sunil Ravib0ac25f2024-07-12 01:42:03 +0000403 bool pending_listen_wait_drv;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700404
405 u8 dev_capab;
406
407 int in_listen;
408 int drv_in_listen;
409
410 /**
411 * sd_queries - Pending service discovery queries
412 */
413 struct p2p_sd_query *sd_queries;
414
415 /**
416 * srv_update_indic - Service Update Indicator for local services
417 */
418 u16 srv_update_indic;
Dmitry Shmidteaf261d2013-08-14 15:30:08 -0700419
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700420 struct wpabuf *sd_resp; /* Fragmented SD response */
421 u8 sd_resp_addr[ETH_ALEN];
422 u8 sd_resp_dialog_token;
423 size_t sd_resp_pos; /* Offset in sd_resp */
424 u8 sd_frag_id;
425
426 struct wpabuf *sd_rx_resp; /* Reassembled SD response */
427 u16 sd_rx_update_indic;
428
429 /* P2P Invitation data */
430 enum p2p_invite_role inv_role;
431 u8 inv_bssid[ETH_ALEN];
432 int inv_bssid_set;
Dmitry Shmidt9d9e6022015-04-23 10:34:55 -0700433 u8 inv_ssid[SSID_MAX_LEN];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700434 size_t inv_ssid_len;
435 u8 inv_sa[ETH_ALEN];
436 u8 inv_group_bssid[ETH_ALEN];
437 u8 *inv_group_bssid_ptr;
438 u8 inv_go_dev_addr[ETH_ALEN];
439 u8 inv_status;
440 int inv_op_freq;
441 int inv_persistent;
442
443 enum p2p_discovery_type find_type;
Dmitry Shmidtd2986c22017-10-23 14:22:09 -0700444 int find_specified_freq;
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800445 unsigned int last_p2p_find_timeout;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700446 u8 last_prog_scan_class;
447 u8 last_prog_scan_chan;
Dmitry Shmidtd2986c22017-10-23 14:22:09 -0700448 unsigned int find_pending_full:1;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700449 int p2p_scan_running;
450 enum p2p_after_scan {
451 P2P_AFTER_SCAN_NOTHING,
452 P2P_AFTER_SCAN_LISTEN,
453 P2P_AFTER_SCAN_CONNECT
454 } start_after_scan;
455 u8 after_scan_peer[ETH_ALEN];
Dmitry Shmidt4582d2a2014-02-28 11:14:23 -0800456 unsigned int send_action_in_progress:1;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700457
458 /* Requested device types for find/search */
459 unsigned int num_req_dev_types;
460 u8 *req_dev_types;
Dmitry Shmidtc5ec7f52012-03-06 16:33:24 -0800461 u8 *find_dev_id;
462 u8 find_dev_id_buf[ETH_ALEN];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700463
Dmitry Shmidtfb79edc2014-01-10 10:45:54 -0800464 struct os_reltime find_start; /* time of last p2p_find start */
Dmitry Shmidtf8623282013-02-20 14:34:59 -0800465
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700466 struct p2p_group **groups;
467 size_t num_groups;
468
469 struct p2p_device *pending_client_disc_go;
470 u8 pending_client_disc_addr[ETH_ALEN];
471 u8 pending_dev_disc_dialog_token;
472 u8 pending_dev_disc_addr[ETH_ALEN];
473 int pending_dev_disc_freq;
474 unsigned int pending_client_disc_freq;
475
476 int ext_listen_only;
477 unsigned int ext_listen_period;
478 unsigned int ext_listen_interval;
479 unsigned int ext_listen_interval_sec;
480 unsigned int ext_listen_interval_usec;
481
482 u8 peer_filter[ETH_ALEN];
483
484 int cross_connect;
485
486 int best_freq_24;
487 int best_freq_5;
488 int best_freq_overall;
Dmitry Shmidt700a1372013-03-15 14:14:44 -0700489 int own_freq_preference;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700490
491 /**
492 * wps_vendor_ext - WPS Vendor Extensions to add
493 */
494 struct wpabuf *wps_vendor_ext[P2P_MAX_WPS_VENDOR_EXT];
Jouni Malinen75ecf522011-06-27 15:19:46 -0700495
496 /*
497 * user_initiated_pd - Whether a PD request is user initiated or not.
498 */
499 u8 user_initiated_pd;
500
501 /*
502 * Keep track of which peer a given PD request was sent to.
503 * Used to raise a timeout alert in case there is no response.
504 */
505 u8 pending_pd_devaddr[ETH_ALEN];
506
507 /*
508 * Retry counter for provision discovery requests when issued
509 * in IDLE state.
510 */
511 int pd_retries;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700512
Dmitry Shmidt051af732013-10-22 13:52:46 -0700513 /**
514 * pd_force_freq - Forced frequency for PD retries or 0 to auto-select
515 *
516 * This is is used during PD retries for join-a-group case to use the
517 * correct operating frequency determined from a BSS entry for the GO.
518 */
519 int pd_force_freq;
520
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700521 u8 go_timeout;
522 u8 client_timeout;
523
524 /* Extra delay in milliseconds between search iterations */
525 unsigned int search_delay;
526 int in_search_delay;
527
Dmitry Shmidt43cb5782014-06-16 16:23:22 -0700528 u8 pending_reg_class;
529 u8 pending_channel;
530 u8 pending_channel_forced;
531
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800532 /* ASP Support */
533 struct p2ps_advertisement *p2ps_adv_list;
534 struct p2ps_provision *p2ps_prov;
535 u8 wild_card_hash[P2PS_HASH_LEN];
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800536 u8 p2ps_seek;
Dmitry Shmidta3dc3092015-06-23 11:21:28 -0700537 u8 p2ps_seek_hash[P2P_MAX_QUERY_HASH * P2PS_HASH_LEN];
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800538 u8 p2ps_seek_count;
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800539
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700540#ifdef CONFIG_WIFI_DISPLAY
541 struct wpabuf *wfd_ie_beacon;
542 struct wpabuf *wfd_ie_probe_req;
543 struct wpabuf *wfd_ie_probe_resp;
544 struct wpabuf *wfd_ie_assoc_req;
545 struct wpabuf *wfd_ie_invitation;
546 struct wpabuf *wfd_ie_prov_disc_req;
547 struct wpabuf *wfd_ie_prov_disc_resp;
548 struct wpabuf *wfd_ie_go_neg;
549 struct wpabuf *wfd_dev_info;
550 struct wpabuf *wfd_assoc_bssid;
551 struct wpabuf *wfd_coupled_sink_info;
Dmitry Shmidtd2986c22017-10-23 14:22:09 -0700552 struct wpabuf *wfd_r2_dev_info;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700553#endif /* CONFIG_WIFI_DISPLAY */
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800554
555 u16 authorized_oob_dev_pw_id;
Dmitry Shmidt2e67f062014-07-16 09:55:28 -0700556
557 struct wpabuf **vendor_elem;
Dmitry Shmidtd80a4012015-11-05 16:35:40 -0800558
Sunil8cd6f4d2022-06-28 18:40:46 +0000559 struct weighted_pcl pref_freq_list[P2P_MAX_PREF_CHANNELS];
Dmitry Shmidtd80a4012015-11-05 16:35:40 -0800560 unsigned int num_pref_freq;
Dmitry Shmidtebd93af2017-02-21 13:40:44 -0800561
562 /* Override option for preferred operating channel in GO Negotiation */
563 u8 override_pref_op_class;
564 u8 override_pref_channel;
Hai Shaloma20dcd72022-02-04 13:43:00 -0800565 bool p2p_6ghz_capable;
566 bool include_6ghz;
567 bool allow_6ghz;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700568};
569
570/**
571 * struct p2p_message - Parsed P2P message (or P2P IE)
572 */
573struct p2p_message {
574 struct wpabuf *p2p_attributes;
575 struct wpabuf *wps_attributes;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700576 struct wpabuf *wfd_subelems;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700577
578 u8 dialog_token;
579
580 const u8 *capability;
581 const u8 *go_intent;
582 const u8 *status;
583 const u8 *listen_channel;
584 const u8 *operating_channel;
585 const u8 *channel_list;
586 u8 channel_list_len;
587 const u8 *config_timeout;
588 const u8 *intended_addr;
589 const u8 *group_bssid;
590 const u8 *invitation_flags;
591
592 const u8 *group_info;
593 size_t group_info_len;
594
595 const u8 *group_id;
596 size_t group_id_len;
597
598 const u8 *device_id;
599
600 const u8 *manageability;
601
602 const u8 *noa;
603 size_t noa_len;
604
605 const u8 *ext_listen_timing;
606
607 const u8 *minor_reason_code;
608
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800609 const u8 *oob_go_neg_channel;
610
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700611 /* P2P Device Info */
612 const u8 *p2p_device_info;
613 size_t p2p_device_info_len;
614 const u8 *p2p_device_addr;
615 const u8 *pri_dev_type;
616 u8 num_sec_dev_types;
Dmitry Shmidt9d9e6022015-04-23 10:34:55 -0700617 char device_name[WPS_DEV_NAME_MAX_LEN + 1];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700618 u16 config_methods;
619
620 /* WPS IE */
621 u16 dev_password_id;
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800622 int dev_password_id_present;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700623 u16 wps_config_methods;
624 const u8 *wps_pri_dev_type;
625 const u8 *wps_sec_dev_type_list;
626 size_t wps_sec_dev_type_list_len;
627 const u8 *wps_vendor_ext[P2P_MAX_WPS_VENDOR_EXT];
628 size_t wps_vendor_ext_len[P2P_MAX_WPS_VENDOR_EXT];
629 const u8 *manufacturer;
630 size_t manufacturer_len;
631 const u8 *model_name;
632 size_t model_name_len;
633 const u8 *model_number;
634 size_t model_number_len;
635 const u8 *serial_number;
636 size_t serial_number_len;
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800637 const u8 *oob_dev_password;
638 size_t oob_dev_password_len;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700639
640 /* DS Parameter Set IE */
641 const u8 *ds_params;
642
643 /* SSID IE */
644 const u8 *ssid;
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800645
646 /* P2PS */
647 u8 service_hash_count;
648 const u8 *service_hash;
649
650 const u8 *session_info;
651 size_t session_info_len;
652
653 const u8 *conn_cap;
654
655 const u8 *adv_id;
656 const u8 *adv_mac;
657
658 const u8 *adv_service_instance;
659 size_t adv_service_instance_len;
660
661 const u8 *session_id;
662 const u8 *session_mac;
663
664 const u8 *feature_cap;
665 size_t feature_cap_len;
666
667 const u8 *persistent_dev;
668 const u8 *persistent_ssid;
669 size_t persistent_ssid_len;
Dmitry Shmidtd80a4012015-11-05 16:35:40 -0800670
671 const u8 *pref_freq_list;
672 size_t pref_freq_list_len;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700673};
674
675
676#define P2P_MAX_GROUP_ENTRIES 50
677
678struct p2p_group_info {
679 unsigned int num_clients;
680 struct p2p_client_info {
681 const u8 *p2p_device_addr;
682 const u8 *p2p_interface_addr;
683 u8 dev_capab;
684 u16 config_methods;
685 const u8 *pri_dev_type;
686 u8 num_sec_dev_types;
687 const u8 *sec_dev_types;
688 const char *dev_name;
689 size_t dev_name_len;
690 } client[P2P_MAX_GROUP_ENTRIES];
691};
692
693
694/* p2p_utils.c */
695int p2p_random(char *buf, size_t len);
Dmitry Shmidt4b060592013-04-29 16:42:49 -0700696int p2p_freq_to_channel(unsigned int freq, u8 *op_class, u8 *channel);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700697void p2p_channels_intersect(const struct p2p_channels *a,
698 const struct p2p_channels *b,
699 struct p2p_channels *res);
Dmitry Shmidt6c0da2b2015-01-05 13:08:17 -0800700void p2p_channels_union_inplace(struct p2p_channels *res,
701 const struct p2p_channels *b);
Dmitry Shmidt68d0e3e2013-10-28 17:59:21 -0700702void p2p_channels_union(const struct p2p_channels *a,
703 const struct p2p_channels *b,
704 struct p2p_channels *res);
705void p2p_channels_remove_freqs(struct p2p_channels *chan,
706 const struct wpa_freq_range_list *list);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700707int p2p_channels_includes(const struct p2p_channels *channels, u8 reg_class,
708 u8 channel);
Dmitry Shmidt4ce9c872013-10-24 11:08:13 -0700709void p2p_channels_dump(struct p2p_data *p2p, const char *title,
710 const struct p2p_channels *chan);
Dmitry Shmidte0e48dc2013-11-18 12:00:06 -0800711int p2p_channel_select(struct p2p_channels *chans, const int *classes,
712 u8 *op_class, u8 *op_channel);
Dmitry Shmidtd11f0192014-03-24 12:09:47 -0700713int p2p_channel_random_social(struct p2p_channels *chans, u8 *op_class,
Hai Shalom74f70d42019-02-11 14:42:39 -0800714 u8 *op_channel,
715 struct wpa_freq_range_list *avoid_list,
716 struct wpa_freq_range_list *disallow_list);
Hai Shaloma20dcd72022-02-04 13:43:00 -0800717void p2p_copy_channels(struct p2p_channels *dst, const struct p2p_channels *src,
718 bool allow_6ghz);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700719
720/* p2p_parse.c */
Dmitry Shmidtd80a4012015-11-05 16:35:40 -0800721void p2p_copy_filter_devname(char *dst, size_t dst_len,
722 const void *src, size_t src_len);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700723int p2p_parse_p2p_ie(const struct wpabuf *buf, struct p2p_message *msg);
724int p2p_parse_ies(const u8 *data, size_t len, struct p2p_message *msg);
725int p2p_parse(const u8 *data, size_t len, struct p2p_message *msg);
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800726int p2p_parse_ies_separate(const u8 *wsc, size_t wsc_len, const u8 *p2p,
727 size_t p2p_len, struct p2p_message *msg);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700728void p2p_parse_free(struct p2p_message *msg);
729int p2p_attr_text(struct wpabuf *data, char *buf, char *end);
730int p2p_group_info_parse(const u8 *gi, size_t gi_len,
731 struct p2p_group_info *info);
732
733/* p2p_build.c */
734
735struct p2p_noa_desc {
736 u8 count_type;
737 u32 duration;
738 u32 interval;
739 u32 start_time;
740};
741
742/* p2p_group.c */
743const u8 * p2p_group_get_interface_addr(struct p2p_group *group);
744u8 p2p_group_presence_req(struct p2p_group *group,
745 const u8 *client_interface_addr,
746 const u8 *noa, size_t noa_len);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700747int p2p_group_is_group_id_match(struct p2p_group *group, const u8 *group_id,
748 size_t group_id_len);
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700749void p2p_group_update_ies(struct p2p_group *group);
Dmitry Shmidtb96dad42013-11-05 10:07:29 -0800750void p2p_group_force_beacon_update_ies(struct p2p_group *group);
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700751struct wpabuf * p2p_group_get_wfd_ie(struct p2p_group *g);
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800752void p2p_buf_add_group_info(struct p2p_group *group, struct wpabuf *buf,
753 int max_clients);
754void p2p_group_buf_add_id(struct p2p_group *group, struct wpabuf *buf);
755int p2p_group_get_freq(struct p2p_group *group);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700756
757
758void p2p_buf_add_action_hdr(struct wpabuf *buf, u8 subtype, u8 dialog_token);
759void p2p_buf_add_public_action_hdr(struct wpabuf *buf, u8 subtype,
760 u8 dialog_token);
761u8 * p2p_buf_add_ie_hdr(struct wpabuf *buf);
762void p2p_buf_add_status(struct wpabuf *buf, u8 status);
763void p2p_buf_add_device_info(struct wpabuf *buf, struct p2p_data *p2p,
764 struct p2p_device *peer);
765void p2p_buf_add_device_id(struct wpabuf *buf, const u8 *dev_addr);
766void p2p_buf_update_ie_hdr(struct wpabuf *buf, u8 *len);
767void p2p_buf_add_capability(struct wpabuf *buf, u8 dev_capab, u8 group_capab);
768void p2p_buf_add_go_intent(struct wpabuf *buf, u8 go_intent);
769void p2p_buf_add_listen_channel(struct wpabuf *buf, const char *country,
770 u8 reg_class, u8 channel);
771void p2p_buf_add_operating_channel(struct wpabuf *buf, const char *country,
772 u8 reg_class, u8 channel);
773void p2p_buf_add_channel_list(struct wpabuf *buf, const char *country,
Sunil8cd6f4d2022-06-28 18:40:46 +0000774 struct p2p_channels *chan, bool is_6ghz_capab);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700775void p2p_buf_add_config_timeout(struct wpabuf *buf, u8 go_timeout,
776 u8 client_timeout);
777void p2p_buf_add_intended_addr(struct wpabuf *buf, const u8 *interface_addr);
778void p2p_buf_add_group_bssid(struct wpabuf *buf, const u8 *bssid);
779void p2p_buf_add_group_id(struct wpabuf *buf, const u8 *dev_addr,
780 const u8 *ssid, size_t ssid_len);
781void p2p_buf_add_invitation_flags(struct wpabuf *buf, u8 flags);
782void p2p_buf_add_noa(struct wpabuf *buf, u8 noa_index, u8 opp_ps, u8 ctwindow,
783 struct p2p_noa_desc *desc1, struct p2p_noa_desc *desc2);
784void p2p_buf_add_ext_listen_timing(struct wpabuf *buf, u16 period,
785 u16 interval);
786void p2p_buf_add_p2p_interface(struct wpabuf *buf, struct p2p_data *p2p);
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800787void p2p_buf_add_oob_go_neg_channel(struct wpabuf *buf, const char *country,
788 u8 oper_class, u8 channel,
789 enum p2p_role_indication role);
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800790void p2p_buf_add_service_hash(struct wpabuf *buf, struct p2p_data *p2p);
791void p2p_buf_add_session_info(struct wpabuf *buf, const char *info);
792void p2p_buf_add_connection_capability(struct wpabuf *buf, u8 connection_cap);
793void p2p_buf_add_advertisement_id(struct wpabuf *buf, u32 id, const u8 *mac);
794void p2p_buf_add_service_instance(struct wpabuf *buf, struct p2p_data *p2p,
795 u8 count, const u8 *hash,
796 struct p2ps_advertisement *adv_list);
797void p2p_buf_add_session_id(struct wpabuf *buf, u32 id, const u8 *mac);
798void p2p_buf_add_feature_capability(struct wpabuf *buf, u16 len,
799 const u8 *mask);
800void p2p_buf_add_persistent_group_info(struct wpabuf *buf, const u8 *dev_addr,
801 const u8 *ssid, size_t ssid_len);
Dmitry Shmidt68d0e3e2013-10-28 17:59:21 -0700802int p2p_build_wps_ie(struct p2p_data *p2p, struct wpabuf *buf, int pw_id,
803 int all_attr);
Dmitry Shmidtd80a4012015-11-05 16:35:40 -0800804void p2p_buf_add_pref_channel_list(struct wpabuf *buf,
Sunil8cd6f4d2022-06-28 18:40:46 +0000805 const struct weighted_pcl *pref_freq_list,
Hai Shaloma20dcd72022-02-04 13:43:00 -0800806 unsigned int size);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700807
808/* p2p_sd.c */
809struct p2p_sd_query * p2p_pending_sd_req(struct p2p_data *p2p,
810 struct p2p_device *dev);
811void p2p_free_sd_queries(struct p2p_data *p2p);
812void p2p_rx_gas_initial_req(struct p2p_data *p2p, const u8 *sa,
813 const u8 *data, size_t len, int rx_freq);
814void p2p_rx_gas_initial_resp(struct p2p_data *p2p, const u8 *sa,
815 const u8 *data, size_t len, int rx_freq);
816void p2p_rx_gas_comeback_req(struct p2p_data *p2p, const u8 *sa,
817 const u8 *data, size_t len, int rx_freq);
818void p2p_rx_gas_comeback_resp(struct p2p_data *p2p, const u8 *sa,
819 const u8 *data, size_t len, int rx_freq);
820int p2p_start_sd(struct p2p_data *p2p, struct p2p_device *dev);
821
822/* p2p_go_neg.c */
823int p2p_peer_channels_check(struct p2p_data *p2p, struct p2p_channels *own,
824 struct p2p_device *dev,
825 const u8 *channel_list, size_t channel_list_len);
826void p2p_process_go_neg_req(struct p2p_data *p2p, const u8 *sa,
827 const u8 *data, size_t len, int rx_freq);
828void p2p_process_go_neg_resp(struct p2p_data *p2p, const u8 *sa,
829 const u8 *data, size_t len, int rx_freq);
830void p2p_process_go_neg_conf(struct p2p_data *p2p, const u8 *sa,
831 const u8 *data, size_t len);
832int p2p_connect_send(struct p2p_data *p2p, struct p2p_device *dev);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700833u16 p2p_wps_method_pw_id(enum p2p_wps_method wps_method);
Dmitry Shmidt91c40cd2012-09-25 14:23:53 -0700834void p2p_reselect_channel(struct p2p_data *p2p,
835 struct p2p_channels *intersection);
Dmitry Shmidtd80a4012015-11-05 16:35:40 -0800836void p2p_check_pref_chan(struct p2p_data *p2p, int go,
837 struct p2p_device *dev, struct p2p_message *msg);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700838
839/* p2p_pd.c */
840void p2p_process_prov_disc_req(struct p2p_data *p2p, const u8 *sa,
841 const u8 *data, size_t len, int rx_freq);
842void p2p_process_prov_disc_resp(struct p2p_data *p2p, const u8 *sa,
843 const u8 *data, size_t len);
844int p2p_send_prov_disc_req(struct p2p_data *p2p, struct p2p_device *dev,
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800845 int join, int force_freq);
Jouni Malinen75ecf522011-06-27 15:19:46 -0700846void p2p_reset_pending_pd(struct p2p_data *p2p);
Dmitry Shmidta3dc3092015-06-23 11:21:28 -0700847void p2ps_prov_free(struct p2p_data *p2p);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700848
849/* p2p_invitation.c */
850void p2p_process_invitation_req(struct p2p_data *p2p, const u8 *sa,
851 const u8 *data, size_t len, int rx_freq);
852void p2p_process_invitation_resp(struct p2p_data *p2p, const u8 *sa,
853 const u8 *data, size_t len);
854int p2p_invite_send(struct p2p_data *p2p, struct p2p_device *dev,
Dmitry Shmidtcf32e602014-01-28 10:57:39 -0800855 const u8 *go_dev_addr, int dev_pw_id);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700856void p2p_invitation_req_cb(struct p2p_data *p2p, int success);
857void p2p_invitation_resp_cb(struct p2p_data *p2p, int success);
858
859/* p2p_dev_disc.c */
860void p2p_process_dev_disc_req(struct p2p_data *p2p, const u8 *sa,
861 const u8 *data, size_t len, int rx_freq);
862void p2p_dev_disc_req_cb(struct p2p_data *p2p, int success);
863int p2p_send_dev_disc_req(struct p2p_data *p2p, struct p2p_device *dev);
864void p2p_dev_disc_resp_cb(struct p2p_data *p2p, int success);
865void p2p_process_dev_disc_resp(struct p2p_data *p2p, const u8 *sa,
866 const u8 *data, size_t len);
867void p2p_go_disc_req_cb(struct p2p_data *p2p, int success);
868void p2p_process_go_disc_req(struct p2p_data *p2p, const u8 *da, const u8 *sa,
869 const u8 *data, size_t len, int rx_freq);
870
871/* p2p.c */
872void p2p_set_state(struct p2p_data *p2p, int new_state);
873void p2p_set_timeout(struct p2p_data *p2p, unsigned int sec,
874 unsigned int usec);
875void p2p_clear_timeout(struct p2p_data *p2p);
876void p2p_continue_find(struct p2p_data *p2p);
877struct p2p_device * p2p_add_dev_from_go_neg_req(struct p2p_data *p2p,
878 const u8 *addr,
879 struct p2p_message *msg);
Sunil Ravi38ad1ed2023-01-17 23:58:31 +0000880void p2p_update_peer_6ghz_capab(struct p2p_device *dev,
881 const struct p2p_message *msg);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700882void p2p_add_dev_info(struct p2p_data *p2p, const u8 *addr,
883 struct p2p_device *dev, struct p2p_message *msg);
Dmitry Shmidta54fa5f2013-01-15 13:53:35 -0800884int p2p_add_device(struct p2p_data *p2p, const u8 *addr, int freq,
Dmitry Shmidtfb79edc2014-01-10 10:45:54 -0800885 struct os_reltime *rx_time, int level, const u8 *ies,
Dmitry Shmidta54fa5f2013-01-15 13:53:35 -0800886 size_t ies_len, int scan_res);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700887struct p2p_device * p2p_get_device(struct p2p_data *p2p, const u8 *addr);
888struct p2p_device * p2p_get_device_interface(struct p2p_data *p2p,
889 const u8 *addr);
Dmitry Shmidt6c0da2b2015-01-05 13:08:17 -0800890void p2p_go_neg_failed(struct p2p_data *p2p, int status);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700891void p2p_go_complete(struct p2p_data *p2p, struct p2p_device *peer);
892int p2p_match_dev_type(struct p2p_data *p2p, struct wpabuf *wps);
893int dev_type_list_match(const u8 *dev_type, const u8 *req_dev_type[],
894 size_t num_req_dev_type);
Dmitry Shmidta3dc3092015-06-23 11:21:28 -0700895struct wpabuf * p2p_build_probe_resp_ies(struct p2p_data *p2p,
896 const u8 *query_hash,
897 u8 query_count);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700898void p2p_build_ssid(struct p2p_data *p2p, u8 *ssid, size_t *ssid_len);
899int p2p_send_action(struct p2p_data *p2p, unsigned int freq, const u8 *dst,
900 const u8 *src, const u8 *bssid, const u8 *buf,
901 size_t len, unsigned int wait_time);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700902void p2p_stop_listen_for_freq(struct p2p_data *p2p, int freq);
Dmitry Shmidt7a5e50a2013-03-05 12:37:16 -0800903int p2p_prepare_channel(struct p2p_data *p2p, struct p2p_device *dev,
Dmitry Shmidt68d0e3e2013-10-28 17:59:21 -0700904 unsigned int force_freq, unsigned int pref_freq,
905 int go);
Dmitry Shmidt6c0da2b2015-01-05 13:08:17 -0800906void p2p_go_neg_wait_timeout(void *eloop_ctx, void *timeout_ctx);
Dmitry Shmidt216983b2015-02-06 10:50:36 -0800907int p2p_go_select_channel(struct p2p_data *p2p, struct p2p_device *dev,
908 u8 *status);
Sunil8cd6f4d2022-06-28 18:40:46 +0000909void p2p_pref_channel_filter(const struct p2p_channels *a,
910 const struct weighted_pcl *freq_list,
911 unsigned int num_channels,
912 struct p2p_channels *res, bool go);
Sunil Ravi7f769292024-07-23 22:21:32 +0000913
914void p2p_sd_query_cb(struct p2p_data *p2p, int success);
915
Dmitry Shmidtb6e9aaf2013-05-20 14:49:44 -0700916void p2p_dbg(struct p2p_data *p2p, const char *fmt, ...)
917PRINTF_FORMAT(2, 3);
918void p2p_info(struct p2p_data *p2p, const char *fmt, ...)
919PRINTF_FORMAT(2, 3);
920void p2p_err(struct p2p_data *p2p, const char *fmt, ...)
921PRINTF_FORMAT(2, 3);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700922
923#endif /* P2P_I_H */