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) 9dffb0049SJerome Forissierinclude mk/checkconf.mk 104334e8d7SJerome Forissierinclude $(platform-dir)/conf.mk 11739804b5SJens Wiklanderinclude mk/config.mk 120de9a5fbSJens Wiklanderinclude core/arch/$(ARCH)/$(ARCH).mk 13b0104773SPascal Brand 149fc53171SJerome ForissierPLATFORM_$(PLATFORM) := y 159fc53171SJerome ForissierPLATFORM_FLAVOR_$(PLATFORM_FLAVOR) := y 169fc53171SJerome Forissier 171b4eb4f5SJens Wiklander# Setup compiler for this sub module 181b4eb4f5SJens WiklanderCOMPILER_$(sm) ?= $(COMPILER) 191b4eb4f5SJens Wiklanderinclude mk/$(COMPILER_$(sm)).mk 201b4eb4f5SJens Wiklander 2145082335SJens Wiklandercppflags$(sm) += -D__KERNEL__ 2245082335SJens Wiklander 23a3911433SJerome Forissiercppflags$(sm) += -Icore/include 24b5569a68SPascal Brandcppflags$(sm) += -include $(conf-file) 25d5a887c8SJens Wiklandercppflags$(sm) += -I$(out-dir)/core/include/generated 26739804b5SJens Wiklandercppflags$(sm) += $(core-platform-cppflags) 27739804b5SJens Wiklandercflags$(sm) += $(core-platform-cflags) 28be715239SJens Wiklanderifeq ($(CFG_CORE_SANITIZE_UNDEFINED),y) 29be715239SJens Wiklandercflags$(sm) += -fsanitize=undefined 30be715239SJens Wiklanderendif 31*1d171f95SJens Wiklanderifeq ($(CFG_CORE_SANITIZE_KADDRESS),y) 32*1d171f95SJens Wiklanderifeq ($(CFG_ASAN_SHADOW_OFFSET),) 33*1d171f95SJens Wiklander$(error error: CFG_CORE_SANITIZE_KADDRESS not supported by platform (flavor)) 34*1d171f95SJens Wiklanderendif 35*1d171f95SJens Wiklandercflags_kasan += -fsanitize=kernel-address \ 36*1d171f95SJens Wiklander -fasan-shadow-offset=$(CFG_ASAN_SHADOW_OFFSET)\ 37*1d171f95SJens Wiklander --param asan-stack=1 --param asan-globals=1 \ 38*1d171f95SJens Wiklander --param asan-instrumentation-with-call-threshold=0 39*1d171f95SJens Wiklandercflags$(sm) += $(cflags_kasan) 40*1d171f95SJens Wiklanderendif 41739804b5SJens Wiklanderaflags$(sm) += $(core-platform-aflags) 42b0104773SPascal Brand 438a1e7b89SJerome Forissiercppflags$(sm) += -DTRACE_LEVEL=$(CFG_TEE_CORE_LOG_LEVEL) 44156fe685SPascal Brandifeq ($(CFG_TEE_CORE_MALLOC_DEBUG),y) 45156fe685SPascal Brandcppflags$(sm) += -DENABLE_MDBG=1 46156fe685SPascal Brandendif 4799eee037SEtienne Carriereifneq ($(CFG_TEE_CORE_DEBUG),y) 4899eee037SEtienne Carrierecppflags$(sm) += -DNDEBUG 4999eee037SEtienne Carriereendif 50b0104773SPascal Brand 51b0104773SPascal Brandcppflags$(sm) += -Ilib/libutee/include 52b0104773SPascal Brand 53fe52b1f5SJerome Forissier# Tell all libraries and sub-directories (included below) that we have a 54fe52b1f5SJerome Forissier# configuration file 55fe52b1f5SJerome Forissier 56b5569a68SPascal Brandconf-file := $(out-dir)/include/generated/conf.h 57b5569a68SPascal Brandconf-mk-file := $(out-dir)/conf.mk 58dde0e235Setienne carriere$(conf-file): $(conf-mk-file) 59dde0e235Setienne carriere 60fe52b1f5SJerome Forissiercleanfiles += $(conf-file) 61dde0e235Setienne carrierecleanfiles += $(conf-mk-file) 62fe52b1f5SJerome Forissier 63fe52b1f5SJerome Forissier$(conf-file): FORCE 64fe52b1f5SJerome Forissier $(call check-conf-h) 65fe52b1f5SJerome Forissier 66dde0e235Setienne carriere$(conf-mk-file): FORCE 673354f9b2SJerome Forissier $(call check-conf-mk) 68dde0e235Setienne carriere 69b0104773SPascal Brand# 70b0104773SPascal Brand# Do libraries 71b0104773SPascal Brand# 72b0104773SPascal Brand 73b0104773SPascal Brand# Set a prefix to avoid conflicts with user TAs that will use the same 74b0104773SPascal Brand# source but with different flags below 75b0104773SPascal Brandbase-prefix := $(sm)- 76b0104773SPascal Brandlibname = utils 77b0104773SPascal Brandlibdir = lib/libutils 78b0104773SPascal Brandinclude mk/lib.mk 79b0104773SPascal Brand 80b0104773SPascal Brandlibname = mpa 81b0104773SPascal Brandlibdir = lib/libmpa 82b0104773SPascal Brandinclude mk/lib.mk 83b0104773SPascal Brandbase-prefix := 84b0104773SPascal Brand 85b0104773SPascal Brandlibname = tomcrypt 86b0104773SPascal Brandlibdir = core/lib/libtomcrypt 87b0104773SPascal Brandinclude mk/lib.mk 88b0104773SPascal Brand 89b908c675SJens Wiklanderifeq ($(CFG_DT),y) 90b908c675SJens Wiklanderlibname = fdt 91b908c675SJens Wiklanderlibdir = core/lib/libfdt 92b908c675SJens Wiklanderinclude mk/lib.mk 93b908c675SJens Wiklanderendif 94b908c675SJens Wiklander 95b0104773SPascal Brand# 96b0104773SPascal Brand# Do main source 97b0104773SPascal Brand# 98bc420748SJens Wiklander 99b0104773SPascal Brandsubdirs = $(core-platform-subdirs) core 100b0104773SPascal Brandinclude mk/subdir.mk 101bc420748SJens Wiklander 102d5a887c8SJens Wiklanderasm-defines-file := core/arch/$(ARCH)/kernel/asm-defines.c 103b0104773SPascal Brandinclude mk/compile.mk 104d5a887c8SJens Wiklander 1054334e8d7SJerome Forissierinclude $(platform-dir)/link.mk 106