# hw definition file for processing by chibios_pins.py # Sierra-PrecisionPoint # MCU class and specific type MCU STM32F4xx STM32F412Rx FLASH_RESERVE_START_KB 0 # two sectors for bootloader, two for storage FLASH_BOOTLOADER_LOAD_KB 64 # board ID for firmware load APJ_BOARD_ID 1095 # setup build for a peripheral firmware env AP_PERIPH 1 # crystal frequency OSCILLATOR_HZ 16000000 define CH_CFG_ST_FREQUENCY 1000000 # assume 512k flash part FLASH_SIZE_KB 512 STDOUT_SERIAL SD1 STDOUT_BAUDRATE 57600 # USB PA11 USB_FS_DM OTG1 PA12 USB_FS_DP OTG1 PA9 VBUS INPUT OPENDRAIN # USB setup USB_STRING_MANUFACTURER "Sierra Aerospace" USB_STRING_PRODUCT "Sierra-PrecisionPoint-BL" # workaround missing define in headers define RCC_AHB1RSTR_OTGHRST 0x20000000 # order of UARTs SERIAL_ORDER OTG1 USART1 # USART1 PB6 USART1_TX USART1 PB7 USART1_RX USART1 # SWD debugging PA13 JTMS-SWDIO SWD PA14 JTCK-SWCLK SWD define HAL_USE_SERIAL TRUE define STM32_SERIAL_USE_USART1 TRUE define STM32_SERIAL_USE_USART2 FALSE define STM32_SERIAL_USE_USART3 FALSE define HAL_NO_GPIO_IRQ define HAL_USE_EMPTY_IO TRUE define DMA_RESERVE_SIZE 0 define HAL_DISABLE_LOOP_DELAY # avoid timer and RCIN threads to save memory define HAL_NO_TIMER_THREAD define HAL_NO_RCIN_THREAD # enable CAN support PB8 CAN1_RX CAN1 PB9 CAN1_TX CAN1 PB13 GPIO_CAN1_SILENT OUTPUT PUSHPULL SPEED_LOW LOW PB14 GPIO_CAN1_TERM OUTPUT PUSHPULL SPEED_LOW LOW define CAN_APP_NODE_NAME "in.sierraaerospace.PrecisionPoint" # make bl baudrate match debug baudrate for easier debugging define BOOTLOADER_BAUDRATE 57600 # use a small bootloader timeout define HAL_BOOTLOADER_TIMEOUT 1000 # Add CS pins to ensure they are high in bootloader PC0 RM3100_CS CS PC1 DPS310_CS CS Pc4 ICM42688_CS CS # USB select PC6 USB_SEL OUTPUT PUSHPULL SPEED_LOW HIGH PB12 LED_BOOTLOADER OUTPUT LOW define HAL_LED_ON 0