2014-09-16 13:09:14 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2010 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.
|
|
|
|
*/
|
|
|
|
|
2013-11-27 16:28:31 +01:00
|
|
|
|
|
|
|
/**
|
2013-11-27 17:54:30 +01:00
|
|
|
* @defgroup sys_uart0 UART0
|
|
|
|
* @ingroup sys
|
|
|
|
* @brief UART0 interface abstraction
|
|
|
|
* @{
|
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2013-11-27 17:54:30 +01:00
|
|
|
* @brief Interface definitions for the UART0 abstraction
|
2013-11-27 16:28:31 +01:00
|
|
|
*/
|
|
|
|
|
2010-09-30 15:10:39 +02:00
|
|
|
#ifndef __BOARD_UART0_H
|
2013-06-22 05:11:53 +02:00
|
|
|
#define __BOARD_UART0_H
|
2010-09-30 15:10:39 +02:00
|
|
|
|
2014-07-06 22:57:56 +02:00
|
|
|
#include "kernel_types.h"
|
2015-05-22 14:31:23 +02:00
|
|
|
#include "cpu_conf.h" /* To give user access to UART0_BUFSIZE */
|
2013-12-19 16:48:31 +01:00
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-12-05 19:01:40 +01:00
|
|
|
/**
|
|
|
|
* @brief Process identifier for the UART0 module.
|
|
|
|
*/
|
2014-07-06 22:57:56 +02:00
|
|
|
extern kernel_pid_t uart0_handler_pid;
|
2010-09-30 15:10:39 +02:00
|
|
|
|
2014-12-05 19:01:40 +01:00
|
|
|
/**
|
|
|
|
* @brief Initialize and starts the UART0 handler.
|
|
|
|
*/
|
2010-11-18 17:33:25 +01:00
|
|
|
void board_uart0_init(void);
|
2014-12-05 19:01:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief To be called from the uart interrupt handler for every incoming
|
|
|
|
* character.
|
|
|
|
*
|
|
|
|
* @param[in] c The received character.
|
|
|
|
*/
|
2010-09-30 16:07:31 +02:00
|
|
|
void uart0_handle_incoming(int c);
|
2014-12-05 19:01:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Notify the chardev thread that new characters are available in the
|
|
|
|
* ringbuffer.
|
|
|
|
*/
|
2010-11-18 17:33:25 +01:00
|
|
|
void uart0_notify_thread(void);
|
|
|
|
|
2014-12-05 19:01:40 +01:00
|
|
|
/**
|
|
|
|
* @brief Reads one character from the ringbuffer.
|
|
|
|
*
|
|
|
|
* @returns The first available character from the ringbuffer.
|
|
|
|
*/
|
2010-11-18 17:33:25 +01:00
|
|
|
int uart0_readc(void);
|
2014-12-05 19:01:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Wrapper to putchar.
|
|
|
|
*
|
|
|
|
* @param[in] c The character to put on the UART.
|
|
|
|
*/
|
2010-11-18 17:33:25 +01:00
|
|
|
void uart0_putc(int c);
|
2010-09-30 15:10:39 +02:00
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-11-27 17:54:30 +01:00
|
|
|
/** @} */
|
2010-09-30 15:10:39 +02:00
|
|
|
#endif /* __BOARD_UART0_H */
|