xref: /optee_os/ta/mk/ta_dev_kit.mk (revision 19fdfcf617e386c561f6327bc60d829096472778)
1b0104773SPascal Brand# Get the dir of the ta-dev-kit, requires make version 3.81 or later
24334e8d7SJerome Forissierta-dev-kit-dir := $(patsubst %/,%,$(abspath $(dir $(lastword $(MAKEFILE_LIST)))..))
3b0104773SPascal Brand
4b0104773SPascal Brand.PHONY: all
5b0104773SPascal Brandall:
6b0104773SPascal Brand
7bc33bbd9SJens Wiklanderinclude $(ta-dev-kit-dir)/mk/conf.mk
835b4ef75SJens Wiklanderta-dev-kit-dir$(sm) := $(ta-dev-kit-dir)
9bc33bbd9SJens Wiklander
10f8896d13SJerome Forissierifneq (1, $(words $(BINARY) $(LIBNAME) $(SHLIBNAME)))
11f8896d13SJerome Forissier$(error You must specify exactly one of BINARY, LIBNAME or SHLIBNAME)
12ceae7156SJerome Forissierendif
13ceae7156SJerome Forissier
14b0104773SPascal Brandifneq ($O,)
154334e8d7SJerome Forissierout-dir := $O
16c3c7db16SJerome Forissierelse
17c3c7db16SJerome Forissierout-dir := .
18b0104773SPascal Brandendif
1935b4ef75SJens Wiklanderlink-out-dir := $(out-dir)	# backward compat
2035b4ef75SJens Wiklanderlink-out-dir$(sm) := $(out-dir)
2135b4ef75SJens Wiklander
22d58d79ecSJens Wiklanderuser-ta-uuid := $(BINARY)
23682f256cSSumit Garguser-ta-version := $(if $(CFG_TA_VERSION),$(CFG_TA_VERSION),0)
24d58d79ecSJens Wiklanderuser-ta-ldadd := $(LDADD)
2535b4ef75SJens Wiklanderlibname := $(LIBNAME)
2635b4ef75SJens Wiklandershlibname := $(SHLIBNAME)
2735b4ef75SJens Wiklandershlibuuid := $(SHLIBUUID)
2835b4ef75SJens Wiklander
29*19fdfcf6SEtienne Carrierearch-bits-ta_arm32 := 32
30*19fdfcf6SEtienne Carrierearch-bits-ta_arm64 := 64
31b0104773SPascal Brand
32b0104773SPascal Brandifneq ($V,1)
33b0104773SPascal Brandq := @
34b0104773SPascal Brandcmd-echo := true
3562428631SJens Wiklandercmd-echo-silent := echo
36b0104773SPascal Brandelse
37b0104773SPascal Brandq :=
38b0104773SPascal Brandcmd-echo := echo
3962428631SJens Wiklandercmd-echo-silent := true
40b0104773SPascal Brandendif
41b0104773SPascal Brand
4262428631SJens Wiklanderifneq ($(filter 4.%,$(MAKE_VERSION)),)  # make-4
4362428631SJens Wiklanderifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),)
4462428631SJens Wiklandercmd-echo-silent := true
4562428631SJens Wiklanderendif
4662428631SJens Wiklanderelse                                    # make-3.8x
473dc79b0dSPascal Brandifneq ($(findstring s, $(MAKEFLAGS)),)
4862428631SJens Wiklandercmd-echo-silent := true
4962428631SJens Wiklanderendif
5062428631SJens Wiklanderendif
5162428631SJens Wiklander
52c5402ff6SJerome Forissiercppflags$(sm)  := $($(sm)-platform-cppflags) $(CPPFLAGS_$(sm))
53739804b5SJens Wiklanderaflags$(sm)    := $($(sm)-platform-aflags)
54c5402ff6SJerome Forissiercflags$(sm)    := $($(sm)-platform-cflags) $(CFLAGS_$(sm))
55be3bc461SJerome Forissiercxxflags$(sm)  := $($(sm)-platform-cxxflags) $(CXXFLAGS_$(sm))
56be3bc461SJerome Forissierifneq (,$(shlibname))
57be3bc461SJerome Forissier# Exception handling is not supported in shared libraries (with GCC it would
58be3bc461SJerome Forissier# require to use the shared libgcc, which depend on the GNU libc)
59be3bc461SJerome Forissiercxxflags$(sm)  += -fno-exceptions
60be3bc461SJerome Forissierendif
613bce5ba1SJerome Forissier
621a48b444SJerome ForissierCFG_TEE_TA_LOG_LEVEL ?= 2
631a48b444SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL)
641a48b444SJerome Forissier
6535b4ef75SJens Wiklandercppflags$(sm) += -I. -I$(ta-dev-kit-dir$(sm))/include
66b0104773SPascal Brand
67b02ae382SSumit Gargifeq ($(CFG_TA_MCOUNT),y)
68b02ae382SSumit Gargcppflags$(sm) += -pg
69b02ae382SSumit Gargendif
70b02ae382SSumit Garg
7135b4ef75SJens Wiklanderlibdirs += $(ta-dev-kit-dir$(sm))/lib
72062e3d01SJens Wiklanderlibnames += utils
7335b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutils.a
74062e3d01SJens Wiklanderlibnames += utee
7535b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutee.a
76a97bc4a0SJens Wiklanderifeq ($(CFG_TA_MBEDTLS),y)
77a97bc4a0SJens Wiklanderlibnames += mbedtls
7835b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libmbedtls.a
79a97bc4a0SJens Wiklanderendif
80c96bced4SJerome Forissierlibnames += dl
81c96bced4SJerome Forissierlibdeps += $(ta-dev-kit-dir$(sm))/lib/libdl.a
82b0104773SPascal Brand
83f50962e3SVolodymyr Babchuk# libutils provides __getauxval symbol which is needed by libgcc 10.x. We can't
84f50962e3SVolodymyr Babchuk# link libutils after libgcc, because libgcc will replace some symbols provided
85f50962e3SVolodymyr Babchuk# by libutils, which will cause further linking issues.
86f50962e3SVolodymyr Babchuk#
87f50962e3SVolodymyr Babchuk# But if we place libutils before libgcc, linker will not be able to resolve
88f50962e3SVolodymyr Babchuk# __getauxval. So we need to link with libutils twice: before and after libgcc.
89f50962e3SVolodymyr Babchuk# Hence it included both in $(libnames) and in $(libnames-after-libgcc)
90f50962e3SVolodymyr Babchuklibnames-after-libgcc += utils
91f50962e3SVolodymyr Babchuklibdeps-after-libgcc += $(ta-dev-kit-dir$(sm))/lib/libutils.a
92f50962e3SVolodymyr Babchuk
93a62bf61eSJens Wiklander# Pass config variable (CFG_) from conf.mk on the command line
94a62bf61eSJens Wiklandercppflags$(sm) += $(strip \
95a62bf61eSJens Wiklander	$(foreach var, $(filter CFG_%,$(.VARIABLES)), \
96a62bf61eSJens Wiklander		$(if $(filter y,$($(var))), \
97a62bf61eSJens Wiklander			-D$(var)=1, \
98a62bf61eSJens Wiklander			$(if $(filter xn x,x$($(var))),,-D$(var)='$($(var))'))))
99a62bf61eSJens Wiklander
10035b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/cleandirs.mk
1019ac870c9SJerome Forissier
102b0104773SPascal Brand.PHONY: clean
103b0104773SPascal Brandclean:
1049ac870c9SJerome Forissier	@$(cmd-echo-silent) '  CLEAN   $(out-dir)'
105b0104773SPascal Brand	${q}rm -f $(cleanfiles)
10630a44336SJerome Forissier	${q}dirs="$(call cleandirs-for-rmdir)"; if [ "$$dirs" ]; then $(RMDIR) $$dirs; fi
1079ac870c9SJerome Forissier	@$(cmd-echo-silent) '  CLEAN   $(O)'
10830a44336SJerome Forissier	${q}if [ -d "$(O)" ]; then $(RMDIR) $(O); fi
109b0104773SPascal Brand
110331ebf7eSJerome Forissierinclude  $(ta-dev-kit-dir$(sm))/mk/$(COMPILER_$(sm)).mk
111331ebf7eSJerome Forissierinclude  $(ta-dev-kit-dir$(sm))/mk/cc-option.mk
112331ebf7eSJerome Forissier
113b0104773SPascal Brandsubdirs = .
11435b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/subdir.mk
1159faf0da7SZeng Tao
116d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),)
117ceae7156SJerome Forissier# Build target is TA
11835b4ef75SJens Wiklandervpath %.c $(ta-dev-kit-dir$(sm))/src
119b0104773SPascal Brandsrcs += user_ta_header.c
120c8061893SJerome Forissierifeq ($(sm),ta_arm32)
121c8061893SJerome Forissiervpath %.S $(ta-dev-kit-dir$(sm))/src
122c8061893SJerome Forissiersrcs += ta_entry_a32.S
123c8061893SJerome Forissierendif
1249faf0da7SZeng Taoendif
125b0104773SPascal Brand
12638f4260cSJerome ForissierSCRIPTS_DIR := $(ta-dev-kit-dir)/scripts
12735b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/compile.mk
128f8896d13SJerome Forissier
129d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),)
13035b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/link.mk
131ceae7156SJerome Forissierendif
132ceae7156SJerome Forissier
1339faf0da7SZeng Taoifneq ($(libname),)
134ceae7156SJerome Forissier# Build target is static library
1359faf0da7SZeng Taoall: $(libname).a
1369faf0da7SZeng Taocleanfiles += $(libname).a
1379faf0da7SZeng Tao
1389faf0da7SZeng Tao$(libname).a: $(objs)
1399faf0da7SZeng Tao	@echo '  AR      $@'
1409faf0da7SZeng Tao	$(q)rm -f $@ && $(AR$(sm)) rcs -o $@ $^
1419faf0da7SZeng Taoendif
142f8896d13SJerome Forissier
143f8896d13SJerome Forissierifneq (,$(shlibname))
14435b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link_shlib.mk
145f8896d13SJerome Forissierendif
146