| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- TOOLCHAIN = arm
- FLASH_ADDRESS = 0x08000000
- RAM_EXEC ?= 0
- ifeq ($(RAM_EXEC), 1)
- CFLAGS += -DFURI_RAM_EXEC -DVECT_TAB_SRAM -DFLIPPER_STREAM_LITE
- else
- LDFLAGS += -u _printf_float
- endif
- DEBUG_RTOS_THREADS ?= 1
- ifeq ($(DEBUG_RTOS_THREADS), 1)
- OPENOCD_OPTS = -f interface/stlink.cfg -c "transport select hla_swd" -f ../debug/stm32wbx.cfg -c "stm32wbx.cpu configure -rtos auto" -c "init"
- else
- OPENOCD_OPTS = -f interface/stlink.cfg -c "transport select hla_swd" -f ../debug/stm32wbx.cfg -c "init"
- endif
- MCU_FLAGS = -mcpu=cortex-m4 -mthumb -mfpu=fpv4-sp-d16 -mfloat-abi=hard
- # Warnings configuration
- CFLAGS += -Wall -Wextra -Wredundant-decls -Wdouble-promotion
- CFLAGS += $(MCU_FLAGS) -DSTM32WB55xx -fdata-sections -ffunction-sections -fsingle-precision-constant
- LDFLAGS += $(MCU_FLAGS) -specs=nosys.specs -specs=nano.specs
- CPPFLAGS += -fno-rtti -fno-use-cxa-atexit -fno-exceptions
- LDFLAGS += -Wl,--start-group -lstdc++ -lsupc++ -Wl,--end-group
- HARDWARE_TARGET = 7
- MXPROJECT_DIR = $(TARGET_DIR)
- # Entry Point
- ASM_SOURCES += $(MXPROJECT_DIR)/startup_stm32wb55xx_cm4.s
- # STM32WB HAL
- CUBE_DIR = ../lib/STM32CubeWB
- CFLAGS += \
- -DUSE_FULL_LL_DRIVER \
- -DUSE_FULL_ASSERT \
- -DHAVE_FREERTOS
- CFLAGS += \
- -I$(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Inc \
- -I$(CUBE_DIR)/Drivers/CMSIS/Device/ST \
- -I$(CUBE_DIR)/Drivers/CMSIS/Device/ST/STM32WBxx/Include \
- -I$(CUBE_DIR)/Drivers/CMSIS/Include
- C_SOURCES += \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_adc.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_comp.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_dma.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_gpio.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_i2c.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_lptim.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_rcc.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_rtc.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_spi.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_tim.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_usart.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_lpuart.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_utils.c \
- $(CUBE_DIR)/Drivers/STM32WBxx_HAL_Driver/Src/stm32wbxx_ll_rng.c
- # FreeRTOS
- CFLAGS += \
- -I$(LIB_DIR)/FreeRTOS-Kernel/include \
- -I$(LIB_DIR)/FreeRTOS-Kernel/portable/GCC/ARM_CM4F \
- -I$(LIB_DIR)/FreeRTOS-glue/
- C_SOURCES += \
- $(LIB_DIR)/FreeRTOS-Kernel/event_groups.c \
- $(LIB_DIR)/FreeRTOS-Kernel/list.c \
- $(LIB_DIR)/FreeRTOS-Kernel/queue.c \
- $(LIB_DIR)/FreeRTOS-Kernel/stream_buffer.c \
- $(LIB_DIR)/FreeRTOS-Kernel/tasks.c \
- $(LIB_DIR)/FreeRTOS-Kernel/timers.c \
- $(LIB_DIR)/FreeRTOS-Kernel/portable/GCC/ARM_CM4F/port.c \
- $(LIB_DIR)/FreeRTOS-glue/cmsis_os2.c \
- # BLE glue
- CFLAGS += \
- -I$(TARGET_DIR)/ble_glue \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/template \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl \
- -I$(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/shci
- C_SOURCES += \
- $(wildcard $(TARGET_DIR)/ble_glue/*.c) \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities/otp.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities/stm_list.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/utilities/dbg_trace.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/svc/Src/svc_ctl.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/template/osal.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_hci_le.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_gap_aci.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_gatt_aci.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_hal_aci.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/ble/core/auto/ble_l2cap_aci.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/tl_mbox.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/hci_tl.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/hci_tl_if.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/shci_tl.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/tl/shci_tl_if.c \
- $(CUBE_DIR)/Middlewares/ST/STM32_WPAN/interface/patterns/ble_thread/shci/shci.c
- # USB stack
- CFLAGS += \
- -DSTM32WB \
- -DUSB_PMASIZE=0x400
- # Furi HAL
- FURI_HAL_OS_DEBUG ?= 0
- ifeq ($(FURI_HAL_OS_DEBUG), 1)
- CFLAGS += -DFURI_HAL_OS_DEBUG
- endif
- FURI_HAL_USB_VCP_DEBUG ?= 0
- ifeq ($(FURI_HAL_USB_VCP_DEBUG), 1)
- CFLAGS += -DFURI_HAL_USB_VCP_DEBUG
- endif
- ifeq ($(FURI_HAL_POWER_DEEP_SLEEP_ENABLED), 1)
- CFLAGS += -DFURI_HAL_POWER_DEEP_SLEEP_ENABLED
- endif
- FURI_HAL_SUBGHZ_TX_GPIO ?= 0
- ifneq ($(FURI_HAL_SUBGHZ_TX_GPIO), 0)
- CFLAGS += -DFURI_HAL_SUBGHZ_TX_GPIO=$(FURI_HAL_SUBGHZ_TX_GPIO)
- endif
- ifeq ($(INVERT_RFID_IN), 1)
- CFLAGS += -DINVERT_RFID_IN
- endif
- ifeq ($(BLE_GLUE_DEBUG), 1)
- CFLAGS += -DBLE_GLUE_DEBUG
- endif
- FURI_HAL_DIR = $(TARGET_DIR)/furi_hal
- CFLAGS += -I$(FURI_HAL_DIR)
- C_SOURCES += $(wildcard $(FURI_HAL_DIR)/*.c)
- # Other
- CFLAGS += \
- -I$(MXPROJECT_DIR)/Inc \
- -I$(MXPROJECT_DIR)/fatfs
- C_SOURCES += \
- $(wildcard $(MXPROJECT_DIR)/Src/*.c) \
- $(wildcard $(MXPROJECT_DIR)/fatfs/*.c)
- ifeq ($(RAM_EXEC), 1)
- LDFLAGS += -T$(MXPROJECT_DIR)/stm32wb55xx_ram_fw.ld
- else # RAM_EXEC
- # Linker options
- LDFLAGS += -T$(MXPROJECT_DIR)/stm32wb55xx_flash.ld
- endif # RAM_EXEC
- SVD_FILE = ../debug/STM32WB55_CM4.svd
|