altos: Split out SPI driver.
[fw/altos] / src / ao_pins.h
1 /*
2  * Copyright © 2010 Keith Packard <keithp@keithp.com>
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; version 2 of the License.
7  *
8  * This program is distributed in the hope that it will be useful, but
9  * WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11  * General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License along
14  * with this program; if not, write to the Free Software Foundation, Inc.,
15  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
16  */
17
18 #ifndef _AO_PINS_H_
19 #define _AO_PINS_H_
20
21 #if defined(TELEMETRUM_V_1_0)
22         #define HAS_SERIAL_1            1
23         #define HAS_ADC                 1
24         #define HAS_EEPROM              1
25         #define HAS_DBG                 1
26         #define DBG_ON_P1               1
27         #define DBG_ON_P0               0
28         #define PACKET_HAS_MASTER       0
29         #define PACKET_HAS_SLAVE        1
30
31         #define AO_LED_RED              1
32         #define LEDS_AVAILABLE          (AO_LED_RED)
33         #define HAS_EXTERNAL_TEMP       0
34         #define SPI_CS_ON_P1            1
35         #define SPI_CS_ON_P0            0
36 #endif
37
38 #if defined(TELEDONGLE_V_0_2)
39         #define HAS_SERIAL_1            0
40         #define HAS_ADC                 0
41         #define HAS_DBG                 1
42         #define HAS_EEPROM              0
43         #define DBG_ON_P1               1
44         #define DBG_ON_P0               0
45         #define PACKET_HAS_MASTER       1
46         #define PACKET_HAS_SLAVE        0
47         #define AO_LED_RED              1
48         #define AO_LED_GREEN            2
49         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
50         #define SPI_CS_ON_P1            1
51         #define SPI_CS_ON_P0            0
52 #endif
53
54 #if defined(TELEMETRUM_V_0_1)
55         #define HAS_SERIAL_1            1
56         #define HAS_ADC                 1
57         #define HAS_DBG                 0
58         #define HAS_EEPROM              1
59         #define DBG_ON_P1               0
60         #define DBG_ON_P0               1
61         #define PACKET_HAS_MASTER       0
62         #define PACKET_HAS_SLAVE        1
63         #define AO_LED_RED              2
64         #define AO_LED_GREEN            1
65         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
66         #define HAS_EXTERNAL_TEMP       1
67         #define SPI_CS_ON_P1            1
68         #define SPI_CS_ON_P0            0
69 #endif
70
71 #if defined(TELEDONGLE_V_0_1)
72         #define HAS_SERIAL_1            0
73         #define HAS_ADC                 0
74         #define HAS_DBG                 0
75         #define HAS_EEPROM              0
76         #define DBG_ON_P1               0
77         #define DBG_ON_P0               1
78         #define PACKET_HAS_MASTER       1
79         #define PACKET_HAS_SLAVE        0
80         #define AO_LED_RED              2
81         #define AO_LED_GREEN            1
82         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
83         #define SPI_CS_ON_P1            0
84         #define SPI_CS_ON_P0            1
85 #endif
86
87 #if defined(TIDONGLE)
88         #define HAS_SERIAL_1            0
89         #define HAS_ADC                 0
90         #define HAS_DBG                 1
91         #define HAS_EEPROM              0
92         #define DBG_ON_P1               0
93         #define DBG_ON_P0               1
94         #define PACKET_HAS_MASTER       1
95         #define PACKET_HAS_SLAVE        0
96         #define AO_LED_RED              2
97         #define LEDS_AVAILABLE          (AO_LED_RED)
98         #define SPI_CS_ON_P1            0
99         #define SPI_CS_ON_P0            1
100 #endif
101
102 #if DBG_ON_P1
103
104         #define DBG_CLOCK       (1 << 4)        /* mi0 */
105         #define DBG_DATA        (1 << 5)        /* mo0 */
106         #define DBG_RESET_N     (1 << 3)        /* c0 */
107
108         #define DBG_CLOCK_PIN   (P1_4)
109         #define DBG_DATA_PIN    (P1_5)
110         #define DBG_RESET_N_PIN (P1_3)
111
112         #define DBG_PORT_NUM    1
113         #define DBG_PORT        P1
114         #define DBG_PORT_SEL    P1SEL
115         #define DBG_PORT_INP    P1INP
116         #define DBG_PORT_DIR    P1DIR
117
118 #endif /* DBG_ON_P1 */
119
120 #if DBG_ON_P0
121
122         #define DBG_CLOCK       (1 << 3)
123         #define DBG_DATA        (1 << 4)
124         #define DBG_RESET_N     (1 << 5)
125
126         #define DBG_CLOCK_PIN   (P0_3)
127         #define DBG_DATA_PIN    (P0_4)
128         #define DBG_RESET_N_PIN (P0_5)
129
130         #define DBG_PORT_NUM    0
131         #define DBG_PORT        P0
132         #define DBG_PORT_SEL    P0SEL
133         #define DBG_PORT_INP    P0INP
134         #define DBG_PORT_DIR    P0DIR
135
136 #endif /* DBG_ON_P0 */
137
138 #if SPI_CS_ON_P1
139         #define SPI_CS_PORT     P1
140         #define SPI_CS_SEL      P1SEL
141         #define SPI_CS_DIR      P1DIR
142 #endif
143
144 #if SPI_CS_ON_P0
145         #define SPI_CS_PORT     P0
146         #define SPI_CS_SEL      P0SEL
147         #define SPI_CS_DIR      P0DIR
148 #endif
149
150 #ifndef HAS_SERIAL_1
151 #error Please define HAS_SERIAL_1
152 #endif
153
154 #ifndef HAS_ADC
155 #error Please define HAS_ADC
156 #endif
157
158 #ifndef HAS_EEPROM
159 #error Please define HAS_EEPROM
160 #endif
161
162 #ifndef HAS_DBG
163 #error Please define HAS_DBG
164 #endif
165
166 #ifndef PACKET_HAS_MASTER
167 #error Please define PACKET_HAS_MASTER
168 #endif
169
170 #ifndef PACKET_HAS_SLAVE
171 #error Please define PACKET_HAS_SLAVE
172 #endif
173
174 #endif /* _AO_PINS_H_ */