blob: 80dfa53cd1c83dcf2602dd25955e5254c1d6dd19 [file] [log] [blame]
Yidi Lin174a1cf2021-03-19 22:13:11 +08001#
Leon Chen2f3f5932022-05-29 22:25:44 +08002# Copyright (c) 2021-2022, MediaTek Inc. All rights reserved.
Yidi Lin174a1cf2021-03-19 22:13:11 +08003#
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/ \
Bo-Chen Chencd7890d2022-09-29 10:41:26 +080011 -I${MTK_PLAT}/common/lpm/ \
Rex-BC Chencc768962022-07-08 14:48:56 +080012 -I${MTK_PLAT}/drivers/cirq/ \
Rex-BC Chend150b622022-07-11 18:48:43 +080013 -I${MTK_PLAT}/drivers/dp/ \
Bo-Chen Chen33747522022-09-05 11:18:04 +080014 -I${MTK_PLAT}/drivers/gic600/ \
15 -I${MTK_PLAT}/drivers/gpio/ \
Bo-Chen Chen80fa7582022-09-01 16:32:46 +080016 -I${MTK_PLAT}/drivers/pmic/ \
Bo-Chen Chenca93b012022-09-01 15:16:23 +080017 -I${MTK_PLAT}/drivers/pmic_wrap/ \
Bo-Chen Chen33747522022-09-05 11:18:04 +080018 -I${MTK_PLAT}/drivers/rtc/ \
19 -I${MTK_PLAT}/drivers/timer/ \
20 -I${MTK_PLAT}/drivers/uart/ \
Leon Chen2f3f5932022-05-29 22:25:44 +080021 -I${MTK_PLAT}/include/ \
Flora Fu88906b42021-11-01 16:43:47 +080022 -I${MTK_PLAT_SOC}/drivers/apusys/ \
Garmin Chang49d3bd82021-07-02 15:54:57 +080023 -I${MTK_PLAT_SOC}/drivers/dcm \
Rex-BC Chen3b994a72021-08-10 11:10:58 +080024 -I${MTK_PLAT_SOC}/drivers/dfd \
Penny Jan75edd342021-08-19 15:34:43 +080025 -I${MTK_PLAT_SOC}/drivers/emi_mpu/ \
mtk20895aebd4dc2021-03-31 14:53:43 +080026 -I${MTK_PLAT_SOC}/drivers/gpio/ \
James Liaoacc85542020-06-15 16:41:03 +080027 -I${MTK_PLAT_SOC}/drivers/mcdi/ \
Yidi Lin09098192021-04-08 16:37:15 +080028 -I${MTK_PLAT_SOC}/drivers/pmic/ \
James Liao0d82eff2020-06-16 13:28:28 +080029 -I${MTK_PLAT_SOC}/drivers/spmc/ \
Bo-Chen Chen33747522022-09-05 11:18:04 +080030 -I${MTK_PLAT_SOC}/drivers/ptp3/ \
Yidi Lin174a1cf2021-03-19 22:13:11 +080031 -I${MTK_PLAT_SOC}/include/
32
christine.zhuc63f1452021-03-24 21:44:52 +080033GICV3_SUPPORT_GIC600 := 1
Yidi Lin174a1cf2021-03-19 22:13:11 +080034include drivers/arm/gic/v3/gicv3.mk
35include lib/xlat_tables_v2/xlat_tables.mk
36
37PLAT_BL_COMMON_SOURCES := ${GICV3_SOURCES} \
38 ${XLAT_TABLES_LIB_SRCS} \
39 plat/common/aarch64/crash_console_helpers.S \
40 plat/common/plat_psci_common.c
41
42
43BL31_SOURCES += common/desc_image_load.c \
Yidi Lin65f0dd12021-03-26 18:33:43 +080044 drivers/delay_timer/delay_timer.c \
mtk20895aebd4dc2021-03-31 14:53:43 +080045 drivers/gpio/gpio.c \
Yidi Lin65f0dd12021-03-26 18:33:43 +080046 drivers/delay_timer/generic_delay_timer.c \
Yidi Lin174a1cf2021-03-19 22:13:11 +080047 drivers/ti/uart/aarch64/16550_console.S \
48 lib/bl_aux_params/bl_aux_params.c \
49 lib/cpus/aarch64/cortex_a55.S \
50 lib/cpus/aarch64/cortex_a78.S \
51 plat/common/plat_gicv3.c \
Yidi Lin174a1cf2021-03-19 22:13:11 +080052 ${MTK_PLAT}/common/mtk_plat_common.c \
Yidi Lin938fd422021-03-29 16:50:30 +080053 ${MTK_PLAT}/common/mtk_sip_svc.c \
Yidi Lin174a1cf2021-03-19 22:13:11 +080054 ${MTK_PLAT}/common/params_setup.c \
Bo-Chen Chencd7890d2022-09-29 10:41:26 +080055 ${MTK_PLAT}/common/lpm/mt_lp_rm.c \
Rex-BC Chencc768962022-07-08 14:48:56 +080056 ${MTK_PLAT}/drivers/cirq/mt_cirq.c \
Rex-BC Chend150b622022-07-11 18:48:43 +080057 ${MTK_PLAT}/drivers/dp/mt_dp.c \
Bo-Chen Chen33747522022-09-05 11:18:04 +080058 ${MTK_PLAT}/drivers/gic600/mt_gic_v3.c \
59 ${MTK_PLAT}/drivers/gpio/mtgpio_common.c \
Bo-Chen Chen80fa7582022-09-01 16:32:46 +080060 ${MTK_PLAT}/drivers/pmic/pmic.c \
Bo-Chen Chen33747522022-09-05 11:18:04 +080061 ${MTK_PLAT}/drivers/pmic_wrap/pmic_wrap_init_v2.c \
62 ${MTK_PLAT}/drivers/rtc/rtc_common.c \
63 ${MTK_PLAT}/drivers/rtc/rtc_mt6359p.c \
64 ${MTK_PLAT}/drivers/timer/mt_timer.c \
65 ${MTK_PLAT}/drivers/uart/uart.c \
Yidi Lin174a1cf2021-03-19 22:13:11 +080066 ${MTK_PLAT_SOC}/aarch64/platform_common.c \
67 ${MTK_PLAT_SOC}/aarch64/plat_helpers.S \
68 ${MTK_PLAT_SOC}/bl31_plat_setup.c \
Flora Fu296b5902021-11-08 16:37:39 +080069 ${MTK_PLAT_SOC}/drivers/apusys/apupll.c \
70 ${MTK_PLAT_SOC}/drivers/apusys/apupwr_clkctl.c \
Bo-Chen Chen33747522022-09-05 11:18:04 +080071 ${MTK_PLAT_SOC}/drivers/apusys/mtk_apusys.c \
Garmin Chang49d3bd82021-07-02 15:54:57 +080072 ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm.c \
73 ${MTK_PLAT_SOC}/drivers/dcm/mtk_dcm_utils.c \
Rex-BC Chen3b994a72021-08-10 11:10:58 +080074 ${MTK_PLAT_SOC}/drivers/dfd/plat_dfd.c \
Penny Jan75edd342021-08-19 15:34:43 +080075 ${MTK_PLAT_SOC}/drivers/emi_mpu/emi_mpu.c \
mtk20895aebd4dc2021-03-31 14:53:43 +080076 ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c \
James Liaoacc85542020-06-15 16:41:03 +080077 ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm.c \
78 ${MTK_PLAT_SOC}/drivers/mcdi/mt_cpu_pm_cpc.c \
79 ${MTK_PLAT_SOC}/drivers/mcdi/mt_mcdi.c \
Bo-Chen Chen33747522022-09-05 11:18:04 +080080 ${MTK_PLAT_SOC}/drivers/mcdi/mt_lp_irqremain.c \
mtk20895aebd4dc2021-03-31 14:53:43 +080081 ${MTK_PLAT_SOC}/drivers/gpio/mtgpio.c \
Elly Chiang04818962021-06-20 16:48:08 +080082 ${MTK_PLAT_SOC}/drivers/ptp3/mtk_ptp3_main.c \
James Liao0d82eff2020-06-16 13:28:28 +080083 ${MTK_PLAT_SOC}/drivers/spmc/mtspmc.c \
Yidi Lin174a1cf2021-03-19 22:13:11 +080084 ${MTK_PLAT_SOC}/plat_pm.c \
Yidi Lin938fd422021-03-29 16:50:30 +080085 ${MTK_PLAT_SOC}/plat_sip_calls.c \
Yidi Lin174a1cf2021-03-19 22:13:11 +080086 ${MTK_PLAT_SOC}/plat_topology.c
87
Edward-JW Yang859e3462021-06-28 11:29:51 +080088# Build SPM drivers
89include ${MTK_PLAT_SOC}/drivers/spm/build.mk
90
Yidi Lin174a1cf2021-03-19 22:13:11 +080091# Configs for A78 and A55
92HW_ASSISTED_COHERENCY := 1
93USE_COHERENT_MEM := 0
94CTX_INCLUDE_AARCH32_REGS := 0
95ERRATA_A55_1530923 := 1
96
Rex-BC Chenc21a7362022-01-05 14:51:57 +080097ERRATA_A78_1688305 := 1
98ERRATA_A78_1941498 := 1
99ERRATA_A78_1951500 := 1
100ERRATA_A78_1821534 := 1
101ERRATA_A78_2132060 := 1
102ERRATA_A78_2242635 := 1
103
Yidi Lin174a1cf2021-03-19 22:13:11 +0800104# indicate the reset vector address can be programmed
105PROGRAMMABLE_RESET_ADDRESS := 1
106
107COLD_BOOT_SINGLE_CPU := 1
108
109MACH_MT8195 := 1
110$(eval $(call add_define,MACH_MT8195))
111
112include lib/coreboot/coreboot.mk