2016-11-09 21:20:55 -05:00
|
|
|
# Functionality common to both top-level project makefile (project.mk)
|
|
|
|
# and component makefiles (component_wrapper.mk)
|
2016-08-17 11:08:22 -04:00
|
|
|
#
|
|
|
|
|
2016-11-09 21:20:55 -05:00
|
|
|
# Include project config makefile, if it exists.
|
|
|
|
#
|
|
|
|
# (Note that we only rebuild this makefile automatically for some
|
|
|
|
# targets, see project_config.mk for details.)
|
2017-02-06 01:02:07 -05:00
|
|
|
SDKCONFIG_MAKEFILE ?= $(abspath $(BUILD_DIR_BASE)/include/config/auto.conf)
|
2017-04-26 06:26:21 -04:00
|
|
|
-include $(SDKCONFIG_MAKEFILE)
|
2016-11-09 21:20:55 -05:00
|
|
|
export SDKCONFIG_MAKEFILE # sub-makes (like bootloader) will reuse this path
|
|
|
|
|
2017-02-10 01:38:24 -05:00
|
|
|
# BATCH_BUILD flag disables interactive terminal features, defaults to verbose build
|
|
|
|
ifdef BATCH_BUILD
|
|
|
|
V ?= 1
|
|
|
|
endif
|
|
|
|
|
2016-08-17 11:08:22 -04:00
|
|
|
#Handling of V=1/VERBOSE=1 flag
|
2016-08-24 01:02:24 -04:00
|
|
|
#
|
|
|
|
# if V=1, $(summary) does nothing and $(details) will echo extra details
|
|
|
|
# if V is unset or not 1, $(summary) echoes a summary and $(details) does nothing
|
2016-12-03 17:11:22 -05:00
|
|
|
VERBOSE ?=
|
2016-08-17 11:08:22 -04:00
|
|
|
V ?= $(VERBOSE)
|
|
|
|
ifeq ("$(V)","1")
|
2016-08-24 01:02:24 -04:00
|
|
|
summary := @true
|
|
|
|
details := @echo
|
2016-08-17 11:08:22 -04:00
|
|
|
else
|
2016-08-24 01:02:24 -04:00
|
|
|
summary := @echo
|
|
|
|
details := @true
|
2017-09-05 02:10:00 -04:00
|
|
|
endif
|
2016-11-10 20:29:38 -05:00
|
|
|
|
|
|
|
# disable echoing of commands, directory names
|
2017-09-05 02:10:00 -04:00
|
|
|
MAKEFLAGS += --silent
|
|
|
|
|
|
|
|
ifdef CONFIG_MAKE_WARN_UNDEFINED_VARIABLES
|
|
|
|
MAKEFLAGS += --warn-undefined-variables
|
2016-08-17 11:08:22 -04:00
|
|
|
endif
|
|
|
|
|
|
|
|
# General make utilities
|
|
|
|
|
|
|
|
# convenience variable for printing an 80 asterisk wide separator line
|
|
|
|
SEPARATOR:="*******************************************************************************"
|
|
|
|
|
2016-11-03 02:33:30 -04:00
|
|
|
# macro to remove quotes from an argument, ie $(call dequote,$(CONFIG_BLAH))
|
2016-08-17 11:08:22 -04:00
|
|
|
define dequote
|
|
|
|
$(subst ",,$(1))
|
|
|
|
endef
|
|
|
|
# " comment kept here to keep syntax highlighting happy
|
2016-11-03 02:33:30 -04:00
|
|
|
|
|
|
|
|
|
|
|
# macro to keep an absolute path as-is, but resolve a relative path
|
|
|
|
# against a particular parent directory
|
|
|
|
#
|
|
|
|
# $(1) path to resolve
|
|
|
|
# $(2) directory to resolve non-absolute path against
|
|
|
|
#
|
|
|
|
# Path and directory don't have to exist (definition of a "relative
|
|
|
|
# path" is one that doesn't start with /)
|
|
|
|
#
|
|
|
|
# $(2) can contain a trailing forward slash or not, result will not
|
|
|
|
# double any path slashes.
|
|
|
|
#
|
|
|
|
# example $(call resolvepath,$(CONFIG_PATH),$(CONFIG_DIR))
|
|
|
|
define resolvepath
|
2016-12-11 23:54:30 -05:00
|
|
|
$(foreach dir,$(1),$(if $(filter /%,$(dir)),$(dir),$(subst //,/,$(2)/$(dir))))
|
2016-11-03 02:33:30 -04:00
|
|
|
endef
|
2016-12-22 00:32:19 -05:00
|
|
|
|
|
|
|
|
|
|
|
# macro to include a target only if it's on the list of targets that make
|
|
|
|
# was invoked with
|
|
|
|
#
|
|
|
|
# This allows you to have something like an "order-only phony prerequisite",
|
|
|
|
# ie a prerequisite that determines an order phony targets have to run in.
|
|
|
|
#
|
|
|
|
# Because normal order-only prerequisites don't work with phony targets.
|
|
|
|
#
|
|
|
|
# example $(call prereq_if_explicit,erase_flash)
|
|
|
|
define prereq_if_explicit
|
|
|
|
$(filter $(1),$(MAKECMDGOALS))
|
|
|
|
endef
|
2017-05-31 05:20:29 -04:00
|
|
|
|
|
|
|
# macro to kill duplicate items in a list without messing up the sort order of the list.
|
|
|
|
# Will only keep the unique items; if there are non-unique items in the list, it will remove
|
|
|
|
# the later recurring ones so only the first one remains.
|
|
|
|
# Copied from http://stackoverflow.com/questions/16144115/makefile-remove-duplicate-words-without-sorting
|
|
|
|
define uniq
|
|
|
|
$(if $1,$(firstword $1) $(call uniq,$(filter-out $(firstword $1),$1)))
|
|
|
|
endef
|