Paparazzi UAS
v7.0_unstable
Paparazzi is a free software Unmanned Aircraft System.
board.h
Go to the documentation of this file.
1
/*
2
ChibiOS - Copyright (C) 2006..2015 Giovanni Di Sirio
3
4
Licensed under the Apache License, Version 2.0 (the "License");
5
you may not use this file except in compliance with the License.
6
You may obtain a copy of the License at
7
8
http://www.apache.org/licenses/LICENSE-2.0
9
10
Unless required by applicable law or agreed to in writing, software
11
distributed under the License is distributed on an "AS IS" BASIS,
12
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
See the License for the specific language governing permissions and
14
limitations under the License.
15
*/
16
17
#pragma once
18
19
/*
20
* Board identifier.
21
*/
22
#define BOARD_ST_CRAZYFLIE
23
#define BOARD_NAME "Bitcraze Crazyflie 2.1"
24
25
/*
26
* Board oscillators-related settings.
27
* NOTE: LSE fitted.
28
*/
29
#if !defined(STM32_LSECLK)
30
#define STM32_LSECLK 32768
31
#endif
32
33
#if !defined(STM32_HSECLK)
34
#define STM32_HSECLK 8000000
35
#endif
36
37
/*
38
* Board voltages.
39
* Required for performance limits calculation.
40
*/
41
#define STM32_VDD 300
42
43
/*
44
* MCU type as defined in the ST header file stm32f4xx.h.
45
*/
46
#define STM32F405xx
47
48
/*
49
* AHB_CLK
50
*/
51
#define AHB_CLK STM32_HCLK
52
53
54
/*
55
* IO pins assignments.
56
*/
57
#define PA00 0U
58
#define MOTOR1 1U
59
#define E_TX2 2U
60
#define E_RX2 3U
61
#define NRF_FLOW_CTRL 4U
62
#define E_SCK 5U
63
#define E_MISO 6U
64
#define E_MOSI 7U
65
#define I2C3_SCL 8U
66
#define PA09 9U
67
#define USB_ID 10U
68
#define USB_DM 11U
69
#define USB_DP 12U
70
#define STM_SWIO 13U
71
#define STM_SWCLK 14U
72
#define MOTOR3 15U
73
74
#define PB00 0U
75
#define PB01 1U
76
#define BOOT1 2U
77
#define PB03 3U
78
#define E_CS1 4U
79
#define E_CS2 5U
80
#define I2C1_SCL 6U
81
#define I2C1_SDA 7U
82
#define E_CS3 8U
83
#define MOTOR4 9U
84
#define PB10 10U
85
#define MOTOR2 11U
86
#define PB12 12U
87
#define NRF_SWCLK 13U
88
#define PB14 14U
89
#define NRF_SWIO 15U
90
91
#define LED_RED_L 0U
92
#define LED_GREEN_L 1U
93
#define LED_GREEN_R 2U
94
#define LED_RED_R 3U
95
#define PC04 4U
96
#define PC05 5U
97
#define NRF_TX 6U
98
#define NRF_RX 7U
99
#define PC08 8U
100
#define I2C3_SDA 9U
101
#define E_TX1 10U
102
#define E_RX1 11U
103
#define E_CS0 12U
104
#define PC13 13U
105
#define PC14 14U
106
#define PC15 15U
107
108
#define PD00 0U
109
#define PD01 1U
110
#define LED_BLUE_L 2U
111
#define PD03 3U
112
#define PD04 4U
113
#define PD05 5U
114
#define PD06 6U
115
#define PD07 7U
116
#define PD08 8U
117
#define PD09 9U
118
#define PD10 10U
119
#define PD11 11U
120
#define PD12 12U
121
#define PD13 13U
122
#define PD14 14U
123
#define PD15 15U
124
125
#define PE00 0U
126
#define PE01 1U
127
#define PE02 2U
128
#define PE03 3U
129
#define PE04 4U
130
#define PE05 5U
131
#define PE06 6U
132
#define PE07 7U
133
#define PE08 8U
134
#define PE09 9U
135
#define PE10 10U
136
#define PE11 11U
137
#define PE12 12U
138
#define PE13 13U
139
#define PE14 14U
140
#define PE15 15U
141
142
#define PF00 0U
143
#define PF01 1U
144
#define PF02 2U
145
#define PF03 3U
146
#define PF04 4U
147
#define PF05 5U
148
#define PF06 6U
149
#define PF07 7U
150
#define PF08 8U
151
#define PF09 9U
152
#define PF10 10U
153
#define PF11 11U
154
#define PF12 12U
155
#define PF13 13U
156
#define PF14 14U
157
#define PF15 15U
158
159
#define PG00 0U
160
#define PG01 1U
161
#define PG02 2U
162
#define PG03 3U
163
#define PG04 4U
164
#define PG05 5U
165
#define PG06 6U
166
#define PG07 7U
167
#define PG08 8U
168
#define PG09 9U
169
#define PG10 10U
170
#define PG11 11U
171
#define PG12 12U
172
#define PG13 13U
173
#define PG14 14U
174
#define PG15 15U
175
176
#define OSC_IN 0U
177
#define OSC_OUT 1U
178
#define PH02 2U
179
#define PH03 3U
180
#define PH04 4U
181
#define PH05 5U
182
#define PH06 6U
183
#define PH07 7U
184
#define PH08 8U
185
#define PH09 9U
186
#define PH10 10U
187
#define PH11 11U
188
#define PH12 12U
189
#define PH13 13U
190
#define PH14 14U
191
#define PH15 15U
192
193
#define PI00 0U
194
#define PI01 1U
195
#define PI02 2U
196
#define PI03 3U
197
#define PI04 4U
198
#define PI05 5U
199
#define PI06 6U
200
#define PI07 7U
201
#define PI08 8U
202
#define PI09 9U
203
#define PI10 10U
204
#define PI11 11U
205
#define PI12 12U
206
#define PI13 13U
207
#define PI14 14U
208
#define PI15 15U
209
210
#define PJ00 0U
211
#define PJ01 1U
212
#define PJ02 2U
213
#define PJ03 3U
214
#define PJ04 4U
215
#define PJ05 5U
216
#define PJ06 6U
217
#define PJ07 7U
218
#define PJ08 8U
219
#define PJ09 9U
220
#define PJ10 10U
221
#define PJ11 11U
222
#define PJ12 12U
223
#define PJ13 13U
224
#define PJ14 14U
225
#define PJ15 15U
226
227
#define PK00 0U
228
#define PK01 1U
229
#define PK02 2U
230
#define PK03 3U
231
#define PK04 4U
232
#define PK05 5U
233
#define PK06 6U
234
#define PK07 7U
235
#define PK08 8U
236
#define PK09 9U
237
#define PK10 10U
238
#define PK11 11U
239
#define PK12 12U
240
#define PK13 13U
241
#define PK14 14U
242
#define PK15 15U
243
244
/*
245
* IO lines assignments.
246
*/
247
#define LINE_MOTOR1 PAL_LINE(GPIOA, 1U)
248
#define LINE_E_TX2 PAL_LINE(GPIOA, 2U)
249
#define LINE_E_RX2 PAL_LINE(GPIOA, 3U)
250
#define LINE_NRF_FLOW_CTRL PAL_LINE(GPIOA, 4U)
251
#define LINE_E_SCK PAL_LINE(GPIOA, 5U)
252
#define LINE_E_MISO PAL_LINE(GPIOA, 6U)
253
#define LINE_E_MOSI PAL_LINE(GPIOA, 7U)
254
#define LINE_I2C3_SCL PAL_LINE(GPIOA, 8U)
255
#define LINE_USB_ID PAL_LINE(GPIOA, 10U)
256
#define LINE_USB_DM PAL_LINE(GPIOA, 11U)
257
#define LINE_USB_DP PAL_LINE(GPIOA, 12U)
258
#define LINE_STM_SWIO PAL_LINE(GPIOA, 13U)
259
#define LINE_STM_SWCLK PAL_LINE(GPIOA, 14U)
260
#define LINE_MOTOR3 PAL_LINE(GPIOA, 15U)
261
262
#define LINE_BOOT1 PAL_LINE(GPIOB, 2U)
263
#define LINE_E_CS1 PAL_LINE(GPIOB, 4U)
264
#define LINE_E_CS2 PAL_LINE(GPIOB, 5U)
265
#define LINE_I2C1_SCL PAL_LINE(GPIOB, 6U)
266
#define LINE_I2C1_SDA PAL_LINE(GPIOB, 7U)
267
#define LINE_E_CS3 PAL_LINE(GPIOB, 8U)
268
#define LINE_MOTOR4 PAL_LINE(GPIOB, 9U)
269
#define LINE_MOTOR2 PAL_LINE(GPIOB, 11U)
270
#define LINE_NRF_SWCLK PAL_LINE(GPIOB, 13U)
271
#define LINE_NRF_SWIO PAL_LINE(GPIOB, 15U)
272
273
#define LINE_LED_RED_L PAL_LINE(GPIOC, 0U)
274
#define LINE_LED_GREEN_L PAL_LINE(GPIOC, 1U)
275
#define LINE_LED_GREEN_R PAL_LINE(GPIOC, 2U)
276
#define LINE_LED_RED_R PAL_LINE(GPIOC, 3U)
277
#define LINE_NRF_TX PAL_LINE(GPIOC, 6U)
278
#define LINE_NRF_RX PAL_LINE(GPIOC, 7U)
279
#define LINE_I2C3_SDA PAL_LINE(GPIOC, 9U)
280
#define LINE_E_TX1 PAL_LINE(GPIOC, 10U)
281
#define LINE_E_RX1 PAL_LINE(GPIOC, 11U)
282
#define LINE_E_CS0 PAL_LINE(GPIOC, 12U)
283
284
#define LINE_LED_BLUE_L PAL_LINE(GPIOD, 2U)
285
286
#define LINE_OSC_IN PAL_LINE(GPIOH, 0U)
287
#define LINE_OSC_OUT PAL_LINE(GPIOH, 1U)
288
289
290
/*
291
* I/O ports initial setup, this configuration is established soon after reset
292
* in the initialization code.
293
* Please refer to the STM32 Reference Manual for details.
294
*/
295
#define PIN_MODE_INPUT(n) (0U << ((n) * 2U))
296
#define PIN_MODE_OUTPUT(n) (1U << ((n) * 2U))
297
#define PIN_MODE_ALTERNATE(n) (2U << ((n) * 2U))
298
#define PIN_MODE_ANALOG(n) (3U << ((n) * 2U))
299
#define PIN_ODR_LEVEL_LOW(n) (0U << (n))
300
#define PIN_ODR_LEVEL_HIGH(n) (1U << (n))
301
#define PIN_OTYPE_PUSHPULL(n) (0U << (n))
302
#define PIN_OTYPE_OPENDRAIN(n) (1U << (n))
303
#define PIN_OSPEED_SPEED_VERYLOW(n) (0U << ((n) * 2U))
304
#define PIN_OSPEED_SPEED_LOW(n) (1U << ((n) * 2U))
305
#define PIN_OSPEED_SPEED_MEDIUM(n) (2U << ((n) * 2U))
306
#define PIN_OSPEED_SPEED_HIGH(n) (3U << ((n) * 2U))
307
#define PIN_PUPDR_FLOATING(n) (0U << ((n) * 2U))
308
#define PIN_PUPDR_PULLUP(n) (1U << ((n) * 2U))
309
#define PIN_PUPDR_PULLDOWN(n) (2U << ((n) * 2U))
310
#define PIN_AFIO_AF(n, v) ((v) << (((n) % 8U) * 4U))
311
312
#define VAL_GPIOA_MODER (PIN_MODE_INPUT(PA00) | \
313
PIN_MODE_ALTERNATE(MOTOR1) | \
314
PIN_MODE_ALTERNATE(E_TX2) | \
315
PIN_MODE_ALTERNATE(E_RX2) | \
316
PIN_MODE_INPUT(NRF_FLOW_CTRL) | \
317
PIN_MODE_ALTERNATE(E_SCK) | \
318
PIN_MODE_ALTERNATE(E_MISO) | \
319
PIN_MODE_ALTERNATE(E_MOSI) | \
320
PIN_MODE_ALTERNATE(I2C3_SCL) | \
321
PIN_MODE_INPUT(PA09) | \
322
PIN_MODE_ALTERNATE(USB_ID) | \
323
PIN_MODE_ALTERNATE(USB_DM) | \
324
PIN_MODE_ALTERNATE(USB_DP) | \
325
PIN_MODE_ALTERNATE(STM_SWIO) | \
326
PIN_MODE_ALTERNATE(STM_SWCLK) | \
327
PIN_MODE_ALTERNATE(MOTOR3))
328
329
#define VAL_GPIOA_OTYPER (PIN_OTYPE_PUSHPULL(PA00) | \
330
PIN_OTYPE_PUSHPULL(MOTOR1) | \
331
PIN_OTYPE_PUSHPULL(E_TX2) | \
332
PIN_OTYPE_PUSHPULL(E_RX2) | \
333
PIN_OTYPE_OPENDRAIN(NRF_FLOW_CTRL) | \
334
PIN_OTYPE_PUSHPULL(E_SCK) | \
335
PIN_OTYPE_PUSHPULL(E_MISO) | \
336
PIN_OTYPE_PUSHPULL(E_MOSI) | \
337
PIN_OTYPE_OPENDRAIN(I2C3_SCL) | \
338
PIN_OTYPE_PUSHPULL(PA09) | \
339
PIN_OTYPE_PUSHPULL(USB_ID) | \
340
PIN_OTYPE_PUSHPULL(USB_DM) | \
341
PIN_OTYPE_PUSHPULL(USB_DP) | \
342
PIN_OTYPE_PUSHPULL(STM_SWIO) | \
343
PIN_OTYPE_PUSHPULL(STM_SWCLK) | \
344
PIN_OTYPE_PUSHPULL(MOTOR3))
345
346
#define VAL_GPIOA_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PA00) | \
347
PIN_OSPEED_SPEED_HIGH(MOTOR1) | \
348
PIN_OSPEED_SPEED_HIGH(E_TX2) | \
349
PIN_OSPEED_SPEED_HIGH(E_RX2) | \
350
PIN_OSPEED_SPEED_VERYLOW(NRF_FLOW_CTRL) | \
351
PIN_OSPEED_SPEED_HIGH(E_SCK) | \
352
PIN_OSPEED_SPEED_HIGH(E_MISO) | \
353
PIN_OSPEED_SPEED_HIGH(E_MOSI) | \
354
PIN_OSPEED_SPEED_HIGH(I2C3_SCL) | \
355
PIN_OSPEED_SPEED_VERYLOW(PA09) | \
356
PIN_OSPEED_SPEED_HIGH(USB_ID) | \
357
PIN_OSPEED_SPEED_HIGH(USB_DM) | \
358
PIN_OSPEED_SPEED_HIGH(USB_DP) | \
359
PIN_OSPEED_SPEED_HIGH(STM_SWIO) | \
360
PIN_OSPEED_SPEED_HIGH(STM_SWCLK) | \
361
PIN_OSPEED_SPEED_HIGH(MOTOR3))
362
363
#define VAL_GPIOA_PUPDR (PIN_PUPDR_PULLDOWN(PA00) | \
364
PIN_PUPDR_FLOATING(MOTOR1) | \
365
PIN_PUPDR_FLOATING(E_TX2) | \
366
PIN_PUPDR_FLOATING(E_RX2) | \
367
PIN_PUPDR_FLOATING(NRF_FLOW_CTRL) | \
368
PIN_PUPDR_FLOATING(E_SCK) | \
369
PIN_PUPDR_FLOATING(E_MISO) | \
370
PIN_PUPDR_FLOATING(E_MOSI) | \
371
PIN_PUPDR_PULLUP(I2C3_SCL) | \
372
PIN_PUPDR_PULLDOWN(PA09) | \
373
PIN_PUPDR_FLOATING(USB_ID) | \
374
PIN_PUPDR_FLOATING(USB_DM) | \
375
PIN_PUPDR_FLOATING(USB_DP) | \
376
PIN_PUPDR_FLOATING(STM_SWIO) | \
377
PIN_PUPDR_FLOATING(STM_SWCLK) | \
378
PIN_PUPDR_FLOATING(MOTOR3))
379
380
#define VAL_GPIOA_ODR (PIN_ODR_LEVEL_LOW(PA00) | \
381
PIN_ODR_LEVEL_LOW(MOTOR1) | \
382
PIN_ODR_LEVEL_HIGH(E_TX2) | \
383
PIN_ODR_LEVEL_HIGH(E_RX2) | \
384
PIN_ODR_LEVEL_LOW(NRF_FLOW_CTRL) | \
385
PIN_ODR_LEVEL_HIGH(E_SCK) | \
386
PIN_ODR_LEVEL_HIGH(E_MISO) | \
387
PIN_ODR_LEVEL_HIGH(E_MOSI) | \
388
PIN_ODR_LEVEL_HIGH(I2C3_SCL) | \
389
PIN_ODR_LEVEL_LOW(PA09) | \
390
PIN_ODR_LEVEL_HIGH(USB_ID) | \
391
PIN_ODR_LEVEL_HIGH(USB_DM) | \
392
PIN_ODR_LEVEL_HIGH(USB_DP) | \
393
PIN_ODR_LEVEL_HIGH(STM_SWIO) | \
394
PIN_ODR_LEVEL_HIGH(STM_SWCLK) | \
395
PIN_ODR_LEVEL_LOW(MOTOR3))
396
397
#define VAL_GPIOA_AFRL (PIN_AFIO_AF(PA00, 0) | \
398
PIN_AFIO_AF(MOTOR1, 1) | \
399
PIN_AFIO_AF(E_TX2, 7) | \
400
PIN_AFIO_AF(E_RX2, 7) | \
401
PIN_AFIO_AF(NRF_FLOW_CTRL, 0) | \
402
PIN_AFIO_AF(E_SCK, 5) | \
403
PIN_AFIO_AF(E_MISO, 5) | \
404
PIN_AFIO_AF(E_MOSI, 5))
405
406
#define VAL_GPIOA_AFRH (PIN_AFIO_AF(I2C3_SCL, 4) | \
407
PIN_AFIO_AF(PA09, 0) | \
408
PIN_AFIO_AF(USB_ID, 10) | \
409
PIN_AFIO_AF(USB_DM, 10) | \
410
PIN_AFIO_AF(USB_DP, 10) | \
411
PIN_AFIO_AF(STM_SWIO, 0) | \
412
PIN_AFIO_AF(STM_SWCLK, 0) | \
413
PIN_AFIO_AF(MOTOR3, 1))
414
415
#define VAL_GPIOB_MODER (PIN_MODE_INPUT(PB00) | \
416
PIN_MODE_INPUT(PB01) | \
417
PIN_MODE_INPUT(BOOT1) | \
418
PIN_MODE_INPUT(PB03) | \
419
PIN_MODE_INPUT(E_CS1) | \
420
PIN_MODE_INPUT(E_CS2) | \
421
PIN_MODE_ALTERNATE(I2C1_SCL) | \
422
PIN_MODE_ALTERNATE(I2C1_SDA) | \
423
PIN_MODE_INPUT(E_CS3) | \
424
PIN_MODE_ALTERNATE(MOTOR4) | \
425
PIN_MODE_INPUT(PB10) | \
426
PIN_MODE_ALTERNATE(MOTOR2) | \
427
PIN_MODE_INPUT(PB12) | \
428
PIN_MODE_INPUT(NRF_SWCLK) | \
429
PIN_MODE_INPUT(PB14) | \
430
PIN_MODE_INPUT(NRF_SWIO))
431
432
#define VAL_GPIOB_OTYPER (PIN_OTYPE_PUSHPULL(PB00) | \
433
PIN_OTYPE_PUSHPULL(PB01) | \
434
PIN_OTYPE_OPENDRAIN(BOOT1) | \
435
PIN_OTYPE_PUSHPULL(PB03) | \
436
PIN_OTYPE_OPENDRAIN(E_CS1) | \
437
PIN_OTYPE_OPENDRAIN(E_CS2) | \
438
PIN_OTYPE_OPENDRAIN(I2C1_SCL) | \
439
PIN_OTYPE_OPENDRAIN(I2C1_SDA) | \
440
PIN_OTYPE_OPENDRAIN(E_CS3) | \
441
PIN_OTYPE_PUSHPULL(MOTOR4) | \
442
PIN_OTYPE_PUSHPULL(PB10) | \
443
PIN_OTYPE_PUSHPULL(MOTOR2) | \
444
PIN_OTYPE_PUSHPULL(PB12) | \
445
PIN_OTYPE_OPENDRAIN(NRF_SWCLK) | \
446
PIN_OTYPE_PUSHPULL(PB14) | \
447
PIN_OTYPE_OPENDRAIN(NRF_SWIO))
448
449
#define VAL_GPIOB_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PB00) | \
450
PIN_OSPEED_SPEED_VERYLOW(PB01) | \
451
PIN_OSPEED_SPEED_VERYLOW(BOOT1) | \
452
PIN_OSPEED_SPEED_VERYLOW(PB03) | \
453
PIN_OSPEED_SPEED_VERYLOW(E_CS1) | \
454
PIN_OSPEED_SPEED_VERYLOW(E_CS2) | \
455
PIN_OSPEED_SPEED_HIGH(I2C1_SCL) | \
456
PIN_OSPEED_SPEED_HIGH(I2C1_SDA) | \
457
PIN_OSPEED_SPEED_VERYLOW(E_CS3) | \
458
PIN_OSPEED_SPEED_HIGH(MOTOR4) | \
459
PIN_OSPEED_SPEED_VERYLOW(PB10) | \
460
PIN_OSPEED_SPEED_HIGH(MOTOR2) | \
461
PIN_OSPEED_SPEED_VERYLOW(PB12) | \
462
PIN_OSPEED_SPEED_VERYLOW(NRF_SWCLK) | \
463
PIN_OSPEED_SPEED_VERYLOW(PB14) | \
464
PIN_OSPEED_SPEED_VERYLOW(NRF_SWIO))
465
466
#define VAL_GPIOB_PUPDR (PIN_PUPDR_PULLDOWN(PB00) | \
467
PIN_PUPDR_PULLDOWN(PB01) | \
468
PIN_PUPDR_FLOATING(BOOT1) | \
469
PIN_PUPDR_PULLDOWN(PB03) | \
470
PIN_PUPDR_FLOATING(E_CS1) | \
471
PIN_PUPDR_FLOATING(E_CS2) | \
472
PIN_PUPDR_PULLUP(I2C1_SCL) | \
473
PIN_PUPDR_PULLUP(I2C1_SDA) | \
474
PIN_PUPDR_FLOATING(E_CS3) | \
475
PIN_PUPDR_FLOATING(MOTOR4) | \
476
PIN_PUPDR_PULLDOWN(PB10) | \
477
PIN_PUPDR_FLOATING(MOTOR2) | \
478
PIN_PUPDR_PULLDOWN(PB12) | \
479
PIN_PUPDR_FLOATING(NRF_SWCLK) | \
480
PIN_PUPDR_PULLDOWN(PB14) | \
481
PIN_PUPDR_FLOATING(NRF_SWIO))
482
483
#define VAL_GPIOB_ODR (PIN_ODR_LEVEL_LOW(PB00) | \
484
PIN_ODR_LEVEL_LOW(PB01) | \
485
PIN_ODR_LEVEL_LOW(BOOT1) | \
486
PIN_ODR_LEVEL_LOW(PB03) | \
487
PIN_ODR_LEVEL_LOW(E_CS1) | \
488
PIN_ODR_LEVEL_LOW(E_CS2) | \
489
PIN_ODR_LEVEL_HIGH(I2C1_SCL) | \
490
PIN_ODR_LEVEL_HIGH(I2C1_SDA) | \
491
PIN_ODR_LEVEL_LOW(E_CS3) | \
492
PIN_ODR_LEVEL_LOW(MOTOR4) | \
493
PIN_ODR_LEVEL_LOW(PB10) | \
494
PIN_ODR_LEVEL_LOW(MOTOR2) | \
495
PIN_ODR_LEVEL_LOW(PB12) | \
496
PIN_ODR_LEVEL_LOW(NRF_SWCLK) | \
497
PIN_ODR_LEVEL_LOW(PB14) | \
498
PIN_ODR_LEVEL_LOW(NRF_SWIO))
499
500
#define VAL_GPIOB_AFRL (PIN_AFIO_AF(PB00, 0) | \
501
PIN_AFIO_AF(PB01, 0) | \
502
PIN_AFIO_AF(BOOT1, 0) | \
503
PIN_AFIO_AF(PB03, 0) | \
504
PIN_AFIO_AF(E_CS1, 0) | \
505
PIN_AFIO_AF(E_CS2, 0) | \
506
PIN_AFIO_AF(I2C1_SCL, 4) | \
507
PIN_AFIO_AF(I2C1_SDA, 4))
508
509
#define VAL_GPIOB_AFRH (PIN_AFIO_AF(E_CS3, 0) | \
510
PIN_AFIO_AF(MOTOR4, 2) | \
511
PIN_AFIO_AF(PB10, 0) | \
512
PIN_AFIO_AF(MOTOR2, 1) | \
513
PIN_AFIO_AF(PB12, 0) | \
514
PIN_AFIO_AF(NRF_SWCLK, 0) | \
515
PIN_AFIO_AF(PB14, 0) | \
516
PIN_AFIO_AF(NRF_SWIO, 0))
517
518
#define VAL_GPIOC_MODER (PIN_MODE_OUTPUT(LED_RED_L) | \
519
PIN_MODE_OUTPUT(LED_GREEN_L) | \
520
PIN_MODE_OUTPUT(LED_GREEN_R) | \
521
PIN_MODE_OUTPUT(LED_RED_R) | \
522
PIN_MODE_INPUT(PC04) | \
523
PIN_MODE_INPUT(PC05) | \
524
PIN_MODE_ALTERNATE(NRF_TX) | \
525
PIN_MODE_ALTERNATE(NRF_RX) | \
526
PIN_MODE_INPUT(PC08) | \
527
PIN_MODE_ALTERNATE(I2C3_SDA) | \
528
PIN_MODE_ALTERNATE(E_TX1) | \
529
PIN_MODE_ALTERNATE(E_RX1) | \
530
PIN_MODE_INPUT(E_CS0) | \
531
PIN_MODE_INPUT(PC13) | \
532
PIN_MODE_INPUT(PC14) | \
533
PIN_MODE_INPUT(PC15))
534
535
#define VAL_GPIOC_OTYPER (PIN_OTYPE_PUSHPULL(LED_RED_L) | \
536
PIN_OTYPE_PUSHPULL(LED_GREEN_L) | \
537
PIN_OTYPE_PUSHPULL(LED_GREEN_R) | \
538
PIN_OTYPE_PUSHPULL(LED_RED_R) | \
539
PIN_OTYPE_PUSHPULL(PC04) | \
540
PIN_OTYPE_PUSHPULL(PC05) | \
541
PIN_OTYPE_PUSHPULL(NRF_TX) | \
542
PIN_OTYPE_PUSHPULL(NRF_RX) | \
543
PIN_OTYPE_PUSHPULL(PC08) | \
544
PIN_OTYPE_OPENDRAIN(I2C3_SDA) | \
545
PIN_OTYPE_PUSHPULL(E_TX1) | \
546
PIN_OTYPE_PUSHPULL(E_RX1) | \
547
PIN_OTYPE_OPENDRAIN(E_CS0) | \
548
PIN_OTYPE_PUSHPULL(PC13) | \
549
PIN_OTYPE_PUSHPULL(PC14) | \
550
PIN_OTYPE_PUSHPULL(PC15))
551
552
#define VAL_GPIOC_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(LED_RED_L) | \
553
PIN_OSPEED_SPEED_VERYLOW(LED_GREEN_L) | \
554
PIN_OSPEED_SPEED_VERYLOW(LED_GREEN_R) | \
555
PIN_OSPEED_SPEED_VERYLOW(LED_RED_R) | \
556
PIN_OSPEED_SPEED_VERYLOW(PC04) | \
557
PIN_OSPEED_SPEED_VERYLOW(PC05) | \
558
PIN_OSPEED_SPEED_HIGH(NRF_TX) | \
559
PIN_OSPEED_SPEED_HIGH(NRF_RX) | \
560
PIN_OSPEED_SPEED_VERYLOW(PC08) | \
561
PIN_OSPEED_SPEED_HIGH(I2C3_SDA) | \
562
PIN_OSPEED_SPEED_HIGH(E_TX1) | \
563
PIN_OSPEED_SPEED_HIGH(E_RX1) | \
564
PIN_OSPEED_SPEED_VERYLOW(E_CS0) | \
565
PIN_OSPEED_SPEED_VERYLOW(PC13) | \
566
PIN_OSPEED_SPEED_VERYLOW(PC14) | \
567
PIN_OSPEED_SPEED_VERYLOW(PC15))
568
569
#define VAL_GPIOC_PUPDR (PIN_PUPDR_FLOATING(LED_RED_L) | \
570
PIN_PUPDR_FLOATING(LED_GREEN_L) | \
571
PIN_PUPDR_FLOATING(LED_GREEN_R) | \
572
PIN_PUPDR_FLOATING(LED_RED_R) | \
573
PIN_PUPDR_PULLDOWN(PC04) | \
574
PIN_PUPDR_PULLDOWN(PC05) | \
575
PIN_PUPDR_FLOATING(NRF_TX) | \
576
PIN_PUPDR_FLOATING(NRF_RX) | \
577
PIN_PUPDR_PULLDOWN(PC08) | \
578
PIN_PUPDR_PULLUP(I2C3_SDA) | \
579
PIN_PUPDR_FLOATING(E_TX1) | \
580
PIN_PUPDR_FLOATING(E_RX1) | \
581
PIN_PUPDR_FLOATING(E_CS0) | \
582
PIN_PUPDR_PULLDOWN(PC13) | \
583
PIN_PUPDR_PULLDOWN(PC14) | \
584
PIN_PUPDR_PULLDOWN(PC15))
585
586
#define VAL_GPIOC_ODR (PIN_ODR_LEVEL_LOW(LED_RED_L) | \
587
PIN_ODR_LEVEL_LOW(LED_GREEN_L) | \
588
PIN_ODR_LEVEL_LOW(LED_GREEN_R) | \
589
PIN_ODR_LEVEL_LOW(LED_RED_R) | \
590
PIN_ODR_LEVEL_LOW(PC04) | \
591
PIN_ODR_LEVEL_LOW(PC05) | \
592
PIN_ODR_LEVEL_HIGH(NRF_TX) | \
593
PIN_ODR_LEVEL_HIGH(NRF_RX) | \
594
PIN_ODR_LEVEL_LOW(PC08) | \
595
PIN_ODR_LEVEL_HIGH(I2C3_SDA) | \
596
PIN_ODR_LEVEL_HIGH(E_TX1) | \
597
PIN_ODR_LEVEL_HIGH(E_RX1) | \
598
PIN_ODR_LEVEL_LOW(E_CS0) | \
599
PIN_ODR_LEVEL_LOW(PC13) | \
600
PIN_ODR_LEVEL_LOW(PC14) | \
601
PIN_ODR_LEVEL_LOW(PC15))
602
603
#define VAL_GPIOC_AFRL (PIN_AFIO_AF(LED_RED_L, 0) | \
604
PIN_AFIO_AF(LED_GREEN_L, 0) | \
605
PIN_AFIO_AF(LED_GREEN_R, 0) | \
606
PIN_AFIO_AF(LED_RED_R, 0) | \
607
PIN_AFIO_AF(PC04, 0) | \
608
PIN_AFIO_AF(PC05, 0) | \
609
PIN_AFIO_AF(NRF_TX, 8) | \
610
PIN_AFIO_AF(NRF_RX, 8))
611
612
#define VAL_GPIOC_AFRH (PIN_AFIO_AF(PC08, 0) | \
613
PIN_AFIO_AF(I2C3_SDA, 4) | \
614
PIN_AFIO_AF(E_TX1, 7) | \
615
PIN_AFIO_AF(E_RX1, 7) | \
616
PIN_AFIO_AF(E_CS0, 0) | \
617
PIN_AFIO_AF(PC13, 0) | \
618
PIN_AFIO_AF(PC14, 0) | \
619
PIN_AFIO_AF(PC15, 0))
620
621
#define VAL_GPIOD_MODER (PIN_MODE_INPUT(PD00) | \
622
PIN_MODE_INPUT(PD01) | \
623
PIN_MODE_OUTPUT(LED_BLUE_L) | \
624
PIN_MODE_INPUT(PD03) | \
625
PIN_MODE_INPUT(PD04) | \
626
PIN_MODE_INPUT(PD05) | \
627
PIN_MODE_INPUT(PD06) | \
628
PIN_MODE_INPUT(PD07) | \
629
PIN_MODE_INPUT(PD08) | \
630
PIN_MODE_INPUT(PD09) | \
631
PIN_MODE_INPUT(PD10) | \
632
PIN_MODE_INPUT(PD11) | \
633
PIN_MODE_INPUT(PD12) | \
634
PIN_MODE_INPUT(PD13) | \
635
PIN_MODE_INPUT(PD14) | \
636
PIN_MODE_INPUT(PD15))
637
638
#define VAL_GPIOD_OTYPER (PIN_OTYPE_PUSHPULL(PD00) | \
639
PIN_OTYPE_PUSHPULL(PD01) | \
640
PIN_OTYPE_PUSHPULL(LED_BLUE_L) | \
641
PIN_OTYPE_PUSHPULL(PD03) | \
642
PIN_OTYPE_PUSHPULL(PD04) | \
643
PIN_OTYPE_PUSHPULL(PD05) | \
644
PIN_OTYPE_PUSHPULL(PD06) | \
645
PIN_OTYPE_PUSHPULL(PD07) | \
646
PIN_OTYPE_PUSHPULL(PD08) | \
647
PIN_OTYPE_PUSHPULL(PD09) | \
648
PIN_OTYPE_PUSHPULL(PD10) | \
649
PIN_OTYPE_PUSHPULL(PD11) | \
650
PIN_OTYPE_PUSHPULL(PD12) | \
651
PIN_OTYPE_PUSHPULL(PD13) | \
652
PIN_OTYPE_PUSHPULL(PD14) | \
653
PIN_OTYPE_PUSHPULL(PD15))
654
655
#define VAL_GPIOD_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PD00) | \
656
PIN_OSPEED_SPEED_VERYLOW(PD01) | \
657
PIN_OSPEED_SPEED_VERYLOW(LED_BLUE_L) | \
658
PIN_OSPEED_SPEED_VERYLOW(PD03) | \
659
PIN_OSPEED_SPEED_VERYLOW(PD04) | \
660
PIN_OSPEED_SPEED_VERYLOW(PD05) | \
661
PIN_OSPEED_SPEED_VERYLOW(PD06) | \
662
PIN_OSPEED_SPEED_VERYLOW(PD07) | \
663
PIN_OSPEED_SPEED_VERYLOW(PD08) | \
664
PIN_OSPEED_SPEED_VERYLOW(PD09) | \
665
PIN_OSPEED_SPEED_VERYLOW(PD10) | \
666
PIN_OSPEED_SPEED_VERYLOW(PD11) | \
667
PIN_OSPEED_SPEED_VERYLOW(PD12) | \
668
PIN_OSPEED_SPEED_VERYLOW(PD13) | \
669
PIN_OSPEED_SPEED_VERYLOW(PD14) | \
670
PIN_OSPEED_SPEED_VERYLOW(PD15))
671
672
#define VAL_GPIOD_PUPDR (PIN_PUPDR_PULLDOWN(PD00) | \
673
PIN_PUPDR_PULLDOWN(PD01) | \
674
PIN_PUPDR_FLOATING(LED_BLUE_L) | \
675
PIN_PUPDR_PULLDOWN(PD03) | \
676
PIN_PUPDR_PULLDOWN(PD04) | \
677
PIN_PUPDR_PULLDOWN(PD05) | \
678
PIN_PUPDR_PULLDOWN(PD06) | \
679
PIN_PUPDR_PULLDOWN(PD07) | \
680
PIN_PUPDR_PULLDOWN(PD08) | \
681
PIN_PUPDR_PULLDOWN(PD09) | \
682
PIN_PUPDR_PULLDOWN(PD10) | \
683
PIN_PUPDR_PULLDOWN(PD11) | \
684
PIN_PUPDR_PULLDOWN(PD12) | \
685
PIN_PUPDR_PULLDOWN(PD13) | \
686
PIN_PUPDR_PULLDOWN(PD14) | \
687
PIN_PUPDR_PULLDOWN(PD15))
688
689
#define VAL_GPIOD_ODR (PIN_ODR_LEVEL_LOW(PD00) | \
690
PIN_ODR_LEVEL_LOW(PD01) | \
691
PIN_ODR_LEVEL_LOW(LED_BLUE_L) | \
692
PIN_ODR_LEVEL_LOW(PD03) | \
693
PIN_ODR_LEVEL_LOW(PD04) | \
694
PIN_ODR_LEVEL_LOW(PD05) | \
695
PIN_ODR_LEVEL_LOW(PD06) | \
696
PIN_ODR_LEVEL_LOW(PD07) | \
697
PIN_ODR_LEVEL_LOW(PD08) | \
698
PIN_ODR_LEVEL_LOW(PD09) | \
699
PIN_ODR_LEVEL_LOW(PD10) | \
700
PIN_ODR_LEVEL_LOW(PD11) | \
701
PIN_ODR_LEVEL_LOW(PD12) | \
702
PIN_ODR_LEVEL_LOW(PD13) | \
703
PIN_ODR_LEVEL_LOW(PD14) | \
704
PIN_ODR_LEVEL_LOW(PD15))
705
706
#define VAL_GPIOD_AFRL (PIN_AFIO_AF(PD00, 0) | \
707
PIN_AFIO_AF(PD01, 0) | \
708
PIN_AFIO_AF(LED_BLUE_L, 0) | \
709
PIN_AFIO_AF(PD03, 0) | \
710
PIN_AFIO_AF(PD04, 0) | \
711
PIN_AFIO_AF(PD05, 0) | \
712
PIN_AFIO_AF(PD06, 0) | \
713
PIN_AFIO_AF(PD07, 0))
714
715
#define VAL_GPIOD_AFRH (PIN_AFIO_AF(PD08, 0) | \
716
PIN_AFIO_AF(PD09, 0) | \
717
PIN_AFIO_AF(PD10, 0) | \
718
PIN_AFIO_AF(PD11, 0) | \
719
PIN_AFIO_AF(PD12, 0) | \
720
PIN_AFIO_AF(PD13, 0) | \
721
PIN_AFIO_AF(PD14, 0) | \
722
PIN_AFIO_AF(PD15, 0))
723
724
#define VAL_GPIOE_MODER (PIN_MODE_INPUT(PE00) | \
725
PIN_MODE_INPUT(PE01) | \
726
PIN_MODE_INPUT(PE02) | \
727
PIN_MODE_INPUT(PE03) | \
728
PIN_MODE_INPUT(PE04) | \
729
PIN_MODE_INPUT(PE05) | \
730
PIN_MODE_INPUT(PE06) | \
731
PIN_MODE_INPUT(PE07) | \
732
PIN_MODE_INPUT(PE08) | \
733
PIN_MODE_INPUT(PE09) | \
734
PIN_MODE_INPUT(PE10) | \
735
PIN_MODE_INPUT(PE11) | \
736
PIN_MODE_INPUT(PE12) | \
737
PIN_MODE_INPUT(PE13) | \
738
PIN_MODE_INPUT(PE14) | \
739
PIN_MODE_INPUT(PE15))
740
741
#define VAL_GPIOE_OTYPER (PIN_OTYPE_PUSHPULL(PE00) | \
742
PIN_OTYPE_PUSHPULL(PE01) | \
743
PIN_OTYPE_PUSHPULL(PE02) | \
744
PIN_OTYPE_PUSHPULL(PE03) | \
745
PIN_OTYPE_PUSHPULL(PE04) | \
746
PIN_OTYPE_PUSHPULL(PE05) | \
747
PIN_OTYPE_PUSHPULL(PE06) | \
748
PIN_OTYPE_PUSHPULL(PE07) | \
749
PIN_OTYPE_PUSHPULL(PE08) | \
750
PIN_OTYPE_PUSHPULL(PE09) | \
751
PIN_OTYPE_PUSHPULL(PE10) | \
752
PIN_OTYPE_PUSHPULL(PE11) | \
753
PIN_OTYPE_PUSHPULL(PE12) | \
754
PIN_OTYPE_PUSHPULL(PE13) | \
755
PIN_OTYPE_PUSHPULL(PE14) | \
756
PIN_OTYPE_PUSHPULL(PE15))
757
758
#define VAL_GPIOE_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PE00) | \
759
PIN_OSPEED_SPEED_VERYLOW(PE01) | \
760
PIN_OSPEED_SPEED_VERYLOW(PE02) | \
761
PIN_OSPEED_SPEED_VERYLOW(PE03) | \
762
PIN_OSPEED_SPEED_VERYLOW(PE04) | \
763
PIN_OSPEED_SPEED_VERYLOW(PE05) | \
764
PIN_OSPEED_SPEED_VERYLOW(PE06) | \
765
PIN_OSPEED_SPEED_VERYLOW(PE07) | \
766
PIN_OSPEED_SPEED_VERYLOW(PE08) | \
767
PIN_OSPEED_SPEED_VERYLOW(PE09) | \
768
PIN_OSPEED_SPEED_VERYLOW(PE10) | \
769
PIN_OSPEED_SPEED_VERYLOW(PE11) | \
770
PIN_OSPEED_SPEED_VERYLOW(PE12) | \
771
PIN_OSPEED_SPEED_VERYLOW(PE13) | \
772
PIN_OSPEED_SPEED_VERYLOW(PE14) | \
773
PIN_OSPEED_SPEED_VERYLOW(PE15))
774
775
#define VAL_GPIOE_PUPDR (PIN_PUPDR_PULLDOWN(PE00) | \
776
PIN_PUPDR_PULLDOWN(PE01) | \
777
PIN_PUPDR_PULLDOWN(PE02) | \
778
PIN_PUPDR_PULLDOWN(PE03) | \
779
PIN_PUPDR_PULLDOWN(PE04) | \
780
PIN_PUPDR_PULLDOWN(PE05) | \
781
PIN_PUPDR_PULLDOWN(PE06) | \
782
PIN_PUPDR_PULLDOWN(PE07) | \
783
PIN_PUPDR_PULLDOWN(PE08) | \
784
PIN_PUPDR_PULLDOWN(PE09) | \
785
PIN_PUPDR_PULLDOWN(PE10) | \
786
PIN_PUPDR_PULLDOWN(PE11) | \
787
PIN_PUPDR_PULLDOWN(PE12) | \
788
PIN_PUPDR_PULLDOWN(PE13) | \
789
PIN_PUPDR_PULLDOWN(PE14) | \
790
PIN_PUPDR_PULLDOWN(PE15))
791
792
#define VAL_GPIOE_ODR (PIN_ODR_LEVEL_LOW(PE00) | \
793
PIN_ODR_LEVEL_LOW(PE01) | \
794
PIN_ODR_LEVEL_LOW(PE02) | \
795
PIN_ODR_LEVEL_LOW(PE03) | \
796
PIN_ODR_LEVEL_LOW(PE04) | \
797
PIN_ODR_LEVEL_LOW(PE05) | \
798
PIN_ODR_LEVEL_LOW(PE06) | \
799
PIN_ODR_LEVEL_LOW(PE07) | \
800
PIN_ODR_LEVEL_LOW(PE08) | \
801
PIN_ODR_LEVEL_LOW(PE09) | \
802
PIN_ODR_LEVEL_LOW(PE10) | \
803
PIN_ODR_LEVEL_LOW(PE11) | \
804
PIN_ODR_LEVEL_LOW(PE12) | \
805
PIN_ODR_LEVEL_LOW(PE13) | \
806
PIN_ODR_LEVEL_LOW(PE14) | \
807
PIN_ODR_LEVEL_LOW(PE15))
808
809
#define VAL_GPIOE_AFRL (PIN_AFIO_AF(PE00, 0) | \
810
PIN_AFIO_AF(PE01, 0) | \
811
PIN_AFIO_AF(PE02, 0) | \
812
PIN_AFIO_AF(PE03, 0) | \
813
PIN_AFIO_AF(PE04, 0) | \
814
PIN_AFIO_AF(PE05, 0) | \
815
PIN_AFIO_AF(PE06, 0) | \
816
PIN_AFIO_AF(PE07, 0))
817
818
#define VAL_GPIOE_AFRH (PIN_AFIO_AF(PE08, 0) | \
819
PIN_AFIO_AF(PE09, 0) | \
820
PIN_AFIO_AF(PE10, 0) | \
821
PIN_AFIO_AF(PE11, 0) | \
822
PIN_AFIO_AF(PE12, 0) | \
823
PIN_AFIO_AF(PE13, 0) | \
824
PIN_AFIO_AF(PE14, 0) | \
825
PIN_AFIO_AF(PE15, 0))
826
827
#define VAL_GPIOF_MODER (PIN_MODE_INPUT(PF00) | \
828
PIN_MODE_INPUT(PF01) | \
829
PIN_MODE_INPUT(PF02) | \
830
PIN_MODE_INPUT(PF03) | \
831
PIN_MODE_INPUT(PF04) | \
832
PIN_MODE_INPUT(PF05) | \
833
PIN_MODE_INPUT(PF06) | \
834
PIN_MODE_INPUT(PF07) | \
835
PIN_MODE_INPUT(PF08) | \
836
PIN_MODE_INPUT(PF09) | \
837
PIN_MODE_INPUT(PF10) | \
838
PIN_MODE_INPUT(PF11) | \
839
PIN_MODE_INPUT(PF12) | \
840
PIN_MODE_INPUT(PF13) | \
841
PIN_MODE_INPUT(PF14) | \
842
PIN_MODE_INPUT(PF15))
843
844
#define VAL_GPIOF_OTYPER (PIN_OTYPE_PUSHPULL(PF00) | \
845
PIN_OTYPE_PUSHPULL(PF01) | \
846
PIN_OTYPE_PUSHPULL(PF02) | \
847
PIN_OTYPE_PUSHPULL(PF03) | \
848
PIN_OTYPE_PUSHPULL(PF04) | \
849
PIN_OTYPE_PUSHPULL(PF05) | \
850
PIN_OTYPE_PUSHPULL(PF06) | \
851
PIN_OTYPE_PUSHPULL(PF07) | \
852
PIN_OTYPE_PUSHPULL(PF08) | \
853
PIN_OTYPE_PUSHPULL(PF09) | \
854
PIN_OTYPE_PUSHPULL(PF10) | \
855
PIN_OTYPE_PUSHPULL(PF11) | \
856
PIN_OTYPE_PUSHPULL(PF12) | \
857
PIN_OTYPE_PUSHPULL(PF13) | \
858
PIN_OTYPE_PUSHPULL(PF14) | \
859
PIN_OTYPE_PUSHPULL(PF15))
860
861
#define VAL_GPIOF_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PF00) | \
862
PIN_OSPEED_SPEED_VERYLOW(PF01) | \
863
PIN_OSPEED_SPEED_VERYLOW(PF02) | \
864
PIN_OSPEED_SPEED_VERYLOW(PF03) | \
865
PIN_OSPEED_SPEED_VERYLOW(PF04) | \
866
PIN_OSPEED_SPEED_VERYLOW(PF05) | \
867
PIN_OSPEED_SPEED_VERYLOW(PF06) | \
868
PIN_OSPEED_SPEED_VERYLOW(PF07) | \
869
PIN_OSPEED_SPEED_VERYLOW(PF08) | \
870
PIN_OSPEED_SPEED_VERYLOW(PF09) | \
871
PIN_OSPEED_SPEED_VERYLOW(PF10) | \
872
PIN_OSPEED_SPEED_VERYLOW(PF11) | \
873
PIN_OSPEED_SPEED_VERYLOW(PF12) | \
874
PIN_OSPEED_SPEED_VERYLOW(PF13) | \
875
PIN_OSPEED_SPEED_VERYLOW(PF14) | \
876
PIN_OSPEED_SPEED_VERYLOW(PF15))
877
878
#define VAL_GPIOF_PUPDR (PIN_PUPDR_PULLDOWN(PF00) | \
879
PIN_PUPDR_PULLDOWN(PF01) | \
880
PIN_PUPDR_PULLDOWN(PF02) | \
881
PIN_PUPDR_PULLDOWN(PF03) | \
882
PIN_PUPDR_PULLDOWN(PF04) | \
883
PIN_PUPDR_PULLDOWN(PF05) | \
884
PIN_PUPDR_PULLDOWN(PF06) | \
885
PIN_PUPDR_PULLDOWN(PF07) | \
886
PIN_PUPDR_PULLDOWN(PF08) | \
887
PIN_PUPDR_PULLDOWN(PF09) | \
888
PIN_PUPDR_PULLDOWN(PF10) | \
889
PIN_PUPDR_PULLDOWN(PF11) | \
890
PIN_PUPDR_PULLDOWN(PF12) | \
891
PIN_PUPDR_PULLDOWN(PF13) | \
892
PIN_PUPDR_PULLDOWN(PF14) | \
893
PIN_PUPDR_PULLDOWN(PF15))
894
895
#define VAL_GPIOF_ODR (PIN_ODR_LEVEL_LOW(PF00) | \
896
PIN_ODR_LEVEL_LOW(PF01) | \
897
PIN_ODR_LEVEL_LOW(PF02) | \
898
PIN_ODR_LEVEL_LOW(PF03) | \
899
PIN_ODR_LEVEL_LOW(PF04) | \
900
PIN_ODR_LEVEL_LOW(PF05) | \
901
PIN_ODR_LEVEL_LOW(PF06) | \
902
PIN_ODR_LEVEL_LOW(PF07) | \
903
PIN_ODR_LEVEL_LOW(PF08) | \
904
PIN_ODR_LEVEL_LOW(PF09) | \
905
PIN_ODR_LEVEL_LOW(PF10) | \
906
PIN_ODR_LEVEL_LOW(PF11) | \
907
PIN_ODR_LEVEL_LOW(PF12) | \
908
PIN_ODR_LEVEL_LOW(PF13) | \
909
PIN_ODR_LEVEL_LOW(PF14) | \
910
PIN_ODR_LEVEL_LOW(PF15))
911
912
#define VAL_GPIOF_AFRL (PIN_AFIO_AF(PF00, 0) | \
913
PIN_AFIO_AF(PF01, 0) | \
914
PIN_AFIO_AF(PF02, 0) | \
915
PIN_AFIO_AF(PF03, 0) | \
916
PIN_AFIO_AF(PF04, 0) | \
917
PIN_AFIO_AF(PF05, 0) | \
918
PIN_AFIO_AF(PF06, 0) | \
919
PIN_AFIO_AF(PF07, 0))
920
921
#define VAL_GPIOF_AFRH (PIN_AFIO_AF(PF08, 0) | \
922
PIN_AFIO_AF(PF09, 0) | \
923
PIN_AFIO_AF(PF10, 0) | \
924
PIN_AFIO_AF(PF11, 0) | \
925
PIN_AFIO_AF(PF12, 0) | \
926
PIN_AFIO_AF(PF13, 0) | \
927
PIN_AFIO_AF(PF14, 0) | \
928
PIN_AFIO_AF(PF15, 0))
929
930
#define VAL_GPIOG_MODER (PIN_MODE_INPUT(PG00) | \
931
PIN_MODE_INPUT(PG01) | \
932
PIN_MODE_INPUT(PG02) | \
933
PIN_MODE_INPUT(PG03) | \
934
PIN_MODE_INPUT(PG04) | \
935
PIN_MODE_INPUT(PG05) | \
936
PIN_MODE_INPUT(PG06) | \
937
PIN_MODE_INPUT(PG07) | \
938
PIN_MODE_INPUT(PG08) | \
939
PIN_MODE_INPUT(PG09) | \
940
PIN_MODE_INPUT(PG10) | \
941
PIN_MODE_INPUT(PG11) | \
942
PIN_MODE_INPUT(PG12) | \
943
PIN_MODE_INPUT(PG13) | \
944
PIN_MODE_INPUT(PG14) | \
945
PIN_MODE_INPUT(PG15))
946
947
#define VAL_GPIOG_OTYPER (PIN_OTYPE_PUSHPULL(PG00) | \
948
PIN_OTYPE_PUSHPULL(PG01) | \
949
PIN_OTYPE_PUSHPULL(PG02) | \
950
PIN_OTYPE_PUSHPULL(PG03) | \
951
PIN_OTYPE_PUSHPULL(PG04) | \
952
PIN_OTYPE_PUSHPULL(PG05) | \
953
PIN_OTYPE_PUSHPULL(PG06) | \
954
PIN_OTYPE_PUSHPULL(PG07) | \
955
PIN_OTYPE_PUSHPULL(PG08) | \
956
PIN_OTYPE_PUSHPULL(PG09) | \
957
PIN_OTYPE_PUSHPULL(PG10) | \
958
PIN_OTYPE_PUSHPULL(PG11) | \
959
PIN_OTYPE_PUSHPULL(PG12) | \
960
PIN_OTYPE_PUSHPULL(PG13) | \
961
PIN_OTYPE_PUSHPULL(PG14) | \
962
PIN_OTYPE_PUSHPULL(PG15))
963
964
#define VAL_GPIOG_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PG00) | \
965
PIN_OSPEED_SPEED_VERYLOW(PG01) | \
966
PIN_OSPEED_SPEED_VERYLOW(PG02) | \
967
PIN_OSPEED_SPEED_VERYLOW(PG03) | \
968
PIN_OSPEED_SPEED_VERYLOW(PG04) | \
969
PIN_OSPEED_SPEED_VERYLOW(PG05) | \
970
PIN_OSPEED_SPEED_VERYLOW(PG06) | \
971
PIN_OSPEED_SPEED_VERYLOW(PG07) | \
972
PIN_OSPEED_SPEED_VERYLOW(PG08) | \
973
PIN_OSPEED_SPEED_VERYLOW(PG09) | \
974
PIN_OSPEED_SPEED_VERYLOW(PG10) | \
975
PIN_OSPEED_SPEED_VERYLOW(PG11) | \
976
PIN_OSPEED_SPEED_VERYLOW(PG12) | \
977
PIN_OSPEED_SPEED_VERYLOW(PG13) | \
978
PIN_OSPEED_SPEED_VERYLOW(PG14) | \
979
PIN_OSPEED_SPEED_VERYLOW(PG15))
980
981
#define VAL_GPIOG_PUPDR (PIN_PUPDR_PULLDOWN(PG00) | \
982
PIN_PUPDR_PULLDOWN(PG01) | \
983
PIN_PUPDR_PULLDOWN(PG02) | \
984
PIN_PUPDR_PULLDOWN(PG03) | \
985
PIN_PUPDR_PULLDOWN(PG04) | \
986
PIN_PUPDR_PULLDOWN(PG05) | \
987
PIN_PUPDR_PULLDOWN(PG06) | \
988
PIN_PUPDR_PULLDOWN(PG07) | \
989
PIN_PUPDR_PULLDOWN(PG08) | \
990
PIN_PUPDR_PULLDOWN(PG09) | \
991
PIN_PUPDR_PULLDOWN(PG10) | \
992
PIN_PUPDR_PULLDOWN(PG11) | \
993
PIN_PUPDR_PULLDOWN(PG12) | \
994
PIN_PUPDR_PULLDOWN(PG13) | \
995
PIN_PUPDR_PULLDOWN(PG14) | \
996
PIN_PUPDR_PULLDOWN(PG15))
997
998
#define VAL_GPIOG_ODR (PIN_ODR_LEVEL_LOW(PG00) | \
999
PIN_ODR_LEVEL_LOW(PG01) | \
1000
PIN_ODR_LEVEL_LOW(PG02) | \
1001
PIN_ODR_LEVEL_LOW(PG03) | \
1002
PIN_ODR_LEVEL_LOW(PG04) | \
1003
PIN_ODR_LEVEL_LOW(PG05) | \
1004
PIN_ODR_LEVEL_LOW(PG06) | \
1005
PIN_ODR_LEVEL_LOW(PG07) | \
1006
PIN_ODR_LEVEL_LOW(PG08) | \
1007
PIN_ODR_LEVEL_LOW(PG09) | \
1008
PIN_ODR_LEVEL_LOW(PG10) | \
1009
PIN_ODR_LEVEL_LOW(PG11) | \
1010
PIN_ODR_LEVEL_LOW(PG12) | \
1011
PIN_ODR_LEVEL_LOW(PG13) | \
1012
PIN_ODR_LEVEL_LOW(PG14) | \
1013
PIN_ODR_LEVEL_LOW(PG15))
1014
1015
#define VAL_GPIOG_AFRL (PIN_AFIO_AF(PG00, 0) | \
1016
PIN_AFIO_AF(PG01, 0) | \
1017
PIN_AFIO_AF(PG02, 0) | \
1018
PIN_AFIO_AF(PG03, 0) | \
1019
PIN_AFIO_AF(PG04, 0) | \
1020
PIN_AFIO_AF(PG05, 0) | \
1021
PIN_AFIO_AF(PG06, 0) | \
1022
PIN_AFIO_AF(PG07, 0))
1023
1024
#define VAL_GPIOG_AFRH (PIN_AFIO_AF(PG08, 0) | \
1025
PIN_AFIO_AF(PG09, 0) | \
1026
PIN_AFIO_AF(PG10, 0) | \
1027
PIN_AFIO_AF(PG11, 0) | \
1028
PIN_AFIO_AF(PG12, 0) | \
1029
PIN_AFIO_AF(PG13, 0) | \
1030
PIN_AFIO_AF(PG14, 0) | \
1031
PIN_AFIO_AF(PG15, 0))
1032
1033
#define VAL_GPIOH_MODER (PIN_MODE_ALTERNATE(OSC_IN) | \
1034
PIN_MODE_ALTERNATE(OSC_OUT) | \
1035
PIN_MODE_INPUT(PH02) | \
1036
PIN_MODE_INPUT(PH03) | \
1037
PIN_MODE_INPUT(PH04) | \
1038
PIN_MODE_INPUT(PH05) | \
1039
PIN_MODE_INPUT(PH06) | \
1040
PIN_MODE_INPUT(PH07) | \
1041
PIN_MODE_INPUT(PH08) | \
1042
PIN_MODE_INPUT(PH09) | \
1043
PIN_MODE_INPUT(PH10) | \
1044
PIN_MODE_INPUT(PH11) | \
1045
PIN_MODE_INPUT(PH12) | \
1046
PIN_MODE_INPUT(PH13) | \
1047
PIN_MODE_INPUT(PH14) | \
1048
PIN_MODE_INPUT(PH15))
1049
1050
#define VAL_GPIOH_OTYPER (PIN_OTYPE_PUSHPULL(OSC_IN) | \
1051
PIN_OTYPE_PUSHPULL(OSC_OUT) | \
1052
PIN_OTYPE_PUSHPULL(PH02) | \
1053
PIN_OTYPE_PUSHPULL(PH03) | \
1054
PIN_OTYPE_PUSHPULL(PH04) | \
1055
PIN_OTYPE_PUSHPULL(PH05) | \
1056
PIN_OTYPE_PUSHPULL(PH06) | \
1057
PIN_OTYPE_PUSHPULL(PH07) | \
1058
PIN_OTYPE_PUSHPULL(PH08) | \
1059
PIN_OTYPE_PUSHPULL(PH09) | \
1060
PIN_OTYPE_PUSHPULL(PH10) | \
1061
PIN_OTYPE_PUSHPULL(PH11) | \
1062
PIN_OTYPE_PUSHPULL(PH12) | \
1063
PIN_OTYPE_PUSHPULL(PH13) | \
1064
PIN_OTYPE_PUSHPULL(PH14) | \
1065
PIN_OTYPE_PUSHPULL(PH15))
1066
1067
#define VAL_GPIOH_OSPEEDR (PIN_OSPEED_SPEED_HIGH(OSC_IN) | \
1068
PIN_OSPEED_SPEED_HIGH(OSC_OUT) | \
1069
PIN_OSPEED_SPEED_VERYLOW(PH02) | \
1070
PIN_OSPEED_SPEED_VERYLOW(PH03) | \
1071
PIN_OSPEED_SPEED_VERYLOW(PH04) | \
1072
PIN_OSPEED_SPEED_VERYLOW(PH05) | \
1073
PIN_OSPEED_SPEED_VERYLOW(PH06) | \
1074
PIN_OSPEED_SPEED_VERYLOW(PH07) | \
1075
PIN_OSPEED_SPEED_VERYLOW(PH08) | \
1076
PIN_OSPEED_SPEED_VERYLOW(PH09) | \
1077
PIN_OSPEED_SPEED_VERYLOW(PH10) | \
1078
PIN_OSPEED_SPEED_VERYLOW(PH11) | \
1079
PIN_OSPEED_SPEED_VERYLOW(PH12) | \
1080
PIN_OSPEED_SPEED_VERYLOW(PH13) | \
1081
PIN_OSPEED_SPEED_VERYLOW(PH14) | \
1082
PIN_OSPEED_SPEED_VERYLOW(PH15))
1083
1084
#define VAL_GPIOH_PUPDR (PIN_PUPDR_FLOATING(OSC_IN) | \
1085
PIN_PUPDR_FLOATING(OSC_OUT) | \
1086
PIN_PUPDR_PULLDOWN(PH02) | \
1087
PIN_PUPDR_PULLDOWN(PH03) | \
1088
PIN_PUPDR_PULLDOWN(PH04) | \
1089
PIN_PUPDR_PULLDOWN(PH05) | \
1090
PIN_PUPDR_PULLDOWN(PH06) | \
1091
PIN_PUPDR_PULLDOWN(PH07) | \
1092
PIN_PUPDR_PULLDOWN(PH08) | \
1093
PIN_PUPDR_PULLDOWN(PH09) | \
1094
PIN_PUPDR_PULLDOWN(PH10) | \
1095
PIN_PUPDR_PULLDOWN(PH11) | \
1096
PIN_PUPDR_PULLDOWN(PH12) | \
1097
PIN_PUPDR_PULLDOWN(PH13) | \
1098
PIN_PUPDR_PULLDOWN(PH14) | \
1099
PIN_PUPDR_PULLDOWN(PH15))
1100
1101
#define VAL_GPIOH_ODR (PIN_ODR_LEVEL_HIGH(OSC_IN) | \
1102
PIN_ODR_LEVEL_HIGH(OSC_OUT) | \
1103
PIN_ODR_LEVEL_LOW(PH02) | \
1104
PIN_ODR_LEVEL_LOW(PH03) | \
1105
PIN_ODR_LEVEL_LOW(PH04) | \
1106
PIN_ODR_LEVEL_LOW(PH05) | \
1107
PIN_ODR_LEVEL_LOW(PH06) | \
1108
PIN_ODR_LEVEL_LOW(PH07) | \
1109
PIN_ODR_LEVEL_LOW(PH08) | \
1110
PIN_ODR_LEVEL_LOW(PH09) | \
1111
PIN_ODR_LEVEL_LOW(PH10) | \
1112
PIN_ODR_LEVEL_LOW(PH11) | \
1113
PIN_ODR_LEVEL_LOW(PH12) | \
1114
PIN_ODR_LEVEL_LOW(PH13) | \
1115
PIN_ODR_LEVEL_LOW(PH14) | \
1116
PIN_ODR_LEVEL_LOW(PH15))
1117
1118
#define VAL_GPIOH_AFRL (PIN_AFIO_AF(OSC_IN, 0) | \
1119
PIN_AFIO_AF(OSC_OUT, 0) | \
1120
PIN_AFIO_AF(PH02, 0) | \
1121
PIN_AFIO_AF(PH03, 0) | \
1122
PIN_AFIO_AF(PH04, 0) | \
1123
PIN_AFIO_AF(PH05, 0) | \
1124
PIN_AFIO_AF(PH06, 0) | \
1125
PIN_AFIO_AF(PH07, 0))
1126
1127
#define VAL_GPIOH_AFRH (PIN_AFIO_AF(PH08, 0) | \
1128
PIN_AFIO_AF(PH09, 0) | \
1129
PIN_AFIO_AF(PH10, 0) | \
1130
PIN_AFIO_AF(PH11, 0) | \
1131
PIN_AFIO_AF(PH12, 0) | \
1132
PIN_AFIO_AF(PH13, 0) | \
1133
PIN_AFIO_AF(PH14, 0) | \
1134
PIN_AFIO_AF(PH15, 0))
1135
1136
#define VAL_GPIOI_MODER (PIN_MODE_INPUT(PI00) | \
1137
PIN_MODE_INPUT(PI01) | \
1138
PIN_MODE_INPUT(PI02) | \
1139
PIN_MODE_INPUT(PI03) | \
1140
PIN_MODE_INPUT(PI04) | \
1141
PIN_MODE_INPUT(PI05) | \
1142
PIN_MODE_INPUT(PI06) | \
1143
PIN_MODE_INPUT(PI07) | \
1144
PIN_MODE_INPUT(PI08) | \
1145
PIN_MODE_INPUT(PI09) | \
1146
PIN_MODE_INPUT(PI10) | \
1147
PIN_MODE_INPUT(PI11) | \
1148
PIN_MODE_INPUT(PI12) | \
1149
PIN_MODE_INPUT(PI13) | \
1150
PIN_MODE_INPUT(PI14) | \
1151
PIN_MODE_INPUT(PI15))
1152
1153
#define VAL_GPIOI_OTYPER (PIN_OTYPE_PUSHPULL(PI00) | \
1154
PIN_OTYPE_PUSHPULL(PI01) | \
1155
PIN_OTYPE_PUSHPULL(PI02) | \
1156
PIN_OTYPE_PUSHPULL(PI03) | \
1157
PIN_OTYPE_PUSHPULL(PI04) | \
1158
PIN_OTYPE_PUSHPULL(PI05) | \
1159
PIN_OTYPE_PUSHPULL(PI06) | \
1160
PIN_OTYPE_PUSHPULL(PI07) | \
1161
PIN_OTYPE_PUSHPULL(PI08) | \
1162
PIN_OTYPE_PUSHPULL(PI09) | \
1163
PIN_OTYPE_PUSHPULL(PI10) | \
1164
PIN_OTYPE_PUSHPULL(PI11) | \
1165
PIN_OTYPE_PUSHPULL(PI12) | \
1166
PIN_OTYPE_PUSHPULL(PI13) | \
1167
PIN_OTYPE_PUSHPULL(PI14) | \
1168
PIN_OTYPE_PUSHPULL(PI15))
1169
1170
#define VAL_GPIOI_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PI00) | \
1171
PIN_OSPEED_SPEED_VERYLOW(PI01) | \
1172
PIN_OSPEED_SPEED_VERYLOW(PI02) | \
1173
PIN_OSPEED_SPEED_VERYLOW(PI03) | \
1174
PIN_OSPEED_SPEED_VERYLOW(PI04) | \
1175
PIN_OSPEED_SPEED_VERYLOW(PI05) | \
1176
PIN_OSPEED_SPEED_VERYLOW(PI06) | \
1177
PIN_OSPEED_SPEED_VERYLOW(PI07) | \
1178
PIN_OSPEED_SPEED_VERYLOW(PI08) | \
1179
PIN_OSPEED_SPEED_VERYLOW(PI09) | \
1180
PIN_OSPEED_SPEED_VERYLOW(PI10) | \
1181
PIN_OSPEED_SPEED_VERYLOW(PI11) | \
1182
PIN_OSPEED_SPEED_VERYLOW(PI12) | \
1183
PIN_OSPEED_SPEED_VERYLOW(PI13) | \
1184
PIN_OSPEED_SPEED_VERYLOW(PI14) | \
1185
PIN_OSPEED_SPEED_VERYLOW(PI15))
1186
1187
#define VAL_GPIOI_PUPDR (PIN_PUPDR_PULLDOWN(PI00) | \
1188
PIN_PUPDR_PULLDOWN(PI01) | \
1189
PIN_PUPDR_PULLDOWN(PI02) | \
1190
PIN_PUPDR_PULLDOWN(PI03) | \
1191
PIN_PUPDR_PULLDOWN(PI04) | \
1192
PIN_PUPDR_PULLDOWN(PI05) | \
1193
PIN_PUPDR_PULLDOWN(PI06) | \
1194
PIN_PUPDR_PULLDOWN(PI07) | \
1195
PIN_PUPDR_PULLDOWN(PI08) | \
1196
PIN_PUPDR_PULLDOWN(PI09) | \
1197
PIN_PUPDR_PULLDOWN(PI10) | \
1198
PIN_PUPDR_PULLDOWN(PI11) | \
1199
PIN_PUPDR_PULLDOWN(PI12) | \
1200
PIN_PUPDR_PULLDOWN(PI13) | \
1201
PIN_PUPDR_PULLDOWN(PI14) | \
1202
PIN_PUPDR_PULLDOWN(PI15))
1203
1204
#define VAL_GPIOI_ODR (PIN_ODR_LEVEL_LOW(PI00) | \
1205
PIN_ODR_LEVEL_LOW(PI01) | \
1206
PIN_ODR_LEVEL_LOW(PI02) | \
1207
PIN_ODR_LEVEL_LOW(PI03) | \
1208
PIN_ODR_LEVEL_LOW(PI04) | \
1209
PIN_ODR_LEVEL_LOW(PI05) | \
1210
PIN_ODR_LEVEL_LOW(PI06) | \
1211
PIN_ODR_LEVEL_LOW(PI07) | \
1212
PIN_ODR_LEVEL_LOW(PI08) | \
1213
PIN_ODR_LEVEL_LOW(PI09) | \
1214
PIN_ODR_LEVEL_LOW(PI10) | \
1215
PIN_ODR_LEVEL_LOW(PI11) | \
1216
PIN_ODR_LEVEL_LOW(PI12) | \
1217
PIN_ODR_LEVEL_LOW(PI13) | \
1218
PIN_ODR_LEVEL_LOW(PI14) | \
1219
PIN_ODR_LEVEL_LOW(PI15))
1220
1221
#define VAL_GPIOI_AFRL (PIN_AFIO_AF(PI00, 0) | \
1222
PIN_AFIO_AF(PI01, 0) | \
1223
PIN_AFIO_AF(PI02, 0) | \
1224
PIN_AFIO_AF(PI03, 0) | \
1225
PIN_AFIO_AF(PI04, 0) | \
1226
PIN_AFIO_AF(PI05, 0) | \
1227
PIN_AFIO_AF(PI06, 0) | \
1228
PIN_AFIO_AF(PI07, 0))
1229
1230
#define VAL_GPIOI_AFRH (PIN_AFIO_AF(PI08, 0) | \
1231
PIN_AFIO_AF(PI09, 0) | \
1232
PIN_AFIO_AF(PI10, 0) | \
1233
PIN_AFIO_AF(PI11, 0) | \
1234
PIN_AFIO_AF(PI12, 0) | \
1235
PIN_AFIO_AF(PI13, 0) | \
1236
PIN_AFIO_AF(PI14, 0) | \
1237
PIN_AFIO_AF(PI15, 0))
1238
1239
#define VAL_GPIOJ_MODER (PIN_MODE_INPUT(PJ00) | \
1240
PIN_MODE_INPUT(PJ01) | \
1241
PIN_MODE_INPUT(PJ02) | \
1242
PIN_MODE_INPUT(PJ03) | \
1243
PIN_MODE_INPUT(PJ04) | \
1244
PIN_MODE_INPUT(PJ05) | \
1245
PIN_MODE_INPUT(PJ06) | \
1246
PIN_MODE_INPUT(PJ07) | \
1247
PIN_MODE_INPUT(PJ08) | \
1248
PIN_MODE_INPUT(PJ09) | \
1249
PIN_MODE_INPUT(PJ10) | \
1250
PIN_MODE_INPUT(PJ11) | \
1251
PIN_MODE_INPUT(PJ12) | \
1252
PIN_MODE_INPUT(PJ13) | \
1253
PIN_MODE_INPUT(PJ14) | \
1254
PIN_MODE_INPUT(PJ15))
1255
1256
#define VAL_GPIOJ_OTYPER (PIN_OTYPE_PUSHPULL(PJ00) | \
1257
PIN_OTYPE_PUSHPULL(PJ01) | \
1258
PIN_OTYPE_PUSHPULL(PJ02) | \
1259
PIN_OTYPE_PUSHPULL(PJ03) | \
1260
PIN_OTYPE_PUSHPULL(PJ04) | \
1261
PIN_OTYPE_PUSHPULL(PJ05) | \
1262
PIN_OTYPE_PUSHPULL(PJ06) | \
1263
PIN_OTYPE_PUSHPULL(PJ07) | \
1264
PIN_OTYPE_PUSHPULL(PJ08) | \
1265
PIN_OTYPE_PUSHPULL(PJ09) | \
1266
PIN_OTYPE_PUSHPULL(PJ10) | \
1267
PIN_OTYPE_PUSHPULL(PJ11) | \
1268
PIN_OTYPE_PUSHPULL(PJ12) | \
1269
PIN_OTYPE_PUSHPULL(PJ13) | \
1270
PIN_OTYPE_PUSHPULL(PJ14) | \
1271
PIN_OTYPE_PUSHPULL(PJ15))
1272
1273
#define VAL_GPIOJ_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PJ00) | \
1274
PIN_OSPEED_SPEED_VERYLOW(PJ01) | \
1275
PIN_OSPEED_SPEED_VERYLOW(PJ02) | \
1276
PIN_OSPEED_SPEED_VERYLOW(PJ03) | \
1277
PIN_OSPEED_SPEED_VERYLOW(PJ04) | \
1278
PIN_OSPEED_SPEED_VERYLOW(PJ05) | \
1279
PIN_OSPEED_SPEED_VERYLOW(PJ06) | \
1280
PIN_OSPEED_SPEED_VERYLOW(PJ07) | \
1281
PIN_OSPEED_SPEED_VERYLOW(PJ08) | \
1282
PIN_OSPEED_SPEED_VERYLOW(PJ09) | \
1283
PIN_OSPEED_SPEED_VERYLOW(PJ10) | \
1284
PIN_OSPEED_SPEED_VERYLOW(PJ11) | \
1285
PIN_OSPEED_SPEED_VERYLOW(PJ12) | \
1286
PIN_OSPEED_SPEED_VERYLOW(PJ13) | \
1287
PIN_OSPEED_SPEED_VERYLOW(PJ14) | \
1288
PIN_OSPEED_SPEED_VERYLOW(PJ15))
1289
1290
#define VAL_GPIOJ_PUPDR (PIN_PUPDR_PULLDOWN(PJ00) | \
1291
PIN_PUPDR_PULLDOWN(PJ01) | \
1292
PIN_PUPDR_PULLDOWN(PJ02) | \
1293
PIN_PUPDR_PULLDOWN(PJ03) | \
1294
PIN_PUPDR_PULLDOWN(PJ04) | \
1295
PIN_PUPDR_PULLDOWN(PJ05) | \
1296
PIN_PUPDR_PULLDOWN(PJ06) | \
1297
PIN_PUPDR_PULLDOWN(PJ07) | \
1298
PIN_PUPDR_PULLDOWN(PJ08) | \
1299
PIN_PUPDR_PULLDOWN(PJ09) | \
1300
PIN_PUPDR_PULLDOWN(PJ10) | \
1301
PIN_PUPDR_PULLDOWN(PJ11) | \
1302
PIN_PUPDR_PULLDOWN(PJ12) | \
1303
PIN_PUPDR_PULLDOWN(PJ13) | \
1304
PIN_PUPDR_PULLDOWN(PJ14) | \
1305
PIN_PUPDR_PULLDOWN(PJ15))
1306
1307
#define VAL_GPIOJ_ODR (PIN_ODR_LEVEL_LOW(PJ00) | \
1308
PIN_ODR_LEVEL_LOW(PJ01) | \
1309
PIN_ODR_LEVEL_LOW(PJ02) | \
1310
PIN_ODR_LEVEL_LOW(PJ03) | \
1311
PIN_ODR_LEVEL_LOW(PJ04) | \
1312
PIN_ODR_LEVEL_LOW(PJ05) | \
1313
PIN_ODR_LEVEL_LOW(PJ06) | \
1314
PIN_ODR_LEVEL_LOW(PJ07) | \
1315
PIN_ODR_LEVEL_LOW(PJ08) | \
1316
PIN_ODR_LEVEL_LOW(PJ09) | \
1317
PIN_ODR_LEVEL_LOW(PJ10) | \
1318
PIN_ODR_LEVEL_LOW(PJ11) | \
1319
PIN_ODR_LEVEL_LOW(PJ12) | \
1320
PIN_ODR_LEVEL_LOW(PJ13) | \
1321
PIN_ODR_LEVEL_LOW(PJ14) | \
1322
PIN_ODR_LEVEL_LOW(PJ15))
1323
1324
#define VAL_GPIOJ_AFRL (PIN_AFIO_AF(PJ00, 0) | \
1325
PIN_AFIO_AF(PJ01, 0) | \
1326
PIN_AFIO_AF(PJ02, 0) | \
1327
PIN_AFIO_AF(PJ03, 0) | \
1328
PIN_AFIO_AF(PJ04, 0) | \
1329
PIN_AFIO_AF(PJ05, 0) | \
1330
PIN_AFIO_AF(PJ06, 0) | \
1331
PIN_AFIO_AF(PJ07, 0))
1332
1333
#define VAL_GPIOJ_AFRH (PIN_AFIO_AF(PJ08, 0) | \
1334
PIN_AFIO_AF(PJ09, 0) | \
1335
PIN_AFIO_AF(PJ10, 0) | \
1336
PIN_AFIO_AF(PJ11, 0) | \
1337
PIN_AFIO_AF(PJ12, 0) | \
1338
PIN_AFIO_AF(PJ13, 0) | \
1339
PIN_AFIO_AF(PJ14, 0) | \
1340
PIN_AFIO_AF(PJ15, 0))
1341
1342
#define VAL_GPIOK_MODER (PIN_MODE_INPUT(PK00) | \
1343
PIN_MODE_INPUT(PK01) | \
1344
PIN_MODE_INPUT(PK02) | \
1345
PIN_MODE_INPUT(PK03) | \
1346
PIN_MODE_INPUT(PK04) | \
1347
PIN_MODE_INPUT(PK05) | \
1348
PIN_MODE_INPUT(PK06) | \
1349
PIN_MODE_INPUT(PK07) | \
1350
PIN_MODE_INPUT(PK08) | \
1351
PIN_MODE_INPUT(PK09) | \
1352
PIN_MODE_INPUT(PK10) | \
1353
PIN_MODE_INPUT(PK11) | \
1354
PIN_MODE_INPUT(PK12) | \
1355
PIN_MODE_INPUT(PK13) | \
1356
PIN_MODE_INPUT(PK14) | \
1357
PIN_MODE_INPUT(PK15))
1358
1359
#define VAL_GPIOK_OTYPER (PIN_OTYPE_PUSHPULL(PK00) | \
1360
PIN_OTYPE_PUSHPULL(PK01) | \
1361
PIN_OTYPE_PUSHPULL(PK02) | \
1362
PIN_OTYPE_PUSHPULL(PK03) | \
1363
PIN_OTYPE_PUSHPULL(PK04) | \
1364
PIN_OTYPE_PUSHPULL(PK05) | \
1365
PIN_OTYPE_PUSHPULL(PK06) | \
1366
PIN_OTYPE_PUSHPULL(PK07) | \
1367
PIN_OTYPE_PUSHPULL(PK08) | \
1368
PIN_OTYPE_PUSHPULL(PK09) | \
1369
PIN_OTYPE_PUSHPULL(PK10) | \
1370
PIN_OTYPE_PUSHPULL(PK11) | \
1371
PIN_OTYPE_PUSHPULL(PK12) | \
1372
PIN_OTYPE_PUSHPULL(PK13) | \
1373
PIN_OTYPE_PUSHPULL(PK14) | \
1374
PIN_OTYPE_PUSHPULL(PK15))
1375
1376
#define VAL_GPIOK_OSPEEDR (PIN_OSPEED_SPEED_VERYLOW(PK00) | \
1377
PIN_OSPEED_SPEED_VERYLOW(PK01) | \
1378
PIN_OSPEED_SPEED_VERYLOW(PK02) | \
1379
PIN_OSPEED_SPEED_VERYLOW(PK03) | \
1380
PIN_OSPEED_SPEED_VERYLOW(PK04) | \
1381
PIN_OSPEED_SPEED_VERYLOW(PK05) | \
1382
PIN_OSPEED_SPEED_VERYLOW(PK06) | \
1383
PIN_OSPEED_SPEED_VERYLOW(PK07) | \
1384
PIN_OSPEED_SPEED_VERYLOW(PK08) | \
1385
PIN_OSPEED_SPEED_VERYLOW(PK09) | \
1386
PIN_OSPEED_SPEED_VERYLOW(PK10) | \
1387
PIN_OSPEED_SPEED_VERYLOW(PK11) | \
1388
PIN_OSPEED_SPEED_VERYLOW(PK12) | \
1389
PIN_OSPEED_SPEED_VERYLOW(PK13) | \
1390
PIN_OSPEED_SPEED_VERYLOW(PK14) | \
1391
PIN_OSPEED_SPEED_VERYLOW(PK15))
1392
1393
#define VAL_GPIOK_PUPDR (PIN_PUPDR_PULLDOWN(PK00) | \
1394
PIN_PUPDR_PULLDOWN(PK01) | \
1395
PIN_PUPDR_PULLDOWN(PK02) | \
1396
PIN_PUPDR_PULLDOWN(PK03) | \
1397
PIN_PUPDR_PULLDOWN(PK04) | \
1398
PIN_PUPDR_PULLDOWN(PK05) | \
1399
PIN_PUPDR_PULLDOWN(PK06) | \
1400
PIN_PUPDR_PULLDOWN(PK07) | \
1401
PIN_PUPDR_PULLDOWN(PK08) | \
1402
PIN_PUPDR_PULLDOWN(PK09) | \
1403
PIN_PUPDR_PULLDOWN(PK10) | \
1404
PIN_PUPDR_PULLDOWN(PK11) | \
1405
PIN_PUPDR_PULLDOWN(PK12) | \
1406
PIN_PUPDR_PULLDOWN(PK13) | \
1407
PIN_PUPDR_PULLDOWN(PK14) | \
1408
PIN_PUPDR_PULLDOWN(PK15))
1409
1410
#define VAL_GPIOK_ODR (PIN_ODR_LEVEL_LOW(PK00) | \
1411
PIN_ODR_LEVEL_LOW(PK01) | \
1412
PIN_ODR_LEVEL_LOW(PK02) | \
1413
PIN_ODR_LEVEL_LOW(PK03) | \
1414
PIN_ODR_LEVEL_LOW(PK04) | \
1415
PIN_ODR_LEVEL_LOW(PK05) | \
1416
PIN_ODR_LEVEL_LOW(PK06) | \
1417
PIN_ODR_LEVEL_LOW(PK07) | \
1418
PIN_ODR_LEVEL_LOW(PK08) | \
1419
PIN_ODR_LEVEL_LOW(PK09) | \
1420
PIN_ODR_LEVEL_LOW(PK10) | \
1421
PIN_ODR_LEVEL_LOW(PK11) | \
1422
PIN_ODR_LEVEL_LOW(PK12) | \
1423
PIN_ODR_LEVEL_LOW(PK13) | \
1424
PIN_ODR_LEVEL_LOW(PK14) | \
1425
PIN_ODR_LEVEL_LOW(PK15))
1426
1427
#define VAL_GPIOK_AFRL (PIN_AFIO_AF(PK00, 0) | \
1428
PIN_AFIO_AF(PK01, 0) | \
1429
PIN_AFIO_AF(PK02, 0) | \
1430
PIN_AFIO_AF(PK03, 0) | \
1431
PIN_AFIO_AF(PK04, 0) | \
1432
PIN_AFIO_AF(PK05, 0) | \
1433
PIN_AFIO_AF(PK06, 0) | \
1434
PIN_AFIO_AF(PK07, 0))
1435
1436
#define VAL_GPIOK_AFRH (PIN_AFIO_AF(PK08, 0) | \
1437
PIN_AFIO_AF(PK09, 0) | \
1438
PIN_AFIO_AF(PK10, 0) | \
1439
PIN_AFIO_AF(PK11, 0) | \
1440
PIN_AFIO_AF(PK12, 0) | \
1441
PIN_AFIO_AF(PK13, 0) | \
1442
PIN_AFIO_AF(PK14, 0) | \
1443
PIN_AFIO_AF(PK15, 0))
1444
1445
#define AF_MOTOR1 1U
1446
#define AF_LINE_MOTOR1 1U
1447
#define AF_E_TX2 7U
1448
#define AF_LINE_E_TX2 7U
1449
#define AF_E_RX2 7U
1450
#define AF_LINE_E_RX2 7U
1451
#define AF_E_SCK 5U
1452
#define AF_LINE_E_SCK 5U
1453
#define AF_E_MISO 5U
1454
#define AF_LINE_E_MISO 5U
1455
#define AF_E_MOSI 5U
1456
#define AF_LINE_E_MOSI 5U
1457
#define AF_I2C3_SCL 4U
1458
#define AF_LINE_I2C3_SCL 4U
1459
#define AF_USB_ID 10U
1460
#define AF_LINE_USB_ID 10U
1461
#define AF_USB_DM 10U
1462
#define AF_LINE_USB_DM 10U
1463
#define AF_USB_DP 10U
1464
#define AF_LINE_USB_DP 10U
1465
#define AF_STM_SWIO 0U
1466
#define AF_LINE_STM_SWIO 0U
1467
#define AF_STM_SWCLK 0U
1468
#define AF_LINE_STM_SWCLK 0U
1469
#define AF_MOTOR3 1U
1470
#define AF_LINE_MOTOR3 1U
1471
#define AF_I2C1_SCL 4U
1472
#define AF_LINE_I2C1_SCL 4U
1473
#define AF_I2C1_SDA 4U
1474
#define AF_LINE_I2C1_SDA 4U
1475
#define AF_MOTOR4 2U
1476
#define AF_LINE_MOTOR4 2U
1477
#define AF_MOTOR2 1U
1478
#define AF_LINE_MOTOR2 1U
1479
#define AF_NRF_TX 8U
1480
#define AF_LINE_NRF_TX 8U
1481
#define AF_NRF_RX 8U
1482
#define AF_LINE_NRF_RX 8U
1483
#define AF_I2C3_SDA 4U
1484
#define AF_LINE_I2C3_SDA 4U
1485
#define AF_E_TX1 7U
1486
#define AF_LINE_E_TX1 7U
1487
#define AF_E_RX1 7U
1488
#define AF_LINE_E_RX1 7U
1489
#define AF_OSC_IN 0U
1490
#define AF_LINE_OSC_IN 0U
1491
#define AF_OSC_OUT 0U
1492
#define AF_LINE_OSC_OUT 0U
1493
1494
1495
1496
#define BOARD_GROUP_DECLFOREACH(line, group) \
1497
static const ioline_t group ## _ARRAY[] = {group}; \
1498
for (ioline_t i=0, line = group ## _ARRAY[i]; (i < group ## _SIZE) && (line = group ## _ARRAY[i]); i++)
1499
1500
#define BOARD_GROUP_FOREACH(line, group) \
1501
for (ioline_t i=0, line = group ## _ARRAY[i]; (i < group ## _SIZE) && (line = group ## _ARRAY[i]); i++)
1502
1503
1504
#define BOARD_GROUP_DECLFOR(array, index, group) \
1505
static const ioline_t group ## _ARRAY[] = {group}; \
1506
for (ioline_t index=0, *array = (ioline_t *) group ## _ARRAY; index < group ## _SIZE; index++)
1507
1508
#define BOARD_GROUP_FOR(array, index, group) \
1509
for (ioline_t index=0, *array = (ioline_t *) group ## _ARRAY; index < group ## _SIZE; index++)
1510
1511
#if !defined(_FROM_ASM_)
1512
#ifdef __cplusplus
1513
extern
"C"
{
1514
#endif
1515
void
boardInit
(
void
);
1516
#ifdef __cplusplus
1517
}
1518
#endif
1519
#endif
/* _FROM_ASM_ */
1520
boardInit
void boardInit(void)
Board-specific initialization code.
Definition:
board.c:317
sw
airborne
boards
crazyflie
chibios
v2.1
board.h
Generated on Thu Dec 5 2024 13:05:29 for Paparazzi UAS by
1.9.1