Contiki 2.5
cb_uart01.c
1 /*
2  * Copyright (c) 2007, Swedish Institute of Computer Science
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * 3. Neither the name of the Institute nor the names of its contributors
14  * may be used to endorse or promote products derived from this software
15  * without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  *
29  * @(#)$Id: cb_uart01.c,v 1.1 2007/02/02 14:09:06 bg- Exp $
30  */
31 
32 #include <stdio.h>
33 
34 #include <avr/interrupt.h>
35 
36 #include "contiki.h"
37 
38 #include "dev/slip.h"
39 
40 static int
41 uart0_putchar(char c, FILE *stream)
42 {
43  while (!(UCSR0A & BV(UDRE0)))
44  ;
45  UDR0 = c;
46 
47  return c;
48 }
49 
50 static FILE uart0_stdout =
51 FDEV_SETUP_STREAM(uart0_putchar, NULL, _FDEV_SETUP_WRITE);
52 
53 void
54 slip_arch_init(unsigned long ubr)
55 {
56  u8_t dummy;
57  spl_t s = splhigh();
58 
59  UBRR1L = ubr;
60  UBRR1H = ubr >> 8;
61 
62  UCSR1C = BV(UCSZ1) | BV(UCSZ0); /* 1 start bit, no parity, 1 stop bit */
63  UCSR1B = BV(RXEN) | BV(TXEN) | BV(RXCIE);
64  dummy = UDR1; /* Flush RX buffer. */
65 
66  /* And now UART0. */
67  UBRR0L = BAUD2UBR(38400);
68  UBRR0H = BAUD2UBR(38400) >> 8;
69 
70  UCSR0C = BV(UCSZ1) | BV(UCSZ0); /* 1 start bit, no parity, 1 stop bit */
71  UCSR0B = BV(TXEN); /* TX ONLY!!! */
72 
73  splx(s);
74 
75  stdout = &uart0_stdout;
76 }
77 
78 void
79 slip_arch_writeb(unsigned char c)
80 {
81  while (!(UCSR1A & BV(UDRE1)))
82  ;
83  UDR1 = c;
84 }
85 
86 ISR(SIG_UART1_RECV)
87 {
88  /* Should deal with receive errors. */
89  slip_input_byte(UDR1);
90 }