altosdroid: Auto tab changing
[fw/altos] / src / stm-demo / ao_pins.h
1 /*
2  * Copyright © 2012 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 /* Bridge SB17 on the board and use the MCO from the other chip */
22 #define AO_HSE          8000000
23 #define AO_HSE_BYPASS           1
24
25 /* PLLVCO = 96MHz (so that USB will work) */
26 #define AO_PLLMUL               12
27 #define AO_RCC_CFGR_PLLMUL      (STM_RCC_CFGR_PLLMUL_12)
28
29 /* SYSCLK = 32MHz */
30 #define AO_PLLDIV               3
31 #define AO_RCC_CFGR_PLLDIV      (STM_RCC_CFGR_PLLDIV_3)
32
33 /* HCLK = 32MHZ (CPU clock) */
34 #define AO_AHB_PRESCALER        1
35 #define AO_RCC_CFGR_HPRE_DIV    STM_RCC_CFGR_HPRE_DIV_1
36
37 /* Run APB1 at HCLK/1 */
38 #define AO_APB1_PRESCALER       1
39 #define AO_RCC_CFGR_PPRE1_DIV   STM_RCC_CFGR_PPRE2_DIV_1
40
41 /* Run APB2 at HCLK/1 */
42 #define AO_APB2_PRESCALER       1
43 #define AO_RCC_CFGR_PPRE2_DIV   STM_RCC_CFGR_PPRE2_DIV_1
44
45 #define HAS_SERIAL_1            1
46 #define USE_SERIAL_1_STDIN      1
47 #define SERIAL_1_PB6_PB7        1
48 #define SERIAL_1_PA9_PA10       0
49
50 #define HAS_SERIAL_2            0
51 #define USE_SERIAL_2_STDIN      1
52 #define SERIAL_2_PA2_PA3        0
53 #define SERIAL_2_PD5_PD6        1
54
55 #define HAS_SERIAL_3            0
56 #define USE_SERIAL_3_STDIN      1
57 #define SERIAL_3_PB10_PB11      0
58 #define SERIAL_3_PC10_PC11      0
59 #define SERIAL_3_PD8_PD9        1
60
61 #define HAS_SPI_1               1
62 #define SPI_1_PB3_PB4_PB5       1
63
64 #define HAS_SPI_2               0
65
66 #define HAS_USB                 1
67 #define HAS_BEEP                0
68 #define PACKET_HAS_SLAVE        0
69
70 #define LOW_LEVEL_DEBUG         1
71
72 #define LED_PORT_ENABLE         STM_RCC_AHBENR_GPIOBEN
73 #define LED_PORT                (&stm_gpiob)
74 #define LED_PIN_GREEN           7
75 #define LED_PIN_BLUE            6
76 #define AO_LED_GREEN            (1 << LED_PIN_GREEN)
77 #define AO_LED_BLUE             (1 << LED_PIN_BLUE)
78
79 #define AO_LED_RED              AO_LED_BLUE     /* a patent lie */
80
81 #define LEDS_AVAILABLE          (AO_LED_BLUE | AO_LED_GREEN)
82
83 #define AO_LCD_STM_SEG_ENABLED_0 (              \
84                 (1 << 0) | /* PA1 */            \
85                 (1 << 1) | /* PA2 */            \
86                 (1 << 2) | /* PA3 */            \
87                 (0 << 3) | /* PA6 */            \
88                 (0 << 4) | /* PA7 */            \
89                 (0 << 5) | /* PB0 */            \
90                 (0 << 6) | /* PB1 */            \
91                 (1 << 7) | /* PB3 */            \
92                 (1 << 8) | /* PB4 */            \
93                 (1 << 9) | /* PB5 */            \
94                 (1 << 10) | /* PB10 */          \
95                 (1 << 11) | /* PB11 */          \
96                 (1 << 12) | /* PB12 */          \
97                 (1 << 13) | /* PB13 */          \
98                 (1 << 14) | /* PB14 */          \
99                 (1 << 15) | /* PB15 */          \
100                 (1 << 16) | /* PB8 */           \
101                 (1 << 17) | /* PA15 */          \
102                 (1 << 18) | /* PC0 */           \
103                 (1 << 19) | /* PC1 */           \
104                 (1 << 20) | /* PC2 */           \
105                 (1 << 21) | /* PC3 */           \
106                 (0 << 22) | /* PC4 */           \
107                 (0 << 23) | /* PC5 */           \
108                 (1 << 24) | /* PC6 */           \
109                 (1 << 25) | /* PC7 */           \
110                 (1 << 26) | /* PC8 */           \
111                 (1 << 27) | /* PC9 */           \
112                 (1 << 28) | /* PC10 or PD8 */   \
113                 (1 << 29) | /* PC11 or PD9 */   \
114                 (0 << 30) | /* PC12 or PD10 */  \
115                 (0 << 31))  /* PD2 or PD11 */
116
117 #define AO_LCD_STM_SEG_ENABLED_1 (              \
118                 (0 << 0) | /* PD12 */           \
119                 (0 << 1) | /* PD13 */           \
120                 (0 << 2) | /* PD14 */           \
121                 (0 << 3) | /* PD15 */           \
122                 (0 << 4) | /* PE0 */            \
123                 (0 << 5) | /* PE1 */            \
124                 (0 << 6) | /* PE2 */            \
125                 (0 << 7))  /* PE3 */
126
127 #define AO_LCD_STM_COM_ENABLED (                \
128                 (1 << 0) | /* PA8 */            \
129                 (1 << 1) | /* PA9 */            \
130                 (1 << 2) | /* PA10 */           \
131                 (1 << 3) | /* PB9 */            \
132                 (0 << 4) | /* PC10 */           \
133                 (0 << 5) | /* PC11 */           \
134                 (0 << 6)) /* PC12 */
135
136 #define AO_LCD_28_ON_C  1
137
138 #define AO_LCD_DUTY     STM_LCD_CR_DUTY_STATIC
139
140 #define HAS_ADC                 1
141
142 #define AO_ADC_RING             32
143
144 struct ao_adc {
145         uint16_t                tick;
146         int16_t                 idd;
147         int16_t                 temp;
148         int16_t                 vref;
149 };
150
151 #define AO_ADC_IDD              4
152 #define AO_ADC_PIN0_PORT        (&stm_gpioa)
153 #define AO_ADC_PIN0_PIN         4
154
155 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_GPIOAEN))
156 #define AO_ADC_TEMP             16
157 #define AO_ADC_VREF             17
158
159 #define HAS_ADC_TEMP            1
160
161 #define AO_DATA_RING            32
162 #define AO_NUM_ADC              3
163
164 #define AO_ADC_SQ1              AO_ADC_IDD
165 #define AO_ADC_SQ2              AO_ADC_TEMP
166 #define AO_ADC_SQ3              AO_ADC_VREF
167         
168 #define HAS_I2C_1               1
169 #define I2C_1_PB6_PB7           0
170 #define I2C_1_PB8_PB9           1
171
172 #define HAS_I2C_2               0
173 #define I2C_2_PB10_PB11         0
174
175 #define AO_EVENT                1
176
177 #define AO_QUADRATURE_COUNT     2
178 #define AO_QUADRATURE_MODE      AO_EXTI_MODE_PULL_UP
179
180 #define AO_QUADRATURE_0_PORT    &stm_gpioc
181 #define AO_QUADRATURE_0_A       1
182 #define AO_QUADRATURE_0_B       0
183
184 #define AO_QUADRATURE_1_PORT    &stm_gpioc
185 #define AO_QUADRATURE_1_A       3
186 #define AO_QUADRATURE_1_B       2
187
188 #define AO_BUTTON_COUNT         2
189 #define AO_BUTTON_MODE          AO_EXTI_MODE_PULL_UP
190
191 #define AO_BUTTON_0_PORT        &stm_gpioc
192 #define AO_BUTTON_0             6
193
194 #define AO_BUTTON_1_PORT        &stm_gpioc
195 #define AO_BUTTON_1             7
196
197 #define AO_TICK_TYPE            uint32_t
198 #define AO_TICK_SIGNED          int32_t
199
200 #endif /* _AO_PINS_H_ */