target.mk 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. TOOLCHAIN = arm
  2. BOOT_ADDRESS = 0x08000000
  3. FW_ADDRESS = 0x08008000
  4. OS_OFFSET = 0x00008000
  5. FLASH_ADDRESS = 0x08008000
  6. NO_BOOTLOADER ?= 0
  7. ifeq ($(NO_BOOTLOADER), 1)
  8. BOOT_ADDRESS = 0x08000000
  9. FW_ADDRESS = 0x08000000
  10. OS_OFFSET = 0x00000000
  11. FLASH_ADDRESS = 0x08000000
  12. CFLAGS += -DNO_BOOTLOADER
  13. endif
  14. OPENOCD_OPTS = -f interface/stlink.cfg -c "transport select hla_swd" -f ../debug/stm32wbx.cfg -c "stm32wbx.cpu configure -rtos auto" -c "init"
  15. BOOT_CFLAGS = -DBOOT_ADDRESS=$(BOOT_ADDRESS) -DFW_ADDRESS=$(FW_ADDRESS) -DOS_OFFSET=$(OS_OFFSET)
  16. MCU_FLAGS = -mcpu=cortex-m4 -mthumb -mfpu=fpv4-sp-d16 -mfloat-abi=hard
  17. CFLAGS += $(MCU_FLAGS) $(BOOT_CFLAGS) -DSTM32WB55xx -Wall -fdata-sections -ffunction-sections
  18. LDFLAGS += $(MCU_FLAGS) -specs=nosys.specs -specs=nano.specs -u _printf_float
  19. CPPFLAGS += -fno-rtti -fno-use-cxa-atexit -fno-exceptions
  20. LDFLAGS += -Wl,--start-group -lstdc++ -lsupc++ -Wl,--end-group
  21. HARDWARE_TARGET = 7
  22. MXPROJECT_DIR = $(TARGET_DIR)
  23. # Entry Point
  24. ASM_SOURCES += $(MXPROJECT_DIR)/startup_stm32wb55xx_cm4.s
  25. # STM32WB HAL
  26. CUBE_DIR = ../lib/STM32CubeWB
  27. CFLAGS += \
  28. -DUSE_FULL_LL_DRIVER \
  29. -DUSE_HAL_DRIVER \
  30. -DHAVE_FREERTOS
  31. CFLAGS += \
  32. -I$(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Inc \
  33. -I$(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Inc/Legacy \
  34. -I$(CUBE_DIR)/Drivers/CMSIS/Device/ST \
  35. -I$(CUBE_DIR)/Drivers/CMSIS/Device/ST/STM32WBxx/Include \
  36. -I$(CUBE_DIR)/Drivers/CMSIS/Include
  37. C_SOURCES += \
  38. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal.c \
  39. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_comp.c \
  40. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_cortex.c \
  41. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_cryp.c \
  42. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_exti.c \
  43. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_gpio.c \
  44. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_hsem.c \
  45. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_ipcc.c \
  46. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_pcd.c \
  47. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_pcd_ex.c \
  48. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_pwr.c \
  49. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_pwr_ex.c \
  50. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_rcc.c \
  51. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_rtc_ex.c \
  52. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_tim.c \
  53. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_hal_tim_ex.c \
  54. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_adc.c \
  55. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_dma.c \
  56. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_gpio.c \
  57. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_i2c.c \
  58. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_lptim.c \
  59. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_rcc.c \
  60. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_rtc.c \
  61. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_spi.c \
  62. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_tim.c \
  63. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_usart.c \
  64. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_lpuart.c \
  65. $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_utils.c
  66. # FreeRTOS
  67. CFLAGS += \
  68. -I$(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/include \
  69. -I$(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS_V2 \
  70. -I$(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/portable/GCC/ARM_CM4F
  71. C_SOURCES += \
  72. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/event_groups.c \
  73. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/list.c \
  74. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/queue.c \
  75. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/stream_buffer.c \
  76. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/tasks.c \
  77. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/timers.c \
  78. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS_V2/cmsis_os2.c \
  79. $(CUBE_DIR)/Middlewares/Third_Party/FreeRTOS/Source/portable/GCC/ARM_CM4F/port.c
  80. # BLE glue
  81. CFLAGS += \
  82. -I$(TARGET_DIR)/ble-glue \
  83. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN \
  84. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble \
  85. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core \
  86. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/template \
  87. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities \
  88. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread \
  89. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl \
  90. -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/shci
  91. C_SOURCES += \
  92. $(wildcard $(TARGET_DIR)/ble-glue/*.c) \
  93. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities/otp.c \
  94. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities/stm_list.c \
  95. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities/dbg_trace.c \
  96. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/svc/Src/svc_ctl.c \
  97. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/template/osal.c \
  98. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_hci_le.c \
  99. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_gap_aci.c \
  100. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_gatt_aci.c \
  101. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_hal_aci.c \
  102. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/tl_mbox.c \
  103. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/hci_tl.c \
  104. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/hci_tl_if.c \
  105. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/shci_tl.c \
  106. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/shci_tl_if.c \
  107. $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/shci/shci.c
  108. # USB stack
  109. CFLAGS += \
  110. -DSTM32WB \
  111. -DUSB_PMASIZE=0x400
  112. # Furi HAL
  113. FURI_HAL_OS_DEBUG ?= 0
  114. ifeq ($(FURI_HAL_OS_DEBUG), 1)
  115. CFLAGS += -DFURI_HAL_OS_DEBUG
  116. endif
  117. FURI_HAL_USB_VCP_DEBUG ?= 0
  118. ifeq ($(FURI_HAL_USB_VCP_DEBUG), 1)
  119. CFLAGS += -DFURI_HAL_USB_VCP_DEBUG
  120. endif
  121. FURI_HAL_SUBGHZ_TX_GPIO ?= 0
  122. ifneq ($(FURI_HAL_SUBGHZ_TX_GPIO), 0)
  123. CFLAGS += -DFURI_HAL_SUBGHZ_TX_GPIO=$(FURI_HAL_SUBGHZ_TX_GPIO)
  124. endif
  125. ifeq ($(INVERT_RFID_IN), 1)
  126. CFLAGS += -DINVERT_RFID_IN
  127. endif
  128. FURI_HAL_DIR = $(TARGET_DIR)/furi-hal
  129. CFLAGS += -I$(FURI_HAL_DIR)
  130. C_SOURCES += $(wildcard $(FURI_HAL_DIR)/*.c)
  131. # Other
  132. CFLAGS += \
  133. -I$(MXPROJECT_DIR)/Inc \
  134. -I$(MXPROJECT_DIR)/fatfs
  135. C_SOURCES += \
  136. $(wildcard $(MXPROJECT_DIR)/Src/*.c) \
  137. $(wildcard $(MXPROJECT_DIR)/fatfs/*.c)
  138. # Linker options
  139. ifeq ($(NO_BOOTLOADER), 1)
  140. LDFLAGS += -T$(MXPROJECT_DIR)/stm32wb55xx_flash_cm4_no_bootloader.ld
  141. else
  142. LDFLAGS += -T$(MXPROJECT_DIR)/stm32wb55xx_flash_cm4_with_bootloader.ld
  143. endif
  144. SVD_FILE = ../debug/STM32WB55_CM4.svd