1b0104773SPascal Brandinclude mk/cleanvars.mk 2b0104773SPascal Brand 3b0104773SPascal Brand# Set current submodule (used for module specific flags compile result etc) 4b0104773SPascal Brandsm := core 5b0104773SPascal Brandsm-$(sm) := y 6b0104773SPascal Brand 74334e8d7SJerome Forissierarch-dir := core/arch/$(ARCH) 84334e8d7SJerome Forissierplatform-dir := $(arch-dir)/plat-$(PLATFORM) 94334e8d7SJerome Forissierinclude $(platform-dir)/conf.mk 10739804b5SJens Wiklanderinclude mk/config.mk 11331ebf7eSJerome Forissier# $(ARCH).mk also sets the compiler for the core module 120de9a5fbSJens Wiklanderinclude core/arch/$(ARCH)/$(ARCH).mk 13b0104773SPascal Brand 14835688acSJerome Forissierifeq ($(CFG_OS_REV_REPORTS_GIT_SHA1),y) 15835688acSJerome Forissierifeq ($(arch-bits-core),64) 16835688acSJerome Forissiergit-sha1-len := 16 17835688acSJerome Forissierelse 18835688acSJerome Forissiergit-sha1-len := 8 19835688acSJerome Forissierendif 20835688acSJerome ForissierTEE_IMPL_GIT_SHA1 := 0x$(shell git rev-parse --short=$(git-sha1-len) HEAD 2>/dev/null || echo 0 | cut -c -$(git-sha1-len)) 21835688acSJerome Forissierelse 22835688acSJerome ForissierTEE_IMPL_GIT_SHA1 := 0x0 23835688acSJerome Forissierendif 24835688acSJerome Forissier 259fc53171SJerome ForissierPLATFORM_$(PLATFORM) := y 269fc53171SJerome ForissierPLATFORM_FLAVOR_$(PLATFORM_FLAVOR) := y 279fc53171SJerome Forissier 286b385aafSJerome Forissier$(eval $(call cfg-depends-all,CFG_PAGED_USER_TA,CFG_WITH_PAGER CFG_WITH_USER_TA)) 29a2a3dfbcSJens Wiklander_CFG_CORE_ASYNC_NOTIF_DEFAULT_IMPL ?= $(CFG_CORE_ASYNC_NOTIF) 303d3ad63dSJens Wiklanderinclude core/crypto.mk 31a884c935SJens Wiklander 324c4212e9SVincent Guittotifeq ($(CFG_SCMI_SCPFW),y) 334c4212e9SVincent Guittotinclude core/lib/scmi-server/conf.mk 344c4212e9SVincent Guittotendif 354c4212e9SVincent Guittot 3645082335SJens Wiklandercppflags$(sm) += -D__KERNEL__ 3745082335SJens Wiklander 38a3911433SJerome Forissiercppflags$(sm) += -Icore/include 39b5569a68SPascal Brandcppflags$(sm) += -include $(conf-file) 4089fe7c3cSJerome Forissiercppflags$(sm) += -I$(out-dir)/core/include 41739804b5SJens Wiklandercppflags$(sm) += $(core-platform-cppflags) 42739804b5SJens Wiklandercflags$(sm) += $(core-platform-cflags) 4345507d10SKhoa Hoang 4445507d10SKhoa Hoangcore-stackp-cflags-$(CFG_CORE_STACK_PROTECTOR) := -fstack-protector 4545507d10SKhoa Hoangcore-stackp-cflags-$(CFG_CORE_STACK_PROTECTOR_STRONG) := -fstack-protector-strong 4645507d10SKhoa Hoangcore-stackp-cflags-$(CFG_CORE_STACK_PROTECTOR_ALL) := -fstack-protector-all 4745507d10SKhoa Hoangcflags$(sm) += $(core-stackp-cflags-y) 4845507d10SKhoa Hoang 49be715239SJens Wiklanderifeq ($(CFG_CORE_SANITIZE_UNDEFINED),y) 50be715239SJens Wiklandercflags$(sm) += -fsanitize=undefined 51be715239SJens Wiklanderendif 521d171f95SJens Wiklanderifeq ($(CFG_CORE_SANITIZE_KADDRESS),y) 531d171f95SJens Wiklanderifeq ($(CFG_ASAN_SHADOW_OFFSET),) 541d171f95SJens Wiklander$(error error: CFG_CORE_SANITIZE_KADDRESS not supported by platform (flavor)) 551d171f95SJens Wiklanderendif 5698d863a5SJerome Forissierifeq ($(COMPILER),clang) 5798d863a5SJerome Forissier$(error error: CFG_CORE_SANITIZE_KADDRESS not supported with Clang) 5898d863a5SJerome Forissierendif 591d171f95SJens Wiklandercflags_kasan += -fsanitize=kernel-address \ 601d171f95SJens Wiklander -fasan-shadow-offset=$(CFG_ASAN_SHADOW_OFFSET)\ 611d171f95SJens Wiklander --param asan-stack=1 --param asan-globals=1 \ 621d171f95SJens Wiklander --param asan-instrumentation-with-call-threshold=0 631d171f95SJens Wiklandercflags$(sm) += $(cflags_kasan) 641d171f95SJens Wiklanderendif 65e2f03e07SJerome Forissierifeq ($(CFG_CORE_DEBUG_CHECK_STACKS),y) 66e2f03e07SJerome Forissierfinstrument-functions := $(call cc-option,-finstrument-functions) 67e2f03e07SJerome Forissierifeq (,$(finstrument-functions)) 68e2f03e07SJerome Forissier$(error -finstrument-functions not supported) 69e2f03e07SJerome Forissierendif 70e2f03e07SJerome Forissiercflags$(sm) += $(finstrument-functions) 71e2f03e07SJerome Forissierendif 72099918f6SSumit Gargifeq ($(CFG_SYSCALL_FTRACE),y) 73099918f6SSumit Gargcflags$(sm) += -pg 74099918f6SSumit Gargendif 75739804b5SJens Wiklanderaflags$(sm) += $(core-platform-aflags) 76b0104773SPascal Brand 778a1e7b89SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_CORE_LOG_LEVEL) 78156fe685SPascal Brandifeq ($(CFG_TEE_CORE_MALLOC_DEBUG),y) 79156fe685SPascal Brandcppflags$(sm) += -DENABLE_MDBG=1 80156fe685SPascal Brandendif 8199eee037SEtienne Carriereifneq ($(CFG_TEE_CORE_DEBUG),y) 8299eee037SEtienne Carrierecppflags$(sm) += -DNDEBUG 8399eee037SEtienne Carriereendif 84b0104773SPascal Brand 85dd22da8eSJens Wiklandercppflags$(sm) += -Ildelf/include 86b0104773SPascal Brandcppflags$(sm) += -Ilib/libutee/include 87b0104773SPascal Brand 888aeb6c94SJens Wiklanderifeq ($(filter y, $(CFG_CORE_DYN_SHM) $(CFG_CORE_RESERVED_SHM)),) 898aeb6c94SJens Wiklander$(error error: No shared memory configured) 908aeb6c94SJens Wiklanderendif 918aeb6c94SJens Wiklander 92fe52b1f5SJerome Forissier# Tell all libraries and sub-directories (included below) that we have a 93fe52b1f5SJerome Forissier# configuration file 94fe52b1f5SJerome Forissier 95b5569a68SPascal Brandconf-file := $(out-dir)/include/generated/conf.h 96b5569a68SPascal Brandconf-mk-file := $(out-dir)/conf.mk 97b924c494SJens Wiklanderconf-cmake-file := $(out-dir)/conf.cmake 98dde0e235Setienne carriere$(conf-file): $(conf-mk-file) 99dde0e235Setienne carriere 100fe52b1f5SJerome Forissiercleanfiles += $(conf-file) 101dde0e235Setienne carrierecleanfiles += $(conf-mk-file) 10240015a64SJerome Forissiercleanfiles += $(conf-cmake-file) 103fe52b1f5SJerome Forissier 104fe52b1f5SJerome Forissier$(conf-file): FORCE 105fe52b1f5SJerome Forissier $(call check-conf-h) 106fe52b1f5SJerome Forissier 107dde0e235Setienne carriere$(conf-mk-file): FORCE 1083354f9b2SJerome Forissier $(call check-conf-mk) 109dde0e235Setienne carriere 110b924c494SJens Wiklander$(conf-cmake-file): FORCE 111b924c494SJens Wiklander $(call check-conf-cmake) 112b924c494SJens Wiklander 113b0104773SPascal Brand# 114b0104773SPascal Brand# Do libraries 115b0104773SPascal Brand# 116b0104773SPascal Brand 117b0104773SPascal Brand# Set a prefix to avoid conflicts with user TAs that will use the same 118b0104773SPascal Brand# source but with different flags below 119b0104773SPascal Brandbase-prefix := $(sm)- 120b0104773SPascal Brandlibname = utils 121b0104773SPascal Brandlibdir = lib/libutils 122b0104773SPascal Brandinclude mk/lib.mk 123b0104773SPascal Brand 12418dd462bSJens Wiklander# CFG_CRYPTOLIB_NAME must not be changed beyond this line 12518dd462bSJens WiklanderCFG_CRYPTOLIB_NAME_$(CFG_CRYPTOLIB_NAME) := y 126e789ada3SJens Wiklander 127fcd21d9eSJens Wiklanderifeq ($(CFG_CRYPTOLIB_NAME),tomcrypt) 128e789ada3SJens Wiklander# We're compiling mbedtls too, but with a limited configuration which only 129e789ada3SJens Wiklander# provides the MPI routines 130e789ada3SJens Wiklanderlibname = mbedtls 131e789ada3SJens Wiklanderlibdir = lib/libmbedtls 132e789ada3SJens Wiklanderinclude mk/lib.mk 133fcd21d9eSJens Wiklanderendif #tomcrypt 134e789ada3SJens Wiklander 13577327d7aSEdison Aiifeq ($(CFG_CRYPTOLIB_NAME),mbedtls) 13677327d7aSEdison Ai$(call force,CFG_CRYPTO_RSASSA_NA1,n,not supported by mbedtls) 137884462feSJens Wiklanderlibname = tomcrypt 138884462feSJens Wiklanderlibdir = core/lib/libtomcrypt 139884462feSJens Wiklanderbase-prefix := 140884462feSJens Wiklanderinclude mk/lib.mk 141884462feSJens Wiklanderbase-prefix := $(sm)- 14277327d7aSEdison Aiendif 14377327d7aSEdison Ai 144fa788ef9SJens Wiklanderifeq ($(firstword $(subst /, ,$(CFG_CRYPTOLIB_DIR))),core) 145fa788ef9SJens Wiklander# If a library can be compiled for both core and user space a base-prefix 146fa788ef9SJens Wiklander# is needed in order to avoid conflicts in the output. However, if the 147fa788ef9SJens Wiklander# library resides under core then it can't be compiled to user space. 148b0104773SPascal Brandbase-prefix := 149fa788ef9SJens Wiklanderendif 150b0104773SPascal Brand 151d2d2d58bSdeebee-v2libname = $(CFG_CRYPTOLIB_NAME) 152d2d2d58bSdeebee-v2libdir = $(CFG_CRYPTOLIB_DIR) 153b0104773SPascal Brandinclude mk/lib.mk 154b0104773SPascal Brand 155fa788ef9SJens Wiklanderbase-prefix := 156fa788ef9SJens Wiklander 157b908c675SJens Wiklanderlibname = fdt 158b908c675SJens Wiklanderlibdir = core/lib/libfdt 159b908c675SJens Wiklanderinclude mk/lib.mk 160b908c675SJens Wiklander 161b3be2f66SJerome Forissierifeq ($(CFG_ZLIB),y) 162b3be2f66SJerome Forissierlibname = zlib 163b3be2f66SJerome Forissierlibdir = core/lib/zlib 164b3be2f66SJerome Forissierinclude mk/lib.mk 165b3be2f66SJerome Forissierendif 166b3be2f66SJerome Forissier 16702d307b7SJerome Forissierlibname = unw 16802d307b7SJerome Forissierlibdir = lib/libunw 16902d307b7SJerome Forissierinclude mk/lib.mk 17002d307b7SJerome Forissier 1714c4212e9SVincent Guittotifeq ($(CFG_SCMI_SCPFW),y) 1724c4212e9SVincent Guittotlibname = scmi-server 1734c4212e9SVincent Guittotlibdir = core/lib/scmi-server 1744c4212e9SVincent Guittotinclude mk/lib.mk 1754c4212e9SVincent Guittotendif 1764c4212e9SVincent Guittot 177*a796042aSYuichi Sugiyamaifeq ($(CFG_QCBOR),y) 178*a796042aSYuichi Sugiyamalibname = qcbor 179*a796042aSYuichi Sugiyamalibdir = core/lib/qcbor 180*a796042aSYuichi Sugiyamainclude mk/lib.mk 181*a796042aSYuichi Sugiyamaendif 182*a796042aSYuichi Sugiyama 183b0104773SPascal Brand# 184b0104773SPascal Brand# Do main source 185b0104773SPascal Brand# 186bc420748SJens Wiklander 187b0104773SPascal Brandsubdirs = $(core-platform-subdirs) core 188b0104773SPascal Brandinclude mk/subdir.mk 189bc420748SJens Wiklander 190b0104773SPascal Brandinclude mk/compile.mk 191d5a887c8SJens Wiklander 19271315c30SAndrew F. Davisinclude $(if $(wildcard $(platform-dir)/link.mk), \ 19371315c30SAndrew F. Davis $(platform-dir)/link.mk, \ 19471315c30SAndrew F. Davis core/arch/$(ARCH)/kernel/link.mk) 195