2014-05-15 08:49:20 +02:00
|
|
|
/*
|
|
|
|
* uart0.c - Implementation of the uart.
|
|
|
|
* Copyright (C) 2013 Milan Babel <babel@inf.fu-berlin.de>
|
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* 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.
|
2014-05-15 08:49:20 +02:00
|
|
|
*/
|
2013-05-25 12:34:18 +02:00
|
|
|
|
2013-12-16 17:54:58 +01:00
|
|
|
#include <stdio.h>
|
2013-05-25 12:34:18 +02:00
|
|
|
#include "board.h"
|
|
|
|
|
|
|
|
#define UART0_TX U0TXBUF
|
|
|
|
#define UART0_WAIT_TXDONE() while( (U0TCTL & TXEPT) == 0 ) { _NOP(); }
|
|
|
|
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "kernel.h"
|
2013-05-25 12:34:18 +02:00
|
|
|
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "board_uart0.h"
|
2013-05-25 12:34:18 +02:00
|
|
|
|
|
|
|
int putchar(int c)
|
|
|
|
{
|
|
|
|
UART0_TX = c;
|
|
|
|
UART0_WAIT_TXDONE();
|
|
|
|
|
|
|
|
if (c == 10) {
|
|
|
|
UART0_TX = 13;
|
|
|
|
UART0_WAIT_TXDONE();
|
|
|
|
}
|
|
|
|
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
|
|
|
void usart0irq(void);
|
|
|
|
/**
|
|
|
|
* \brief the interrupt function
|
|
|
|
*/
|
|
|
|
interrupt(USART0RX_VECTOR) usart0irq(void) {
|
|
|
|
int dummy = 0;
|
|
|
|
/* Check status register for receive errors. */
|
|
|
|
if(U0RCTL & RXERR) {
|
|
|
|
if (U0RCTL & FE) {
|
|
|
|
puts("rx framing error");
|
|
|
|
}
|
|
|
|
if (U0RCTL & OE) {
|
|
|
|
puts("rx overrun error");
|
|
|
|
}
|
|
|
|
if (U0RCTL & PE) {
|
|
|
|
puts("rx parity error");
|
|
|
|
}
|
|
|
|
if (U0RCTL & BRK) {
|
|
|
|
puts("rx break error");
|
|
|
|
}
|
|
|
|
/* Clear error flags by forcing a dummy read. */
|
|
|
|
dummy = U0RXBUF;
|
|
|
|
}
|
|
|
|
#ifdef MODULE_UART0
|
2014-08-06 09:44:31 +02:00
|
|
|
else if (uart0_handler_pid != KERNEL_PID_UNDEF) {
|
2013-05-25 12:34:18 +02:00
|
|
|
dummy = U0RXBUF;
|
|
|
|
uart0_handle_incoming(dummy);
|
|
|
|
uart0_notify_thread();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|