1b0104773SPascal Brandinclude mk/cleanvars.mk 2b0104773SPascal Brand 3b0104773SPascal Brand# Set current submodule (used for module specific flags compile result etc) 4*bc33bbd9SJens Wiklandersm := $(ta-target) 5b0104773SPascal Brandsm-$(sm) := y 6b0104773SPascal Brand 71b4eb4f5SJens Wiklander# Setup compiler for this sub module 8b6106707SJerome ForissierCROSS_COMPILE_$(sm) ?= $(CROSS_COMPILE) 91b4eb4f5SJens WiklanderCOMPILER_$(sm) ?= $(COMPILER) 101b4eb4f5SJens Wiklanderinclude mk/$(COMPILER_$(sm)).mk 111b4eb4f5SJens Wiklander 12153c4954SJens Wiklanderinclude ta/arch/$(ARCH)/$(ARCH).mk 13153c4954SJens Wiklander 14*bc33bbd9SJens Wiklander# Expand platform flags here as $(sm) will change if we have several TA 15*bc33bbd9SJens Wiklander# targets. Platform flags should not change after inclusion of ta/ta.mk. 16*bc33bbd9SJens Wiklandercppflags$(sm) := $(platform-cppflags) $($(sm)-platform-cppflags) 17*bc33bbd9SJens Wiklandercflags$(sm) := $(platform-cflags) $($(sm)-platform-cflags) 18*bc33bbd9SJens Wiklanderaflags$(sm) := $(platform-aflags) $($(sm)-platform-aflags) 19b0104773SPascal Brand 20b0104773SPascal Brand# Config flags from mk/config.mk 218a1e7b89SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL) 22b0104773SPascal Brandcppflags$(sm) += -DCFG_TEE_CORE_USER_MEM_DEBUG=$(CFG_TEE_CORE_USER_MEM_DEBUG) 230fcbddd4SSY Chiucppflags$(sm) += -DENABLE_MDBG=$(CFG_TEE_TA_MALLOC_DEBUG) 24b0104773SPascal Brand 25b0104773SPascal Brandbase-prefix := $(sm)- 26b0104773SPascal Brand 27b0104773SPascal Brandlibname = utils 28b0104773SPascal Brandlibdir = lib/libutils 29b0104773SPascal Brandinclude mk/lib.mk 30b0104773SPascal Brand 31b0104773SPascal Brandlibname = mpa 32b0104773SPascal Brandlibdir = lib/libmpa 33b0104773SPascal Brandinclude mk/lib.mk 34b0104773SPascal Brand 35b0104773SPascal Brandlibname = utee 36b0104773SPascal Brandlibdir = lib/libutee 37b0104773SPascal Brandinclude mk/lib.mk 38b0104773SPascal Brand 39b0104773SPascal Brandbase-prefix := 40b0104773SPascal Brand 41b0104773SPascal Brandincdirs-host := $(filter-out lib/libutils%, $(incdirs$(sm))) 42fecbba79SJens Wiklanderincfiles-extra-host := lib/libutils/ext/include/compiler.h 433c73419cSJens Wiklanderincfiles-extra-host += lib/libutils/ext/include/util.h 44a2e9a830SCedric Chaumontincfiles-extra-host += $(out-dir)/core/include/generated/conf.h 45a2e9a830SCedric Chaumontincfiles-extra-host += $(out-dir)/core/conf.mk 469470783fSSY Chiuincfiles-extra-host += core/include/tee/tee_fs_key_manager.h 4792ea2867SJens Wiklanderincfiles-extra-host += core/include/signed_hdr.h 48b0104773SPascal Brand 49b0104773SPascal Brand# 50b0104773SPascal Brand# Copy lib files and exported headers from each lib 51b0104773SPascal Brand# 52b0104773SPascal Brand 53b0104773SPascal Branddefine copy-file 54b0104773SPascal Brand$2/$$(notdir $1): $1 550047cb63SJerome Forissier @set -e; \ 560047cb63SJerome Forissier mkdir -p $$(dir $$@) ; \ 5762428631SJens Wiklander $(cmd-echo-silent) ' INSTALL $$@' ; \ 58b0104773SPascal Brand cp $$< $$@ 59b0104773SPascal Brand 60b0104773SPascal Brandcleanfiles += $2/$$(notdir $1) 61b0104773SPascal Brandall: $2/$$(notdir $1) 62b0104773SPascal Brandendef 63b0104773SPascal Brand 64b0104773SPascal Brand# Copy the .a files 65b0104773SPascal Brand$(foreach f, $(libfiles), \ 66*bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/lib))) 67b0104773SPascal Brand 68b0104773SPascal Brand# Copy .mk files 692cb1e0d0SJens Wiklanderta-mkfiles = mk/compile.mk mk/subdir.mk mk/gcc.mk \ 703bce5ba1SJerome Forissier $(wildcard core/arch/$(ARCH)/plat-$(PLATFORM)/platform_flags.mk) \ 712cb1e0d0SJens Wiklander $(wildcard ta/arch/$(ARCH)/link.mk) \ 72b0104773SPascal Brand ta/mk/ta_dev_kit.mk 733bce5ba1SJerome Forissier 74b0104773SPascal Brand$(foreach f, $(ta-mkfiles), \ 75*bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/mk))) 76b0104773SPascal Brand 77153c4954SJens Wiklander# Special treatment for ta/arch/$(ARCH)/$(ARCH).mk 78*bc33bbd9SJens Wiklanderarch-arch-mk := $(out-dir)/export-$(sm)/mk/arch.mk 79153c4954SJens Wiklander$(arch-arch-mk): ta/arch/$(ARCH)/$(ARCH).mk 80153c4954SJens Wiklander @set -e; \ 81153c4954SJens Wiklander mkdir -p $(dir $@) ; \ 8262428631SJens Wiklander $(cmd-echo-silent) ' INSTALL $@' ; \ 83153c4954SJens Wiklander cp $< $@ 84153c4954SJens Wiklander 85153c4954SJens Wiklandercleanfiles += $(arch-arch-mk) 86153c4954SJens Wiklanderall: $(arch-arch-mk) 87153c4954SJens Wiklander 88b0104773SPascal Brand# Copy the .h files for TAs 89b0104773SPascal Branddefine copy-incdir 90b0104773SPascal Brandsf := $(subst $1/, , $(shell find $1 -name "*.h")) 91b0104773SPascal Brand$$(foreach h, $$(sf), $$(eval $$(call copy-file, $1/$$(h), \ 920047cb63SJerome Forissier $$(patsubst %/,%,$$(subst /./,/,$2/$$(dir $$(h))))))) 93b0104773SPascal Brandendef 94b0104773SPascal Brand$(foreach d, $(incdirs$(sm)), \ 95*bc33bbd9SJens Wiklander $(eval $(call copy-incdir, $(d), $(out-dir)/export-$(sm)/include))) 96b0104773SPascal Brand 97b0104773SPascal Brand# Copy the .h files needed by host 98b0104773SPascal Brand$(foreach d, $(incdirs-host), \ 99*bc33bbd9SJens Wiklander $(eval $(call copy-incdir, $(d), $(out-dir)/export-$(sm)/host_include))) 100fecbba79SJens Wiklander$(foreach f, $(incfiles-extra-host), \ 101*bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/host_include))) 102b0104773SPascal Brand 103b0104773SPascal Brand# Copy the src files 104b0104773SPascal Brandta-srcfiles = ta/arch/$(ARCH)/user_ta_header.c \ 105*bc33bbd9SJens Wiklander $(wildcard ta/arch/$(ARCH)/ta.ld.S) 106b0104773SPascal Brand$(foreach f, $(ta-srcfiles), \ 107*bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/src))) 1082cb1e0d0SJens Wiklander 109bc420748SJens Wiklander# Copy keys 110bc420748SJens Wiklanderta-keys = keys/default_ta.pem 111bc420748SJens Wiklander$(foreach f, $(ta-keys), \ 112*bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/keys))) 113bc420748SJens Wiklander 1142cb1e0d0SJens Wiklander# Copy the scripts 115bc420748SJens Wiklanderta-scripts = $(wildcard scripts/sign.py) 1162cb1e0d0SJens Wiklander$(foreach f, $(ta-scripts), \ 117*bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/scripts))) 118*bc33bbd9SJens Wiklander 119*bc33bbd9SJens Wiklander# Create config file 120*bc33bbd9SJens Wiklanderconf-file := $(out-dir)/export-$(sm)/mk/conf.mk 121*bc33bbd9SJens Wiklandersm-$(conf-file) := $(sm) 122*bc33bbd9SJens Wiklander# The file is only created if it doesn't exist, this is currently OK as the 123*bc33bbd9SJens Wiklander# content of the file is static for a given TA dev kit. 124*bc33bbd9SJens Wiklander$(conf-file): 125*bc33bbd9SJens Wiklander @$(cmd-echo-silent) ' GEN ' $@ 126*bc33bbd9SJens Wiklander $(q)echo sm := $(sm-$(@)) > $@ 127*bc33bbd9SJens Wiklander $(q)echo sm-$(sm-$(@)) := y >> $@ 128*bc33bbd9SJens Wiklander $(q)echo CFG_ARM32_$(sm-$(@)) := $(CFG_ARM32_$(sm-$(@))) >> $@ 129*bc33bbd9SJens Wiklander $(q)echo CFG_ARM64_$(sm-$(@)) := $(CFG_ARM64_$(sm-$(@))) >> $@ 130*bc33bbd9SJens Wiklander 131*bc33bbd9SJens Wiklandercleanfiles := $(cleanfiles) $(conf-file) 132*bc33bbd9SJens Wiklanderall: $(conf-file) 133