blob: 057a6eae303bc36b27711d0ba631c26315a87f36 [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
Khoa Hoang45507d12022-11-18 11:43:44 -080015ta-stackp-cflags-$(CFG_TA_STACK_PROTECTOR) := -fstack-protector
16ta-stackp-cflags-$(CFG_TA_STACK_PROTECTOR_STRONG) := -fstack-protector-strong
17ta-stackp-cflags-$(CFG_TA_STACK_PROTECTOR_ALL) := -fstack-protector-all
18$(sm)-platform-cflags += $(ta-stackp-cflags-y)
19
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020020ifeq ($(CFG_TA_MBEDTLS_SELF_TEST),y)
21$(sm)-platform-cppflags += -DMBEDTLS_SELF_TEST
22endif
23
Jens Wiklander137eb242018-04-19 17:30:53 +020024ifeq ($(CFG_TEE_TA_MALLOC_DEBUG),y)
25# Build malloc debug code into libutils: (mdbg_malloc(), mdbg_free(),
26# mdbg_check(), etc.).
27$(sm)-platform-cppflags += -DENABLE_MDBG=1
28endif
29
Jens Wiklanderc21bf052018-04-20 12:44:36 +020030# Config variables to be explicitly exported to the dev kit conf.mk
Jens Wiklander28a6ae12018-04-19 17:32:30 +020031ta-mk-file-export-vars-$(sm) += CFG_TA_FLOAT_SUPPORT
Jens Wiklanderc21bf052018-04-20 12:44:36 +020032ta-mk-file-export-vars-$(sm) += CFG_CACHE_API
33ta-mk-file-export-vars-$(sm) += CFG_SECURE_DATA_PATH
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020034ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS_SELF_TEST
35ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS
Jens Wiklander062e3d02018-11-13 09:37:22 +010036ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS_MPI
Igor Opaniuk4bca3022018-05-22 16:29:49 +030037ta-mk-file-export-vars-$(sm) += CFG_SYSTEM_PTA
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
Ruchika Gupta5a8d8ba2021-12-01 11:15:17 +053041ta-mk-file-export-vars-$(sm) += CFG_TA_BTI
Ruchika Guptaf0d8ad62022-01-20 18:21:20 +053042ta-mk-file-export-vars-$(sm) += CFG_TA_PAUTH
Javier Almansa Sobrinodd333f02020-01-20 14:03:29 +000043ta-mk-file-export-vars-$(sm) += CFG_CORE_TPM_EVENT_LOG
Jerome Forissier9efcd732020-07-29 16:51:35 +020044ta-mk-file-export-add-$(sm) += CFG_TEE_TA_LOG_LEVEL ?= $(CFG_TEE_TA_LOG_LEVEL)_nl_
Jens Wiklander27e8d082020-12-27 21:17:52 +010045ta-mk-file-export-vars-$(sm) += CFG_TA_BGET_TEST
Jerome Forissier7e05ec22021-10-27 18:19:29 +020046ta-mk-file-export-vars-$(sm) += CFG_ATTESTATION_PTA
Jens Wiklandera0e8ffe2022-04-04 14:52:07 +020047ta-mk-file-export-vars-$(sm) += CFG_MEMTAG
Jens Wiklander28a6ae12018-04-19 17:32:30 +020048
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +010049# Expand platform flags here as $(sm) will change if we have several TA
50# targets. Platform flags should not change after inclusion of ta/ta.mk.
51cppflags$(sm) := $(platform-cppflags) $($(sm)-platform-cppflags)
52cflags$(sm) := $(platform-cflags) $($(sm)-platform-cflags)
53aflags$(sm) := $(platform-aflags) $($(sm)-platform-aflags)
Pascal Brandb0104772014-06-12 15:56:20 +020054
Jens Wiklander137eb242018-04-19 17:30:53 +020055# Changes to cppflags$(sm) will only affect how TA dev kit libraries are
56# compiled, these flags are not propagated to the TA
Pascal Brandb5569a62016-01-08 15:14:30 +010057cppflags$(sm) += -include $(conf-file)
Jerome Forissier8a1e7b82015-03-31 00:44:06 +020058cppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL)
Pascal Brandb0104772014-06-12 15:56:20 +020059
Sumit Garg4486d582019-07-04 12:41:52 +053060ifeq ($(ta-target),ta_arm32)
61arm32-user-sysreg-txt = lib/libutee/arch/arm/arm32_user_sysreg.txt
62arm32-user-sysregs-$(arm32-user-sysreg-txt)-h := arm32_user_sysreg.h
63arm32-user-sysregs += $(arm32-user-sysreg-txt)
64
65arm32-user-sysregs-out := $(out-dir)/include/generated
66
67define process-arm32-user-sysreg
68FORCE-GENSRC$(sm): $$(arm32-user-sysregs-out)/$$(arm32-user-sysregs-$(1)-h)
69cleanfiles := $$(cleanfiles) \
70 $$(arm32-user-sysregs-out)/$$(arm32-user-sysregs-$(1)-h)
71
72$$(arm32-user-sysregs-out)/$$(arm32-user-sysregs-$(1)-h): \
73 $(1) scripts/arm32_sysreg.py
74 @$(cmd-echo-silent) ' GEN $$@'
75 $(q)mkdir -p $$(dir $$@)
Dick Olssonb4faf482020-07-22 08:49:12 +020076 $(q)$(PYTHON3) scripts/arm32_sysreg.py --guard __$$(arm32-user-sysregs-$(1)-h) \
Sumit Garg4486d582019-07-04 12:41:52 +053077 < $$< > $$@
78
79endef #process-arm32-user-sysreg
80
81$(foreach sr, $(arm32-user-sysregs), \
82 $(eval $(call process-arm32-user-sysreg,$(sr))))
83
84cppflags$(sm) += -I$(arm32-user-sysregs-out)
85endif
86
Pascal Brandb0104772014-06-12 15:56:20 +020087base-prefix := $(sm)-
88
89libname = utils
90libdir = lib/libutils
Jerome Forissier64718c92018-05-29 18:03:11 +020091libuuid = 71855bba-6055-4293-a63f-b0963a737360
Pascal Brandb0104772014-06-12 15:56:20 +020092include mk/lib.mk
93
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020094libname = mbedtls
95libdir = lib/libmbedtls
Jerome Forissier64718c92018-05-29 18:03:11 +020096libuuid = 87bb6ae8-4b1d-49fe-9986-2b966132c309
97libl = utils
Jens Wiklandera97bc4a2018-05-18 15:49:22 +020098include mk/lib.mk
99ta-mk-file-export-vars-$(sm) += CFG_TA_MBEDTLS
Jens Wiklandera97bc4a2018-05-18 15:49:22 +0200100
Jerome Forissier64718c92018-05-29 18:03:11 +0200101libname = utee
102libdir = lib/libutee
Jens Wiklander36f7daa2022-12-14 15:52:29 +0100103libuuid = 4b3d937e-d57e-418b-8673-1c04f2420226
Jerome Forissier7fb525f2020-01-23 18:24:14 +0100104libl = mbedtls utils
Jerome Forissier64718c92018-05-29 18:03:11 +0200105include mk/lib.mk
106
Jerome Forissierc96bced2019-08-01 18:00:07 +0200107libname = dl
108libdir = lib/libdl
109libuuid = be807bbd-81e1-4dc4-bd99-3d363f240ece
110libl = utee utils
111include mk/lib.mk
112
Pascal Brandb0104772014-06-12 15:56:20 +0200113base-prefix :=
114
115incdirs-host := $(filter-out lib/libutils%, $(incdirs$(sm)))
Jens Wiklanderfecbba72015-01-26 09:53:56 +0100116incfiles-extra-host := lib/libutils/ext/include/compiler.h
Jens Wiklander3c734192015-01-26 16:39:07 +0100117incfiles-extra-host += lib/libutils/ext/include/util.h
Jens Wiklander09d93d22016-04-09 00:21:32 +0200118incfiles-extra-host += lib/libutils/ext/include/types_ext.h
Pascal Brandb5569a62016-01-08 15:14:30 +0100119incfiles-extra-host += $(conf-file)
120incfiles-extra-host += $(conf-mk-file)
Jens Wiklanderb924c492018-02-08 14:50:07 +0100121incfiles-extra-host += $(conf-cmake-file)
SY Chiu94707832015-09-09 17:17:49 +0800122incfiles-extra-host += core/include/tee/tee_fs_key_manager.h
Jens Wiklander50a81492017-02-15 15:26:35 +0100123incfiles-extra-host += core/include/tee/fs_htree.h
Jens Wiklander92ea2862015-10-26 13:37:30 +0100124incfiles-extra-host += core/include/signed_hdr.h
Sumit Garg4486d582019-07-04 12:41:52 +0530125ifeq ($(ta-target),ta_arm32)
126incfiles-extra-host += $(out-dir)/include/generated/arm32_user_sysreg.h
127endif
Jelle Sels1fdb1c42022-09-05 14:02:43 +0200128ifeq ($(CFG_SPMC_TESTS),y)
129incfiles-extra-host += core/arch/arm/include/ffa.h
130incfiles-extra-host += core/arch/arm/include/smccc.h
131endif
Pascal Brandb0104772014-06-12 15:56:20 +0200132#
133# Copy lib files and exported headers from each lib
134#
135
136define copy-file
137$2/$$(notdir $1): $1
Jerome Forissier0047cb62014-09-01 13:41:48 +0200138 @set -e; \
139 mkdir -p $$(dir $$@) ; \
Jens Wiklander62428632015-04-29 15:05:19 +0200140 $(cmd-echo-silent) ' INSTALL $$@' ; \
Jerome Forissier64718c92018-05-29 18:03:11 +0200141 cp -P $$< $$@
Pascal Brandb0104772014-06-12 15:56:20 +0200142
143cleanfiles += $2/$$(notdir $1)
Jerome Forissier4746a222017-08-16 18:11:55 +0200144ta_dev_kit: $2/$$(notdir $1)
Jerome Forissier8452bf42018-08-13 15:19:23 +0200145ta_dev_kit-files += $2/$$(notdir $1)
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200146ta_dev_kit-files-$3 += $2/$$(notdir $1)
Pascal Brandb0104772014-06-12 15:56:20 +0200147endef
148
149# Copy the .a files
150$(foreach f, $(libfiles), \
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200151 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/lib,lib)))
Pascal Brandb0104772014-06-12 15:56:20 +0200152
153# Copy .mk files
Jerome Forissier38f42602019-09-17 10:38:15 +0200154ta-mkfiles = mk/compile.mk mk/subdir.mk mk/gcc.mk mk/clang.mk mk/cleandirs.mk \
Jerome Forissier331ebf72020-05-26 15:21:00 +0200155 mk/cc-option.mk \
liushiwei31b31012023-03-29 16:19:57 +0800156 ta/link.mk ta/link_shlib.mk \
Jerome Forissierf8896d12018-02-06 16:25:53 +0100157 ta/mk/ta_dev_kit.mk
Jerome Forissier3bce5ba2014-12-16 19:23:24 +0100158
Pascal Brandb0104772014-06-12 15:56:20 +0200159$(foreach f, $(ta-mkfiles), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100160 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/mk)))
Pascal Brandb0104772014-06-12 15:56:20 +0200161
162# Copy the .h files for TAs
163define copy-incdir
Jerome Forissierc8061892019-07-03 17:47:50 +0200164sf := $(subst $1/, , $(shell find $1 -name "*.[hS]"))
Pascal Brandb0104772014-06-12 15:56:20 +0200165$$(foreach h, $$(sf), $$(eval $$(call copy-file, $1/$$(h), \
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200166 $$(patsubst %/,%,$$(subst /./,/,$2/$$(dir $$(h)))),$3)))
Pascal Brandb0104772014-06-12 15:56:20 +0200167endef
168$(foreach d, $(incdirs$(sm)), \
Jerome Forissier0265f1e2019-08-01 14:54:09 +0200169 $(eval $(call copy-incdir,$(d),$(out-dir)/export-$(sm)/include,include)))
Pascal Brandb0104772014-06-12 15:56:20 +0200170
171# Copy the .h files needed by host
172$(foreach d, $(incdirs-host), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100173 $(eval $(call copy-incdir, $(d), $(out-dir)/export-$(sm)/host_include)))
Jens Wiklanderfecbba72015-01-26 09:53:56 +0100174$(foreach f, $(incfiles-extra-host), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100175 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/host_include)))
Pascal Brandb0104772014-06-12 15:56:20 +0200176
177# Copy the src files
liushiwei31b31012023-03-29 16:19:57 +0800178ta-srcfiles = ta/user_ta_header.c ta/arch/$(ARCH)/ta.ld.S
Jerome Forissierc8061892019-07-03 17:47:50 +0200179ifeq ($(ta-target),ta_arm32)
180ta-srcfiles += ta/arch/$(ARCH)/ta_entry_a32.S
181endif
Pascal Brandb0104772014-06-12 15:56:20 +0200182$(foreach f, $(ta-srcfiles), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100183 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/src)))
Jens Wiklander2cb1e0d2014-08-15 11:35:17 +0200184
Jens Wiklanderbc420742015-05-05 14:59:15 +0200185# Copy keys
186ta-keys = keys/default_ta.pem
187$(foreach f, $(ta-keys), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100188 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/keys)))
Jens Wiklanderbc420742015-05-05 14:59:15 +0200189
Jens Wiklander2cb1e0d2014-08-15 11:35:17 +0200190# Copy the scripts
Jerome Forissier33017d82019-11-22 15:34:20 +0100191ta-scripts = scripts/sign_encrypt.py scripts/symbolize.py
Jens Wiklander2cb1e0d2014-08-15 11:35:17 +0200192$(foreach f, $(ta-scripts), \
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100193 $(eval $(call copy-file, $(f), $(out-dir)/export-$(sm)/scripts)))
194
195# Create config file
Pascal Brandb5569a62016-01-08 15:14:30 +0100196conf-mk-file-export := $(out-dir)/export-$(sm)/mk/conf.mk
197sm-$(conf-mk-file-export) := $(sm)
Jerome Forissier50ce5902017-01-06 15:28:52 +0100198define mk-file-export
Jens Wiklandera42a05a2018-04-19 17:01:06 +0200199.PHONY: $(conf-mk-file-export)
200$(conf-mk-file-export):
201 @$$(cmd-echo-silent) ' CHK ' $$@
Jerome Forissier42893422020-07-28 17:28:43 +0200202 $(q)mkdir -p $$(dir $$@)
Jens Wiklandera42a05a2018-04-19 17:01:06 +0200203 $(q)echo sm := $$(sm-$(conf-mk-file-export)) > $$@.tmp
204 $(q)echo sm-$$(sm-$(conf-mk-file-export)) := y >> $$@.tmp
Jerome Forissier50ce5902017-01-06 15:28:52 +0100205 $(q)($$(foreach v, $$(ta-mk-file-export-vars-$$(sm-$(conf-mk-file-export))), \
Jens Wiklander13084592018-04-20 16:07:30 +0200206 $$(if $$($$(v)),echo $$(v) := $$($$(v));,))) >> $$@.tmp
Jens Wiklandera42a05a2018-04-19 17:01:06 +0200207 $(q)echo '$$(ta-mk-file-export-add-$$(sm-$(conf-mk-file-export)))' | sed 's/_nl_ */\n/g' >> $$@.tmp
208 $(q)$(call mv-if-changed,$$@.tmp,$$@)
Jerome Forissier50ce5902017-01-06 15:28:52 +0100209endef
210$(eval $(mk-file-export))
Jens Wiklanderbc33bbd2015-11-11 14:08:26 +0100211
Pascal Brandb5569a62016-01-08 15:14:30 +0100212cleanfiles := $(cleanfiles) $(conf-mk-file-export)
Jerome Forissier4746a222017-08-16 18:11:55 +0200213ta_dev_kit: $(conf-mk-file-export)
214
215all: ta_dev_kit