xref: /optee_os/ta/mk/ta_dev_kit.mk (revision 1283e108ad11f392f4f69f8e77b055e928349d15)
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
105831e426SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/macros.mk
115831e426SJens Wiklander
12f8896d13SJerome Forissierifneq (1, $(words $(BINARY) $(LIBNAME) $(SHLIBNAME)))
13f8896d13SJerome Forissier$(error You must specify exactly one of BINARY, LIBNAME or SHLIBNAME)
14ceae7156SJerome Forissierendif
15ceae7156SJerome Forissier
16b0104773SPascal Brandifneq ($O,)
174334e8d7SJerome Forissierout-dir := $O
18c3c7db16SJerome Forissierelse
19c3c7db16SJerome Forissierout-dir := .
20b0104773SPascal Brandendif
2135b4ef75SJens Wiklanderlink-out-dir := $(out-dir)	# backward compat
2235b4ef75SJens Wiklanderlink-out-dir$(sm) := $(out-dir)
2335b4ef75SJens Wiklander
24d58d79ecSJens Wiklanderuser-ta-uuid := $(BINARY)
25682f256cSSumit Garguser-ta-version := $(if $(CFG_TA_VERSION),$(CFG_TA_VERSION),0)
26d58d79ecSJens Wiklanderuser-ta-ldadd := $(LDADD)
2735b4ef75SJens Wiklanderlibname := $(LIBNAME)
2835b4ef75SJens Wiklandershlibname := $(SHLIBNAME)
2935b4ef75SJens Wiklandershlibuuid := $(SHLIBUUID)
3035b4ef75SJens Wiklander
3119fdfcf6SEtienne Carrierearch-bits-ta_arm32 := 32
3219fdfcf6SEtienne Carrierearch-bits-ta_arm64 := 64
33b0104773SPascal Brand
340ee43c37SClement Faure# For convenience
350ee43c37SClement Faureifdef CFLAGS
360ee43c37SClement FaureCFLAGS32 ?= $(CFLAGS)
370ee43c37SClement FaureCFLAGS64 ?= $(CFLAGS)
380ee43c37SClement Faureendif
390ee43c37SClement Faure
40b0104773SPascal Brandifneq ($V,1)
41b0104773SPascal Brandq := @
42b0104773SPascal Brandcmd-echo := true
4362428631SJens Wiklandercmd-echo-silent := echo
44b0104773SPascal Brandelse
45b0104773SPascal Brandq :=
46b0104773SPascal Brandcmd-echo := echo
4762428631SJens Wiklandercmd-echo-silent := true
48b0104773SPascal Brandendif
49b0104773SPascal Brand
5062428631SJens Wiklanderifneq ($(filter 4.%,$(MAKE_VERSION)),)  # make-4
5162428631SJens Wiklanderifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),)
5262428631SJens Wiklandercmd-echo-silent := true
5362428631SJens Wiklanderendif
5462428631SJens Wiklanderelse                                    # make-3.8x
553dc79b0dSPascal Brandifneq ($(findstring s, $(MAKEFLAGS)),)
5662428631SJens Wiklandercmd-echo-silent := true
5762428631SJens Wiklanderendif
5862428631SJens Wiklanderendif
5962428631SJens Wiklander
60c5402ff6SJerome Forissiercppflags$(sm)  := $($(sm)-platform-cppflags) $(CPPFLAGS_$(sm))
61739804b5SJens Wiklanderaflags$(sm)    := $($(sm)-platform-aflags)
62c5402ff6SJerome Forissiercflags$(sm)    := $($(sm)-platform-cflags) $(CFLAGS_$(sm))
63be3bc461SJerome Forissiercxxflags$(sm)  := $($(sm)-platform-cxxflags) $(CXXFLAGS_$(sm))
64be3bc461SJerome Forissierifneq (,$(shlibname))
65be3bc461SJerome Forissier# Exception handling is not supported in shared libraries (with GCC it would
66be3bc461SJerome Forissier# require to use the shared libgcc, which depend on the GNU libc)
67be3bc461SJerome Forissiercxxflags$(sm)  += -fno-exceptions
68be3bc461SJerome Forissierendif
693bce5ba1SJerome Forissier
708bbc2e9cSJens Wiklanderifeq ($(CFG_TA_OPTEE_CORE_API_COMPAT_1_1),y)
718bbc2e9cSJens Wiklandercppflags$(sm)	+= -D__OPTEE_CORE_API_COMPAT_1_1=1
728bbc2e9cSJens Wiklanderendif
731a48b444SJerome ForissierCFG_TEE_TA_LOG_LEVEL ?= 2
741a48b444SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL)
751a48b444SJerome Forissier
7635b4ef75SJens Wiklandercppflags$(sm) += -I. -I$(ta-dev-kit-dir$(sm))/include
77b0104773SPascal Brand
78b02ae382SSumit Gargifeq ($(CFG_TA_MCOUNT),y)
79b02ae382SSumit Gargcppflags$(sm) += -pg
80b02ae382SSumit Gargendif
81b02ae382SSumit Garg
82949b0c0cSAleksandr Iashchenkoifeq ($(CFG_TA_SANITIZE_UNDEFINED),y)
83949b0c0cSAleksandr Iashchenkocflags$(sm) += -fsanitize=undefined
84949b0c0cSAleksandr Iashchenkoendif
85949b0c0cSAleksandr Iashchenko
8635b4ef75SJens Wiklanderlibdirs += $(ta-dev-kit-dir$(sm))/lib
87062e3d01SJens Wiklanderlibnames += utils
8835b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutils.a
89062e3d01SJens Wiklanderlibnames += utee
9035b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutee.a
91a97bc4a0SJens Wiklanderifeq ($(CFG_TA_MBEDTLS),y)
92a97bc4a0SJens Wiklanderlibnames += mbedtls
9335b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libmbedtls.a
94a97bc4a0SJens Wiklanderendif
95c96bced4SJerome Forissierlibnames += dl
96c96bced4SJerome Forissierlibdeps += $(ta-dev-kit-dir$(sm))/lib/libdl.a
97b0104773SPascal Brand
98f50962e3SVolodymyr Babchuk# libutils provides __getauxval symbol which is needed by libgcc 10.x. We can't
99f50962e3SVolodymyr Babchuk# link libutils after libgcc, because libgcc will replace some symbols provided
100f50962e3SVolodymyr Babchuk# by libutils, which will cause further linking issues.
101f50962e3SVolodymyr Babchuk#
102f50962e3SVolodymyr Babchuk# But if we place libutils before libgcc, linker will not be able to resolve
103f50962e3SVolodymyr Babchuk# __getauxval. So we need to link with libutils twice: before and after libgcc.
104f50962e3SVolodymyr Babchuk# Hence it included both in $(libnames) and in $(libnames-after-libgcc)
105f50962e3SVolodymyr Babchuklibnames-after-libgcc += utils
106f50962e3SVolodymyr Babchuklibdeps-after-libgcc += $(ta-dev-kit-dir$(sm))/lib/libutils.a
107f50962e3SVolodymyr Babchuk
108*1283e108SAlvin Chang# Pass config variable (CFG_) and (_CFG_) from conf.mk on the command line
109a62bf61eSJens Wiklandercppflags$(sm) += $(strip \
110*1283e108SAlvin Chang	$(foreach var, $(filter CFG_% _CFG_%,$(.VARIABLES)), \
111a62bf61eSJens Wiklander		$(if $(filter y,$($(var))), \
112a62bf61eSJens Wiklander			-D$(var)=1, \
113a62bf61eSJens Wiklander			$(if $(filter xn x,x$($(var))),,-D$(var)='$($(var))'))))
114a62bf61eSJens Wiklander
11535b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/cleandirs.mk
1169ac870c9SJerome Forissier
117b0104773SPascal Brand.PHONY: clean
118b0104773SPascal Brandclean:
1199ac870c9SJerome Forissier	@$(cmd-echo-silent) '  CLEAN   $(out-dir)'
120b0104773SPascal Brand	${q}rm -f $(cleanfiles)
12130a44336SJerome Forissier	${q}dirs="$(call cleandirs-for-rmdir)"; if [ "$$dirs" ]; then $(RMDIR) $$dirs; fi
1229ac870c9SJerome Forissier	@$(cmd-echo-silent) '  CLEAN   $(O)'
12330a44336SJerome Forissier	${q}if [ -d "$(O)" ]; then $(RMDIR) $(O); fi
124b0104773SPascal Brand
125331ebf7eSJerome Forissierinclude  $(ta-dev-kit-dir$(sm))/mk/$(COMPILER_$(sm)).mk
126331ebf7eSJerome Forissierinclude  $(ta-dev-kit-dir$(sm))/mk/cc-option.mk
127331ebf7eSJerome Forissier
128b0104773SPascal Brandsubdirs = .
12935b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/subdir.mk
1309faf0da7SZeng Tao
131d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),)
132ceae7156SJerome Forissier# Build target is TA
133fc9ea0dbSJens Wiklanderspec-out-dir := $(link-out-dir$(sm))
134fc9ea0dbSJens Wiklanderspec-srcs += $(ta-dev-kit-dir$(sm))/src/user_ta_header.c
135c8061893SJerome Forissierifeq ($(sm),ta_arm32)
136fc9ea0dbSJens Wiklanderspec-srcs += $(ta-dev-kit-dir$(sm))/src/ta_entry_a32.S
137c8061893SJerome Forissierendif
1389faf0da7SZeng Taoendif
139b0104773SPascal Brand
14038f4260cSJerome ForissierSCRIPTS_DIR := $(ta-dev-kit-dir)/scripts
14135b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/compile.mk
142f8896d13SJerome Forissier
143d58d79ecSJens Wiklanderifneq ($(user-ta-uuid),)
14435b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/link.mk
145ceae7156SJerome Forissierendif
146ceae7156SJerome Forissier
1479faf0da7SZeng Taoifneq ($(libname),)
148ceae7156SJerome Forissier# Build target is static library
149d1b003feSTadd Kaoall: $(link-out-dir$(sm))/$(libname).a
150d1b003feSTadd Kaocleanfiles += $(link-out-dir$(sm))/$(libname).a
1519faf0da7SZeng Tao
152d1b003feSTadd Kao$(link-out-dir$(sm))/$(libname).a: $(objs)
1539faf0da7SZeng Tao	@echo '  AR      $@'
154830faadeSJerome Forissier	$(q)rm -f $@ && $(AR$(sm)) rcs $@ $^
1559faf0da7SZeng Taoendif
156f8896d13SJerome Forissier
157f8896d13SJerome Forissierifneq (,$(shlibname))
15835b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link_shlib.mk
159f8896d13SJerome Forissierendif
160