-
Notifications
You must be signed in to change notification settings - Fork 17.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
AP_HAL_ChibiOS:add board support for CrazyF405
- Loading branch information
1 parent
4d31a73
commit 5cf1dad
Showing
6 changed files
with
254 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
# CrazyF405HD ELRS 1-2SAIO Flight Controller | ||
|
||
The CrazyF405HD ELRS 1-2S AIO is a flight controller produced by [Happymodel](https://www.happymodel.cn/index.php/2023/05/26/crazyf405hd-elrs-1-2s-aio-fc-built-in-uart-elrs-receiver-and-12a-blheli_s-esc/.) | ||
|
||
## Features | ||
|
||
- MCU: STM32F405RGT6, 168MHz | ||
- Gyro: BMI270 (SPI) | ||
- 1Mb Onboard Flash | ||
- BEC output: 5V, 2A@4V | ||
- Barometer: BMP280 | ||
- 3 UARTS: (UART1, UART2 ,UART6) | ||
- 5 PWM outputs (4 motor outputs used internally for integrated 4-in-1 ESC and 1 integrated LED) | ||
- Integrated 4-in-1 BlueJay ESC | ||
- Firmware target: BetaflightF4 | ||
|
||
## Pinout | ||
|
||
![CrazyF405HD ELRS 1-2S AIO Board](CrazyF405HD_pinout.jpg "CrazyF405HD ELRS 1-2S AIO") | ||
|
||
## UART Mapping | ||
|
||
The UARTs are marked Rn and Tn in the above pinouts. The Rn pin is the | ||
receive pin for UARTn. The Tn pin is the transmit pin for UARTn. | ||
|Name|Pin|Function| | ||
|:-|:-|:-| | ||
|SERIAL0|COMPUTER|USB| | ||
|SERIAL1|RX1/TX1|UART1 (Display Port,DMA-enabled)| | ||
|SERIAL2|TX2/RX2|UART2 (RCIN,ELRS, internal) | ||
|SERIAL5|RX6|UART6 (USER,DMA-disabled)| | ||
|
||
## RC Input | ||
|
||
RC input is configured on the on-board ELRS on UART2 or through (UART2_RX/UART2_TX) pins. It supports all serial RC protocols. | ||
To disable the onboard ELRS module and use an external RC on TX2/RX2, desolder the RX/TX pads of the onboard ELRS receiver as shown in the image.<br> | ||
<center> | ||
<img src="CrazyF405_external_elrs.jpg" alt="CrazyF405HD ELRS Pinout" title="CrazyF405HD ELRS 1-2S AIO" style="width:50%;"> | ||
</center> | ||
|
||
## OSD Support | ||
The CrazyF405HDAIO is optimized for Digital HD FPV and does not require the analog OSD chip (MAX7456); OSD data is transmitted via MSP to the digital VTX. | ||
|
||
## PWM Output | ||
|
||
The Carzyf405HD AIO has 4 PWM outputs internally connected to its 4-in-1 ESC. The pads for motor output are M1 to M4 on the board. All 4 outputs support DShot, as well as all PWM types. The default configuration is for DShot using the already installed BlueJay firmware. | ||
|
||
|
||
## Battery Monitoring | ||
|
||
The board has a builtin voltage sensor and a current sensor input tied to its 4 in 1 ESC current sensor. The voltage sensor can handle up to 2S | ||
LiPo/Li-Hv batteries. | ||
|
||
The correct battery setting parameters are: | ||
|
||
- BATT_MONITOR 4 | ||
- BATT_VOLT_PIN 12 | ||
- BATT_VOLT_MULT 10.9 | ||
- BATT_CURR_PIN 13 | ||
- BATT_CURR_MULT 50 | ||
|
||
These are set by default in the firmware and shouldn't need to be adjusted | ||
|
||
## Compass | ||
|
||
The BETAFPV F405 AIO does not have a builtin compass. | ||
|
||
|
||
## Loading Firmware | ||
|
||
Initial firmware load can be done with DFU by plugging in USB with the | ||
bootloader button pressed. Then you should load the "with_bl.hex" | ||
firmware, using your favourite DFU loading tool. | ||
|
||
Once the initial firmware is loaded you can update the firmware using | ||
any ArduPilot ground station software. Updates should be done with the | ||
*.apj firmware files. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# Bluejay installed by default | ||
SERVO_BLH_AUTO 1 | ||
SERVO_BLH_BDMASK 15 | ||
SERVO_DSHOT_ESC 2 | ||
MOT_PWM_TYPE 6 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
|
||
# hw definition file for processing by chibios_hwdef.py | ||
# for BETAFLIGHTF4 hardware. | ||
# thanks to betaflight for pin information | ||
|
||
# MCU class and specific type | ||
MCU STM32F4xx STM32F405xx | ||
|
||
# board ID for firmware load | ||
APJ_BOARD_ID 1177 | ||
|
||
# crystal frequency, setup to use external oscillator | ||
OSCILLATOR_HZ 8000000 | ||
|
||
FLASH_SIZE_KB 1024 | ||
|
||
# bootloader starts at zero offset | ||
FLASH_RESERVE_START_KB 0 | ||
|
||
# the location where the bootloader will put the firmware | ||
FLASH_BOOTLOADER_LOAD_KB 48 | ||
|
||
# order of UARTs (and USB) | ||
SERIAL_ORDER OTG1 | ||
|
||
# PA10 IO-debug-console | ||
PA11 OTG_FS_DM OTG1 | ||
PA12 OTG_FS_DP OTG1 | ||
|
||
PA13 JTMS-SWDIO SWD | ||
PA14 JTCK-SWCLK SWD | ||
|
||
# default to all pins low to avoid ESD issues | ||
DEFAULTGPIO OUTPUT LOW PULLDOWN | ||
|
||
|
||
# Chip select pins | ||
PA15 FLASH1_CS CS | ||
PB12 OSD1_CS CS | ||
PA4 GYRO1_CS CS | ||
|
||
PB5 LED_BOOTLOADER OUTPUT LOW | ||
define HAL_LED_ON 0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,130 @@ | ||
|
||
# hw definition file for processing by chibios_hwdef.py | ||
# for BETAFLIGHTF4 hardware. | ||
# thanks to betaflight for pin information | ||
|
||
# MCU class and specific type | ||
MCU STM32F4xx STM32F405xx | ||
|
||
# board ID for firmware load | ||
APJ_BOARD_ID AP_HW_CrazyF405 | ||
|
||
# crystal frequency, setup to use external oscillator | ||
OSCILLATOR_HZ 8000000 | ||
|
||
FLASH_SIZE_KB 1024 | ||
|
||
# bootloader takes first sector | ||
FLASH_RESERVE_START_KB 48 | ||
|
||
define HAL_STORAGE_SIZE 16384 | ||
define STORAGE_FLASH_PAGE 1 | ||
|
||
STM32_ST_USE_TIMER 5 | ||
|
||
# SPI devices | ||
|
||
# SPI1 | ||
PA5 SPI1_SCK SPI1 | ||
PA6 SPI1_MISO SPI1 | ||
PA7 SPI1_MOSI SPI1 | ||
|
||
# SPI2 | ||
PB13 SPI2_SCK SPI2 | ||
PB14 SPI2_MISO SPI2 | ||
PB15 SPI2_MOSI SPI2 | ||
|
||
# SPI3 | ||
PC10 SPI3_SCK SPI3 | ||
PC11 SPI3_MISO SPI3 | ||
PC12 SPI3_MOSI SPI3 | ||
|
||
# Chip select pins | ||
PA15 FLASH1_CS CS | ||
PB12 OSD_CS CS | ||
PA4 GYRO1_CS CS | ||
|
||
# Beeper | ||
PB4 BUZZER OUTPUT GPIO(80) LOW | ||
define HAL_BUZZER_PIN 80 | ||
|
||
# SERIAL ports | ||
SERIAL_ORDER OTG1 USART1 USART2 EMPTY EMPTY USART6 | ||
# PA10 IO-debug-console | ||
PA11 OTG_FS_DM OTG1 | ||
PA12 OTG_FS_DP OTG1 | ||
|
||
# USART1 | ||
PA10 USART1_RX USART1 | ||
PA9 USART1_TX USART1 | ||
define DEFAULT_SERIAL1_PROTOCOL SerialProtocol_MSP_DisplayPort | ||
|
||
# USART2 | ||
PA2 USART2_TX USART2 | ||
PA3 USART2_RX USART2 | ||
define DEFAULT_SERIAL3_PROTOCOL SerialProtocol_RCIN | ||
|
||
# USART6 | ||
PC6 USART6_TX USART6 NODMA | ||
PC7 USART6_RX USART6 NODMA | ||
|
||
# I2C ports | ||
I2C_ORDER I2C2 | ||
|
||
# I2C2 | ||
PB10 I2C2_SCL I2C2 | ||
PB11 I2C2_SDA I2C2 | ||
|
||
|
||
# ADC ports | ||
|
||
# ADC1 | ||
PC1 BATT_CURRENT_SENS ADC1 SCALE(1) | ||
define HAL_BATT_CURR_PIN 11 | ||
define HAL_BATT_CURR_SCALE 25.0 | ||
PC2 BATT_VOLTAGE_SENS ADC1 SCALE(1) | ||
define HAL_BATT_VOLT_PIN 12 | ||
define HAL_BATT_VOLT_SCALE 11.0 | ||
define HAL_BATT_MONITOR_DEFAULT 4 | ||
|
||
# MOTORS | ||
PB0 TIM3_CH3 TIM3 PWM(1) GPIO(50) # M1 | ||
PB1 TIM3_CH4 TIM3 PWM(2) GPIO(51) # M2 | ||
PC9 TIM8_CH4 TIM8 PWM(3) GPIO(52) # M3 | ||
PC8 TIM8_CH3 TIM8 PWM(4) GPIO(53) # M4 | ||
PB6 TIM4_CH1 TIM4 PWM(5) GPIO(54) # M5 | ||
|
||
# LEDs | ||
|
||
PB5 LED0 OUTPUT LOW GPIO(90) | ||
define HAL_GPIO_A_LED_PIN 90 | ||
define AP_NOTIFY_GPIO_LED_ENABLED 1 | ||
|
||
|
||
# Dataflash setup | ||
SPIDEV dataflash SPI3 DEVID1 FLASH1_CS MODE3 104*MHZ 104*MHZ | ||
|
||
define HAL_LOGGING_DATAFLASH_ENABLED 1 | ||
define HAL_OSD_TYPE_DEFAULT 5 | ||
|
||
# IMU setup | ||
SPIDEV bmi270 SPI1 DEVID1 GYRO1_CS MODE3 2*MHZ 10*MHZ | ||
IMU BMI270 SPI:bmi270 ROTATION_NONE | ||
DMA_NOSHARE TIM3_UP TIM8_UP TIM4_UP SPI1* | ||
DMA_PRIORITY TIM3_UP TIM8_UP TIM4_UP SPI1* | ||
|
||
# Baro Setup | ||
BARO BMP280 I2C:0:0x76 | ||
|
||
# no built-in compass, but probe the i2c bus for all possible | ||
# external compass types | ||
define ALLOW_ARM_NO_COMPASS | ||
define HAL_PROBE_EXTERNAL_I2C_COMPASSES | ||
define HAL_I2C_INTERNAL_MASK 0 | ||
define HAL_COMPASS_AUTO_ROT_DEFAULT 2 | ||
define HAL_DEFAULT_INS_FAST_SAMPLE 3 | ||
# Motor order implies Betaflight/X for standard ESCs | ||
define HAL_FRAME_TYPE_DEFAULT 12 | ||
|
||
include ../include/minimize_common.inc | ||
AUTOBUILD_TARGETS Copter |