# hw definition file for processing by chibios_hwdef.py # for the BotBloxSwitch hardware # default to all pins low to avoid ESD issues DEFAULTGPIO OUTPUT LOW PULLDOWN # MCU class and specific type MCU STM32H7xx STM32H723xx # crystal frequency OSCILLATOR_HZ 16000000 # setup build for a peripheral bootloader env AP_PERIPH 1 # board ID for firmware load APJ_BOARD_ID AP_HW_BotBloxSwitch FLASH_RESERVE_START_KB 128 define HAL_STORAGE_SIZE 32768 # use last 2 pages for flash storage # H723 has 8 pages of 128k each STORAGE_FLASH_PAGE 6 # flash size FLASH_SIZE_KB 1024 env OPTIMIZE -Os # pins for SWD debugging PA13 JTMS-SWDIO SWD PA14 JTCK-SWCLK SWD # USB PA11 OTG_HS_DM OTG1 PA12 OTG_HS_DP OTG1 PA9 VBUS INPUT OPENDRAIN # CAN bus PD0 CAN1_RX CAN1 PD1 CAN1_TX CAN1 #PD4 USART2_DE USART2 PD5 USART2_TX USART2 PD6 USART2_RX USART2 PD8 USART3_TX USART3 PD9 USART3_RX USART3 PD12 USART3_RTS USART3 PD11 USART3_CTS USART3 # LEDs PC0 LED_STT1 OUTPUT OPENDRAIN HIGH PA4 LED_STT2 OUTPUT OPENDRAIN HIGH define HAL_LED_ON 0 # use first LED define HAL_GPIO_PIN_LED HAL_GPIO_PIN_LED_STT1 # Ethernet switch chip reset pin PD13 GPIO_ETH_RST OUTPUT HIGH PULLUP # CAN1 standby GPIO PA0 GPIO_CAN_S OUTPUT LOW PULLUP # GPIO/PWMs #PC6 TIM3_CH1 TIM3 PWM(1) GPIO(100) #PB14 TIM12_CH1 TIM12 PWM(2) GPIO(101) #PB15 TIM12_CH2 TIM12 PWM(3) GPIO(102) PC1 ETH_MDC ETH1 PA2 ETH_MDIO ETH1 PC4 ETH_RMII_RXD0 ETH1 PC5 ETH_RMII_RXD1 ETH1 PB12 ETH_RMII_TXD0 ETH1 PB13 ETH_RMII_TXD1 ETH1 PB11 ETH_RMII_TX_EN ETH1 PA7 ETH_RMII_CRS_DV ETH1 PA1 ETH_RMII_REF_CLK ETH1 define BOARD_PHY_ADDRESS 5 define BOARD_PHY_RMII # auto-negotiation doesn't work, force 100MBit full duplex define STM32_MAC_PHY_LINK_TYPE MAC_LINK_100_FULLDUPLEX define HAL_PERIPH_ENABLE_NETWORKING define AP_NETWORKING_MAX_INSTANCES 4 # allow load from USB SERIAL_ORDER OTG1 USART3 define HAL_RCIN_THREAD_ENABLED 1 define HAL_SCHEDULER_LOOP_DELAY_ENABLED 1 define HAL_USE_ADC FALSE define AP_SERIALMANAGER_REGISTER_ENABLED 1 define AP_SCRIPTING_ENABLED 1 define AP_FILESYSTEM_ROMFS_ENABLED 1 # keep ROMFS uncompressed as we don't have enough RAM # to uncompress the network enabled bootloader at runtime env ROMFS_UNCOMPRESSED True include ../include/network_PPPGW.inc define HAL_MONITOR_THREAD_ENABLED 1