blob: 1e3619e50446c64f0ef46f49bdb07f486750091f [file] [log] [blame]
/*
* Copyright (c) 2017 Nordic Semiconductor ASA
*
* SPDX-License-Identifier: Apache-2.0
*/
/** @file
* @brief OpenThread L2 stack public header
*/
#ifndef ZEPHYR_INCLUDE_NET_OPENTHREAD_H_
#define ZEPHYR_INCLUDE_NET_OPENTHREAD_H_
/**
* @brief OpenThread Layer 2 abstraction layer
* @defgroup openthread OpenThread L2 abstraction layer
* @ingroup ieee802154
* @{
*/
#include <zephyr/kernel.h>
#include <zephyr/net/net_if.h>
#include <openthread/instance.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @cond INTERNAL_HIDDEN
*/
/**
* @brief Type of pkt_list
*/
struct pkt_list_elem {
struct net_pkt *pkt;
};
/**
* @brief OpenThread l2 private data.
*/
struct openthread_context {
/** Pointer to OpenThread stack instance */
otInstance *instance;
/** Pointer to OpenThread network interface */
struct net_if *iface;
/** Index indicates the head of pkt_list ring buffer */
uint16_t pkt_list_in_idx;
/** Index indicates the tail of pkt_list ring buffer */
uint16_t pkt_list_out_idx;
/** Flag indicates that pkt_list is full */
uint8_t pkt_list_full;
/** Array for storing net_pkt for OpenThread internal usage */
struct pkt_list_elem pkt_list[CONFIG_OPENTHREAD_PKT_LIST_SIZE];
/** A mutex to protect API calls from being preempted. */
struct k_mutex api_lock;
/** A work queue for all OpenThread activity */
struct k_work_q work_q;
/** Work object for OpenThread internal usage */
struct k_work api_work;
/** A list for state change callbacks */
sys_slist_t state_change_cbs;
};
/**
* INTERNAL_HIDDEN @endcond
*/
/** OpenThread state change callback */
/**
* @brief OpenThread state change callback structure
*
* Used to register a callback in the callback list. As many
* callbacks as needed can be added as long as each of them
* are unique pointers of struct openthread_state_changed_cb.
* Beware such structure should not be allocated on stack.
*/
struct openthread_state_changed_cb {
/**
* @brief Callback for notifying configuration or state changes.
*
* @param flags as per OpenThread otStateChangedCallback() aFlags parameter.
* See https://openthread.io/reference/group/api-instance#otstatechangedcallback
* @param ot_context the OpenThread context the callback is registered with.
* @param user_data Data to pass to the callback.
*/
void (*state_changed_cb)(otChangedFlags flags, struct openthread_context *ot_context,
void *user_data);
/** User data if required */
void *user_data;
/**
* Internally used field for list handling
* - user must not directly modify
*/
sys_snode_t node;
};
/**
* @brief Registers callbacks which will be called when certain configuration
* or state changes occur within OpenThread.
*
* @param ot_context the OpenThread context to register the callback with.
* @param cb callback struct to register.
*/
int openthread_state_changed_cb_register(struct openthread_context *ot_context,
struct openthread_state_changed_cb *cb);
/**
* @brief Unregisters OpenThread configuration or state changed callbacks.
*
* @param ot_context the OpenThread context to unregister the callback from.
* @param cb callback struct to unregister.
*/
int openthread_state_changed_cb_unregister(struct openthread_context *ot_context,
struct openthread_state_changed_cb *cb);
/**
* @brief Get OpenThread thread identification.
*/
k_tid_t openthread_thread_id_get(void);
/**
* @brief Get pointer to default OpenThread context.
*
* @retval !NULL On success.
* @retval NULL On failure.
*/
struct openthread_context *openthread_get_default_context(void);
/**
* @brief Get pointer to default OpenThread instance.
*
* @retval !NULL On success.
* @retval NULL On failure.
*/
struct otInstance *openthread_get_default_instance(void);
/**
* @brief Starts the OpenThread network.
*
* @details Depends on active settings: it uses stored network configuration,
* start joining procedure or uses default network configuration. Additionally
* when the device is MTD, it sets the SED mode to properly attach the network.
*
* @param ot_context
*/
int openthread_start(struct openthread_context *ot_context);
/**
* @brief Lock internal mutex before accessing OT API.
*
* @details OpenThread API is not thread-safe, therefore before accessing any
* API function, it's needed to lock the internal mutex, to prevent the
* OpenThread thread from preempting the API call.
*
* @param ot_context Context to lock.
*/
void openthread_api_mutex_lock(struct openthread_context *ot_context);
/**
* @brief Try to lock internal mutex before accessing OT API.
*
* @details This function behaves like openthread_api_mutex_lock() provided that
* the internal mutex is unlocked. Otherwise, it exists immediately and returns
* a negative value.
*
* @param ot_context Context to lock.
* @retval 0 On success.
* @retval <0 On failure.
*/
int openthread_api_mutex_try_lock(struct openthread_context *ot_context);
/**
* @brief Unlock internal mutex after accessing OT API.
*
* @param ot_context Context to unlock.
*/
void openthread_api_mutex_unlock(struct openthread_context *ot_context);
/** @cond INTERNAL_HIDDEN */
#define OPENTHREAD_L2_CTX_TYPE struct openthread_context
/** @endcond */
#ifdef __cplusplus
}
#endif
/**
* @}
*/
#endif /* ZEPHYR_INCLUDE_NET_OPENTHREAD_H_ */