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