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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @{
|
|
|
|
* @ingroup net
|
|
|
|
* @file
|
|
|
|
* @brief Implementation of OpenThread UART platform abstraction
|
|
|
|
*
|
|
|
|
* @author Jose Ignacio Alamos <jialamos@uc.cl>
|
2018-06-12 17:40:27 +02:00
|
|
|
* @author Baptiste Clenet <bapclenet@gmail.com>
|
2017-05-19 01:02:19 +02:00
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
2018-06-12 17:40:27 +02:00
|
|
|
#include <string.h>
|
2017-05-19 01:02:19 +02:00
|
|
|
|
2018-10-05 16:44:29 +02:00
|
|
|
#include "stdio_uart.h"
|
2017-05-19 01:02:19 +02:00
|
|
|
#include "periph/uart.h"
|
|
|
|
#include "openthread/platform/uart.h"
|
2018-06-12 17:40:27 +02:00
|
|
|
#include "ot.h"
|
2020-09-16 16:59:22 +02:00
|
|
|
#include "event.h"
|
2018-06-12 17:40:27 +02:00
|
|
|
|
|
|
|
#define ENABLE_DEBUG (0)
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
#define OPENTHREAD_SPINEL_FRAME_MARKER (0x7e)
|
|
|
|
|
|
|
|
static serial_msg_t gSerialMessage[OPENTHREAD_NUMBER_OF_SERIAL_BUFFER];
|
|
|
|
static uint16_t frameLength = 0;
|
|
|
|
|
2020-09-16 16:59:22 +02:00
|
|
|
static void _ev_serial_handler(event_t *event)
|
|
|
|
{
|
|
|
|
(void) event;
|
|
|
|
/* Tell OpenThread about the reception of a CLI command */
|
|
|
|
otPlatUartReceived((uint8_t*)gSerialMessage[0].buf, gSerialMessage[0].length);
|
|
|
|
gSerialMessage[0].serial_buffer_status = OPENTHREAD_SERIAL_BUFFER_STATUS_FREE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static event_t ev_serial = {
|
|
|
|
.handler = _ev_serial_handler
|
|
|
|
};
|
|
|
|
|
2018-06-12 17:40:27 +02:00
|
|
|
static void uart_handler(void* arg, char c) {
|
|
|
|
(void)arg;
|
|
|
|
|
|
|
|
if (frameLength == 0) {
|
|
|
|
memset(&gSerialMessage[0], 0, sizeof(serial_msg_t));
|
|
|
|
}
|
|
|
|
switch (c) {
|
|
|
|
case '\r':
|
|
|
|
case '\n':
|
|
|
|
if (frameLength > 0) {
|
|
|
|
gSerialMessage[0].buf[frameLength] = c;
|
|
|
|
frameLength++;
|
|
|
|
gSerialMessage[0].length = frameLength;
|
2020-09-16 16:59:22 +02:00
|
|
|
event_post(openthread_get_evq(), &ev_serial);
|
2018-06-12 17:40:27 +02:00
|
|
|
frameLength = 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
if (frameLength < OPENTHREAD_SERIAL_BUFFER_SIZE) {
|
|
|
|
gSerialMessage[0].buf[frameLength] = c;
|
|
|
|
frameLength++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2017-05-19 01:02:19 +02:00
|
|
|
|
|
|
|
/* OpenThread will call this for enabling UART (required for OpenThread's CLI)*/
|
2018-06-12 17:40:27 +02:00
|
|
|
otError otPlatUartEnable(void)
|
2017-05-19 01:02:19 +02:00
|
|
|
{
|
2018-06-12 17:40:27 +02:00
|
|
|
for (uint8_t i = 0; i < OPENTHREAD_NUMBER_OF_SERIAL_BUFFER; i++) {
|
|
|
|
gSerialMessage[i].serial_buffer_status = OPENTHREAD_SERIAL_BUFFER_STATUS_FREE;
|
|
|
|
}
|
|
|
|
|
2018-10-05 16:44:29 +02:00
|
|
|
uart_init(STDIO_UART_DEV, STDIO_UART_BAUDRATE, (uart_rx_cb_t) uart_handler, NULL);
|
2018-06-12 17:40:27 +02:00
|
|
|
return OT_ERROR_NONE;
|
2017-05-19 01:02:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* OpenThread will call this for disabling UART */
|
2018-06-12 17:40:27 +02:00
|
|
|
otError otPlatUartDisable(void)
|
2017-05-19 01:02:19 +02:00
|
|
|
{
|
2018-10-05 16:44:29 +02:00
|
|
|
uart_poweroff(STDIO_UART_DEV);
|
2018-06-12 17:40:27 +02:00
|
|
|
return OT_ERROR_NONE;
|
2017-05-19 01:02:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* OpenThread will call this for sending data through UART */
|
2018-06-12 17:40:27 +02:00
|
|
|
otError otPlatUartSend(const uint8_t *aBuf, uint16_t aBufLength)
|
2017-05-19 01:02:19 +02:00
|
|
|
{
|
2018-10-05 16:44:29 +02:00
|
|
|
uart_write(STDIO_UART_DEV, aBuf, aBufLength);
|
2017-05-19 01:02:19 +02:00
|
|
|
|
|
|
|
/* Tell OpenThread the sending of UART is done */
|
|
|
|
otPlatUartSendDone();
|
|
|
|
|
2018-06-12 17:40:27 +02:00
|
|
|
return OT_ERROR_NONE;
|
2017-05-19 01:02:19 +02:00
|
|
|
}
|