Added a typedef for IO addresses
[simavr] / simavr / sim / avr_ioport.h
1 /*
2         avr_ioport.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_IOPORT_H__
23 #define __AVR_IOPORT_H__
24
25 #include "sim_avr.h"
26
27 enum {
28         IOPORT_IRQ_PIN0 = 0,
29         IOPORT_IRQ_PIN1,IOPORT_IRQ_PIN2,IOPORT_IRQ_PIN3,IOPORT_IRQ_PIN4,
30         IOPORT_IRQ_PIN5,IOPORT_IRQ_PIN6,IOPORT_IRQ_PIN7,
31         IOPORT_IRQ_PIN_ALL,
32         IOPORT_IRQ_COUNT
33 };
34
35 // add port name (uppercase) to get the real IRQ
36 #define AVR_IOCTL_IOPORT_GETIRQ(_name) AVR_IOCTL_DEF('i','o','g',(_name))
37
38 typedef struct avr_ioport_t {
39         avr_io_t        io;
40         char name;
41         avr_io_addr_t r_port;
42         avr_io_addr_t r_ddr;
43         avr_io_addr_t r_pin;
44
45         avr_int_vector_t pcint; // PCINT vector
46         avr_io_addr_t r_pcint;          // pcint 8 pins mask
47 } avr_ioport_t;
48
49 void avr_ioport_init(avr_t * avr, avr_ioport_t * port);
50
51
52 #endif /* __AVR_IOPORT_H__ */