quark: Introduce Quark Secure Partition
Test partition designed to have a virtual address space as small as
possible in order to test the extension ARMv8.4-TTST. This Secure
Partition doesn't have print capabilities. The only service it provides
is one that returns a magic number to verify that it has been loaded.
Change-Id: I431f6c65f2926d486836d12ddfefe05e83b0c47f
Signed-off-by: Antonio Nino Diaz <antonio.ninodiaz@arm.com>
diff --git a/spm/quark/quark.mk b/spm/quark/quark.mk
new file mode 100644
index 0000000..554d334
--- /dev/null
+++ b/spm/quark/quark.mk
@@ -0,0 +1,64 @@
+#
+# Copyright (c) 2018-2019, Arm Limited. All rights reserved.
+#
+# SPDX-License-Identifier: BSD-3-Clause
+#
+
+include lib/sprt/sprt_client.mk
+
+QUARK_DTB := $(BUILD_PLAT)/quark.dtb
+
+QUARK_INCLUDES := \
+ -Iinclude \
+ -Iinclude/common \
+ -Iinclude/common/${ARCH} \
+ -Iinclude/lib \
+ -Iinclude/lib/${ARCH} \
+ -Iinclude/lib/sprt \
+ -Iinclude/lib/utils \
+ -Iinclude/lib/xlat_tables \
+ -Iinclude/runtime_services \
+ -Iinclude/runtime_services/secure_el0_payloads \
+ -Ispm/quark \
+ -Ispm/common \
+ ${SPRT_LIB_INCLUDES}
+
+QUARK_SOURCES := \
+ $(addprefix spm/quark/, \
+ aarch64/quark_entrypoint.S \
+ quark_main.c \
+ ) \
+ $(addprefix spm/common/, \
+ aarch64/sp_arch_helpers.S \
+ sp_helpers.c \
+ ) \
+
+# TODO: Remove dependency on TFTF files.
+QUARK_SOURCES += \
+ tftf/framework/debug.c \
+ tftf/framework/${ARCH}/asm_debug.S
+
+QUARK_SOURCES += drivers/console/${ARCH}/dummy_console.S \
+ lib/locks/${ARCH}/spinlock.S \
+ lib/utils/mp_printf.c \
+ ${SPRT_LIB_SOURCES}
+
+QUARK_LINKERFILE := spm/quark/quark.ld.S
+
+QUARK_DEFINES :=
+
+$(eval $(call add_define,QUARK_DEFINES,DEBUG))
+$(eval $(call add_define,QUARK_DEFINES,ENABLE_ASSERTIONS))
+$(eval $(call add_define,QUARK_DEFINES,PLAT_${PLAT}))
+$(eval $(call add_define,QUARK_DEFINES,AARCH64))
+
+$(QUARK_DTB) : $(BUILD_PLAT)/quark $(BUILD_PLAT)/quark/quark.elf
+$(QUARK_DTB) : spm/quark/quark.dts
+ @echo " DTBGEN spm/quark/quark.dts"
+ ${Q}tools/generate_dtb/generate_dtb.sh \
+ quark spm/quark/quark.dts $(BUILD_PLAT)
+ @echo
+ @echo "Built $@ successfully"
+ @echo
+
+quark: $(QUARK_DTB) $(AUTOGEN_DIR)/tests_list.h