2019-05-26 22:45:51 -03:00
|
|
|
# hw definition file for processing by chibios_pins.py
|
|
|
|
|
|
|
|
# MCU class and specific type
|
|
|
|
MCU STM32F103 STM32F103xB
|
|
|
|
|
2020-08-23 17:55:53 -03:00
|
|
|
# bootloader starts firmware at 23k + 2k (STORAGE_FLASH_PAGES)
|
2019-05-26 22:45:51 -03:00
|
|
|
FLASH_RESERVE_START_KB 25
|
|
|
|
|
|
|
|
# store parameters in pages 23 and 24
|
|
|
|
define STORAGE_FLASH_PAGE 23
|
|
|
|
define HAL_STORAGE_SIZE 800
|
|
|
|
|
|
|
|
# board ID for firmware load
|
2019-08-04 22:33:59 -03:00
|
|
|
APJ_BOARD_ID 1000
|
2019-05-26 22:45:51 -03:00
|
|
|
|
2019-07-25 06:13:26 -03:00
|
|
|
# setup build for a peripheral firmware
|
|
|
|
env AP_PERIPH 1
|
|
|
|
|
2019-10-20 07:50:04 -03:00
|
|
|
# enable watchdog
|
|
|
|
define HAL_WATCHDOG_ENABLED_DEFAULT true
|
|
|
|
|
2019-05-26 22:45:51 -03:00
|
|
|
# crystal frequency
|
|
|
|
OSCILLATOR_HZ 8000000
|
|
|
|
|
|
|
|
define CH_CFG_ST_FREQUENCY 1000
|
|
|
|
|
|
|
|
# assume the 128k flash part for now
|
|
|
|
FLASH_SIZE_KB 128
|
|
|
|
|
|
|
|
|
|
|
|
# order of UARTs
|
2020-04-24 08:10:08 -03:00
|
|
|
SERIAL_ORDER EMPTY EMPTY EMPTY USART1
|
2019-05-26 22:45:51 -03:00
|
|
|
|
|
|
|
# a LED to flash
|
|
|
|
PA4 LED OUTPUT LOW
|
|
|
|
|
|
|
|
# USART1, connected to GPS
|
|
|
|
PA9 USART1_TX USART1 SPEED_HIGH NODMA
|
|
|
|
PA10 USART1_RX USART1 SPEED_HIGH NODMA
|
|
|
|
|
2019-11-06 03:25:34 -04:00
|
|
|
# USART2 for debug (disabled)
|
|
|
|
# PA2 USART2_TX USART2 SPEED_HIGH NODMA
|
|
|
|
# PA3 USART2_RX USART2 SPEED_HIGH NODMA
|
2019-05-26 22:45:51 -03:00
|
|
|
|
|
|
|
define HAL_UART_NODMA
|
|
|
|
|
|
|
|
# only one I2C bus in normal config
|
|
|
|
PB6 I2C1_SCL I2C1
|
|
|
|
PB7 I2C1_SDA I2C1
|
|
|
|
|
|
|
|
PB0 MAG_CS CS
|
|
|
|
|
|
|
|
# analog input
|
|
|
|
# PA5 VIN5 ADC1
|
|
|
|
define HAL_USE_ADC TRUE
|
|
|
|
define STM32_ADC_USE_ADC1 TRUE
|
|
|
|
define HAL_DISABLE_ADC_DRIVER TRUE
|
|
|
|
|
|
|
|
define HAL_NO_GPIO_IRQ
|
|
|
|
define CH_CFG_ST_TIMEDELTA 0
|
|
|
|
#define CH_CFG_USE_DYNAMIC FALSE
|
|
|
|
define SERIAL_BUFFERS_SIZE 512
|
|
|
|
define PORT_INT_REQUIRED_STACK 64
|
|
|
|
|
|
|
|
# avoid timer and RCIN threads to save memory
|
|
|
|
define HAL_NO_TIMER_THREAD
|
2020-12-05 15:16:27 -04:00
|
|
|
define HAL_NO_RCOUT_THREAD
|
2019-05-26 22:45:51 -03:00
|
|
|
define HAL_NO_RCIN_THREAD
|
|
|
|
|
|
|
|
#defined to turn off undef warnings
|
|
|
|
define __FPU_PRESENT 0
|
|
|
|
|
|
|
|
define HAL_USE_RTC FALSE
|
|
|
|
define DISABLE_SERIAL_ESC_COMM TRUE
|
|
|
|
define NO_DATAFLASH TRUE
|
|
|
|
|
|
|
|
define DMA_RESERVE_SIZE 0
|
|
|
|
|
|
|
|
define PERIPH_FW TRUE
|
|
|
|
|
2020-11-28 00:19:14 -04:00
|
|
|
# MAIN_STACK is stack of initial thread and ISRs
|
|
|
|
MAIN_STACK 0x200
|
2019-05-26 22:45:51 -03:00
|
|
|
|
|
|
|
# PROCESS_STACK controls stack for main thread
|
2019-10-23 06:53:16 -03:00
|
|
|
PROCESS_STACK 0x600
|
2019-05-26 22:45:51 -03:00
|
|
|
define HAL_DISABLE_LOOP_DELAY
|
|
|
|
|
|
|
|
# enable CAN support
|
|
|
|
PA11 CAN_RX CAN
|
|
|
|
PA12 CAN_TX CAN
|
2020-08-27 12:00:22 -03:00
|
|
|
|
|
|
|
|
2019-05-26 22:45:51 -03:00
|
|
|
|
2019-11-06 03:25:34 -04:00
|
|
|
# reduce memory overheads
|
|
|
|
define HAL_CAN_POOL_SIZE 2500
|
|
|
|
|
2019-05-26 22:45:51 -03:00
|
|
|
define HAL_USE_I2C TRUE
|
|
|
|
define STM32_I2C_USE_I2C1 TRUE
|
|
|
|
|
2019-11-06 03:25:34 -04:00
|
|
|
define HAL_UART_MIN_TX_SIZE 128
|
2019-05-26 22:45:51 -03:00
|
|
|
define HAL_UART_MIN_RX_SIZE 128
|
|
|
|
|
|
|
|
define HAL_UART_STACK_SIZE 256
|
2020-11-29 19:16:05 -04:00
|
|
|
define STORAGE_THD_WA_SIZE 300
|
|
|
|
define IO_THD_WA_SIZE 300
|
2019-05-26 22:45:51 -03:00
|
|
|
|
|
|
|
define HAL_NO_GCS
|
|
|
|
define HAL_NO_MONITOR_THREAD
|
|
|
|
|
|
|
|
define HAL_MINIMIZE_FEATURES 0
|
|
|
|
|
|
|
|
define HAL_BUILD_AP_PERIPH
|
|
|
|
|
|
|
|
# only one I2C bus
|
|
|
|
I2C_ORDER I2C1
|
|
|
|
|
|
|
|
define HAL_I2C_CLEAR_ON_TIMEOUT 0
|
|
|
|
|
2019-10-22 03:49:51 -03:00
|
|
|
define HAL_DEVICE_THREAD_STACK 256
|
2019-05-26 22:45:51 -03:00
|
|
|
|
|
|
|
define AP_PARAM_MAX_EMBEDDED_PARAM 0
|
|
|
|
|
|
|
|
define HAL_I2C_INTERNAL_MASK 0
|
|
|
|
|
|
|
|
# disable dual GPS and GPS blending to save flash space
|
|
|
|
define GPS_MAX_RECEIVERS 1
|
|
|
|
define GPS_MAX_INSTANCES 1
|
2019-10-10 00:19:43 -03:00
|
|
|
define HAL_COMPASS_MAX_SENSORS 1
|
2019-08-09 13:04:28 -03:00
|
|
|
define HAL_WITH_DSP FALSE
|
2019-10-20 23:36:57 -03:00
|
|
|
|
|
|
|
# use the app descriptor needed by MissionPlanner for CAN upload
|
|
|
|
env APP_DESCRIPTOR MissionPlanner
|
2019-10-21 00:48:39 -03:00
|
|
|
|
|
|
|
# reserve 256 bytes for comms between app and bootloader
|
|
|
|
RAM_RESERVE_START 256
|
2019-10-22 03:49:51 -03:00
|
|
|
|
2019-10-23 06:54:10 -03:00
|
|
|
# keep ROMFS uncompressed as we don't have enough RAM
|
|
|
|
# to uncompress the bootloader at runtime
|
|
|
|
env ROMFS_UNCOMPRESSED True
|
2020-08-27 12:00:22 -03:00
|
|
|
|
|
|
|
# reduce the number of CAN RX Buffer
|
2020-11-28 00:20:52 -04:00
|
|
|
define HAL_CAN_RX_QUEUE_SIZE 32
|
|
|
|
|
|
|
|
# disable stack checking to reduce flash cost
|
|
|
|
define CH_DBG_ENABLE_STACK_CHECK FALSE
|