92 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| ST_FAMILY = h7
 | |
| ST_PREFIX = stm32${ST_FAMILY}xx
 | |
| ST_CMSIS = hw/mcu/st/cmsis_device_$(ST_FAMILY)
 | |
| ST_HAL_DRIVER = hw/mcu/st/${ST_PREFIX}_hal_driver
 | |
| ST_MFXSTM32L152 = hw/mcu/st/stm32-mfxstm32l152
 | |
| 
 | |
| UF2_FAMILY_ID = 0x6db66082
 | |
| 
 | |
| include $(TOP)/$(BOARD_PATH)/board.mk
 | |
| CPU_CORE ?= cortex-m7
 | |
| 
 | |
| # ----------------------
 | |
| # Port & Speed Selection
 | |
| # ----------------------
 | |
| RHPORT_SPEED ?= OPT_MODE_FULL_SPEED OPT_MODE_FULL_SPEED
 | |
| RHPORT_DEVICE ?= 0
 | |
| RHPORT_HOST ?= 0
 | |
| 
 | |
| # Determine RHPORT_DEVICE_SPEED if not defined
 | |
| ifndef RHPORT_DEVICE_SPEED
 | |
| ifeq ($(RHPORT_DEVICE), 0)
 | |
|   RHPORT_DEVICE_SPEED = $(firstword $(RHPORT_SPEED))
 | |
| else
 | |
|   RHPORT_DEVICE_SPEED = $(lastword $(RHPORT_SPEED))
 | |
| endif
 | |
| endif
 | |
| 
 | |
| # Determine RHPORT_HOST_SPEED if not defined
 | |
| ifndef RHPORT_HOST_SPEED
 | |
| ifeq ($(RHPORT_HOST), 0)
 | |
|   RHPORT_HOST_SPEED = $(firstword $(RHPORT_SPEED))
 | |
| else
 | |
|   RHPORT_HOST_SPEED = $(lastword $(RHPORT_SPEED))
 | |
| endif
 | |
| endif
 | |
| 
 | |
| # --------------
 | |
| # Compiler Flags
 | |
| # --------------
 | |
| CFLAGS += \
 | |
|   -DCFG_TUSB_MCU=OPT_MCU_STM32H7 \
 | |
| 	-DBOARD_TUD_RHPORT=${RHPORT_DEVICE} \
 | |
| 	-DBOARD_TUD_MAX_SPEED=${RHPORT_DEVICE_SPEED} \
 | |
| 	-DBOARD_TUH_RHPORT=${RHPORT_HOST} \
 | |
| 	-DBOARD_TUH_MAX_SPEED=${RHPORT_HOST_SPEED} \
 | |
| 
 | |
| # GCC Flags
 | |
| # suppress warning caused by vendor mcu driver
 | |
| CFLAGS_GCC += \
 | |
|   -flto \
 | |
|   -Wno-error=cast-align \
 | |
|   -Wno-error=unused-parameter \
 | |
| 
 | |
| LDFLAGS_GCC += \
 | |
|   -nostdlib -nostartfiles \
 | |
|   --specs=nosys.specs --specs=nano.specs
 | |
| 
 | |
| # -----------------
 | |
| # Sources & Include
 | |
| # -----------------
 | |
| 
 | |
| SRC_C += \
 | |
| 	src/portable/synopsys/dwc2/dcd_dwc2.c \
 | |
| 	src/portable/synopsys/dwc2/hcd_dwc2.c \
 | |
| 	src/portable/synopsys/dwc2/dwc2_common.c \
 | |
| 	$(ST_CMSIS)/Source/Templates/system_${ST_PREFIX}.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_cortex.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_dma.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_gpio.c \
 | |
|   ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_i2c.c \
 | |
|   ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_i2c_ex.c \
 | |
|   $(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_pwr.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_pwr_ex.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_rcc.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_rcc_ex.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_uart.c \
 | |
| 	$(ST_HAL_DRIVER)/Src/${ST_PREFIX}_hal_uart_ex.c \
 | |
| 
 | |
| INC += \
 | |
| 	$(TOP)/$(BOARD_PATH) \
 | |
| 	$(TOP)/lib/CMSIS_5/CMSIS/Core/Include \
 | |
| 	$(TOP)/$(ST_CMSIS)/Include \
 | |
| 	$(TOP)/$(ST_HAL_DRIVER)/Inc
 | |
| 
 | |
| # Startup
 | |
| SRC_S_GCC += $(ST_CMSIS)/Source/Templates/gcc/startup_$(MCU_VARIANT).s
 | |
| SRC_S_IAR += $(ST_CMSIS)/Source/Templates/iar/startup_$(MCU_VARIANT).s
 | |
| 
 | |
| # Linker
 | |
| LD_FILE_IAR ?= $(ST_CMSIS)/Source/Templates/iar/linker/$(MCU_VARIANT)_flash.icf
 | 
