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 105831e426SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/macros.mk 115831e426SJens Wiklander 12f8896d13SJerome Forissierifneq (1, $(words $(BINARY) $(LIBNAME) $(SHLIBNAME))) 13f8896d13SJerome Forissier$(error You must specify exactly one of BINARY, LIBNAME or SHLIBNAME) 14ceae7156SJerome Forissierendif 15ceae7156SJerome Forissier 16b0104773SPascal Brandifneq ($O,) 174334e8d7SJerome Forissierout-dir := $O 18c3c7db16SJerome Forissierelse 19c3c7db16SJerome Forissierout-dir := . 20b0104773SPascal Brandendif 2135b4ef75SJens Wiklanderlink-out-dir := $(out-dir) # backward compat 2235b4ef75SJens Wiklanderlink-out-dir$(sm) := $(out-dir) 2335b4ef75SJens Wiklander 24d58d79ecSJens Wiklanderuser-ta-uuid := $(BINARY) 25682f256cSSumit Garguser-ta-version := $(if $(CFG_TA_VERSION),$(CFG_TA_VERSION),0) 26d58d79ecSJens Wiklanderuser-ta-ldadd := $(LDADD) 2735b4ef75SJens Wiklanderlibname := $(LIBNAME) 2835b4ef75SJens Wiklandershlibname := $(SHLIBNAME) 2935b4ef75SJens Wiklandershlibuuid := $(SHLIBUUID) 3035b4ef75SJens Wiklander 3119fdfcf6SEtienne Carrierearch-bits-ta_arm32 := 32 3219fdfcf6SEtienne Carrierearch-bits-ta_arm64 := 64 33b0104773SPascal Brand 340ee43c37SClement Faure# For convenience 350ee43c37SClement Faureifdef CFLAGS 360ee43c37SClement FaureCFLAGS32 ?= $(CFLAGS) 370ee43c37SClement FaureCFLAGS64 ?= $(CFLAGS) 380ee43c37SClement Faureendif 390ee43c37SClement Faure 40b0104773SPascal Brandifneq ($V,1) 41b0104773SPascal Brandq := @ 42b0104773SPascal Brandcmd-echo := true 4362428631SJens Wiklandercmd-echo-silent := echo 44b0104773SPascal Brandelse 45b0104773SPascal Brandq := 46b0104773SPascal Brandcmd-echo := echo 4762428631SJens Wiklandercmd-echo-silent := true 48b0104773SPascal Brandendif 49b0104773SPascal Brand 5062428631SJens Wiklanderifneq ($(filter 4.%,$(MAKE_VERSION)),) # make-4 5162428631SJens Wiklanderifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),) 5262428631SJens Wiklandercmd-echo-silent := true 5362428631SJens Wiklanderendif 5462428631SJens Wiklanderelse # make-3.8x 553dc79b0dSPascal Brandifneq ($(findstring s, $(MAKEFLAGS)),) 5662428631SJens Wiklandercmd-echo-silent := true 5762428631SJens Wiklanderendif 5862428631SJens Wiklanderendif 5962428631SJens Wiklander 60c5402ff6SJerome Forissiercppflags$(sm) := $($(sm)-platform-cppflags) $(CPPFLAGS_$(sm)) 61739804b5SJens Wiklanderaflags$(sm) := $($(sm)-platform-aflags) 62c5402ff6SJerome Forissiercflags$(sm) := $($(sm)-platform-cflags) $(CFLAGS_$(sm)) 63be3bc461SJerome Forissiercxxflags$(sm) := $($(sm)-platform-cxxflags) $(CXXFLAGS_$(sm)) 64be3bc461SJerome Forissierifneq (,$(shlibname)) 65be3bc461SJerome Forissier# Exception handling is not supported in shared libraries (with GCC it would 66be3bc461SJerome Forissier# require to use the shared libgcc, which depend on the GNU libc) 67be3bc461SJerome Forissiercxxflags$(sm) += -fno-exceptions 68be3bc461SJerome Forissierendif 693bce5ba1SJerome Forissier 708bbc2e9cSJens Wiklanderifeq ($(CFG_TA_OPTEE_CORE_API_COMPAT_1_1),y) 718bbc2e9cSJens Wiklandercppflags$(sm) += -D__OPTEE_CORE_API_COMPAT_1_1=1 728bbc2e9cSJens Wiklanderendif 731a48b444SJerome ForissierCFG_TEE_TA_LOG_LEVEL ?= 2 741a48b444SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL) 751a48b444SJerome Forissier 7635b4ef75SJens Wiklandercppflags$(sm) += -I. -I$(ta-dev-kit-dir$(sm))/include 77b0104773SPascal Brand 78b02ae382SSumit Gargifeq ($(CFG_TA_MCOUNT),y) 79b02ae382SSumit Gargcppflags$(sm) += -pg 80b02ae382SSumit Gargendif 81b02ae382SSumit Garg 82*949b0c0cSAleksandr Iashchenkoifeq ($(CFG_TA_SANITIZE_UNDEFINED),y) 83*949b0c0cSAleksandr Iashchenkocflags$(sm) += -fsanitize=undefined 84*949b0c0cSAleksandr Iashchenkoendif 85*949b0c0cSAleksandr Iashchenko 8635b4ef75SJens Wiklanderlibdirs += $(ta-dev-kit-dir$(sm))/lib 87062e3d01SJens Wiklanderlibnames += utils 8835b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutils.a 89062e3d01SJens Wiklanderlibnames += utee 9035b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutee.a 91a97bc4a0SJens Wiklanderifeq ($(CFG_TA_MBEDTLS),y) 92a97bc4a0SJens Wiklanderlibnames += mbedtls 9335b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libmbedtls.a 94a97bc4a0SJens Wiklanderendif 95c96bced4SJerome Forissierlibnames += dl 96c96bced4SJerome Forissierlibdeps += $(ta-dev-kit-dir$(sm))/lib/libdl.a 97b0104773SPascal Brand 98f50962e3SVolodymyr Babchuk# libutils provides __getauxval symbol which is needed by libgcc 10.x. We can't 99f50962e3SVolodymyr Babchuk# link libutils after libgcc, because libgcc will replace some symbols provided 100f50962e3SVolodymyr Babchuk# by libutils, which will cause further linking issues. 101f50962e3SVolodymyr Babchuk# 102f50962e3SVolodymyr Babchuk# But if we place libutils before libgcc, linker will not be able to resolve 103f50962e3SVolodymyr Babchuk# __getauxval. So we need to link with libutils twice: before and after libgcc. 104f50962e3SVolodymyr Babchuk# Hence it included both in $(libnames) and in $(libnames-after-libgcc) 105f50962e3SVolodymyr Babchuklibnames-after-libgcc += utils 106f50962e3SVolodymyr Babchuklibdeps-after-libgcc += $(ta-dev-kit-dir$(sm))/lib/libutils.a 107f50962e3SVolodymyr Babchuk 108a62bf61eSJens Wiklander# Pass config variable (CFG_) from conf.mk on the command line 109a62bf61eSJens Wiklandercppflags$(sm) += $(strip \ 110a62bf61eSJens Wiklander $(foreach var, $(filter CFG_%,$(.VARIABLES)), \ 111a62bf61eSJens Wiklander $(if $(filter y,$($(var))), \ 112a62bf61eSJens Wiklander -D$(var)=1, \ 113a62bf61eSJens Wiklander $(if $(filter xn x,x$($(var))),,-D$(var)='$($(var))')))) 114a62bf61eSJens Wiklander 11535b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/cleandirs.mk 1169ac870c9SJerome Forissier 117b0104773SPascal Brand.PHONY: clean 118b0104773SPascal Brandclean: 1199ac870c9SJerome Forissier @$(cmd-echo-silent) ' CLEAN $(out-dir)' 120b0104773SPascal Brand ${q}rm -f $(cleanfiles) 12130a44336SJerome Forissier ${q}dirs="$(call cleandirs-for-rmdir)"; if [ "$$dirs" ]; then $(RMDIR) $$dirs; fi 1229ac870c9SJerome Forissier @$(cmd-echo-silent) ' CLEAN $(O)' 12330a44336SJerome Forissier ${q}if [ -d "$(O)" ]; then $(RMDIR) $(O); fi 124b0104773SPascal Brand 125331ebf7eSJerome Forissierinclude $(ta-dev-kit-dir$(sm))/mk/$(COMPILER_$(sm)).mk 126331ebf7eSJerome Forissierinclude $(ta-dev-kit-dir$(sm))/mk/cc-option.mk 127331ebf7eSJerome Forissier 128b0104773SPascal Brandsubdirs = . 12935b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/subdir.mk 1309faf0da7SZeng Tao 131d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),) 132ceae7156SJerome Forissier# Build target is TA 133fc9ea0dbSJens Wiklanderspec-out-dir := $(link-out-dir$(sm)) 134fc9ea0dbSJens Wiklanderspec-srcs += $(ta-dev-kit-dir$(sm))/src/user_ta_header.c 135c8061893SJerome Forissierifeq ($(sm),ta_arm32) 136fc9ea0dbSJens Wiklanderspec-srcs += $(ta-dev-kit-dir$(sm))/src/ta_entry_a32.S 137c8061893SJerome Forissierendif 1389faf0da7SZeng Taoendif 139b0104773SPascal Brand 14038f4260cSJerome ForissierSCRIPTS_DIR := $(ta-dev-kit-dir)/scripts 14135b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/compile.mk 142f8896d13SJerome Forissier 143d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),) 14435b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link.mk 145ceae7156SJerome Forissierendif 146ceae7156SJerome Forissier 1479faf0da7SZeng Taoifneq ($(libname),) 148ceae7156SJerome Forissier# Build target is static library 149d1b003feSTadd Kaoall: $(link-out-dir$(sm))/$(libname).a 150d1b003feSTadd Kaocleanfiles += $(link-out-dir$(sm))/$(libname).a 1519faf0da7SZeng Tao 152d1b003feSTadd Kao$(link-out-dir$(sm))/$(libname).a: $(objs) 1539faf0da7SZeng Tao @echo ' AR $@' 154830faadeSJerome Forissier $(q)rm -f $@ && $(AR$(sm)) rcs $@ $^ 1559faf0da7SZeng Taoendif 156f8896d13SJerome Forissier 157f8896d13SJerome Forissierifneq (,$(shlibname)) 15835b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link_shlib.mk 159f8896d13SJerome Forissierendif 160