• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1#
2# Copyright (c) 2021-2024, 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
10# True Random Number Generator firmware Interface
11TRNG_SUPPORT := 1
12
13PLAT_INCLUDES := -I${MTK_PLAT}/common/                            \
14                 -I${MTK_PLAT}/drivers/cirq/                      \
15                 -I${MTK_PLAT}/drivers/gic600/                    \
16                 -I${MTK_PLAT}/drivers/gpio/                      \
17                 -I${MTK_PLAT}/drivers/msdc/                      \
18                 -I${MTK_PLAT}/drivers/msdc/${PLAT}               \
19                 -I${MTK_PLAT}/drivers/pmic_wrap/                 \
20                 -I${MTK_PLAT}/drivers/timer/                     \
21                 -I${MTK_PLAT}/drivers/uart/                      \
22                 -I${MTK_PLAT}/include/                           \
23                 -I${MTK_PLAT}/include/lpm                        \
24                 -I${MTK_PLAT_SOC}/drivers/spm/                   \
25                 -I${MTK_PLAT_SOC}/drivers/dcm/                   \
26                 -I${MTK_PLAT_SOC}/drivers/dfd/                   \
27                 -I${MTK_PLAT_SOC}/drivers/emi_mpu/               \
28                 -I${MTK_PLAT_SOC}/drivers/gpio/                  \
29                 -I${MTK_PLAT_SOC}/drivers/mcdi/                  \
30                 -I${MTK_PLAT_SOC}/drivers/pmic/                  \
31                 -I${MTK_PLAT_SOC}/drivers/rtc/                   \
32                 -I${MTK_PLAT_SOC}/drivers/spmc/                  \
33                 -I${MTK_PLAT_SOC}/include/
34
35GICV3_SUPPORT_GIC600        :=      1
36include drivers/arm/gic/v3/gicv3.mk
37include lib/xlat_tables_v2/xlat_tables.mk
38
39PLAT_BL_COMMON_SOURCES := ${GICV3_SOURCES}                              \
40                          ${XLAT_TABLES_LIB_SRCS}                       \
41                          plat/common/aarch64/crash_console_helpers.S   \
42                          plat/common/plat_psci_common.c
43
44
45BL31_SOURCES += common/desc_image_load.c                              \
46                drivers/delay_timer/delay_timer.c                     \
47                drivers/gpio/gpio.c                                   \
48                drivers/delay_timer/generic_delay_timer.c             \
49                drivers/ti/uart/aarch64/16550_console.S               \
50                lib/bl_aux_params/bl_aux_params.c                     \
51                lib/cpus/aarch64/cortex_a55.S                         \
52                lib/cpus/aarch64/cortex_a76.S                         \
53                plat/common/plat_gicv3.c                              \
54                ${MTK_PLAT}/common/mtk_plat_common.c                  \
55                ${MTK_PLAT}/common/mtk_sip_svc.c                      \
56                ${MTK_PLAT}/common/params_setup.c                     \
57                ${MTK_PLAT}/common/lpm/mt_lp_rm.c                     \
58                ${MTK_PLAT}/drivers/cirq/mt_cirq.c                    \
59                ${MTK_PLAT}/drivers/gic600/mt_gic_v3.c                \
60                ${MTK_PLAT}/drivers/gpio/mtgpio_common.c              \
61                ${MTK_PLAT}/drivers/msdc/mt_msdc.c                    \
62                ${MTK_PLAT}/drivers/pmic_wrap/pmic_wrap_init.c        \
63                ${MTK_PLAT}/drivers/rtc/rtc_common.c                  \
64                ${MTK_PLAT}/drivers/timer/mt_timer.c                  \
65                ${MTK_PLAT}/drivers/uart/uart.c                       \
66                ${MTK_PLAT_SOC}/aarch64/platform_common.c             \
67                ${MTK_PLAT_SOC}/aarch64/plat_helpers.S                \
68                ${MTK_PLAT_SOC}/bl31_plat_setup.c                     \
69                ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm.c                 \
70                ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm_utils.c           \
71                ${MTK_PLAT_SOC}/drivers/dfd/plat_dfd.c                \
72                ${MTK_PLAT_SOC}/drivers/emi_mpu/emi_mpu.c             \
73                ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c                 \
74                ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm.c              \
75                ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm_cpc.c          \
76                ${MTK_PLAT_SOC}/drivers/mcdi/mt_mcdi.c                \
77                ${MTK_PLAT_SOC}/drivers/mcdi/mt_lp_irqremain.c        \
78                ${MTK_PLAT_SOC}/drivers/pmic/pmic.c                   \
79                ${MTK_PLAT_SOC}/drivers/rtc/rtc.c                     \
80                ${MTK_PLAT_SOC}/drivers/spmc/mtspmc.c                 \
81                ${MTK_PLAT_SOC}/plat_pm.c                             \
82                ${MTK_PLAT_SOC}/plat_sip_calls.c                      \
83                ${MTK_PLAT_SOC}/plat_topology.c
84
85ifeq (${TRNG_SUPPORT},1)
86BL31_SOURCES += ${MTK_PLAT}/drivers/rng/rng.c                         \
87                ${MTK_PLAT}/drivers/rng/${PLAT}/rng_plat.c
88endif
89
90# Build SPM drivers
91include ${MTK_PLAT_SOC}/drivers/spm/build.mk
92
93# Configs for A76 and A55
94HW_ASSISTED_COHERENCY := 1
95USE_COHERENT_MEM := 0
96CTX_INCLUDE_AARCH32_REGS := 0
97ERRATA_A55_1530923 := 1
98ERRATA_A55_1221012 := 1
99
100ERRATA_A76_1257314 := 1
101ERRATA_A76_1262606 := 1
102ERRATA_A76_1262888 := 1
103ERRATA_A76_1275112 := 1
104ERRATA_A76_1286807 := 1
105ERRATA_A76_1791580 := 1
106ERRATA_A76_1165522 := 1
107ERRATA_A76_1868343 := 1
108ERRATA_A76_1946160 := 1
109
110# indicate the reset vector address can be programmed
111PROGRAMMABLE_RESET_ADDRESS := 1
112
113COLD_BOOT_SINGLE_CPU := 1
114
115MACH_MT8186 := 1
116$(eval $(call add_define,MACH_MT8186))
117
118include lib/coreboot/coreboot.mk
119