blob: 89b1dfe499aee451baa1f13d96ccde192435e2d8 [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"
Leonardo Sandovalb2e54a92021-11-11 13:53:09 -060075mkdir -p ${project_filer}
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050076
77# FIXME: place below code in above loop
78# fetch https://downloads.trustedfirmware.org/tf-a/dummy-crypto-lib.tar
79cd ${project_filer}
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060080resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050081 dummy-crypto-lib.tar \
82 https://downloads.trustedfirmware.org/tf-a/dummy-crypto-lib.tar
83tar xf dummy-crypto-lib.tar
84
85# fetch Juno rootfs, required by fvp
86linaro_2001_release="/nfs/downloads/linaro/20.01"
87cd ${linaro_2001_release}
Leonardo Sandoval3a931b92021-02-05 11:20:09 -060088resilient_cmd curl --connect-timeout 5 --retry 5 --retry-delay 1 -fsSLo \
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050089 lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz \
90 https://releases.linaro.org/openembedded/juno-lsk/latest/lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz
91
Leonardo Sandoval6631c432021-04-14 12:15:38 -050092# export trace code coverage variable
93export coverage_trace_plugin="${tf_downloads}/coverage-plugin/qa-tools/coverage-tool/coverage-plugin/coverage_trace.so"
94
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -050095# FIXME: create temporal /arm softlinks.
96# Reason behind is described at
97# https://git.trustedfirmware.org/ci/dockerfiles.git/commit/?id=4e2c2c94e434bc8a9b25f5da7c6018a43db8cb2f
98
99# /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update/bin/arm-none-eabi-gcc
100mkdir -p /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update
101ln -s \
102 ${TOOLS_DIR}/bin \
103 /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-9-2020-q2-update/bin
104
Leonardo Sandovale2123b12021-06-11 15:25:08 -0500105# /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-10-2020-q4-major/bin/arm-none-eabi-gcc
106mkdir -p /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-10-2020-q4-major
107ln -s \
108 ${TOOLS_DIR}/gnu-rm/bin \
109 /arm/pdsw/downloads/scp-models/tools/gcc-arm-none-eabi-10-2020-q4-major/bin
110
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500111# /arm/projectscratch/ssg/trusted-fw/dummy-crypto-lib
112mkdir -p /arm/projectscratch/ssg/trusted-fw
113ln -s \
114 ${project_filer}/dummy-crypto-lib \
115 /arm/projectscratch/ssg/trusted-fw/dummy-crypto-lib
116
117
118# /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-
119mkdir -p /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu
120ln -s ${TOOLS_DIR}/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin \
121 /arm/pdsw/tools/gcc-linaro-6.2.1-2016.11-x86_64_aarch64-linux-gnu/bin
122
Harrison Mutaidc174472022-02-16 15:05:44 +0000123# CC=/arm/warehouse/Distributions/FA/ARMCompiler/6.18/19/standalone-linux-x86_64-rel/bin/armclang
124# FIXME: link to ARMCompiler 6.17 until 6.18 is available on Open-CI.
125mkdir -p /arm/warehouse/Distributions/FA/ARMCompiler/6.18/19/standalone-linux-x86_64-rel
126ln -s ${TOOLS_DIR}/armclang-6.17/bin \
127 /arm/warehouse/Distributions/FA/ARMCompiler/6.18/19/standalone-linux-x86_64-rel/bin
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200128
129# Mandatory workspace
130export workspace="${workspace:-${WORKSPACE}/workspace}"
131
132# During feature development, we need incremental build, so don't run
133# 'distlcean' on every invocation.
134export dont_clean="${dont_clean:-1}"
135
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200136# Local paths to TF and TFTF repositories
137export tf_root="${tf_root:-${WORKSPACE}/trusted-firmware-a}"
138export tftf_root="${tftf_root:-${WORKSPACE}/tf-a-tests}"
139
140# We'd need to see the terminals during development runs, so no need for
141# automation.
142export test_run="${test_run:-1}"
143
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500144# By default, do not execute any run
145export skip_runs="${skip_runs:-1}"
146
147# set linaro platform release folder
148export linaro_2001_release="file://${linaro_2001_release}"
149
150export docker_registry="${DOCKER_REGISTRY}"
151export armlmd_license_file="${ARMLMD_LICENSE_FILE}"
152export juno_rootfs_url="${JUNO_ROOTFS_URL}"
153
154# Parse TEST_DESC and export test_group & tf_config and & run_config
155test_desc="${test_desc:-$TEST_DESC}"
156test_desc="${test_desc:?}"
157
158# Strip test suffix
159test_desc="${test_desc%%.test}"
160
161lhs="$(echo "$test_desc" | awk -F: '{print $1}')"
162rhs="$(echo "$test_desc" | awk -F: '{print $2}')"
163
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600164test_group="$(echo "$lhs" | awk -F% '{print $2}')"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500165build_config="$(echo "$lhs" | awk -F% '{print $3}')"
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600166run_config="${rhs%.test}"
Paul Sokolovsky7be2e052021-11-08 14:45:01 +0300167test_config="${TEST_CONFIG}"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500168
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600169export BUILD_CONFIG="$build_config"
170export RUN_CONFIG="$run_config"
171export TEST_CONFIG="$test_config"
172export TEST_GROUP="$test_group"
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500173
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200174# Run this script bash -x, and it gets passed downstream for debugging
175if echo "$-" | grep -q "x"; then
176 bash_opts="-x"
177fi
178
Leonardo Sandoval601d8822021-03-17 10:40:06 -0600179mkdir -p "${workspace}"
180bash $bash_opts "$ci_root/script/build_package.sh"
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200181
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500182# compress rootfs.bin file
183for a in $(find ${workspace} -type d -name artefacts); do
Leonardo Sandoval60afea52021-03-16 10:48:03 -0600184 for r in $(find $a -type f -name rootfs.bin -or -name busybox.bin); do
Leonardo Sandovaldc2a03a2020-10-05 18:12:19 -0500185 d=$(dirname $r); b=$(basename $r); cd "$d" && gzip "$b"
186 done
187done
188
Fathi Boudra9e402bf2019-12-05 11:16:41 +0200189cp -a $(find ${workspace} -type d -name artefacts) ${WORKSPACE}/