xref: /optee_os/ta/mk/ta_dev_kit.mk (revision 35b4ef75d056aa8e5657df14af016c31f1ad6c0c)
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
8*35b4ef75SJens 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
19*35b4ef75SJens Wiklanderlink-out-dir := $(out-dir)	# backward compat
20*35b4ef75SJens Wiklanderlink-out-dir$(sm) := $(out-dir)
21*35b4ef75SJens Wiklander
22*35b4ef75SJens Wiklanderbinary := $(BINARY)
23*35b4ef75SJens Wiklanderlibname := $(LIBNAME)
24*35b4ef75SJens Wiklandershlibname := $(SHLIBNAME)
25*35b4ef75SJens Wiklandershlibuuid := $(SHLIBUUID)
26*35b4ef75SJens Wiklander
27b0104773SPascal Brand
28b0104773SPascal Brandifneq ($V,1)
29b0104773SPascal Brandq := @
30b0104773SPascal Brandcmd-echo := true
3162428631SJens Wiklandercmd-echo-silent := echo
32b0104773SPascal Brandelse
33b0104773SPascal Brandq :=
34b0104773SPascal Brandcmd-echo := echo
3562428631SJens Wiklandercmd-echo-silent := true
36b0104773SPascal Brandendif
37b0104773SPascal Brand
3862428631SJens Wiklanderifneq ($(filter 4.%,$(MAKE_VERSION)),)  # make-4
3962428631SJens Wiklanderifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),)
4062428631SJens Wiklandercmd-echo-silent := true
4162428631SJens Wiklanderendif
4262428631SJens Wiklanderelse                                    # make-3.8x
433dc79b0dSPascal Brandifneq ($(findstring s, $(MAKEFLAGS)),)
4462428631SJens Wiklandercmd-echo-silent := true
4562428631SJens Wiklanderendif
4662428631SJens Wiklanderendif
4762428631SJens Wiklander
48c5402ff6SJerome Forissiercppflags$(sm)  := $($(sm)-platform-cppflags) $(CPPFLAGS_$(sm))
49739804b5SJens Wiklanderaflags$(sm)    := $($(sm)-platform-aflags)
50c5402ff6SJerome Forissiercflags$(sm)    := $($(sm)-platform-cflags) $(CFLAGS_$(sm))
513bce5ba1SJerome Forissier
521a48b444SJerome ForissierCFG_TEE_TA_LOG_LEVEL ?= 2
531a48b444SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_TA_LOG_LEVEL)
541a48b444SJerome Forissier
55*35b4ef75SJens Wiklandercppflags$(sm) += -I. -I$(ta-dev-kit-dir$(sm))/include
56b0104773SPascal Brand
57*35b4ef75SJens Wiklanderlibdirs += $(ta-dev-kit-dir$(sm))/lib
58be5c06caSJerome Forissierlibnames += utils utee mpa
59*35b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutils.a
60*35b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libmpa.a
61*35b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libutee.a
62a97bc4a0SJens Wiklanderifeq ($(CFG_TA_MBEDTLS),y)
63a97bc4a0SJens Wiklanderlibnames += mbedtls
64*35b4ef75SJens Wiklanderlibdeps += $(ta-dev-kit-dir$(sm))/lib/libmbedtls.a
65a97bc4a0SJens Wiklanderendif
66b0104773SPascal Brand
67a62bf61eSJens Wiklander# Pass config variable (CFG_) from conf.mk on the command line
68a62bf61eSJens Wiklandercppflags$(sm) += $(strip \
69a62bf61eSJens Wiklander	$(foreach var, $(filter CFG_%,$(.VARIABLES)), \
70a62bf61eSJens Wiklander		$(if $(filter y,$($(var))), \
71a62bf61eSJens Wiklander			-D$(var)=1, \
72a62bf61eSJens Wiklander			$(if $(filter xn x,x$($(var))),,-D$(var)='$($(var))'))))
73a62bf61eSJens Wiklander
74*35b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/cleandirs.mk
759ac870c9SJerome Forissier
76b0104773SPascal Brand.PHONY: clean
77b0104773SPascal Brandclean:
789ac870c9SJerome Forissier	@$(cmd-echo-silent) '  CLEAN   $(out-dir)'
79b0104773SPascal Brand	${q}rm -f $(cleanfiles)
8030a44336SJerome Forissier	${q}dirs="$(call cleandirs-for-rmdir)"; if [ "$$dirs" ]; then $(RMDIR) $$dirs; fi
819ac870c9SJerome Forissier	@$(cmd-echo-silent) '  CLEAN   $(O)'
8230a44336SJerome Forissier	${q}if [ -d "$(O)" ]; then $(RMDIR) $(O); fi
83b0104773SPascal Brand
84b0104773SPascal Brandsubdirs = .
85*35b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/subdir.mk
869faf0da7SZeng Tao
879faf0da7SZeng Taoifneq ($(binary),)
88ceae7156SJerome Forissier# Build target is TA
89*35b4ef75SJens Wiklandervpath %.c $(ta-dev-kit-dir$(sm))/src
90b0104773SPascal Brandsrcs += user_ta_header.c
919faf0da7SZeng Taoendif
92b0104773SPascal Brand
93*35b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/gcc.mk
94*35b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/compile.mk
95f8896d13SJerome Forissier
969faf0da7SZeng Taoifneq ($(binary),)
97*35b4ef75SJens Wiklanderinclude  $(ta-dev-kit-dir$(sm))/mk/link.mk
98ceae7156SJerome Forissierendif
99ceae7156SJerome Forissier
1009faf0da7SZeng Taoifneq ($(libname),)
101ceae7156SJerome Forissier# Build target is static library
1029faf0da7SZeng Taoall: $(libname).a
1039faf0da7SZeng Taocleanfiles += $(libname).a
1049faf0da7SZeng Tao
1059faf0da7SZeng Tao$(libname).a: $(objs)
1069faf0da7SZeng Tao	@echo '  AR      $@'
1079faf0da7SZeng Tao	$(q)rm -f $@ && $(AR$(sm)) rcs -o $@ $^
1089faf0da7SZeng Taoendif
109f8896d13SJerome Forissier
110f8896d13SJerome Forissierifneq (,$(shlibname))
111*35b4ef75SJens Wiklanderinclude $(ta-dev-kit-dir$(sm))/mk/link_shlib.mk
112f8896d13SJerome Forissierendif
113