blob: 13497ea4caa7d6335b7c05b6d95d370f5bb60330 [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"
Chris Kay3a0b71d2022-11-18 11:42:59 +000026 elif echo "$JENKINS_URL" | grep -q "ci.trustedfirmware.org"; then
27 source "$ci_root/openci-env.sh"
Sandrine Bailleuxaaaffe02020-08-07 11:15:55 +020028 fi
29fi
30
Fathi Boudra422bf772019-12-02 11:10:16 +020031# Storage area to host toolchains, rootfs, tools, models, binaries, etc...
32nfs_volume="${nfs_volume:-$NFS_VOLUME}"
33nfs_volume="${nfs_volume:?}"
34
35# Override workspace for local runs
36workspace="${workspace:-$WORKSPACE}"
37workspace="${workspace:?}"
38workspace="$(readlink -f "$workspace")"
39artefacts="$workspace/artefacts"
40
41# pushd and popd outputs the directory stack every time, which could be
42# confusing when shown on the log. Suppress its output.
43pushd() {
44 builtin pushd "$1" &>/dev/null
45}
46popd() {
47 builtin popd &>/dev/null
48}
49
50# Copy a file to the $archive directory
51archive_file() {
52 local f out target md5
53 f="${1:?}"
54
55 out="${archive:?}"
56 [ ! -d "$out" ] && die "$out is not a directory"
57
58 target="$out/$(basename $f)"
59 if [ -f "$target" ]; then
60 # Prevent same file error
61 if [ "$(stat --format=%i "$target")" = \
62 "$(stat --format=%i "$f")" ]; then
63 return
64 fi
65 fi
66
67 md5="$(md5sum "$f" | awk '{print $1}')"
68 cp -t "$out" "$f"
69 echo "Archived: $f (md5: $md5)"
70}
71
72die() {
73 [ "$1" ] && echo "$1" >&2
74 exit 1
75}
76
77# Emit environment variables for the purpose of sourcing from shells and as
78# Jenkins property files. Whether the RHS is quoted depends on "$quote".
79emit_env() {
80 local env_file="${env_file:?}"
81 local var="${1:?}"
82
83 # Value parameter is mandatory, but allow for it to be empty
84 local val="${2?}"
85
86 if upon "$quote"; then
87 val="\"$val\""
88 else
89 # If RHS is not required to be quoted, any white space in it
90 # won't go well with a shell sourcing this file.
91 if echo "$var" | grep -q '\s'; then
92 die "$var: value '$val' has white space"
93 fi
94 fi
95
96 echo "$var=$val" >> "$env_file"
97}
98
Fathi Boudra422bf772019-12-02 11:10:16 +020099fetch_directory() {
100 local base="$(basename "${url:?}")"
101 local sa
102
Fathi Boudradd31e7b2020-01-29 15:44:42 +0200103 case "${url}" in
104 http*://*)
105 # Have exactly one trailing /
106 local modified_url="$(echo "${url}" | sed 's#/*$##')/"
Fathi Boudra422bf772019-12-02 11:10:16 +0200107
Fathi Boudradd31e7b2020-01-29 15:44:42 +0200108 # Figure out the number of components between hostname and the
109 # final one
110 local cut_dirs="$(echo "$modified_url" | awk -F/ '{print NF - 5}')"
111 sa="${saveas:-$base}"
112 echo "Fetch: $modified_url -> $sa"
laurenw-arm2d62c712022-09-13 14:27:15 -0500113 wget -rq -nH --cut-dirs="$cut_dirs" --no-parent -e robots=off \
Fathi Boudradd31e7b2020-01-29 15:44:42 +0200114 --reject="index.html*" "$modified_url"
115 if [ "$sa" != "$base" ]; then
116 mv "$base" "$sa"
117 fi
118 ;;
119 file://*)
120 sa="${saveas:-.}"
121 echo "Fetch: ${url} -> $sa"
122 cp -r "${url#file://}" "$sa"
123 ;;
124 *)
125 sa="${saveas:-.}"
126 echo "Fetch: ${url} -> $sa"
127 cp -r "${url}" "$sa"
128 ;;
129 esac
Fathi Boudra422bf772019-12-02 11:10:16 +0200130}
131
132fetch_file() {
133 local url="${url:?}"
134 local sa
135 local saveas
136
137 if is_url "$url"; then
Fathi Boudra422bf772019-12-02 11:10:16 +0200138 saveas="${saveas-"$(basename "$url")"}"
Sandrine Bailleux3da4bd12020-08-06 16:18:36 +0200139 sa="${saveas+-o $saveas}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200140 echo "Fetch: $url -> $saveas"
141 # Use curl to support file protocol
Sandrine Bailleux2a05b9c2021-02-25 13:52:21 +0100142 curl --fail -sLS $sa "$url"
Fathi Boudra422bf772019-12-02 11:10:16 +0200143 else
144 sa="${saveas-.}"
145 echo "Fetch: $url -> $sa"
146 cp "$url" "$sa"
147 fi
148}
149
Harrison Mutaia197d5d2022-09-15 13:45:21 +0100150fetch_and_archive() {
151 url=${url:?}
152 filename=${filename:-basename $url}
153
154 url="$url" saveas="$filename" fetch_file
155 archive_file "$filename"
156}
157
158filter_artefacts(){
159 local model_param_file="${model_param_file-$archive/model_params}"
160
161 # Bash doesn't have array values, we have to create references to the
162 # array of artefacts and the artefact filters.
163 declare -ga "$1"
164 declare -n artefacts="$1"
165 declare -n filters="$2"
166
167 for artefact in "${!filters[@]}"; do
168 if grep -E -q "${filters[${artefact}]}" "$model_param_file"; then
169 artefacts+=("${artefact}")
170 fi
171 done
172}
173
174gen_lava_job_def() {
175 local yaml_template_file="${yaml_template_file:?}"
176 local yaml_file="${yaml_file:?}"
177 local yaml_job_file="${yaml_job_file}"
178
179 # Bash doesn't have array values, we have to create references to the
180 # array of artefacts and their urls.
181 declare -n artefacts="$1"
182 declare -n artefact_urls="$2"
183
184 readarray -t boot_arguments < "${lava_model_params}"
185
186 # Generate the LAVA job definition, minus the test expectations
187 expand_template "${yaml_template_file}" > "${yaml_file}"
188
189 if [[ ! $model =~ "qemu" ]]; then
190 # Append expect commands into the job definition through
191 # test-interactive commands
192 gen_fvp_yaml_expect >> "$yaml_file"
193 fi
194
195 # create job.yaml
196 cp "$yaml_file" "$yaml_job_file"
197
198 # archive both yamls
199 archive_file "$yaml_file"
200 archive_file "$yaml_job_file"
201}
202
203gen_lava_model_params() {
204 local lava_model_params="${lava_model_params:?}"
205 declare -n macros="$1"
206
207 # Derive LAVA model parameters from the non-LAVA ones
208 cp "${archive}/model_params" "${lava_model_params}"
209
210 if [[ $model =~ "qemu" ]]; then
211 # Strip the model parameters of parameters already specified in the deploy
212 # overlay and job context.
213 sed -i '/-M/d;/kernel/d;/initrd/d;/bios/d;/cpu/d;/^[[:space:]]*$/d' \
214 $lava_model_params
215 elif [[ ! $model =~ "qemu" ]]; then
216 # FIXME find a way to properly match FVP configurations.
217 # Ensure braces in the FVP model parameters are not accidentally
218 # interpreted as LAVA macros.
219 sed -i -e 's/{/{{/g' "${lava_model_params}"
220 sed -i -e 's/}/}}/g' "${lava_model_params}"
221 else
222 echo "Unsupported emulated platform $model."
223 fi
224
225 # LAVA expects binary paths as macros, i.e. `{X}` instead of `x.bin`, so
226 # replace the file paths in our pre-generated model parameters.
227 for regex in "${!macros[@]}"; do
228 sed -i -e "s!${regex}!${macros[${regex}]}!" "${lava_model_params}"
229 done
230}
231
232gen_yaml_template() {
233 local target="${target-fvp}"
234 local yaml_template_file="${yaml_template_file-$workspace/${target}_template.yaml}"
235
236 local payload_type="${payload_type:?}"
237
238 cp "${ci_root}/script/lava-templates/${target}-${payload_type:?}.yaml" \
239 "${yaml_template_file}"
240
241 archive_file "$yaml_template_file"
242}
243
244# Generate link to an archived binary.
245gen_bin_url() {
246 local bin_mode="${bin_mode:?}"
247 local bin="${1:?}"
248
249 if upon "$jenkins_run"; then
250 echo "$jenkins_url/job/$JOB_NAME/$BUILD_NUMBER/artifact/artefacts/$bin_mode/$bin"
251 else
252 echo "file://$workspace/artefacts/$bin_mode/$bin"
253 fi
254}
255
256get_kernel() {
257 local kernel_type="${kernel_type:?}"
258 local url="${plat_kernel_list[$kernel_type]}"
259
260 url="${url:?}" filename="kernel.bin" fetch_and_archive
261}
262
Chris Kaya75c0a62022-11-17 18:53:50 +0000263# Get the path to the run environment variables file.
264#
265# Run environment variables are the test-specific environment variables
266# configured by the CI's test configuration.
267#
268# Usage: get_run_env_path <archive>
269get_run_env_path() {
270 echo "${1:?}/run/env"
271}
272
273# Get a run environment variable.
274#
275# Run environment variables are the test-specific environment variables
276# configured by the CI's test configuration.
277#
278# Usage: get_run_env <archive> <variable> [default]
279get_run_env() {
280 if [ -f "$(get_run_env_path "${1:?}")" ] && [ ! -v "${2:?}" ]; then
281 . "$(get_run_env_path "${1:?}")"
282 fi
283
284 echo "${!2:-${3}}"
285}
286
287# Get the number of UARTs configured by the current test configuration. This
288# defaults to `4`.
289#
290# Usage: get_num_uarts <archive> [default]
291get_num_uarts() {
292 local default=4
293
294 get_run_env "${1:?}" num_uarts "${2-${default}}"
295}
296
297# Get the ports script configured by the current test configuration. This
298# defaults to `script/default-ports-script.awk`.
299#
300# Usage: get_ports_script <archive> [default]
301get_ports_script() {
302 local default="${ci_root}/script/default-ports-script.awk"
303
304 get_run_env "${1:?}" ports_script "${2-${default}}"
305}
306
307# Get the primary UART configured by the current test configuration. This
308# defaults to `0`.
309#
310# Usage: get_primary_uart <archive> [default]
311get_primary_uart() {
312 local default=0
313
314 get_run_env "${1:?}" primary_uart "${2-${default}}"
315}
316
317# Get the payload UART configured by the current test configuration. This
318# defaults to the primary UART.
319#
320# Usage: get_payload_uart <archive> [default]
321get_payload_uart() {
322 local default="$(get_primary_uart "${1:?}")"
323
324 get_run_env "${1:?}" payload_uart "${2-${default}}"
325}
326
327# Get the path to a UART's environment variable directory.
328#
329# UART environment variables are the UART-specific environment variables
330# configured by the CI's test configuration.
331#
332# Usage: get_uart_env_path <archive> <uart>
333get_uart_env_path() {
334 echo "${1:?}/run/uart${2:?}"
335}
336
337# Get a UART environment variable.
338#
339# UART environment variables are the UART-specific environment variables
340# configured by the CI's test configuration.
341#
342# Usage: get_uart_env <archive> <uart> <variable> [default]
343get_uart_env() {
344 if [ ! -v "${3:?}" ] && [ -f "$(get_uart_env_path "${1:?}" "${2:?}")/${3:?}" ]; then
345 cat "$(get_uart_env_path "${1:?}" "${2:?}")/${3:?}"
346 else
347 echo "${!3:?-${4}}"
348 fi
349}
350
351# Get the path to the Expect script for a given UART. This defaults to nothing.
352#
353# Usage: get_uart_expect_script <archive> <uart> [default]
354get_uart_expect_script() {
355 local default=
356
357 get_uart_env "${1:?}" "${2:?}" expect "${3-${default}}"
358}
359
360# Get the FVP port for a given UART. This defaults to `5000 + ${uart}`.
361#
362# Usage: get_uart_port <archive> <uart> [default]
363get_uart_port() {
364 local default="$(( 5000 + "${2:?}" ))"
365
366 get_uart_env "${1:?}" "${2:?}" port "${3-${default}}"
367}
368
Fathi Boudra422bf772019-12-02 11:10:16 +0200369# Make a temporary directory/file insdie workspace, so that it doesn't need to
370# be cleaned up. Jenkins is setup to clean up workspace before a job runs.
371mktempdir() {
372 local ws="${workspace:?}"
373
374 mktemp -d --tmpdir="$ws"
375}
376mktempfile() {
377 local ws="${workspace:?}"
378
379 mktemp --tmpdir="$ws"
380}
381
382not_upon() {
383 ! upon "$1"
384}
385
386# Use "$1" as a boolean
387upon() {
388 case "$1" in
389 "" | "0" | "false") return 1;;
390 *) return 0;;
391 esac
392}
393
394# Check if the argument is a URL
395is_url() {
396 echo "$1" | grep -q "://"
397}
398
399# Check if a path is absolute
400is_abs() {
401 [ "${1:0:1}" = "/" ]
402}
403
404# Unset a variable based on its boolean value
405# If foo=, foo will be unset
406# If foo=blah, then leave it as is
407reset_var() {
408 local var="$1"
409 local val="${!var}"
410
411 if [ -z "$val" ]; then
412 unset "$var"
413 else
414 var="$val"
415 fi
416}
417
418default_var() {
419 local var="$1"
420 local val="${!var}"
421 local default="$2"
422
423 if [ -z "$val" ]; then
424 eval "$var=$default"
425 fi
426}
427
428# String various items joined by ":" to form a path. Items are prepended by
429# default; or 'op' can be set to 'append' to have them appended.
430# For example, to set: PATH=foo:bar:baz:$PATH
431extend_path() {
432 local path_var="$1"
433 local array_var="$2"
Leonardo Sandoval2af93202020-07-16 17:29:18 -0500434 local path_val="${!path_var}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200435 local op="${op:-prepend}"
Leonardo Sandoval2af93202020-07-16 17:29:18 -0500436 local sep=':'
437 local array_val
Fathi Boudra422bf772019-12-02 11:10:16 +0200438
Leonardo Sandoval2af93202020-07-16 17:29:18 -0500439 eval "array_val=\"\${$array_var[@]}\""
440 array_val="$(echo ${array_val// /:})"
441
442 [ -z "$path_val" ] && sep=''
443
444 if [ "$op" = "prepend" ]; then
445 array_val="${array_val}${sep}${path_val}"
446 elif [ "$op" = "append" ]; then
447 array_val="${path_val}${sep}${array_val}"
448 fi
449
450 eval "$path_var=\"$array_val\""
Fathi Boudra422bf772019-12-02 11:10:16 +0200451}
452
Chris Kay3d807882022-08-31 16:00:02 +0100453# Expand and evaluate Bash variables and expressions in a file, whose path is
454# given by the first parameter.
455#
456# For example, to expand a file containing the following:
457#
458# My name is ${name}!
459#
460# You might use:
461#
462# name="Chris" expand_template "path-to-my-file.txt"
463#
464# This would yield:
465#
466# My name is Chris!
467#
468# If you need to run multiple expansions on a file (e.g. to fill out information
469# incrementally), then you can escape expansion of a variable with a backslash,
470# e.g. `\${name}`.
471#
472# The expanded output is printed to the standard output stream.
473expand_template() {
474 local path="$1"
475
476 eval "cat <<-EOF
477 $(<${path})
478 EOF"
479}
480
Harrison Mutai013f6332022-02-16 16:06:33 +0000481# Fetch and extract the latest supported version of the LLVM toolchain from
482# a compressed archive file to a target directory, if it is required.
483setup_llvm_toolchain() {
484 link="${1:-$llvm_archive}"
485 archive="${2:-"$workspace/llvm.tar.xz"}"
486 target_dir="${3:-$llvm_dir}"
487
488 if is_arm_jenkins_env || upon "$local_ci"; then
489 url="$link" saveas="$archive" fetch_file
490 mkdir -p $target_dir
491 extract_tarball $archive $target_dir --strip-components=1 -k
492 fi
493}
494
495# Extract files from compressed archive to target directory. Supports .zip,
496# .tar.gz, and tar.xf format
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500497extract_tarball() {
498 local archive="$1"
499 local target_dir="$2"
Leonardo Sandovalec9e16c2020-09-09 14:32:40 -0500500 local extra_params="${3:-}"
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500501
502 pushd "$target_dir"
503 case $(file --mime-type -b "$archive") in
504 application/gzip)
Leonardo Sandovalec9e16c2020-09-09 14:32:40 -0500505 tar -xz $extra_params -f $archive
Zelalem219df412020-05-17 19:21:20 -0500506 ;;
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500507 application/zip)
Leonardo Sandovalec9e16c2020-09-09 14:32:40 -0500508 unzip -q $extra_params $archive
Zelalem219df412020-05-17 19:21:20 -0500509 ;;
Harrison Mutai013f6332022-02-16 16:06:33 +0000510 application/x-xz)
511 tar -x $extra_params -f $archive
512 ;;
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500513 esac
Zelalem219df412020-05-17 19:21:20 -0500514 popd "$target_dir"
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500515}
516
Gary Morrison999a9d72022-03-14 18:29:06 -0500517# See if execution is done by Jenkins. If called with a parameter,
518# representing a 'domain', e.g. arm.com, it will also check if
Leonardo Sandoval795b6212020-08-14 16:20:00 -0500519# JENKINS_URL contains the latter.
520is_jenkins_env () {
521 local domain="${1-}"
522
523 # check if running under Jenkins, if not, return non-zero
524 # the checks assumes Jenkins executing if JENKINS_HOME is set
525 [ -z "$JENKINS_HOME" ] && return 1
526
527 # if no parameter passed, no more checks, quit
528 [ -z "$domain" ] && return 0
529
530 if echo "$JENKINS_URL" | grep -q "$domain"; then
531 return 0
532 fi
533
534 return 1
535}
536
537
538# Check if execution is under ARM's jenkins
539is_arm_jenkins_env() {
540 local arm_domain="arm.com"
541 return $(is_jenkins_env "$arm_domain")
542}
543
Leonardo Sandovalfeae3a22020-11-17 16:53:59 -0600544
545# Provide correct linaro cross toolchain based on environment
546set_cross_compile_gcc_linaro_toolchain() {
547 local cross_compile_path="/home/buildslave/tools"
548
549 # if under arm enviroment, overide cross-compilation path
Madhukar Pappireddy21a5e672021-03-08 17:49:45 -0600550 is_arm_jenkins_env || upon "$local_ci" && cross_compile_path="/arm/pdsw/tools"
Leonardo Sandovalfeae3a22020-11-17 16:53:59 -0600551
552 echo "${cross_compile_path}/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-"
553}
554
Leonardo Sandoval795b6212020-08-14 16:20:00 -0500555if is_jenkins_env; then
Fathi Boudra422bf772019-12-02 11:10:16 +0200556 jenkins_run=1
557 umask 0002
558else
559 unset jenkins_run
560fi
561
562# Project scratch location for Trusted Firmware CI
563project_filer="${nfs_volume}/projectscratch/ssg/trusted-fw"
564project_scratch="${PROJECT_SCRATCH:-$project_filer/ci-workspace}"
565warehouse="${nfs_volume}/warehouse"
566jenkins_url="${JENKINS_URL%/*}"
567jenkins_url="${jenkins_url:-https://ci.trustedfirmware.org/}"
568
laurenw-arm35faeaa2021-05-03 14:28:17 -0500569# 11.12 Model revisions
570model_version_11_12="11.12"
571model_build_11_12="38"
572model_flavour_11_12="Linux64_GCC-6.4"
573
laurenw-armafdc3bc2022-09-14 15:31:42 -0500574# 11.16 Model revisions
575model_version_11_16="11.16"
576model_build_11_16="16"
577model_flavour_11_16="Linux64_GCC-6.4"
578
579# 11.17 Model revisions
580model_version_11_17="11.17"
581model_build_11_17="21"
582model_flavour_11_17="Linux64_GCC-9.3"
583
Fathi Boudra422bf772019-12-02 11:10:16 +0200584# Model revisions
laurenw-armafdc3bc2022-09-14 15:31:42 -0500585model_version="${model_version:-11.19}"
586model_build="${model_build:-14}"
Maksims Svecovs5c542512022-03-29 10:13:05 +0100587model_flavour="${model_flavour:-Linux64_GCC-9.3}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200588
589# Model snapshots from filer are not normally not accessible from developer
590# systems. Ignore failures from picking real path for local runs.
591pinned_cortex="$(readlink -f ${pinned_cortex:-$project_filer/models/cortex})" || true
592pinned_css="$(readlink -f ${pinned_css:-$project_filer/models/css})" || true
593
Fathi Boudra422bf772019-12-02 11:10:16 +0200594tforg_gerrit_url="review.trustedfirmware.org"
595
596# Repository URLs. We're using anonymous HTTP as they appear to be faster rather
597# than any scheme with authentication.
Fathi Boudra422bf772019-12-02 11:10:16 +0200598tf_src_repo_url="${tf_src_repo_url:-$TF_SRC_REPO_URL}"
599tf_src_repo_url="${tf_src_repo_url:-https://$tforg_gerrit_url/TF-A/trusted-firmware-a}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200600tftf_src_repo_url="${tftf_src_repo_url:-$TFTF_SRC_REPO_URL}"
601tftf_src_repo_url="${tftf_src_repo_url:-https://$tforg_gerrit_url/TF-A/tf-a-tests}"
Jimmy Brisson29ca0a02020-09-22 16:15:35 -0500602ci_src_repo_url="${ci_src_repo_url:-$CI_SRC_REPO_URL}"
603ci_src_repo_url="${ci_src_repo_url:-https://$tforg_gerrit_url/ci/tf-a-ci-scripts}"
Zelalemdd655272020-10-06 16:29:05 -0500604tf_ci_repo_url="$ci_src_repo_url"
Fathi Boudra422bf772019-12-02 11:10:16 +0200605scp_src_repo_url="${scp_src_repo_url:-$SCP_SRC_REPO_URL}"
Girish Pathak97f7ad42020-08-27 11:38:15 +0100606scp_src_repo_url="${scp_src_repo_url:-$scp_src_repo_default}"
Olivier Deprez965a7792019-12-16 14:09:03 +0100607spm_src_repo_url="${spm_src_repo_url:-$SPM_SRC_REPO_URL}"
608spm_src_repo_url="${spm_src_repo_url:-https://$tforg_gerrit_url/hafnium/hafnium}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200609
Leonardo Sandovald98f8332021-04-13 16:46:38 -0500610tf_downloads="${tf_downloads:-file:///downloads/}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200611tfa_downloads="${tfa_downloads:-file:///downloads/tf-a}"
612css_downloads="${css_downloads:-$tfa_downloads/css}"
613
Jayanth Dodderi Chidanandbf7369d2022-04-06 10:59:14 +0100614# SCP/MCP v2.10.0 release binaries.
Manish V Badarkhe83e4b8d2022-10-26 12:02:41 +0100615scp_mcp_downloads="${scp_mcp_downloads:-$tfa_downloads/css_scp_2.11.0}"
Alexei Fedorov9e4473d2020-11-04 10:13:07 +0000616
Leonardo Sandoval15676062020-11-19 11:58:09 -0600617linaro_2001_release="${linaro_2001_release:-$tfa_downloads/linaro/20.01}"
Alexei Fedorove405cc32020-09-30 18:13:55 +0100618linaro_release="${linaro_release:-$linaro_2001_release}"
Daniel Boulbyb63dd8c2022-09-23 11:55:20 +0100619mbedtls_version="${mbedtls_version:-2.28.1}"
Zelalem219df412020-05-17 19:21:20 -0500620
Madhukar Pappireddy4b686cf2020-03-31 13:05:14 -0500621# mbedTLS archive public hosting available at github.com
Sandrine Bailleuxdf823892022-04-22 13:27:45 +0200622mbedtls_archive="${mbedtls_archive:-https://github.com/Mbed-TLS/mbedtls/archive/refs/tags/v${mbedtls_version}.tar.gz}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200623
Harrison Mutai013f6332022-02-16 16:06:33 +0000624# FIXME: workaround to allow all on-prem host machines to access the latest LLVM
625# LLVM archive public hosting available at github.com
626llvm_version="${llvm_version:-14.0.0}"
627llvm_dir="$workspace/llvm-$llvm_version"
628llvm_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}"
629
Mark Dykes30138ad2021-11-09 16:48:17 -0600630coverity_path="${coverity_path:-${nfs_volume}/tools/coverity/static-analysis/2020.12}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200631coverity_default_checkers=(
632"--all"
633"--checker-option DEADCODE:no_dead_default:true"
Fathi Boudra422bf772019-12-02 11:10:16 +0200634"--enable AUDIT.SPECULATIVE_EXECUTION_DATA_LEAK"
Zelalem219df412020-05-17 19:21:20 -0500635"--enable ENUM_AS_BOOLEAN"
Fathi Boudra422bf772019-12-02 11:10:16 +0200636"--enable-constraint-fpp"
Fathi Boudra422bf772019-12-02 11:10:16 +0200637"--ticker-mode none"
Zelalem219df412020-05-17 19:21:20 -0500638"--hfa"
Fathi Boudra422bf772019-12-02 11:10:16 +0200639)
640
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500641docker_registry="${docker_registry:-}"
642
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500643# Define toolchain version and toolchain binary paths
Jayanth Dodderi Chidanandcc4d2342022-09-12 14:44:21 +0100644toolchain_version="11.3.rel1"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500645
Jayanth Dodderi Chidanandcc4d2342022-09-12 14:44:21 +0100646aarch64_none_elf_dir="${nfs_volume}/pdsw/tools/arm-gnu-toolchain-${toolchain_version}-x86_64-aarch64-none-elf"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500647aarch64_none_elf_prefix="aarch64-none-elf-"
648
Jayanth Dodderi Chidanandcc4d2342022-09-12 14:44:21 +0100649arm_none_eabi_dir="${nfs_volume}/pdsw/tools/arm-gnu-toolchain-${toolchain_version}-x86_64-arm-none-eabi"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500650arm_none_eabi_prefix="arm-none-eabi-"
651
Fathi Boudra422bf772019-12-02 11:10:16 +0200652path_list=(
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500653 "${aarch64_none_elf_dir}/bin"
654 "${arm_none_eabi_dir}/bin"
Harrison Mutai013f6332022-02-16 16:06:33 +0000655 "${llvm_dir}/bin"
Leonardo Sandoval1c24ae52020-07-08 11:47:23 -0500656 "${nfs_volume}/pdsw/tools/gcc-arm-none-eabi-5_4-2016q3/bin"
657 "$coverity_path/bin"
Fathi Boudra422bf772019-12-02 11:10:16 +0200658)
659
660ld_library_path_list=(
661)
662
Sandrine Bailleuxa6a1d6e2020-08-07 10:24:17 +0200663license_path_list=${license_path_list-(
664)}
Fathi Boudra422bf772019-12-02 11:10:16 +0200665
666# Setup various paths
667if upon "$retain_paths"; then
668 # If explicitly requested, retain local paths; apppend CI paths to the
669 # existing ones.
670 op="append" extend_path "PATH" "path_list"
671 op="append" extend_path "LD_LIBRARY_PATH" "ld_library_path_list"
672 op="append" extend_path "LM_LICENSE_FILE" "license_path_list"
673else
674 # Otherwise, prepend CI paths so that they take effect before local ones
675 extend_path "PATH" "path_list"
676 extend_path "LD_LIBRARY_PATH" "ld_library_path_list"
677 extend_path "LM_LICENSE_FILE" "license_path_list"
678fi
679
680export LD_LIBRARY_PATH
681export LM_LICENSE_FILE
Fathi Boudra422bf772019-12-02 11:10:16 +0200682export ARM_TOOL_VARIANT=ult
683
684# vim: set tw=80 sw=8 noet: