blob: fca06220bc58964b40cbed22ba39d0296af16d66 [file] [log] [blame]
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +02001#
2# Copyright (c) 2017, ARM Limited and Contributors. All rights reserved.
3#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6
Victor Chongf3367742017-10-28 01:59:41 +09007# On Poplar, the TSP can execute from TZC secure area in DRAM.
8POPLAR_TSP_RAM_LOCATION := dram
9ifeq (${POPLAR_TSP_RAM_LOCATION}, dram)
10 POPLAR_TSP_RAM_LOCATION_ID = POPLAR_DRAM_ID
Victor Chongce2547f2018-01-29 18:08:34 +090011else ifeq (${POPLAR_TSP_RAM_LOCATION}, sram)
Victor Chongf3367742017-10-28 01:59:41 +090012 POPLAR_TSP_RAM_LOCATION_ID := POPLAR_SRAM_ID
13else
14 $(error "Currently unsupported POPLAR_TSP_RAM_LOCATION value")
15endif
16$(eval $(call add_define,POPLAR_TSP_RAM_LOCATION_ID))
17
Victor Chong8ad132b2018-01-29 18:11:02 +090018POPLAR_DRAM_SIZE ?= two_gig
19ifeq (${POPLAR_DRAM_SIZE}, two_gig)
20 POPLAR_DRAM_SIZE_ID = POPLAR_DRAM_SIZE_2G
21else ifeq (${POPLAR_DRAM_SIZE}, one_gig)
22 POPLAR_DRAM_SIZE_ID = POPLAR_DRAM_SIZE_1G
23else
24 $(error "Currently unsupported POPLAR_DRAM_SIZE value")
25endif
26$(eval $(call add_define,POPLAR_DRAM_SIZE_ID))
27
Victor Chong15b54e72018-01-16 00:29:47 +090028POPLAR_RECOVERY := 0
29$(eval $(call add_define,POPLAR_RECOVERY))
30
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020031NEED_BL33 := yes
32
33COLD_BOOT_SINGLE_CPU := 1
34PROGRAMMABLE_RESET_ADDRESS := 1
35CTX_INCLUDE_FPREGS := 1
36ENABLE_PLAT_COMPAT := 0
37ERRATA_A53_855873 := 1
38ERRATA_A53_835769 := 1
39ERRATA_A53_843419 := 1
David Cunado3872fc22017-10-31 23:19:21 +000040ENABLE_SVE_FOR_NS := 0
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020041
Dimitris Papastamos383c8082018-01-24 16:41:14 +000042WORKAROUND_CVE_2017_5715 := 0
43
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020044ARM_GIC_ARCH := 2
45$(eval $(call add_define,ARM_GIC_ARCH))
46
47PLAT_PL061_MAX_GPIOS := 104
48$(eval $(call add_define,PLAT_PL061_MAX_GPIOS))
49
50PLAT_INCLUDES := -Iplat/hisilicon/poplar/include \
51 -Iinclude/plat/arm/common/ \
52 -Iplat/hisilicon/poplar \
53 -Iinclude/common/tbbr \
Victor Chong59149bb2018-01-03 01:53:08 +090054 -Iinclude/drivers/synopsys \
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020055 -Iinclude/drivers/io
56
57PLAT_BL_COMMON_SOURCES := \
58 lib/aarch64/xlat_tables.c \
59 drivers/delay_timer/generic_delay_timer.c \
60 drivers/arm/gic/common/gic_common.c \
61 drivers/arm/gic/v2/gicv2_helpers.c \
62 drivers/delay_timer/delay_timer.c \
63 drivers/arm/pl011/pl011_console.S \
64 drivers/arm/gic/v2/gicv2_main.c \
65 plat/arm/common/aarch64/arm_helpers.S \
66 plat/arm/common/arm_gicv2.c \
67 plat/common/plat_gicv2.c \
68 plat/hisilicon/poplar/aarch64/platform_common.c
69
70BL1_SOURCES += \
71 lib/cpus/aarch64/cortex_a53.S \
72 drivers/arm/pl061/pl061_gpio.c \
Victor Chong59149bb2018-01-03 01:53:08 +090073 drivers/emmc/emmc.c \
74 drivers/synopsys/emmc/dw_mmc.c \
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020075 drivers/io/io_storage.c \
76 drivers/io/io_block.c \
77 drivers/gpio/gpio.c \
78 drivers/io/io_fip.c \
79 drivers/io/io_memmap.c \
80 plat/hisilicon/poplar/bl1_plat_setup.c \
Victor Chongce2547f2018-01-29 18:08:34 +090081 plat/hisilicon/poplar/plat_storage.c
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020082
83
84BL2_SOURCES += \
85 drivers/arm/pl061/pl061_gpio.c \
Victor Chong59149bb2018-01-03 01:53:08 +090086 drivers/emmc/emmc.c \
87 drivers/synopsys/emmc/dw_mmc.c \
Jorge Ramirez-Ortize35d0ed2017-06-28 10:11:31 +020088 drivers/io/io_storage.c \
89 drivers/io/io_block.c \
90 drivers/io/io_fip.c \
91 drivers/gpio/gpio.c \
92 drivers/io/io_memmap.c \
93 plat/hisilicon/poplar/bl2_plat_setup.c \
94 plat/hisilicon/poplar/plat_storage.c
95
96
97BL31_SOURCES += \
98 lib/cpus/aarch64/aem_generic.S \
99 lib/cpus/aarch64/cortex_a53.S \
100 plat/common/aarch64/plat_psci_common.c \
101 plat/hisilicon/poplar/bl31_plat_setup.c \
102 plat/hisilicon/poplar/plat_topology.c \
103 plat/hisilicon/poplar/plat_pm.c