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/RT - Copyright (C) 2006-2013 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 #ifndef _BOARD_H_
18 #define _BOARD_H_
19 
20 /*
21  * Setup for Pixhawk PX4FMU_2.4 board
22  * Note the MCU used is STM32F427VIT6
23  */
24 
25 /*
26  * Board identifier.
27  */
28 #define BOARD_PX4FMU_v2
29 #define BOARD_NAME "Pixhawk PX4 FMU v 2.4"
30 
31 /*
32  * Board oscillators-related settings.
33  * NOTE: LSE NOT? fitted.
34  */
35 #if !defined(STM32_LSECLK)
36 #define STM32_LSECLK 0 // originally was 32000 ?
37 #endif
38 
39 #if !defined(STM32_HSECLK)
40 #define STM32_HSECLK 24000000
41 #endif
42 
43 
44 /*
45  * Board voltages.
46  * Required for performance limits calculation.
47  */
48 #define STM32_VDD 330
49 
50 /*
51  * MCU type as defined in the ST header file stm32f4xx.h.
52  */
53 #define STM32F407xx
54 
55 /*
56  * I/O ports initial setup, this configuration is established soon after reset
57  * in the initialization code.
58  * Please refer to the STM32 Reference Manual for details.
59  */
60 #define PIN_MODE_INPUT(n) (0U << ((n) * 2U))
61 #define PIN_MODE_OUTPUT(n) (1U << ((n) * 2U))
62 #define PIN_MODE_ALTERNATE(n) (2U << ((n) * 2U))
63 #define PIN_MODE_ANALOG(n) (3U << ((n) * 2U))
64 #define PIN_ODR_LOW(n) (0U << (n))
65 #define PIN_ODR_HIGH(n) (1U << (n))
66 #define PIN_OTYPE_PUSHPULL(n) (0U << (n))
67 #define PIN_OTYPE_OPENDRAIN(n) (1U << (n))
68 #define PIN_OSPEED_2M(n) (0U << ((n) * 2U))
69 #define PIN_OSPEED_25M(n) (1U << ((n) * 2U))
70 #define PIN_OSPEED_50M(n) (2U << ((n) * 2U))
71 #define PIN_OSPEED_100M(n) (3U << ((n) * 2U))
72 #define PIN_PUPDR_FLOATING(n) (0U << ((n) * 2U))
73 #define PIN_PUPDR_PULLUP(n) (1U << ((n) * 2U))
74 #define PIN_PUPDR_PULLDOWN(n) (2U << ((n) * 2U))
75 #define PIN_AFIO_AF(n, v) ((v) << (((n) % 8U) * 4U))
76 
77 /*
78  * Port A setup.
79  *
80  * PA0 - Alternate Push Pull output 50MHz (UART4_TX)
81  * PA1 - Alternate Digital input (UART4_RX)
82  * PA2 - Analog input (BATT VOLTAGE SENS - ADC in)
83  * PA3 - Analog input (BATT CURRENT SENS - ADC in)
84  * PA4 - Analog input (VDD 5V SENS - ADC in)
85  * PA5 - Alternate Push Pull output 50MHz (EXTSPI1_SCK)
86  * PA6 - Alternate Digital input. (EXTSPI1_MISO)
87  * PA7 - Alternate Push Pull output 50MHz (EXTSPI1_MOSI)
88  * PA8 - Digital input (!VDD_5V_PERIPH_EN)
89  * PA9 - Digital input. (USB_VBUS)
90  * PA10 - Alternate Digital input (UART1_Rx)
91  * PA11 - Alternate input (USB_DM)
92  * PA12 - Alternate input (USB_DP)
93  * PA13 - Alternate Digital input (SWDIO)
94  * PA14 - Alternate Digital input (SWCLCK)
95  * PA15 - Digital output (ALARM)
96  */
97 #define VAL_GPIOA_MODER (PIN_MODE_ALTERNATE(0)| \
98  PIN_MODE_ALTERNATE(1) | \
99  PIN_MODE_ANALOG(2) | \
100  PIN_MODE_ANALOG(3) | \
101  PIN_MODE_ANALOG(4) | \
102  PIN_MODE_ALTERNATE(5) | \
103  PIN_MODE_ALTERNATE(6) | \
104  PIN_MODE_ALTERNATE(7) | \
105  PIN_MODE_INPUT(8) | \
106  PIN_MODE_INPUT(9) | \
107  PIN_MODE_ALTERNATE(10) | \
108  PIN_MODE_ALTERNATE(11) | \
109  PIN_MODE_ALTERNATE(12) | \
110  PIN_MODE_ALTERNATE(13) | \
111  PIN_MODE_ALTERNATE(14) | \
112  PIN_MODE_OUTPUT(15))
113 #define VAL_GPIOA_OTYPER (PIN_OTYPE_PUSHPULL(0) | \
114  PIN_OTYPE_PUSHPULL(1) | \
115  PIN_OTYPE_PUSHPULL(2) | \
116  PIN_OTYPE_PUSHPULL(3) | \
117  PIN_OTYPE_PUSHPULL(4) | \
118  PIN_OTYPE_PUSHPULL(5) | \
119  PIN_OTYPE_PUSHPULL(6) | \
120  PIN_OTYPE_PUSHPULL(7) | \
121  PIN_OTYPE_PUSHPULL(8) | \
122  PIN_OTYPE_PUSHPULL(9) | \
123  PIN_OTYPE_PUSHPULL(10) | \
124  PIN_OTYPE_PUSHPULL(11) | \
125  PIN_OTYPE_PUSHPULL(12) | \
126  PIN_OTYPE_PUSHPULL(13) | \
127  PIN_OTYPE_PUSHPULL(14) | \
128  PIN_OTYPE_OPENDRAIN(15))
129 #define VAL_GPIOA_OSPEEDR (PIN_OSPEED_100M(0) | \
130  PIN_OSPEED_100M(1) | \
131  PIN_OSPEED_100M(2) | \
132  PIN_OSPEED_100M(3) | \
133  PIN_OSPEED_100M(4) | \
134  PIN_OSPEED_50M(5) | \
135  PIN_OSPEED_50M(6) | \
136  PIN_OSPEED_50M(7) | \
137  PIN_OSPEED_100M(8) | \
138  PIN_OSPEED_100M(9) | \
139  PIN_OSPEED_100M(10) | \
140  PIN_OSPEED_100M(11) | \
141  PIN_OSPEED_100M(12) | \
142  PIN_OSPEED_100M(13) | \
143  PIN_OSPEED_100M(14) | \
144  PIN_OSPEED_100M(15))
145 #define VAL_GPIOA_PUPDR (PIN_PUPDR_FLOATING(0) | \
146  PIN_PUPDR_FLOATING(1) | \
147  PIN_PUPDR_FLOATING(2) | \
148  PIN_PUPDR_FLOATING(3) | \
149  PIN_PUPDR_FLOATING(4) | \
150  PIN_PUPDR_FLOATING(5) | \
151  PIN_PUPDR_FLOATING(6) | \
152  PIN_PUPDR_FLOATING(7) | \
153  PIN_PUPDR_FLOATING(8) | \
154  PIN_PUPDR_FLOATING(9) | \
155  PIN_PUPDR_FLOATING(10) | \
156  PIN_PUPDR_FLOATING(11) | \
157  PIN_PUPDR_FLOATING(12) | \
158  PIN_PUPDR_FLOATING(13) | \
159  PIN_PUPDR_FLOATING(14) | \
160  PIN_PUPDR_FLOATING(15))
161 #define VAL_GPIOA_ODR (PIN_ODR_HIGH(0) | \
162  PIN_ODR_HIGH(1) | \
163  PIN_ODR_HIGH(2) | \
164  PIN_ODR_HIGH(3) | \
165  PIN_ODR_HIGH(4) | \
166  PIN_ODR_HIGH(5) | \
167  PIN_ODR_HIGH(6) | \
168  PIN_ODR_HIGH(7) | \
169  PIN_ODR_HIGH(8) | \
170  PIN_ODR_HIGH(9) | \
171  PIN_ODR_HIGH(10) | \
172  PIN_ODR_HIGH(11) | \
173  PIN_ODR_HIGH(12) | \
174  PIN_ODR_HIGH(13) | \
175  PIN_ODR_HIGH(14) | \
176  PIN_ODR_HIGH(15))
177 #define VAL_GPIOA_AFRL (PIN_AFIO_AF(0, 8) | \
178  PIN_AFIO_AF(1, 8) | \
179  PIN_AFIO_AF(2, 0) | \
180  PIN_AFIO_AF(3, 0) | \
181  PIN_AFIO_AF(4, 0) | \
182  PIN_AFIO_AF(5, 5) | \
183  PIN_AFIO_AF(6, 5) | \
184  PIN_AFIO_AF(7, 5))
185 #define VAL_GPIOA_AFRH (PIN_AFIO_AF(8, 0) | \
186  PIN_AFIO_AF(9, 0) | \
187  PIN_AFIO_AF(10, 7) | \
188  PIN_AFIO_AF(11, 10) | \
189  PIN_AFIO_AF(12, 10) | \
190  PIN_AFIO_AF(13, 0) | \
191  PIN_AFIO_AF(14, 0) | \
192  PIN_AFIO_AF(15, 0))
193 
194 /*
195  * Port B setup:
196  * PB0 - Digital input (GYRO_DRDY) #
197  * PB1 - Digital input (MAG_DRDY) #
198  * PB2 - Digital input (BOOT) # ?
199  * PB3 - Digital input (JTAG_TDO/SWD) #
200  * PB4 - Digital input (ACCEL_DRDY) #
201  * PB5 - Digital input (!VDD_BRICK_VALID) #
202  * PB6 - Alternate Push Pull output 50MHz (CAN2_TX)
203  * PB7 - Digital input (!VDD_SERVO_VALID)
204  * PB8 - Alternate Open Drain output 50MHz (I2C1_SCL)
205  * PB9 - Alternate Open Drain output 50MHz (I2C1_SDA)
206  * PB10 - Alternate Open Drain output 50MHz (I2C2_SCL)
207  * PB11 - Alternate Open Drain output 50MHz (I2C2_SDA)
208  * PB12 - Alternate Push Pull output 50MHz (CAN2_RX)
209  * PB13 - Alternate Push Pull output 50MHz (FRAM_SPI2_SCK) #
210  * PB14 - Alternate Digital input (FRAM_SPI2_MISO) #
211  * PB15 - Alternate Push Pull output 50MHz (FRAM_SPI2_MOSI) #
212  */
213 #define VAL_GPIOB_MODER (PIN_MODE_INPUT(0) | \
214  PIN_MODE_INPUT(1) | \
215  PIN_MODE_INPUT(2) | \
216  PIN_MODE_ALTERNATE(3) | \
217  PIN_MODE_INPUT(4) | \
218  PIN_MODE_INPUT(5) | \
219  PIN_MODE_ALTERNATE(6) | \
220  PIN_MODE_INPUT(7) | \
221  PIN_MODE_ALTERNATE(8) | \
222  PIN_MODE_ALTERNATE(9) | \
223  PIN_MODE_ALTERNATE(10) | \
224  PIN_MODE_ALTERNATE(11) | \
225  PIN_MODE_ALTERNATE(12) | \
226  PIN_MODE_ALTERNATE(13) | \
227  PIN_MODE_ALTERNATE(14) | \
228  PIN_MODE_ALTERNATE(15))
229 #define VAL_GPIOB_OTYPER (PIN_OTYPE_PUSHPULL(0) | \
230  PIN_OTYPE_PUSHPULL(1) | \
231  PIN_OTYPE_PUSHPULL(2) | \
232  PIN_OTYPE_PUSHPULL(3) | \
233  PIN_OTYPE_PUSHPULL(4) | \
234  PIN_OTYPE_PUSHPULL(5) | \
235  PIN_OTYPE_PUSHPULL(6) | \
236  PIN_OTYPE_PUSHPULL(7) | \
237  PIN_OTYPE_OPENDRAIN(8) | \
238  PIN_OTYPE_OPENDRAIN(9) | \
239  PIN_OTYPE_OPENDRAIN(10) | \
240  PIN_OTYPE_OPENDRAIN(11) | \
241  PIN_OTYPE_PUSHPULL(12) | \
242  PIN_OTYPE_PUSHPULL(13) | \
243  PIN_OTYPE_PUSHPULL(14) | \
244  PIN_OTYPE_PUSHPULL(15))
245 #define VAL_GPIOB_OSPEEDR (PIN_OSPEED_50M(0) | \
246  PIN_OSPEED_50M(1) | \
247  PIN_OSPEED_50M(2) | \
248  PIN_OSPEED_100M(3) | \
249  PIN_OSPEED_50M(4) | \
250  PIN_OSPEED_50M(5) | \
251  PIN_OSPEED_50M(6) | \
252  PIN_OSPEED_50M(7) | \
253  PIN_OSPEED_50M(8) | \
254  PIN_OSPEED_50M(9) | \
255  PIN_OSPEED_50M(10) | \
256  PIN_OSPEED_50M(11) | \
257  PIN_OSPEED_50M(12) | \
258  PIN_OSPEED_50M(13) | \
259  PIN_OSPEED_50M(14) | \
260  PIN_OSPEED_50M(15))
261 #define VAL_GPIOB_PUPDR (PIN_PUPDR_FLOATING(0) | \
262  PIN_PUPDR_FLOATING(1) | \
263  PIN_PUPDR_FLOATING(2) | \
264  PIN_PUPDR_FLOATING(3) | \
265  PIN_PUPDR_FLOATING(4) | \
266  PIN_PUPDR_FLOATING(5) | \
267  PIN_PUPDR_FLOATING(6) | \
268  PIN_PUPDR_FLOATING(7) | \
269  PIN_PUPDR_FLOATING(8) | \
270  PIN_PUPDR_FLOATING(9) | \
271  PIN_PUPDR_FLOATING(10) | \
272  PIN_PUPDR_FLOATING(11) | \
273  PIN_PUPDR_FLOATING(12) | \
274  PIN_PUPDR_FLOATING(13) | \
275  PIN_PUPDR_FLOATING(14) | \
276  PIN_PUPDR_FLOATING(15))
277 #define VAL_GPIOB_ODR (PIN_ODR_HIGH(0) | \
278  PIN_ODR_HIGH(1) | \
279  PIN_ODR_HIGH(2) | \
280  PIN_ODR_HIGH(3) | \
281  PIN_ODR_HIGH(4) | \
282  PIN_ODR_HIGH(5) | \
283  PIN_ODR_HIGH(6) | \
284  PIN_ODR_HIGH(7) | \
285  PIN_ODR_HIGH(8) | \
286  PIN_ODR_HIGH(9) | \
287  PIN_ODR_HIGH(10) | \
288  PIN_ODR_HIGH(11) | \
289  PIN_ODR_HIGH(12) | \
290  PIN_ODR_HIGH(13) | \
291  PIN_ODR_HIGH(14) | \
292  PIN_ODR_HIGH(15))
293 #define VAL_GPIOB_AFRL (PIN_AFIO_AF(0, 0) | \
294  PIN_AFIO_AF(1, 0) | \
295  PIN_AFIO_AF(2, 0) | \
296  PIN_AFIO_AF(3, 0) | \
297  PIN_AFIO_AF(4, 0) | \
298  PIN_AFIO_AF(5, 0) | \
299  PIN_AFIO_AF(6, 9) | \
300  PIN_AFIO_AF(7, 0))
301 #define VAL_GPIOB_AFRH (PIN_AFIO_AF(8, 4) | \
302  PIN_AFIO_AF(9, 4) | \
303  PIN_AFIO_AF(10, 4) | \
304  PIN_AFIO_AF(11, 4) | \
305  PIN_AFIO_AF(12, 9) | \
306  PIN_AFIO_AF(13, 5) | \
307  PIN_AFIO_AF(14, 5) | \
308  PIN_AFIO_AF(15, 5))
309 
310 /*
311  * Port C setup:
312  * PC0 - Digital input (!VBUS_VALID) #
313  * PC1 - Analog input (ADC3) #
314  * PC2 - Push Pull output 50MHz. (!MPU_CS) #
315  * PC3 - Analog input (ADC1) #
316  * PC4 - Analog input (ADC2) #
317  * PC5 - Analog input (PRESSURE_SENS - ADC) #
318  * PC6 - Alternate Push Pull output 50MHz (UART6-TX)
319  * PC7 - Alternate Digital intput (UART6_RX)
320  * PC8 - Alternate pullup 100MHz (SDIO_D0)
321  * PC9 - Alternate pullup 100MHz (SDIO_D1)
322  * PC10 - Alternate pullup 100MHz (SDIO_D2)
323  * PC11 - Alternate pullup 100MHz (SDIO_D3)
324  * PC12 - Alternate floating 100MHz (SDIO_CK)
325  * PC13 - Push Pull output 50MHz. (!GYRO_SS) #
326  * PC14 - Digital input (GPIO_EXT_1)
327  * PC15 - Push Pull output 50MHz. (!ACCEL_MAG_SS)
328  */
329 #define VAL_GPIOC_MODER (PIN_MODE_INPUT(0) |\
330  PIN_MODE_INPUT(1) | \
331  PIN_MODE_OUTPUT(2) | \
332  PIN_MODE_INPUT(3) | \
333  PIN_MODE_INPUT(4) | \
334  PIN_MODE_INPUT(5) | \
335  PIN_MODE_ALTERNATE(6) | \
336  PIN_MODE_ALTERNATE(7) | \
337  PIN_MODE_ALTERNATE(8) | \
338  PIN_MODE_ALTERNATE(9) | \
339  PIN_MODE_ALTERNATE(10) | \
340  PIN_MODE_ALTERNATE(11) | \
341  PIN_MODE_ALTERNATE(12) | \
342  PIN_MODE_OUTPUT(13) | \
343  PIN_MODE_INPUT(14) | \
344  PIN_MODE_OUTPUT(15))
345 #define VAL_GPIOC_OTYPER (PIN_OTYPE_PUSHPULL(0) |\
346  PIN_OTYPE_PUSHPULL(1) | \
347  PIN_OTYPE_PUSHPULL(2) | \
348  PIN_OTYPE_PUSHPULL(3) | \
349  PIN_OTYPE_PUSHPULL(4) | \
350  PIN_OTYPE_PUSHPULL(5) | \
351  PIN_OTYPE_PUSHPULL(6) | \
352  PIN_OTYPE_PUSHPULL(7) | \
353  PIN_OTYPE_PUSHPULL(8) | \
354  PIN_OTYPE_PUSHPULL(9) | \
355  PIN_OTYPE_PUSHPULL(10) | \
356  PIN_OTYPE_PUSHPULL(11) | \
357  PIN_OTYPE_PUSHPULL(12) | \
358  PIN_OTYPE_PUSHPULL(13) | \
359  PIN_OTYPE_PUSHPULL(14) | \
360  PIN_OTYPE_PUSHPULL(15))
361 #define VAL_GPIOC_OSPEEDR (PIN_OSPEED_50M(0) |\
362  PIN_OSPEED_50M(1) | \
363  PIN_OSPEED_50M(2) | \
364  PIN_OSPEED_50M(3) | \
365  PIN_OSPEED_50M(4) | \
366  PIN_OSPEED_50M(5) | \
367  PIN_OSPEED_50M(6) | \
368  PIN_OSPEED_50M(7) | \
369  PIN_OSPEED_50M(8) | \
370  PIN_OSPEED_50M(9) | \
371  PIN_OSPEED_50M(10) | \
372  PIN_OSPEED_50M(11) | \
373  PIN_OSPEED_50M(12) | \
374  PIN_OSPEED_2M(13) | \
375  PIN_OSPEED_50M(14) | \
376  PIN_OSPEED_2M(15))
377 #define VAL_GPIOC_PUPDR (PIN_PUPDR_FLOATING(0) |\
378  PIN_PUPDR_FLOATING(1) | \
379  PIN_PUPDR_FLOATING(2) | \
380  PIN_PUPDR_FLOATING(3) | \
381  PIN_PUPDR_FLOATING(4) | \
382  PIN_PUPDR_FLOATING(5) | \
383  PIN_PUPDR_FLOATING(6) | \
384  PIN_PUPDR_FLOATING(7) | \
385  PIN_PUPDR_PULLUP(8) | \
386  PIN_PUPDR_PULLUP(9) | \
387  PIN_PUPDR_PULLUP(10) | \
388  PIN_PUPDR_PULLUP(11) | \
389  PIN_PUPDR_FLOATING(12) | \
390  PIN_PUPDR_FLOATING(13) | \
391  PIN_PUPDR_FLOATING(14) | \
392  PIN_PUPDR_FLOATING(15))
393 #define VAL_GPIOC_ODR (PIN_ODR_HIGH(0) | \
394  PIN_ODR_HIGH(1) | \
395  PIN_ODR_HIGH(2) | \
396  PIN_ODR_HIGH(3) | \
397  PIN_ODR_HIGH(4) | \
398  PIN_ODR_HIGH(5) | \
399  PIN_ODR_HIGH(6) | \
400  PIN_ODR_HIGH(7) | \
401  PIN_ODR_HIGH(8) | \
402  PIN_ODR_HIGH(9) | \
403  PIN_ODR_HIGH(10) | \
404  PIN_ODR_HIGH(11) | \
405  PIN_ODR_HIGH(12) | \
406  PIN_ODR_HIGH(13) | \
407  PIN_ODR_HIGH(14) | \
408  PIN_ODR_HIGH(15))
409 #define VAL_GPIOC_AFRL (PIN_AFIO_AF(0, 0) |\
410  PIN_AFIO_AF(1, 0) | \
411  PIN_AFIO_AF(2, 0) | \
412  PIN_AFIO_AF(3, 0) | \
413  PIN_AFIO_AF(4, 0) | \
414  PIN_AFIO_AF(5, 0) | \
415  PIN_AFIO_AF(6, 8) | \
416  PIN_AFIO_AF(7, 8))
417 #define VAL_GPIOC_AFRH (PIN_AFIO_AF(8, 12) | \
418  PIN_AFIO_AF(9, 12) | \
419  PIN_AFIO_AF(10, 12) | \
420  PIN_AFIO_AF(11, 12) | \
421  PIN_AFIO_AF(12, 12) | \
422  PIN_AFIO_AF(13, 0) | \
423  PIN_AFIO_AF(14, 0) | \
424  PIN_AFIO_AF(15, 0))
425 
426 /*
427  * Port D setup:
428  * PD0 - CAN1_RX.
429  * PD1 - CAN1_TX
430  * PD2 - SDIO_CMD
431  * PD3 - UART2_CTS
432  * PD4 - UART2_RTS
433  * PD5 - UART2_TX
434  * PD6 - UART2_RX
435  * PD7 - !BARO_CS
436  * PD8 - UART3_TX
437  * PD9 - UART3_RX
438  * PD10 - !FRAM_CS
439  * PD11 - UART3_CTS
440  * PD12 - UART3_RTS
441  * PD13 - SERVO_5
442  * PD14 - SERVO_6
443  * PD15 - MPU_DRDY
444  */
445 #define VAL_GPIOD_MODER (PIN_MODE_ALTERNATE(0) | \
446  PIN_MODE_ALTERNATE(1) | \
447  PIN_MODE_ALTERNATE(2) | \
448  PIN_MODE_ALTERNATE(3) | \
449  PIN_MODE_ALTERNATE(4) | \
450  PIN_MODE_ALTERNATE(5) | \
451  PIN_MODE_ALTERNATE(6) | \
452  PIN_MODE_OUTPUT(7) | \
453  PIN_MODE_ALTERNATE(8) | \
454  PIN_MODE_ALTERNATE(9) | \
455  PIN_MODE_OUTPUT(10) | \
456  PIN_MODE_ALTERNATE(11) | \
457  PIN_MODE_ALTERNATE(12) | \
458  PIN_MODE_INPUT(13) | \
459  PIN_MODE_INPUT(14) | \
460  PIN_MODE_INPUT(15))
461 #define VAL_GPIOD_OTYPER (PIN_OTYPE_PUSHPULL(0) | \
462  PIN_OTYPE_PUSHPULL(1) | \
463  PIN_OTYPE_PUSHPULL(2) | \
464  PIN_OTYPE_PUSHPULL(3) | \
465  PIN_OTYPE_PUSHPULL(4) | \
466  PIN_OTYPE_PUSHPULL(5) |\
467  PIN_OTYPE_PUSHPULL(6) | \
468  PIN_OTYPE_PUSHPULL(7) | \
469  PIN_OTYPE_PUSHPULL(8) | \
470  PIN_OTYPE_PUSHPULL(9) | \
471  PIN_OTYPE_PUSHPULL(10) | \
472  PIN_OTYPE_PUSHPULL(11) | \
473  PIN_OTYPE_PUSHPULL(12) | \
474  PIN_OTYPE_PUSHPULL(13) | \
475  PIN_OTYPE_PUSHPULL(14) | \
476  PIN_OTYPE_PUSHPULL(15))
477 #define VAL_GPIOD_OSPEEDR (PIN_OSPEED_100M(0) | \
478  PIN_OSPEED_100M(1) | \
479  PIN_OSPEED_100M(2) | \
480  PIN_OSPEED_100M(3) | \
481  PIN_OSPEED_100M(4) | \
482  PIN_OSPEED_100M(5) | \
483  PIN_OSPEED_100M(6) | \
484  PIN_OSPEED_2M(7) | \
485  PIN_OSPEED_100M(8) | \
486  PIN_OSPEED_100M(9) | \
487  PIN_OSPEED_100M(10) | \
488  PIN_OSPEED_100M(11) | \
489  PIN_OSPEED_100M(12) | \
490  PIN_OSPEED_100M(13) | \
491  PIN_OSPEED_100M(14) | \
492  PIN_OSPEED_100M(15))
493 #define VAL_GPIOD_PUPDR (PIN_PUPDR_FLOATING(0) | \
494  PIN_PUPDR_FLOATING(1) | \
495  PIN_PUPDR_FLOATING(2) | \
496  PIN_PUPDR_FLOATING(3) | \
497  PIN_PUPDR_FLOATING(4) | \
498  PIN_PUPDR_FLOATING(5) |\
499  PIN_PUPDR_FLOATING(6) | \
500  PIN_PUPDR_FLOATING(7) | \
501  PIN_PUPDR_FLOATING(8) | \
502  PIN_PUPDR_FLOATING(9) | \
503  PIN_PUPDR_FLOATING(10) | \
504  PIN_PUPDR_FLOATING(11) | \
505  PIN_PUPDR_FLOATING(12) | \
506  PIN_PUPDR_FLOATING(13) | \
507  PIN_PUPDR_FLOATING(14) | \
508  PIN_PUPDR_FLOATING(15))
509 #define VAL_GPIOD_ODR (PIN_ODR_HIGH(0) | \
510  PIN_ODR_HIGH(1) | \
511  PIN_ODR_HIGH(2) | \
512  PIN_ODR_HIGH(3) | \
513  PIN_ODR_HIGH(4) | \
514  PIN_ODR_HIGH(5) | \
515  PIN_ODR_HIGH(6) | \
516  PIN_ODR_HIGH(7) | \
517  PIN_ODR_HIGH(8) | \
518  PIN_ODR_HIGH(9) | \
519  PIN_ODR_HIGH(10) | \
520  PIN_ODR_HIGH(11) | \
521  PIN_ODR_HIGH(12) | \
522  PIN_ODR_HIGH(13) | \
523  PIN_ODR_HIGH(14) | \
524  PIN_ODR_HIGH(15))
525 #define VAL_GPIOD_AFRL (PIN_AFIO_AF(0, 9) | \
526  PIN_AFIO_AF(1, 9) | \
527  PIN_AFIO_AF(2, 12) | \
528  PIN_AFIO_AF(3, 7) | \
529  PIN_AFIO_AF(4, 7) | \
530  PIN_AFIO_AF(5, 7) | \
531  PIN_AFIO_AF(6, 7) | \
532  PIN_AFIO_AF(7, 0))
533 #define VAL_GPIOD_AFRH (PIN_AFIO_AF(8, 7) | \
534  PIN_AFIO_AF(9, 7) | \
535  PIN_AFIO_AF(10, 0) | \
536  PIN_AFIO_AF(11, 7) | \
537  PIN_AFIO_AF(12, 7) | \
538  PIN_AFIO_AF(13, 0) | \
539  PIN_AFIO_AF(14, 0) | \
540  PIN_AFIO_AF(15, 0))
541 
542 /*
543  * Port E setup:
544  * PE0 - UART8_RX
545  * PE1 - UART8_TX
546  * PE2 - SPI4_EXT_SCK
547  * PE3 - VDD_3V3_SENSOR_EN
548  * PE4 - !SPI4_EXT_NSS
549  * PE5 - SPI4_EXT_MISO
550  * PE6 - SPI4_EXT_MOSI
551  * PE7 - UART7_RX
552  * PE8 - UART7_TX
553  * PE9 - SERVO_CH4
554  * PE10 - !VDD_HIPOWER_OC
555  * PE11 - SERVO_CH3
556  * PE12 - LED_AMBER
557  * PE13 - SERVO_CH2
558  * PE14 - SERVO_CH1
559  * PE15 - !VDD_5V_PERIPH_OC
560  */
561 #define VAL_GPIOE_MODER (PIN_MODE_ALTERNATE(0) | \
562  PIN_MODE_ALTERNATE(1) | \
563  PIN_MODE_ALTERNATE(2) | \
564  PIN_MODE_OUTPUT(3) | \
565  PIN_MODE_ALTERNATE(4) | \
566  PIN_MODE_ALTERNATE(5) | \
567  PIN_MODE_ALTERNATE(6) | \
568  PIN_MODE_ALTERNATE(7) | \
569  PIN_MODE_ALTERNATE(8) | \
570  PIN_MODE_INPUT(9) | \
571  PIN_MODE_INPUT(10) | \
572  PIN_MODE_INPUT(11) | \
573  PIN_MODE_OUTPUT(12) | \
574  PIN_MODE_INPUT(13) | \
575  PIN_MODE_INPUT(14) | \
576  PIN_MODE_INPUT(15))
577 #define VAL_GPIOE_OTYPER (PIN_OTYPE_PUSHPULL(0) | \
578  PIN_OTYPE_PUSHPULL(1) | \
579  PIN_OTYPE_PUSHPULL(2) | \
580  PIN_OTYPE_PUSHPULL(3) | \
581  PIN_OTYPE_PUSHPULL(4) | \
582  PIN_OTYPE_PUSHPULL(5) | \
583  PIN_OTYPE_PUSHPULL(6) | \
584  PIN_OTYPE_PUSHPULL(7) | \
585  PIN_OTYPE_PUSHPULL(8) | \
586  PIN_OTYPE_PUSHPULL(9) | \
587  PIN_OTYPE_PUSHPULL(10) | \
588  PIN_OTYPE_PUSHPULL(11) | \
589  PIN_OTYPE_OPENDRAIN(12) | \
590  PIN_OTYPE_PUSHPULL(13) | \
591  PIN_OTYPE_PUSHPULL(14) | \
592  PIN_OTYPE_PUSHPULL(15))
593 #define VAL_GPIOE_OSPEEDR (PIN_OSPEED_100M(0) | \
594  PIN_OSPEED_100M(1) | \
595  PIN_OSPEED_50M(2) | \
596  PIN_OSPEED_100M(3) | \
597  PIN_OSPEED_50M(4) | \
598  PIN_OSPEED_50M(5) | \
599  PIN_OSPEED_50M(6) | \
600  PIN_OSPEED_100M(7) | \
601  PIN_OSPEED_100M(8) | \
602  PIN_OSPEED_100M(9) | \
603  PIN_OSPEED_100M(10) | \
604  PIN_OSPEED_100M(11) | \
605  PIN_OSPEED_100M(12) | \
606  PIN_OSPEED_100M(13) | \
607  PIN_OSPEED_100M(14) | \
608  PIN_OSPEED_100M(15))
609 #define VAL_GPIOE_PUPDR (PIN_PUPDR_FLOATING(0) | \
610  PIN_PUPDR_FLOATING(1) | \
611  PIN_PUPDR_FLOATING(2) | \
612  PIN_PUPDR_FLOATING(3) | \
613  PIN_PUPDR_FLOATING(4) | \
614  PIN_PUPDR_FLOATING(5) | \
615  PIN_PUPDR_FLOATING(6) | \
616  PIN_PUPDR_FLOATING(7) | \
617  PIN_PUPDR_FLOATING(8) | \
618  PIN_PUPDR_FLOATING(9) | \
619  PIN_PUPDR_FLOATING(10) | \
620  PIN_PUPDR_FLOATING(11) | \
621  PIN_PUPDR_FLOATING(12) | \
622  PIN_PUPDR_FLOATING(13) | \
623  PIN_PUPDR_FLOATING(14) | \
624  PIN_PUPDR_FLOATING(15))
625 #define VAL_GPIOE_ODR (PIN_ODR_HIGH(0) | \
626  PIN_ODR_HIGH(1) | \
627  PIN_ODR_HIGH(2) | \
628  PIN_ODR_HIGH(3) | \
629  PIN_ODR_HIGH(4) | \
630  PIN_ODR_HIGH(5) | \
631  PIN_ODR_HIGH(6) | \
632  PIN_ODR_HIGH(7) | \
633  PIN_ODR_HIGH(8) | \
634  PIN_ODR_HIGH(9) | \
635  PIN_ODR_HIGH(10) | \
636  PIN_ODR_HIGH(11) | \
637  PIN_ODR_HIGH(12) | \
638  PIN_ODR_HIGH(13) | \
639  PIN_ODR_HIGH(14) | \
640  PIN_ODR_HIGH(15))
641 #define VAL_GPIOE_AFRL (PIN_AFIO_AF(0, 8) | \
642  PIN_AFIO_AF(1, 8) | \
643  PIN_AFIO_AF(2, 5) | \
644  PIN_AFIO_AF(3, 0) | \
645  PIN_AFIO_AF(4, 5) | \
646  PIN_AFIO_AF(5, 5) | \
647  PIN_AFIO_AF(6, 5) | \
648  PIN_AFIO_AF(7, 8))
649 #define VAL_GPIOE_AFRH (PIN_AFIO_AF(8, 8) | \
650  PIN_AFIO_AF(9, 0) | \
651  PIN_AFIO_AF(10, 0) | \
652  PIN_AFIO_AF(11, 0) | \
653  PIN_AFIO_AF(12, 0) | \
654  PIN_AFIO_AF(13, 0) | \
655  PIN_AFIO_AF(14, 0) | \
656  PIN_AFIO_AF(15, 0))
657 
658 /*
659  * GPIOF setup:
660  *
661 */
662 #define VAL_GPIOF_MODER 0x00000000
663 #define VAL_GPIOF_OTYPER 0x00000000
664 #define VAL_GPIOF_OSPEEDR 0x00000000
665 #define VAL_GPIOF_PUPDR 0x55555555 // all pullup
666 #define VAL_GPIOF_ODR 0xFFFFFFFF
667 #define VAL_GPIOF_AFRL 0x00000000
668 #define VAL_GPIOF_AFRH 0x00000000
669 
670 /*
671  * GPIOG setup:
672  *
673 */
674 #define VAL_GPIOG_MODER 0x00000000
675 #define VAL_GPIOG_OTYPER 0x00000000
676 #define VAL_GPIOG_OSPEEDR 0x00000000
677 #define VAL_GPIOG_PUPDR 0x55555555 // all pullup
678 #define VAL_GPIOG_ODR 0xFFFFFFFF
679 #define VAL_GPIOG_AFRL 0x00000000
680 #define VAL_GPIOG_AFRH 0x00000000
681 /*
682  * GPIOH setup:
683  *
684 */
685 #define VAL_GPIOH_MODER 0x00000000
686 #define VAL_GPIOH_OTYPER 0x00000000
687 #define VAL_GPIOH_OSPEEDR 0x00000000
688 #define VAL_GPIOH_PUPDR 0x55555555 // all pullup
689 #define VAL_GPIOH_ODR 0xFFFFFFFF
690 #define VAL_GPIOH_AFRL 0x00000000
691 #define VAL_GPIOH_AFRH 0x00000000
692 
693 /*
694  * GPIOI setup:
695  *
696 */
697 #define VAL_GPIOI_MODER 0x00000000
698 #define VAL_GPIOI_OTYPER 0x00000000
699 #define VAL_GPIOI_OSPEEDR 0x00000000
700 #define VAL_GPIOI_PUPDR 0x55555555 // all pullup
701 #define VAL_GPIOI_ODR 0xFFFFFFFF
702 #define VAL_GPIOI_AFRL 0x00000000
703 #define VAL_GPIOI_AFRH 0x00000000
704 
705 
706 
707 /*
708  * Concat macro
709  */
710 #define _CONCAT_BOARD_PARAM(_s1, _s2) _s1 ## _s2
711 #define CONCAT_BOARD_PARAM(_s1, _s2) _CONCAT_BOARD_PARAM(_s1, _s2)
712 
713 /*
714  * Onboard LEDs
715  */
716 /* red, on PE12 */
717 #ifndef USE_LED_1
718 #define USE_LED_1 1
719 #endif
720 #define LED_1_GPIO GPIOE
721 #define LED_1_GPIO_PIN GPIO12
722 #define LED_1_GPIO_ON gpio_clear
723 #define LED_1_GPIO_OFF gpio_set
724 #define LED_1_AFIO_REMAP ((void)0)
725 
726 /*
727  * ADCs TODO
728  */
729 // AUX 1
730 #if USE_ADC_1
731 #define AD1_1_CHANNEL ADC_CHANNEL_IN9
732 #define ADC_1 AD1_1
733 #define ADC_1_GPIO_PORT GPIOB
734 #define ADC_1_GPIO_PIN GPIO1
735 #endif
736 
737 // AUX 2
738 #if USE_ADC_2
739 #define AD1_2_CHANNEL ADC_CHANNEL_IN15
740 #define ADC_2 AD1_2
741 #define ADC_2_GPIO_PORT GPIOC
742 #define ADC_2_GPIO_PIN GPIO5
743 #endif
744 
745 // AUX 3
746 #if USE_ADC_3
747 #define AD1_3_CHANNEL ADC_CHANNEL_IN14
748 #define ADC_3 AD1_3
749 #define ADC_3_GPIO_PORT GPIOC
750 #define ADC_3_GPIO_PIN GPIO4
751 #endif
752 
753 // Internal ADC for battery enabled by default
754 #ifndef USE_ADC_4
755 #define USE_ADC_4 1
756 #endif
757 #if USE_ADC_4
758 #define AD1_4_CHANNEL ADC_CHANNEL_IN4
759 #define ADC_4 AD1_4
760 #define ADC_4_GPIO_PORT GPIOA
761 #define ADC_4_GPIO_PIN GPIO4
762 #endif
763 
764 /* allow to define ADC_CHANNEL_VSUPPLY in the airframe file*/
765 #ifndef ADC_CHANNEL_VSUPPLY
766 #define ADC_CHANNEL_VSUPPLY ADC_4
767 #endif
768 
769 #define DefaultVoltageOfAdc(adc) (0.006185*adc)
770 
771 /*
772  * PWM TIM defines
773  * enable TIM2 and TIM3 by default
774  */
775 #ifndef USE_PWM_TIM2
776 #define USE_PWM_TIM2 1
777 #endif
778 
779 #ifndef USE_PWM_TIM3
780 #define USE_PWM_TIM3 1
781 #endif
782 
783 /*
784  * PWM defines TODO
785  */
786 #ifndef USE_PWM0
787 #define USE_PWM0 1
788 #endif
789 #if USE_PWM0
790 #define PWM_SERVO_0 0
791 #define PWM_SERVO_0_GPIO GPIOB
792 #define PWM_SERVO_0_PIN GPIO0
793 #define PWM_SERVO_0_AF GPIO_AF2
794 #define PWM_SERVO_0_DRIVER PWMD3
795 #define PWM_SERVO_0_CHANNEL 2
796 #define PWM_SERVO_0_CONF pwmcfg3
797 #endif
798 
799 #ifndef USE_PWM1
800 #define USE_PWM1 1
801 #endif
802 #if USE_PWM1
803 #define PWM_SERVO_1 1
804 #define PWM_SERVO_1_GPIO GPIOA
805 #define PWM_SERVO_1_PIN GPIO2
806 #define PWM_SERVO_1_AF GPIO_AF1
807 #define PWM_SERVO_1_DRIVER PWMD2
808 #define PWM_SERVO_1_CHANNEL 2
809 #define PWM_SERVO_1_CONF pwmcfg2
810 #endif
811 
812 #ifndef USE_PWM2
813 #define USE_PWM2 1
814 #endif
815 #if USE_PWM2
816 #define PWM_SERVO_2 2
817 #define PWM_SERVO_2_GPIO GPIOB
818 #define PWM_SERVO_2_PIN GPIO5
819 #define PWM_SERVO_2_AF GPIO_AF2
820 #define PWM_SERVO_2_DRIVER PWMD3
821 #define PWM_SERVO_2_CHANNEL 1
822 #define PWM_SERVO_2_CONF pwmcfg3
823 #endif
824 
825 #ifndef USE_PWM3
826 #define USE_PWM3 1
827 #endif
828 #if USE_PWM3
829 #define PWM_SERVO_3 3
830 #define PWM_SERVO_3_GPIO GPIOB
831 #define PWM_SERVO_3_PIN GPIO4
832 #define PWM_SERVO_3_AF GPIO_AF2
833 #define PWM_SERVO_3_DRIVER PWMD3
834 #define PWM_SERVO_3_CHANNEL 0
835 #define PWM_SERVO_3_CONF pwmcfg3
836 #endif
837 
838 #ifndef USE_PWM4
839 #define USE_PWM4 1
840 #endif
841 #if USE_PWM4
842 #define PWM_SERVO_4 4
843 #define PWM_SERVO_4_GPIO GPIOB
844 #define PWM_SERVO_4_PIN GPIO3
845 #define PWM_SERVO_4_AF GPIO_AF1
846 #define PWM_SERVO_4_DRIVER PWMD2
847 #define PWM_SERVO_4_CHANNEL 1
848 #define PWM_SERVO_4_CONF pwmcfg2
849 #endif
850 
851 #ifndef USE_PWM5
852 #define USE_PWM5 1
853 #endif
854 #if USE_PWM5
855 #define PWM_SERVO_5 5
856 #define PWM_SERVO_5_GPIO GPIOA
857 #define PWM_SERVO_5_PIN GPIO15
858 #define PWM_SERVO_5_AF GPIO_AF1
859 #define PWM_SERVO_5_DRIVER PWMD2
860 #define PWM_SERVO_5_CHANNEL 0
861 #define PWM_SERVO_5_CONF pwmcfg2
862 #endif
863 
864 #if USE_PWM6
865 #define PWM_SERVO_6 6
866 #define PWM_SERVO_6_GPIO GPIOB
867 #define PWM_SERVO_6_PIN GPIO1
868 #define PWM_SERVO_6_AF GPIO_AF2
869 #define PWM_SERVO_6_DRIVER PWMD3
870 #define PWM_SERVO_6_CHANNEL 3
871 #define PWM_SERVO_6_CONF pwmcfg3
872 #endif
873 
877 #define RC_PPM_TICKS_PER_USEC 2
878 #define PPM_TIMER_FREQUENCY 2000000
879 #define PPM_CHANNEL ICU_CHANNEL_1
880 #define PPM_TIMER ICUD1
881 
882 /*
883  * PWM input TODO
884  */
885 // PWM_INPUT 1 on PA8 (also PPM IN)
886 #define PWM_INPUT1_ICU ICUD1
887 #define PWM_INPUT1_CHANNEL ICU_CHANNEL_1
888 // PPM in (aka PA8) is used: not compatible with PPM RC receiver
889 #define PWM_INPUT1_GPIO_PORT GPIOA
890 #define PWM_INPUT1_GPIO_PIN GPIO8
891 #define PWM_INPUT1_GPIO_AF GPIO_AF1
892 
893 // PWM_INPUT 2 on PA3 (also SERVO 1)
894 #if (USE_PWM1 && USE_PWM_INPUT2)
895 #error "PW1 and PWM_INPUT2 are not compatible"
896 #endif
897 #define PWM_INPUT2_ICU ICUD2
898 #define PWM_INPUT2_CHANNEL ICU_CHANNEL_1
899 #define PWM_INPUT2_GPIO_PORT GPIOA
900 #define PWM_INPUT2_GPIO_PIN GPIO2
901 #define PWM_INPUT2_GPIO_AF GPIO_AF3
902 
903 
907 #ifndef I2C1_CLOCK_SPEED
908 #define I2C1_CLOCK_SPEED 400000
909 #endif
910 #if I2C1_CLOCK_SPEED == 400000
911 #define I2C1_DUTY_CYCLE FAST_DUTY_CYCLE_2
912 #elif I2C1_CLOCK_SPEED == 100000
913 #define I2C1_DUTY_CYCLE STD_DUTY_CYCLE
914 #else
915 #error Invalid I2C1 clock speed
916 #endif
917 #define I2C1_CFG_DEF { \
918  OPMODE_I2C, \
919  I2C1_CLOCK_SPEED, \
920  I2C1_DUTY_CYCLE, \
921  }
922 
923 #ifndef I2C2_CLOCK_SPEED
924 #define I2C2_CLOCK_SPEED 400000
925 #endif
926 #if I2C2_CLOCK_SPEED == 400000
927 #define I2C2_DUTY_CYCLE FAST_DUTY_CYCLE_2
928 #elif I2C2_CLOCK_SPEED == 100000
929 #define I2C2_DUTY_CYCLE STD_DUTY_CYCLE
930 #else
931 #error Invalid I2C2 clock speed
932 #endif
933 #define I2C2_CFG_DEF { \
934  OPMODE_I2C, \
935  I2C2_CLOCK_SPEED, \
936  I2C2_DUTY_CYCLE, \
937  }
938 
946 // SPI1_SLAVE0 -> slave select pin for the L3GD20 (gyro)
947 #define SPI_SELECT_SLAVE0_PORT GPIOC
948 #define SPI_SELECT_SLAVE0_PIN GPIO13
949 // SPI1_SLAVE1 -> slave select pin for the LSM303D (accel/mag)
950 #define SPI_SELECT_SLAVE1_PORT GPIOC
951 #define SPI_SELECT_SLAVE1_PIN GPIO15
952 // SPI1_SLAVE3 -> slave select pin for the MS5611 baro
953 #define SPI_SELECT_SLAVE3_PORT GPIOD
954 #define SPI_SELECT_SLAVE3_PIN GPIO7
955 
962 #ifndef USE_BARO_BOARD
963 #define USE_BARO_BOARD 1
964 #endif
965 
970 #define GPIOA_OTG_FS_VBUS 9
971 
972 #define GPIOD_SDIO_CMD 2
973 #define GPIOC_SDIO_D0 8
974 #define GPIOC_SDIO_D1 9
975 #define GPIOC_SDIO_D2 10
976 #define GPIOC_SDIO_D3 11
977 #define GPIOC_SDIO_CK 12
978 
979 /*
980  * Actuators for fixedwing
981  */
982  /* Default actuators driver */
983 #define DEFAULT_ACTUATORS "modules/actuators/actuators_pwm.h"
984 #define ActuatorDefaultSet(_x,_y) ActuatorPwmSet(_x,_y)
985 #define ActuatorsDefaultInit() ActuatorsPwmInit()
986 #define ActuatorsDefaultCommit() ActuatorsPwmCommit()
987 
988 #if !defined(_FROM_ASM_)
989 #ifdef __cplusplus
990 extern "C" {
991 #endif
992  void boardInit(void);
993 #ifdef __cplusplus
994 }
995 #endif
996 #endif /* _FROM_ASM_ */
997 
998 #endif /* _BOARD_H_ */
void boardInit(void)
Board-specific initialization code.
Definition: board.c:317