xref: /arm-trusted-firmware/plat/mediatek/mt8186/platform.mk (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu#
2*91f16700Schasinglulu# Copyright (c) 2021-2023, MediaTek Inc. All rights reserved.
3*91f16700Schasinglulu#
4*91f16700Schasinglulu# SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu#
6*91f16700Schasinglulu
7*91f16700SchasingluluMTK_PLAT     := plat/mediatek
8*91f16700SchasingluluMTK_PLAT_SOC := ${MTK_PLAT}/${PLAT}
9*91f16700Schasinglulu
10*91f16700SchasingluluPLAT_INCLUDES := -I${MTK_PLAT}/common/                            \
11*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/cirq/                      \
12*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/gic600/                    \
13*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/gpio/                      \
14*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/msdc/                      \
15*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/msdc/${PLAT}               \
16*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/pmic_wrap/                 \
17*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/timer/                     \
18*91f16700Schasinglulu                 -I${MTK_PLAT}/drivers/uart/                      \
19*91f16700Schasinglulu                 -I${MTK_PLAT}/include/                           \
20*91f16700Schasinglulu                 -I${MTK_PLAT}/include/lpm                        \
21*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/spm/                   \
22*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/dcm/                   \
23*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/dfd/                   \
24*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/emi_mpu/               \
25*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/gpio/                  \
26*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/mcdi/                  \
27*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/pmic/                  \
28*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/rtc/                   \
29*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/drivers/spmc/                  \
30*91f16700Schasinglulu                 -I${MTK_PLAT_SOC}/include/
31*91f16700Schasinglulu
32*91f16700SchasingluluGICV3_SUPPORT_GIC600        :=      1
33*91f16700Schasingluluinclude drivers/arm/gic/v3/gicv3.mk
34*91f16700Schasingluluinclude lib/xlat_tables_v2/xlat_tables.mk
35*91f16700Schasinglulu
36*91f16700SchasingluluPLAT_BL_COMMON_SOURCES := ${GICV3_SOURCES}                              \
37*91f16700Schasinglulu                          ${XLAT_TABLES_LIB_SRCS}                       \
38*91f16700Schasinglulu                          plat/common/aarch64/crash_console_helpers.S   \
39*91f16700Schasinglulu                          plat/common/plat_psci_common.c
40*91f16700Schasinglulu
41*91f16700Schasinglulu
42*91f16700SchasingluluBL31_SOURCES += common/desc_image_load.c                              \
43*91f16700Schasinglulu                drivers/delay_timer/delay_timer.c                     \
44*91f16700Schasinglulu                drivers/gpio/gpio.c                                   \
45*91f16700Schasinglulu                drivers/delay_timer/generic_delay_timer.c             \
46*91f16700Schasinglulu                drivers/ti/uart/aarch64/16550_console.S               \
47*91f16700Schasinglulu                lib/bl_aux_params/bl_aux_params.c                     \
48*91f16700Schasinglulu                lib/cpus/aarch64/cortex_a55.S                         \
49*91f16700Schasinglulu                lib/cpus/aarch64/cortex_a76.S                         \
50*91f16700Schasinglulu                plat/common/plat_gicv3.c                              \
51*91f16700Schasinglulu                ${MTK_PLAT}/common/mtk_plat_common.c                  \
52*91f16700Schasinglulu                ${MTK_PLAT}/common/mtk_sip_svc.c                      \
53*91f16700Schasinglulu                ${MTK_PLAT}/common/params_setup.c                     \
54*91f16700Schasinglulu                ${MTK_PLAT}/common/lpm/mt_lp_rm.c                     \
55*91f16700Schasinglulu                ${MTK_PLAT}/drivers/cirq/mt_cirq.c                    \
56*91f16700Schasinglulu                ${MTK_PLAT}/drivers/gic600/mt_gic_v3.c                \
57*91f16700Schasinglulu                ${MTK_PLAT}/drivers/gpio/mtgpio_common.c              \
58*91f16700Schasinglulu                ${MTK_PLAT}/drivers/msdc/mt_msdc.c                    \
59*91f16700Schasinglulu                ${MTK_PLAT}/drivers/pmic_wrap/pmic_wrap_init.c        \
60*91f16700Schasinglulu                ${MTK_PLAT}/drivers/rtc/rtc_common.c                  \
61*91f16700Schasinglulu                ${MTK_PLAT}/drivers/timer/mt_timer.c                  \
62*91f16700Schasinglulu                ${MTK_PLAT}/drivers/uart/uart.c                       \
63*91f16700Schasinglulu                ${MTK_PLAT_SOC}/aarch64/platform_common.c             \
64*91f16700Schasinglulu                ${MTK_PLAT_SOC}/aarch64/plat_helpers.S                \
65*91f16700Schasinglulu                ${MTK_PLAT_SOC}/bl31_plat_setup.c                     \
66*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm.c                 \
67*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm_utils.c           \
68*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/dfd/plat_dfd.c                \
69*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/emi_mpu/emi_mpu.c             \
70*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c                 \
71*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm.c              \
72*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm_cpc.c          \
73*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/mcdi/mt_mcdi.c                \
74*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/mcdi/mt_lp_irqremain.c        \
75*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/pmic/pmic.c                   \
76*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/rtc/rtc.c                     \
77*91f16700Schasinglulu                ${MTK_PLAT_SOC}/drivers/spmc/mtspmc.c                 \
78*91f16700Schasinglulu                ${MTK_PLAT_SOC}/plat_pm.c                             \
79*91f16700Schasinglulu                ${MTK_PLAT_SOC}/plat_sip_calls.c                      \
80*91f16700Schasinglulu                ${MTK_PLAT_SOC}/plat_topology.c
81*91f16700Schasinglulu
82*91f16700Schasinglulu# Build SPM drivers
83*91f16700Schasingluluinclude ${MTK_PLAT_SOC}/drivers/spm/build.mk
84*91f16700Schasinglulu
85*91f16700Schasinglulu# Configs for A76 and A55
86*91f16700SchasingluluHW_ASSISTED_COHERENCY := 1
87*91f16700SchasingluluUSE_COHERENT_MEM := 0
88*91f16700SchasingluluCTX_INCLUDE_AARCH32_REGS := 0
89*91f16700SchasingluluERRATA_A55_1530923 := 1
90*91f16700SchasingluluERRATA_A55_1221012 := 1
91*91f16700Schasinglulu
92*91f16700SchasingluluERRATA_A76_1257314 := 1
93*91f16700SchasingluluERRATA_A76_1262606 := 1
94*91f16700SchasingluluERRATA_A76_1262888 := 1
95*91f16700SchasingluluERRATA_A76_1275112 := 1
96*91f16700SchasingluluERRATA_A76_1286807 := 1
97*91f16700SchasingluluERRATA_A76_1791580 := 1
98*91f16700SchasingluluERRATA_A76_1165522 := 1
99*91f16700SchasingluluERRATA_A76_1868343 := 1
100*91f16700SchasingluluERRATA_A76_1946160 := 1
101*91f16700Schasinglulu
102*91f16700Schasinglulu# indicate the reset vector address can be programmed
103*91f16700SchasingluluPROGRAMMABLE_RESET_ADDRESS := 1
104*91f16700Schasinglulu
105*91f16700SchasingluluCOLD_BOOT_SINGLE_CPU := 1
106*91f16700Schasinglulu
107*91f16700SchasingluluMACH_MT8186 := 1
108*91f16700Schasinglulu$(eval $(call add_define,MACH_MT8186))
109*91f16700Schasinglulu
110*91f16700Schasingluluinclude lib/coreboot/coreboot.mk
111