Skip to content

Commit 2b17d2d

Browse files
committed
AP_HAL_ChibiOS: hwdef: ARK_FPV board support
1 parent 47342db commit 2b17d2d

File tree

2 files changed

+323
-0
lines changed

2 files changed

+323
-0
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,75 @@
1+
# hw definition file for processing by chibios_hwdef.py
2+
# for the ARKV6X hardware
3+
4+
# MCU class and specific type
5+
MCU STM32H7xx STM32H743xx
6+
7+
# crystal frequency
8+
OSCILLATOR_HZ 16000000
9+
10+
# board ID for firmware load
11+
APJ_BOARD_ID 59
12+
13+
# bootloader is installed at zero offset
14+
FLASH_RESERVE_START_KB 0
15+
16+
# the location where the bootloader will put the firmware
17+
FLASH_BOOTLOADER_LOAD_KB 128
18+
19+
# flash size
20+
FLASH_SIZE_KB 2048
21+
22+
env OPTIMIZE -Os
23+
24+
# order of UARTs (and USB)
25+
SERIAL_ORDER OTG1 UART7 UART5 USART3
26+
27+
# USB
28+
PA11 OTG_FS_DM OTG1
29+
PA12 OTG_FS_DP OTG1
30+
PA9 VBUS INPUT OPENDRAIN
31+
32+
# pins for SWD debugging
33+
PA13 JTMS-SWDIO SWD
34+
PA14 JTCK-SWCLK SWD
35+
36+
# CS pins
37+
38+
# ICM20602
39+
PI9 IMU1_CS CS
40+
# BMMI088 Accel
41+
PI4 BMI088_A_CS CS
42+
# BMMI088 Gyro
43+
PI8 BMI088_G_CS CS
44+
# Unused
45+
# PG7 FRAM_CS CS
46+
PI10 EXT1_CS CS
47+
48+
# telem1
49+
PE8 UART7_TX UART7
50+
PF6 UART7_RX UART7
51+
52+
# telem2
53+
PC12 UART5_TX UART5
54+
PD2 UART5_RX UART5
55+
56+
# debug uart
57+
PD8 USART3_TX USART3
58+
PD9 USART3_RX USART3
59+
60+
# armed indication
61+
PE6 nARMED OUTPUT HIGH
62+
63+
# 12V peripheral enable
64+
PG4 nVDD_5V_PERIPH_EN OUTPUT HIGH
65+
66+
# LEDs
67+
PE3 LED_ACTIVITY OUTPUT OPENDRAIN HIGH # red
68+
PE5 LED_BOOTLOADER OUTPUT OPENDRAIN HIGH # blue
69+
define HAL_LED_ON 0
70+
71+
define HAL_USE_EMPTY_STORAGE 1
72+
define HAL_STORAGE_SIZE 16384
73+
74+
# enable DFU by default
75+
ENABLE_DFU_BOOT 1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,248 @@
1+
# hw definition file for processing by chibios_hwdef.py
2+
# for the ARKV6X hardware
3+
4+
# MCU class and specific type
5+
MCU STM32H7xx STM32H743xx
6+
7+
# crystal frequency
8+
OSCILLATOR_HZ 16000000
9+
10+
# TODO: changing clockrate causes the build to fail
11+
# MCU_CLOCKRATE_MHZ 320
12+
13+
# ChibiOS system timer
14+
STM32_ST_USE_TIMER 2
15+
16+
# board ID for firmware load
17+
APJ_BOARD_ID 59
18+
19+
FLASH_RESERVE_START_KB 128
20+
21+
# to be compatible with the px4 bootloader we need
22+
# to use a different RAM_MAP
23+
env USE_ALT_RAM_MAP 1
24+
25+
# flash size
26+
FLASH_SIZE_KB 2048
27+
28+
env OPTIMIZE -O2
29+
30+
SERIAL_ORDER OTG1 UART7 UART5 USART1 USART2 UART4 USART6 OTG2
31+
32+
# debug console
33+
STDOUT_SERIAL SD3
34+
STDOUT_BAUDRATE 57600
35+
36+
# default to all pins low to avoid ESD issues
37+
DEFAULTGPIO OUTPUT LOW PULLDOWN
38+
39+
# USB
40+
PA11 OTG_FS_DM OTG1
41+
PA12 OTG_FS_DP OTG1
42+
PA9 VBUS INPUT OPENDRAIN
43+
44+
# pins for SWD debugging
45+
PA13 JTMS-SWDIO SWD
46+
PA14 JTCK-SWCLK SWD
47+
48+
# telem1
49+
PE8 UART7_TX UART7
50+
PF6 UART7_RX UART7
51+
PF8 UART7_RTS UART7
52+
PE10 UART7_CTS UART7
53+
54+
# telem2
55+
PC8 UART5_RTS UART5
56+
PC9 UART5_CTS UART5
57+
PC12 UART5_TX UART5
58+
PD2 UART5_RX UART5
59+
60+
# telem3
61+
PA3 USART2_RX USART2
62+
PD5 USART2_TX USART2
63+
PD3 USART2_CTS USART2
64+
PD4 USART2_RTS USART2
65+
66+
# GPS1
67+
PB6 USART1_TX USART1
68+
PB7 USART1_RX USART1
69+
70+
# uart4
71+
PH13 UART4_TX UART4
72+
PH14 UART4_RX UART4
73+
74+
# debug uart
75+
PD8 USART3_TX USART3
76+
PD9 USART3_RX USART3
77+
78+
# used for RC SBUS
79+
PC6 USART6_TX USART6
80+
PC7 USART6_RX USART6
81+
82+
# ADC
83+
PA0 SCALED1_V3V3 ADC1 SCALE(2)
84+
PA4 SCALED2_V3V3 ADC1 SCALE(2)
85+
PB0 SCALED3_V3V3 ADC1 SCALE(2)
86+
87+
PB1 VDD_5V_SENS ADC1 SCALE(2)
88+
89+
# ESC Telem on UART4
90+
define HAL_SERIAL_ESC_COMM_ENABLED 1
91+
define HAL_WITH_ESC_TELEM 1
92+
define DEFAULT_SERIAL4_PROTOCOL SerialProtocol_ESCTelemetry
93+
94+
# TODO: ESC analog current (CURR_IN)
95+
# PC2 ADC1_6V6 ADC1 SCALE(2)
96+
97+
# SPI1 - IIM42653
98+
PA5 SPI1_SCK SPI1
99+
PB5 SPI1_MOSI SPI1
100+
PG9 SPI1_MISO SPI1
101+
PI9 IMU1_CS CS
102+
PF2 IMU1_DRDY INPUT
103+
104+
# SPI6 - external1
105+
PB3 SPI6_SCK SPI6
106+
PA6 SPI6_MISO SPI6
107+
PG14 SPI6_MOSI SPI6
108+
PI10 EXT1_CS CS
109+
PD11 DRDY_ADIS16507 INPUT GPIO(93)
110+
111+
# use GPIO(93) for data ready on ADIS16507
112+
#define ADIS_DRDY_PIN 93
113+
114+
# PWM output pins
115+
PI0 TIM5_CH4 TIM5 PWM(1) GPIO(50)
116+
PH12 TIM5_CH3 TIM5 PWM(2) GPIO(51)
117+
PH11 TIM5_CH2 TIM5 PWM(3) GPIO(52)
118+
PH10 TIM5_CH1 TIM5 PWM(4) GPIO(53)
119+
PI5 TIM8_CH1 TIM8 PWM(5) GPIO(54)
120+
PI6 TIM8_CH2 TIM8 PWM(6) GPIO(55)
121+
PI7 TIM8_CH3 TIM8 PWM(7) GPIO(56)
122+
PI2 TIM8_CH4 TIM8 PWM(8) GPIO(57)
123+
PD12 TIM4_CH1 TIM4 PWM(9) GPIO(58)
124+
125+
# CAN bus
126+
PD0 CAN1_RX CAN1
127+
PD1 CAN1_TX CAN1
128+
129+
# I2C buses
130+
131+
# I2C1 (GPS1 compass, external)
132+
PB9 I2C1_SDA I2C1
133+
PB8 I2C1_SCL I2C1
134+
135+
# I2C2 (BMP390 baro, internal)
136+
PF1 I2C2_SCL I2C2
137+
PF0 I2C2_SDA I2C2
138+
139+
# I2C4 (IIS2MDC compass, internal)
140+
PF14 I2C4_SCL I2C4
141+
PF15 I2C4_SDA I2C4
142+
143+
# order of I2C buses
144+
I2C_ORDER I2C1 I2C2 I2C4
145+
define HAL_I2C_INTERNAL_MASK 6
146+
147+
# TODO: where does these GPIO numbers come from? ie, GPIO(80)
148+
PB10 HEATER_EN OUTPUT LOW GPIO(80)
149+
define HAL_HEATER_GPIO_PIN 80
150+
151+
# Setup the IMU heater
152+
define HAL_HAVE_IMU_HEATER 1
153+
define HAL_IMU_TEMP_DEFAULT 45
154+
define HAL_IMUHEAT_P_DEFAULT 50
155+
define HAL_IMUHEAT_I_DEFAULT 0.07
156+
# TODO: should we use this?
157+
# define HAL_IMU_TEMP_MARGIN_LOW_DEFAULT 5
158+
159+
# armed indication
160+
PE6 nARMED OUTPUT HIGH
161+
162+
# power enable pins
163+
PC13 VDD_3V3_SD_CARD_EN OUTPUT HIGH
164+
PI11 VDD_3V3_SENSORS1_EN OUTPUT HIGH
165+
166+
# start peripheral power off, then enable after init
167+
# this prevents a problem with radios that use RTS for
168+
# bootloader hold
169+
PG4 nVDD_5V_PERIPH_EN OUTPUT HIGH
170+
171+
# power sensing
172+
PE15 VDD_5V_PERIPH_nOC INPUT PULLUP
173+
PF13 VDD_5V_HIPOWER_nOC INPUT PULLUP
174+
175+
PG1 VDD_BRICK_nVALID INPUT PULLUP
176+
177+
# microSD support
178+
PD6 SDMMC2_CK SDMMC2
179+
PD7 SDMMC2_CMD SDMMC2
180+
PB14 SDMMC2_D0 SDMMC2
181+
PB15 SDMMC2_D1 SDMMC2
182+
PG11 SDMMC2_D2 SDMMC2
183+
PB4 SDMMC2_D3 SDMMC2
184+
define FATFS_HAL_DEVICE SDCD2
185+
186+
# LEDs
187+
PE3 LED_RED OUTPUT OPENDRAIN GPIO(90) HIGH
188+
PE4 LED_GREEN OUTPUT OPENDRAIN GPIO(91) HIGH
189+
PE5 LED_BLUE OUTPUT OPENDRAIN GPIO(92) HIGH
190+
191+
# setup for "pixracer" RGB LEDs
192+
define AP_NOTIFY_GPIO_LED_RGB_RED_PIN 90
193+
define AP_NOTIFY_GPIO_LED_RGB_GREEN_PIN 91
194+
define AP_NOTIFY_GPIO_LED_RGB_BLUE_PIN 92
195+
196+
define AP_NOTIFY_GPIO_LED_RGB_ENABLED 1
197+
198+
# ID pins
199+
PG0 HW_VER_REV_DRIVE OUTPUT LOW
200+
# PH3 HW_VER_SENS ADC3 SCALE(1)
201+
# PH4 HW_REV_SENS ADC3 SCALE(1)
202+
203+
# PWM output for buzzer
204+
PF9 TIM14_CH1 TIM14 GPIO(77) ALARM
205+
206+
# barometer on i2c_2
207+
BARO BMP388 I2C:1:0x76
208+
209+
# compass
210+
define HAL_PROBE_EXTERNAL_I2C_COMPASSES
211+
212+
# builtin compass
213+
COMPASS IIS2MDC I2C:2:0x1E false ROTATION_NONE
214+
215+
# IIM42653 on SPI1
216+
SPIDEV iim42653 SPI1 DEVID1 IMU1_CS MODE3 2*MHZ 8*MHZ
217+
#SPIDEV adis16507 SPI6 DEVID1 EXT1_CS MODE3 1*MHZ 2*MHZ
218+
219+
# ARKV6X 1 IIM42653 IMU
220+
IMU Invensensev3 SPI:iim42653 ROTATION_YAW_270
221+
222+
# IMU Invensensev3 SPI:iim42652 ROTATION_YAW_270
223+
#IMU ADIS1647x SPI:adis16507 ROTATION_NONE ADIS_DRDY_PIN
224+
225+
define HAL_DEFAULT_INS_FAST_SAMPLE 1
226+
227+
# enable RAMTROM parameter storage
228+
define HAL_STORAGE_SIZE 32768
229+
230+
# INA226 battery monitor
231+
define HAL_BATTMON_INA2XX_BUS 2
232+
define HAL_BATTMON_INA2XX_ADDR 0
233+
define HAL_BATT_MONITOR_DEFAULT 21
234+
235+
DMA_PRIORITY SDMMC* USART6* ADC* UART* USART* SPI* TIM*
236+
237+
# enable FAT filesystem support (needs a microSD defined via SDMMC)
238+
define HAL_OS_FATFS_IO 1
239+
240+
# ROMFS io_firmware.bin Tools/IO_Firmware/iofirmware_lowpolh.bin
241+
242+
# enable DFU reboot for installing bootloader
243+
# note that if firmware is build with --secure-bl then DFU is
244+
# disabled
245+
ENABLE_DFU_BOOT 1
246+
247+
# bootloader embedding / bootloader flashing not available
248+
define AP_BOOTLOADER_FLASHING_ENABLED 0

0 commit comments

Comments
 (0)