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)
|
|
|
|
|
|
|
|
PROJECT := $(BOARD)-$(notdir $(CURDIR))
|
|
|
|
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))))
|
2020-03-25 14:06:51 +07:00
|
|
|
|
2021-01-25 23:40:52 +07:00
|
|
|
# TODO Check if submodule haven't checkout yet
|
|
|
|
fetch_submodule_if_empty = \
|
|
|
|
ifeq ($(wildcard $(TOP)/$1/*),) \
|
|
|
|
$(info $(shell git -C $(TOP) submodule update --init)) \
|
|
|
|
endif
|
|
|
|
|
2020-11-28 00:16:28 +07:00
|
|
|
#-------------- Select the board to build for. ------------
|
|
|
|
#BOARD_LIST = $(sort $(subst /.,,$(subst $(TOP)/hw/bsp/,,$(wildcard $(TOP)/hw/bsp/*/.))))
|
|
|
|
#ifeq ($(filter $(BOARD),$(BOARD_LIST)),)
|
|
|
|
# $(info You must provide a BOARD parameter with 'BOARD=', supported boards are:)
|
|
|
|
# $(foreach b,$(BOARD_LIST),$(info - $(b)))
|
|
|
|
# $(error Invalid BOARD specified)
|
|
|
|
#endif
|
|
|
|
|
2021-01-13 12:56:33 +07:00
|
|
|
# Board without family
|
|
|
|
BOARD_PATH := $(subst $(TOP)/,,$(wildcard $(TOP)/hw/bsp/$(BOARD)))
|
|
|
|
FAMILY :=
|
|
|
|
|
|
|
|
# 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),)
|
|
|
|
$(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-01-22 14:58:32 +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-01-25 23:40:52 +07:00
|
|
|
#TODO $(call fetch_submodule_if_empty,lib/sct_neopixel)
|
|
|
|
|
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++
|
|
|
|
OBJCOPY = $(CROSS_COMPILE)objcopy
|
|
|
|
SIZE = $(CROSS_COMPILE)size
|
|
|
|
MKDIR = mkdir
|
2021-01-14 01:19:43 +09:00
|
|
|
ifeq ($(CMDEXE),1)
|
2021-01-10 20:46:29 +09:00
|
|
|
CP = copy
|
|
|
|
RM = del
|
|
|
|
else
|
2020-03-25 14:06:51 +07:00
|
|
|
SED = sed
|
|
|
|
CP = cp
|
|
|
|
RM = rm
|
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
|
|
|
|
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 \
|
|
|
|
-Wall \
|
|
|
|
-Wextra \
|
|
|
|
-Werror \
|
|
|
|
-Wfatal-errors \
|
|
|
|
-Werror-implicit-function-declaration \
|
|
|
|
-Wfloat-equal \
|
|
|
|
-Wundef \
|
|
|
|
-Wshadow \
|
|
|
|
-Wwrite-strings \
|
|
|
|
-Wsign-compare \
|
|
|
|
-Wmissing-format-attribute \
|
|
|
|
-Wunreachable-code \
|
|
|
|
-Wcast-align
|
|
|
|
|
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),)
|
|
|
|
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
|
2020-04-22 17:08:41 +07:00
|
|
|
ifeq ($(LOGGER),rtt)
|
2020-07-23 01:39:15 +07:00
|
|
|
RTT_SRC = lib/SEGGER_RTT
|
|
|
|
CFLAGS += -DLOGGER_RTT -DSEGGER_RTT_MODE_DEFAULT=SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL
|
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
|