1b0104773SPascal BrandSHELL = /bin/bash 2b0104773SPascal Brand 380b563f5SJerome Forissier# It can happen that a makefile calls us, which contains an 'export' directive 480b563f5SJerome Forissier# or the '.EXPORT_ALL_VARIABLES:' special target. In this case, all the make 580b563f5SJerome Forissier# variables are added to the environment for each line of the recipes, so that 680b563f5SJerome Forissier# any sub-makefile can use them. 780b563f5SJerome Forissier# We have observed this can cause issues such as 'Argument list too long' 880b563f5SJerome Forissier# errors as the shell runs out of memory. 980b563f5SJerome Forissier# Since this Makefile won't call any sub-makefiles, and since the commands do 1080b563f5SJerome Forissier# not expect to implicitely obtain any make variable from the environment, we 1180b563f5SJerome Forissier# can safely cancel this export mechanism. Unfortunately, it can't be done 1280b563f5SJerome Forissier# globally, only by name. Let's unexport MAKEFILE_LIST which is by far the 1380b563f5SJerome Forissier# biggest one due to our way of tracking dependencies and compile flags 1480b563f5SJerome Forissier# (we include many *.cmd and *.d files). 1580b563f5SJerome Forissierunexport MAKEFILE_LIST 1680b563f5SJerome Forissier 17b0104773SPascal Brand.PHONY: all 18b0104773SPascal Brandall: 19b0104773SPascal Brand 2029f1a45dSJens Wiklander.PHONY: mem_usage 2129f1a45dSJens Wiklandermem_usage: 2229f1a45dSJens Wiklander 23dde0e235Setienne carriere# log and load eventual tee config file 24dde0e235Setienne carriere# path is absolute or relative to current source root directory. 25dde0e235Setienne carriereifdef CFG_OPTEE_CONFIG 26dde0e235Setienne carriere$(info Loading OPTEE configuration file $(CFG_OPTEE_CONFIG)) 27dde0e235Setienne carriereinclude $(CFG_OPTEE_CONFIG) 28dde0e235Setienne carriereendif 29dde0e235Setienne carriere 3071767a5cSJerome Forissier# If $(PLATFORM) is defined and contains a hyphen, parse it as 3171767a5cSJerome Forissier# $(PLATFORM)-$(PLATFORM_FLAVOR) for convenience 3271767a5cSJerome Forissierifneq (,$(findstring -,$(PLATFORM))) 3371767a5cSJerome Forissierops := $(join PLATFORM PLATFORM_FLAVOR,$(addprefix =,$(subst -, ,$(PLATFORM)))) 3471767a5cSJerome Forissier$(foreach op,$(ops),$(eval override $(op))) 3571767a5cSJerome Forissierendif 3671767a5cSJerome Forissier 37b0104773SPascal Brand# Make these default for now 38abe38974SJens WiklanderARCH ?= arm 39a75f2e14SJerome ForissierPLATFORM ?= vexpress 409fc53171SJerome Forissier# Default value for PLATFORM_FLAVOR is set in plat-$(PLATFORM)/conf.mk 419ac870c9SJerome Forissierifeq ($O,) 429ac870c9SJerome ForissierO := out 439ac870c9SJerome Forissierout-dir := $(O)/$(ARCH)-plat-$(PLATFORM) 449ac870c9SJerome Forissierelse 459ac870c9SJerome Forissierout-dir := $(O) 469ac870c9SJerome Forissierendif 47b0104773SPascal Brand 48b0104773SPascal Brandarch_$(ARCH) := y 49b0104773SPascal Brand 50b0104773SPascal Brandifneq ($V,1) 51b0104773SPascal Brandq := @ 52b0104773SPascal Brandcmd-echo := true 5362428631SJens Wiklandercmd-echo-silent := echo 54b0104773SPascal Brandelse 55b0104773SPascal Brandq := 56b0104773SPascal Brandcmd-echo := echo 5762428631SJens Wiklandercmd-echo-silent := true 58b0104773SPascal Brandendif 59b0104773SPascal Brand 6062428631SJens Wiklanderifneq ($(filter 4.%,$(MAKE_VERSION)),) # make-4 6162428631SJens Wiklanderifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),) 6262428631SJens Wiklandercmd-echo-silent := true 6362428631SJens Wiklanderendif 6462428631SJens Wiklanderelse # make-3.8x 653dc79b0dSPascal Brandifneq ($(findstring s, $(MAKEFLAGS)),) 6662428631SJens Wiklandercmd-echo-silent := true 6762428631SJens Wiklanderendif 6862428631SJens Wiklanderendif 6962428631SJens Wiklander 7062428631SJens Wiklander 71b0104773SPascal Brandinclude core/core.mk 72b0104773SPascal Brand 73bc33bbd9SJens Wiklander# Platform config is supposed to assign the targets 74bc33bbd9SJens Wiklanderta-targets ?= user_ta 75bc33bbd9SJens Wiklander 766fbac37eSJens Wiklanderifeq ($(CFG_WITH_USER_TA),y) 77bc33bbd9SJens Wiklanderdefine build-ta-target 78bc33bbd9SJens Wiklanderta-target := $(1) 79b0104773SPascal Brandinclude ta/ta.mk 80bc33bbd9SJens Wiklanderendef 81bc33bbd9SJens Wiklander$(foreach t, $(ta-targets), $(eval $(call build-ta-target, $(t)))) 826fbac37eSJens Wiklanderendif 83b0104773SPascal Brand 849ac870c9SJerome Forissierinclude mk/cleandirs.mk 859ac870c9SJerome Forissier 86b0104773SPascal Brand.PHONY: clean 87b0104773SPascal Brandclean: 889ac870c9SJerome Forissier @$(cmd-echo-silent) ' CLEAN $(out-dir)' 89b0104773SPascal Brand ${q}rm -f $(cleanfiles) 90*30a44336SJerome Forissier ${q}dirs="$(call cleandirs-for-rmdir)"; if [ "$$dirs" ]; then $(RMDIR) $$dirs; fi 919ac870c9SJerome Forissier @if [ "$(out-dir)" != "$(O)" ]; then $(cmd-echo-silent) ' CLEAN $(O)'; fi 92*30a44336SJerome Forissier ${q}if [ -d "$(O)" ]; then $(RMDIR) $(O); fi 93b0104773SPascal Brand 94b0104773SPascal Brand.PHONY: cscope 95b0104773SPascal Brandcscope: 960047cb63SJerome Forissier @echo ' CSCOPE .' 97b0104773SPascal Brand ${q}rm -f cscope.* 98b0104773SPascal Brand ${q}find $(PWD) -name "*.[chSs]" > cscope.files 99b0104773SPascal Brand ${q}cscope -b -q -k 100