PageRenderTime 38ms CodeModel.GetById 15ms RepoModel.GetById 1ms app.codeStats 0ms

/make/mcu/STM32H7.mk

https://repo.or.cz/betaflight.git
Makefile | 285 lines | 212 code | 39 blank | 34 comment | 2 complexity | f9a03ba2ba2635f6b3f44eca0448339d MD5 | raw file
Possible License(s): GPL-3.0, BSD-3-Clause
  1. #
  2. # H7 Make file include
  3. #
  4. ifeq ($(DEBUG_HARDFAULTS),H7)
  5. CFLAGS += -DDEBUG_HARDFAULTS
  6. endif
  7. #CMSIS
  8. CMSIS_DIR := $(ROOT)/lib/main/CMSIS
  9. #STDPERIPH
  10. STDPERIPH_DIR = $(ROOT)/lib/main/STM32H7/Drivers/STM32H7xx_HAL_Driver
  11. STDPERIPH_SRC = $(notdir $(wildcard $(STDPERIPH_DIR)/Src/*.c))
  12. EXCLUDES = \
  13. stm32h7xx_hal_cec.c \
  14. stm32h7xx_hal_comp.c \
  15. stm32h7xx_hal_crc.c \
  16. stm32h7xx_hal_crc_ex.c \
  17. stm32h7xx_hal_cryp.c \
  18. stm32h7xx_hal_cryp_ex.c \
  19. stm32h7xx_hal_dcmi.c \
  20. stm32h7xx_hal_dfsdm.c \
  21. stm32h7xx_hal_dma2d.c \
  22. stm32h7xx_hal_dsi.c \
  23. stm32h7xx_hal_eth.c \
  24. stm32h7xx_hal_eth_ex.c \
  25. stm32h7xx_hal_fdcan.c \
  26. stm32h7xx_hal_hash.c \
  27. stm32h7xx_hal_hash_ex.c \
  28. stm32h7xx_hal_hcd.c \
  29. stm32h7xx_hal_hrtim.c \
  30. stm32h7xx_hal_hsem.c \
  31. stm32h7xx_hal_i2s.c \
  32. stm32h7xx_hal_i2s_ex.c \
  33. stm32h7xx_hal_irda.c \
  34. stm32h7xx_hal_iwdg.c \
  35. stm32h7xx_hal_jpeg.c \
  36. stm32h7xx_hal_lptim.c \
  37. stm32h7xx_hal_ltdc.c \
  38. stm32h7xx_hal_ltdc_ex.c \
  39. stm32h7xx_hal_mdios.c \
  40. stm32h7xx_hal_mdma.c \
  41. stm32h7xx_hal_mmc.c \
  42. stm32h7xx_hal_mmc_ex.c \
  43. stm32h7xx_hal_msp_template.c \
  44. stm32h7xx_hal_nand.c \
  45. stm32h7xx_hal_nor.c \
  46. stm32h7xx_hal_opamp.c \
  47. stm32h7xx_hal_opamp_ex.c \
  48. stm32h7xx_hal_ramecc.c \
  49. stm32h7xx_hal_rng.c \
  50. stm32h7xx_hal_rtc.c \
  51. stm32h7xx_hal_sai.c \
  52. stm32h7xx_hal_sai_ex.c \
  53. stm32h7xx_hal_sd_ex.c \
  54. stm32h7xx_hal_sdram.c \
  55. stm32h7xx_hal_smartcard.c \
  56. stm32h7xx_hal_smartcard_ex.c \
  57. stm32h7xx_hal_smbus.c \
  58. stm32h7xx_hal_spdifrx.c \
  59. stm32h7xx_hal_sram.c \
  60. stm32h7xx_hal_swpmi.c \
  61. stm32h7xx_hal_usart.c \
  62. stm32h7xx_hal_usart_ex.c \
  63. stm32h7xx_hal_wwdg.c \
  64. stm32h7xx_ll_adc.c \
  65. stm32h7xx_ll_bdma.c \
  66. stm32h7xx_ll_comp.c \
  67. stm32h7xx_ll_crc.c \
  68. stm32h7xx_ll_dac.c \
  69. stm32h7xx_ll_delayblock.c \
  70. stm32h7xx_ll_dma2d.c \
  71. stm32h7xx_ll_exti.c \
  72. stm32h7xx_ll_fmc.c \
  73. stm32h7xx_ll_gpio.c \
  74. stm32h7xx_ll_hrtim.c \
  75. stm32h7xx_ll_i2c.c \
  76. stm32h7xx_ll_lptim.c \
  77. stm32h7xx_ll_lpuart.c \
  78. stm32h7xx_ll_mdma.c \
  79. stm32h7xx_ll_opamp.c \
  80. stm32h7xx_ll_pwr.c \
  81. stm32h7xx_ll_rcc.c \
  82. stm32h7xx_ll_rng.c \
  83. stm32h7xx_ll_rtc.c \
  84. stm32h7xx_ll_spi.c \
  85. stm32h7xx_ll_swpmi.c \
  86. stm32h7xx_ll_usart.c \
  87. stm32h7xx_ll_utils.c
  88. STDPERIPH_SRC := $(filter-out ${EXCLUDES}, $(STDPERIPH_SRC))
  89. #USB
  90. USBCORE_DIR = $(ROOT)/lib/main/STM32H7/Middlewares/ST/STM32_USB_Device_Library/Core
  91. USBCORE_SRC = $(notdir $(wildcard $(USBCORE_DIR)/Src/*.c))
  92. EXCLUDES = usbd_conf_template.c
  93. USBCORE_SRC := $(filter-out ${EXCLUDES}, $(USBCORE_SRC))
  94. USBCDC_DIR = $(ROOT)/lib/main/STM32H7/Middlewares/ST/STM32_USB_Device_Library/Class/CDC
  95. USBCDC_SRC = $(notdir $(wildcard $(USBCDC_DIR)/Src/*.c))
  96. EXCLUDES = usbd_cdc_if_template.c
  97. USBCDC_SRC := $(filter-out ${EXCLUDES}, $(USBCDC_SRC))
  98. USBHID_DIR = $(ROOT)/lib/main/STM32H7/Middlewares/ST/STM32_USB_Device_Library/Class/HID
  99. USBHID_SRC = $(notdir $(wildcard $(USBHID_DIR)/Src/*.c))
  100. USBMSC_DIR = $(ROOT)/lib/main/STM32H7/Middlewares/ST/STM32_USB_Device_Library/Class/MSC
  101. USBMSC_SRC = $(notdir $(wildcard $(USBMSC_DIR)/Src/*.c))
  102. EXCLUDES = usbd_msc_storage_template.c usbd_msc_scsi.c
  103. USBMSC_SRC := $(filter-out ${EXCLUDES}, $(USBMSC_SRC))
  104. VPATH := $(VPATH):$(USBCDC_DIR)/Src:$(USBCORE_DIR)/Src:$(USBHID_DIR)/Src:$(USBMSC_DIR)/Src
  105. DEVICE_STDPERIPH_SRC := $(STDPERIPH_SRC) \
  106. $(USBCORE_SRC) \
  107. $(USBCDC_SRC) \
  108. $(USBHID_SRC) \
  109. $(USBMSC_SRC)
  110. #CMSIS
  111. VPATH := $(VPATH):$(CMSIS_DIR)/Include:$(CMSIS_DIR)/Device/ST/STM32H7xx
  112. VPATH := $(VPATH):$(STDPERIPH_DIR)/Src
  113. CMSIS_SRC :=
  114. INCLUDE_DIRS := $(INCLUDE_DIRS) \
  115. $(STDPERIPH_DIR)/Inc \
  116. $(USBCORE_DIR)/Inc \
  117. $(USBCDC_DIR)/Inc \
  118. $(USBHID_DIR)/Inc \
  119. $(USBMSC_DIR)/Inc \
  120. $(CMSIS_DIR)/Core/Include \
  121. $(ROOT)/lib/main/STM32H7/Drivers/CMSIS/Device/ST/STM32H7xx/Include \
  122. $(ROOT)/src/main/vcp_hal
  123. ifneq ($(filter SDCARD_SPI,$(FEATURES)),)
  124. INCLUDE_DIRS := $(INCLUDE_DIRS) \
  125. $(FATFS_DIR)
  126. VPATH := $(VPATH):$(FATFS_DIR)
  127. endif
  128. ifneq ($(filter SDCARD_SDIO,$(FEATURES)),)
  129. INCLUDE_DIRS := $(INCLUDE_DIRS) \
  130. $(FATFS_DIR)
  131. VPATH := $(VPATH):$(FATFS_DIR)
  132. endif
  133. #Flags
  134. ARCH_FLAGS = -mthumb -mcpu=cortex-m7 -mfloat-abi=hard -mfpu=fpv5-sp-d16 -fsingle-precision-constant -Wdouble-promotion
  135. # Flags that are used in the STM32 libraries
  136. DEVICE_FLAGS = -DUSE_HAL_DRIVER -DUSE_FULL_LL_DRIVER
  137. #
  138. # H743xI : 2M FLASH, 1M RAM (H753xI also)
  139. # H743xG : 1M FLASH, 1M RAM (H753xG also)
  140. # H750xB : 128K FLASH, 1M RAM
  141. #
  142. ifeq ($(TARGET),$(filter $(TARGET),$(H743xI_TARGETS)))
  143. DEVICE_FLAGS += -DSTM32H743xx
  144. DEFAULT_LD_SCRIPT = $(LINKER_DIR)/stm32_flash_h743_2m.ld
  145. STARTUP_SRC = startup_stm32h743xx.s
  146. MCU_FLASH_SIZE := 2048
  147. DEVICE_FLAGS += -DMAX_MPU_REGIONS=16
  148. ifeq ($(RAM_BASED),yes)
  149. FIRMWARE_SIZE := 448
  150. # TARGET_FLASH now becomes the amount of RAM memory that is occupied by the firmware
  151. # and the maximum size of the data stored on the external storage device.
  152. MCU_FLASH_SIZE := FIRMWARE_SIZE
  153. DEFAULT_LD_SCRIPT = $(LINKER_DIR)/stm32_flash_h743_ram_based.ld
  154. endif
  155. else ifeq ($(TARGET),$(filter $(TARGET),$(H750xB_TARGETS)))
  156. DEVICE_FLAGS += -DSTM32H750xx
  157. DEFAULT_LD_SCRIPT = $(LINKER_DIR)/stm32_flash_h750_128k.ld
  158. STARTUP_SRC = startup_stm32h743xx.s
  159. DEFAULT_TARGET_FLASH := 128
  160. ifeq ($(TARGET_FLASH),)
  161. MCU_FLASH_SIZE := $(DEFAULT_TARGET_FLASH)
  162. endif
  163. ifeq ($(EXST),yes)
  164. FIRMWARE_SIZE := 448
  165. # TARGET_FLASH now becomes the amount of RAM memory that is occupied by the firmware
  166. # and the maximum size of the data stored on the external storage device.
  167. MCU_FLASH_SIZE := FIRMWARE_SIZE
  168. DEFAULT_LD_SCRIPT = $(LINKER_DIR)/stm32_flash_h750_exst.ld
  169. endif
  170. ifeq ($(EXST),yes)
  171. # Upper 8 regions are reserved for a boot loader in EXST environment
  172. DEVICE_FLAGS += -DMAX_MPU_REGIONS=8
  173. else
  174. DEVICE_FLAGS += -DMAX_MPU_REGIONS=16
  175. endif
  176. ifneq ($(DEBUG),GDB)
  177. OPTIMISE_DEFAULT := -Os
  178. OPTIMISE_SPEED := -Os
  179. OPTIMISE_SIZE := -Os
  180. LTO_FLAGS := $(OPTIMISATION_BASE) $(OPTIMISE_DEFAULT)
  181. endif
  182. else
  183. $(error Unknown MCU for H7 target)
  184. endif
  185. ifeq ($(LD_SCRIPT),)
  186. LD_SCRIPT = $(DEFAULT_LD_SCRIPT)
  187. endif
  188. ifneq ($(FIRMWARE_SIZE),)
  189. DEVICE_FLAGS += -DFIRMWARE_SIZE=$(FIRMWARE_SIZE)
  190. endif
  191. DEVICE_FLAGS += -DHSE_VALUE=$(HSE_VALUE) -DHSE_STARTUP_TIMEOUT=1000
  192. TARGET_FLAGS = -D$(TARGET)
  193. VCP_SRC = \
  194. vcp_hal/usbd_desc.c \
  195. vcp_hal/usbd_conf_stm32h7xx.c \
  196. vcp_hal/usbd_cdc_hid.c \
  197. vcp_hal/usbd_cdc_interface.c \
  198. drivers/serial_usb_vcp.c \
  199. drivers/usb_io.c
  200. MCU_COMMON_SRC = \
  201. startup/system_stm32h7xx.c \
  202. drivers/system_stm32h7xx.c \
  203. drivers/timer_hal.c \
  204. drivers/timer_stm32h7xx.c \
  205. drivers/serial_uart_hal.c \
  206. drivers/serial_uart_stm32h7xx.c \
  207. drivers/bus_quadspi_hal.c \
  208. drivers/bus_spi_hal.c \
  209. drivers/dma_stm32h7xx.c \
  210. drivers/light_ws2811strip_hal.c \
  211. drivers/adc_stm32h7xx.c \
  212. drivers/bus_i2c_hal.c \
  213. drivers/bus_i2c_hal_init.c \
  214. drivers/pwm_output_dshot_hal.c \
  215. drivers/pwm_output_dshot_shared.c \
  216. drivers/persistent.c \
  217. drivers/transponder_ir_io_hal.c \
  218. drivers/audio_stm32h7xx.c \
  219. drivers/memprot_hal.c \
  220. drivers/memprot_stm32h7xx.c \
  221. #drivers/accgyro/accgyro_mpu.c \
  222. MCU_EXCLUDES = \
  223. drivers/bus_i2c.c \
  224. drivers/timer.c
  225. #MSC_SRC = \
  226. # drivers/usb_msc_common.c \
  227. # drivers/usb_msc_h7xx.c \
  228. # msc/usbd_storage.c
  229. ifneq ($(filter SDCARD_SDIO,$(FEATURES)),)
  230. MCU_COMMON_SRC += \
  231. drivers/sdio_h7xx.c
  232. MSC_SRC += \
  233. msc/usbd_storage_sdio.c
  234. endif
  235. #ifneq ($(filter SDCARD_SPI,$(FEATURES)),)
  236. #MSC_SRC += \
  237. # msc/usbd_storage_sd_spi.c
  238. #endif
  239. #ifneq ($(filter ONBOARDFLASH,$(FEATURES)),)
  240. #MSC_SRC += \
  241. # msc/usbd_storage_emfat.c \
  242. # msc/emfat.c \
  243. # msc/emfat_file.c
  244. #endif
  245. DSP_LIB := $(ROOT)/lib/main/CMSIS/DSP
  246. DEVICE_FLAGS += -DARM_MATH_MATRIX_CHECK -DARM_MATH_ROUNDING -D__FPU_PRESENT=1 -DUNALIGNED_SUPPORT_DISABLE -DARM_MATH_CM7