1b0104773SPascal Brandinclude mk/cleanvars.mk 2b0104773SPascal Brand 3b0104773SPascal Brand# Set current submodule (used for module specific flags compile result etc) 4bc33bbd9SJens 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 14bc33bbd9SJens Wiklander# Expand platform flags here as $(sm) will change if we have several TA 15bc33bbd9SJens Wiklander# targets. Platform flags should not change after inclusion of ta/ta.mk. 16bc33bbd9SJens Wiklandercppflags$(sm) := $(platform-cppflags) $($(sm)-platform-cppflags) 17bc33bbd9SJens Wiklandercflags$(sm) := $(platform-cflags) $($(sm)-platform-cflags) 18bc33bbd9SJens 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) 23*156fe685SPascal Brandifeq ($(CFG_TEE_TA_MALLOC_DEBUG),y) 24*156fe685SPascal Brandcppflags$(sm) += -DENABLE_MDBG=1 25*156fe685SPascal Brandendif 26b0104773SPascal Brand 27b0104773SPascal Brandbase-prefix := $(sm)- 28b0104773SPascal Brand 29b0104773SPascal Brandlibname = utils 30b0104773SPascal Brandlibdir = lib/libutils 31b0104773SPascal Brandinclude mk/lib.mk 32b0104773SPascal Brand 33b0104773SPascal Brandlibname = mpa 34b0104773SPascal Brandlibdir = lib/libmpa 35b0104773SPascal Brandinclude mk/lib.mk 36b0104773SPascal Brand 37b0104773SPascal Brandlibname = utee 38b0104773SPascal Brandlibdir = lib/libutee 39b0104773SPascal Brandinclude mk/lib.mk 40b0104773SPascal Brand 41b0104773SPascal Brandbase-prefix := 42b0104773SPascal Brand 43b0104773SPascal Brandincdirs-host := $(filter-out lib/libutils%, $(incdirs$(sm))) 44fecbba79SJens Wiklanderincfiles-extra-host := lib/libutils/ext/include/compiler.h 453c73419cSJens Wiklanderincfiles-extra-host += lib/libutils/ext/include/util.h 46a2e9a830SCedric Chaumontincfiles-extra-host += $(out-dir)/core/include/generated/conf.h 47a2e9a830SCedric Chaumontincfiles-extra-host += $(out-dir)/core/conf.mk 489470783fSSY Chiuincfiles-extra-host += core/include/tee/tee_fs_key_manager.h 4992ea2867SJens Wiklanderincfiles-extra-host += core/include/signed_hdr.h 50b0104773SPascal Brand 51b0104773SPascal Brand# 52b0104773SPascal Brand# Copy lib files and exported headers from each lib 53b0104773SPascal Brand# 54b0104773SPascal Brand 55b0104773SPascal Branddefine copy-file 56b0104773SPascal Brand$2/$$(notdir $1): $1 570047cb63SJerome Forissier @set -e; \ 580047cb63SJerome Forissier mkdir -p $$(dir $$@) ; \ 5962428631SJens Wiklander $(cmd-echo-silent) ' INSTALL $$@' ; \ 60b0104773SPascal Brand cp $$< $$@ 61b0104773SPascal Brand 62b0104773SPascal Brandcleanfiles += $2/$$(notdir $1) 63b0104773SPascal Brandall: $2/$$(notdir $1) 64b0104773SPascal Brandendef 65b0104773SPascal Brand 66b0104773SPascal Brand# Copy the .a files 67b0104773SPascal Brand$(foreach f, $(libfiles), \ 68bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/lib))) 69b0104773SPascal Brand 70b0104773SPascal Brand# Copy .mk files 712cb1e0d0SJens Wiklanderta-mkfiles = mk/compile.mk mk/subdir.mk mk/gcc.mk \ 723bce5ba1SJerome Forissier $(wildcard core/arch/$(ARCH)/plat-$(PLATFORM)/platform_flags.mk) \ 732cb1e0d0SJens Wiklander $(wildcard ta/arch/$(ARCH)/link.mk) \ 74b0104773SPascal Brand ta/mk/ta_dev_kit.mk 753bce5ba1SJerome Forissier 76b0104773SPascal Brand$(foreach f, $(ta-mkfiles), \ 77bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/mk))) 78b0104773SPascal Brand 79153c4954SJens Wiklander# Special treatment for ta/arch/$(ARCH)/$(ARCH).mk 80bc33bbd9SJens Wiklanderarch-arch-mk := $(out-dir)/export-$(sm)/mk/arch.mk 81153c4954SJens Wiklander$(arch-arch-mk): ta/arch/$(ARCH)/$(ARCH).mk 82153c4954SJens Wiklander @set -e; \ 83153c4954SJens Wiklander mkdir -p $(dir $@) ; \ 8462428631SJens Wiklander $(cmd-echo-silent) ' INSTALL $@' ; \ 85153c4954SJens Wiklander cp $< $@ 86153c4954SJens Wiklander 87153c4954SJens Wiklandercleanfiles += $(arch-arch-mk) 88153c4954SJens Wiklanderall: $(arch-arch-mk) 89153c4954SJens Wiklander 90b0104773SPascal Brand# Copy the .h files for TAs 91b0104773SPascal Branddefine copy-incdir 92b0104773SPascal Brandsf := $(subst $1/, , $(shell find $1 -name "*.h")) 93b0104773SPascal Brand$$(foreach h, $$(sf), $$(eval $$(call copy-file, $1/$$(h), \ 940047cb63SJerome Forissier $$(patsubst %/,%,$$(subst /./,/,$2/$$(dir $$(h))))))) 95b0104773SPascal Brandendef 96b0104773SPascal Brand$(foreach d, $(incdirs$(sm)), \ 97bc33bbd9SJens Wiklander $(eval $(call copy-incdir, $(d), $(out-dir)/export-$(sm)/include))) 98b0104773SPascal Brand 99b0104773SPascal Brand# Copy the .h files needed by host 100b0104773SPascal Brand$(foreach d, $(incdirs-host), \ 101bc33bbd9SJens Wiklander $(eval $(call copy-incdir, $(d), $(out-dir)/export-$(sm)/host_include))) 102fecbba79SJens Wiklander$(foreach f, $(incfiles-extra-host), \ 103bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/host_include))) 104b0104773SPascal Brand 105b0104773SPascal Brand# Copy the src files 106b0104773SPascal Brandta-srcfiles = ta/arch/$(ARCH)/user_ta_header.c \ 107bc33bbd9SJens Wiklander $(wildcard ta/arch/$(ARCH)/ta.ld.S) 108b0104773SPascal Brand$(foreach f, $(ta-srcfiles), \ 109bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/src))) 1102cb1e0d0SJens Wiklander 111bc420748SJens Wiklander# Copy keys 112bc420748SJens Wiklanderta-keys = keys/default_ta.pem 113bc420748SJens Wiklander$(foreach f, $(ta-keys), \ 114bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/keys))) 115bc420748SJens Wiklander 1162cb1e0d0SJens Wiklander# Copy the scripts 117bc420748SJens Wiklanderta-scripts = $(wildcard scripts/sign.py) 1182cb1e0d0SJens Wiklander$(foreach f, $(ta-scripts), \ 119bc33bbd9SJens Wiklander $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/scripts))) 120bc33bbd9SJens Wiklander 121bc33bbd9SJens Wiklander# Create config file 122bc33bbd9SJens Wiklanderconf-file := $(out-dir)/export-$(sm)/mk/conf.mk 123bc33bbd9SJens Wiklandersm-$(conf-file) := $(sm) 124bc33bbd9SJens Wiklander# The file is only created if it doesn't exist, this is currently OK as the 125bc33bbd9SJens Wiklander# content of the file is static for a given TA dev kit. 126bc33bbd9SJens Wiklander$(conf-file): 127bc33bbd9SJens Wiklander @$(cmd-echo-silent) ' GEN ' $@ 128bc33bbd9SJens Wiklander $(q)echo sm := $(sm-$(@)) > $@ 129bc33bbd9SJens Wiklander $(q)echo sm-$(sm-$(@)) := y >> $@ 130bc33bbd9SJens Wiklander $(q)echo CFG_ARM32_$(sm-$(@)) := $(CFG_ARM32_$(sm-$(@))) >> $@ 131bc33bbd9SJens Wiklander $(q)echo CFG_ARM64_$(sm-$(@)) := $(CFG_ARM64_$(sm-$(@))) >> $@ 132bc33bbd9SJens Wiklander 133bc33bbd9SJens Wiklandercleanfiles := $(cleanfiles) $(conf-file) 134bc33bbd9SJens Wiklanderall: $(conf-file) 135