xref: /rk3399_ARM-atf/plat/mediatek/mt8195/platform.mk (revision 52035dee1ae7b0f2f0d5f16c734ca7a5cea127b7)
1#
2# Copyright (c) 2021-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}/common/drivers/gic600/             \
12                 -I${MTK_PLAT}/common/drivers/gpio/               \
13                 -I${MTK_PLAT}/common/drivers/rtc/                \
14                 -I${MTK_PLAT}/common/drivers/timer/              \
15                 -I${MTK_PLAT}/common/drivers/uart/               \
16                 -I${MTK_PLAT}/common/lpm/                        \
17                 -I${MTK_PLAT}/include/                           \
18                 -I${MTK_PLAT_SOC}/drivers/apusys/                \
19                 -I${MTK_PLAT_SOC}/drivers/dcm                    \
20                 -I${MTK_PLAT_SOC}/drivers/dfd                    \
21                 -I${MTK_PLAT_SOC}/drivers/dp/                    \
22                 -I${MTK_PLAT_SOC}/drivers/emi_mpu/               \
23                 -I${MTK_PLAT_SOC}/drivers/gpio/                  \
24                 -I${MTK_PLAT_SOC}/drivers/mcdi/                  \
25                 -I${MTK_PLAT_SOC}/drivers/pmic/                  \
26                 -I${MTK_PLAT_SOC}/drivers/spmc/                  \
27                 -I${MTK_PLAT_SOC}/drivers/ptp3/                   \
28                 -I${MTK_PLAT_SOC}/include/
29
30GICV3_SUPPORT_GIC600        :=      1
31include drivers/arm/gic/v3/gicv3.mk
32include lib/xlat_tables_v2/xlat_tables.mk
33
34PLAT_BL_COMMON_SOURCES := ${GICV3_SOURCES}                              \
35                          ${XLAT_TABLES_LIB_SRCS}                       \
36                          plat/common/aarch64/crash_console_helpers.S   \
37                          plat/common/plat_psci_common.c
38
39
40BL31_SOURCES += common/desc_image_load.c                              \
41                drivers/delay_timer/delay_timer.c                     \
42                drivers/gpio/gpio.c                                   \
43                drivers/delay_timer/generic_delay_timer.c             \
44                drivers/ti/uart/aarch64/16550_console.S               \
45                lib/bl_aux_params/bl_aux_params.c                     \
46                lib/cpus/aarch64/cortex_a55.S                         \
47                lib/cpus/aarch64/cortex_a78.S                         \
48                plat/common/plat_gicv3.c                              \
49                ${MTK_PLAT}/common/drivers/gic600/mt_gic_v3.c         \
50                ${MTK_PLAT}/common/drivers/gpio/mtgpio_common.c       \
51                ${MTK_PLAT}/common/drivers/pmic_wrap/pmic_wrap_init_v2.c \
52                ${MTK_PLAT}/common/drivers/rtc/rtc_common.c           \
53                ${MTK_PLAT}/common/drivers/rtc/rtc_mt6359p.c          \
54                ${MTK_PLAT}/common/drivers/timer/mt_timer.c           \
55		${MTK_PLAT}/common/drivers/uart/uart.c                \
56		${MTK_PLAT}/common/lpm/mt_lp_rm.c                     \
57                ${MTK_PLAT}/common/mtk_cirq.c                         \
58                ${MTK_PLAT}/common/mtk_plat_common.c                  \
59                ${MTK_PLAT}/common/mtk_sip_svc.c                      \
60                ${MTK_PLAT}/common/params_setup.c                     \
61                ${MTK_PLAT_SOC}/aarch64/platform_common.c             \
62                ${MTK_PLAT_SOC}/aarch64/plat_helpers.S                \
63                ${MTK_PLAT_SOC}/bl31_plat_setup.c                     \
64                ${MTK_PLAT_SOC}/drivers/apusys/apupll.c               \
65                ${MTK_PLAT_SOC}/drivers/apusys/apupwr_clkctl.c        \
66		${MTK_PLAT_SOC}/drivers/apusys/mtk_apusys.c           \
67                ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm.c                 \
68                ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm_utils.c           \
69                ${MTK_PLAT_SOC}/drivers/dfd/plat_dfd.c                \
70                ${MTK_PLAT_SOC}/drivers/dp/mt_dp.c                    \
71                ${MTK_PLAT_SOC}/drivers/emi_mpu/emi_mpu.c             \
72                ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c                 \
73                ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm.c              \
74                ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm_cpc.c          \
75                ${MTK_PLAT_SOC}/drivers/mcdi/mt_mcdi.c                \
76		${MTK_PLAT_SOC}/drivers/mcdi/mt_lp_irqremain.c        \
77                ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c                 \
78                ${MTK_PLAT_SOC}/drivers/pmic/pmic.c                   \
79                ${MTK_PLAT_SOC}/drivers/ptp3/mtk_ptp3_main.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
85# Build SPM drivers
86include ${MTK_PLAT_SOC}/drivers/spm/build.mk
87
88# Configs for A78 and A55
89HW_ASSISTED_COHERENCY := 1
90USE_COHERENT_MEM := 0
91CTX_INCLUDE_AARCH32_REGS := 0
92ERRATA_A55_1530923 := 1
93
94ERRATA_A78_1688305 := 1
95ERRATA_A78_1941498 := 1
96ERRATA_A78_1951500 := 1
97ERRATA_A78_1821534 := 1
98ERRATA_A78_2132060 := 1
99ERRATA_A78_2242635 := 1
100
101# indicate the reset vector address can be programmed
102PROGRAMMABLE_RESET_ADDRESS := 1
103
104COLD_BOOT_SINGLE_CPU := 1
105
106MACH_MT8195 := 1
107$(eval $(call add_define,MACH_MT8195))
108
109include lib/coreboot/coreboot.mk
110