blob: f323ef72e28ee9e301d67695ead72156c539c594 [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"
13#include "p2p.h"
14
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070015enum p2p_go_state {
16 UNKNOWN_GO,
17 LOCAL_GO,
18 REMOTE_GO
19};
20
21/**
22 * struct p2p_device - P2P Device data (internal to P2P module)
23 */
24struct p2p_device {
25 struct dl_list list;
26 struct os_time last_seen;
27 int listen_freq;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070028 enum p2p_wps_method wps_method;
29
30 struct p2p_peer_info info;
31
32 /*
33 * If the peer was discovered based on an interface address (e.g., GO
34 * from Beacon/Probe Response), the interface address is stored here.
35 * p2p_device_addr must still be set in such a case to the unique
36 * identifier for the P2P Device.
37 */
38 u8 interface_addr[ETH_ALEN];
39
40 /*
41 * P2P Device Address of the GO in whose group this P2P Device is a
42 * client.
43 */
44 u8 member_in_go_dev[ETH_ALEN];
45
46 /*
47 * P2P Interface Address of the GO in whose group this P2P Device is a
48 * client.
49 */
50 u8 member_in_go_iface[ETH_ALEN];
51
52 int go_neg_req_sent;
53 enum p2p_go_state go_state;
54 u8 dialog_token;
Dmitry Shmidt9cdf1b92013-02-27 12:58:50 -080055 u8 tie_breaker;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070056 u8 intended_addr[ETH_ALEN];
57
58 char country[3];
59 struct p2p_channels channels;
60 int oper_freq;
61 u8 oper_ssid[32];
62 size_t oper_ssid_len;
63
64 /**
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080065 * req_config_methods - Pending provision discovery methods
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070066 */
67 u16 req_config_methods;
68
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080069 /**
70 * wps_prov_info - Stored provisioning WPS config method
71 *
72 * This is used to store pending WPS config method between Provisioning
73 * Discovery and connection to a running group.
74 */
75 u16 wps_prov_info;
76
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070077#define P2P_DEV_PROBE_REQ_ONLY BIT(0)
78#define P2P_DEV_REPORTED BIT(1)
79#define P2P_DEV_NOT_YET_READY BIT(2)
80#define P2P_DEV_SD_INFO BIT(3)
81#define P2P_DEV_SD_SCHEDULE BIT(4)
82#define P2P_DEV_PD_PEER_DISPLAY BIT(5)
83#define P2P_DEV_PD_PEER_KEYPAD BIT(6)
84#define P2P_DEV_USER_REJECTED BIT(7)
85#define P2P_DEV_PEER_WAITING_RESPONSE BIT(8)
86#define P2P_DEV_PREFER_PERSISTENT_GROUP BIT(9)
87#define P2P_DEV_WAIT_GO_NEG_RESPONSE BIT(10)
88#define P2P_DEV_WAIT_GO_NEG_CONFIRM BIT(11)
89#define P2P_DEV_GROUP_CLIENT_ONLY BIT(12)
90#define P2P_DEV_FORCE_FREQ BIT(13)
91#define P2P_DEV_PD_FOR_JOIN BIT(14)
92#define P2P_DEV_REPORTED_ONCE BIT(15)
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080093#define P2P_DEV_PREFER_PERSISTENT_RECONN BIT(16)
Dmitry Shmidt04949592012-07-19 12:16:46 -070094#define P2P_DEV_PD_BEFORE_GO_NEG BIT(17)
Dmitry Shmidt7a5e50a2013-03-05 12:37:16 -080095#define P2P_DEV_NO_PREF_CHAN BIT(18)
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070096 unsigned int flags;
97
98 int status; /* enum p2p_status_code */
99 unsigned int wait_count;
100 unsigned int connect_reqs;
101 unsigned int invitation_reqs;
102
103 u16 ext_listen_period;
104 u16 ext_listen_interval;
105
106 u8 go_timeout;
107 u8 client_timeout;
108};
109
110struct p2p_sd_query {
111 struct p2p_sd_query *next;
112 u8 peer[ETH_ALEN];
113 int for_all_peers;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700114 int wsd; /* Wi-Fi Display Service Discovery Request */
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700115 struct wpabuf *tlvs;
116};
117
118struct p2p_pending_action_tx {
119 unsigned int freq;
120 u8 dst[ETH_ALEN];
121 u8 src[ETH_ALEN];
122 u8 bssid[ETH_ALEN];
123 size_t len;
124 unsigned int wait_time;
125 /* Followed by len octets of the frame */
126};
127
128/**
129 * struct p2p_data - P2P module data (internal to P2P module)
130 */
131struct p2p_data {
132 /**
133 * cfg - P2P module configuration
134 *
135 * This is included in the same memory allocation with the
136 * struct p2p_data and as such, must not be freed separately.
137 */
138 struct p2p_config *cfg;
139
140 /**
141 * state - The current P2P state
142 */
143 enum p2p_state {
144 /**
145 * P2P_IDLE - Idle
146 */
147 P2P_IDLE,
148
149 /**
150 * P2P_SEARCH - Search (Device Discovery)
151 */
152 P2P_SEARCH,
153
154 /**
155 * P2P_CONNECT - Trying to start GO Negotiation
156 */
157 P2P_CONNECT,
158
159 /**
160 * P2P_CONNECT_LISTEN - Listen during GO Negotiation start
161 */
162 P2P_CONNECT_LISTEN,
163
164 /**
165 * P2P_GO_NEG - In GO Negotiation
166 */
167 P2P_GO_NEG,
168
169 /**
170 * P2P_LISTEN_ONLY - Listen only
171 */
172 P2P_LISTEN_ONLY,
173
174 /**
175 * P2P_WAIT_PEER_CONNECT - Waiting peer in List for GO Neg
176 */
177 P2P_WAIT_PEER_CONNECT,
178
179 /**
180 * P2P_WAIT_PEER_IDLE - Waiting peer idle for GO Neg
181 */
182 P2P_WAIT_PEER_IDLE,
183
184 /**
185 * P2P_SD_DURING_FIND - Service Discovery during find
186 */
187 P2P_SD_DURING_FIND,
188
189 /**
190 * P2P_PROVISIONING - Provisioning (during group formation)
191 */
192 P2P_PROVISIONING,
193
194 /**
195 * P2P_PD_DURING_FIND - Provision Discovery during find
196 */
197 P2P_PD_DURING_FIND,
198
199 /**
200 * P2P_INVITE - Trying to start Invite
201 */
202 P2P_INVITE,
203
204 /**
205 * P2P_INVITE_LISTEN - Listen during Invite
206 */
207 P2P_INVITE_LISTEN,
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800208
209 /**
210 * P2P_SEARCH_WHEN_READY - Waiting to start Search
211 */
212 P2P_SEARCH_WHEN_READY,
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700213
214 /**
215 * P2P_CONTINUE_SEARCH_WHEN_READY - Waiting to continue Search
216 */
217 P2P_CONTINUE_SEARCH_WHEN_READY,
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700218 } state;
219
220 /**
221 * min_disc_int - minDiscoverableInterval
222 */
223 int min_disc_int;
224
225 /**
226 * max_disc_int - maxDiscoverableInterval
227 */
228 int max_disc_int;
229
230 /**
Dmitry Shmidtd5e49232012-12-03 15:08:10 -0800231 * max_disc_tu - Maximum number of TUs for discoverable interval
232 */
233 int max_disc_tu;
234
235 /**
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700236 * devices - List of known P2P Device peers
237 */
238 struct dl_list devices;
239
Irfan Sherifff44b9c42012-06-13 11:09:23 -0700240#ifdef ANDROID_P2P
241 /**
242 * sd_dev_list - device pointer to be serviced next
243 * for service discovery
244 */
245 struct dl_list *sd_dev_list;
246#endif
247
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700248 /**
249 * go_neg_peer - Pointer to GO Negotiation peer
250 */
251 struct p2p_device *go_neg_peer;
252
253 /**
254 * invite_peer - Pointer to Invite peer
255 */
256 struct p2p_device *invite_peer;
257
258 const u8 *invite_go_dev_addr;
259 u8 invite_go_dev_addr_buf[ETH_ALEN];
260
261 /**
262 * sd_peer - Pointer to Service Discovery peer
263 */
264 struct p2p_device *sd_peer;
265
266 /**
267 * sd_query - Pointer to Service Discovery query
268 */
269 struct p2p_sd_query *sd_query;
270
271 /* GO Negotiation data */
272
273 /**
274 * intended_addr - Local Intended P2P Interface Address
275 *
276 * This address is used during group owner negotiation as the Intended
277 * P2P Interface Address and the group interface will be created with
278 * address as the local address in case of successfully completed
279 * negotiation.
280 */
281 u8 intended_addr[ETH_ALEN];
282
283 /**
284 * go_intent - Local GO Intent to be used during GO Negotiation
285 */
286 u8 go_intent;
287
288 /**
289 * next_tie_breaker - Next tie-breaker value to use in GO Negotiation
290 */
291 u8 next_tie_breaker;
292
293 /**
294 * ssid - Selected SSID for GO Negotiation (if local end will be GO)
295 */
296 u8 ssid[32];
297
298 /**
299 * ssid_len - ssid length in octets
300 */
301 size_t ssid_len;
302
303 /**
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800304 * ssid_set - Whether SSID is already set for GO Negotiation
305 */
306 int ssid_set;
307
308 /**
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700309 * Regulatory class for own operational channel
310 */
311 u8 op_reg_class;
312
313 /**
314 * op_channel - Own operational channel
315 */
316 u8 op_channel;
317
318 /**
319 * channels - Own supported regulatory classes and channels
320 *
321 * List of supposerted channels per regulatory class. The regulatory
322 * classes are defined in IEEE Std 802.11-2007 Annex J and the
323 * numbering of the clases depends on the configured country code.
324 */
325 struct p2p_channels channels;
326
327 enum p2p_pending_action_state {
328 P2P_NO_PENDING_ACTION,
329 P2P_PENDING_GO_NEG_REQUEST,
330 P2P_PENDING_GO_NEG_RESPONSE,
331 P2P_PENDING_GO_NEG_RESPONSE_FAILURE,
332 P2P_PENDING_GO_NEG_CONFIRM,
333 P2P_PENDING_SD,
334 P2P_PENDING_PD,
335 P2P_PENDING_INVITATION_REQUEST,
336 P2P_PENDING_INVITATION_RESPONSE,
337 P2P_PENDING_DEV_DISC_REQUEST,
338 P2P_PENDING_DEV_DISC_RESPONSE,
339 P2P_PENDING_GO_DISC_REQ
340 } pending_action_state;
341
342 unsigned int pending_listen_freq;
343 unsigned int pending_listen_sec;
344 unsigned int pending_listen_usec;
345
346 u8 dev_capab;
347
348 int in_listen;
349 int drv_in_listen;
350
351 /**
352 * sd_queries - Pending service discovery queries
353 */
354 struct p2p_sd_query *sd_queries;
355
356 /**
357 * srv_update_indic - Service Update Indicator for local services
358 */
359 u16 srv_update_indic;
Dmitry Shmidteaf261d2013-08-14 15:30:08 -0700360
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700361 struct wpabuf *sd_resp; /* Fragmented SD response */
362 u8 sd_resp_addr[ETH_ALEN];
363 u8 sd_resp_dialog_token;
364 size_t sd_resp_pos; /* Offset in sd_resp */
365 u8 sd_frag_id;
366
367 struct wpabuf *sd_rx_resp; /* Reassembled SD response */
368 u16 sd_rx_update_indic;
369
370 /* P2P Invitation data */
371 enum p2p_invite_role inv_role;
372 u8 inv_bssid[ETH_ALEN];
373 int inv_bssid_set;
374 u8 inv_ssid[32];
375 size_t inv_ssid_len;
376 u8 inv_sa[ETH_ALEN];
377 u8 inv_group_bssid[ETH_ALEN];
378 u8 *inv_group_bssid_ptr;
379 u8 inv_go_dev_addr[ETH_ALEN];
380 u8 inv_status;
381 int inv_op_freq;
382 int inv_persistent;
383
384 enum p2p_discovery_type find_type;
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800385 unsigned int last_p2p_find_timeout;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700386 u8 last_prog_scan_class;
387 u8 last_prog_scan_chan;
388 int p2p_scan_running;
389 enum p2p_after_scan {
390 P2P_AFTER_SCAN_NOTHING,
391 P2P_AFTER_SCAN_LISTEN,
392 P2P_AFTER_SCAN_CONNECT
393 } start_after_scan;
394 u8 after_scan_peer[ETH_ALEN];
395 struct p2p_pending_action_tx *after_scan_tx;
Dmitry Shmidt8da800a2013-04-24 12:57:01 -0700396 unsigned int after_scan_tx_in_progress:1;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700397
398 /* Requested device types for find/search */
399 unsigned int num_req_dev_types;
400 u8 *req_dev_types;
Dmitry Shmidtc5ec7f52012-03-06 16:33:24 -0800401 u8 *find_dev_id;
402 u8 find_dev_id_buf[ETH_ALEN];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700403
Dmitry Shmidtf8623282013-02-20 14:34:59 -0800404 struct os_time find_start; /* time of last p2p_find start */
405
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700406 struct p2p_group **groups;
407 size_t num_groups;
408
409 struct p2p_device *pending_client_disc_go;
410 u8 pending_client_disc_addr[ETH_ALEN];
411 u8 pending_dev_disc_dialog_token;
412 u8 pending_dev_disc_addr[ETH_ALEN];
413 int pending_dev_disc_freq;
414 unsigned int pending_client_disc_freq;
415
416 int ext_listen_only;
417 unsigned int ext_listen_period;
418 unsigned int ext_listen_interval;
419 unsigned int ext_listen_interval_sec;
420 unsigned int ext_listen_interval_usec;
421
422 u8 peer_filter[ETH_ALEN];
423
424 int cross_connect;
425
426 int best_freq_24;
427 int best_freq_5;
428 int best_freq_overall;
Dmitry Shmidt700a1372013-03-15 14:14:44 -0700429 int own_freq_preference;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700430
431 /**
432 * wps_vendor_ext - WPS Vendor Extensions to add
433 */
434 struct wpabuf *wps_vendor_ext[P2P_MAX_WPS_VENDOR_EXT];
Jouni Malinen75ecf522011-06-27 15:19:46 -0700435
436 /*
437 * user_initiated_pd - Whether a PD request is user initiated or not.
438 */
439 u8 user_initiated_pd;
440
441 /*
442 * Keep track of which peer a given PD request was sent to.
443 * Used to raise a timeout alert in case there is no response.
444 */
445 u8 pending_pd_devaddr[ETH_ALEN];
446
447 /*
448 * Retry counter for provision discovery requests when issued
449 * in IDLE state.
450 */
451 int pd_retries;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700452
Dmitry Shmidt051af732013-10-22 13:52:46 -0700453 /**
454 * pd_force_freq - Forced frequency for PD retries or 0 to auto-select
455 *
456 * This is is used during PD retries for join-a-group case to use the
457 * correct operating frequency determined from a BSS entry for the GO.
458 */
459 int pd_force_freq;
460
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700461 u8 go_timeout;
462 u8 client_timeout;
463
464 /* Extra delay in milliseconds between search iterations */
465 unsigned int search_delay;
466 int in_search_delay;
467
468#ifdef CONFIG_WIFI_DISPLAY
469 struct wpabuf *wfd_ie_beacon;
470 struct wpabuf *wfd_ie_probe_req;
471 struct wpabuf *wfd_ie_probe_resp;
472 struct wpabuf *wfd_ie_assoc_req;
473 struct wpabuf *wfd_ie_invitation;
474 struct wpabuf *wfd_ie_prov_disc_req;
475 struct wpabuf *wfd_ie_prov_disc_resp;
476 struct wpabuf *wfd_ie_go_neg;
477 struct wpabuf *wfd_dev_info;
478 struct wpabuf *wfd_assoc_bssid;
479 struct wpabuf *wfd_coupled_sink_info;
480#endif /* CONFIG_WIFI_DISPLAY */
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700481};
482
483/**
484 * struct p2p_message - Parsed P2P message (or P2P IE)
485 */
486struct p2p_message {
487 struct wpabuf *p2p_attributes;
488 struct wpabuf *wps_attributes;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700489 struct wpabuf *wfd_subelems;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700490
491 u8 dialog_token;
492
493 const u8 *capability;
494 const u8 *go_intent;
495 const u8 *status;
496 const u8 *listen_channel;
497 const u8 *operating_channel;
498 const u8 *channel_list;
499 u8 channel_list_len;
500 const u8 *config_timeout;
501 const u8 *intended_addr;
502 const u8 *group_bssid;
503 const u8 *invitation_flags;
504
505 const u8 *group_info;
506 size_t group_info_len;
507
508 const u8 *group_id;
509 size_t group_id_len;
510
511 const u8 *device_id;
512
513 const u8 *manageability;
514
515 const u8 *noa;
516 size_t noa_len;
517
518 const u8 *ext_listen_timing;
519
520 const u8 *minor_reason_code;
521
522 /* P2P Device Info */
523 const u8 *p2p_device_info;
524 size_t p2p_device_info_len;
525 const u8 *p2p_device_addr;
526 const u8 *pri_dev_type;
527 u8 num_sec_dev_types;
528 char device_name[33];
529 u16 config_methods;
530
531 /* WPS IE */
532 u16 dev_password_id;
533 u16 wps_config_methods;
534 const u8 *wps_pri_dev_type;
535 const u8 *wps_sec_dev_type_list;
536 size_t wps_sec_dev_type_list_len;
537 const u8 *wps_vendor_ext[P2P_MAX_WPS_VENDOR_EXT];
538 size_t wps_vendor_ext_len[P2P_MAX_WPS_VENDOR_EXT];
539 const u8 *manufacturer;
540 size_t manufacturer_len;
541 const u8 *model_name;
542 size_t model_name_len;
543 const u8 *model_number;
544 size_t model_number_len;
545 const u8 *serial_number;
546 size_t serial_number_len;
547
548 /* DS Parameter Set IE */
549 const u8 *ds_params;
550
551 /* SSID IE */
552 const u8 *ssid;
553};
554
555
556#define P2P_MAX_GROUP_ENTRIES 50
557
558struct p2p_group_info {
559 unsigned int num_clients;
560 struct p2p_client_info {
561 const u8 *p2p_device_addr;
562 const u8 *p2p_interface_addr;
563 u8 dev_capab;
564 u16 config_methods;
565 const u8 *pri_dev_type;
566 u8 num_sec_dev_types;
567 const u8 *sec_dev_types;
568 const char *dev_name;
569 size_t dev_name_len;
570 } client[P2P_MAX_GROUP_ENTRIES];
571};
572
573
574/* p2p_utils.c */
575int p2p_random(char *buf, size_t len);
Dmitry Shmidt4b060592013-04-29 16:42:49 -0700576int p2p_channel_to_freq(int op_class, int channel);
577int p2p_freq_to_channel(unsigned int freq, u8 *op_class, u8 *channel);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700578void p2p_channels_intersect(const struct p2p_channels *a,
579 const struct p2p_channels *b,
580 struct p2p_channels *res);
581int p2p_channels_includes(const struct p2p_channels *channels, u8 reg_class,
582 u8 channel);
Dmitry Shmidtedcc8d62013-10-08 13:56:42 -0700583#ifdef ANDROID_P2P
584size_t p2p_copy_reg_class(struct p2p_reg_class *dc, struct p2p_reg_class *sc);
585#endif
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700586
587/* p2p_parse.c */
588int p2p_parse_p2p_ie(const struct wpabuf *buf, struct p2p_message *msg);
589int p2p_parse_ies(const u8 *data, size_t len, struct p2p_message *msg);
590int p2p_parse(const u8 *data, size_t len, struct p2p_message *msg);
591void p2p_parse_free(struct p2p_message *msg);
592int p2p_attr_text(struct wpabuf *data, char *buf, char *end);
593int p2p_group_info_parse(const u8 *gi, size_t gi_len,
594 struct p2p_group_info *info);
595
596/* p2p_build.c */
597
598struct p2p_noa_desc {
599 u8 count_type;
600 u32 duration;
601 u32 interval;
602 u32 start_time;
603};
604
605/* p2p_group.c */
606const u8 * p2p_group_get_interface_addr(struct p2p_group *group);
607u8 p2p_group_presence_req(struct p2p_group *group,
608 const u8 *client_interface_addr,
609 const u8 *noa, size_t noa_len);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700610int p2p_group_is_group_id_match(struct p2p_group *group, const u8 *group_id,
611 size_t group_id_len);
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700612void p2p_group_update_ies(struct p2p_group *group);
613struct wpabuf * p2p_group_get_wfd_ie(struct p2p_group *g);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700614
615
616void p2p_buf_add_action_hdr(struct wpabuf *buf, u8 subtype, u8 dialog_token);
617void p2p_buf_add_public_action_hdr(struct wpabuf *buf, u8 subtype,
618 u8 dialog_token);
619u8 * p2p_buf_add_ie_hdr(struct wpabuf *buf);
620void p2p_buf_add_status(struct wpabuf *buf, u8 status);
621void p2p_buf_add_device_info(struct wpabuf *buf, struct p2p_data *p2p,
622 struct p2p_device *peer);
623void p2p_buf_add_device_id(struct wpabuf *buf, const u8 *dev_addr);
624void p2p_buf_update_ie_hdr(struct wpabuf *buf, u8 *len);
625void p2p_buf_add_capability(struct wpabuf *buf, u8 dev_capab, u8 group_capab);
626void p2p_buf_add_go_intent(struct wpabuf *buf, u8 go_intent);
627void p2p_buf_add_listen_channel(struct wpabuf *buf, const char *country,
628 u8 reg_class, u8 channel);
629void p2p_buf_add_operating_channel(struct wpabuf *buf, const char *country,
630 u8 reg_class, u8 channel);
631void p2p_buf_add_channel_list(struct wpabuf *buf, const char *country,
632 struct p2p_channels *chan);
633void p2p_buf_add_config_timeout(struct wpabuf *buf, u8 go_timeout,
634 u8 client_timeout);
635void p2p_buf_add_intended_addr(struct wpabuf *buf, const u8 *interface_addr);
636void p2p_buf_add_group_bssid(struct wpabuf *buf, const u8 *bssid);
637void p2p_buf_add_group_id(struct wpabuf *buf, const u8 *dev_addr,
638 const u8 *ssid, size_t ssid_len);
639void p2p_buf_add_invitation_flags(struct wpabuf *buf, u8 flags);
640void p2p_buf_add_noa(struct wpabuf *buf, u8 noa_index, u8 opp_ps, u8 ctwindow,
641 struct p2p_noa_desc *desc1, struct p2p_noa_desc *desc2);
642void p2p_buf_add_ext_listen_timing(struct wpabuf *buf, u16 period,
643 u16 interval);
644void p2p_buf_add_p2p_interface(struct wpabuf *buf, struct p2p_data *p2p);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700645void p2p_build_wps_ie(struct p2p_data *p2p, struct wpabuf *buf, int pw_id,
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700646 int all_attr);
647
648/* p2p_sd.c */
649struct p2p_sd_query * p2p_pending_sd_req(struct p2p_data *p2p,
650 struct p2p_device *dev);
651void p2p_free_sd_queries(struct p2p_data *p2p);
652void p2p_rx_gas_initial_req(struct p2p_data *p2p, const u8 *sa,
653 const u8 *data, size_t len, int rx_freq);
654void p2p_rx_gas_initial_resp(struct p2p_data *p2p, const u8 *sa,
655 const u8 *data, size_t len, int rx_freq);
656void p2p_rx_gas_comeback_req(struct p2p_data *p2p, const u8 *sa,
657 const u8 *data, size_t len, int rx_freq);
658void p2p_rx_gas_comeback_resp(struct p2p_data *p2p, const u8 *sa,
659 const u8 *data, size_t len, int rx_freq);
660int p2p_start_sd(struct p2p_data *p2p, struct p2p_device *dev);
661
662/* p2p_go_neg.c */
663int p2p_peer_channels_check(struct p2p_data *p2p, struct p2p_channels *own,
664 struct p2p_device *dev,
665 const u8 *channel_list, size_t channel_list_len);
666void p2p_process_go_neg_req(struct p2p_data *p2p, const u8 *sa,
667 const u8 *data, size_t len, int rx_freq);
668void p2p_process_go_neg_resp(struct p2p_data *p2p, const u8 *sa,
669 const u8 *data, size_t len, int rx_freq);
670void p2p_process_go_neg_conf(struct p2p_data *p2p, const u8 *sa,
671 const u8 *data, size_t len);
672int p2p_connect_send(struct p2p_data *p2p, struct p2p_device *dev);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700673u16 p2p_wps_method_pw_id(enum p2p_wps_method wps_method);
Dmitry Shmidt91c40cd2012-09-25 14:23:53 -0700674void p2p_reselect_channel(struct p2p_data *p2p,
675 struct p2p_channels *intersection);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700676
677/* p2p_pd.c */
678void p2p_process_prov_disc_req(struct p2p_data *p2p, const u8 *sa,
679 const u8 *data, size_t len, int rx_freq);
680void p2p_process_prov_disc_resp(struct p2p_data *p2p, const u8 *sa,
681 const u8 *data, size_t len);
682int p2p_send_prov_disc_req(struct p2p_data *p2p, struct p2p_device *dev,
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800683 int join, int force_freq);
Jouni Malinen75ecf522011-06-27 15:19:46 -0700684void p2p_reset_pending_pd(struct p2p_data *p2p);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700685
686/* p2p_invitation.c */
687void p2p_process_invitation_req(struct p2p_data *p2p, const u8 *sa,
688 const u8 *data, size_t len, int rx_freq);
689void p2p_process_invitation_resp(struct p2p_data *p2p, const u8 *sa,
690 const u8 *data, size_t len);
691int p2p_invite_send(struct p2p_data *p2p, struct p2p_device *dev,
692 const u8 *go_dev_addr);
693void p2p_invitation_req_cb(struct p2p_data *p2p, int success);
694void p2p_invitation_resp_cb(struct p2p_data *p2p, int success);
695
696/* p2p_dev_disc.c */
697void p2p_process_dev_disc_req(struct p2p_data *p2p, const u8 *sa,
698 const u8 *data, size_t len, int rx_freq);
699void p2p_dev_disc_req_cb(struct p2p_data *p2p, int success);
700int p2p_send_dev_disc_req(struct p2p_data *p2p, struct p2p_device *dev);
701void p2p_dev_disc_resp_cb(struct p2p_data *p2p, int success);
702void p2p_process_dev_disc_resp(struct p2p_data *p2p, const u8 *sa,
703 const u8 *data, size_t len);
704void p2p_go_disc_req_cb(struct p2p_data *p2p, int success);
705void p2p_process_go_disc_req(struct p2p_data *p2p, const u8 *da, const u8 *sa,
706 const u8 *data, size_t len, int rx_freq);
707
708/* p2p.c */
709void p2p_set_state(struct p2p_data *p2p, int new_state);
710void p2p_set_timeout(struct p2p_data *p2p, unsigned int sec,
711 unsigned int usec);
712void p2p_clear_timeout(struct p2p_data *p2p);
713void p2p_continue_find(struct p2p_data *p2p);
714struct p2p_device * p2p_add_dev_from_go_neg_req(struct p2p_data *p2p,
715 const u8 *addr,
716 struct p2p_message *msg);
717void p2p_add_dev_info(struct p2p_data *p2p, const u8 *addr,
718 struct p2p_device *dev, struct p2p_message *msg);
Dmitry Shmidta54fa5f2013-01-15 13:53:35 -0800719int p2p_add_device(struct p2p_data *p2p, const u8 *addr, int freq,
Dmitry Shmidtf8623282013-02-20 14:34:59 -0800720 struct os_time *rx_time, int level, const u8 *ies,
Dmitry Shmidta54fa5f2013-01-15 13:53:35 -0800721 size_t ies_len, int scan_res);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700722struct p2p_device * p2p_get_device(struct p2p_data *p2p, const u8 *addr);
723struct p2p_device * p2p_get_device_interface(struct p2p_data *p2p,
724 const u8 *addr);
725void p2p_go_neg_failed(struct p2p_data *p2p, struct p2p_device *peer,
726 int status);
727void p2p_go_complete(struct p2p_data *p2p, struct p2p_device *peer);
728int p2p_match_dev_type(struct p2p_data *p2p, struct wpabuf *wps);
729int dev_type_list_match(const u8 *dev_type, const u8 *req_dev_type[],
730 size_t num_req_dev_type);
731struct wpabuf * p2p_build_probe_resp_ies(struct p2p_data *p2p);
732void p2p_build_ssid(struct p2p_data *p2p, u8 *ssid, size_t *ssid_len);
733int p2p_send_action(struct p2p_data *p2p, unsigned int freq, const u8 *dst,
734 const u8 *src, const u8 *bssid, const u8 *buf,
735 size_t len, unsigned int wait_time);
Dmitry Shmidt04949592012-07-19 12:16:46 -0700736void p2p_stop_listen_for_freq(struct p2p_data *p2p, int freq);
Dmitry Shmidt7a5e50a2013-03-05 12:37:16 -0800737int p2p_prepare_channel(struct p2p_data *p2p, struct p2p_device *dev,
738 unsigned int force_freq, unsigned int pref_freq);
Dmitry Shmidtb6e9aaf2013-05-20 14:49:44 -0700739void p2p_dbg(struct p2p_data *p2p, const char *fmt, ...)
740PRINTF_FORMAT(2, 3);
741void p2p_info(struct p2p_data *p2p, const char *fmt, ...)
742PRINTF_FORMAT(2, 3);
743void p2p_err(struct p2p_data *p2p, const char *fmt, ...)
744PRINTF_FORMAT(2, 3);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700745
746#endif /* P2P_I_H */