mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-16 01:24:27 +00:00

When TF-A is compiled with BTI enabled, the branches in the ROMLIB jumptable must be preceded by a "bti j" instruction. Moreover, when the additional "bti" instruction is inserted, the jumptable entries have a distance of 8 bytes between them instead of 4. Hence, the wrappers are also modified accordinly. If TF-A is compiled without BTI enabled, the ROMLIB jumptable and wrappers are generated as before. Change-Id: Iaa59897668f8e59888d39046233300c2241d8de7 Signed-off-by: John Tsichritzis <john.tsichritzis@arm.com>
71 lines
1 KiB
Bash
Executable file
71 lines
1 KiB
Bash
Executable file
#!/bin/sh
|
|
# Copyright (c) 2018-2019, ARM Limited and Contributors. All rights reserved.
|
|
#
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
set -e
|
|
|
|
build=.
|
|
out=output.a
|
|
|
|
for i
|
|
do
|
|
case $i in
|
|
-o)
|
|
out=$2
|
|
shift 2
|
|
;;
|
|
-b)
|
|
build=$2
|
|
shift 2
|
|
;;
|
|
--bti=*)
|
|
enable_bti=$(echo $1 | sed 's/--bti=\(.*\)/\1/')
|
|
shift 1
|
|
;;
|
|
--asflags=*)
|
|
asflags=$(echo $1 | sed 's/--asflags=\(.*\)/\1/')
|
|
shift 1
|
|
;;
|
|
--)
|
|
shift
|
|
break
|
|
;;
|
|
-*)
|
|
echo usage: genwrappers.sh [-o output] [-b dir] file ... >&2
|
|
exit 1
|
|
;;
|
|
esac
|
|
done
|
|
|
|
awk -v BTI=$enable_bti '
|
|
{sub(/[:blank:]*#.*/,"")}
|
|
!/^$/ && $NF != "patch" && $NF != "reserved" {
|
|
if (BTI == 1)
|
|
print $1*8, $2, $3
|
|
else
|
|
print $1*4, $2, $3}' "$@" |
|
|
while read idx lib sym
|
|
do
|
|
file=$build/${lib}_$sym
|
|
|
|
cat <<EOF > $file.s
|
|
.globl $sym
|
|
$sym:
|
|
EOF
|
|
if [ $enable_bti = 1 ]
|
|
then
|
|
echo "\tbti\tjc" >> $file.s
|
|
fi
|
|
cat <<EOF >> $file.s
|
|
ldr x17, =jmptbl
|
|
mov x16, #$idx
|
|
ldr x17, [x17]
|
|
add x16, x16, x17
|
|
br x16
|
|
EOF
|
|
|
|
${CROSS_COMPILE}as ${asflags} -o $file.o $file.s
|
|
done
|
|
|
|
${CROSS_COMPILE}ar -rc $out $build/*.o
|