| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-13 12:56:33 +07:00
										 |  |  | # Build directory
 | 
					
						
							| 
									
										
										
										
											2021-01-26 21:19:14 +07:00
										 |  |  | BUILD := _build/$(BOARD) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-10 17:24:36 +07:00
										 |  |  | PROJECT := $(notdir $(CURDIR)) | 
					
						
							| 
									
										
										
										
											2021-01-26 21:19:14 +07:00
										 |  |  | BIN := $(TOP)/_bin/$(BOARD)/$(notdir $(CURDIR)) | 
					
						
							| 
									
										
										
										
											2021-01-13 12:56:33 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							| 
									
										
										
										
											2019-05-01 14:27:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-01 20:25:55 +07:00
										 |  |  | # Fetch submodules depended by family
 | 
					
						
							| 
									
										
										
										
											2021-03-10 13:26:14 +07:00
										 |  |  | fetch_submodule_if_empty = $(if $(wildcard $(TOP)/$1/*),,$(info $(shell git -C $(TOP) submodule update --init $1))) | 
					
						
							| 
									
										
										
										
											2021-03-04 22:53:02 +07:00
										 |  |  | ifdef DEPS_SUBMODULES | 
					
						
							| 
									
										
										
										
											2021-03-10 13:26:14 +07:00
										 |  |  |   $(foreach s,$(DEPS_SUBMODULES),$(call fetch_submodule_if_empty,$(s))) | 
					
						
							| 
									
										
										
										
											2021-03-01 20:25:55 +07:00
										 |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-25 14:06:51 +07:00
										 |  |  | #-------------- Cross Compiler  ------------
 | 
					
						
							|  |  |  | # Can be set by board, default to ARM GCC
 | 
					
						
							|  |  |  | CROSS_COMPILE ?= arm-none-eabi- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CC = $(CROSS_COMPILE)gcc | 
					
						
							|  |  |  | CXX = $(CROSS_COMPILE)g++ | 
					
						
							| 
									
										
										
										
											2021-04-16 14:23:27 +01:00
										 |  |  | GDB = $(CROSS_COMPILE)gdb | 
					
						
							| 
									
										
										
										
											2020-03-25 14:06:51 +07:00
										 |  |  | OBJCOPY = $(CROSS_COMPILE)objcopy | 
					
						
							|  |  |  | SIZE = $(CROSS_COMPILE)size | 
					
						
							|  |  |  | MKDIR = mkdir | 
					
						
							| 
									
										
										
										
											2021-03-03 20:07:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-14 01:19:43 +09:00
										 |  |  | ifeq ($(CMDEXE),1) | 
					
						
							| 
									
										
										
										
											2021-03-03 20:07:17 +07:00
										 |  |  |   CP = copy | 
					
						
							|  |  |  |   RM = del | 
					
						
							| 
									
										
										
										
											2021-09-07 17:43:45 +07:00
										 |  |  |   PYTHON = python | 
					
						
							| 
									
										
										
										
											2021-01-10 20:46:29 +09:00
										 |  |  | else | 
					
						
							| 
									
										
										
										
											2021-03-03 20:07:17 +07:00
										 |  |  |   SED = sed | 
					
						
							|  |  |  |   CP = cp | 
					
						
							|  |  |  |   RM = rm | 
					
						
							| 
									
										
										
										
											2021-09-07 17:43:45 +07:00
										 |  |  |   PYTHON = python3 | 
					
						
							| 
									
										
										
										
											2021-01-10 20:46:29 +09:00
										 |  |  | endif | 
					
						
							| 
									
										
										
										
											2020-03-25 14:06:51 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #-------------- Source files and compiler flags --------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-03 20:07:17 +07:00
										 |  |  | INC   += $(TOP)/$(FAMILY_PATH) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-01 14:27:17 +07:00
										 |  |  | # Compiler Flags
 | 
					
						
							|  |  |  | CFLAGS += \
 | 
					
						
							| 
									
										
										
										
											2020-07-23 01:39:15 +07:00
										 |  |  |   -ggdb \
 | 
					
						
							|  |  |  |   -fdata-sections \
 | 
					
						
							|  |  |  |   -ffunction-sections \
 | 
					
						
							|  |  |  |   -fsingle-precision-constant \
 | 
					
						
							|  |  |  |   -fno-strict-aliasing \
 | 
					
						
							|  |  |  |   -Wdouble-promotion \
 | 
					
						
							|  |  |  |   -Wstrict-prototypes \
 | 
					
						
							| 
									
										
										
										
											2021-05-25 21:02:40 +07:00
										 |  |  |   -Wstrict-overflow \
 | 
					
						
							| 
									
										
										
										
											2020-07-23 01:39:15 +07:00
										 |  |  |   -Wall \
 | 
					
						
							|  |  |  |   -Wextra \
 | 
					
						
							|  |  |  |   -Werror \
 | 
					
						
							|  |  |  |   -Wfatal-errors \
 | 
					
						
							|  |  |  |   -Werror-implicit-function-declaration \
 | 
					
						
							|  |  |  |   -Wfloat-equal \
 | 
					
						
							|  |  |  |   -Wundef \
 | 
					
						
							|  |  |  |   -Wshadow \
 | 
					
						
							|  |  |  |   -Wwrite-strings \
 | 
					
						
							|  |  |  |   -Wsign-compare \
 | 
					
						
							|  |  |  |   -Wmissing-format-attribute \
 | 
					
						
							|  |  |  |   -Wunreachable-code \
 | 
					
						
							| 
									
										
										
										
											2021-05-25 21:02:40 +07:00
										 |  |  |   -Wcast-align \
 | 
					
						
							| 
									
										
										
										
											2021-10-17 16:26:27 +07:00
										 |  |  |   -Wcast-function-type \
 | 
					
						
							| 
									
										
										
										
											2021-10-18 00:13:40 +07:00
										 |  |  |   -Wcast-qual \
 | 
					
						
							|  |  |  |   -Wnull-dereference | 
					
						
							| 
									
										
										
										
											2020-07-23 01:39:15 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-01 14:27:17 +07:00
										 |  |  | # Debugging/Optimization
 | 
					
						
							|  |  |  | ifeq ($(DEBUG), 1) | 
					
						
							| 
									
										
										
										
											2020-07-23 01:39:15 +07:00
										 |  |  |   CFLAGS += -Og | 
					
						
							| 
									
										
										
										
											2019-05-01 14:27:17 +07:00
										 |  |  | else | 
					
						
							| 
									
										
										
										
											2020-07-23 01:39:15 +07:00
										 |  |  |   CFLAGS += -Os | 
					
						
							| 
									
										
										
										
											2019-10-03 14:22:43 +02:00
										 |  |  | endif | 
					
						
							| 
									
										
										
										
											2019-11-03 13:18:02 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 |