altos: Make STM clock configuration per-product. Fix 32MHz CPU speed
[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 /* No external crystal */
22 #define AO_HSE          0
23
24 #define AO_AHB_PRESCALER        1
25 #define AO_RCC_CFGR_HPRE_DIV    STM_RCC_CFGR_HPRE_DIV_1
26
27 #define AO_APB1_PRESCALER       2
28 #define AO_RCC_CFGR_PPRE1_DIV   STM_RCC_CFGR_PPRE2_DIV_2
29
30 #define AO_APB2_PRESCALER       2
31 #define AO_RCC_CFGR_PPRE2_DIV   STM_RCC_CFGR_PPRE2_DIV_2
32
33 #define AO_PLLMUL               6
34 #define AO_PLLDIV               4
35 #define AO_RCC_CFGR_PLLMUL      (STM_RCC_CFGR_PLLMUL_6)
36 #define AO_RCC_CFGR_PLLDIV      (STM_RCC_CFGR_PLLDIV_4)
37
38 #define HAS_SERIAL_1            1
39 #define USE_SERIAL_1_STDIN      1
40 #define SERIAL_1_PB6_PB7        1
41 #define SERIAL_1_PA9_PA10       0
42
43 #define HAS_SERIAL_2            0
44 #define USE_SERIAL_2_STDIN      1
45 #define SERIAL_2_PA2_PA3        0
46 #define SERIAL_2_PD5_PD6        1
47
48 #define HAS_SERIAL_3            0
49 #define USE_SERIAL_3_STDIN      1
50 #define SERIAL_3_PB10_PB11      0
51 #define SERIAL_3_PC10_PC11      0
52 #define SERIAL_3_PD8_PD9        1
53
54 #define HAS_SPI_1               1
55 #define SPI_1_PB3_PB4_PB5       1
56
57 #define HAS_SPI_2               0
58
59 #define HAS_USB                 0
60 #define HAS_BEEP                0
61 #define PACKET_HAS_SLAVE        0
62
63 #define LOW_LEVEL_DEBUG         1
64
65 #define LED_PORT_ENABLE         STM_RCC_AHBENR_GPIOBEN
66 #define LED_PORT                stm_gpiob
67 #define LED_PIN_GREEN           7
68 #define LED_PIN_BLUE            6
69 #define AO_LED_GREEN            (1 << LED_PIN_GREEN)
70 #define AO_LED_BLUE             (1 << LED_PIN_BLUE)
71
72 #define AO_LED_RED              AO_LED_BLUE     /* a patent lie */
73
74 #define LEDS_AVAILABLE          (AO_LED_BLUE | AO_LED_GREEN)
75
76 #define AO_LCD_STM_SEG_ENABLED_0 (              \
77                 (1 << 0) | /* PA1 */            \
78                 (1 << 1) | /* PA2 */            \
79                 (1 << 2) | /* PA3 */            \
80                 (0 << 3) | /* PA6 */            \
81                 (0 << 4) | /* PA7 */            \
82                 (0 << 5) | /* PB0 */            \
83                 (0 << 6) | /* PB1 */            \
84                 (1 << 7) | /* PB3 */            \
85                 (1 << 8) | /* PB4 */            \
86                 (1 << 9) | /* PB5 */            \
87                 (1 << 10) | /* PB10 */          \
88                 (1 << 11) | /* PB11 */          \
89                 (1 << 12) | /* PB12 */          \
90                 (1 << 13) | /* PB13 */          \
91                 (1 << 14) | /* PB14 */          \
92                 (1 << 15) | /* PB15 */          \
93                 (1 << 16) | /* PB8 */           \
94                 (1 << 17) | /* PA15 */          \
95                 (1 << 18) | /* PC0 */           \
96                 (1 << 19) | /* PC1 */           \
97                 (1 << 20) | /* PC2 */           \
98                 (1 << 21) | /* PC3 */           \
99                 (0 << 22) | /* PC4 */           \
100                 (0 << 23) | /* PC5 */           \
101                 (1 << 24) | /* PC6 */           \
102                 (1 << 25) | /* PC7 */           \
103                 (1 << 26) | /* PC8 */           \
104                 (1 << 27) | /* PC9 */           \
105                 (1 << 28) | /* PC10 or PD8 */   \
106                 (1 << 29) | /* PC11 or PD9 */   \
107                 (0 << 30) | /* PC12 or PD10 */  \
108                 (0 << 31))  /* PD2 or PD11 */
109
110 #define AO_LCD_STM_SEG_ENABLED_1 (              \
111                 (0 << 0) | /* PD12 */           \
112                 (0 << 1) | /* PD13 */           \
113                 (0 << 2) | /* PD14 */           \
114                 (0 << 3) | /* PD15 */           \
115                 (0 << 4) | /* PE0 */            \
116                 (0 << 5) | /* PE1 */            \
117                 (0 << 6) | /* PE2 */            \
118                 (0 << 7))  /* PE3 */
119
120 #define AO_LCD_STM_COM_ENABLED (                \
121                 (1 << 0) | /* PA8 */            \
122                 (1 << 1) | /* PA9 */            \
123                 (1 << 2) | /* PA10 */           \
124                 (1 << 3) | /* PB9 */            \
125                 (0 << 4) | /* PC10 */           \
126                 (0 << 5) | /* PC11 */           \
127                 (0 << 6)) /* PC12 */
128
129 #define AO_LCD_28_ON_C  1
130
131 #define HAS_ADC                 1
132
133 #define AO_ADC_RING             32
134
135 struct ao_adc {
136         uint16_t                tick;
137         int16_t                 idd;
138         int16_t                 temp;
139         int16_t                 vref;
140 };
141
142 #define AO_ADC_IDD              4
143 #define AO_ADC_PIN0_PORT        stm_gpioa
144 #define AO_ADC_PIN0_PIN         4
145
146 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_GPIOAEN))
147 #define AO_ADC_TEMP             16
148 #define AO_ADC_VREF             17
149
150 #define HAS_ADC_TEMP            1
151
152 #define AO_NUM_ADC              3
153
154 #define AO_ADC_SQ1              AO_ADC_IDD
155 #define AO_ADC_SQ2              AO_ADC_TEMP
156 #define AO_ADC_SQ3              AO_ADC_VREF
157         
158 #define HAS_I2C_1               1
159 #define I2C_1_PB6_PB7           0
160 #define I2C_1_PB8_PB9           1
161
162 #define HAS_I2C_2               0
163 #define I2C_2_PB10_PB11         0
164
165 #endif /* _AO_PINS_H_ */