| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-24 19:21:26 +07:00
										 |  |  | #-------------------------------------------------------------
 | 
					
						
							|  |  |  | # Toolchain
 | 
					
						
							|  |  |  | # Can be changed via TOOLCHAIN=gcc|iar or CC=arm-none-eabi-gcc|iccarm|clang
 | 
					
						
							|  |  |  | #-------------------------------------------------------------
 | 
					
						
							|  |  |  | ifneq (,$(findstring clang,$(CC))) | 
					
						
							|  |  |  |   TOOLCHAIN = clang | 
					
						
							|  |  |  | else ifneq (,$(findstring iccarm,$(CC))) | 
					
						
							|  |  |  |   TOOLCHAIN = iar | 
					
						
							|  |  |  | else ifneq (,$(findstring gcc,$(CC))) | 
					
						
							|  |  |  |   TOOLCHAIN = gcc | 
					
						
							|  |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Default to GCC
 | 
					
						
							|  |  |  | ifndef TOOLCHAIN | 
					
						
							|  |  |  |   TOOLCHAIN = gcc | 
					
						
							|  |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-06 13:25:56 +07:00
										 |  |  | #-------------- TOP and CURRENT_PATH ------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-23 11:44:14 +07:00
										 |  |  | # 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.
 | 
					
						
							| 
									
										
										
										
											2023-03-06 13:25:56 +07:00
										 |  |  | THIS_MAKEFILE := $(lastword $(MAKEFILE_LIST)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-23 20:19:14 +07:00
										 |  |  | # strip off /examples/build_system/make to get for example ../../..
 | 
					
						
							| 
									
										
										
										
											2023-03-06 13:25:56 +07:00
										 |  |  | # and Set TOP to an absolute path
 | 
					
						
							| 
									
										
										
										
											2023-11-23 20:19:14 +07:00
										 |  |  | TOP = $(abspath $(subst make.mk,../../..,$(THIS_MAKEFILE))) | 
					
						
							| 
									
										
										
										
											2023-03-06 13:25:56 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Set CURRENT_PATH to the relative path from TOP to the current directory, ie examples/device/cdc_msc_freertos
 | 
					
						
							|  |  |  | CURRENT_PATH = $(subst $(TOP)/,,$(abspath .)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-24 16:17:33 +07:00
										 |  |  | #-------------- Linux/Windows ------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-06 13:25:56 +07:00
										 |  |  | # 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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-24 16:17:33 +07:00
										 |  |  | ifeq ($(CMDEXE),1) | 
					
						
							|  |  |  |   CP = copy | 
					
						
							|  |  |  |   RM = del | 
					
						
							|  |  |  |   MKDIR = mkdir | 
					
						
							|  |  |  |   PYTHON = python | 
					
						
							|  |  |  | else | 
					
						
							|  |  |  |   CP = cp | 
					
						
							|  |  |  |   RM = rm | 
					
						
							|  |  |  |   MKDIR = mkdir | 
					
						
							|  |  |  |   PYTHON = python3 | 
					
						
							|  |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 21:18:07 +07:00
										 |  |  | #-------------------------------------------------------------
 | 
					
						
							|  |  |  | # Board / Family
 | 
					
						
							|  |  |  | #-------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2020-11-28 00:16:28 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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),) | 
					
						
							| 
									
										
										
										
											2024-04-24 16:17:33 +07:00
										 |  |  |   BOARD_PATH := hw/bsp/$(BOARD) | 
					
						
							|  |  |  |   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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 21:18:07 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-25 11:31:19 +07:00
										 |  |  | ifdef CFLAGS_CLI | 
					
						
							|  |  |  | 	CFLAGS += $(CFLAGS_CLI) | 
					
						
							|  |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							| 
									
										
										
										
											2024-04-04 10:55:14 +07:00
										 |  |  |   CMAKE_DEFSYM +=	-DMAX3421_HOST=1 | 
					
						
							| 
									
										
										
										
											2023-09-11 11:35:51 +07:00
										 |  |  | 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),) | 
					
						
							| 
									
										
										
										
											2024-04-24 19:21:26 +07:00
										 |  |  |   CMAKE_DEFSYM +=	-DLOGGER=$(LOGGER) | 
					
						
							| 
									
										
										
										
											2021-01-29 11:24:05 +07:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2023-11-23 11:44:14 +07:00
										 |  |  |   include ${TOP}/examples/build_system/make/cpu/$(CPU_CORE).mk | 
					
						
							| 
									
										
										
										
											2023-06-24 19:08:37 +07:00
										 |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-24 17:35:37 +07:00
										 |  |  | # toolchain specific
 | 
					
						
							| 
									
										
										
										
											2023-11-23 11:44:14 +07:00
										 |  |  | include ${TOP}/examples/build_system/make/toolchain/arm_$(TOOLCHAIN).mk | 
					
						
							| 
									
										
										
										
											2024-04-24 16:17:33 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 21:18:07 +07:00
										 |  |  | #---------------------- FreeRTOS -----------------------
 | 
					
						
							|  |  |  | FREERTOS_SRC = lib/FreeRTOS-Kernel | 
					
						
							|  |  |  | FREERTOS_PORTABLE_PATH = $(FREERTOS_SRC)/portable/$(if $(findstring iar,$(TOOLCHAIN)),IAR,GCC) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ifeq ($(RTOS),freertos) | 
					
						
							|  |  |  | 	SRC_C += \
 | 
					
						
							|  |  |  | 		$(FREERTOS_SRC)/list.c \
 | 
					
						
							|  |  |  | 		$(FREERTOS_SRC)/queue.c \
 | 
					
						
							|  |  |  | 		$(FREERTOS_SRC)/tasks.c \
 | 
					
						
							|  |  |  | 		$(FREERTOS_SRC)/timers.c \
 | 
					
						
							|  |  |  | 		$(subst $(TOP)/,,$(wildcard $(TOP)/$(FREERTOS_PORTABLE_SRC)/*.c)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	SRC_S += $(subst $(TOP)/,,$(wildcard $(TOP)/$(FREERTOS_PORTABLE_SRC)/*.s)) | 
					
						
							|  |  |  | 	INC += \
 | 
					
						
							|  |  |  | 		$(TOP)/hw/bsp/$(FAMILY)/FreeRTOSConfig \
 | 
					
						
							|  |  |  | 		$(TOP)/$(FREERTOS_SRC)/include \
 | 
					
						
							|  |  |  | 		$(TOP)/$(FREERTOS_PORTABLE_SRC) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 21:55:28 +07:00
										 |  |  | 	CFLAGS += -DCFG_TUSB_OS=OPT_OS_FREERTOS | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 21:18:07 +07:00
										 |  |  | 	# Suppress FreeRTOSConfig.h warnings | 
					
						
							|  |  |  | 	CFLAGS_GCC += -Wno-error=redundant-decls | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	# Suppress FreeRTOS source warnings | 
					
						
							|  |  |  | 	CFLAGS_GCC += -Wno-error=cast-qual | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	# FreeRTOS (lto + Os) linker issue | 
					
						
							|  |  |  | 	LDFLAGS_GCC += -Wl,--undefined=vTaskSwitchContext | 
					
						
							|  |  |  | endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #---------------- Helper ----------------
 | 
					
						
							| 
									
										
										
										
											2024-04-24 16:17:33 +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)))) |