mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2026-07-04 18:18:43 +00:00
This patch adds the functionality needed for platforms to provide Branch Target Identification (BTI) extension, introduced to AArch64 in Armv8.5-A by adding BTI instruction used to mark valid targets for indirect branches. The patch sets new GP bit [50] to the stage 1 Translation Table Block and Page entries to denote guarded EL3 code pages which will cause processor to trap instructions in protected pages trying to perform an indirect branch to any instruction other than BTI. BTI feature is selected by BRANCH_PROTECTION option which supersedes the previous ENABLE_PAUTH used for Armv8.3-A Pointer Authentication and is disabled by default. Enabling BTI requires compiler support and was tested with GCC versions 9.0.0, 9.0.1 and 10.0.0. The assembly macros and helpers are modified to accommodate the BTI instruction. This is an experimental feature. Note. The previous ENABLE_PAUTH build option to enable PAuth in EL3 is now made as an internal flag and BRANCH_PROTECTION flag should be used instead to enable Pointer Authentication. Note. USE_LIBROM=1 option is currently not supported. Change-Id: Ifaf4438609b16647dc79468b70cd1f47a623362e Signed-off-by: Alexei Fedorov <Alexei.Fedorov@arm.com>
37 lines
1.1 KiB
Makefile
37 lines
1.1 KiB
Makefile
#
|
|
# Copyright (c) 2013-2019, ARM Limited and Contributors. All rights reserved.
|
|
#
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
#
|
|
|
|
INCLUDES += -Iinclude/bl32/tsp
|
|
|
|
BL32_SOURCES += bl32/tsp/tsp_main.c \
|
|
bl32/tsp/aarch64/tsp_entrypoint.S \
|
|
bl32/tsp/aarch64/tsp_exceptions.S \
|
|
bl32/tsp/aarch64/tsp_request.S \
|
|
bl32/tsp/tsp_interrupt.c \
|
|
bl32/tsp/tsp_timer.c \
|
|
common/aarch64/early_exceptions.S \
|
|
lib/locks/exclusive/aarch64/spinlock.S
|
|
|
|
BL32_LINKERFILE := bl32/tsp/tsp.ld.S
|
|
|
|
# This flag determines if the TSPD initializes BL32 in tspd_init() (synchronous
|
|
# method) or configures BL31 to pass control to BL32 instead of BL33
|
|
# (asynchronous method).
|
|
TSP_INIT_ASYNC := 0
|
|
|
|
$(eval $(call assert_boolean,TSP_INIT_ASYNC))
|
|
$(eval $(call add_define,TSP_INIT_ASYNC))
|
|
|
|
# Include the platform-specific TSP Makefile
|
|
# If no platform-specific TSP Makefile exists, it means TSP is not supported
|
|
# on this platform.
|
|
TSP_PLAT_MAKEFILE := $(wildcard ${PLAT_DIR}/tsp/tsp-${PLAT}.mk)
|
|
ifeq (,${TSP_PLAT_MAKEFILE})
|
|
$(error TSP is not supported on platform ${PLAT})
|
|
else
|
|
include ${TSP_PLAT_MAKEFILE}
|
|
endif
|