• Antonio Nino Diaz's avatar
    TSP: Enable pointer authentication support · 67b6ff9f
    Antonio Nino Diaz authored
    The size increase after enabling options related to ARMv8.3-PAuth is:
    
    +----------------------------+-------+-------+-------+--------+
    |                            |  text |  bss  |  data | rodata |
    +----------------------------+-------+-------+-------+--------+
    | CTX_INCLUDE_PAUTH_REGS = 1 |   +40 |   +0  |   +0  |   +0   |
    |                            |  0.4% |       |       |        |
    +----------------------------+-------+-------+-------+--------+
    | ENABLE_PAUTH = 1           |  +352 |    +0 |  +16  |   +0   |
    |                            |  3.1% |       | 15.8% |        |
    +----------------------------+-------+-------+-------+--------+
    
    Results calculated with the following build configuration:
    
        make PLAT=fvp SPD=tspd DEBUG=1 \
        SDEI_SUPPORT=1                 \
        EL3_EXCEPTION_HANDLING=1       \
        TSP_NS_INTR_ASYNC_PREEMPT=1    \
        CTX_INCLUDE_PAUTH_REGS=1       \
        ENABLE_PAUTH=1
    
    Change-Id: I6cc1fe0b2345c547dcef66f98758c4eb55fe5ee4
    Signed-off-...
    67b6ff9f
tsp.mk 1.26 KB
#
# 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 whether pointer authentication is used in the TSP or not
ifeq ($(ENABLE_PAUTH),1)
BL32_CFLAGS		+=	-msign-return-address=non-leaf
endif

# 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