1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/pkg/openwsn/include/openwsn_uart.h
Francisco Molina 844ccfbeb3
pkg/OpenWSN: initial import
Co-authored-by: Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
Co-authored-by: Jose Alamos <jose.alamos@haw-hamburg.de>
Co-authored-by: Michel Rottleuthner <michel.rottleuthner@haw-hamburg.de>
2020-06-30 13:08:36 +02:00

142 lines
3.0 KiB
C

/*
* Copyright (C) 2018 Hamburg University of Applied Sciences
* 2020 Inria
*
* 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 pkg_openwsn
* @{
*
* For details on the implementation check pkg/openwsn/doc.txt
*
* @file
* @brief RIOT adaption-specific definition of the "uart" bsp module.
*
* @author Thomas Watteyne <watteyne@eecs.berkeley.edu>, February 2012
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>, July 2018
* @author Francisco Molina <francois-xavier.molina@inria.fr>
*
* @}
*/
#ifndef OPENWSN_UART_H
#define OPENWSN_UART_H
#include "stdint.h"
#include "board.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief UART device to use for STDIO
*
* Dont want to include the stdio header, so redefine the default value
*
*/
#ifndef STDIO_UART_DEV
#define STDIO_UART_DEV (UART_DEV(0))
#endif
/**
* @brief OpenWSN default uart dev.
*
* @note If only one UART is available that uart might collide with
* STDIO_UART_DEV, otherwise the next available UART will be used.
*
*/
#ifndef OPENWSN_UART_DEV
#ifdef MODULE_STDIO_NULL
#define OPENWSN_UART_DEV (STDIO_UART_DEV)
#else
#define OPENWSN_UART_DEV ((STDIO_UART_DEV + 1) % UART_NUMOF)
#endif
#endif
/**
* @brief OpenWSN uart baudrate
*/
#ifndef OPENWSN_UART_BAUDRATE
#ifndef STDIO_UART_BAUDRATE
#define OPENWSN_UART_BAUDRATE (115200U)
#else
#define OPENWSN_UART_BAUDRATE (STDIO_UART_BAUDRATE)
#endif
#endif
/**
* @brief Initialize OpenWSN uart
*
* This will initialize a uart device at STDIO_UART_BAUDRATE/8N1. It will also
* initialize a timer to set sw tx_isr.
*
*/
void uart_init_openwsn(void);
/**
* @brief OpenWSN uart tx callback type
*/
typedef void (*uart_tx_cbt)(void);
/**
* @brief OpenWSN uart rx callback type
*/
typedef void (*uart_rx_cbt)(void);
/**
* @brief OpenWSN uart tx callback type
*/
void uart_setCallbacks(uart_tx_cbt txCb, uart_rx_cbt rxCb);
/**
* @brief Sets software flow control CTS
*
* This function sends XON or XOFF bytes to "set" or "unset" CTS by sw.
*
* @param[in] state true sets CTS, false clears CTS
*/
void uart_setCTS(bool state);
/**
* @brief Write a single byte to the configured OpenWSN uart
*/
void uart_writeByte(uint8_t byteToWrite);
/**
* @brief Reads a single byte received through uart.
*
* OpenWSN will call this thrpugh uart_rx_cbt.
*
*/
uint8_t uart_readByte(void);
/**
* @brief Unused in RIOT, needs to be defined for OpenWSN
*/
void uart_enableInterrupts(void);
/**
* @brief Unused in RIOT, needs to be defined for OpenWSN
*/
void uart_disableInterrupts(void);
/**
* @brief Unused in RIOT, needs to be defined for OpenWSN
*/
void uart_clearRxInterrupts(void);
/**
* @brief Unused in RIOT, needs to be defined for OpenWSN
*/
void uart_clearTxInterrupts(void);
#ifdef __cplusplus
}
#endif
#endif /* OPENWSN_UART_H */