hwdef.dat 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. # hw definition file for processing by chibios_pins.py
  2. # Omnibus F4 PRO with on-board current sensor
  3. # with F405 mcu, mpu6000 imu, bmp280 barometer, 7456 series osd and sdcard
  4. MCU STM32F4xx STM32F405xx
  5. HAL_CHIBIOS_ARCH_F405 1
  6. # board ID for firmware load
  7. APJ_BOARD_ID 131
  8. # crystal frequency
  9. OSCILLATOR_HZ 8000000
  10. STM32_PLLM_VALUE 8
  11. # board voltage
  12. STM32_VDD 330U
  13. STM32_ST_USE_TIMER 5
  14. # flash size
  15. FLASH_SIZE_KB 1024
  16. FLASH_RESERVE_START_KB 64
  17. # order of I2C buses
  18. I2C_ORDER I2C2
  19. # order of UARTs
  20. UART_ORDER OTG1 USART6 USART1
  21. #adc
  22. PC1 BAT_CURR_SENS ADC1 SCALE(1)
  23. PC2 BAT_VOLT_SENS ADC1 SCALE(1)
  24. PA0 RSSI_IN ADC1
  25. #pwm output. 1 - 4 on main header, 5 & 6 on separated header w/o 5V supply, 7 & 8 on CH5 and CH6 pads
  26. PB0 TIM1_CH2N TIM1 PWM(1) GPIO(50)
  27. PB1 TIM1_CH3N TIM1 PWM(2) GPIO(51)
  28. PA3 TIM2_CH4 TIM2 PWM(3) GPIO(52)
  29. PA2 TIM2_CH3 TIM2 PWM(4) GPIO(53)
  30. PA1 TIM2_CH2 TIM2 PWM(5) GPIO(54)
  31. PA8 TIM1_CH1 TIM1 PWM(6) GPIO(55)
  32. PC8 TIM8_CH3 TIM8 PWM(7) GPIO(56)
  33. PC9 TIM8_CH4 TIM8 PWM(8) GPIO(59)
  34. PA4 MPU6000_CS CS
  35. PA5 SPI1_SCK SPI1
  36. PA6 SPI1_MISO SPI1
  37. PA7 SPI1_MOSI SPI1
  38. # note that this board needs PULLUP on I2C pins
  39. PB10 I2C2_SCL I2C2 PULLUP
  40. PB11 I2C2_SDA I2C2 PULLUP
  41. PB15 SPI2_MOSI SPI2
  42. PB14 SPI2_MISO SPI2
  43. PB13 SPI2_SCK SPI2
  44. PB12 SDCARD_CS CS
  45. PA10 USART1_RX USART1
  46. PA9 USART1_TX USART1
  47. PC6 USART6_TX USART6
  48. PC7 USART6_RX USART6
  49. PA13 JTMS-SWDIO SWD
  50. PA14 JTCK-SWCLK SWD
  51. PA15 OSD_CS CS
  52. PB3 BMP280_CS CS
  53. PC12 SPI3_MOSI SPI3
  54. PC11 SPI3_MISO SPI3
  55. PC10 SPI3_SCK SPI3
  56. PB5 LED_BLUE OUTPUT LOW GPIO(1)
  57. define HAL_GPIO_A_LED_PIN 1
  58. #dummy assignment required to allow AP_NOTIFY to use board led
  59. define HAL_GPIO_B_LED_PIN 2
  60. PB4 TIM3_CH1 TIM3 GPIO(58) ALARM LOW
  61. PA11 OTG_FS_DM OTG1
  62. PA12 OTG_FS_DP OTG1
  63. PC5 VBUS INPUT OPENDRAIN
  64. # "PPM" solder pad/resistor should be soldered and "S-BUS" resistor/solder pad removed
  65. # Overwise UART1 or UART6 or RCIN will not work
  66. PB8 TIM4_CH3 TIM4 RCININT PULLDOWN LOW
  67. # SPI Device table
  68. SPIDEV mpu6000 SPI1 DEVID1 MPU6000_CS MODE3 1*MHZ 8*MHZ
  69. SPIDEV sdcard SPI2 DEVID2 SDCARD_CS MODE0 400*KHZ 25*MHZ
  70. SPIDEV bmp280 SPI3 DEVID3 BMP280_CS MODE3 1*MHZ 8*MHZ
  71. SPIDEV osd SPI3 DEVID4 OSD_CS MODE0 10*MHZ 10*MHZ
  72. define CONFIG_HAL_BOARD_SUBTYPE HAL_BOARD_SUBTYPE_CHIBIOS_OMNIBUSF4PRO
  73. # one IMU
  74. IMU Invensense SPI:mpu6000 ROTATION_YAW_180
  75. # one baro
  76. BARO BMP280 SPI:bmp280
  77. # no built-in compass, but probe the i2c bus for all possible
  78. # external compass types
  79. define ALLOW_ARM_NO_COMPASS
  80. define HAL_COMPASS_DEFAULT HAL_COMPASS_NONE
  81. define HAL_PROBE_EXTERNAL_I2C_COMPASSES
  82. define HAL_I2C_INTERNAL_MASK 0
  83. define HAL_COMPASS_AUTO_ROT_DEFAULT 2
  84. define STORAGE_FLASH_PAGE 1
  85. define HAL_STORAGE_SIZE 15360
  86. define HAL_OS_FATFS_IO 1
  87. define HAL_BOARD_LOG_DIRECTORY "/APM/LOGS"
  88. define HAL_BOARD_TERRAIN_DIRECTORY "/APM/TERRAIN"
  89. # define default battery setup
  90. define HAL_BATT_VOLT_PIN 12
  91. define HAL_BATT_CURR_PIN 11
  92. define HAL_BATT_VOLT_SCALE 11
  93. define HAL_BATT_CURR_SCALE 18.2
  94. #analog rssi pin (also could be used as analog airspeed input)
  95. # PA0 - ADC123_CH0
  96. define BOARD_RSSI_ANA_PIN 0
  97. define OSD_ENABLED ENABLED
  98. define HAL_OSD_TYPE_DEFAULT 1
  99. #To complementary channels work we define this
  100. define STM32_PWM_USE_ADVANCED TRUE
  101. define BOARD_PWM_COUNT_DEFAULT 8
  102. #define CH_DBG_ENABLE_ASSERTS TRUE
  103. #define CH_DBG_ENABLE_CHECKS TRUE
  104. #define CH_DBG_SYSTEM_STATE_CHECK TRUE
  105. #define CH_DBG_ENABLE_STACK_CHECK TRUE
  106. #font for the osd
  107. ROMFS_WILDCARD libraries/AP_OSD/fonts/font*.bin