2018-11-25 16:02:23 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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 drivers_slipdev
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @internal
|
|
|
|
* @brief Internal SLIP device definitions
|
|
|
|
*
|
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
#ifndef SLIPDEV_INTERNAL_H
|
|
|
|
#define SLIPDEV_INTERNAL_H
|
|
|
|
|
2018-11-25 15:59:38 +01:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2018-11-25 18:21:36 +01:00
|
|
|
#include "isrpipe.h"
|
2018-11-25 15:59:38 +01:00
|
|
|
#include "periph/uart.h"
|
2018-11-25 18:21:36 +01:00
|
|
|
#include "mutex.h"
|
2018-11-25 15:59:38 +01:00
|
|
|
|
2018-11-25 16:02:23 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name SLIP marker bytes
|
2018-11-25 15:59:38 +01:00
|
|
|
* @see [RFC 1055](https://tools.ietf.org/html/rfc1055)
|
2018-11-25 16:02:23 +01:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define SLIPDEV_END (0xc0U)
|
|
|
|
#define SLIPDEV_ESC (0xdbU)
|
|
|
|
#define SLIPDEV_END_ESC (0xdcU)
|
|
|
|
#define SLIPDEV_ESC_ESC (0xddU)
|
2018-11-25 18:21:36 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Marker byte for beginning of stdio
|
|
|
|
* @see taken from diagnostic transfer from
|
|
|
|
* [SLIPMUX](https://tools.ietf.org/html/draft-bormann-t2trg-slipmux-02#section-4)
|
|
|
|
*/
|
|
|
|
#define SLIPDEV_STDIO_START (0x0aU)
|
2018-11-25 16:02:23 +01:00
|
|
|
/** @} */
|
|
|
|
|
2018-11-25 18:21:36 +01:00
|
|
|
/**
|
|
|
|
* @brief ISR pipe to hand read bytes to stdin
|
|
|
|
*/
|
|
|
|
extern isrpipe_t slipdev_stdio_isrpipe;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Mutex to synchronize write operations to the UART between stdio
|
|
|
|
* sub-module and normal SLIP.
|
|
|
|
*/
|
|
|
|
extern mutex_t slipdev_mutex;
|
|
|
|
|
2018-11-25 15:59:38 +01:00
|
|
|
/**
|
|
|
|
* @brief Writes one byte to UART
|
|
|
|
*
|
|
|
|
* @param[in] uart The UART device to write to.
|
|
|
|
* @param[in] byte The byte to write to @p uart.
|
|
|
|
*/
|
|
|
|
static inline void slipdev_write_byte(uart_t uart, uint8_t byte)
|
|
|
|
{
|
|
|
|
uart_write(uart, &byte, 1U);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Write multiple bytes SLIP-escaped to UART
|
|
|
|
*
|
|
|
|
* @param[in] uart The UART device to write to.
|
|
|
|
* @param[in] data The bytes to write SLIP-escaped to @p uart.
|
|
|
|
* @param[in] len Number of bytes in @p data.
|
|
|
|
*/
|
|
|
|
void slipdev_write_bytes(uart_t uart, const uint8_t *data, size_t len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Unstuffs a (SLIP-escaped) byte.
|
|
|
|
*
|
|
|
|
* @param[out] buf The buffer to write to. It must at least be able to
|
|
|
|
* receive 1 byte.
|
|
|
|
* @param[in] byte The byte to unstuff.
|
|
|
|
* @param[in,out] escaped When set to `false` on in, @p byte will be read as
|
|
|
|
* though it was not escaped, when set to `true` it
|
|
|
|
* will be read as though it was escaped. On out it
|
|
|
|
* will be `false` unless @p byte was `SLIPDEV_ESC`.
|
|
|
|
*
|
|
|
|
* @return 0, when @p byte did not resolve to an actual byte
|
|
|
|
* @return 1, when @p byte resolves to an actual byte (or @p escaped was set to
|
|
|
|
* true on in and resolves to a byte that was previously escaped).
|
|
|
|
*/
|
|
|
|
unsigned slipdev_unstuff_readbyte(uint8_t *buf, uint8_t byte, bool *escaped);
|
|
|
|
|
2018-11-25 16:02:23 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* SLIPDEV_INTERNAL_H */
|
|
|
|
/** @} */
|