blob: 9c1df317ca63d111408ffba4cb229dcf16b6cbcc [file] [log] [blame]
Sunil Ravib0ac25f2024-07-12 01:42:03 +00001/*
2 * NAN Discovery Engine
3 * Copyright (c) 2024, Qualcomm Innovation Center, Inc.
4 *
5 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
7 */
8
9#ifndef NAN_DE_H
10#define NAN_DE_H
11
12#include "nan.h"
13
14/* Maximum number of active local publish and subscribe instances */
15#ifndef NAN_DE_MAX_SERVICE
16#define NAN_DE_MAX_SERVICE 20
17#endif /* NAN_DE_MAX_SERVICE */
18
19struct nan_de;
20
21enum nan_de_reason {
22 NAN_DE_REASON_TIMEOUT,
23 NAN_DE_REASON_USER_REQUEST,
24 NAN_DE_REASON_FAILURE,
25};
26
27struct nan_callbacks {
28 void *ctx;
29
30 int (*tx)(void *ctx, unsigned int freq, unsigned int wait_time,
31 const u8 *dst, const u8 *src, const u8 *bssid,
32 const struct wpabuf *buf);
33 int (*listen)(void *ctx, unsigned int freq, unsigned int duration);
34
35 /* NAN DE Events */
36 void (*discovery_result)(void *ctx, int subscribe_id,
37 enum nan_service_protocol_type srv_proto_type,
38 const u8 *ssi, size_t ssi_len,
39 int peer_publish_id,
40 const u8 *peer_addr, bool fsd, bool fsd_gas);
41
42 void (*replied)(void *ctx, int publish_id, const u8 *peer_addr,
43 int peer_subscribe_id,
44 enum nan_service_protocol_type srv_proto_type,
45 const u8 *ssi, size_t ssi_len);
46
47 void (*publish_terminated)(void *ctx, int publish_id,
48 enum nan_de_reason reason);
49
50 void (*subscribe_terminated)(void *ctx, int subscribe_id,
51 enum nan_de_reason reason);
52
53 void (*receive)(void *ctx, int id, int peer_instance_id,
54 const u8 *ssi, size_t ssi_len,
55 const u8 *peer_addr);
Sunil Ravic0f5d412024-09-11 22:12:49 +000056
57 void (*process_p2p_usd_elems)(void *ctx, const u8 *buf,
58 u16 buf_len, const u8 *peer_addr,
59 unsigned int freq);
Sunil Ravib0ac25f2024-07-12 01:42:03 +000060};
61
Sunil Ravi79e6c4f2025-01-04 00:47:06 +000062bool nan_de_is_nan_network_id(const u8 *addr);
63bool nan_de_is_p2p_network_id(const u8 *addr);
Sunil Ravic0f5d412024-09-11 22:12:49 +000064struct nan_de * nan_de_init(const u8 *nmi, bool offload, bool ap,
Sunil Ravi79e6c4f2025-01-04 00:47:06 +000065 unsigned int max_listen,
Sunil Ravib0ac25f2024-07-12 01:42:03 +000066 const struct nan_callbacks *cb);
67void nan_de_flush(struct nan_de *de);
68void nan_de_deinit(struct nan_de *de);
69
70void nan_de_listen_started(struct nan_de *de, unsigned int freq,
71 unsigned int duration);
72void nan_de_listen_ended(struct nan_de *de, unsigned int freq);
73void nan_de_tx_status(struct nan_de *de, unsigned int freq, const u8 *dst);
74void nan_de_tx_wait_ended(struct nan_de *de);
75
Sunil Ravi79e6c4f2025-01-04 00:47:06 +000076void nan_de_rx_sdf(struct nan_de *de, const u8 *peer_addr, const u8 *a3,
77 unsigned int freq, const u8 *buf, size_t len);
Sunil Ravic0f5d412024-09-11 22:12:49 +000078const u8 * nan_de_get_service_id(struct nan_de *de, int id);
Sunil Ravib0ac25f2024-07-12 01:42:03 +000079
80struct nan_publish_params {
81 /* configuration_parameters */
82
83 /* Publish type */
84 bool unsolicited;
85 bool solicited;
86
87 /* Solicited transmission type */
88 bool solicited_multicast;
89
90 /* Time to live (in seconds); 0 = one TX only */
91 unsigned int ttl;
92
93 /* Event conditions */
94 bool disable_events;
95
96 /* Further Service Discovery flag */
97 bool fsd;
98
99 /* Further Service Discovery function */
100 bool fsd_gas;
101
102 /* Default frequency (defaultPublishChannel) */
103 unsigned int freq;
104
105 /* Multi-channel frequencies (publishChannelList) */
106 const int *freq_list;
107
108 /* Announcement period in ms; 0 = use default */
109 unsigned int announcement_period;
110};
111
112/* Returns -1 on failure or >0 publish_id */
113int nan_de_publish(struct nan_de *de, const char *service_name,
114 enum nan_service_protocol_type srv_proto_type,
115 const struct wpabuf *ssi, const struct wpabuf *elems,
Sunil Ravic0f5d412024-09-11 22:12:49 +0000116 struct nan_publish_params *params, bool p2p);
Sunil Ravib0ac25f2024-07-12 01:42:03 +0000117
118void nan_de_cancel_publish(struct nan_de *de, int publish_id);
119
120int nan_de_update_publish(struct nan_de *de, int publish_id,
121 const struct wpabuf *ssi);
122
123struct nan_subscribe_params {
124 /* configuration_parameters */
125
126 /* Subscribe type */
127 bool active;
128
129 /* Time to live (in seconds); 0 = until first result */
130 unsigned int ttl;
131
132 /* Selected frequency */
133 unsigned int freq;
134
Sunil Ravic0f5d412024-09-11 22:12:49 +0000135 /* Multi-channel frequencies (publishChannelList) */
136 const int *freq_list;
137
Sunil Ravib0ac25f2024-07-12 01:42:03 +0000138 /* Query period in ms; 0 = use default */
139 unsigned int query_period;
140};
141
142/* Returns -1 on failure or >0 subscribe_id */
143int nan_de_subscribe(struct nan_de *de, const char *service_name,
144 enum nan_service_protocol_type srv_proto_type,
145 const struct wpabuf *ssi, const struct wpabuf *elems,
Sunil Ravic0f5d412024-09-11 22:12:49 +0000146 struct nan_subscribe_params *params, bool p2p);
Sunil Ravib0ac25f2024-07-12 01:42:03 +0000147
148void nan_de_cancel_subscribe(struct nan_de *de, int subscribe_id);
149
150/* handle = publish_id or subscribe_id
151 * req_instance_id = peer publish_id or subscribe_id */
152int nan_de_transmit(struct nan_de *de, int handle,
153 const struct wpabuf *ssi, const struct wpabuf *elems,
154 const u8 *peer_addr, u8 req_instance_id);
155
156#endif /* NAN_DE_H */