1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/drivers/include/periph/uart.h

184 lines
5.3 KiB
C
Raw Normal View History

/*
* Copyright (C) 2014 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.
*/
/**
* @defgroup driver_periph_uart UART
* @ingroup driver_periph
* @brief Low-level UART peripheral driver
* @{
*
* @file
* @brief Low-level UART peripheral driver interface definitions
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*/
#ifndef PERIPH_UART_H
#define PERIPH_UART_H
#include <stdint.h>
#include "periph_conf.h"
#ifdef __cplusplus
extern "C" {
#endif
/* guard file in case no UART device was specified */
#if UART_NUMOF
/**
* @brief Definition of available UART devices
2014-05-14 10:46:15 +02:00
*
* To this point a maximum of 4 UART devices would be available,
* this should be enough for most applications?!
*/
typedef enum {
#if UART_0_EN
UART_0 = 0, /**< UART channel 0 */
#endif
#if UART_1_EN
UART_1, /**< UART channel 1 */
#endif
#if UART_2_EN
UART_2, /**< UART channel 2 */
#endif
#if UART_3_EN
UART_3, /**< UART channel 3 */
#endif
} uart_t;
/**
* @brief Signature for receive interrupt callback
*
* @param[in] arg optional argument to put the callback in the right context
* @param[in] data the byte that was received
*/
typedef void(*uart_rx_cb_t)(void *arg, char data);
/**
* @brief Signature for the transmit complete interrupt callback
*
* @param[in] arg optional argument to put the callback in the right context
*
* @return 1 if more data is to be send
* @return 0 if no more data is to be send
*/
typedef int(*uart_tx_cb_t)(void *arg);
/**
* @brief Initialize a given UART device
2014-05-14 10:46:15 +02:00
*
* The UART device will be initialized with the following configuration:
* - 8 data bits
* - no parity
* - 1 stop bit
* - baud-rate as given
2014-05-14 10:46:15 +02:00
*
* @param[in] uart the UART device to initialize
* @param[in] baudrate the desired baud-rate in baud/s
* @param[in] rx_cb receive callback is called for every byte the is receive
* in interrupt context
* @param[in] tx_cb transmit callback is called when done with sending a byte
* (TX buffer gets empty)
* @param[in] arg optional argument passed to the callback functions
2014-05-14 10:46:15 +02:00
*
* @return 0 on success
* @return -1 for invalid baud-rate
* @return -2 for all other errors
*/
int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, uart_tx_cb_t tx_cb, void *arg);
/**
* @brief Initialize an UART device for (conventional) blocking usage
2014-05-14 10:46:15 +02:00
*
* This function initializes the an UART device for usage without interrupts.
2014-05-14 10:46:15 +02:00
* When initializing with this function, the corresponding read_blocking and
* write_blocking functions must be used.
2014-05-14 10:46:15 +02:00
*
* The blocking mode should only be used for debugging and testing.
2014-05-14 10:46:15 +02:00
*
* Same as uart_init(), the UART device is configured with in 8N1 mode with the given baud-rate.
2014-05-14 10:46:15 +02:00
*
* @param[in] uart the UART device to initialize
* @param[in] baudrate the desired baud-rate in baud/s
2014-05-14 10:46:15 +02:00
*
* @return 0 on success, -1 for invalid baud-rate, -2 for all other errors
*/
int uart_init_blocking(uart_t uart, uint32_t baudrate);
/**
* @brief Begin a new transmission, on most platforms this function will enable the TX interrupt
2014-05-14 10:46:15 +02:00
*
* @param[in] uart UART device that will start a transmission
*/
void uart_tx_begin(uart_t uart);
/**
* @brief Write a byte into the UART's send register
2014-05-14 10:46:15 +02:00
*
* Writing a byte into while another byte is still waiting to be transferred will override
* the old byte. This method should be used in the transmit callback routine as in this it
* is made sure that no old byte is waiting to be transferred.
2014-05-14 10:46:15 +02:00
*
* @param[in] uart the UART device to use for transmission
* @param[in] data the byte to write
2014-05-14 10:46:15 +02:00
*
* @return 1 on success, -1 on error
*/
int uart_write(uart_t uart, char data);
/**
* @brief Read a single character from the given UART device in blocking manner.
2014-05-14 10:46:15 +02:00
*
* This function will actively wait until a byte is available in the UART receive
* register. Consider using the interrupt driven UART mode instead!
2014-05-14 10:46:15 +02:00
*
* @param[in] uart the UART device to read from
* @param[in] data the byte to write
2014-05-14 10:46:15 +02:00
*
* @return 1 on success, -1 on error
*/
int uart_read_blocking(uart_t uart, char *data);
/**
* @brief Write a single byte to the given UART device in blocking manner.
2014-05-14 10:46:15 +02:00
*
* Note: in contrast uart_write, this function will actively wait (block) until the UART
* device is ready to send a new byte. Consider using the interrupt driven UART mode instead.
2014-05-14 10:46:15 +02:00
*
* @param[in] uart the UART device to write to
* @param[in] data the byte to send
2014-05-14 10:46:15 +02:00
*
* @return 1 on success, -1 on error
*/
int uart_write_blocking(uart_t uart, char data);
/**
* @brief Power on the given UART device
*
* @param[in] uart the UART device to power on
*/
void uart_poweron(uart_t uart);
/**
* @brief Power off the given UART device
*
* @param[in] uart the UART device to power off
*/
void uart_poweroff(uart_t uart);
#endif /* UART_NUMOF */
#ifdef __cplusplus
}
#endif
#endif /* PERIPH_UART_H */
/** @} */