forked from tobyp/kthw
-
Notifications
You must be signed in to change notification settings - Fork 0
/
stm32f407vg.h
257 lines (222 loc) · 9.16 KB
/
stm32f407vg.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
#include <stdint.h>
#include <stddef.h>
/* CORTEX-M FEATURES */
/* (4.3) Nested vectored interrupt controller (NVIC) */
#define NVIC_BASE 0xe000e100ul
#define NVIC_PRIn(n) ((volatile uint32_t*)(NVIC_BASE+0x300+4*(n)))
#define NVIC_ISER(n) ((volatile uint32_t*)(NVIC_BASE+0x000+4*(n)))
/* (4.4) System Control Block (SCB) */
#define SCB_BASE 0xe000ed00ul
#define SCB_ICSR ((volatile uint32_t*)(SCB_BASE+0x04))
#define SCB_ICSR_PENDSVSET 0x10000000ul
#define SCB_CCR ((volatile uint32_t*)(SCB_BASE+0x14))
#define SCB_CCR_STKALIGN 0x00000200ul
/* (4.5) System timer (STK) */
#define STK_BASE 0xe000e010ul
#define STK_CTRL ((volatile uint32_t*)(STK_BASE+0x00))
#define STK_ENABLE 0x00000001ul
#define STK_TICKINT 0x00000002ul
#define STK_CLKSOURCE 0x00000004ul
#define STK_COUNTFLAG 0x00010000ul
#define STK_LOAD ((volatile uint32_t *)(STK_BASE+0x04))
#define STK_VAL ((volatile uint32_t *)(STK_BASE+0x08))
/* STM32F407VG FEATURES */
/* (7) Reset and clock control (RCC) */
#define RCC_BASE 0x40023800ul
#define RCC_CR ((volatile uint32_t*)(RCC_BASE+0x00))
#define RCC_CR_HSION 0x00000001ul
#define RCC_CR_HSIRDY 0x00000002ul
#define RCC_CR_HSEON 0x00010000ul
#define RCC_CR_HSERDY 0x00020000ul
#define RCC_CR_HSEBYP 0x00040000ul
#define RCC_CR_CSSON 0x00080000ul
#define RCC_CR_PLLON 0x01000000ul
#define RCC_CR_PLLRDY 0x02000000ul
#define RCC_CR_PLLI2SON 0x04000000ul
#define RCC_CR_PLLI2SRDY 0x08000000ul
#define RCC_PLLCFGR ((volatile uint32_t*)(RCC_BASE+0x04))
#define RNG_PLLCFGR_PLLSRC 0x00400000ul
#define RCC_CFGR ((volatile uint32_t*)(RCC_BASE+0x08))
#define RCC_CIR ((volatile uint32_t*)(RCC_BASE+0x0c))
#define RCC_AHB1ENR ((volatile uint32_t*)(RCC_BASE+0x30))
#define RCC_AHB1ENR_GPIOAEN 0x00000001ul
#define RCC_AHB1ENR_GPIOBEN 0x00000002ul
#define RCC_AHB1ENR_GPIOCEN 0x00000004ul
#define RCC_AHB1ENR_GPIODEN 0x00000008ul
#define RCC_AHB1ENR_GPIOEEN 0x00000010ul
#define RCC_AHB1ENR_GPIOFEN 0x00000020ul
#define RCC_AHB1ENR_GPIOGEN 0x00000040ul
#define RCC_AHB1ENR_GPIOHEN 0x00000080ul
#define RCC_AHB1ENR_GPIOIEN 0x00000100ul
#define RCC_AHB1ENR_CRCEN 0x00001000ul
#define RCC_AHB1ENR_BKPSRAMEN 0x00040000ul
#define RCC_AHB1ENR_CCMDATARAMEN 0x00100000ul
#define RCC_AHB1ENR_DMA1EN 0x00200000ul
#define RCC_AHB1ENR_DMA2EN 0x00400000ul
#define RCC_AHB1ENR_ETHMACEN 0x02000000ul
#define RCC_AHB1ENR_ETHMACTXEN 0x04000000ul
#define RCC_AHB1ENR_ETHMACRXEN 0x08000000ul
#define RCC_AHB1ENR_ETHMACPTPEN 0x10000000ul
#define RCC_AHB1ENR_OTGHSEN 0x20000000ul
#define RCC_AHB1ENR_OTGHSULPIEN 0x40000000ul
#define RCC_AHB2ENR ((volatile uint32_t*)(RCC_BASE+0x34))
#define RCC_AHB2ENR_DCMIEN 0x00000001ul
#define RCC_AHB2ENR_CRYPEN 0x00000010ul
#define RCC_AHB2ENR_HASHEN 0x00000020ul
#define RCC_AHB2ENR_RNGEN 0x00000040ul
#define RCC_AHB2ENR_OTGFSEN 0x00000080ul
#define RCC_AHB3ENR ((volatile uint32_t*)(RCC_BASE+0x38))
#define RCC_AHB3ENR_FSMCEN 0x00000001ul
#define RCC_APB1ENR ((volatile uint32_t*)(RCC_BASE+0x40))
#define RCC_APB1ENR_TIM2EN 0x00000001ul
#define RCC_APB1ENR_TIM3EN 0x00000002ul
#define RCC_APB1ENR_TIM4EN 0x00000004ul
#define RCC_APB1ENR_TIM5EN 0x00000008ul
#define RCC_APB1ENR_TIM6EN 0x00000010ul
#define RCC_APB1ENR_TIM7EN 0x00000020ul
#define RCC_APB1ENR_TIM12EN 0x00000040ul
#define RCC_APB1ENR_TIM13EN 0x00000080ul
#define RCC_APB1ENR_TIM14EN 0x00000100ul
#define RCC_APB1ENR_WWDGEN 0x00000800ul
#define RCC_APB1ENR_SPI2EN 0x00004000ul
#define RCC_APB1ENR_SPI3EN 0x00008000ul
#define RCC_APB1ENR_USART2EN 0x00020000ul
#define RCC_APB1ENR_USART3EN 0x00040000ul
#define RCC_APB1ENR_USART4EN 0x00080000ul
#define RCC_APB1ENR_USART5EN 0x00100000ul
#define RCC_APB1ENR_I2C1EN 0x00200000ul
#define RCC_APB1ENR_I2C2EN 0x00400000ul
#define RCC_APB1ENR_I2C3EN 0x00800000ul
#define RCC_APB1ENR_CAN1EN 0x02000000ul
#define RCC_APB1ENR_CAN2EN 0x04000000ul
#define RCC_APB1ENR_PWREN 0x10000000ul
#define RCC_APB1ENR_DACEN 0x20000000ul
#define RCC_APB2ENR ((volatile uint32_t*)(RCC_BASE+0x44))
#define RCC_APB2ENR_TIM1EN 0x00000001ul
#define RCC_APB2ENR_TIM8EN 0x00000002ul
#define RCC_APB2ENR_USART1EN 0x00000010ul
#define RCC_APB2ENR_USART6EN 0x00000020ul
#define RCC_APB2ENR_ADC1EN 0x00000100ul
#define RCC_APB2ENR_ADC2EN 0x00000200ul
#define RCC_APB2ENR_ADC3EN 0x00000400ul
#define RCC_APB2ENR_SDIO 0x00000800ul
#define RCC_APB2ENR_SPI1EN 0x00001000ul
#define RCC_APB2ENR_SPI4EN 0x00002000ul
#define RCC_APB2ENR_SYSCFGEN 0x00004000ul
#define RCC_APB2ENR_TIM9EN 0x00010000ul
#define RCC_APB2ENR_TIM10EN 0x00020000ul
#define RCC_APB2ENR_TIM11EN 0x00040000ul
#define RCC_APB2ENR_SPI5EN 0x00100000ul
#define RCC_APB2ENR_SPI6EN 0x00200000ul
/* (8) General-purpose I/Os (GPIO) */
#define GPIOA_BASE 0x40020000ul
#define GPIOB_BASE 0x40020400ul
#define GPIOC_BASE 0x40020800ul
#define GPIOD_BASE 0x40020C00ul
#define GPIOE_BASE 0x40021000ul
#define GPIOF_BASE 0x40021400ul
#define GPIOG_BASE 0x40021800ul
#define GPIOH_BASE 0x40021C00ul
#define GPIOI_BASE 0x40022000ul
#define GPIOx_MODER(base) ((volatile uint32_t*)(base+0x00))
#define GPIOx_OTYPER(base) ((volatile uint32_t*)(base+0x04))
#define GPIOx_OSPEEDR(base) ((volatile uint32_t*)(base+0x08))
#define GPIOx_PUPDR(base) ((volatile uint32_t*)(base+0x0c))
#define GPIOx_IDR(base) ((volatile uint32_t*)(base+0x10))
#define GPIOx_ODR(base) ((volatile uint32_t*)(base+0x14))
#define GPIOx_BSRR(base) ((volatile uint32_t*)(base+0x18))
#define GPIOx_LCKR(base) ((volatile uint32_t*)(base+0x1c))
#define GPIOx_AFRL(base) ((volatile uint32_t*)(base+0x20))
#define GPIOx_AFRH(base) ((volatile uint32_t*)(base+0x24))
/* (13) Analog-to-digital converter (ADC) */
#define ADC_BASE 0x40012000ul
#define ADC1_BASE (ADC_BASE+0x000)
#define ADC2_BASE (ADC_BASE+0x100)
#define ADC3_BASE (ADC_BASE+0x200)
#define ADC_COMMON_BASE (ADC_BASE+0x300)
#define ADCx_SR(base) ((volatile uint32_t*)(base+0x00))
#define ADC_SR_AWD 0x00000001ul
#define ADC_SR_EOC 0x00000002ul
#define ADC_SR_JEOC 0x00000004ul
#define ADC_SR_JSTRT 0x00000008ul
#define ADC_SR_STRT 0x00000010ul
#define ADC_SR_OVR 0x00000020ul
#define ADCx_CR1(base) ((volatile uint32_t*)(base+0x04))
#define ADC_CR1_EOCIE 0x00000020ul
#define ADC_CR1_SCAN 0x00000100ul
#define ADCx_CR2(base) ((volatile uint32_t*)(base+0x08))
#define ADC_CR2_CONT 0x00000002ul
#define ADC_CR2_ADON 0x00000001ul
#define ADC_CR2_EOCS 0x00000400ul
#define ADC_CR2_ALIGN 0x00000800ul
#define ADC_CR2_SWSTART 0x40000000ul
#define ADCx_SMPR1(base) ((volatile uint32_t*)(base+0x0c))
#define ADCx_SMPR2(base) ((volatile uint32_t*)(base+0x10))
#define ADCx_JOFR1(base) ((volatile uint32_t*)(base+0x14))
#define ADCx_JOFR2(base) ((volatile uint32_t*)(base+0x18))
#define ADCx_JOFR3(base) ((volatile uint32_t*)(base+0x1c))
#define ADCx_JOFR4(base) ((volatile uint32_t*)(base+0x20))
#define ADCx_HTR(base) ((volatile uint32_t*)(base+0x24))
#define ADCx_LTR(base) ((volatile uint32_t*)(base+0x28))
#define ADCx_SQR1(base) ((volatile uint32_t*)(base+0x2c))
#define ADCx_SQR2(base) ((volatile uint32_t*)(base+0x30))
#define ADCx_SQR3(base) ((volatile uint32_t*)(base+0x34))
#define ADCx_JSQR(base) ((volatile uint32_t*)(base+0x38))
#define ADCx_JDR1(base) ((volatile uint32_t*)(base+0x3c))
#define ADCx_JDR2(base) ((volatile uint32_t*)(base+0x40))
#define ADCx_JDR3(base) ((volatile uint32_t*)(base+0x44))
#define ADCx_JDR4(base) ((volatile uint32_t*)(base+0x48))
#define ADCx_DR(base) ((volatile uint32_t*)(base+0x4c))
/* (24) Random number generator (RNG) */
#define RNG_BASE 0x50060800ul
#define RNG_CR ((volatile uint32_t*)(RNG_BASE+0x00))
#define RNG_CR_RNGEN 0x00000004ul
#define RNG_CR_IE 0x00000008ul
#define RNG_SR ((volatile uint32_t*)(RNG_BASE+0x04))
#define RNG_SR_DRDY 0x00000001ul
#define RNG_SR_CECS 0x00000002ul
#define RNG_SR_SECS 0x00000004ul
#define RNG_SR_CEIS 0x00000020ul
#define RNG_SR_SEIS 0x00000040ul
#define RNG_DR ((volatile uint32_t*)(RNG_BASE+0x08))
/* (30) Universal aynchronous asynchronous receiver transmitter (USART) */
#define USART1_BASE 0x40011000ul
#define USART2_BASE 0x40004400ul
#define USART3_BASE 0x40004800ul
#define UART4_BASE 0x40004c00ul
#define UART5_BASE 0x40005000ul
#define USART6_BASE 0x40011400ul
#define UART7_BASE 0x40017800ul
#define UART8_BASE 0x40017C00ul
#define USARTx_SR(base) ((volatile uint32_t*)(base+0x00))
#define USART_SR_PE 0x001ul
#define USART_SR_FE 0x002ul
#define USART_SR_NF 0x004ul
#define USART_SR_ORF 0x008ul
#define USART_SR_IDLE 0x010ul
#define USART_SR_RXNE 0x020ul
#define USART_SR_TC 0x040ul
#define USART_SR_TXE 0x080ul
#define USART_SR_LBD 0x100ul
#define USART_SR_CTS 0x200ul
#define USARTx_DR(base) ((volatile uint32_t*)(base+0x04))
#define USARTx_BRR(base) ((volatile uint32_t*)(base+0x08))
#define USARTx_CR1(base) ((volatile uint32_t*)(base+0x0C))
#define USART_CR1_SBK 0x0001ul
#define USART_CR1_RWU 0x0002ul
#define USART_CR1_RE 0x0004ul
#define USART_CR1_TE 0x0008ul
#define USART_CR1_IDLEIE 0x0010ul
#define USART_CR1_RXNEIE 0x0020ul
#define USART_CR1_TCIE 0x0040ul
#define USART_CR1_TXEIE 0x0080ul
#define USART_CR1_PEIE 0x0100ul
#define USART_CR1_PS 0x0200ul
#define USART_CR1_PCE 0x0400ul
#define USART_CR1_WAKE 0x0800ul
#define USART_CR1_M 0x1000ul
#define USART_CR1_UE 0x2000ul
#define USART_CR1_OVER8 0x8000ul
#define USARTx_CR2(base) ((volatile uint32_t*)(base+0x10))
#define USARTx_CR3(base) ((volatile uint32_t*)(base+0x14))
#define USARTx_GTPR(base) ((volatile uint32_t*)(base+0x18))