css_common.mk 3.04 KB
Newer Older
1
#
2
# Copyright (c) 2015-2018, ARM Limited and Contributors. All rights reserved.
3
#
dp-arm's avatar
dp-arm committed
4
# SPDX-License-Identifier: BSD-3-Clause
5
6
#

7
8
9
10

# By default, SCP images are needed by CSS platforms.
CSS_LOAD_SCP_IMAGES	?=	1

Soby Mathew's avatar
Soby Mathew committed
11
# By default, SCMI driver is disabled for CSS platforms
Soby Mathew's avatar
Soby Mathew committed
12
CSS_USE_SCMI_SDS_DRIVER	?=	0
Soby Mathew's avatar
Soby Mathew committed
13

14
15
16
17
PLAT_INCLUDES		+=	-Iinclude/plat/arm/css/common			\
				-Iinclude/plat/arm/css/common/aarch64


18
PLAT_BL_COMMON_SOURCES	+=	plat/arm/css/common/${ARCH}/css_helpers.S
19

20
BL1_SOURCES		+=	plat/arm/css/common/css_bl1_setup.c
21

Soby Mathew's avatar
Soby Mathew committed
22
BL2_SOURCES		+=	plat/arm/css/common/css_bl2_setup.c
23

Soby Mathew's avatar
Soby Mathew committed
24
BL2U_SOURCES		+=	plat/arm/css/common/css_bl2u_setup.c
25
26

BL31_SOURCES		+=	plat/arm/css/common/css_pm.c			\
Soby Mathew's avatar
Soby Mathew committed
27
28
				plat/arm/css/common/css_topology.c

Soby Mathew's avatar
Soby Mathew committed
29
ifeq (${CSS_USE_SCMI_SDS_DRIVER},0)
Soby Mathew's avatar
Soby Mathew committed
30
BL31_SOURCES		+=	plat/arm/css/drivers/scp/css_pm_scpi.c		\
31
				plat/arm/css/drivers/mhu/css_mhu.c		\
32
				plat/arm/css/drivers/scpi/css_scpi.c
Soby Mathew's avatar
Soby Mathew committed
33
34
else
BL31_SOURCES		+=	plat/arm/css/drivers/scp/css_pm_scmi.c		\
35
				plat/arm/css/drivers/scmi/scmi_ap_core_proto.c	\
Soby Mathew's avatar
Soby Mathew committed
36
37
				plat/arm/css/drivers/scmi/scmi_common.c		\
				plat/arm/css/drivers/scmi/scmi_pwr_dmn_proto.c	\
38
39
				plat/arm/css/drivers/scmi/scmi_sys_pwr_proto.c	\
				plat/arm/css/drivers/mhu/css_mhu_doorbell.c
Soby Mathew's avatar
Soby Mathew committed
40
endif
41
42

ifneq (${RESET_TO_BL31},0)
43
  $(error "Using BL31 as the reset vector is not supported on CSS platforms. \
44
45
46
  Please set RESET_TO_BL31 to 0.")
endif

47
48
49
50
51
# Process CSS_LOAD_SCP_IMAGES flag
$(eval $(call assert_boolean,CSS_LOAD_SCP_IMAGES))
$(eval $(call add_define,CSS_LOAD_SCP_IMAGES))

ifeq (${CSS_LOAD_SCP_IMAGES},1)
52
  NEED_SCP_BL2 := yes
53
  ifneq (${TRUSTED_BOARD_BOOT},0)
54
    $(eval $(call TOOL_ADD_IMG,scp_bl2u,--scp-fwu-cfg,FWU_))
55
56
  endif

Soby Mathew's avatar
Soby Mathew committed
57
58
59
  ifeq (${CSS_USE_SCMI_SDS_DRIVER},1)
    BL2U_SOURCES	+=	plat/arm/css/drivers/scp/css_sds.c	\
				plat/arm/css/drivers/sds/sds.c
60

Soby Mathew's avatar
Soby Mathew committed
61
62
63
64
    BL2_SOURCES		+=	plat/arm/css/drivers/scp/css_sds.c	\
				plat/arm/css/drivers/sds/sds.c
  else
    BL2U_SOURCES	+=	plat/arm/css/drivers/scp/css_bom_bootloader.c	\
65
				plat/arm/css/drivers/mhu/css_mhu.c		\
Soby Mathew's avatar
Soby Mathew committed
66
				plat/arm/css/drivers/scpi/css_scpi.c
67

Soby Mathew's avatar
Soby Mathew committed
68
    BL2_SOURCES		+=	plat/arm/css/drivers/scp/css_bom_bootloader.c	\
69
				plat/arm/css/drivers/mhu/css_mhu.c		\
Soby Mathew's avatar
Soby Mathew committed
70
71
72
73
74
75
76
77
78
79
				plat/arm/css/drivers/scpi/css_scpi.c
    # Enable option to detect whether the SCP ROM firmware in use predates version
    # 1.7.0 and therefore, is incompatible.
    CSS_DETECT_PRE_1_7_0_SCP	:=	1

    # Process CSS_DETECT_PRE_1_7_0_SCP flag
    $(eval $(call assert_boolean,CSS_DETECT_PRE_1_7_0_SCP))
    $(eval $(call add_define,CSS_DETECT_PRE_1_7_0_SCP))
  endif
endif
Soby Mathew's avatar
Soby Mathew committed
80

Soby Mathew's avatar
Soby Mathew committed
81
82
83
ifeq (${CSS_USE_SCMI_SDS_DRIVER},1)
  PLAT_BL_COMMON_SOURCES	+=	plat/arm/css/drivers/sds/${ARCH}/sds_helpers.S
endif
Soby Mathew's avatar
Soby Mathew committed
84

Soby Mathew's avatar
Soby Mathew committed
85
86
87
# Process CSS_USE_SCMI_SDS_DRIVER flag
$(eval $(call assert_boolean,CSS_USE_SCMI_SDS_DRIVER))
$(eval $(call add_define,CSS_USE_SCMI_SDS_DRIVER))
88
89
90
91
92
93
94
95
96

# Process CSS_NON_SECURE_UART flag
# This undocumented build option is only to enable debug access to the UART
# from non secure code, which is useful on some platforms.
# Default (obviously) is off.
CSS_NON_SECURE_UART		:= 0
$(eval $(call assert_boolean,CSS_NON_SECURE_UART))
$(eval $(call add_define,CSS_NON_SECURE_UART))