altos: Cannot scan for flash chips until the OS is running.
[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 AUDIO_STANDBY_ON_P2_4   0
35         #define SPI_CS_ON_P1            1
36         #define SPI_CS_ON_P0            0
37         #define M25_CS_MASK             0x02
38 #endif
39
40 #if defined(TELEDONGLE_V_0_2)
41         #define HAS_SERIAL_1            0
42         #define HAS_ADC                 0
43         #define HAS_DBG                 1
44         #define HAS_EEPROM              0
45         #define DBG_ON_P1               1
46         #define DBG_ON_P0               0
47         #define PACKET_HAS_MASTER       1
48         #define PACKET_HAS_SLAVE        0
49         #define AO_LED_RED              1
50         #define AO_LED_GREEN            2
51         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
52         #define AUDIO_STANDBY_ON_P2_4   0
53         #define SPI_CS_ON_P1            1
54         #define SPI_CS_ON_P0            0
55 #endif
56
57 #if defined(TELEMETRUM_V_0_1)
58         #define HAS_SERIAL_1            1
59         #define HAS_ADC                 1
60         #define HAS_DBG                 0
61         #define HAS_EEPROM              1
62         #define DBG_ON_P1               0
63         #define DBG_ON_P0               1
64         #define PACKET_HAS_MASTER       0
65         #define PACKET_HAS_SLAVE        1
66         #define AO_LED_RED              2
67         #define AO_LED_GREEN            1
68         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
69         #define HAS_EXTERNAL_TEMP       1
70         #define AUDIO_STANDBY_ON_P2_4   0
71         #define SPI_CS_ON_P1            1
72         #define SPI_CS_ON_P0            0
73 #endif
74
75 #if defined(TELEDONGLE_V_0_1)
76         #define HAS_SERIAL_1            0
77         #define HAS_ADC                 0
78         #define HAS_DBG                 0
79         #define HAS_EEPROM              0
80         #define DBG_ON_P1               0
81         #define DBG_ON_P0               1
82         #define PACKET_HAS_MASTER       1
83         #define PACKET_HAS_SLAVE        0
84         #define AO_LED_RED              2
85         #define AO_LED_GREEN            1
86         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
87         #define AUDIO_STANDBY_ON_P2_4   0
88         #define SPI_CS_ON_P1            1
89         #define SPI_CS_ON_P0            0
90 #endif
91
92 #if defined(TELETERRA_V_0_1)
93         #define HAS_SERIAL_1            1
94         #define HAS_ADC                 0
95         #define HAS_DBG                 1
96         #define HAS_EEPROM              0
97         #define DBG_ON_P1               1
98         #define DBG_ON_P0               0
99         #define PACKET_HAS_MASTER       1
100         #define PACKET_HAS_SLAVE        0
101         #define AO_LED_RED              1
102         #define AO_LED_GREEN            2
103         #define LEDS_AVAILABLE          (AO_LED_RED|AO_LED_GREEN)
104         #define AUDIO_STANDBY_ON_P2_4   1
105         #define SPI_CS_ON_P1            0
106         #define SPI_CS_ON_P0            1
107         #define M25_CS_MASK             0x0f
108 #endif
109
110 #if defined(TIDONGLE)
111         #define HAS_SERIAL_1            0
112         #define HAS_ADC                 0
113         #define HAS_DBG                 1
114         #define HAS_EEPROM              0
115         #define DBG_ON_P1               0
116         #define DBG_ON_P0               1
117         #define PACKET_HAS_MASTER       1
118         #define PACKET_HAS_SLAVE        0
119         #define AO_LED_RED              2
120         #define LEDS_AVAILABLE          (AO_LED_RED)
121         #define AUDIO_STANDBY_ON_P2_4   0
122         #define SPI_CS_ON_P1            1
123         #define SPI_CS_ON_P0            0
124 #endif
125
126 #if DBG_ON_P1
127
128         #define DBG_CLOCK       (1 << 4)        /* mi0 */
129         #define DBG_DATA        (1 << 5)        /* mo0 */
130         #define DBG_RESET_N     (1 << 3)        /* c0 */
131
132         #define DBG_CLOCK_PIN   (P1_4)
133         #define DBG_DATA_PIN    (P1_5)
134         #define DBG_RESET_N_PIN (P1_3)
135
136         #define DBG_PORT_NUM    1
137         #define DBG_PORT        P1
138         #define DBG_PORT_SEL    P1SEL
139         #define DBG_PORT_INP    P1INP
140         #define DBG_PORT_DIR    P1DIR
141
142 #endif /* DBG_ON_P1 */
143
144 #if DBG_ON_P0
145
146         #define DBG_CLOCK       (1 << 3)
147         #define DBG_DATA        (1 << 4)
148         #define DBG_RESET_N     (1 << 5)
149
150         #define DBG_CLOCK_PIN   (P0_3)
151         #define DBG_DATA_PIN    (P0_4)
152         #define DBG_RESET_N_PIN (P0_5)
153
154         #define DBG_PORT_NUM    0
155         #define DBG_PORT        P0
156         #define DBG_PORT_SEL    P0SEL
157         #define DBG_PORT_INP    P0INP
158         #define DBG_PORT_DIR    P0DIR
159
160 #endif /* DBG_ON_P0 */
161
162 #if SPI_CS_ON_P1
163         #define SPI_CS_PORT     P1
164         #define SPI_CS_SEL      P1SEL
165         #define SPI_CS_DIR      P1DIR
166 #endif
167
168 #if SPI_CS_ON_P0
169         #define SPI_CS_PORT     P0
170         #define SPI_CS_SEL      P0SEL
171         #define SPI_CS_DIR      P0DIR
172 #endif
173
174 #ifndef HAS_SERIAL_1
175 #error Please define HAS_SERIAL_1
176 #endif
177
178 #ifndef HAS_ADC
179 #error Please define HAS_ADC
180 #endif
181
182 #ifndef HAS_EEPROM
183 #error Please define HAS_EEPROM
184 #endif
185
186 #ifndef HAS_DBG
187 #error Please define HAS_DBG
188 #endif
189
190 #ifndef PACKET_HAS_MASTER
191 #error Please define PACKET_HAS_MASTER
192 #endif
193
194 #ifndef PACKET_HAS_SLAVE
195 #error Please define PACKET_HAS_SLAVE
196 #endif
197
198
199 #ifndef AUDIO_STANDBY_ON_P2_4
200 #error Please define AUDIO_STANDBY_ON_P2_4
201 #endif
202
203 #endif /* _AO_PINS_H_ */