xref: /optee_os/ta/ta.mk (revision bc33bbd90ab37717cf6f15d67feed35bed654029)
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