Fixed CONFIG_FASTLOOP_PREFERRED_ACC related magic numbers
[betaflight.git] / src / main / target / SPRACINGF3MINI / target.h
blob5272a49030742b0a61518be1b59a46fed6a3d24e
1 /*
2 * This file is part of Cleanflight.
4 * Cleanflight 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, either version 3 of the License, or
7 * (at your option) any later version.
9 * Cleanflight is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with Cleanflight. If not, see <http://www.gnu.org/licenses/>.
18 #pragma once
20 #define TARGET_BOARD_IDENTIFIER "SRFM"
22 #define CONFIG_FASTLOOP_PREFERRED_ACC ACC_NONE
24 // early prototype had slightly different pin mappings.
25 //#define SPRACINGF3MINI_MKII_REVA
27 #define LED0 PB3
29 #define BEEPER PC15
30 #define BEEPER_INVERTED
32 #define USABLE_TIMER_CHANNEL_COUNT 12 // 8 Outputs; PPM; LED Strip; 2 additional PWM pins also on UART3 RX/TX pins.
34 #define EXTI15_10_CALLBACK_HANDLER_COUNT 2 // MPU_INT, SDCardDetect
36 #define USE_EXTI
37 #define MPU_INT_EXTI PC13
38 #define USE_MPU_DATA_READY_SIGNAL
39 #define ENSURE_MPU_DATA_READY_IS_LOW
41 #define USE_MAG_DATA_READY_SIGNAL
42 #define ENSURE_MAG_DATA_READY_IS_HIGH
45 #define GYRO
46 //#define USE_FAKE_GYRO
47 #define USE_GYRO_MPU6500
49 #define ACC
50 //#define USE_FAKE_ACC
51 #define USE_ACC_MPU6500
53 #define ACC_MPU6500_ALIGN CW180_DEG
54 #define GYRO_MPU6500_ALIGN CW180_DEG
56 #define BARO
57 #define USE_BARO_BMP280
59 #define MAG
60 #define USE_MPU9250_MAG // Enables bypass configuration
61 #define USE_MAG_AK8975
62 #define USE_MAG_HMC5883 // External
64 #define MAG_AK8975_ALIGN CW90_DEG_FLIP
66 #define SONAR
68 #define USB_IO
69 #define USB_CABLE_DETECTION
71 #define USB_DETECT_PIN PB5
73 #define USE_VCP
74 #define USE_USART1
75 #define USE_USART2
76 #define USE_USART3
77 #define USE_SOFTSERIAL1
78 #define SERIAL_PORT_COUNT 5
80 #ifndef UART1_GPIO
81 #define UART1_TX_PIN GPIO_Pin_9 // PA9
82 #define UART1_RX_PIN GPIO_Pin_10 // PA10
83 #define UART1_GPIO GPIOA
84 #define UART1_GPIO_AF GPIO_AF_7
85 #define UART1_TX_PINSOURCE GPIO_PinSource9
86 #define UART1_RX_PINSOURCE GPIO_PinSource10
87 #endif
89 #define UART2_TX_PIN GPIO_Pin_14 // PA14 / SWCLK
90 #define UART2_RX_PIN GPIO_Pin_15 // PA15
91 #define UART2_GPIO GPIOA
92 #define UART2_GPIO_AF GPIO_AF_7
93 #define UART2_TX_PINSOURCE GPIO_PinSource14
94 #define UART2_RX_PINSOURCE GPIO_PinSource15
96 #ifndef UART3_GPIO
97 #define UART3_TX_PIN GPIO_Pin_10 // PB10 (AF7)
98 #define UART3_RX_PIN GPIO_Pin_11 // PB11 (AF7)
99 #define UART3_GPIO_AF GPIO_AF_7
100 #define UART3_GPIO GPIOB
101 #define UART3_TX_PINSOURCE GPIO_PinSource10
102 #define UART3_RX_PINSOURCE GPIO_PinSource11
103 #endif
105 #define SOFTSERIAL_1_TIMER TIM2
106 #define SOFTSERIAL_1_TIMER_RX_HARDWARE 9 // PA0 / PAD3
107 #define SOFTSERIAL_1_TIMER_TX_HARDWARE 10 // PA1 / PAD4
109 #define USE_I2C
110 #define I2C_DEVICE (I2CDEV_1) // PB6/SCL, PB7/SDA
112 #define USE_SPI
113 #define USE_SPI_DEVICE_2 // PB12,13,14,15 on AF5
115 #define SPI2_NSS_PIN PB12
116 #define SPI2_SCK_PIN PB13
117 #define SPI2_MISO_PIN PB14
118 #define SPI2_MOSI_PIN PB15
120 #define USE_SDCARD
121 #define USE_SDCARD_SPI2
123 #define SDCARD_DETECT_INVERTED
125 #define SDCARD_DETECT_PIN PC14
126 #define SDCARD_SPI_INSTANCE SPI2
127 #define SDCARD_SPI_CS_PIN SPI2_NSS_PIN
129 // SPI2 is on the APB1 bus whose clock runs at 36MHz. Divide to under 400kHz for init:
130 #define SDCARD_SPI_INITIALIZATION_CLOCK_DIVIDER 128
131 // Divide to under 25MHz for normal operation:
132 #define SDCARD_SPI_FULL_SPEED_CLOCK_DIVIDER 2
134 // Note, this is the same DMA channel as USART1_RX. Luckily we don't use DMA for USART Rx.
135 #define SDCARD_DMA_CHANNEL_TX DMA1_Channel5
136 #define SDCARD_DMA_CHANNEL_TX_COMPLETE_FLAG DMA1_FLAG_TC5
138 // Performance logging for SD card operations:
139 // #define AFATFS_USE_INTROSPECTIVE_LOGGING
141 #define USE_ADC
142 #define BOARD_HAS_VOLTAGE_DIVIDER
145 #define ADC_INSTANCE ADC2
146 #define ADC_DMA_CHANNEL DMA2_Channel1
147 #define ADC_AHB_PERIPHERAL RCC_AHBPeriph_DMA2
149 #define VBAT_ADC_GPIO GPIOA
150 #define VBAT_ADC_GPIO_PIN GPIO_Pin_4
151 #define VBAT_ADC_CHANNEL ADC_Channel_1
153 #define CURRENT_METER_ADC_GPIO GPIOA
154 #define CURRENT_METER_ADC_GPIO_PIN GPIO_Pin_5
155 #define CURRENT_METER_ADC_CHANNEL ADC_Channel_2
157 #define RSSI_ADC_GPIO GPIOB
158 #define RSSI_ADC_GPIO_PIN GPIO_Pin_2
159 #define RSSI_ADC_CHANNEL ADC_Channel_12
161 #define LED_STRIP
162 #define LED_STRIP_TIMER TIM1
164 #define WS2811_GPIO GPIOA
165 #define WS2811_GPIO_AHB_PERIPHERAL RCC_AHBPeriph_GPIOA
166 #define WS2811_GPIO_AF GPIO_AF_6
167 #define WS2811_PIN GPIO_Pin_8
168 #define WS2811_PIN_SOURCE GPIO_PinSource8
169 #define WS2811_TIMER TIM1
170 #define WS2811_TIMER_APB2_PERIPHERAL RCC_APB2Periph_TIM1
171 #define WS2811_DMA_CHANNEL DMA1_Channel2
172 #define WS2811_IRQ DMA1_Channel2_IRQn
173 #define WS2811_DMA_TC_FLAG DMA1_FLAG_TC2
174 #define WS2811_DMA_HANDLER_IDENTIFER DMA1_CH2_HANDLER
177 #define TRANSPONDER
178 #define TRANSPONDER_GPIO GPIOA
179 #define TRANSPONDER_GPIO_AHB_PERIPHERAL RCC_AHBPeriph_GPIOA
180 #define TRANSPONDER_GPIO_AF GPIO_AF_6
181 #define TRANSPONDER_PIN GPIO_Pin_8
182 #define TRANSPONDER_PIN_SOURCE GPIO_PinSource8
183 #define TRANSPONDER_TIMER TIM1
184 #define TRANSPONDER_TIMER_APB2_PERIPHERAL RCC_APB2Periph_TIM1
185 #define TRANSPONDER_DMA_CHANNEL DMA1_Channel2
186 #define TRANSPONDER_IRQ DMA1_Channel2_IRQn
187 #define TRANSPONDER_DMA_TC_FLAG DMA1_FLAG_TC2
188 #define TRANSPONDER_DMA_HANDLER_IDENTIFER DMA1_CH2_HANDLER
190 #define REDUCE_TRANSPONDER_CURRENT_DRAW_WHEN_USB_CABLE_PRESENT
192 #define ENABLE_BLACKBOX_LOGGING_ON_SDCARD_BY_DEFAULT
193 #define DEFAULT_RX_FEATURE FEATURE_RX_PPM
195 #define BUTTONS
196 #define BUTTON_A_PORT GPIOB
197 #define BUTTON_A_PIN Pin_1
198 #define BUTTON_B_PORT GPIOB
199 #define BUTTON_B_PIN Pin_0
201 #define SPEKTRUM_BIND
202 // USART3,
203 #define BIND_PIN PB11
205 #define HARDWARE_BIND_PLUG
206 #define BINDPLUG_PIN PB0
208 #define USE_SERIAL_4WAY_BLHELI_INTERFACE
210 #define TARGET_IO_PORTA 0xffff
211 #define TARGET_IO_PORTB 0xffff
212 #define TARGET_IO_PORTC (BIT(13)|BIT(14)|BIT(15))
213 #define TARGET_IO_PORTF (BIT(0)|BIT(1)|BIT(4))
215 #define USED_TIMERS (TIM_N(1) | TIM_N(2) | TIM_N(3) | TIM_N(4) | TIM_N(15) | TIM_N(16) |TIM_N(17))
217 #define TIMER_APB1_PERIPHERALS (RCC_APB1Periph_TIM2 | RCC_APB1Periph_TIM3 | RCC_APB1Periph_TIM4)
218 #define TIMER_APB2_PERIPHERALS (RCC_APB2Periph_TIM1 | RCC_APB2Periph_TIM15 | RCC_APB2Periph_TIM16 | RCC_APB2Periph_TIM17)
219 #define TIMER_AHB_PERIPHERALS (RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOB)