blob: 4716c8044c637c6fc2bc11581609741c8e9f81dd [file] [log] [blame]
Leonardo Sandoval9dfdd1b2020-08-06 17:08:11 -05001#!/usr/bin/env bash
Fathi Boudra422bf772019-12-02 11:10:16 +02002#
Jayanth Dodderi Chidanandbf7369d2022-04-06 10:59:14 +01003# Copyright (c) 2019-2022, Arm Limited. All rights reserved.
Fathi Boudra422bf772019-12-02 11:10:16 +02004#
5# SPDX-License-Identifier: BSD-3-Clause
6#
7
8# This file is meant to be SOURCED only after setting $ci_root. $ci_root must be
9# the absolute path to the root of the CI repository
10#
11# A convenient way to set ci_root from the calling script like this:
12# ci_root="$(readlink -f "$(dirname "$0")/..")"
13#
14
15# Accept root of CI location from $CI_ROOT or $ci_root, in that order
16ci_root="${ci_root:-$CI_ROOT}"
17ci_root="${ci_root:?}"
18
Sandrine Bailleuxaaaffe02020-08-07 11:15:55 +020019# Optionally source a file containing environmental settings.
20if [ -n "$host_env" ]; then
21 source "$host_env"
22else
23 # Are we running on Arm infrastructure?
Gary Morrison999a9d72022-03-14 18:29:06 -050024 if echo "$JENKINS_URL" | grep -q "oss.arm.com"; then
Sandrine Bailleuxaaaffe02020-08-07 11:15:55 +020025 source "$ci_root/arm-env.sh"
26 fi
27fi
28
Fathi Boudra422bf772019-12-02 11:10:16 +020029# Storage area to host toolchains, rootfs, tools, models, binaries, etc...
30nfs_volume="${nfs_volume:-$NFS_VOLUME}"
31nfs_volume="${nfs_volume:?}"
32
33# Override workspace for local runs
34workspace="${workspace:-$WORKSPACE}"
35workspace="${workspace:?}"
36workspace="$(readlink -f "$workspace")"
37artefacts="$workspace/artefacts"
38
39# pushd and popd outputs the directory stack every time, which could be
40# confusing when shown on the log. Suppress its output.
41pushd() {
42 builtin pushd "$1" &>/dev/null
43}
44popd() {
45 builtin popd &>/dev/null
46}
47
48# Copy a file to the $archive directory
49archive_file() {
50 local f out target md5
51 f="${1:?}"
52
53 out="${archive:?}"
54 [ ! -d "$out" ] && die "$out is not a directory"
55
56 target="$out/$(basename $f)"
57 if [ -f "$target" ]; then
58 # Prevent same file error
59 if [ "$(stat --format=%i "$target")" = \
60 "$(stat --format=%i "$f")" ]; then
61 return
62 fi
63 fi
64
65 md5="$(md5sum "$f" | awk '{print $1}')"
66 cp -t "$out" "$f"
67 echo "Archived: $f (md5: $md5)"
68}
69
70die() {
71 [ "$1" ] && echo "$1" >&2
72 exit 1
73}
74
75# Emit environment variables for the purpose of sourcing from shells and as
76# Jenkins property files. Whether the RHS is quoted depends on "$quote".
77emit_env() {
78 local env_file="${env_file:?}"
79 local var="${1:?}"
80
81 # Value parameter is mandatory, but allow for it to be empty
82 local val="${2?}"
83
84 if upon "$quote"; then
85 val="\"$val\""
86 else
87 # If RHS is not required to be quoted, any white space in it
88 # won't go well with a shell sourcing this file.
89 if echo "$var" | grep -q '\s'; then
90 die "$var: value '$val' has white space"
91 fi
92 fi
93
94 echo "$var=$val" >> "$env_file"
95}
96
Fathi Boudra422bf772019-12-02 11:10:16 +020097fetch_directory() {
98 local base="$(basename "${url:?}")"
99 local sa
100
Fathi Boudradd31e7b2020-01-29 15:44:42 +0200101 case "${url}" in
102 http*://*)
103 # Have exactly one trailing /
104 local modified_url="$(echo "${url}" | sed 's#/*$##')/"
Fathi Boudra422bf772019-12-02 11:10:16 +0200105
Fathi Boudradd31e7b2020-01-29 15:44:42 +0200106 # Figure out the number of components between hostname and the
107 # final one
108 local cut_dirs="$(echo "$modified_url" | awk -F/ '{print NF - 5}')"
109 sa="${saveas:-$base}"
110 echo "Fetch: $modified_url -> $sa"
laurenw-arm2d62c712022-09-13 14:27:15 -0500111 wget -rq -nH --cut-dirs="$cut_dirs" --no-parent -e robots=off \
Fathi Boudradd31e7b2020-01-29 15:44:42 +0200112 --reject="index.html*" "$modified_url"
113 if [ "$sa" != "$base" ]; then
114 mv "$base" "$sa"
115 fi
116 ;;
117 file://*)
118 sa="${saveas:-.}"
119 echo "Fetch: ${url} -> $sa"
120 cp -r "${url#file://}" "$sa"
121 ;;
122 *)
123 sa="${saveas:-.}"
124 echo "Fetch: ${url} -> $sa"
125 cp -r "${url}" "$sa"
126 ;;
127 esac
Fathi Boudra422bf772019-12-02 11:10:16 +0200128}
129
130fetch_file() {
131 local url="${url:?}"
132 local sa
133 local saveas
134
135 if is_url "$url"; then
Fathi Boudra422bf772019-12-02 11:10:16 +0200136 saveas="${saveas-"$(basename "$url")"}"
Sandrine Bailleux3da4bd12020-08-06 16:18:36 +0200137 sa="${saveas+-o $saveas}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200138 echo "Fetch: $url -> $saveas"
139 # Use curl to support file protocol
Sandrine Bailleux2a05b9c2021-02-25 13:52:21 +0100140 curl --fail -sLS $sa "$url"
Fathi Boudra422bf772019-12-02 11:10:16 +0200141 else
142 sa="${saveas-.}"
143 echo "Fetch: $url -> $sa"
144 cp "$url" "$sa"
145 fi
146}
147
148# Make a temporary directory/file insdie workspace, so that it doesn't need to
149# be cleaned up. Jenkins is setup to clean up workspace before a job runs.
150mktempdir() {
151 local ws="${workspace:?}"
152
153 mktemp -d --tmpdir="$ws"
154}
155mktempfile() {
156 local ws="${workspace:?}"
157
158 mktemp --tmpdir="$ws"
159}
160
161not_upon() {
162 ! upon "$1"
163}
164
165# Use "$1" as a boolean
166upon() {
167 case "$1" in
168 "" | "0" | "false") return 1;;
169 *) return 0;;
170 esac
171}
172
173# Check if the argument is a URL
174is_url() {
175 echo "$1" | grep -q "://"
176}
177
178# Check if a path is absolute
179is_abs() {
180 [ "${1:0:1}" = "/" ]
181}
182
183# Unset a variable based on its boolean value
184# If foo=, foo will be unset
185# If foo=blah, then leave it as is
186reset_var() {
187 local var="$1"
188 local val="${!var}"
189
190 if [ -z "$val" ]; then
191 unset "$var"
192 else
193 var="$val"
194 fi
195}
196
197default_var() {
198 local var="$1"
199 local val="${!var}"
200 local default="$2"
201
202 if [ -z "$val" ]; then
203 eval "$var=$default"
204 fi
205}
206
207# String various items joined by ":" to form a path. Items are prepended by
208# default; or 'op' can be set to 'append' to have them appended.
209# For example, to set: PATH=foo:bar:baz:$PATH
210extend_path() {
211 local path_var="$1"
212 local array_var="$2"
Leonardo Sandoval2af93202020-07-16 17:29:18 -0500213 local path_val="${!path_var}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200214 local op="${op:-prepend}"
Leonardo Sandoval2af93202020-07-16 17:29:18 -0500215 local sep=':'
216 local array_val
Fathi Boudra422bf772019-12-02 11:10:16 +0200217
Leonardo Sandoval2af93202020-07-16 17:29:18 -0500218 eval "array_val=\"\${$array_var[@]}\""
219 array_val="$(echo ${array_val// /:})"
220
221 [ -z "$path_val" ] && sep=''
222
223 if [ "$op" = "prepend" ]; then
224 array_val="${array_val}${sep}${path_val}"
225 elif [ "$op" = "append" ]; then
226 array_val="${path_val}${sep}${array_val}"
227 fi
228
229 eval "$path_var=\"$array_val\""
Fathi Boudra422bf772019-12-02 11:10:16 +0200230}
231
Chris Kay3d807882022-08-31 16:00:02 +0100232# Expand and evaluate Bash variables and expressions in a file, whose path is
233# given by the first parameter.
234#
235# For example, to expand a file containing the following:
236#
237# My name is ${name}!
238#
239# You might use:
240#
241# name="Chris" expand_template "path-to-my-file.txt"
242#
243# This would yield:
244#
245# My name is Chris!
246#
247# If you need to run multiple expansions on a file (e.g. to fill out information
248# incrementally), then you can escape expansion of a variable with a backslash,
249# e.g. `\${name}`.
250#
251# The expanded output is printed to the standard output stream.
252expand_template() {
253 local path="$1"
254
255 eval "cat <<-EOF
256 $(<${path})
257 EOF"
258}
259
Harrison Mutai013f6332022-02-16 16:06:33 +0000260# Fetch and extract the latest supported version of the LLVM toolchain from
261# a compressed archive file to a target directory, if it is required.
262setup_llvm_toolchain() {
263 link="${1:-$llvm_archive}"
264 archive="${2:-"$workspace/llvm.tar.xz"}"
265 target_dir="${3:-$llvm_dir}"
266
267 if is_arm_jenkins_env || upon "$local_ci"; then
268 url="$link" saveas="$archive" fetch_file
269 mkdir -p $target_dir
270 extract_tarball $archive $target_dir --strip-components=1 -k
271 fi
272}
273
274# Extract files from compressed archive to target directory. Supports .zip,
275# .tar.gz, and tar.xf format
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500276extract_tarball() {
277 local archive="$1"
278 local target_dir="$2"
Leonardo Sandovalec9e16c2020-09-09 14:32:40 -0500279 local extra_params="${3:-}"
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500280
281 pushd "$target_dir"
282 case $(file --mime-type -b "$archive") in
283 application/gzip)
Leonardo Sandovalec9e16c2020-09-09 14:32:40 -0500284 tar -xz $extra_params -f $archive
Zelalem219df412020-05-17 19:21:20 -0500285 ;;
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500286 application/zip)
Leonardo Sandovalec9e16c2020-09-09 14:32:40 -0500287 unzip -q $extra_params $archive
Zelalem219df412020-05-17 19:21:20 -0500288 ;;
Harrison Mutai013f6332022-02-16 16:06:33 +0000289 application/x-xz)
290 tar -x $extra_params -f $archive
291 ;;
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500292 esac
Zelalem219df412020-05-17 19:21:20 -0500293 popd "$target_dir"
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500294}
295
Gary Morrison999a9d72022-03-14 18:29:06 -0500296# See if execution is done by Jenkins. If called with a parameter,
297# representing a 'domain', e.g. arm.com, it will also check if
Leonardo Sandoval795b6212020-08-14 16:20:00 -0500298# JENKINS_URL contains the latter.
299is_jenkins_env () {
300 local domain="${1-}"
301
302 # check if running under Jenkins, if not, return non-zero
303 # the checks assumes Jenkins executing if JENKINS_HOME is set
304 [ -z "$JENKINS_HOME" ] && return 1
305
306 # if no parameter passed, no more checks, quit
307 [ -z "$domain" ] && return 0
308
309 if echo "$JENKINS_URL" | grep -q "$domain"; then
310 return 0
311 fi
312
313 return 1
314}
315
316
317# Check if execution is under ARM's jenkins
318is_arm_jenkins_env() {
319 local arm_domain="arm.com"
320 return $(is_jenkins_env "$arm_domain")
321}
322
Leonardo Sandovalfeae3a22020-11-17 16:53:59 -0600323
324# Provide correct linaro cross toolchain based on environment
325set_cross_compile_gcc_linaro_toolchain() {
326 local cross_compile_path="/home/buildslave/tools"
327
328 # if under arm enviroment, overide cross-compilation path
Madhukar Pappireddy21a5e672021-03-08 17:49:45 -0600329 is_arm_jenkins_env || upon "$local_ci" && cross_compile_path="/arm/pdsw/tools"
Leonardo Sandovalfeae3a22020-11-17 16:53:59 -0600330
331 echo "${cross_compile_path}/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-"
332}
333
Leonardo Sandoval795b6212020-08-14 16:20:00 -0500334if is_jenkins_env; then
Fathi Boudra422bf772019-12-02 11:10:16 +0200335 jenkins_run=1
336 umask 0002
337else
338 unset jenkins_run
339fi
340
341# Project scratch location for Trusted Firmware CI
342project_filer="${nfs_volume}/projectscratch/ssg/trusted-fw"
343project_scratch="${PROJECT_SCRATCH:-$project_filer/ci-workspace}"
344warehouse="${nfs_volume}/warehouse"
345jenkins_url="${JENKINS_URL%/*}"
346jenkins_url="${jenkins_url:-https://ci.trustedfirmware.org/}"
347
laurenw-arm35faeaa2021-05-03 14:28:17 -0500348# 11.12 Model revisions
349model_version_11_12="11.12"
350model_build_11_12="38"
351model_flavour_11_12="Linux64_GCC-6.4"
352
laurenw-armafdc3bc2022-09-14 15:31:42 -0500353# 11.16 Model revisions
354model_version_11_16="11.16"
355model_build_11_16="16"
356model_flavour_11_16="Linux64_GCC-6.4"
357
358# 11.17 Model revisions
359model_version_11_17="11.17"
360model_build_11_17="21"
361model_flavour_11_17="Linux64_GCC-9.3"
362
Fathi Boudra422bf772019-12-02 11:10:16 +0200363# Model revisions
laurenw-armafdc3bc2022-09-14 15:31:42 -0500364model_version="${model_version:-11.19}"
365model_build="${model_build:-14}"
Maksims Svecovs5c542512022-03-29 10:13:05 +0100366model_flavour="${model_flavour:-Linux64_GCC-9.3}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200367
368# Model snapshots from filer are not normally not accessible from developer
369# systems. Ignore failures from picking real path for local runs.
370pinned_cortex="$(readlink -f ${pinned_cortex:-$project_filer/models/cortex})" || true
371pinned_css="$(readlink -f ${pinned_css:-$project_filer/models/css})" || true
372
Fathi Boudra422bf772019-12-02 11:10:16 +0200373tforg_gerrit_url="review.trustedfirmware.org"
374
375# Repository URLs. We're using anonymous HTTP as they appear to be faster rather
376# than any scheme with authentication.
Fathi Boudra422bf772019-12-02 11:10:16 +0200377tf_src_repo_url="${tf_src_repo_url:-$TF_SRC_REPO_URL}"
378tf_src_repo_url="${tf_src_repo_url:-https://$tforg_gerrit_url/TF-A/trusted-firmware-a}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200379tftf_src_repo_url="${tftf_src_repo_url:-$TFTF_SRC_REPO_URL}"
380tftf_src_repo_url="${tftf_src_repo_url:-https://$tforg_gerrit_url/TF-A/tf-a-tests}"
Jimmy Brisson29ca0a02020-09-22 16:15:35 -0500381ci_src_repo_url="${ci_src_repo_url:-$CI_SRC_REPO_URL}"
382ci_src_repo_url="${ci_src_repo_url:-https://$tforg_gerrit_url/ci/tf-a-ci-scripts}"
Zelalemdd655272020-10-06 16:29:05 -0500383tf_ci_repo_url="$ci_src_repo_url"
Fathi Boudra422bf772019-12-02 11:10:16 +0200384scp_src_repo_url="${scp_src_repo_url:-$SCP_SRC_REPO_URL}"
Girish Pathak97f7ad42020-08-27 11:38:15 +0100385scp_src_repo_url="${scp_src_repo_url:-$scp_src_repo_default}"
Olivier Deprez965a7792019-12-16 14:09:03 +0100386spm_src_repo_url="${spm_src_repo_url:-$SPM_SRC_REPO_URL}"
387spm_src_repo_url="${spm_src_repo_url:-https://$tforg_gerrit_url/hafnium/hafnium}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200388
Leonardo Sandovald98f8332021-04-13 16:46:38 -0500389tf_downloads="${tf_downloads:-file:///downloads/}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200390tfa_downloads="${tfa_downloads:-file:///downloads/tf-a}"
391css_downloads="${css_downloads:-$tfa_downloads/css}"
392
Jayanth Dodderi Chidanandbf7369d2022-04-06 10:59:14 +0100393# SCP/MCP v2.10.0 release binaries.
Manish V Badarkhe83e4b8d2022-10-26 12:02:41 +0100394scp_mcp_downloads="${scp_mcp_downloads:-$tfa_downloads/css_scp_2.11.0}"
Alexei Fedorov9e4473d2020-11-04 10:13:07 +0000395
Leonardo Sandoval15676062020-11-19 11:58:09 -0600396linaro_2001_release="${linaro_2001_release:-$tfa_downloads/linaro/20.01}"
Alexei Fedorove405cc32020-09-30 18:13:55 +0100397linaro_release="${linaro_release:-$linaro_2001_release}"
Daniel Boulbyb63dd8c2022-09-23 11:55:20 +0100398mbedtls_version="${mbedtls_version:-2.28.1}"
Zelalem219df412020-05-17 19:21:20 -0500399
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500400# mbedTLS archive public hosting available at github.com
Sandrine Bailleuxdf823892022-04-22 13:27:45 +0200401mbedtls_archive="${mbedtls_archive:-https://github.com/Mbed-TLS/mbedtls/archive/refs/tags/v${mbedtls_version}.tar.gz}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200402
Harrison Mutai013f6332022-02-16 16:06:33 +0000403# FIXME: workaround to allow all on-prem host machines to access the latest LLVM
404# LLVM archive public hosting available at github.com
405llvm_version="${llvm_version:-14.0.0}"
406llvm_dir="$workspace/llvm-$llvm_version"
407llvm_archive="${llvm_archive:-https://github.com/llvm/llvm-project/releases/download/llvmorg-$llvm_version/clang+llvm-$llvm_version-x86_64-linux-gnu-ubuntu-18.04.tar.xz}"
408
Mark Dykes30138ad2021-11-09 16:48:17 -0600409coverity_path="${coverity_path:-${nfs_volume}/tools/coverity/static-analysis/2020.12}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200410coverity_default_checkers=(
411"--all"
412"--checker-option DEADCODE:no_dead_default:true"
Fathi Boudra422bf772019-12-02 11:10:16 +0200413"--enable AUDIT.SPECULATIVE_EXECUTION_DATA_LEAK"
Zelalem219df412020-05-17 19:21:20 -0500414"--enable ENUM_AS_BOOLEAN"
Fathi Boudra422bf772019-12-02 11:10:16 +0200415"--enable-constraint-fpp"
Fathi Boudra422bf772019-12-02 11:10:16 +0200416"--ticker-mode none"
Zelalem219df412020-05-17 19:21:20 -0500417"--hfa"
Fathi Boudra422bf772019-12-02 11:10:16 +0200418)
419
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500420docker_registry="${docker_registry:-}"
421
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500422# Define toolchain version and toolchain binary paths
Jayanth Dodderi Chidanandcc4d2342022-09-12 14:44:21 +0100423toolchain_version="11.3.rel1"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500424
Jayanth Dodderi Chidanandcc4d2342022-09-12 14:44:21 +0100425aarch64_none_elf_dir="${nfs_volume}/pdsw/tools/arm-gnu-toolchain-${toolchain_version}-x86_64-aarch64-none-elf"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500426aarch64_none_elf_prefix="aarch64-none-elf-"
427
Jayanth Dodderi Chidanandcc4d2342022-09-12 14:44:21 +0100428arm_none_eabi_dir="${nfs_volume}/pdsw/tools/arm-gnu-toolchain-${toolchain_version}-x86_64-arm-none-eabi"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500429arm_none_eabi_prefix="arm-none-eabi-"
430
Fathi Boudra422bf772019-12-02 11:10:16 +0200431path_list=(
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500432 "${aarch64_none_elf_dir}/bin"
433 "${arm_none_eabi_dir}/bin"
Harrison Mutai013f6332022-02-16 16:06:33 +0000434 "${llvm_dir}/bin"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500435 "${nfs_volume}/pdsw/tools/gcc-arm-none-eabi-5_4-2016q3/bin"
436 "$coverity_path/bin"
Fathi Boudra422bf772019-12-02 11:10:16 +0200437)
438
439ld_library_path_list=(
440)
441
Sandrine Bailleuxa6a1d6e2020-08-07 10:24:17 +0200442license_path_list=${license_path_list-(
443)}
Fathi Boudra422bf772019-12-02 11:10:16 +0200444
445# Setup various paths
446if upon "$retain_paths"; then
447 # If explicitly requested, retain local paths; apppend CI paths to the
448 # existing ones.
449 op="append" extend_path "PATH" "path_list"
450 op="append" extend_path "LD_LIBRARY_PATH" "ld_library_path_list"
451 op="append" extend_path "LM_LICENSE_FILE" "license_path_list"
452else
453 # Otherwise, prepend CI paths so that they take effect before local ones
454 extend_path "PATH" "path_list"
455 extend_path "LD_LIBRARY_PATH" "ld_library_path_list"
456 extend_path "LM_LICENSE_FILE" "license_path_list"
457fi
458
459export LD_LIBRARY_PATH
460export LM_LICENSE_FILE
Fathi Boudra422bf772019-12-02 11:10:16 +0200461export ARM_TOOL_VARIANT=ult
462
463# vim: set tw=80 sw=8 noet: