1#
2# Copyright (c) 2019-2022, MediaTek Inc. All rights reserved.
3#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6
7MTK_PLAT      := plat/mediatek
8MTK_PLAT_SOC  := ${MTK_PLAT}/${PLAT}
9
10PLAT_INCLUDES := -I${MTK_PLAT}/common/                            \
11                 -I${MTK_PLAT}/drivers/uart/                      \
12                 -I${MTK_PLAT}/include/                           \
13                 -I${MTK_PLAT_SOC}/drivers/                       \
14                 -I${MTK_PLAT_SOC}/drivers/emi_mpu/               \
15                 -I${MTK_PLAT_SOC}/drivers/devapc/                \
16                 -I${MTK_PLAT_SOC}/drivers/mcdi/                  \
17                 -I${MTK_PLAT_SOC}/drivers/spmc/                  \
18                 -I${MTK_PLAT_SOC}/drivers/gpio/                  \
19                 -I${MTK_PLAT_SOC}/drivers/timer/                 \
20                 -I${MTK_PLAT_SOC}/drivers/pmic/                  \
21                 -I${MTK_PLAT_SOC}/drivers/spm/                   \
22                 -I${MTK_PLAT_SOC}/drivers/sspm/                  \
23                 -I${MTK_PLAT_SOC}/drivers/rtc/                   \
24                 -I${MTK_PLAT_SOC}/include/
25
26PLAT_BL_COMMON_SOURCES := lib/xlat_tables/aarch64/xlat_tables.c       \
27                          lib/xlat_tables/xlat_tables_common.c        \
28                          plat/common/plat_psci_common.c              \
29                          plat/common/aarch64/crash_console_helpers.S
30
31# Include GICv3 driver files
32include drivers/arm/gic/v3/gicv3.mk
33
34BL31_SOURCES    += common/desc_image_load.c                              \
35                   drivers/arm/cci/cci.c                                 \
36                   ${GICV3_SOURCES}					 \
37                   drivers/delay_timer/delay_timer.c                     \
38                   drivers/delay_timer/generic_delay_timer.c             \
39                   drivers/gpio/gpio.c                                   \
40                   drivers/ti/uart/aarch64/16550_console.S               \
41                   lib/bl_aux_params/bl_aux_params.c                     \
42                   lib/cpus/aarch64/aem_generic.S                        \
43                   lib/cpus/aarch64/cortex_a53.S                         \
44                   lib/cpus/aarch64/cortex_a73.S                         \
45                   plat/common/plat_gicv3.c                              \
46                   ${MTK_PLAT}/common/mtk_plat_common.c                  \
47                   ${MTK_PLAT}/common/params_setup.c                     \
48                   ${MTK_PLAT}/drivers/pmic_wrap/pmic_wrap_init.c        \
49                   ${MTK_PLAT}/drivers/rtc/rtc_common.c                  \
50                   ${MTK_PLAT}/drivers/uart/uart.c                       \
51                   ${MTK_PLAT_SOC}/aarch64/plat_helpers.S                \
52                   ${MTK_PLAT_SOC}/aarch64/platform_common.c             \
53                   ${MTK_PLAT_SOC}/drivers/devapc/devapc.c               \
54                   ${MTK_PLAT_SOC}/drivers/mcsi/mcsi.c                   \
55                   ${MTK_PLAT_SOC}/drivers/pmic/pmic.c                   \
56                   ${MTK_PLAT_SOC}/drivers/rtc/rtc.c                     \
57                   ${MTK_PLAT_SOC}/drivers/mcdi/mtk_mcdi.c               \
58                   ${MTK_PLAT_SOC}/drivers/spmc/mtspmc.c                 \
59                   ${MTK_PLAT_SOC}/drivers/spm/spm.c                     \
60                   ${MTK_PLAT_SOC}/drivers/spm/spm_pmic_wrap.c           \
61                   ${MTK_PLAT_SOC}/drivers/spm/spm_suspend.c             \
62                   ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c                 \
63                   ${MTK_PLAT_SOC}/drivers/timer/mt_timer.c              \
64                   ${MTK_PLAT_SOC}/drivers/emi_mpu/emi_mpu.c             \
65                   ${MTK_PLAT_SOC}/plat_pm.c                             \
66                   ${MTK_PLAT_SOC}/plat_topology.c                       \
67                   ${MTK_PLAT_SOC}/plat_mt_gic.c                         \
68                   ${MTK_PLAT_SOC}/plat_dcm.c                            \
69                   ${MTK_PLAT_SOC}/bl31_plat_setup.c                     \
70                   ${MTK_PLAT_SOC}/plat_debug.c                          \
71                   ${MTK_PLAT_SOC}/scu.c                                 \
72                   ${MTK_PLAT_SOC}/drivers/sspm/sspm.c
73
74# Enable workarounds for selected Cortex-A53 erratas.
75ERRATA_A53_826319 := 0
76ERRATA_A53_836870 := 1
77ERRATA_A53_855873 := 1
78
79# indicate the reset vector address can be programmed
80PROGRAMMABLE_RESET_ADDRESS := 1
81
82COLD_BOOT_SINGLE_CPU := 1
83
84MULTI_CONSOLE_API := 1
85
86MACH_MT8183 := 1
87$(eval $(call add_define,MACH_MT8183))
88
89include lib/coreboot/coreboot.mk
90
91