Select one of the symbols to view example projects that use it.
 
Outline
#define OPENTHREAD_NETDATA_H_
#include <openthread/commissioner.h>
#include <openthread/ip6.h>
#define OT_NETWORK_DATA_ITERATOR_INIT
otNetworkDataIterator
otBorderRouterConfig
otLowpanContextInfo
otExternalRouteConfig
otRoutePreference
#define OT_SERVICE_DATA_MAX_SIZE
#define OT_SERVER_DATA_MAX_SIZE
otServerConfig
otServiceConfig
otNetDataGet(otInstance *, bool, uint8_t *, uint8_t *);
otNetDataGetLength(otInstance *);
otNetDataGetMaxLength(otInstance *);
otNetDataResetMaxLength(otInstance *);
otNetDataGetNextOnMeshPrefix(otInstance *, otNetworkDataIterator *, otBorderRouterConfig *);
otNetDataGetNextRoute(otInstance *, otNetworkDataIterator *, otExternalRouteConfig *);
otNetDataGetNextService(otInstance *, otNetworkDataIterator *, otServiceConfig *);
otNetDataGetNextLowpanContextInfo(otInstance *, otNetworkDataIterator *, otLowpanContextInfo *);
otNetDataGetCommissioningDataset(otInstance *, otCommissioningDataset *);
otNetDataGetVersion(otInstance *);
otNetDataGetStableVersion(otInstance *);
otNetDataSteeringDataCheckJoiner(otInstance *, const otExtAddress *);
otJoinerDiscerner
otNetDataSteeringDataCheckJoinerWithDiscerner(otInstance *, const struct otJoinerDiscerner *);
otNetDataContainsOmrPrefix(otInstance *, const otIp6Prefix *);
Files
loading...
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/openthread/openthread/include/openthread/netdata.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* * Copyright (c) 2016, The OpenThread Authors. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the copyright holder nor the * names of its contributors may be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. *//* ... */ /** * @file * @brief * This file defines the OpenThread Network Data API. *//* ... */ #ifndef OPENTHREAD_NETDATA_H_ #define OPENTHREAD_NETDATA_H_ #include <openthread/commissioner.h> #include <openthread/ip6.h> #ifdef __cplusplus extern "C" { #endif /** * @addtogroup api-thread-general * * @{ *//* ... */ #define OT_NETWORK_DATA_ITERATOR_INIT 0 ///< Value to initialize `otNetworkDataIterator`. typedef uint32_t otNetworkDataIterator; ///< Used to iterate through Network Data information. /** * Represents a Border Router configuration. *//* ... */ typedef struct otBorderRouterConfig { otIp6Prefix mPrefix; ///< The IPv6 prefix. signed int mPreference : 2; ///< A 2-bit signed int preference (`OT_ROUTE_PREFERENCE_*` values). bool mPreferred : 1; ///< Whether prefix is preferred. bool mSlaac : 1; ///< Whether prefix can be used for address auto-configuration (SLAAC). bool mDhcp : 1; ///< Whether border router is DHCPv6 Agent. bool mConfigure : 1; ///< Whether DHCPv6 Agent supplying other config data. bool mDefaultRoute : 1; ///< Whether border router is a default router for prefix. bool mOnMesh : 1; ///< Whether this prefix is considered on-mesh. bool mStable : 1; ///< Whether this configuration is considered Stable Network Data. bool mNdDns : 1; ///< Whether this border router can supply DNS information via ND. bool mDp : 1; ///< Whether prefix is a Thread Domain Prefix (added since Thread 1.2). uint16_t mRloc16; ///< The border router's RLOC16 (value ignored on config add). }{ ... } otBorderRouterConfig; /** * Represents 6LoWPAN Context ID information associated with a prefix in Network Data. *//* ... */ typedef struct otLowpanContextInfo { uint8_t mContextId; ///< The 6LoWPAN Context ID. bool mCompressFlag; ///< The compress flag. otIp6Prefix mPrefix; ///< The associated IPv6 prefix. }{ ... } otLowpanContextInfo; /** * Represents an External Route configuration. *//* ... */ typedef struct otExternalRouteConfig { otIp6Prefix mPrefix; ///< The IPv6 prefix. uint16_t mRloc16; ///< The border router's RLOC16 (value ignored on config add). signed int mPreference : 2; ///< A 2-bit signed int preference (`OT_ROUTE_PREFERENCE_*` values). bool mNat64 : 1; ///< Whether this is a NAT64 prefix. bool mStable : 1; ///< Whether this configuration is considered Stable Network Data. bool mNextHopIsThisDevice : 1; ///< Whether the next hop is this device (value ignored on config add). bool mAdvPio : 1; ///< Whether or not BR is advertising a ULA prefix in PIO (AP flag). }{ ... } otExternalRouteConfig; /** * Defines valid values for `mPreference` in `otExternalRouteConfig` and `otBorderRouterConfig`. *//* ... */ typedef enum otRoutePreference { OT_ROUTE_PREFERENCE_LOW = -1, ///< Low route preference. OT_ROUTE_PREFERENCE_MED = 0, ///< Medium route preference. OT_ROUTE_PREFERENCE_HIGH = 1, ///< High route preference. }{ ... } otRoutePreference; #define OT_SERVICE_DATA_MAX_SIZE 252 ///< Max size of Service Data in bytes. #define OT_SERVER_DATA_MAX_SIZE 248 ///< Max size of Server Data in bytes. Theoretical limit, practically much lower. /** * Represents a Server configuration. *//* ... */ typedef struct otServerConfig { bool mStable : 1; ///< Whether this config is considered Stable Network Data. uint8_t mServerDataLength; ///< Length of server data. uint8_t mServerData[OT_SERVER_DATA_MAX_SIZE]; ///< Server data bytes. uint16_t mRloc16; ///< The Server RLOC16. }{ ... } otServerConfig; /** * Represents a Service configuration. *//* ... */ typedef struct otServiceConfig { uint8_t mServiceId; ///< Service ID (when iterating over the Network Data). uint32_t mEnterpriseNumber; ///< IANA Enterprise Number. uint8_t mServiceDataLength; ///< Length of service data. uint8_t mServiceData[OT_SERVICE_DATA_MAX_SIZE]; ///< Service data bytes. otServerConfig mServerConfig; ///< The Server configuration. }{ ... } otServiceConfig; /** * Provide full or stable copy of the Partition's Thread Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in] aStable TRUE when copying the stable version, FALSE when copying the full version. * @param[out] aData A pointer to the data buffer. * @param[in,out] aDataLength On entry, size of the data buffer pointed to by @p aData. * On exit, number of copied bytes. * * @retval OT_ERROR_NONE Successfully copied the Thread Network Data into @p aData and updated @p aDataLength. * @retval OT_ERROR_NO_BUFS Not enough space in @p aData to fully copy the Thread Network Data. *//* ... */ otError otNetDataGet(otInstance *aInstance, bool aStable, uint8_t *aData, uint8_t *aDataLength); /** * Get the current length (number of bytes) of Partition's Thread Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * * @return The length of the Network Data. *//* ... */ uint8_t otNetDataGetLength(otInstance *aInstance); /** * Get the maximum observed length of the Thread Network Data since OT stack initialization or since the last call to * `otNetDataResetMaxLength()`. * * @param[in] aInstance A pointer to an OpenThread instance. * * @return The maximum length of the Network Data (high water mark for Network Data length). *//* ... */ uint8_t otNetDataGetMaxLength(otInstance *aInstance); /** * Reset the tracked maximum length of the Thread Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * * @sa otNetDataGetMaxLength *//* ... */ void otNetDataResetMaxLength(otInstance *aInstance); /** * Get the next On Mesh Prefix in the partition's Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in,out] aIterator A pointer to the Network Data iterator context. To get the first on-mesh entry it should be set to OT_NETWORK_DATA_ITERATOR_INIT. * @param[out] aConfig A pointer to where the On Mesh Prefix information will be placed. * * @retval OT_ERROR_NONE Successfully found the next On Mesh prefix. * @retval OT_ERROR_NOT_FOUND No subsequent On Mesh prefix exists in the Thread Network Data. *//* ... */ otError otNetDataGetNextOnMeshPrefix(otInstance *aInstance, otNetworkDataIterator *aIterator, otBorderRouterConfig *aConfig); /** * Get the next external route in the partition's Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in,out] aIterator A pointer to the Network Data iterator context. To get the first external route entry it should be set to OT_NETWORK_DATA_ITERATOR_INIT. * @param[out] aConfig A pointer to where the External Route information will be placed. * * @retval OT_ERROR_NONE Successfully found the next External Route. * @retval OT_ERROR_NOT_FOUND No subsequent external route entry exists in the Thread Network Data. *//* ... */ otError otNetDataGetNextRoute(otInstance *aInstance, otNetworkDataIterator *aIterator, otExternalRouteConfig *aConfig); /** * Get the next service in the partition's Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in,out] aIterator A pointer to the Network Data iterator context. To get the first service entry it should be set to OT_NETWORK_DATA_ITERATOR_INIT. * @param[out] aConfig A pointer to where the service information will be placed. * * @retval OT_ERROR_NONE Successfully found the next service. * @retval OT_ERROR_NOT_FOUND No subsequent service exists in the partition's Network Data. *//* ... */ otError otNetDataGetNextService(otInstance *aInstance, otNetworkDataIterator *aIterator, otServiceConfig *aConfig); /** * Get the next 6LoWPAN Context ID info in the partition's Network Data. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in,out] aIterator A pointer to the Network Data iterator. To get the first service entry it should be set to OT_NETWORK_DATA_ITERATOR_INIT. * @param[out] aContextInfo A pointer to where the retrieved 6LoWPAN Context ID information will be placed. * * @retval OT_ERROR_NONE Successfully found the next 6LoWPAN Context ID info. * @retval OT_ERROR_NOT_FOUND No subsequent 6LoWPAN Context info exists in the partition's Network Data. *//* ... */ otError otNetDataGetNextLowpanContextInfo(otInstance *aInstance, otNetworkDataIterator *aIterator, otLowpanContextInfo *aContextInfo); /** * Gets the Commissioning Dataset from the partition's Network Data. * * @param[in] aInstance A pointer to the OpenThread instance. * @param[out] aDataset A pointer to a `otCommissioningDataset` to populate. *//* ... */ void otNetDataGetCommissioningDataset(otInstance *aInstance, otCommissioningDataset *aDataset); /** * Get the Network Data Version. * * @param[in] aInstance A pointer to an OpenThread instance. * * @returns The Network Data Version. *//* ... */ uint8_t otNetDataGetVersion(otInstance *aInstance); /** * Get the Stable Network Data Version. * * @param[in] aInstance A pointer to an OpenThread instance. * * @returns The Stable Network Data Version. *//* ... */ uint8_t otNetDataGetStableVersion(otInstance *aInstance); /** * Check if the steering data includes a Joiner. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in] aEui64 A pointer to the Joiner's IEEE EUI-64. * * @retval OT_ERROR_NONE @p aEui64 is included in the steering data. * @retval OT_ERROR_INVALID_STATE No steering data present. * @retval OT_ERROR_NOT_FOUND @p aEui64 is not included in the steering data. *//* ... */ otError otNetDataSteeringDataCheckJoiner(otInstance *aInstance, const otExtAddress *aEui64); // Forward declaration struct otJoinerDiscerner; /** * Check if the steering data includes a Joiner with a given discerner value. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in] aDiscerner A pointer to the Joiner Discerner. * * @retval OT_ERROR_NONE @p aDiscerner is included in the steering data. * @retval OT_ERROR_INVALID_STATE No steering data present. * @retval OT_ERROR_NOT_FOUND @p aDiscerner is not included in the steering data. *//* ... */ otError otNetDataSteeringDataCheckJoinerWithDiscerner(otInstance *aInstance, const struct otJoinerDiscerner *aDiscerner); /** * Check whether a given Prefix can act as a valid OMR prefix and also the Leader's Network Data contains this prefix. * * @param[in] aInstance A pointer to an OpenThread instance. * @param[in] aPrefix A pointer to the IPv6 prefix. * * @returns Whether @p aPrefix is a valid OMR prefix and Leader's Network Data contains the OMR prefix @p aPrefix. * * @note This API is only available when `OPENTHREAD_CONFIG_BORDER_ROUTING_ENABLE` is used. *//* ... */ bool otNetDataContainsOmrPrefix(otInstance *aInstance, const otIp6Prefix *aPrefix); /** * @} *//* ... */ #ifdef __cplusplus }{...} // extern "C" #endif /* ... */ #endif // OPENTHREAD_NETDATA_H_
Details
Show:
from
Types: Columns:
This file uses the notable symbols shown below. Click anywhere in the file to view more details.