9de90d244230c73996be62bff2eaedfc587cd0dc
[simavr] / simavr / sim / avr_uart.h
1 /*
2         avr_uart.h
3
4         Copyright 2008, 2009 Michel Pollet <buserror@gmail.com>
5
6         This file is part of simavr.
7
8         simavr is free software: you can redistribute it and/or modify
9         it under the terms of the GNU General Public License as published by
10         the Free Software Foundation, either version 3 of the License, or
11         (at your option) any later version.
12
13         simavr is distributed in the hope that it will be useful,
14         but WITHOUT ANY WARRANTY; without even the implied warranty of
15         MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16         GNU General Public License for more details.
17
18         You should have received a copy of the GNU General Public License
19         along with simavr.  If not, see <http://www.gnu.org/licenses/>.
20  */
21
22 #ifndef AVR_UART_H_
23 #define AVR_UART_H_
24
25 #include "simavr.h"
26
27 #include "fifo_declare.h"
28
29 DECLARE_FIFO(uint8_t, uart_fifo, 128);
30
31 enum {
32         UART_IRQ_INPUT = 0,
33         UART_IRQ_OUTPUT,
34         UART_IRQ_COUNT
35 };
36
37 // add port number to get the real IRQ
38 #define AVR_IOCTL_UART_GETIRQ(_name) AVR_IOCTL_DEF('u','a','r',(_name))
39
40 typedef struct avr_uart_t {
41         avr_io_t        io;
42         char name;
43         avr_regbit_t    disabled;       // bit in the PRR
44         
45         uint8_t r_udr;
46         uint8_t r_ucsra;
47         uint8_t r_ucsrb;
48         uint8_t r_ucsrc;
49
50         avr_regbit_t    rxen;           // receive enabled
51         avr_regbit_t    txen;           // transmit enable
52
53         uint8_t r_ubrrl,r_ubrrh;
54
55         avr_int_vector_t rxc;
56         avr_int_vector_t txc;
57         avr_int_vector_t udrc;  
58
59         uart_fifo_t     input;
60         uint16_t        input_cycle_timer;
61 } avr_uart_t;
62
63 void avr_uart_init(avr_t * avr, avr_uart_t * port);
64
65 #endif /* AVR_UART_H_ */