|
| 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