0.01.00
instance.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2016, The OpenThread Authors.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  * 1. Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  * 3. Neither the name of the copyright holder nor the
13  * names of its contributors may be used to endorse or promote products
14  * derived from this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26  * POSSIBILITY OF SUCH DAMAGE.
27  */
28 
35 #ifndef OPENTHREAD_INSTANCE_H_
36 #define OPENTHREAD_INSTANCE_H_
37 
38 #include <stdlib.h>
39 
40 #include <openthread/types.h>
42 
43 #ifdef __cplusplus
44 extern "C" {
45 #endif
46 
57 #ifdef OTDLL
58 
67 OTAPI otApiInstance *OTCALL otApiInit(void);
68 
77 OTAPI void OTCALL otApiFinalize(otApiInstance *aApiInstance);
78 
85 OTAPI void OTCALL otFreeMemory(const void *aMem);
86 
95 typedef void (OTCALL *otDeviceAvailabilityChangedCallback)(bool aAdded, const GUID *aDeviceGuid, void *aContext);
96 
105 OTAPI void OTCALL otSetDeviceAvailabilityChangedCallback(otApiInstance *aApiInstance,
106  otDeviceAvailabilityChangedCallback aCallback, void *aCallbackContext);
107 
115 OTAPI otDeviceList *OTCALL otEnumerateDevices(otApiInstance *aApiInstance);
116 
128 OTAPI otInstance *OTCALL otInstanceInit(otApiInstance *aApiInstance, const GUID *aDeviceGuid);
129 
138 OTAPI GUID OTCALL otGetDeviceGuid(otInstance *aInstance);
139 
148 OTAPI uint32_t OTCALL otGetDeviceIfIndex(otInstance *aInstance);
149 
158 OTAPI uint32_t OTCALL otGetCompartmentId(otInstance *aInstance);
159 
160 #else // OTDLL
161 
180 otInstance *otInstanceInit(void *aInstanceBuffer, size_t *aInstanceBufferSize);
181 
194 
209 bool otInstanceIsInitialized(otInstance *aInstance);
210 
219 void otInstanceFinalize(otInstance *aInstance);
220 
221 #endif // OTDLL
222 
230 typedef void (OTCALL *otStateChangedCallback)(uint32_t aFlags, void *aContext);
231 
244  void *aContext);
245 
255  void *aCallbackContext);
256 
265 OTAPI void OTCALL otInstanceReset(otInstance *aInstance);
266 
273 
285 
295 
307 otError otSetDynamicLogLevel(otInstance *aInstance, otLogLevel aLogLevel);
308 
314 #ifdef __cplusplus
315 } // extern "C"
316 #endif
317 
318 #endif // OPENTHREAD_INSTANCE_H_
otError otSetDynamicLogLevel(otInstance *aInstance, otLogLevel aLogLevel)
This function sets the dynamic log level.
Definition: instance_api.cpp:279
This type represents all the static / global variables used by OpenThread allocated in one place...
Definition: openthread-instance.h:59
This file defines the types and structures used in the OpenThread library API.
OTAPI void OTCALL otInstanceFactoryReset(otInstance *aInstance)
This method deletes all the settings stored on non-volatile memory, and then triggers platform reset...
Definition: instance_api.cpp:248
uint8_t otLogLevel
Log levels.
Definition: types.h:1182
otError otInstanceErasePersistentInfo(otInstance *aInstance)
This function erases all the OpenThread persistent info (network settings) stored on non-volatile mem...
Definition: instance_api.cpp:254
This file includes the platform abstraction for the debug log service.
bool otInstanceIsInitialized(otInstance *aInstance)
This function indicates whether or not the instance is valid/initialized.
Definition: instance_api.cpp:191
otInstance * otInstanceInitSingle(void)
This function initializes the static single instance of the OpenThread library.
Definition: instance_api.cpp:167
OTAPI void OTCALL otInstanceReset(otInstance *aInstance)
This method triggers a platform reset.
Definition: instance_api.cpp:243
otLogLevel otGetDynamicLogLevel(otInstance *aInstance)
This function returns the current dynamic log level.
Definition: instance_api.cpp:265
void otInstanceFinalize(otInstance *aInstance)
This function disables the OpenThread library.
Definition: instance_api.cpp:198
otInstance * otInstanceInit(void *aInstanceBuffer, size_t *aInstanceBufferSize)
This function initializes the OpenThread library.
#define OTCALL
Compiler-specific modifier to export functions in a DLL.
Definition: toolchain.h:217
#define OTAPI
Compiler-specific modifier for public API declarations.
Definition: toolchain.h:216
OTAPI void OTCALL otRemoveStateChangeCallback(otInstance *aInstance, otStateChangedCallback aCallback, void *aCallbackContext)
This function removes a callback to indicate when certain configuration or state changes within OpenT...
Definition: instance_api.cpp:230
void(OTCALL * otStateChangedCallback)(uint32_t aFlags, void *aContext)
This function pointer is called to notify certain configuration or state changes within OpenThread...
Definition: instance.h:230
otError
This enumeration represents error codes used throughout OpenThread.
Definition: types.h:107
OTAPI otError OTCALL otSetStateChangedCallback(otInstance *aInstance, otStateChangedCallback aCallback, void *aContext)
This function registers a callback to indicate when certain configuration or state changes within Ope...
Definition: instance_api.cpp:213