blob: 94e6d26ae2b9d8b39490d278dcb8cb00a9961664 [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
45# 2. tf-l3-code-coverage: Missing library in Open CI, introduced by
46# https://git.trustedfirmware.org/ci/tf-a-ci-scripts.git/commit/?id=024efd51f025b8446e87c9adf99bd770dc769d99
47# 3. fvp-tbb-mbedtls-upcounter,fvp-fwu:fvp-tftf.fwu-aemv8a.invalid_nvcounter-debug: Pending TFC ticket
Leonardo Sandoval63fd38f2021-03-26 14:05:03 -060048# 4. Failure at LAVA job https://tf.validation.linaro.org/scheduler/job/142122
49# TFC ticket https://projects.linaro.org/browse/TFC-70
50# 5. Failure at LAVA job https://tf.validation.linaro.org/scheduler/job/142101
51# TFC ticket https://projects.linaro.org/browse/TFC-70
52
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050053blocklist="blocklist.txt"
54cat << EOF > "${blocklist}"
55coverity-tf-misra
Leonardo Sandovalf9a362f2021-03-04 12:02:57 -060056tf-l3-code-coverage
57fvp-tbb-mbedtls-upcounter,fvp-fwu,nil,nil,nil:fvp-tftf.fwu-aemv8a.invalid_nvcounter-debug
Leonardo Sandoval63fd38f2021-03-26 14:05:03 -060058fvp-mb-256-optee-romlib,nil,nil,nil,nil:fvp-optee.mb-linux.rootfs+ftpm-romlib-fip.ftpm-aemv8a
59fvp-linux-as-bl33,nil,nil,nil,nil:fvp-linux.bl33-dtb-aemv8a.linux.bl33-debug
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050060EOF
61
Leonardo Sandovalf9a362f2021-03-04 12:02:57 -060062if echo "${TEST_DESC}" | grep -F -f ${blocklist} - ; then
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050063 echo ${TEST_DESC} is blocklisted
64 exit 0
65fi
66
67mkdir -p ${WORKSPACE}/nfs/downloads/mbedtls
68cd ${WORKSPACE}/nfs/downloads/mbedtls
69curl --connect-timeout 5 --retry 5 --retry-delay 1 -sLSO -k -C - ${MBEDTLS_URL}
70export mbedtls_archive=${WORKSPACE}/nfs/downloads/mbedtls/$(ls -1 mbedtls-*.tar.gz)
71
Fathi Boudra9e402bf2019-12-05 11:16:41 +020072# Path to root of CI repository
73ci_root="${WORKSPACE}/tf-a-ci-scripts"
74
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050075export tfa_downloads="https://downloads.trustedfirmware.org/tf-a"
76
77# Fetch required firmware/binaries and place it at proper location
Fathi Boudra9e402bf2019-12-05 11:16:41 +020078export nfs_volume="${WORKSPACE}/nfs"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050079project_filer="${nfs_volume}/projectscratch/ssg/trusted-fw"
80for d in spm spm-10-23-2020; do
81 mkdir -p ${project_filer}/ci-files/$d
82 cd ${project_filer}/ci-files/$d
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060083 resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050084 download.json \
85 ${tfa_downloads}/$d/?export=json
86 for f in $(cat download.json | jq .files[].Url | sed s/\"//g); do
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060087 resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo $(basename $f) $f
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050088 done
89done
90
91# FIXME: place below code in above loop
92# fetch https://downloads.trustedfirmware.org/tf-a/dummy-crypto-lib.tar
93cd ${project_filer}
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060094resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050095 dummy-crypto-lib.tar \
96 https://downloads.trustedfirmware.org/tf-a/dummy-crypto-lib.tar
97tar xf dummy-crypto-lib.tar
98
99# fetch Juno rootfs, required by fvp
100linaro_2001_release="/nfs/downloads/linaro/20.01"
101cd ${linaro_2001_release}
Leonardo Sandoval3a931b92021-02-05 11:20:09 -0600102resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500103 lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz \
104 https://releases.linaro.org/openembedded/juno-lsk/latest/lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz
105
106# FIXME: create temporal /arm softlinks.
107# Reason behind is described at
108# https://git.trustedfirmware.org/ci/dockerfiles.git/commit/?id=4e2c2c94e434bc8a9b25f5da7c6018a43db8cb2f
109
110# /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update/bin/arm-none-eabi-gcc
111mkdir -p /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update
112ln -s \
113 ${TOOLS_DIR}/bin \
114 /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update/bin
115
116# /arm/projectscratch/ssg/trusted-fw/dummy-crypto-lib
117mkdir -p /arm/projectscratch/ssg/trusted-fw
118ln -s \
119 ${project_filer}/dummy-crypto-lib \
120 /arm/projectscratch/ssg/trusted-fw/dummy-crypto-lib
121
122
123# /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-
124mkdir -p /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu
125ln -s ${TOOLS_DIR}/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin \
126 /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin
127
128# CC=/arm/warehouse/Distributions/FA/ARMCompiler/6.8/25/standalone-linux-x86_64-rel/bin/armclang
129mkdir -p /arm/warehouse/Distributions/FA/ARMCompiler/6.8/25/standalone-linux-x86_64-rel
130ln -s ${TOOLS_DIR}/armclang-6.8/bin \
131 /arm/warehouse/Distributions/FA/ARMCompiler/6.8/25/standalone-linux-x86_64-rel/bin
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200132
133# Mandatory workspace
134export workspace="${workspace:-${WORKSPACE}/workspace}"
135
136# During feature development, we need incremental build, so don't run
137# 'distlcean' on every invocation.
138export dont_clean="${dont_clean:-1}"
139
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200140# Local paths to TF and TFTF repositories
141export tf_root="${tf_root:-${WORKSPACE}/trusted-firmware-a}"
142export tftf_root="${tftf_root:-${WORKSPACE}/tf-a-tests}"
143
144# We'd need to see the terminals during development runs, so no need for
145# automation.
146export test_run="${test_run:-1}"
147
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500148# By default, do not execute any run
149export skip_runs="${skip_runs:-1}"
150
151# set linaro platform release folder
152export linaro_2001_release="file://${linaro_2001_release}"
153
154export docker_registry="${DOCKER_REGISTRY}"
155export armlmd_license_file="${ARMLMD_LICENSE_FILE}"
156export juno_rootfs_url="${JUNO_ROOTFS_URL}"
157
158# Parse TEST_DESC and export test_group & tf_config and & run_config
159test_desc="${test_desc:-$TEST_DESC}"
160test_desc="${test_desc:?}"
161
162# Strip test suffix
163test_desc="${test_desc%%.test}"
164
165lhs="$(echo "$test_desc" | awk -F: '{print $1}')"
166rhs="$(echo "$test_desc" | awk -F: '{print $2}')"
167
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600168test_group="$(echo "$lhs" | awk -F% '{print $2}')"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500169build_config="$(echo "$lhs" | awk -F% '{print $3}')"
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600170run_config="${rhs%.test}"
171test_config="$(cat $WORKSPACE/TEST_DESC)"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500172
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600173export BUILD_CONFIG="$build_config"
174export RUN_CONFIG="$run_config"
175export TEST_CONFIG="$test_config"
176export TEST_GROUP="$test_group"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500177
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200178# Run this script bash -x, and it gets passed downstream for debugging
179if echo "$-" | grep -q "x"; then
180 bash_opts="-x"
181fi
182
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600183mkdir -p "${workspace}"
184bash $bash_opts "$ci_root/script/build_package.sh"
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200185
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500186# compress rootfs.bin file
187for a in $(find ${workspace} -type d -name artefacts); do
Leonardo Sandoval60afea52021-03-16 10:48:03 -0600188 for r in $(find $a -type f -name rootfs.bin -or -name busybox.bin); do
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500189 d=$(dirname $r); b=$(basename $r); cd "$d" && gzip "$b"
190 done
191done
192
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200193cp -a $(find ${workspace} -type d -name artefacts) ${WORKSPACE}/