altos/telegps-v2.0: Set CPU clock to 48MHz instread of 96MHz
[fw/altos] / src / teleterra-v0.2 / ao_pins.h
1 /*
2  * Copyright © 2011 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; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
17  */
18
19 #ifndef _AO_PINS_H_
20 #define _AO_PINS_H_
21
22 #ifdef TELETERRA_V_0_2
23         #define HAS_FLIGHT              0
24         #define HAS_USB                 1
25         #define HAS_RADIO               1
26         #define HAS_BEEP                1
27         #define HAS_GPS                 1
28         #define HAS_SERIAL_1            1
29         #define HAS_ADC                 0
30         #define HAS_LCD                 1
31         #define HAS_EEPROM              1
32         #define HAS_LOG                 1
33         #define USE_INTERNAL_FLASH      0
34         #define HAS_DBG                 1
35         #define DBG_ON_P1               1
36         #define DBG_ON_P0               0
37         #define IGNITE_ON_P2            0
38         #define IGNITE_ON_P0            0
39         #define PACKET_HAS_MASTER       1
40         #define PACKET_HAS_SLAVE        0
41         #define HAS_RADIO_CHANNELS      1
42
43         #define HAS_COMPANION           0
44
45         #define AO_MONITOR_LED          0
46         #define LEDS_AVAILABLE          0
47         #define HAS_EXTERNAL_TEMP       0
48         #define HAS_ACCEL_REF           0
49         #define HAS_ACCEL               0
50         #define HAS_IGNITE              0
51         #define HAS_MONITOR             1
52         #define HAS_MONITOR_PUT         1
53         #define LEGACY_MONITOR          0
54         #define HAS_RSSI                0
55         #define HAS_AES                 0
56
57         #define SPI_CS_ON_P1            1
58         #define SPI_CS_ON_P0            0
59         #define M25_CS_MASK             0x04
60         #define M25_MAX_CHIPS           1
61
62         #define HAS_BUTTON              1
63         #define BUTTON_1_REG            0
64         #define BUTTON_1_MASK           (1 << 4)        /* P0_4 */
65
66         #define BUTTON_2_REG            2
67         #define BUTTON_2_MASK           (1 << 3)        /* P2_3 */
68
69         #define BUTTON_3_REG            2
70         #define BUTTON_3_MASK           (1 << 4)        /* P2_4 */
71
72         #define HAS_P2_ISR              1
73
74         #define BATTERY_PIN             5
75         #define HAS_TELEMETRY           0
76
77         #define AO_VALUE_32             0
78 #endif
79
80 #if DBG_ON_P1
81
82         #define DBG_CLOCK       (1 << 4)        /* mi0 */
83         #define DBG_DATA        (1 << 5)        /* mo0 */
84         #define DBG_RESET_N     (1 << 3)        /* c0 */
85
86         #define DBG_CLOCK_PIN   (P1_4)
87         #define DBG_DATA_PIN    (P1_5)
88         #define DBG_RESET_N_PIN (P1_3)
89
90         #define DBG_PORT_NUM    1
91         #define DBG_PORT        P1
92         #define DBG_PORT_SEL    P1SEL
93         #define DBG_PORT_INP    P1INP
94         #define DBG_PORT_DIR    P1DIR
95
96 #endif /* DBG_ON_P1 */
97
98 #if DBG_ON_P0
99
100         #define DBG_CLOCK       (1 << 3)
101         #define DBG_DATA        (1 << 4)
102         #define DBG_RESET_N     (1 << 5)
103
104         #define DBG_CLOCK_PIN   (P0_3)
105         #define DBG_DATA_PIN    (P0_4)
106         #define DBG_RESET_N_PIN (P0_5)
107
108         #define DBG_PORT_NUM    0
109         #define DBG_PORT        P0
110         #define DBG_PORT_SEL    P0SEL
111         #define DBG_PORT_INP    P0INP
112         #define DBG_PORT_DIR    P0DIR
113
114 #endif /* DBG_ON_P0 */
115
116 #if COMPANION_CS_ON_P1
117         #define COMPANION_CS_PORT       P1
118         #define COMPANION_CS_SEL        P1SEL
119         #define COMPANION_CS_DIR        P1DIR
120 #endif
121
122 #if SPI_CS_ON_P1
123         #define SPI_CS_PORT     P1
124         #define SPI_CS_SEL      P1SEL
125         #define SPI_CS_DIR      P1DIR
126 #endif
127
128 #if SPI_CS_ON_P0
129         #define SPI_CS_PORT     P0
130         #define SPI_CS_SEL      P0SEL
131         #define SPI_CS_DIR      P0DIR
132 #endif
133
134 #ifndef IGNITE_ON_P2
135 #error Please define IGNITE_ON_P2
136 #endif
137
138 #ifndef IGNITE_ON_P0
139 #error Please define IGNITE_ON_P0
140 #endif
141
142 #ifndef HAS_SERIAL_1
143 #error Please define HAS_SERIAL_1
144 #endif
145
146 #ifndef HAS_ADC
147 #error Please define HAS_ADC
148 #endif
149
150 #ifndef HAS_EEPROM
151 #error Please define HAS_EEPROM
152 #endif
153
154 #ifndef HAS_LOG
155 #error Please define HAS_LOG
156 #endif
157
158 #if HAS_EEPROM
159 #ifndef USE_INTERNAL_FLASH
160 #error Please define USE_INTERNAL_FLASH
161 #endif
162 #endif
163
164 #ifndef HAS_DBG
165 #error Please define HAS_DBG
166 #endif
167
168 #ifndef HAS_IGNITE
169 #error Please define HAS_IGNITE
170 #endif
171
172 #if HAS_IGNITE
173 #define HAS_IGNITE_REPORT 1
174 #endif
175
176 #ifndef PACKET_HAS_MASTER
177 #error Please define PACKET_HAS_MASTER
178 #endif
179
180 #ifndef PACKET_HAS_SLAVE
181 #error Please define PACKET_HAS_SLAVE
182 #endif
183
184 #ifndef HAS_MONITOR
185 #error Please define HAS_MONITOR
186 #endif
187
188 #if HAS_MONITOR
189 #ifndef HAS_RSSI
190 #error Please define HAS_RSSI
191 #endif
192 #endif
193
194 #ifndef HAS_ADC
195 #error Please define HAS_ADC
196 #endif
197
198 #if HAS_ADC
199
200 #if HAS_ACCEL
201 #ifndef HAS_ACCEL_REF
202 #error Please define HAS_ACCEL_REF
203 #endif
204 #else
205 #define HAS_ACCEL_REF 0
206 #endif
207
208 #endif /* HAS_ADC */
209
210 #if IGNITE_ON_P2
211 #define AO_IGNITER_DROGUE       P2_3
212 #define AO_IGNITER_MAIN         P2_4
213 #define AO_IGNITER_DIR          P2DIR
214 #define AO_IGNITER_DROGUE_BIT   (1 << 3)
215 #define AO_IGNITER_MAIN_BIT     (1 << 4)
216 #endif
217
218 #if IGNITE_ON_P0
219 #define AO_IGNITER_DROGUE       P0_5
220 #define AO_IGNITER_MAIN         P0_4
221 #define AO_IGNITER_DIR          P0DIR
222 #define AO_IGNITER_DROGUE_BIT   (1 << 5)
223 #define AO_IGNITER_MAIN_BIT     (1 << 4)
224 #endif
225
226 /* test these values with real igniters */
227 #define AO_IGNITER_OPEN         1000
228 #define AO_IGNITER_CLOSED       7000
229 #define AO_IGNITER_FIRE_TIME    AO_MS_TO_TICKS(50)
230 #define AO_IGNITER_CHARGE_TIME  AO_MS_TO_TICKS(2000)
231
232 #define AO_M25_SPI_CS_PORT      SPI_CS_PORT
233 #define AO_M25_SPI_CS_MASK      M25_CS_MASK
234
235 #endif /* _AO_PINS_H_ */