2017-05-19 01:02:19 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Fundacion Inria Chile
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup pkg_openthread_cli OpenThread
|
|
|
|
* @ingroup pkg_openthread
|
|
|
|
* @brief An open source implementation of Thread stack
|
|
|
|
* @see https://github.com/openthread/openthread
|
|
|
|
*
|
2018-09-26 16:13:21 +02:00
|
|
|
* Thread is a mesh oriented network stack running for IEEE802.15.4 networks.
|
2017-05-19 01:02:19 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
*
|
2018-06-12 17:40:27 +02:00
|
|
|
* @author Jose Ignacio Alamos <jialamos@uc.cl>
|
|
|
|
* @author Baptiste Clenet <bapclenet@gmail.com>
|
2017-05-19 01:02:19 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OT_H
|
|
|
|
#define OT_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "net/netopt.h"
|
|
|
|
#include "net/ieee802154.h"
|
|
|
|
#include "net/ethernet.h"
|
2017-11-30 13:59:45 +01:00
|
|
|
#include "net/netdev.h"
|
2017-05-19 01:02:19 +02:00
|
|
|
#include "thread.h"
|
2019-05-16 23:08:30 +02:00
|
|
|
#include "openthread/instance.h"
|
2017-05-19 01:02:19 +02:00
|
|
|
|
2018-06-12 17:40:27 +02:00
|
|
|
/**
|
|
|
|
* @name Openthread message types
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/** @brief xtimer message receiver event */
|
|
|
|
#define OPENTHREAD_XTIMER_MSG_TYPE_EVENT (0x2235)
|
|
|
|
/** @brief message received from driver */
|
|
|
|
#define OPENTHREAD_NETDEV_MSG_TYPE_EVENT (0x2236)
|
|
|
|
/** @brief event indicating a serial (UART) message was sent to OpenThread */
|
|
|
|
#define OPENTHREAD_SERIAL_MSG_TYPE_EVENT (0x2237)
|
|
|
|
/** @brief event for frame reception */
|
|
|
|
#define OPENTHREAD_MSG_TYPE_RECV (0x2238)
|
|
|
|
/** @brief event indicating an OT_JOB message */
|
|
|
|
#define OPENTHREAD_JOB_MSG_TYPE_EVENT (0x2240)
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Openthread constants
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/** @brief number of serial reception buffer */
|
|
|
|
#define OPENTHREAD_NUMBER_OF_SERIAL_BUFFER (1U)
|
|
|
|
/** @brief sizeof in bytes the two first members of she serial structure */
|
|
|
|
#define OPENTHREAD_SIZEOF_LENGTH_AND_FREEBUFF (4U)
|
|
|
|
/** @brief sizeof the serial buffer */
|
|
|
|
#define OPENTHREAD_SERIAL_BUFFER_SIZE OPENTHREAD_SIZEOF_LENGTH_AND_FREEBUFF + 100
|
|
|
|
/** @brief sizeof the spinel payload data */
|
|
|
|
#define OPENTHREAD_SERIAL_BUFFER__PAYLOAD_SIZE OPENTHREAD_SERIAL_BUFFER_SIZE - OPENTHREAD_SIZEOF_LENGTH_AND_FREEBUFF
|
|
|
|
/** @brief error when no more buffer available */
|
|
|
|
#define OPENTHREAD_ERROR_NO_EMPTY_SERIAL_BUFFER -1
|
|
|
|
/** @brief serial buffer ready to use */
|
|
|
|
#define OPENTHREAD_SERIAL_BUFFER_STATUS_FREE (0x0001)
|
2019-10-23 21:18:08 +02:00
|
|
|
/** @brief serial buffer ready for processing */
|
2018-06-12 17:40:27 +02:00
|
|
|
#define OPENTHREAD_SERIAL_BUFFER_STATUS_READY_TO_PROCESS (0x0002)
|
|
|
|
/** @brief serial buffer payload full */
|
|
|
|
#define OPENTHREAD_SERIAL_BUFFER_STATUS_FULL (0x0004)
|
|
|
|
/** @brief Max length for IEEE802154 frame */
|
|
|
|
#define IEEE802154_MAX_LENGTH (127U)
|
|
|
|
/** @brief Max length for a netdev buffer */
|
|
|
|
#define OPENTHREAD_NETDEV_BUFLEN (IEEE802154_MAX_LENGTH)
|
|
|
|
/** @} */
|
2017-05-19 01:02:19 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Struct containing a serial message
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2018-06-12 17:40:27 +02:00
|
|
|
uint16_t length; /**< length of the message */
|
|
|
|
uint16_t serial_buffer_status; /**< status of the buffer */
|
|
|
|
uint8_t buf[OPENTHREAD_SERIAL_BUFFER__PAYLOAD_SIZE]; /**< buffer containing the message */
|
2017-05-19 01:02:19 +02:00
|
|
|
} serial_msg_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Struct containing an OpenThread job
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
const char *command; /**< A pointer to the job name string. */
|
|
|
|
void *arg; /**< arg for the job **/
|
|
|
|
void *answer; /**< answer from the job **/
|
|
|
|
} ot_job_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets packet from driver and tells OpenThread about the reception.
|
|
|
|
*
|
|
|
|
* @param[in] aInstance pointer to an OpenThread instance
|
2018-02-28 14:52:43 +01:00
|
|
|
* @param[in] dev pointer to a netdev instance
|
2017-05-19 01:02:19 +02:00
|
|
|
*/
|
|
|
|
void recv_pkt(otInstance *aInstance, netdev_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Inform OpenThread when tx is finished
|
|
|
|
*
|
|
|
|
* @param[in] aInstance pointer to an OpenThread instance
|
|
|
|
* @param[in] dev pointer to a netdev interface
|
|
|
|
* @param[in] event just occurred netdev event
|
|
|
|
*/
|
|
|
|
void send_pkt(otInstance *aInstance, netdev_t *dev, netdev_event_t event);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Bootstrap OpenThread
|
|
|
|
*/
|
|
|
|
void openthread_bootstrap(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Init OpenThread radio
|
|
|
|
*
|
|
|
|
* @param[in] dev pointer to a netdev interface
|
|
|
|
* @param[in] tb pointer to the TX buffer designed for OpenThread
|
2018-02-28 14:52:43 +01:00
|
|
|
* @param[in] rb pointer to the RX buffer designed for Open_Thread
|
2017-05-19 01:02:19 +02:00
|
|
|
*/
|
|
|
|
void openthread_radio_init(netdev_t *dev, uint8_t *tb, uint8_t *rb);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Starts OpenThread thread.
|
|
|
|
*
|
|
|
|
* @param[in] stack pointer to the stack designed for OpenThread
|
|
|
|
* @param[in] stacksize size of the stack
|
|
|
|
* @param[in] priority priority of the OpenThread stack
|
|
|
|
* @param[in] name name of the OpenThread stack
|
|
|
|
* @param[in] netdev pointer to the netdev interface
|
|
|
|
*
|
|
|
|
* @return PID of OpenThread thread
|
|
|
|
* @return -EINVAL if there was an error creating the thread
|
|
|
|
*/
|
|
|
|
int openthread_netdev_init(char *stack, int stacksize, char priority, const char *name, netdev_t *netdev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief get PID of OpenThread thread.
|
|
|
|
*
|
|
|
|
* @return PID of OpenThread thread
|
|
|
|
*/
|
|
|
|
kernel_pid_t openthread_get_pid(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Init OpenThread random
|
|
|
|
*/
|
|
|
|
void ot_random_init(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Execute OpenThread command. Call this function only in OpenThread thread
|
|
|
|
*
|
|
|
|
* @param[in] ot_instance OpenThread instance
|
|
|
|
* @param[in] command OpenThread command name
|
|
|
|
* @param[in] arg arg for the command
|
|
|
|
* @param[out] answer answer for the command
|
|
|
|
*
|
|
|
|
* @return 0 on success, 1 on error
|
|
|
|
*/
|
|
|
|
uint8_t ot_exec_command(otInstance *ot_instance, const char* command, void *arg, void* answer);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Call OpenThread command in same thread as OT core (due to concurrency).
|
|
|
|
*
|
|
|
|
* @note An OpenThread command allows direct calls to OpenThread API (otXXX functions) without worrying about concurrency
|
|
|
|
* issues. All API calls should be made in OT_JOB type functions.
|
|
|
|
*
|
|
|
|
* @param[in] command name of the command to call
|
|
|
|
* @param[in] arg arg for the command
|
|
|
|
* @param[out] answer answer for the command
|
|
|
|
*
|
|
|
|
* @return 0 on success, 1 on error
|
|
|
|
*/
|
|
|
|
uint8_t ot_call_command(char* command, void *arg, void* answer);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* OT_H */
|
|
|
|
/** @} */
|