xref: /rk3399_ARM-atf/plat/xilinx/versal/platform.mk (revision a6ea06f563bf1a7545732892d1da3bf2dced2e47)
131ce893eSVenkatesh Yadav Abbarapu# Copyright (c) 2018-2020, ARM Limited and Contributors. All rights reserved.
2f91c3cb1SSiva Durga Prasad Paladugu#
3f91c3cb1SSiva Durga Prasad Paladugu# SPDX-License-Identifier: BSD-3-Clause
4f91c3cb1SSiva Durga Prasad Paladugu
5f91c3cb1SSiva Durga Prasad Paladuguoverride PROGRAMMABLE_RESET_ADDRESS := 1
6f91c3cb1SSiva Durga Prasad PaladuguPSCI_EXTENDED_STATE_ID := 1
7f91c3cb1SSiva Durga Prasad PaladuguA53_DISABLE_NON_TEMPORAL_HINT := 0
8f91c3cb1SSiva Durga Prasad PaladuguSEPARATE_CODE_AND_RODATA := 1
9f91c3cb1SSiva Durga Prasad Paladuguoverride RESET_TO_BL31 := 1
10f91c3cb1SSiva Durga Prasad PaladuguPL011_GENERIC_UART := 1
11f91c3cb1SSiva Durga Prasad Paladugu
12f91c3cb1SSiva Durga Prasad Paladuguifdef VERSAL_ATF_MEM_BASE
13f91c3cb1SSiva Durga Prasad Paladugu    $(eval $(call add_define,VERSAL_ATF_MEM_BASE))
14f91c3cb1SSiva Durga Prasad Paladugu
15f91c3cb1SSiva Durga Prasad Paladugu    ifndef VERSAL_ATF_MEM_SIZE
16f91c3cb1SSiva Durga Prasad Paladugu        $(error "VERSAL_ATF_BASE defined without VERSAL_ATF_SIZE")
17f91c3cb1SSiva Durga Prasad Paladugu    endif
18f91c3cb1SSiva Durga Prasad Paladugu    $(eval $(call add_define,VERSAL_ATF_MEM_SIZE))
19f91c3cb1SSiva Durga Prasad Paladugu
20f91c3cb1SSiva Durga Prasad Paladugu    ifdef VERSAL_ATF_MEM_PROGBITS_SIZE
21f91c3cb1SSiva Durga Prasad Paladugu        $(eval $(call add_define,VERSAL_ATF_MEM_PROGBITS_SIZE))
22f91c3cb1SSiva Durga Prasad Paladugu    endif
23f91c3cb1SSiva Durga Prasad Paladuguendif
24f91c3cb1SSiva Durga Prasad Paladugu
25f91c3cb1SSiva Durga Prasad Paladuguifdef VERSAL_BL32_MEM_BASE
26f91c3cb1SSiva Durga Prasad Paladugu    $(eval $(call add_define,VERSAL_BL32_MEM_BASE))
27f91c3cb1SSiva Durga Prasad Paladugu
28f91c3cb1SSiva Durga Prasad Paladugu    ifndef VERSAL_BL32_MEM_SIZE
29f91c3cb1SSiva Durga Prasad Paladugu        $(error "VERSAL_BL32_BASE defined without VERSAL_BL32_SIZE")
30f91c3cb1SSiva Durga Prasad Paladugu    endif
31f91c3cb1SSiva Durga Prasad Paladugu    $(eval $(call add_define,VERSAL_BL32_MEM_SIZE))
32f91c3cb1SSiva Durga Prasad Paladuguendif
33f91c3cb1SSiva Durga Prasad Paladugu
347b9f0cfdSSiva Durga Prasad PaladuguVERSAL_PLATFORM ?= silicon
35f91c3cb1SSiva Durga Prasad Paladugu$(eval $(call add_define_val,VERSAL_PLATFORM,VERSAL_PLATFORM_ID_${VERSAL_PLATFORM}))
36f91c3cb1SSiva Durga Prasad Paladugu
37f91c3cb1SSiva Durga Prasad PaladuguVERSAL_CONSOLE	?=	pl011
38f91c3cb1SSiva Durga Prasad Paladugu$(eval $(call add_define_val,VERSAL_CONSOLE,VERSAL_CONSOLE_ID_${VERSAL_CONSOLE}))
39f91c3cb1SSiva Durga Prasad Paladugu
405a8ffeabSTejas PatelPLAT_INCLUDES		:=	-Iinclude/plat/arm/common/			\
415a8ffeabSTejas Patel				-Iplat/xilinx/common/include/			\
426e2f0d10SWendy Liang				-Iplat/xilinx/common/ipi_mailbox_service/	\
43c73a90e5STejas Patel				-Iplat/xilinx/versal/include/			\
44c73a90e5STejas Patel				-Iplat/xilinx/versal/pm_service/
45f91c3cb1SSiva Durga Prasad Paladugu
46*a6ea06f5SAlexei Fedorov# Include GICv3 driver files
47*a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk
48*a6ea06f5SAlexei Fedorov
49f91c3cb1SSiva Durga Prasad PaladuguPLAT_BL_COMMON_SOURCES	:=	lib/xlat_tables/xlat_tables_common.c		\
50f91c3cb1SSiva Durga Prasad Paladugu				lib/xlat_tables/aarch64/xlat_tables.c		\
51f91c3cb1SSiva Durga Prasad Paladugu				drivers/delay_timer/delay_timer.c		\
52f91c3cb1SSiva Durga Prasad Paladugu				drivers/delay_timer/generic_delay_timer.c	\
53*a6ea06f5SAlexei Fedorov				${GICV3_SOURCES}				\
54f91c3cb1SSiva Durga Prasad Paladugu				drivers/arm/pl011/aarch64/pl011_console.S	\
552cc97771SAmbroise Vincent				plat/common/aarch64/crash_console_helpers.S	\
565a8ffeabSTejas Patel				plat/arm/common/arm_cci.c			\
5731ce893eSVenkatesh Yadav Abbarapu				plat/arm/common/arm_common.c			\
58f91c3cb1SSiva Durga Prasad Paladugu				plat/common/plat_gicv3.c			\
59f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/aarch64/versal_helpers.S	\
60f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/aarch64/versal_common.c
61f91c3cb1SSiva Durga Prasad Paladugu
625a8ffeabSTejas PatelBL31_SOURCES		+=	drivers/arm/cci/cci.c				\
635a8ffeabSTejas Patel				lib/cpus/aarch64/cortex_a53.S			\
64f91c3cb1SSiva Durga Prasad Paladugu				lib/cpus/aarch64/cortex_a72.S			\
65f91c3cb1SSiva Durga Prasad Paladugu				plat/common/plat_psci_common.c			\
66c73a90e5STejas Patel				plat/xilinx/common/ipi.c			\
6731ce893eSVenkatesh Yadav Abbarapu				plat/xilinx/common/plat_startup.c		\
686e2f0d10SWendy Liang				plat/xilinx/common/ipi_mailbox_service/ipi_mailbox_svc.c \
69c73a90e5STejas Patel				plat/xilinx/common/pm_service/pm_ipi.c		\
70f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/bl31_versal_setup.c		\
71f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/plat_psci.c			\
72f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/plat_versal.c		\
73f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/plat_topology.c		\
74f91c3cb1SSiva Durga Prasad Paladugu				plat/xilinx/versal/sip_svc_setup.c		\
75c73a90e5STejas Patel				plat/xilinx/versal/versal_gicv3.c		\
76c73a90e5STejas Patel				plat/xilinx/versal/versal_ipi.c			\
77c73a90e5STejas Patel				plat/xilinx/versal/pm_service/pm_svc_main.c	\
7895794c73STejas Patel				plat/xilinx/versal/pm_service/pm_api_sys.c	\
79c73a90e5STejas Patel				plat/xilinx/versal/pm_service/pm_client.c
80