Merge remote-tracking branch 'mjb/altosdroid'
[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 #define SPI_1_OSPEEDR           STM_OSPEEDR_10MHz
64
65 #define HAS_SPI_2               0
66
67 #define HAS_USB                 1
68 #define HAS_BEEP                0
69 #define PACKET_HAS_SLAVE        0
70
71 #define LOW_LEVEL_DEBUG         1
72
73 #define LED_PORT_ENABLE         STM_RCC_AHBENR_GPIOBEN
74 #define LED_PORT                (&stm_gpiob)
75 #define LED_PIN_GREEN           7
76 #define LED_PIN_BLUE            6
77 #define AO_LED_GREEN            (1 << LED_PIN_GREEN)
78 #define AO_LED_BLUE             (1 << LED_PIN_BLUE)
79
80 #define AO_LED_RED              AO_LED_BLUE     /* a patent lie */
81
82 #define LEDS_AVAILABLE          (AO_LED_BLUE | AO_LED_GREEN)
83
84 #define AO_LCD_STM_SEG_ENABLED_0 (              \
85                 (1 << 0) | /* PA1 */            \
86                 (1 << 1) | /* PA2 */            \
87                 (1 << 2) | /* PA3 */            \
88                 (0 << 3) | /* PA6 */            \
89                 (0 << 4) | /* PA7 */            \
90                 (0 << 5) | /* PB0 */            \
91                 (0 << 6) | /* PB1 */            \
92                 (1 << 7) | /* PB3 */            \
93                 (1 << 8) | /* PB4 */            \
94                 (1 << 9) | /* PB5 */            \
95                 (1 << 10) | /* PB10 */          \
96                 (1 << 11) | /* PB11 */          \
97                 (1 << 12) | /* PB12 */          \
98                 (1 << 13) | /* PB13 */          \
99                 (1 << 14) | /* PB14 */          \
100                 (1 << 15) | /* PB15 */          \
101                 (1 << 16) | /* PB8 */           \
102                 (1 << 17) | /* PA15 */          \
103                 (1 << 18) | /* PC0 */           \
104                 (1 << 19) | /* PC1 */           \
105                 (1 << 20) | /* PC2 */           \
106                 (1 << 21) | /* PC3 */           \
107                 (0 << 22) | /* PC4 */           \
108                 (0 << 23) | /* PC5 */           \
109                 (1 << 24) | /* PC6 */           \
110                 (1 << 25) | /* PC7 */           \
111                 (1 << 26) | /* PC8 */           \
112                 (1 << 27) | /* PC9 */           \
113                 (1 << 28) | /* PC10 or PD8 */   \
114                 (1 << 29) | /* PC11 or PD9 */   \
115                 (0 << 30) | /* PC12 or PD10 */  \
116                 (0 << 31))  /* PD2 or PD11 */
117
118 #define AO_LCD_STM_SEG_ENABLED_1 (              \
119                 (0 << 0) | /* PD12 */           \
120                 (0 << 1) | /* PD13 */           \
121                 (0 << 2) | /* PD14 */           \
122                 (0 << 3) | /* PD15 */           \
123                 (0 << 4) | /* PE0 */            \
124                 (0 << 5) | /* PE1 */            \
125                 (0 << 6) | /* PE2 */            \
126                 (0 << 7))  /* PE3 */
127
128 #define AO_LCD_STM_COM_ENABLED (                \
129                 (1 << 0) | /* PA8 */            \
130                 (1 << 1) | /* PA9 */            \
131                 (1 << 2) | /* PA10 */           \
132                 (1 << 3) | /* PB9 */            \
133                 (0 << 4) | /* PC10 */           \
134                 (0 << 5) | /* PC11 */           \
135                 (0 << 6)) /* PC12 */
136
137 #define AO_LCD_28_ON_C  1
138
139 #define AO_LCD_DUTY     STM_LCD_CR_DUTY_STATIC
140
141 #define HAS_ADC                 1
142
143 #define AO_ADC_RING             32
144
145 struct ao_adc {
146         uint16_t                tick;
147         int16_t                 idd;
148         int16_t                 temp;
149         int16_t                 vref;
150 };
151
152 #define AO_ADC_IDD              4
153 #define AO_ADC_PIN0_PORT        (&stm_gpioa)
154 #define AO_ADC_PIN0_PIN         4
155
156 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_GPIOAEN))
157 #define AO_ADC_TEMP             16
158 #define AO_ADC_VREF             17
159
160 #define HAS_ADC_TEMP            1
161
162 #define AO_DATA_RING            32
163 #define AO_NUM_ADC              3
164
165 #define AO_ADC_SQ1              AO_ADC_IDD
166 #define AO_ADC_SQ2              AO_ADC_TEMP
167 #define AO_ADC_SQ3              AO_ADC_VREF
168         
169 #define HAS_I2C_1               1
170 #define I2C_1_PB6_PB7           0
171 #define I2C_1_PB8_PB9           1
172
173 #define HAS_I2C_2               0
174 #define I2C_2_PB10_PB11         0
175
176 #define AO_EVENT                1
177
178 #define AO_QUADRATURE_COUNT     2
179 #define AO_QUADRATURE_MODE      AO_EXTI_MODE_PULL_UP
180
181 #define AO_QUADRATURE_0_PORT    &stm_gpioc
182 #define AO_QUADRATURE_0_A       1
183 #define AO_QUADRATURE_0_B       0
184
185 #define AO_QUADRATURE_1_PORT    &stm_gpioc
186 #define AO_QUADRATURE_1_A       3
187 #define AO_QUADRATURE_1_B       2
188
189 #define AO_BUTTON_COUNT         2
190 #define AO_BUTTON_MODE          AO_EXTI_MODE_PULL_UP
191
192 #define AO_BUTTON_0_PORT        &stm_gpioc
193 #define AO_BUTTON_0             6
194
195 #define AO_BUTTON_1_PORT        &stm_gpioc
196 #define AO_BUTTON_1             7
197
198 #define AO_TICK_TYPE            uint32_t
199 #define AO_TICK_SIGNED          int32_t
200
201 #endif /* _AO_PINS_H_ */