Makefile: Use CPPFLAGS for -I stuff
[simavr] / simavr / sim / avr_spi.h
1 /*
2         avr_spi.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_SPI_H_
23 #define AVR_SPI_H_
24
25 #include "sim_avr.h"
26
27 enum {
28         SPI_IRQ_INPUT = 0,
29         SPI_IRQ_OUTPUT,
30         SPI_IRQ_COUNT
31 };
32
33 // add port number to get the real IRQ
34 #define AVR_IOCTL_SPI_GETIRQ(_name) AVR_IOCTL_DEF('s','p','i',(_name))
35
36 typedef struct avr_spi_t {
37         avr_io_t        io;
38         char name;
39         avr_regbit_t    disabled;       // bit in the PRR
40
41         avr_io_addr_t   r_spdr;                 // data register
42         avr_io_addr_t   r_spcr;                 // control register
43         avr_io_addr_t   r_spsr;                 // status register
44         
45         avr_regbit_t spe;               // spi enable
46         avr_regbit_t mstr;              // master/slave
47         avr_regbit_t spr[4];    // clock divider
48         
49         avr_int_vector_t spi;   // spi interrupt
50
51         uint8_t         input_data_register;
52 } avr_spi_t;
53
54 void avr_spi_init(avr_t * avr, avr_spi_t * port);
55
56 #endif /* AVR_SPI_H_ */