blob: 7854081fc77eb5ab287331a74bcf66f374cd8fe3 [file] [log] [blame]
Leonardo Sandoval9dfdd1b2020-08-06 17:08:11 -05001#!/usr/bin/env bash
Fathi Boudra422bf772019-12-02 11:10:16 +02002#
Rupinderjit Singh385f17d2022-07-18 20:28:10 +01003# Copyright (c) 2020-2022, Arm Limited. All rights reserved.
Fathi Boudra422bf772019-12-02 11:10:16 +02004#
5# SPDX-License-Identifier: BSD-3-Clause
6#
7
8set -u
9
10bl1_addr="${bl1_addr:-0x0}"
Zelalem219df412020-05-17 19:21:20 -050011bl31_addr="${bl31_addr:-0x04001000}"
Zelalem1b874612020-08-04 18:08:18 -050012bl32_addr="${bl32_addr:-0x04003000}"
Fathi Boudra422bf772019-12-02 11:10:16 +020013bl33_addr="${bl33_addr:-0x88000000}"
14dtb_addr="${dtb_addr:-0x82000000}"
15fip_addr="${fip_addr:-0x08000000}"
16initrd_addr="${initrd_addr:-0x84000000}"
17kernel_addr="${kernel_addr:-0x80080000}"
18el3_payload_addr="${el3_payload_addr:-0x80000000}"
19
Manish Pandey3c435582020-07-15 12:14:26 +010020# SPM requires following addresses for RESET_TO_BL31 case
21spm_addr="${spm_addr:-0x6000000}"
22spmc_manifest_addr="${spmc_addr:-0x0403f000}"
23sp1_addr="${sp1_addr:-0x7000000}"
24sp2_addr="${sp2_addr:-0x7100000}"
Olivier Deprez0b834092020-08-21 08:36:01 +020025sp3_addr="${sp3_addr:-0x7200000}"
Olivier Deprezdd9ed332021-07-02 12:07:17 +020026sp4_addr="${sp4_addr:-0x7600000}"
Manish Pandey1e7be852020-11-09 16:04:48 +000027# SPM out directories
28export spm_secure_out_dir="${spm_secure_out_dir:-secure_aem_v8a_fvp_clang}"
29export spm_non_secure_out_dir="${spm_non_secure_out_dir:-aem_v8a_fvp_clang}"
Manish Pandey3c435582020-07-15 12:14:26 +010030
Fathi Boudra422bf772019-12-02 11:10:16 +020031ns_bl1u_addr="${ns_bl1u_addr:-0x0beb8000}"
32fwu_fip_addr="${fwu_fip_addr:-0x08400000}"
33backup_fip_addr="${backup_fip_addr:-0x09000000}"
34romlib_addr="${romlib_addr:-0x03ff2000}"
35
36uboot32_fip_url="$linaro_release/fvp32-latest-busybox-uboot/fip.bin"
37
Alexei Fedorove405cc32020-09-30 18:13:55 +010038rootfs_url="$linaro_release/lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz"
Fathi Boudra422bf772019-12-02 11:10:16 +020039
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050040# Default FVP model variables
Leonardo Sandovale1460662021-05-27 16:05:38 -050041default_model_dtb="dtb.bin"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050042
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060043# FVP containers and model paths
laurenw-arm35faeaa2021-05-03 14:28:17 -050044fvp_arm_std_library_11_12="fvp:fvp_arm_std_library_${model_version_11_12}_${model_build_11_12};/opt/model/FVP_ARM_Std_Library/models/${model_flavour_11_12}"
Maksims Svecovs284a50d2021-11-02 11:09:47 +000045fvp_arm_std_library="fvp:fvp_arm_std_library_${model_version}_${model_build};/opt/model/FVP_ARM_Std_Library/FVP_Base"
laurenw-armf414aba2021-04-26 15:58:56 -050046fvp_base_revc_2xaemva="fvp:fvp_base_revc-2xaemva_${model_version}_${model_build};/opt/model/Base_RevC_AEMvA_pkg/models/${model_flavour}"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060047foundation_platform="fvp:foundation_platform_${model_version}_${model_build};/opt/model/Foundation_Platformpkg/models/${model_flavour}"
johpow01936638d2021-11-08 18:22:24 -060048fvp_base_aemv8r="fvp:fvp_base_aemv8r_${model_version}_${model_build};/opt/model/AEMv8R_base_pkg/models/${model_flavour}"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050049
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060050# FVP associate array, run_config are keys and fvp container parameters are the values
51# Container parameters syntax: <model name>;<model dir>;<model bin>
52# FIXMEs: fix those ;;; values with real values
53
54declare -A fvp_models
55fvp_models=(
56[base-aemv8a-quad]=";;;"
57[base-aemv8a-revb]=";;;"
58[base-aemv8a-latest-revb]=";;;"
59[base-aemva]=";;;"
Manish V Badarkhee4783832021-02-22 14:36:56 +000060[base-aemv8a-gic600ae]=";;;"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060061[foundationv8]="${foundation_platform};Foundation_Platform"
laurenw-armf414aba2021-04-26 15:58:56 -050062[base-aemv8a]="${fvp_base_revc_2xaemva};FVP_Base_RevC-2xAEMvA"
johpow01936638d2021-11-08 18:22:24 -060063[baser-aemv8r]=";;;"
laurenw-arm35faeaa2021-05-03 14:28:17 -050064[cortex-a32x4]="${fvp_arm_std_library_11_12};FVP_Base_Cortex-A32x4"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060065[cortex-a35x4]="${fvp_arm_std_library};FVP_Base_Cortex-A35x4"
66[cortex-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A53x4"
Leonardo Sandoval95f896b2021-02-22 10:16:29 -060067[cortex-a55x4-a75x4]="${fvp_arm_std_library};FVP_Base_Cortex-A55x4+Cortex-A75x4"
68[cortex-a55x4-a76x2]="${fvp_arm_std_library};FVP_Base_Cortex-A55x4+Cortex-A76x2"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060069[cortex-a57x1-a53x1]="${fvp_arm_std_library};FVP_Base_Cortex-A57x1-A53x1"
70[cortex-a57x2-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x2-A53x4"
71[cortex-a57x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x4"
72[cortex-a57x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x4-A53x4"
73[cortex-a65aex8]="${fvp_arm_std_library};FVP_Base_Cortex-A65AEx8"
74[cortex-a65x4]="${fvp_arm_std_library};FVP_Base_Cortex-A65x4"
75[cortex-a72x4]="${fvp_arm_std_library};FVP_Base_Cortex-A72x4"
76[cortex-a72x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A72x4-A53x4"
77[cortex-a73x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73x4"
78[cortex-a73x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73x4-A53x4"
79[cortex-a75x4]="${fvp_arm_std_library};FVP_Base_Cortex-A75x4"
80[cortex-a76aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A76AEx4"
81[cortex-a76aex2]="${fvp_arm_std_library};FVP_Base_Cortex-A76AEx2"
82[cortex-a76x4]="${fvp_arm_std_library};FVP_Base_Cortex-A76x4"
83[cortex-a77x4]="${fvp_arm_std_library};FVP_Base_Cortex-A77x4"
84[cortex-a78x4]="${fvp_arm_std_library};FVP_Base_Cortex-A78x4"
laurenw-arm06c4a192022-07-12 14:55:28 -050085[cortex-a78cx4]="${fvp_arm_std_library};FVP_Base_Cortex-A78Cx4"
johpow011008edc2022-02-01 18:50:33 -060086[cortex-x2]="${fvp_arm_std_library};FVP_Base_Cortex-X2x4"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060087[neoverse_e1x1]="${fvp_arm_std_library};FVP_Base_Neoverse-E1x1"
88[neoverse_e1x2]="${fvp_arm_std_library};FVP_Base_Neoverse-E1x2"
89[neoverse_e1x4]="${fvp_arm_std_library};FVP_Base_Neoverse-E1x4"
Leonardo Sandoval54f1ade2021-06-26 19:20:48 -050090[neoverse_n1]="${fvp_arm_std_library};FVP_Base_Neoverse-N1x4"
Maksims Svecovsd10c1b92021-10-06 10:25:40 +010091[neoverse_n2]="${fvp_arm_std_library_11_12};FVP_Base_Neoverse-N1x4"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060092[neoverse-v1x4]=";;;"
Manish V Badarkhecbed15e2021-07-02 09:34:53 +010093[cortexa710x4]=";;;"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060094[css-rdv1]=";;;"
95[css-rde1edge]=";;;"
96[css-rdn1edge]=";;;"
97[css-rdn1edgex2]=";;;"
98[css-sgi575]=";;;"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060099[tc0]=";;;"
Usama Arifcba711d2021-08-04 15:53:42 +0100100[tc1]=";;;"
Rupinderjit Singh385f17d2022-07-18 20:28:10 +0100101[tc2]=";;;"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600102)
103
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500104
Fathi Boudra422bf772019-12-02 11:10:16 +0200105# FVP Kernel URLs
106declare -A fvp_kernels
107fvp_kernels=(
108[fvp-aarch32-zimage]="$linaro_release/fvp32-latest-busybox-uboot/Image"
109[fvp-busybox-uboot]="$linaro_release/fvp-latest-busybox-uboot/Image"
110[fvp-oe-uboot32]="$linaro_release/fvp32-latest-oe-uboot/Image"
111[fvp-oe-uboot]="$linaro_release/fvp-latest-oe-uboot/Image"
112[fvp-quad-busybox-uboot]="$tfa_downloads/quad_cluster/Image"
113)
114
Fathi Boudra422bf772019-12-02 11:10:16 +0200115# FVP initrd URLs
116declare -A fvp_initrd_urls
117fvp_initrd_urls=(
118[aarch32-ramdisk]="$linaro_release/fvp32-latest-busybox-uboot/ramdisk.img"
Fathi Boudra422bf772019-12-02 11:10:16 +0200119[dummy-ramdisk]="$linaro_release/fvp-latest-oe-uboot/ramdisk.img"
120[dummy-ramdisk32]="$linaro_release/fvp32-latest-oe-uboot/ramdisk.img"
121[default]="$linaro_release/fvp-latest-busybox-uboot/ramdisk.img"
122)
123
Fathi Boudra422bf772019-12-02 11:10:16 +0200124get_optee_bin() {
Sandrine Bailleux25ff2942021-02-25 14:00:10 +0100125 url="$tfa_downloads/optee/tee.bin" \
126 saveas="bl32.bin" fetch_file
Fathi Boudra422bf772019-12-02 11:10:16 +0200127 archive_file "bl32.bin"
128}
129
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100130# For Measured Boot tests using a TA based on OPTEE, it is necessary to use a
131# specific build rather than the default one generated by Jenkins.
132get_ftpm_optee_bin() {
Javier Almansa Sobrinode647722020-10-08 19:17:44 +0100133 url="$tfa_downloads/ftpm/optee/tee-header_v2.bin" \
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100134 saveas="bl32.bin" fetch_file
135 archive_file "bl32.bin"
136
Javier Almansa Sobrinode647722020-10-08 19:17:44 +0100137 url="$tfa_downloads/ftpm/optee/tee-pager_v2.bin" \
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100138 saveas="bl32_extra1.bin" fetch_file
139 archive_file "bl32_extra1.bin"
140
Leonardo Sandovalda5f78d2021-03-18 11:09:30 -0600141 # tee-pageable_v2.bin is just a empty file, named as bl32_extra2.bin,
142 # so just create the file
143 touch "bl32_extra2.bin"
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100144 archive_file "bl32_extra2.bin"
145}
146
Fathi Boudra422bf772019-12-02 11:10:16 +0200147get_uboot32_bin() {
148 local tmpdir="$(mktempdir)"
149
150 pushd "$tmpdir"
151 extract_fip "$uboot32_fip_url"
152 mv "nt-fw.bin" "uboot.bin"
153 archive_file "uboot.bin"
154 popd
155}
156
157get_uboot_bin() {
158 local uboot_url="$linaro_release/fvp-latest-busybox-uboot/bl33-uboot.bin"
159
160 url="$uboot_url" saveas="uboot.bin" fetch_file
161 archive_file "uboot.bin"
162}
163
164get_uefi_bin() {
Zelalem219df412020-05-17 19:21:20 -0500165 uefi_downloads="${uefi_downloads:-http://files.oss.arm.com/downloads/uefi}"
166 uefi_ci_bin_url="${uefi_ci_bin_url:-$uefi_downloads/Artifacts/Linux/github/fvp/static/DEBUG_GCC5/FVP_AARCH64_EFI.fd}"
Fathi Boudra422bf772019-12-02 11:10:16 +0200167
168 url=$uefi_ci_bin_url saveas="uefi.bin" fetch_file
169 archive_file "uefi.bin"
170}
171
172get_kernel() {
173 local kernel_type="${kernel_type:?}"
174 local url="${fvp_kernels[$kernel_type]}"
175
176 url="${url:?}" saveas="kernel.bin" fetch_file
177 archive_file "kernel.bin"
178}
179
180get_initrd() {
181 local initrd_type="${initrd_type:?}"
182 local url="${fvp_initrd_urls[$initrd_type]}"
183
184 url="${url:?}" saveas="initrd.bin" fetch_file
185 archive_file "initrd.bin"
186}
187
188get_dtb() {
189 local dtb_type="${dtb_type:?}"
190 local dtb_url
191 local dtb_saveas="$workspace/dtb.bin"
Zelalem219df412020-05-17 19:21:20 -0500192 local cc="$(get_tf_opt CROSS_COMPILE)"
193 local pp_flags="-P -nostdinc -undef -x assembler-with-cpp"
Fathi Boudra422bf772019-12-02 11:10:16 +0200194
195 case "$dtb_type" in
196 "fvp-base-quad-cluster-gicv3-psci")
197 # Get the quad-cluster FDT from pdsw area
198 dtb_url="$tfa_downloads/quad_cluster/fvp-base-quad-cluster-gicv3-psci.dtb"
199 url="$dtb_url" saveas="$dtb_saveas" fetch_file
200 ;;
Fathi Boudra422bf772019-12-02 11:10:16 +0200201 *)
Zelalem219df412020-05-17 19:21:20 -0500202 # Preprocess DTS file
203 ${cc}gcc -E ${pp_flags} -I"$tf_root/fdts" -I"$tf_root/include" \
204 -o "$workspace/${dtb_type}.pre.dts" \
205 "$tf_root/fdts/${dtb_type}.dts"
206 # Generate DTB file from DTS
Fathi Boudra422bf772019-12-02 11:10:16 +0200207 dtc -I dts -O dtb \
Zelalem219df412020-05-17 19:21:20 -0500208 "$workspace/${dtb_type}.pre.dts" -o "$dtb_saveas"
Fathi Boudra422bf772019-12-02 11:10:16 +0200209 esac
210
211 archive_file "$dtb_saveas"
212}
213
214get_rootfs() {
215 local tmpdir
216 local fs_base="$(echo $(basename $rootfs_url) | sed 's/\.gz$//')"
217 local cached="$project_filer/ci-files/$fs_base"
218
219 if upon "$jenkins_run" && [ -f "$cached" ]; then
220 # Job workspace is limited in size, and the root file system is
221 # quite large. This means, parallel runs of root file system
222 # tests could fail. So, for Jenkins runs, copy and use the root
223 # file system image from the $CI_SCRATCH location
224 local private="$CI_SCRATCH/$JOB_NAME-$BUILD_NUMBER"
225 mkdir -p "$private"
226 rm -f "$private/rootfs.bin"
227 url="$cached" saveas="$private/rootfs.bin" fetch_file
228 ln -s "$private/rootfs.bin" "$archive/rootfs.bin"
229 return
230 fi
231
232 tmpdir="$(mktempdir)"
233 pushd "$tmpdir"
234 url="$rootfs_url" saveas="rootfs.bin" fetch_file
235
236 # Possibly, the filesystem image we just downloaded is compressed.
237 # Decompress it if required.
238 if file "rootfs.bin" | grep -iq 'gzip compressed data'; then
239 echo "Decompressing root file system image rootfs.bin ..."
240 gunzip --stdout "rootfs.bin" > uncompressed_fs.bin
241 mv uncompressed_fs.bin "rootfs.bin"
242 fi
243
244 archive_file "rootfs.bin"
245 popd
246}
247
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200248fvp_romlib_jmptbl_backup="$(mktempdir)/jmptbl.i"
249
Fathi Boudra422bf772019-12-02 11:10:16 +0200250fvp_romlib_runtime() {
251 local tmpdir="$(mktempdir)"
252
253 # Save BL1 and romlib binaries from original build
254 mv "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin" "$tmpdir/romlib.bin"
255 mv "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin" "$tmpdir/bl1.bin"
256
257 # Patch index file
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200258 cp "${tf_root:?}/plat/arm/board/fvp/jmptbl.i" "$fvp_romlib_jmptbl_backup"
259 sed -i '/fdt/ s/.$/&\ patch/' ${tf_root:?}/plat/arm/board/fvp/jmptbl.i
Fathi Boudra422bf772019-12-02 11:10:16 +0200260
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200261 # Rebuild with patched file
262 echo "Building patched romlib:"
263 build_tf
Fathi Boudra422bf772019-12-02 11:10:16 +0200264
Fathi Boudra422bf772019-12-02 11:10:16 +0200265 # Retrieve original BL1 and romlib binaries
266 mv "$tmpdir/romlib.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin"
267 mv "$tmpdir/bl1.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin"
268}
269
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200270fvp_romlib_cleanup() {
271 # Restore original index
272 mv "$fvp_romlib_jmptbl_backup" "${tf_root:?}/plat/arm/board/fvp/jmptbl.i"
273}
274
275
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500276fvp_gen_bin_url() {
277 local bin_mode="${bin_mode:?}"
278 local bin="${1:?}"
279
280 if upon "$jenkins_run"; then
281 echo "$jenkins_url/job/$JOB_NAME/$BUILD_NUMBER/artifact/artefacts/$bin_mode/$bin"
282 else
283 echo "file://$workspace/artefacts/$bin_mode/$bin"
284 fi
285}
286
Chris Kayfbbf1322022-10-05 13:13:32 +0100287# Generates the template for YAML-based LAVA job definitions from a file
288# corresponding to the currently-selected payload, e.g.:
289#
290# - `lava-templates/fvp-linux.yaml`
291# - `lava-templates/fvp-tftf.yaml`
292#
293# The job definition template is itself expanded with visibility of all
294# variables that are available from within the function, including those with
295# local scope.
296#
297# TODO: Move the Gerrit metadata generation to to the main YAML generation phase
298# so that we can template the file in one phase.
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500299gen_fvp_yaml_template() {
Chris Kayfbbf1322022-10-05 13:13:32 +0100300 if [ -n "${GERRIT_CHANGE_NUMBER}" ]; then
301 local gerrit_url="https://review.trustedfirmware.org/c/${GERRIT_CHANGE_NUMBER}/${GERRIT_PATCHSET_NUMBER}"
302 elif [ -n "${GERRIT_REFSPEC}" ]; then
303 local gerrit_url=$(echo ${GERRIT_REFSPEC} |
304 awk -F/ '{print "https://review.trustedfirmware.org/c/" $4 "/" $5}')
305 fi
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500306
Chris Kayfbbf1322022-10-05 13:13:32 +0100307 local yaml_template_file="${workspace}/fvp_template.yaml"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500308
Chris Kayfbbf1322022-10-05 13:13:32 +0100309 pushd "${ci_root}/script/lava-templates"
310 expand_template "fvp-${payload_type:?}.yaml" > "$yaml_template_file"
311 popd
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500312
Chris Kayfbbf1322022-10-05 13:13:32 +0100313 archive_file "${yaml_template_file}"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500314}
315
316gen_fvp_yaml() {
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600317 local model="${model:?}"
318
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500319 local yaml_template_file="$workspace/fvp_template.yaml"
320 local yaml_file="$workspace/fvp.yaml"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500321 local yaml_job_file="$workspace/job.yaml"
322 local lava_model_params="$workspace/lava_model_params"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500323
Leonardo Sandovalfda4f292020-10-06 15:59:26 -0500324 # this function expects a template, quit if it is not present
325 if [ ! -f "$yaml_template_file" ]; then
326 return
327 fi
328
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600329 local model_params="${fvp_models[$model]}"
330 local model_name="$(echo "${model_params}" | awk -F ';' '{print $1}')"
331 local model_dir="$(echo "${model_params}" | awk -F ';' '{print $2}')"
332 local model_bin="$(echo "${model_params}" | awk -F ';' '{print $3}')"
333
334 # model params are required for correct yaml creation, quit if empty
335 if [ -z "${model_name}" ]; then
336 echo "FVP model param 'model_name' variable empty, yaml not produced"
337 return
338 elif [ -z "${model_dir}" ]; then
339 echo "FVP model param 'model_dir' variable empty, yaml not produced"
340 return
341 elif [ -z "${model_bin}" ]; then
342 echo "FVP model param 'model_bin' variable empty, yaml not produced"
343 return
344 fi
345
346 echo "FVP model params: model_name=$model_name model_dir=$model_dir model_bin=$model_bin"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500347
348 # optional parameters, defaults to globals
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500349 local model_dtb="${model_dtb:-$default_model_dtb}"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500350
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600351 # possible artefacts
352 backup_fip="$(fvp_gen_bin_url backup_fip.bin)"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500353 bl1="$(fvp_gen_bin_url bl1.bin)"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600354 bl2="$(fvp_gen_bin_url bl2.bin)"
355 bl31="$(fvp_gen_bin_url bl31.bin)"
356 bl32="$(fvp_gen_bin_url bl32.bin)"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600357 busybox="$(fvp_gen_bin_url busybox.bin.gz)"
358 cactus_primary="$(fvp_gen_bin_url cactus-primary.pkg)"
359 cactus_secondary="$(fvp_gen_bin_url cactus-secondary.pkg)"
360 cactus_tertiary="$(fvp_gen_bin_url cactus-tertiary.pkg)"
Leonardo Sandovald98f8332021-04-13 16:46:38 -0500361 coverage_trace_plugin="${coverage_trace_plugin}"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500362 dtb="$(fvp_gen_bin_url ${model_dtb})"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600363 el3_payload="$(fvp_gen_bin_url el3_payload.bin)"
364 fip="$(fvp_gen_bin_url fip.bin)"
Leonardo Sandovalcc52beb2021-05-05 19:05:31 -0500365 fip_gpt="$(fvp_gen_bin_url fip_gpt.bin)"
Leonardo Sandovalb1fb6342021-11-18 15:34:25 -0600366 fvp_spmc_manifest_dtb="$(fvp_gen_bin_url fvp_spmc_manifest.dtb)"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600367 fwu_fip="$(fvp_gen_bin_url fwu_fip.bin)"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600368 generic_trace="${tfa_downloads}/FastModelsPortfolio_${model_version}/plugins/${model_flavour}/GenericTrace.so"
369 hafnium="$(fvp_gen_bin_url hafnium.bin)"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500370 image="$(fvp_gen_bin_url kernel.bin)"
Leonardo Sandovalb1fb6342021-11-18 15:34:25 -0600371 ivy="$(fvp_gen_bin_url ivy.pkg)"
372 manifest_dtb="$(fvp_gen_bin_url manifest.dtb)"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600373 mcp_rom="$(fvp_gen_bin_url mcp_rom.bin)"
374 mcp_rom_hyphen="$(fvp_gen_bin_url mcp-rom.bin)"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500375 ns_bl1u="$(fvp_gen_bin_url ns_bl1u.bin)"
376 ns_bl2u="$(fvp_gen_bin_url ns_bl2u.bin)"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600377 ramdisk="$(fvp_gen_bin_url initrd.bin)"
378 romlib="$(fvp_gen_bin_url romlib.bin)"
379 rootfs="$(fvp_gen_bin_url rootfs.bin.gz)"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600380 secure_hafnium="$(fvp_gen_bin_url secure_hafnium.bin)"
381 scp_ram="$(fvp_gen_bin_url scp_ram.bin)"
382 scp_ram_hyphen="$(fvp_gen_bin_url scp-ram.bin)"
383 scp_rom="$(fvp_gen_bin_url scp_rom.bin)"
384 scp_rom_hyphen="$(fvp_gen_bin_url scp-rom.bin)"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600385 spm="$(fvp_gen_bin_url spm.bin)"
386 tftf="$(fvp_gen_bin_url tftf.bin)"
387 tmp="$(fvp_gen_bin_url tmp.bin)"
388 uboot="$(fvp_gen_bin_url uboot.bin)"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500389
390 docker_registry="${docker_registry:-}"
391 docker_registry="$(docker_registry_append)"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500392 docker_name="${docker_registry}$model_name"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600393 prompt1='/ #'
394 prompt2='root@genericarmv8:~#'
395 version_string="\"Fast Models"' [^\\n]+'"\""
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500396
Leonardo Sandoval5d87b702021-05-10 11:53:13 -0500397 test_config="${TEST_CONFIG}"
398
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600399 # arrays that relates variables and template macros
400 # NOTE: any addition on these arrays, requires an addition in the
401 # fvp templates
Leonardo Sandoval5d87b702021-05-10 11:53:13 -0500402 declare -A metadata_macros
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600403 declare -A yaml_macros
404 declare -A artefacts_macros
Leonardo Sandoval5d87b702021-05-10 11:53:13 -0500405 metadata_macros=(
406 [test_config]="{TEST_CONFIG}"
407 )
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600408 yaml_macros=(
409 [armlmd_license_file]="{ARMLMD_LICENSE_FILE}"
410 [docker_name]="{BOOT_DOCKER_NAME}"
411 [model]="{MODEL}"
412 [model_bin]="{BOOT_IMAGE_BIN}"
413 [model_dir]="{BOOT_IMAGE_DIR}"
414 [prompt1]="{PROMPT1}"
415 [prompt2]="{PROMPT2}"
416 [version_string]="{BOOT_VERSION_STRING}"
417 )
418 artefacts_macros=(
419 [backup_fip]="{BACKUP_FIP}"
420 [bl1]="{BL1}"
421 [bl2]="{BL2}"
422 [bl31]="{BL31}"
423 [bl32]="{BL32}"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600424 [cactus_primary]="{CACTUS_PRIMARY}"
425 [cactus_secondary]="{CACTUS_SECONDARY}"
426 [cactus_tertiary]="{CACTUS_TERTIARY}"
Leonardo Sandovald98f8332021-04-13 16:46:38 -0500427 [coverage_trace_plugin]="{COVERAGE_TRACE_PLUGIN}"
Leonardo Sandovalb1fb6342021-11-18 15:34:25 -0600428 [fvp_spmc_manifest_dtb]="{FVP_SPMC_MANIFEST_DTB}"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600429 [busybox]="{BUSYBOX}"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600430 [dtb]="{DTB}"
431 [el3_payload]="{EL3_PAYLOAD}"
Leonardo Sandovalcc52beb2021-05-05 19:05:31 -0500432 [fip_gpt]="{FIP_GPT}"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600433 [fwu_fip]="{FWU_FIP}"
434 [fip]="{FIP}"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600435 [generic_trace]="{GENERIC_TRACE}"
436 [hafnium]="{HAFNIUM}"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600437 [image]="{IMAGE}"
Leonardo Sandovalb1fb6342021-11-18 15:34:25 -0600438 [ivy]="{IVY}"
439 [manifest_dtb]="{MANIFEST_DTB}"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600440 [mcp_rom]="{MCP_ROM}"
441 [mcp_rom_hyphen]="{MCP_ROM_HYPHEN}"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600442 [ns_bl1u]="{NS_BL1U}"
443 [ns_bl2u]="{NS_BL2U}"
444 [ramdisk]="{RAMDISK}"
445 [romlib]="{ROMLIB}"
446 [rootfs]="{ROOTFS}"
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600447 [secure_hafnium]="{SECURE_HAFNIUM}"
448 [scp_ram]="{SCP_RAM}"
449 [scp_ram_hyphen]="{SCP_RAM_HYPHEN}"
450 [scp_rom]="{SCP_ROM}"
451 [scp_rom_hyphen]="{SCP_ROM_HYPHEN}"
452 [spm]="{SPM}"
453 [tftf]="{TFTF}"
454 [tmp]="{TMP}"
455 [uboot]="{UBOOT}"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600456 )
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500457
Chris Kay4eb9ded2022-10-10 15:51:40 +0100458 declare -A artefact_filters=(
459 [backup_fip]="backup_fip.bin"
460 [bl1]="bl1.bin"
461 [bl2]="bl2.bin"
462 [bl31]="bl31.bin"
463 [bl32]="bl32.bin"
464 [busybox]="busybox.bin"
465 [cactus_primary]="cactus-primary.pkg"
466 [cactus_secondary]="cactus-secondary.pkg"
467 [cactus_tertiary]="cactus-tertiary.pkg"
468 [coverage_trace_plugin]="coverage_trace.so"
469 [dtb]="dtb.bin"
470 [el3_payload]="el3_payload.bin"
471 [fip_gpt]="fip_gpt.bin"
472 [fip]="fip.bin"
473 [fvp_spmc_manifest_dtb]="=fvp_spmc_manifest.dtb"
474 [fwu_fip]="fwu_fip.bin"
475 [generic_trace]="GenericTrace.so"
476 [hafnium]="hafnium.bin"
477 [image]="kernel.bin"
478 [ivy]="ivy.pkg"
479 [manifest_dtb]="=manifest.dtb"
480 [mcp_rom_hyphen]="mcp-rom.bin"
481 [mcp_rom]="mcp_rom.bin"
482 [ns_bl1u]="ns_bl1u.bin"
483 [ns_bl2u]="ns_bl2u.bin"
484 [ramdisk]="initrd.bin|initrd.img"
485 [romlib]="romlib.bin"
486 [rootfs]="rootfs.bin"
487 [scp_ram_hyphen]="scp-ram.bin"
488 [scp_ram]="scp_ram.bin"
489 [scp_rom_hyphen]="scp-rom.bin"
490 [scp_rom]="scp_rom.bin"
491 [secure_hafnium]="secure_hafnium.bin"
492 [spm]="spm.bin"
493 [tftf]="tftf.bin"
494 [tmp]="tmp.bin"
495 [uboot]="uboot.bin"
496 )
497
498 declare -a artefacts=()
499
500 for artefact in "${!artefact_filters[@]}"; do
501 if grep -E -q "${artefact_filters[${artefact}]}" "${archive}/model_params"; then
502 artefacts+=("${artefact}")
503 fi
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600504 done
Leonardo Sandovalbe690bd2020-10-12 17:59:39 -0500505
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600506 # copied files are the working files
507 cp "${yaml_template_file}" "${yaml_file}"
508 cp "$archive/model_params" "$lava_model_params"
509
Chris Kayf07d3392022-10-26 15:42:48 +0100510 # Ensure braces in the FVP model parameters are not accidentally interpreted
511 # as LAVA macros.
512 sed -i -e 's/{/{{/g' "${lava_model_params}"
513 sed -i -e 's/}/}}/g' "${lava_model_params}"
514
Leonardo Sandoval5d87b702021-05-10 11:53:13 -0500515 # replace metadata macros with real values
516 for m in "${!metadata_macros[@]}"; do
517 sed -i -e "s|${metadata_macros[$m]}|${!m}|" "$yaml_file"
518 done
519
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600520 # replace yaml macros with real values
521 for m in "${!yaml_macros[@]}"; do
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600522 sed -i -e "s|${yaml_macros[$m]}|${!m}|" "$yaml_file"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600523 done
524
525 # replace artefact macros with real values
526 for m in "${!artefacts_macros[@]}"; do
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600527 sed -i -e "s|${artefacts_macros[$m]}|${!m}|" "$yaml_file"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600528 done
529
530 # LAVA expects parameters as 'macros', i.e. {X} instead of x.bin, so
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600531 # replace them. As in the macro removal above, handle special cases for several
532 # artefacts
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600533 for m in "${!artefacts_macros[@]}"; do
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600534 case "$m" in
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600535 cactus_primary)
536 sed -i -e "s|=cactus-primary.pkg|=${artefacts_macros[$m]}|" "$lava_model_params"
537 ;;
538 cactus_secondary)
539 sed -i -e "s|=cactus-secondary.pkg|=${artefacts_macros[$m]}|" "$lava_model_params"
540 ;;
541 cactus_tertiary)
542 sed -i -e "s|=cactus-tertiary.pkg|=${artefacts_macros[$m]}|" "$lava_model_params"
543 ;;
Leonardo Sandovald98f8332021-04-13 16:46:38 -0500544 coverage_trace_plugin)
545 sed -i -e "s|--plugin .*coverage_trace.so|--plugin ${artefacts_macros[$m]}|" "$lava_model_params"
546 sed -i -e "s|--plugin=.*coverage_trace.so|--plugin=${artefacts_macros[$m]}|" "$lava_model_params"
547 ;;
Leonardo Sandovalb1fb6342021-11-18 15:34:25 -0600548 fvp_spmc_manifest_dtb)
549 sed -i -e "s|=fvp_spmc_manifest.dtb|=${artefacts_macros[$m]}|" "$lava_model_params"
550 ;;
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600551 generic_trace)
552 sed -i -e "s|--plugin .*GenericTrace.so|--plugin ${artefacts_macros[$m]}|" "$lava_model_params"
553 sed -i -e "s|--plugin=.*GenericTrace.so|--plugin=${artefacts_macros[$m]}|" "$lava_model_params"
554 ;;
555 image)
556 sed -i -e "s|=kernel.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
557 ;;
Leonardo Sandovalb1fb6342021-11-18 15:34:25 -0600558 ivy)
559 sed -i -e "s|=ivy.pkg|=${artefacts_macros[$m]}|" "$lava_model_params"
560 ;;
561 manifest_dtb)
562 sed -i -e "s|=manifest.dtb|=${artefacts_macros[$m]}|" "$lava_model_params"
563 ;;
Leonardo Sandovaldf9c92f2021-03-12 11:31:09 -0600564 mcp_rom_hyphen)
565 sed -i -e "s|=mcp-rom.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
566 ;;
567 ramdisk)
568 sed -i -e "s|=initrd.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
569 sed -i -e "s|=initrd.img|=${artefacts_macros[$m]}|" "$lava_model_params"
570 ;;
571 scp_ram_hyphen)
572 sed -i -e "s|=scp-ram.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
573 ;;
574 scp_rom_hyphen)
575 sed -i -e "s|=scp-rom.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
576 ;;
577 tmp | hafnium | secure_hafnium)
578 sed -i -e "s|=.*/${m}.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
579 ;;
580 *)
581 sed -i -e "s|=${m}.bin|=${artefacts_macros[$m]}|" "$lava_model_params"
582 ;;
583 esac
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600584 done
Leonardo Sandovalbe690bd2020-10-12 17:59:39 -0500585
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500586 # include the model parameters
587 while read -r line; do
588 if [ -n "$line" ]; then
Chris Kay60df24d2022-10-04 17:35:06 +0100589 yaml_line="- $(echo "${line}" | jq -R .)"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600590 sed -i -e "/{BOOT_ARGUMENTS}/i \ \ \ \ $yaml_line" "$yaml_file"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500591 fi
Leonardo Sandovalbe690bd2020-10-12 17:59:39 -0500592 done < "$lava_model_params"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600593 sed -i -e '/{BOOT_ARGUMENTS}/d' "$yaml_file"
Leonardo Sandovalbe690bd2020-10-12 17:59:39 -0500594
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500595 # Append expect commands into the job definition through test-interactive commands
596 gen_fvp_yaml_expect >> "$yaml_file"
597
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600598 # create job.yaml
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500599 cp "$yaml_file" "$yaml_job_file"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500600
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600601 # archive both yamls
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500602 archive_file "$yaml_file"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500603 archive_file "$yaml_job_file"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500604}
605
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500606gen_fvp_yaml_expect() {
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500607
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500608 run_root="$archive/run"
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500609
610 # Loop through all uarts expect files
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500611 for expect_file in $(find $run_root -name expect); do
612
613 # TODO: currently, only handle UART 0
614 case $expect_file in
615 *uart0* )
616 uart_number=uart0
617 ;;
618 *)
619 continue
620 ;;
621 esac
622
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500623 # Array containing "interactive" or "monitor" expect strings and populated during run config execution.
624 # Interactive expect scripts are converted into LAVA Interactive Test Actions (see
625 # https://tf.validation.linaro.org/static/docs/v2/interactive.html#writing-tests-interactive) and
626 # monitor expect scripts are converted into LAVA Monitor Test Actions (see
627 # https://validation.linaro.org/static/docs/v2/actions-test.html#monitor)
628 #
629 # Interactive Expect strings have the format 'i;<prompt>;<succeses>;<failures>;<commands>'
630 # where multiple successes or failures or commands are separated by @
631 #
632 # Monitor Expect strings have the format 'm;<start>;<end>;<patterns>'
633 # where multiple patterns are separated by @
634 #
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500635 expect_string=()
636
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500637 # Get the real name of the expect file
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500638 expect_file=$(cat $expect_file)
639
640 # Source the run_config enviroment variables
641 env=$run_root/$uart_number/env
642 if [ -e $env ]; then
643 source $env
644 fi
645
646 # Get all expect strings
Paul Sokolovskyeece6f72021-12-01 15:04:29 +0300647 expect_file=$ci_root/expect-lava/${expect_file}
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500648 source $expect_file
649
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500650
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500651 if [ ${#expect_string[@]} -gt 0 ]; then
652
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500653 # expect loop
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500654 for key in "${!expect_string[@]}"; do
655
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500656 # single raw expect string
657 es="${expect_string[${key}]}"
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500658
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500659 # action type: either m or i
660 action="$(echo "${es}" | awk -F ';' '{print $1}')"
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500661
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500662 if [ "${action}" = "m" ]; then
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500663
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500664 start="$(echo "${es}" | awk -F ';' '{print $2}')"
665 end="$(echo "${es}" | awk -F ';' '{print $3}')"
666 patterns="$(echo "${es}" | awk -F ';' '{print $4}')"
667
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500668 cat << EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500669- test:
670 monitors:
671 - name: tests
672 start: '${start}'
673 end: '${end}'
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500674EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500675 # Patterns are separated by '@'
676 OLD_IFS=$IFS; IFS=$'@'
677 for p in ${patterns}; do
678 cat << EOF
679 pattern: '$p'
680EOF
681 done
682 IFS=$OLD_IFS
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500683 cat << EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500684 fixupdict:
685 PASS: pass
686 FAIL: fail
687EOF
688 fi # end of monitor action
689
690 if [ "${action}" = "i" ]; then
691
692 prompts="$(echo "${es}" | awk -F ';' '{print $2}')"
693 successes="$(echo "${es}" | awk -F ';' '{print $3}')"
694 failures="$(echo "${es}" | awk -F ';' '{print $4}')"
695 commands="$(echo "${es}" | awk -F ';' '{print $5}')"
696
697 cat << EOF
698- test:
699 interactive:
700EOF
701 OLD_IFS=$IFS; IFS=$'@'
702
703 if [[ -n "${prompts}" && -n "${successes}" && -n "${failures}" ]]; then
704 cat << EOF
705 - name: interactive_${uart_number}_${key}
706 prompts: ['${prompts}']
707 script:
708EOF
709 if [ -z "${commands}" ]; then
710 cat <<EOF
711 - name: interactive_command_${uart_number}_${key}
712 command:
713EOF
714 else
715 for c in ${commands}; do
716 cat <<EOF
717 - name: interactive_command_${uart_number}_${key}
Paul Sokolovskydf445242021-12-15 16:57:51 +0300718 command: "$c"
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500719EOF
720 done
721 fi
722 cat << EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500723 successes:
724EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500725 for s in ${successes}; do
726 cat <<EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500727 - message: '$s'
728EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500729 done
730 cat << EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500731 failures:
732EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500733 for f in ${failures}; do
734 cat <<EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500735 - message: '$f'
736EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500737 done
738 elif [[ -n "${prompts}" && -n "${successes}" ]]; then
739 cat << EOF
740 - name: interactive_${uart_number}_${key}
741 prompts: ['${prompts}']
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500742 script:
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500743EOF
744
745 if [ -z "${commands}" ]; then
746 cat <<EOF
747 - name: interactive_command_${uart_number}_${key}
748 command:
749EOF
750 else
751 for c in ${commands}; do
752 cat <<EOF
753 - name: interactive_command_${uart_number}_${key}
Paul Sokolovskydf445242021-12-15 16:57:51 +0300754 command: "$c"
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500755EOF
756 done
757 fi
758 cat << EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500759 successes:
760EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500761 for s in ${successes}; do
762 cat <<EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500763 - message: '$s'
764EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500765 done
766
767 elif [[ -n "${prompts}" && -n "${failures}" ]]; then
768 cat << EOF
769 - name: interactive_${uart_number}_${key}
770 prompts: ['${prompts}']
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500771 script:
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500772EOF
773 if [ -z "${commands}" ]; then
774 cat <<EOF
775 - name: interactive_command_${uart_number}_${key}
776 command:
777EOF
778 else
779 for c in ${commands}; do
780 cat <<EOF
781 - name: interactive_command_${uart_number}_${key}
Paul Sokolovskydf445242021-12-15 16:57:51 +0300782 command: "$c"
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500783EOF
784 done
785 fi
786 cat << EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500787 failures:
788EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500789 for f in ${failures}; do
790 cat <<EOF
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500791 - message: '$f'
792EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500793 done
794 else
795 cat << EOF
796 - name: interactive_${uart_number}_${key}
797 prompts: ['${prompts}']
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500798 script:
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500799EOF
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500800 if [ -z "${commands}" ]; then
801 cat <<EOF
802 - name: interactive_command_${uart_number}_${key}
803 command:
804EOF
805 else
806 for c in ${commands}; do
807 cat <<EOF
808 - name: interactive_command_${uart_number}_${key}
Paul Sokolovskydf445242021-12-15 16:57:51 +0300809 command: "$c"
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500810EOF
811 done
812 fi
813 fi
814
815 IFS=$OLD_IFS
816 fi # end of interactive action
817
818 done # end of expect loop
819
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500820 fi
Leonardo Sandoval5cfc11f2021-09-08 16:08:13 -0500821 done # end of uart loop
Leonardo Sandovalcd06bf42021-04-08 11:53:39 -0500822}
823
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500824docker_registry_append() {
825 # if docker_registry is empty, just use local docker registry
826 [ -z "$docker_registry" ] && return
827
828 local last=-1
829 local last_char="${docker_registry:last}"
830
831 if [ "$last_char" != '/' ]; then
832 docker_registry="${docker_registry}/";
833 fi
834 echo "$docker_registry"
835}
836
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000837# generate GPT image and archive it
838gen_gpt_bin() {
839 raw_image="fip_gpt.bin"
840 img_uuid="FB90808A-BA9A-4D42-B9A2-A7A937144AEE"
841 img_bank_uuid=`uuidgen`
842 disk_uuid=`uuidgen`
843 bin="${1:?}"
844
845 # maximum FIP size 2MB
846 fip_max_size=2097152
847 start_sector=34
848 sector_size=512
849 num_sectors=$(($fip_max_size/$sector_size))
850 bin_size=$(stat -c %s $bin)
851
852 if [[ $fip_max_size -lt $bin_size ]]
853 then
854 echo "FIP binary ($bin_size bytes) larger than max partition 1"
855 "size ($fip_max_size byte)"
856 return
857 fi
858
859 # create raw 5MB image
860 dd if=/dev/zero of=$raw_image bs=5M count=1
861
862 # create GPT image
863 sgdisk -a 1 -U $disk_uuid -n 1:$start_sector:+$num_sectors \
864 -c 1:FIP_A -t 1:$img_uuid $raw_image -u $img_bank_uuid
865
866 echo "write binary $bin at sector $start_sector"
867 dd if=$bin of=$raw_image bs=$sector_size seek=$start_sector \
868 count=$num_sectors conv=notrunc
869
870 archive_file "fip_gpt.bin"
871}
872
Fathi Boudra422bf772019-12-02 11:10:16 +0200873set +u