2 * Copyright © 2010 Keith Packard <keithp@keithp.com>
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.
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.
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.
21 #if defined(TELEMETRUM_V_1_0)
26 #define HAS_SERIAL_1 1
28 #define USE_SERIAL_STDIN 0
30 #define USE_INTERNAL_FLASH 0
34 #define IGNITE_ON_P2 1
35 #define IGNITE_ON_P0 0
36 #define PACKET_HAS_MASTER 0
37 #define PACKET_HAS_SLAVE 1
40 #define LEDS_AVAILABLE (AO_LED_RED)
41 #define HAS_EXTERNAL_TEMP 0
42 #define HAS_ACCEL_REF 0
47 #if defined(TELEMETRUM_V_1_1)
52 #define HAS_SERIAL_1 1
53 #define USE_SERIAL_STDIN 0
56 #define USE_INTERNAL_FLASH 0
60 #define IGNITE_ON_P2 1
61 #define IGNITE_ON_P0 0
62 #define PACKET_HAS_MASTER 0
63 #define PACKET_HAS_SLAVE 1
66 #define LEDS_AVAILABLE (AO_LED_RED)
67 #define HAS_EXTERNAL_TEMP 0
68 #define HAS_ACCEL_REF 1
69 #define SPI_CS_ON_P1 1
70 #define SPI_CS_ON_P0 0
71 #define M25_CS_MASK 0x02 /* CS0 is P1_1 */
72 #define M25_MAX_CHIPS 1
76 #define ASCENT_SIGNAL P1_2 /* Use CS1 to signal ascent */
77 #define ASCENT_SIGNAL_DIR P1DIR
78 #define ASCENT_SIGNAL_SEL P1SEL
79 #define ASCENT_SIGNAL_PIN 2
82 #if defined(TELETEST_V_1_1)
85 #define HAS_USB_TEST 1
88 #define HAS_SERIAL_1 1
89 #define USE_SERIAL_STDIN 0
92 #define USE_INTERNAL_FLASH 0
96 #define IGNITE_ON_P2 1
97 #define IGNITE_ON_P0 0
98 #define PACKET_HAS_MASTER 0
99 #define PACKET_HAS_SLAVE 1
102 #define LEDS_AVAILABLE (AO_LED_RED)
103 #define HAS_EXTERNAL_TEMP 0
104 #define HAS_ACCEL_REF 1
105 #define SPI_CS_ON_P1 1
106 #define SPI_CS_ON_P0 0
107 #define M25_CS_MASK 0x02 /* CS0 is P1_1 */
108 #define M25_MAX_CHIPS 1
112 #define ASCENT_SIGNAL P1_2 /* Use CS1 to signal ascent */
113 #define ASCENT_SIGNAL_DIR P1DIR
114 #define ASCENT_SIGNAL_SEL P1SEL
115 #define ASCENT_SIGNAL_PIN 2
118 #if defined(TELEDONGLE_V_0_2)
122 #define HAS_SERIAL_1 0
123 #define USE_SERIAL_STDIN 0
129 #define IGNITE_ON_P2 0
130 #define IGNITE_ON_P0 0
131 #define PACKET_HAS_MASTER 1
132 #define PACKET_HAS_SLAVE 0
134 #define AO_LED_GREEN 2
135 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
136 #define SPI_CS_ON_P1 1
137 #define SPI_CS_ON_P0 0
141 #if defined(TELEMINI_V_0_1)
146 #define HAS_SERIAL_1 0
147 #define USE_SERIAL_STDIN 0
150 #define USE_INTERNAL_FLASH 1
152 #define IGNITE_ON_P2 0
153 #define IGNITE_ON_P0 1
154 #define PACKET_HAS_MASTER 0
155 #define PACKET_HAS_SLAVE 1
156 #define USE_FAST_ASCENT_LOG 1
158 #define AO_LED_GREEN 1
160 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
161 #define HAS_EXTERNAL_TEMP 0
166 #if defined(TELENANO_V_0_1)
171 #define HAS_SERIAL_1 0
172 #define USE_SERIAL_STDIN 0
175 #define USE_INTERNAL_FLASH 1
177 #define IGNITE_ON_P2 0
178 #define IGNITE_ON_P0 1
179 #define PACKET_HAS_MASTER 0
180 #define PACKET_HAS_SLAVE 1
182 #define AO_LED_GREEN 1
184 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
185 #define HAS_EXTERNAL_TEMP 0
190 #if defined(TELEMETRUM_V_0_1)
195 #define HAS_SERIAL_1 1
196 #define USE_SERIAL_STDIN 0
200 #define USE_INTERNAL_FLASH 0
203 #define IGNITE_ON_P2 1
204 #define IGNITE_ON_P0 0
205 #define PACKET_HAS_MASTER 0
206 #define PACKET_HAS_SLAVE 1
208 #define AO_LED_GREEN 1
209 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
210 #define HAS_EXTERNAL_TEMP 1
211 #define HAS_ACCEL_REF 0
212 #define SPI_CS_ON_P1 1
213 #define SPI_CS_ON_P0 0
218 #if defined(TELEDONGLE_V_0_1)
222 #define HAS_SERIAL_1 0
223 #define USE_SERIAL_STDIN 0
229 #define IGNITE_ON_P2 0
230 #define IGNITE_ON_P0 0
231 #define PACKET_HAS_MASTER 1
232 #define PACKET_HAS_SLAVE 0
234 #define AO_LED_GREEN 1
235 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
236 #define SPI_CS_ON_P1 0
237 #define SPI_CS_ON_P0 1
241 #if defined(TIDONGLE)
245 #define HAS_SERIAL_1 0
246 #define USE_SERIAL_STDIN 0
252 #define IGNITE_ON_P2 0
253 #define IGNITE_ON_P0 0
254 #define PACKET_HAS_MASTER 1
255 #define PACKET_HAS_SLAVE 0
257 #define LEDS_AVAILABLE (AO_LED_RED)
258 #define SPI_CS_ON_P1 0
259 #define SPI_CS_ON_P0 1
263 #if defined(TELEBT_V_0_0)
267 #define HAS_SERIAL_1 1
268 #define USE_SERIAL_STDIN 1
275 #define IGNITE_ON_P2 0
276 #define IGNITE_ON_P0 0
277 #define PACKET_HAS_MASTER 1
278 #define PACKET_HAS_SLAVE 0
280 #define AO_LED_GREEN 1
281 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
282 #define SPI_CS_ON_P1 1
283 #define SPI_CS_ON_P0 0
285 #define BT_LINK_ON_P2 1
286 #define BT_LINK_ON_P1 0
287 #define BT_LINK_PIN_INDEX 7
288 #define BT_LINK_PIN P2_1
291 #if defined(TELEBT_V_0_1)
295 #define HAS_SERIAL_1 1
296 #define HAS_SERIAL_1_ALT_1 1
297 #define HAS_SERIAL_1_ALT_2 0
298 #define HAS_SERIAL_1_HW_FLOW 1
299 #define USE_SERIAL_STDIN 1
303 #define USE_INTERNAL_FLASH 0
307 #define IGNITE_ON_P2 0
308 #define IGNITE_ON_P0 0
309 #define PACKET_HAS_MASTER 1
310 #define PACKET_HAS_SLAVE 0
312 #define AO_LED_GREEN 2
313 #define LEDS_AVAILABLE (AO_LED_RED|AO_LED_GREEN)
314 #define SPI_CS_ON_P1 1
315 #define SPI_CS_ON_P0 0
316 #define M25_CS_MASK 0x04 /* CS0 is P1_2 */
317 #define M25_MAX_CHIPS 1
320 #define BT_LINK_ON_P2 0
321 #define BT_LINK_ON_P1 1
322 #define BT_LINK_PIN_INDEX 7
323 #define BT_LINK_PIN P1_7
328 #define DBG_CLOCK (1 << 4) /* mi0 */
329 #define DBG_DATA (1 << 5) /* mo0 */
330 #define DBG_RESET_N (1 << 3) /* c0 */
332 #define DBG_CLOCK_PIN (P1_4)
333 #define DBG_DATA_PIN (P1_5)
334 #define DBG_RESET_N_PIN (P1_3)
336 #define DBG_PORT_NUM 1
338 #define DBG_PORT_SEL P1SEL
339 #define DBG_PORT_INP P1INP
340 #define DBG_PORT_DIR P1DIR
342 #endif /* DBG_ON_P1 */
346 #define DBG_CLOCK (1 << 3)
347 #define DBG_DATA (1 << 4)
348 #define DBG_RESET_N (1 << 5)
350 #define DBG_CLOCK_PIN (P0_3)
351 #define DBG_DATA_PIN (P0_4)
352 #define DBG_RESET_N_PIN (P0_5)
354 #define DBG_PORT_NUM 0
356 #define DBG_PORT_SEL P0SEL
357 #define DBG_PORT_INP P0INP
358 #define DBG_PORT_DIR P0DIR
360 #endif /* DBG_ON_P0 */
363 #define SPI_CS_PORT P1
364 #define SPI_CS_SEL P1SEL
365 #define SPI_CS_DIR P1DIR
369 #define SPI_CS_PORT P0
370 #define SPI_CS_SEL P0SEL
371 #define SPI_CS_DIR P0DIR
375 #error Please define IGNITE_ON_P2
379 #error Please define IGNITE_ON_P0
383 #error Please define HAS_SERIAL_1
386 #ifndef USE_SERIAL_STDIN
387 #error Please define USE_SERIAL_STDIN
391 #error Please define HAS_ADC
395 #error Please define HAS_EEPROM
399 #ifndef USE_INTERNAL_FLASH
400 #error Please define USE_INTERNAL_FLASH
405 #error Please define HAS_DBG
409 #error Please define HAS_IGNITE
412 #ifndef PACKET_HAS_MASTER
413 #error Please define PACKET_HAS_MASTER
416 #ifndef PACKET_HAS_SLAVE
417 #error Please define PACKET_HAS_SLAVE
420 #endif /* _AO_PINS_H_ */