blob: ad97edaf08e0ce53188eccbddbbb68650dc733dc [file] [log] [blame]
Pascal Brandb0104772014-06-12 15:56:20 +02001include mk/cleanvars.mk
2
3# Set current submodule (used for module specific flags compile result etc)
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +01004sm := $(ta-target)
Pascal Brandb0104772014-06-12 15:56:20 +02005sm-$(sm) := y
6
Jens Wiklander1b4eb4f2015-02-02 09:19:18 +01007# Setup compiler for this sub module
Jens Wiklander1b4eb4f2015-02-02 09:19:18 +01008COMPILER_$(sm) ?= $(COMPILER)
9include mk/$(COMPILER_$(sm)).mk
10
Jens Wiklander137eb242018-04-19 17:30:53 +020011#
12# Config flags from mk/config.mk
13#
14
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020015ifeq ($(CFG_TA_MBEDTLS_SELF_TEST),y)
16$(sm)-platform-cppflags += -DMBEDTLS_SELF_TEST
17endif
18
Jens Wiklander137eb242018-04-19 17:30:53 +020019ifeq ($(CFG_TEE_TA_MALLOC_DEBUG),y)
20# Build malloc debug code into libutils: (mdbg_malloc(), mdbg_free(),
21# mdbg_check(), etc.).
22$(sm)-platform-cppflags += -DENABLE_MDBG=1
23endif
24
Jens Wiklanderd1911a82019-05-23 17:42:11 +020025# Keep CFG_TA_DYNLINK for backwards compatibility
26$(call force,CFG_TA_DYNLINK,y)
27
Jens Wiklanderc21bf052018-04-20 12:44:36 +020028# Config variables to be explicitly exported to the dev kit conf.mk
Jens Wiklander28a6ae12018-04-19 17:32:30 +020029ta-mk-file-export-vars-$(sm) += CFG_TA_FLOAT_SUPPORT
Jens Wiklanderc21bf052018-04-20 12:44:36 +020030ta-mk-file-export-vars-$(sm) += CFG_CACHE_API
31ta-mk-file-export-vars-$(sm) += CFG_SECURE_DATA_PATH
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020032ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS_SELF_TEST
33ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS
Jens Wiklander062e3d02018-11-13 09:37:22 +010034ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS_MPI
Igor Opaniuk4bca3022018-05-22 16:29:49 +030035ta-mk-file-export-vars-$(sm) += CFG_SYSTEM_PTA
Jerome Forissier0095d8b2018-05-31 09:53:45 +020036ta-mk-file-export-vars-$(sm) += CFG_TA_DYNLINK
Jens Wiklander412dcda2018-11-29 11:52:13 +010037ta-mk-file-export-vars-$(sm) += CFG_TEE_TA_LOG_LEVEL
Sumit Garg099918f2019-09-05 13:23:01 +053038ta-mk-file-export-vars-$(sm) += CFG_FTRACE_SUPPORT
Jerome Forissiere0e762f2019-06-14 08:25:50 +020039ta-mk-file-export-vars-$(sm) += CFG_UNWIND
Jens Wiklander8f8d7cd2019-06-17 22:42:01 +020040ta-mk-file-export-vars-$(sm) += CFG_TA_MCOUNT
Javier Almansa Sobrinodd333f02020-01-20 14:03:29 +000041ta-mk-file-export-vars-$(sm) += CFG_CORE_TPM_EVENT_LOG
Jens Wiklander28a6ae12018-04-19 17:32:30 +020042
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +010043# Expand platform flags here as $(sm) will change if we have several TA
44# targets. Platform flags should not change after inclusion of ta/ta.mk.
45cppflags$(sm) := $(platform-cppflags) $($(sm)-platform-cppflags)
46cflags$(sm) := $(platform-cflags) $($(sm)-platform-cflags)
47aflags$(sm) := $(platform-aflags) $($(sm)-platform-aflags)
Pascal Brandb0104772014-06-12 15:56:20 +020048
Jens Wiklander137eb242018-04-19 17:30:53 +020049# Changes to cppflags$(sm) will only affect how TA dev kit libraries are
50# compiled, these flags are not propagated to the TA
Pascal Brandb5569a62016-01-08 15:14:30 +010051cppflags$(sm) += -include $(conf-file)
Jerome Forissier8a1e7b82015-03-31 00:44:06 +020052cppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL)
Pascal Brandb0104772014-06-12 15:56:20 +020053
Sumit Garg4486d582019-07-04 12:41:52 +053054ifeq ($(ta-target),ta_arm32)
55arm32-user-sysreg-txt = lib/libutee/arch/arm/arm32_user_sysreg.txt
56arm32-user-sysregs-$(arm32-user-sysreg-txt)-h := arm32_user_sysreg.h
57arm32-user-sysregs += $(arm32-user-sysreg-txt)
58
59arm32-user-sysregs-out := $(out-dir)/include/generated
60
61define process-arm32-user-sysreg
62FORCE-GENSRC$(sm): $$(arm32-user-sysregs-out)/$$(arm32-user-sysregs-$(1)-h)
63cleanfiles := $$(cleanfiles) \
64 $$(arm32-user-sysregs-out)/$$(arm32-user-sysregs-$(1)-h)
65
66$$(arm32-user-sysregs-out)/$$(arm32-user-sysregs-$(1)-h): \
67 $(1) scripts/arm32_sysreg.py
68 @$(cmd-echo-silent) ' GEN $$@'
69 $(q)mkdir -p $$(dir $$@)
Dick Olssonb4faf482020-07-22 08:49:12 +020070 $(q)$(PYTHON3) scripts/arm32_sysreg.py --guard __$$(arm32-user-sysregs-$(1)-h) \
Sumit Garg4486d582019-07-04 12:41:52 +053071 < $$< > $$@
72
73endef #process-arm32-user-sysreg
74
75$(foreach sr, $(arm32-user-sysregs), \
76 $(eval $(call process-arm32-user-sysreg,$(sr))))
77
78cppflags$(sm) += -I$(arm32-user-sysregs-out)
79endif
80
Pascal Brandb0104772014-06-12 15:56:20 +020081base-prefix := $(sm)-
82
83libname = utils
84libdir = lib/libutils
Jerome Forissier64718c92018-05-29 18:03:11 +020085libuuid = 71855bba-6055-4293-a63f-b0963a737360
Pascal Brandb0104772014-06-12 15:56:20 +020086include mk/lib.mk
87
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020088libname = mbedtls
89libdir = lib/libmbedtls
Jerome Forissier64718c92018-05-29 18:03:11 +020090libuuid = 87bb6ae8-4b1d-49fe-9986-2b966132c309
91libl = utils
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020092include mk/lib.mk
93ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020094
Jerome Forissier64718c92018-05-29 18:03:11 +020095libname = utee
96libdir = lib/libutee
97libuuid = 527f1a47-b92c-4a74-95bd-72f19f4a6f74
Jerome Forissier7fb525f2020-01-23 18:24:14 +010098libl = mbedtls utils
Jerome Forissier64718c92018-05-29 18:03:11 +020099include mk/lib.mk
100
Jerome Forissierc96bced2019-08-01 18:00:07 +0200101libname = dl
102libdir = lib/libdl
103libuuid = be807bbd-81e1-4dc4-bd99-3d363f240ece
104libl = utee utils
105include mk/lib.mk
106
Pascal Brandb0104772014-06-12 15:56:20 +0200107base-prefix :=
108
109incdirs-host := $(filter-out lib/libutils%, $(incdirs$(sm)))
Jens Wiklanderfecbba72015-01-26 09:53:56 +0100110incfiles-extra-host := lib/libutils/ext/include/compiler.h
Jens Wiklander3c734192015-01-26 16:39:07 +0100111incfiles-extra-host += lib/libutils/ext/include/util.h
Jens Wiklander09d93d22016-04-09 00:21:32 +0200112incfiles-extra-host += lib/libutils/ext/include/types_ext.h
Pascal Brandb5569a62016-01-08 15:14:30 +0100113incfiles-extra-host += $(conf-file)
114incfiles-extra-host += $(conf-mk-file)
Jens Wiklanderb924c492018-02-08 14:50:07 +0100115incfiles-extra-host += $(conf-cmake-file)
SY Chiu94707832015-09-09 17:17:49 +0800116incfiles-extra-host += core/include/tee/tee_fs_key_manager.h
Jens Wiklander50a81492017-02-15 15:26:35 +0100117incfiles-extra-host += core/include/tee/fs_htree.h
Jens Wiklander92ea2862015-10-26 13:37:30 +0100118incfiles-extra-host += core/include/signed_hdr.h
Sumit Garg4486d582019-07-04 12:41:52 +0530119ifeq ($(ta-target),ta_arm32)
120incfiles-extra-host += $(out-dir)/include/generated/arm32_user_sysreg.h
121endif
Pascal Brandb0104772014-06-12 15:56:20 +0200122
123#
124# Copy lib files and exported headers from each lib
125#
126
127define copy-file
128$2/$$(notdir $1): $1
Jerome Forissier0047cb62014-09-01 13:41:48 +0200129 @set -e; \
130 mkdir -p $$(dir $$@) ; \
Jens Wiklander62428632015-04-29 15:05:19 +0200131 $(cmd-echo-silent) ' INSTALL $$@' ; \
Jerome Forissier64718c92018-05-29 18:03:11 +0200132 cp -P $$< $$@
Pascal Brandb0104772014-06-12 15:56:20 +0200133
134cleanfiles += $2/$$(notdir $1)
Jerome Forissier4746a222017-08-16 18:11:55 +0200135ta_dev_kit: $2/$$(notdir $1)
Jerome Forissier8452bf42018-08-13 15:19:23 +0200136ta_dev_kit-files += $2/$$(notdir $1)
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200137ta_dev_kit-files-$3 += $2/$$(notdir $1)
Pascal Brandb0104772014-06-12 15:56:20 +0200138endef
139
140# Copy the .a files
141$(foreach f, $(libfiles), \
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200142 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/lib,lib)))
Pascal Brandb0104772014-06-12 15:56:20 +0200143
144# Copy .mk files
Jerome Forissier38f42602019-09-17 10:38:15 +0200145ta-mkfiles = mk/compile.mk mk/subdir.mk mk/gcc.mk mk/clang.mk mk/cleandirs.mk \
Jerome Forissier331ebf72020-05-26 15:21:00 +0200146 mk/cc-option.mk \
Jerome Forissierf8896d12018-02-06 16:25:53 +0100147 ta/arch/$(ARCH)/link.mk ta/arch/$(ARCH)/link_shlib.mk \
148 ta/mk/ta_dev_kit.mk
Jerome Forissier3bce5ba2014-12-16 19:23:24 +0100149
Pascal Brandb0104772014-06-12 15:56:20 +0200150$(foreach f, $(ta-mkfiles), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100151 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/mk)))
Pascal Brandb0104772014-06-12 15:56:20 +0200152
153# Copy the .h files for TAs
154define copy-incdir
Jerome Forissierc8061892019-07-03 17:47:50 +0200155sf := $(subst $1/, , $(shell find $1 -name "*.[hS]"))
Pascal Brandb0104772014-06-12 15:56:20 +0200156$$(foreach h, $$(sf), $$(eval $$(call copy-file, $1/$$(h), \
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200157 $$(patsubst %/,%,$$(subst /./,/,$2/$$(dir $$(h)))),$3)))
Pascal Brandb0104772014-06-12 15:56:20 +0200158endef
159$(foreach d, $(incdirs$(sm)), \
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200160 $(eval $(call copy-incdir,$(d),$(out-dir)/export-$(sm)/include,include)))
Pascal Brandb0104772014-06-12 15:56:20 +0200161
162# Copy the .h files needed by host
163$(foreach d, $(incdirs-host), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100164 $(eval $(call copy-incdir, $(d), $(out-dir)/export-$(sm)/host_include)))
Jens Wiklanderfecbba72015-01-26 09:53:56 +0100165$(foreach f, $(incfiles-extra-host), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100166 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/host_include)))
Pascal Brandb0104772014-06-12 15:56:20 +0200167
168# Copy the src files
Jerome Forissier0ac9c8c2017-08-17 13:06:09 +0200169ta-srcfiles = ta/arch/$(ARCH)/user_ta_header.c ta/arch/$(ARCH)/ta.ld.S
Jerome Forissierc8061892019-07-03 17:47:50 +0200170ifeq ($(ta-target),ta_arm32)
171ta-srcfiles += ta/arch/$(ARCH)/ta_entry_a32.S
172endif
Pascal Brandb0104772014-06-12 15:56:20 +0200173$(foreach f, $(ta-srcfiles), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100174 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/src)))
Jens Wiklander2cb1e0d2014-08-15 11:35:17 +0200175
Jens Wiklanderbc420742015-05-05 14:59:15 +0200176# Copy keys
177ta-keys = keys/default_ta.pem
178$(foreach f, $(ta-keys), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100179 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/keys)))
Jens Wiklanderbc420742015-05-05 14:59:15 +0200180
Jens Wiklander2cb1e0d2014-08-15 11:35:17 +0200181# Copy the scripts
Jerome Forissier33017d82019-11-22 15:34:20 +0100182ta-scripts = scripts/sign_encrypt.py scripts/symbolize.py
Jens Wiklander2cb1e0d2014-08-15 11:35:17 +0200183$(foreach f, $(ta-scripts), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100184 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/scripts)))
185
186# Create config file
Pascal Brandb5569a62016-01-08 15:14:30 +0100187conf-mk-file-export := $(out-dir)/export-$(sm)/mk/conf.mk
188sm-$(conf-mk-file-export) := $(sm)
Jerome Forissier50ce5902017-01-06 15:28:52 +0100189define mk-file-export
Jens Wiklandera42a05a2018-04-19 17:01:06 +0200190.PHONY: $(conf-mk-file-export)
191$(conf-mk-file-export):
192 @$$(cmd-echo-silent) ' CHK ' $$@
Jerome Forissier42893422020-07-28 17:28:43 +0200193 $(q)mkdir -p $$(dir $$@)
Jens Wiklandera42a05a2018-04-19 17:01:06 +0200194 $(q)echo sm := $$(sm-$(conf-mk-file-export)) > $$@.tmp
195 $(q)echo sm-$$(sm-$(conf-mk-file-export)) := y >> $$@.tmp
Jerome Forissier50ce5902017-01-06 15:28:52 +0100196 $(q)($$(foreach v, $$(ta-mk-file-export-vars-$$(sm-$(conf-mk-file-export))), \
Jens Wiklander13084592018-04-20 16:07:30 +0200197 $$(if $$($$(v)),echo $$(v) := $$($$(v));,))) >> $$@.tmp
Jens Wiklandera42a05a2018-04-19 17:01:06 +0200198 $(q)echo '$$(ta-mk-file-export-add-$$(sm-$(conf-mk-file-export)))' | sed 's/_nl_ */\n/g' >> $$@.tmp
199 $(q)$(call mv-if-changed,$$@.tmp,$$@)
Jerome Forissier50ce5902017-01-06 15:28:52 +0100200endef
201$(eval $(mk-file-export))
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100202
Pascal Brandb5569a62016-01-08 15:14:30 +0100203cleanfiles := $(cleanfiles) $(conf-mk-file-export)
Jerome Forissier4746a222017-08-16 18:11:55 +0200204ta_dev_kit: $(conf-mk-file-export)
205
206all: ta_dev_kit