blob: 145d9c591ca44b0ab38227846ef0d841bf906677 [file] [log] [blame]
Fathi Boudra9e402bf2019-12-05 11:16:41 +02001#!/bin/bash
2
Leonardo Sandoval196c8fe2020-07-26 18:02:10 -05003set -ex
4
Leonardo Sandoval3a931b92021-02-05 11:20:09 -06005# Run the given command passed through parameters, if fails, try
6# at most more N-times with a pause of M-seconds until success.
7resilient_cmd() {
8 local cmd="$*"
9 local max_wait=10
10 local sleep_body=2
11 local iter=0
12
13 echo "Waiting for $cmd to complete"
14 while true; do
15 if ${cmd}; then
16 echo "$cmd job finished"
17 break
18 fi
19
20 sleep ${sleep_body}
21
22 iter=$(( iter + 1 ))
23 if [ ${iter} -ge ${max_wait} ]; then
24 return 1
25 fi
26 done
27 return 0
28}
Fathi Boudra9e402bf2019-12-05 11:16:41 +020029
Fathi Boudra7975ca72020-01-28 16:48:40 +020030# FIXME workaround clone_repos.sh script when using gerrit
31unset GERRIT_PROJECT
32unset GERRIT_BRANCH
33unset GERRIT_REFSPEC
34
Fathi Boudra9e402bf2019-12-05 11:16:41 +020035if [ -z "${WORKSPACE}" ]; then
36 ## Local build
37 export WORKSPACE=${PWD}
38fi
39
Fathi Boudra9e402bf2019-12-05 11:16:41 +020040cd ${WORKSPACE}
41
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050042# Several test descriptions are pending to be included in OpenCI, so for the moment
43# blocklist these.
Leonardo Sandovalf9a362f2021-03-04 12:02:57 -060044# 1. coverity-tf-misra: https://projects.linaro.org/browse/TFC-10
Leonardo Sandoval6631c432021-04-14 12:15:38 -050045# 2. fvp-tbb-mbedtls-upcounter,fvp-fwu:fvp-tftf.fwu-aemv8a.invalid_nvcounter-debug: Pending TFC ticket
Paul Sokolovskyfcb0fd82021-11-11 11:44:58 +030046# 3. Failure at LAVA job https://tf.validation.linaro.org/scheduler/job/142101
Leonardo Sandoval63fd38f2021-03-26 14:05:03 -060047# TFC ticket https://projects.linaro.org/browse/TFC-70
48
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050049blocklist="blocklist.txt"
50cat << EOF > "${blocklist}"
51coverity-tf-misra
Leonardo Sandovalf9a362f2021-03-04 12:02:57 -060052fvp-tbb-mbedtls-upcounter,fvp-fwu,nil,nil,nil:fvp-tftf.fwu-aemv8a.invalid_nvcounter-debug
Leonardo Sandoval63fd38f2021-03-26 14:05:03 -060053fvp-linux-as-bl33,nil,nil,nil,nil:fvp-linux.bl33-dtb-aemv8a.linux.bl33-debug
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050054EOF
55
Leonardo Sandovalf9a362f2021-03-04 12:02:57 -060056if echo "${TEST_DESC}" | grep -F -f ${blocklist} - ; then
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050057 echo ${TEST_DESC} is blocklisted
58 exit 0
59fi
60
61mkdir -p ${WORKSPACE}/nfs/downloads/mbedtls
62cd ${WORKSPACE}/nfs/downloads/mbedtls
63curl --connect-timeout 5 --retry 5 --retry-delay 1 -sLSO -k -C - ${MBEDTLS_URL}
64export mbedtls_archive=${WORKSPACE}/nfs/downloads/mbedtls/$(ls -1 mbedtls-*.tar.gz)
65
Fathi Boudra9e402bf2019-12-05 11:16:41 +020066# Path to root of CI repository
67ci_root="${WORKSPACE}/tf-a-ci-scripts"
68
Leonardo Sandoval6631c432021-04-14 12:15:38 -050069export tf_downloads="https://downloads.trustedfirmware.org"
70export tfa_downloads="${tf_downloads}/tf-a"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050071
72# Fetch required firmware/binaries and place it at proper location
Fathi Boudra9e402bf2019-12-05 11:16:41 +020073export nfs_volume="${WORKSPACE}/nfs"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050074project_filer="${nfs_volume}/projectscratch/ssg/trusted-fw"
75for d in spm spm-10-23-2020; do
76 mkdir -p ${project_filer}/ci-files/$d
77 cd ${project_filer}/ci-files/$d
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060078 resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050079 download.json \
80 ${tfa_downloads}/$d/?export=json
81 for f in $(cat download.json | jq .files[].Url | sed s/\"//g); do
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060082 resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo $(basename $f) $f
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050083 done
84done
85
86# FIXME: place below code in above loop
87# fetch https://downloads.trustedfirmware.org/tf-a/dummy-crypto-lib.tar
88cd ${project_filer}
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060089resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050090 dummy-crypto-lib.tar \
91 https://downloads.trustedfirmware.org/tf-a/dummy-crypto-lib.tar
92tar xf dummy-crypto-lib.tar
93
94# fetch Juno rootfs, required by fvp
95linaro_2001_release="/nfs/downloads/linaro/20.01"
96cd ${linaro_2001_release}
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060097resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050098 lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz \
99 https://releases.linaro.org/openembedded/juno-lsk/latest/lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz
100
Leonardo Sandoval6631c432021-04-14 12:15:38 -0500101# export trace code coverage variable
102export coverage_trace_plugin="${tf_downloads}/coverage-plugin/qa-tools/coverage-tool/coverage-plugin/coverage_trace.so"
103
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500104# FIXME: create temporal /arm softlinks.
105# Reason behind is described at
106# https://git.trustedfirmware.org/ci/dockerfiles.git/commit/?id=4e2c2c94e434bc8a9b25f5da7c6018a43db8cb2f
107
108# /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update/bin/arm-none-eabi-gcc
109mkdir -p /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update
110ln -s \
111 ${TOOLS_DIR}/bin \
112 /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update/bin
113
Leonardo Sandovale2123b12021-06-11 15:25:08 -0500114# /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-10-2020-q4-major/bin/arm-none-eabi-gcc
115mkdir -p /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-10-2020-q4-major
116ln -s \
117 ${TOOLS_DIR}/gnu-rm/bin \
118 /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-10-2020-q4-major/bin
119
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500120# /arm/projectscratch/ssg/trusted-fw/dummy-crypto-lib
121mkdir -p /arm/projectscratch/ssg/trusted-fw
122ln -s \
123 ${project_filer}/dummy-crypto-lib \
124 /arm/projectscratch/ssg/trusted-fw/dummy-crypto-lib
125
126
127# /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-
128mkdir -p /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu
129ln -s ${TOOLS_DIR}/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin \
130 /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin
131
132# CC=/arm/warehouse/Distributions/FA/ARMCompiler/6.8/25/standalone-linux-x86_64-rel/bin/armclang
133mkdir -p /arm/warehouse/Distributions/FA/ARMCompiler/6.8/25/standalone-linux-x86_64-rel
134ln -s ${TOOLS_DIR}/armclang-6.8/bin \
135 /arm/warehouse/Distributions/FA/ARMCompiler/6.8/25/standalone-linux-x86_64-rel/bin
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200136
137# Mandatory workspace
138export workspace="${workspace:-${WORKSPACE}/workspace}"
139
140# During feature development, we need incremental build, so don't run
141# 'distlcean' on every invocation.
142export dont_clean="${dont_clean:-1}"
143
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200144# Local paths to TF and TFTF repositories
145export tf_root="${tf_root:-${WORKSPACE}/trusted-firmware-a}"
146export tftf_root="${tftf_root:-${WORKSPACE}/tf-a-tests}"
147
148# We'd need to see the terminals during development runs, so no need for
149# automation.
150export test_run="${test_run:-1}"
151
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500152# By default, do not execute any run
153export skip_runs="${skip_runs:-1}"
154
155# set linaro platform release folder
156export linaro_2001_release="file://${linaro_2001_release}"
157
158export docker_registry="${DOCKER_REGISTRY}"
159export armlmd_license_file="${ARMLMD_LICENSE_FILE}"
160export juno_rootfs_url="${JUNO_ROOTFS_URL}"
161
162# Parse TEST_DESC and export test_group & tf_config and & run_config
163test_desc="${test_desc:-$TEST_DESC}"
164test_desc="${test_desc:?}"
165
166# Strip test suffix
167test_desc="${test_desc%%.test}"
168
169lhs="$(echo "$test_desc" | awk -F: '{print $1}')"
170rhs="$(echo "$test_desc" | awk -F: '{print $2}')"
171
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600172test_group="$(echo "$lhs" | awk -F% '{print $2}')"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500173build_config="$(echo "$lhs" | awk -F% '{print $3}')"
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600174run_config="${rhs%.test}"
175test_config="$(cat $WORKSPACE/TEST_DESC)"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500176
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600177export BUILD_CONFIG="$build_config"
178export RUN_CONFIG="$run_config"
179export TEST_CONFIG="$test_config"
180export TEST_GROUP="$test_group"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500181
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200182# Run this script bash -x, and it gets passed downstream for debugging
183if echo "$-" | grep -q "x"; then
184 bash_opts="-x"
185fi
186
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600187mkdir -p "${workspace}"
188bash $bash_opts "$ci_root/script/build_package.sh"
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200189
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500190# compress rootfs.bin file
191for a in $(find ${workspace} -type d -name artefacts); do
Leonardo Sandoval60afea52021-03-16 10:48:03 -0600192 for r in $(find $a -type f -name rootfs.bin -or -name busybox.bin); do
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500193 d=$(dirname $r); b=$(basename $r); cd "$d" && gzip "$b"
194 done
195done
196
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200197cp -a $(find ${workspace} -type d -name artefacts) ${WORKSPACE}/