1b0104773SPascal Brand# Get the dir of the ta-dev-kit, requires make version 3.81 or later 24334e8d7SJerome Forissierta-dev-kit-dir := $(patsubst %/,%,$(abspath $(dir $(lastword $(MAKEFILE_LIST)))..)) 3b0104773SPascal Brand 4b0104773SPascal Brand.PHONY: all 5b0104773SPascal Brandall: 6b0104773SPascal Brand 7bc33bbd9SJens Wiklanderinclude $(ta-dev-kit-dir)/mk/conf.mk 835b4ef75SJens Wiklanderta-dev-kit-dir$(sm) := $(ta-dev-kit-dir) 9bc33bbd9SJens Wiklander 10f8896d13SJerome Forissierifneq (1, $(words $(BINARY) $(LIBNAME) $(SHLIBNAME))) 11f8896d13SJerome Forissier$(error You must specify exactly one of BINARY, LIBNAME or SHLIBNAME) 12ceae7156SJerome Forissierendif 13ceae7156SJerome Forissier 14b0104773SPascal Brandifneq ($O,) 154334e8d7SJerome Forissierout-dir := $O 16c3c7db16SJerome Forissierelse 17c3c7db16SJerome Forissierout-dir := . 18b0104773SPascal Brandendif 1935b4ef75SJens Wiklanderlink-out-dir := $(out-dir) # backward compat 2035b4ef75SJens Wiklanderlink-out-dir$(sm) := $(out-dir) 2135b4ef75SJens Wiklander 22d58d79ecSJens Wiklanderuser-ta-uuid := $(BINARY) 23682f256cSSumit Garguser-ta-version := $(if $(CFG_TA_VERSION),$(CFG_TA_VERSION),0) 24d58d79ecSJens Wiklanderuser-ta-ldadd := $(LDADD) 2535b4ef75SJens Wiklanderlibname := $(LIBNAME) 2635b4ef75SJens Wiklandershlibname := $(SHLIBNAME) 2735b4ef75SJens Wiklandershlibuuid := $(SHLIBUUID) 2835b4ef75SJens Wiklander 29b0104773SPascal Brand 30b0104773SPascal Brandifneq ($V,1) 31b0104773SPascal Brandq := @ 32b0104773SPascal Brandcmd-echo := true 3362428631SJens Wiklandercmd-echo-silent := echo 34b0104773SPascal Brandelse 35b0104773SPascal Brandq := 36b0104773SPascal Brandcmd-echo := echo 3762428631SJens Wiklandercmd-echo-silent := true 38b0104773SPascal Brandendif 39b0104773SPascal Brand 4062428631SJens Wiklanderifneq ($(filter 4.%,$(MAKE_VERSION)),) # make-4 4162428631SJens Wiklanderifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),) 4262428631SJens Wiklandercmd-echo-silent := true 4362428631SJens Wiklanderendif 4462428631SJens Wiklanderelse # make-3.8x 453dc79b0dSPascal Brandifneq ($(findstring s, $(MAKEFLAGS)),) 4662428631SJens Wiklandercmd-echo-silent := true 4762428631SJens Wiklanderendif 4862428631SJens Wiklanderendif 4962428631SJens Wiklander 50c5402ff6SJerome Forissiercppflags$(sm) := $($(sm)-platform-cppflags) $(CPPFLAGS_$(sm)) 51739804b5SJens Wiklanderaflags$(sm) := $($(sm)-platform-aflags) 52c5402ff6SJerome Forissiercflags$(sm) := $($(sm)-platform-cflags) $(CFLAGS_$(sm)) 53*be3bc461SJerome Forissiercxxflags$(sm) := $($(sm)-platform-cxxflags) $(CXXFLAGS_$(sm)) 54*be3bc461SJerome Forissierifneq (,$(shlibname)) 55*be3bc461SJerome Forissier# Exception handling is not supported in shared libraries (with GCC it would 56*be3bc461SJerome Forissier# require to use the shared libgcc, which depend on the GNU libc) 57*be3bc461SJerome Forissiercxxflags$(sm) += -fno-exceptions 58*be3bc461SJerome Forissierendif 593bce5ba1SJerome Forissier 601a48b444SJerome ForissierCFG_TEE_TA_LOG_LEVEL ?= 2 611a48b444SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL) 621a48b444SJerome Forissier 6335b4ef75SJens Wiklandercppflags$(sm) += -I. -I$(ta-dev-kit-dir$(sm))/include 64b0104773SPascal Brand 65b02ae382SSumit Gargifeq ($(CFG_TA_MCOUNT),y) 66b02ae382SSumit Gargcppflags$(sm) += -pg 67b02ae382SSumit Gargendif 68b02ae382SSumit Garg 6935b4ef75SJens Wiklanderlibdirs += $(ta-dev-kit-dir$(sm))/lib 70062e3d01SJens Wiklanderlibnames += utils 7135b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutils.a 72062e3d01SJens Wiklanderlibnames += utee 7335b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutee.a 74a97bc4a0SJens Wiklanderifeq ($(CFG_TA_MBEDTLS),y) 75a97bc4a0SJens Wiklanderlibnames += mbedtls 7635b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libmbedtls.a 77a97bc4a0SJens Wiklanderendif 78c96bced4SJerome Forissierlibnames += dl 79c96bced4SJerome Forissierlibdeps += $(ta-dev-kit-dir$(sm))/lib/libdl.a 80b0104773SPascal Brand 81a62bf61eSJens Wiklander# Pass config variable (CFG_) from conf.mk on the command line 82a62bf61eSJens Wiklandercppflags$(sm) += $(strip \ 83a62bf61eSJens Wiklander $(foreach var, $(filter CFG_%,$(.VARIABLES)), \ 84a62bf61eSJens Wiklander $(if $(filter y,$($(var))), \ 85a62bf61eSJens Wiklander -D$(var)=1, \ 86a62bf61eSJens Wiklander $(if $(filter xn x,x$($(var))),,-D$(var)='$($(var))')))) 87a62bf61eSJens Wiklander 8835b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/cleandirs.mk 899ac870c9SJerome Forissier 90b0104773SPascal Brand.PHONY: clean 91b0104773SPascal Brandclean: 929ac870c9SJerome Forissier @$(cmd-echo-silent) ' CLEAN $(out-dir)' 93b0104773SPascal Brand ${q}rm -f $(cleanfiles) 9430a44336SJerome Forissier ${q}dirs="$(call cleandirs-for-rmdir)"; if [ "$$dirs" ]; then $(RMDIR) $$dirs; fi 959ac870c9SJerome Forissier @$(cmd-echo-silent) ' CLEAN $(O)' 9630a44336SJerome Forissier ${q}if [ -d "$(O)" ]; then $(RMDIR) $(O); fi 97b0104773SPascal Brand 98331ebf7eSJerome Forissierinclude $(ta-dev-kit-dir$(sm))/mk/$(COMPILER_$(sm)).mk 99331ebf7eSJerome Forissierinclude $(ta-dev-kit-dir$(sm))/mk/cc-option.mk 100331ebf7eSJerome Forissier 101b0104773SPascal Brandsubdirs = . 10235b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/subdir.mk 1039faf0da7SZeng Tao 104d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),) 105ceae7156SJerome Forissier# Build target is TA 10635b4ef75SJens Wiklandervpath %.c $(ta-dev-kit-dir$(sm))/src 107b0104773SPascal Brandsrcs += user_ta_header.c 108c8061893SJerome Forissierifeq ($(sm),ta_arm32) 109c8061893SJerome Forissiervpath %.S $(ta-dev-kit-dir$(sm))/src 110c8061893SJerome Forissiersrcs += ta_entry_a32.S 111c8061893SJerome Forissierendif 1129faf0da7SZeng Taoendif 113b0104773SPascal Brand 11438f4260cSJerome ForissierSCRIPTS_DIR := $(ta-dev-kit-dir)/scripts 11535b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/compile.mk 116f8896d13SJerome Forissier 117d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),) 11835b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link.mk 119ceae7156SJerome Forissierendif 120ceae7156SJerome Forissier 1219faf0da7SZeng Taoifneq ($(libname),) 122ceae7156SJerome Forissier# Build target is static library 1239faf0da7SZeng Taoall: $(libname).a 1249faf0da7SZeng Taocleanfiles += $(libname).a 1259faf0da7SZeng Tao 1269faf0da7SZeng Tao$(libname).a: $(objs) 1279faf0da7SZeng Tao @echo ' AR $@' 1289faf0da7SZeng Tao $(q)rm -f $@ && $(AR$(sm)) rcs -o $@ $^ 1299faf0da7SZeng Taoendif 130f8896d13SJerome Forissier 131f8896d13SJerome Forissierifneq (,$(shlibname)) 13235b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link_shlib.mk 133f8896d13SJerome Forissierendif 134