altos: Make STM clock configuration per-product. Fix 32MHz CPU speed
[fw/altos] / src / teleterra-v0.1 / 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; 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 #ifdef TELETERRA_V_0_1
22         #define HAS_FLIGHT              0
23         #define HAS_USB                 1
24         #define HAS_BEEP                0
25         #define HAS_GPS                 0
26         #define HAS_SERIAL_1            0
27         #define HAS_ADC                 0
28         #define USE_SERIAL_STDIN        0
29         #define HAS_EEPROM              1
30         #define HAS_LOG                 1
31         #define USE_INTERNAL_FLASH      0
32         #define HAS_DBG                 1
33         #define DBG_ON_P1               1
34         #define DBG_ON_P0               0
35         #define IGNITE_ON_P2            0
36         #define IGNITE_ON_P0            0
37         #define PACKET_HAS_MASTER       1
38         #define PACKET_HAS_SLAVE        0
39
40         #define HAS_COMPANION           1
41         #define COMPANION_CS_ON_P1      1
42         #define COMPANION_CS_MASK       0x4     /* CS1 is P1_2 */
43         #define COMPANION_CS            P1_2
44
45         #define AO_LED_RED              1
46         #define LEDS_AVAILABLE          (AO_LED_RED)
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_RSSI                0
53         #define HAS_AES                 1
54
55         #define SPI_CS_ON_P1            0
56         #define SPI_CS_ON_P0            1
57         #define M25_CS_MASK             0xf
58         #define M25_MAX_CHIPS           4
59 #endif
60
61 #if DBG_ON_P1
62
63         #define DBG_CLOCK       (1 << 4)        /* mi0 */
64         #define DBG_DATA        (1 << 5)        /* mo0 */
65         #define DBG_RESET_N     (1 << 3)        /* c0 */
66
67         #define DBG_CLOCK_PIN   (P1_4)
68         #define DBG_DATA_PIN    (P1_5)
69         #define DBG_RESET_N_PIN (P1_3)
70
71         #define DBG_PORT_NUM    1
72         #define DBG_PORT        P1
73         #define DBG_PORT_SEL    P1SEL
74         #define DBG_PORT_INP    P1INP
75         #define DBG_PORT_DIR    P1DIR
76
77 #endif /* DBG_ON_P1 */
78
79 #if DBG_ON_P0
80
81         #define DBG_CLOCK       (1 << 3)
82         #define DBG_DATA        (1 << 4)
83         #define DBG_RESET_N     (1 << 5)
84
85         #define DBG_CLOCK_PIN   (P0_3)
86         #define DBG_DATA_PIN    (P0_4)
87         #define DBG_RESET_N_PIN (P0_5)
88
89         #define DBG_PORT_NUM    0
90         #define DBG_PORT        P0
91         #define DBG_PORT_SEL    P0SEL
92         #define DBG_PORT_INP    P0INP
93         #define DBG_PORT_DIR    P0DIR
94
95 #endif /* DBG_ON_P0 */
96
97 #if COMPANION_CS_ON_P1
98         #define COMPANION_CS_PORT       P1
99         #define COMPANION_CS_SEL        P1SEL
100         #define COMPANION_CS_DIR        P1DIR
101 #endif
102
103 #if SPI_CS_ON_P1
104         #define SPI_CS_PORT     P1
105         #define SPI_CS_SEL      P1SEL
106         #define SPI_CS_DIR      P1DIR
107 #endif
108
109 #if SPI_CS_ON_P0
110         #define SPI_CS_PORT     P0
111         #define SPI_CS_SEL      P0SEL
112         #define SPI_CS_DIR      P0DIR
113 #endif
114
115 #ifndef IGNITE_ON_P2
116 #error Please define IGNITE_ON_P2
117 #endif
118
119 #ifndef IGNITE_ON_P0
120 #error Please define IGNITE_ON_P0
121 #endif
122
123 #ifndef HAS_SERIAL_1
124 #error Please define HAS_SERIAL_1
125 #endif
126
127 #ifndef USE_SERIAL_STDIN
128 #error Please define USE_SERIAL_STDIN
129 #endif
130
131 #ifndef HAS_ADC
132 #error Please define HAS_ADC
133 #endif
134
135 #ifndef HAS_EEPROM
136 #error Please define HAS_EEPROM
137 #endif
138
139 #ifndef HAS_LOG
140 #error Please define HAS_LOG
141 #endif
142
143 #if HAS_EEPROM
144 #ifndef USE_INTERNAL_FLASH
145 #error Please define USE_INTERNAL_FLASH
146 #endif
147 #endif
148
149 #ifndef HAS_DBG
150 #error Please define HAS_DBG
151 #endif
152
153 #ifndef HAS_IGNITE
154 #error Please define HAS_IGNITE
155 #endif
156
157 #if HAS_IGNITE
158 #define HAS_IGNITE_REPORT 1
159 #endif
160
161 #ifndef PACKET_HAS_MASTER
162 #error Please define PACKET_HAS_MASTER
163 #endif
164
165 #ifndef PACKET_HAS_SLAVE
166 #error Please define PACKET_HAS_SLAVE
167 #endif
168
169 #ifndef HAS_MONITOR
170 #error Please define HAS_MONITOR
171 #endif
172
173 #if HAS_MONITOR
174 #ifndef HAS_RSSI
175 #error Please define HAS_RSSI
176 #endif
177 #endif
178
179 #ifndef HAS_ADC
180 #error Please define HAS_ADC
181 #endif
182
183 #if HAS_ADC
184
185 #if HAS_ACCEL
186 #ifndef HAS_ACCEL_REF
187 #error Please define HAS_ACCEL_REF
188 #endif
189 #else
190 #define HAS_ACCEL_REF 0
191 #endif
192
193 #endif /* HAS_ADC */
194
195 #if IGNITE_ON_P2
196 #define AO_IGNITER_DROGUE       P2_3
197 #define AO_IGNITER_MAIN         P2_4
198 #define AO_IGNITER_DIR          P2DIR
199 #define AO_IGNITER_DROGUE_BIT   (1 << 3)
200 #define AO_IGNITER_MAIN_BIT     (1 << 4)
201 #endif
202
203 #if IGNITE_ON_P0
204 #define AO_IGNITER_DROGUE       P0_5
205 #define AO_IGNITER_MAIN         P0_4
206 #define AO_IGNITER_DIR          P0DIR
207 #define AO_IGNITER_DROGUE_BIT   (1 << 5)
208 #define AO_IGNITER_MAIN_BIT     (1 << 4)
209 #endif
210
211 /* test these values with real igniters */
212 #define AO_IGNITER_OPEN         1000
213 #define AO_IGNITER_CLOSED       7000
214 #define AO_IGNITER_FIRE_TIME    AO_MS_TO_TICKS(50)
215 #define AO_IGNITER_CHARGE_TIME  AO_MS_TO_TICKS(2000)
216
217 #endif /* _AO_PINS_H_ */