2020-03-25 14:06:51 +07:00
|
|
|
# ---------------------------------------
|
2019-05-01 14:27:17 +07:00
|
|
|
# Common make definition for all examples
|
2020-03-25 14:06:51 +07:00
|
|
|
# ---------------------------------------
|
2019-05-01 14:27:17 +07:00
|
|
|
|
2023-06-24 17:35:37 +07:00
|
|
|
# Supported toolchain: gcc, iar
|
2023-05-19 16:02:26 +07:00
|
|
|
TOOLCHAIN ?= gcc
|
|
|
|
|
2023-03-06 13:25:56 +07:00
|
|
|
#-------------- TOP and CURRENT_PATH ------------
|
|
|
|
|
|
|
|
# Set TOP to be the path to get from the current directory (where make was
|
|
|
|
# invoked) to the top of the tree. $(lastword $(MAKEFILE_LIST)) returns
|
|
|
|
# the name of this makefile relative to where make was invoked.
|
|
|
|
THIS_MAKEFILE := $(lastword $(MAKEFILE_LIST))
|
|
|
|
|
|
|
|
# strip off /tools/top.mk to get for example ../../..
|
|
|
|
# and Set TOP to an absolute path
|
|
|
|
TOP = $(abspath $(subst make.mk,..,$(THIS_MAKEFILE)))
|
|
|
|
|
|
|
|
# Set CURRENT_PATH to the relative path from TOP to the current directory, ie examples/device/cdc_msc_freertos
|
|
|
|
CURRENT_PATH = $(subst $(TOP)/,,$(abspath .))
|
|
|
|
|
|
|
|
# Detect whether shell style is windows or not
|
|
|
|
# https://stackoverflow.com/questions/714100/os-detecting-makefile/52062069#52062069
|
|
|
|
ifeq '$(findstring ;,$(PATH))' ';'
|
|
|
|
# PATH contains semicolon - so we're definitely on Windows.
|
|
|
|
CMDEXE := 1
|
|
|
|
|
|
|
|
# makefile shell commands should use syntax for DOS CMD, not unix sh
|
|
|
|
# Force DOS command shell on Windows.
|
|
|
|
SHELL := cmd.exe
|
|
|
|
endif
|
|
|
|
|
2020-03-25 14:06:51 +07:00
|
|
|
# Handy check parameter function
|
2019-05-29 16:56:26 +07:00
|
|
|
check_defined = \
|
|
|
|
$(strip $(foreach 1,$1, \
|
|
|
|
$(call __check_defined,$1,$(strip $(value 2)))))
|
|
|
|
__check_defined = \
|
|
|
|
$(if $(value $1),, \
|
|
|
|
$(error Undefined make flag: $1$(if $2, ($2))))
|
2021-01-25 23:40:52 +07:00
|
|
|
|
2023-06-24 17:35:37 +07:00
|
|
|
|
|
|
|
# Build directory
|
|
|
|
BUILD := _build/$(BOARD)
|
|
|
|
|
|
|
|
PROJECT := $(notdir $(CURDIR))
|
|
|
|
BIN := $(TOP)/_bin/$(BOARD)/$(notdir $(CURDIR))
|
|
|
|
|
2020-11-28 00:16:28 +07:00
|
|
|
#-------------- Select the board to build for. ------------
|
|
|
|
|
2021-01-13 12:56:33 +07:00
|
|
|
# Board without family
|
2021-03-02 12:24:12 +07:00
|
|
|
ifneq ($(wildcard $(TOP)/hw/bsp/$(BOARD)/board.mk),)
|
|
|
|
BOARD_PATH := hw/bsp/$(BOARD)
|
2021-01-13 12:56:33 +07:00
|
|
|
FAMILY :=
|
2021-03-02 12:24:12 +07:00
|
|
|
endif
|
2021-01-13 12:56:33 +07:00
|
|
|
|
|
|
|
# Board within family
|
2020-11-28 00:16:28 +07:00
|
|
|
ifeq ($(BOARD_PATH),)
|
2021-01-13 12:56:33 +07:00
|
|
|
BOARD_PATH := $(subst $(TOP)/,,$(wildcard $(TOP)/hw/bsp/*/boards/$(BOARD)))
|
|
|
|
FAMILY := $(word 3, $(subst /, ,$(BOARD_PATH)))
|
|
|
|
FAMILY_PATH = hw/bsp/$(FAMILY)
|
2020-11-28 00:16:28 +07:00
|
|
|
endif
|
|
|
|
|
2021-01-13 12:56:33 +07:00
|
|
|
ifeq ($(BOARD_PATH),)
|
2021-03-01 20:25:55 +07:00
|
|
|
$(info You must provide a BOARD parameter with 'BOARD=')
|
2021-01-13 12:56:33 +07:00
|
|
|
$(error Invalid BOARD specified)
|
|
|
|
endif
|
2020-11-28 00:16:28 +07:00
|
|
|
|
2021-01-13 12:56:33 +07:00
|
|
|
ifeq ($(FAMILY),)
|
|
|
|
include $(TOP)/hw/bsp/$(BOARD)/board.mk
|
|
|
|
else
|
|
|
|
# Include Family and Board specific defs
|
2021-03-17 17:09:25 +07:00
|
|
|
include $(TOP)/$(FAMILY_PATH)/family.mk
|
2021-01-13 12:56:33 +07:00
|
|
|
SRC_C += $(subst $(TOP)/,,$(wildcard $(TOP)/$(FAMILY_PATH)/*.c))
|
|
|
|
endif
|
2019-05-01 14:27:17 +07:00
|
|
|
|
2023-03-06 14:31:18 +07:00
|
|
|
#-------------- Cross Compiler ------------
|
2023-05-19 16:02:26 +07:00
|
|
|
|
2023-03-06 14:31:18 +07:00
|
|
|
# Can be set by board, default to ARM GCC
|
|
|
|
CROSS_COMPILE ?= arm-none-eabi-
|
|
|
|
|
2023-06-24 17:35:37 +07:00
|
|
|
ifeq ($(TOOLCHAIN),iar)
|
|
|
|
CC := iccarm
|
|
|
|
USE_IAR = 1
|
2023-03-06 14:31:18 +07:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(CMDEXE),1)
|
|
|
|
CP = copy
|
|
|
|
RM = del
|
|
|
|
MKDIR = mkdir
|
|
|
|
PYTHON = python
|
|
|
|
else
|
|
|
|
CP = cp
|
|
|
|
RM = rm
|
|
|
|
MKDIR = mkdir
|
|
|
|
PYTHON = python3
|
|
|
|
endif
|
|
|
|
|
2020-03-25 14:06:51 +07:00
|
|
|
#-------------- Source files and compiler flags --------------
|
2023-06-24 17:35:37 +07:00
|
|
|
# tinyusb makefile
|
|
|
|
include $(TOP)/src/tinyusb.mk
|
2023-09-11 11:35:51 +07:00
|
|
|
SRC_C += $(TINYUSB_SRC_C)
|
2020-03-25 14:06:51 +07:00
|
|
|
|
2020-11-28 00:16:28 +07:00
|
|
|
# Include all source C in family & board folder
|
2019-10-12 00:00:08 +07:00
|
|
|
SRC_C += hw/bsp/board.c
|
2020-11-28 00:16:28 +07:00
|
|
|
SRC_C += $(subst $(TOP)/,,$(wildcard $(TOP)/$(BOARD_PATH)/*.c))
|
2019-05-14 13:59:45 +07:00
|
|
|
|
2023-06-24 17:35:37 +07:00
|
|
|
INC += \
|
|
|
|
$(TOP)/$(FAMILY_PATH) \
|
|
|
|
$(TOP)/src \
|
|
|
|
|
2023-08-06 22:49:45 +09:00
|
|
|
BOARD_UPPER = $(subst a,A,$(subst b,B,$(subst c,C,$(subst d,D,$(subst e,E,$(subst f,F,$(subst g,G,$(subst h,H,$(subst i,I,$(subst j,J,$(subst k,K,$(subst l,L,$(subst m,M,$(subst n,N,$(subst o,O,$(subst p,P,$(subst q,Q,$(subst r,R,$(subst s,S,$(subst t,T,$(subst u,U,$(subst v,V,$(subst w,W,$(subst x,X,$(subst y,Y,$(subst z,Z,$(subst -,_,$(BOARD))))))))))))))))))))))))))))
|
2023-07-31 19:09:40 +07:00
|
|
|
CFLAGS += -DBOARD_$(BOARD_UPPER)
|
2019-11-03 13:18:02 +07:00
|
|
|
|
2023-09-11 11:35:51 +07:00
|
|
|
# use max3421 as host controller
|
|
|
|
ifeq (${MAX3421_HOST},1)
|
|
|
|
SRC_C += src/portable/analog/max3421/hcd_max3421.c
|
|
|
|
CFLAGS += -DCFG_TUH_MAX3421=1
|
|
|
|
endif
|
|
|
|
|
2020-04-22 17:08:41 +07:00
|
|
|
# Log level is mapped to TUSB DEBUG option
|
2019-11-03 13:18:02 +07:00
|
|
|
ifneq ($(LOG),)
|
2021-01-29 11:24:05 +07:00
|
|
|
CMAKE_DEFSYM += -DLOG=$(LOG)
|
2019-11-03 13:18:02 +07:00
|
|
|
CFLAGS += -DCFG_TUSB_DEBUG=$(LOG)
|
2019-05-01 14:27:17 +07:00
|
|
|
endif
|
2020-04-22 17:08:41 +07:00
|
|
|
|
2020-04-22 19:18:03 +07:00
|
|
|
# Logger: default is uart, can be set to rtt or swo
|
2021-01-29 11:24:05 +07:00
|
|
|
ifneq ($(LOGGER),)
|
|
|
|
CMAKE_DEFSYM += -DLOGGER=$(LOGGER)
|
|
|
|
endif
|
|
|
|
|
2020-04-22 17:08:41 +07:00
|
|
|
ifeq ($(LOGGER),rtt)
|
2020-07-23 01:39:15 +07:00
|
|
|
CFLAGS += -DLOGGER_RTT -DSEGGER_RTT_MODE_DEFAULT=SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL
|
2021-01-29 11:24:05 +07:00
|
|
|
RTT_SRC = lib/SEGGER_RTT
|
2020-04-22 17:08:41 +07:00
|
|
|
INC += $(TOP)/$(RTT_SRC)/RTT
|
|
|
|
SRC_C += $(RTT_SRC)/RTT/SEGGER_RTT.c
|
2020-04-22 19:18:03 +07:00
|
|
|
else ifeq ($(LOGGER),swo)
|
2020-07-23 01:39:15 +07:00
|
|
|
CFLAGS += -DLOGGER_SWO
|
2020-04-22 17:08:41 +07:00
|
|
|
endif
|
2023-06-24 17:35:37 +07:00
|
|
|
|
2023-06-24 19:08:37 +07:00
|
|
|
# CPU specific flags
|
|
|
|
ifdef CPU_CORE
|
|
|
|
include $(TOP)/tools/make/cpu/$(CPU_CORE).mk
|
|
|
|
endif
|
|
|
|
|
2023-06-24 17:35:37 +07:00
|
|
|
# toolchain specific
|
|
|
|
include $(TOP)/tools/make/toolchain/arm_$(TOOLCHAIN).mk
|