blob: dd0ac8ff910005c857ea08baeed6ed591ab5c6b1 [file] [log] [blame]
Leonardo Sandoval9dfdd1b2020-08-06 17:08:11 -05001#!/usr/bin/env bash
Fathi Boudra422bf772019-12-02 11:10:16 +02002#
Harrison Mutaie5122542023-03-27 13:14:18 +01003# Copyright (c) 2020-2023, 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
J-Alves12d796c2023-02-27 10:30:58 +000028export spm_secure_out_dir="${spm_secure_out_dir:-secure_aem_v8a_fvp_vhe_clang}"
29export spm_non_secure_out_dir="${spm_non_secure_out_dir:-aem_v8a_fvp_vhe_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
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +010036uefi_downloads="${uefi_downloads:-http://files.oss.arm.com/downloads/uefi}"
37uefi_ci_bin_url="${uefi_ci_bin_url:-$uefi_downloads/Artifacts/Linux/github/fvp/static/DEBUG_GCC5/FVP_AARCH64_EFI.fd}"
38
Fathi Boudra422bf772019-12-02 11:10:16 +020039uboot32_fip_url="$linaro_release/fvp32-latest-busybox-uboot/fip.bin"
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +010040uboot_url="$linaro_release/fvp-latest-busybox-uboot/bl33-uboot.bin"
Fathi Boudra422bf772019-12-02 11:10:16 +020041
Alexei Fedorove405cc32020-09-30 18:13:55 +010042rootfs_url="$linaro_release/lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz"
Fathi Boudra422bf772019-12-02 11:10:16 +020043
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050044# Default FVP model variables
Leonardo Sandovale1460662021-05-27 16:05:38 -050045default_model_dtb="dtb.bin"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050046
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060047# FVP containers and model paths
laurenw-arm35faeaa2021-05-03 14:28:17 -050048fvp_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}"
laurenw-armafdc3bc2022-09-14 15:31:42 -050049fvp_arm_std_library_11_16="fvp:fvp_arm_std_library_${model_version_11_16}_${model_build_11_16};/opt/model/FVP_ARM_Std_Library/FVP_Base"
50fvp_arm_std_library_11_17="fvp:fvp_arm_std_library_${model_version_11_17}_${model_build_11_17};/opt/model/FVP_ARM_Std_Library/FVP_Base"
Maksims Svecovs284a50d2021-11-02 11:09:47 +000051fvp_arm_std_library="fvp:fvp_arm_std_library_${model_version}_${model_build};/opt/model/FVP_ARM_Std_Library/FVP_Base"
laurenw-armafdc3bc2022-09-14 15:31:42 -050052fvp_base_aemva="fvp:fvp_base_aemva_${model_version}_${model_build};/opt/model/FVP_Base_AEMvA/models/${model_flavour}"
laurenw-armf414aba2021-04-26 15:58:56 -050053fvp_base_revc_2xaemva="fvp:fvp_base_revc-2xaemva_${model_version}_${model_build};/opt/model/Base_RevC_AEMvA_pkg/models/${model_flavour}"
laurenw-armafdc3bc2022-09-14 15:31:42 -050054fvp_base_aemv8a_gic600ae="fvp:fvp_base_aemv8a-gic600ae_${model_version_11_17}_${model_build_11_17};/opt/model/FVP_Base_AEMv8A-GIC600AE_pkg/models/${model_flavour_11_17}"
55fvp_base_aemv8a_aemv8a_aemv8a_aemv8a_ccn502="fvp:fvp_base_aemv8a-aemv8a-aemv8a-aemv8a-ccn502_${model_version_11_17}_${model_build_11_17};/opt/model/FVP_Base_AEMv8A-AEMv8A-AEMv8A-AEMv8A-CCN502_pkg/models/${model_flavour_11_17}"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060056foundation_platform="fvp:foundation_platform_${model_version}_${model_build};/opt/model/Foundation_Platformpkg/models/${model_flavour}"
johpow01936638d2021-11-08 18:22:24 -060057fvp_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 -050058
Manish V Badarkhef65f9a32022-11-04 10:07:19 +000059# CSS model list
60fvp_morello="fvp:fvp_morello_0.11_33;/opt/model/FVP_Morello/models/Linux64_GCC-6.4"
61fvp_rd_e1_edge="fvp:fvp_rd_e1_edge_11.17_29;/opt/model/FVP_RD_E1_edge/models/${model_flavour}"
62fvp_rd_n1_edge="fvp:fvp_rd_n1_edge_11.17_29;/opt/model/FVP_RD_N1_edge/models/${model_flavour}"
63fvp_rd_v1="fvp:fvp_rd_v1_11.17_29;/opt/model/FVP_RD_V1/models/${model_flavour}"
64fvp_tc0="fvp:fvp_tc0_11.17_18;/opt/model/FVP_TC0/models/${model_flavour}"
65fvp_tc1="fvp:fvp_tc1_11.17_33;/opt/model/FVP_TC1/models/${model_flavour}"
Manish V Badarkhec6e8e1d2023-03-18 10:25:53 +000066fvp_tc2="fvp:fvp_tc2_11.20_24;/opt/model/FVP_TC2/models/${model_flavour}"
Manish V Badarkhef65f9a32022-11-04 10:07:19 +000067
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060068# FVP associate array, run_config are keys and fvp container parameters are the values
69# Container parameters syntax: <model name>;<model dir>;<model bin>
70# FIXMEs: fix those ;;; values with real values
71
72declare -A fvp_models
73fvp_models=(
Manish V Badarkhe253a1602022-11-09 09:22:44 +000074[base-aemv8a-quad]="${fvp_base_aemv8a_aemv8a_aemv8a_aemv8a_ccn502};FVP_Base_AEMv8A-AEMv8A-AEMv8A-AEMv8A-CCN502"
laurenw-armafdc3bc2022-09-14 15:31:42 -050075[base-aemv8a-revb]="${fvp_arm_std_library};FVP_Base_AEMvA-AEMvA"
76[base-aemv8a-latest-revb]="${fvp_arm_std_library};FVP_Base_AEMvA-AEMvA"
Manish V Badarkhe253a1602022-11-09 09:22:44 +000077[base-aemva]="${fvp_base_aemva};FVP_Base_AEMvA"
78[base-aemv8a-gic600ae]="${fvp_base_aemv8a_gic600ae};FVP_Base_AEMv8A-GIC600AE"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060079[foundationv8]="${foundation_platform};Foundation_Platform"
laurenw-armf414aba2021-04-26 15:58:56 -050080[base-aemv8a]="${fvp_base_revc_2xaemva};FVP_Base_RevC-2xAEMvA"
laurenw-arm35faeaa2021-05-03 14:28:17 -050081[cortex-a32x4]="${fvp_arm_std_library_11_12};FVP_Base_Cortex-A32x4"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060082[cortex-a35x4]="${fvp_arm_std_library};FVP_Base_Cortex-A35x4"
83[cortex-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A53x4"
laurenw-armafdc3bc2022-09-14 15:31:42 -050084[cortex-a55x4]="${fvp_arm_std_library};FVP_Base_Cortex-A55"
Leonardo Sandoval95f896b2021-02-22 10:16:29 -060085[cortex-a55x4-a75x4]="${fvp_arm_std_library};FVP_Base_Cortex-A55x4+Cortex-A75x4"
86[cortex-a55x4-a76x2]="${fvp_arm_std_library};FVP_Base_Cortex-A55x4+Cortex-A76x2"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060087[cortex-a57x1-a53x1]="${fvp_arm_std_library};FVP_Base_Cortex-A57x1-A53x1"
88[cortex-a57x2-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x2-A53x4"
89[cortex-a57x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x4"
90[cortex-a57x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x4-A53x4"
laurenw-armafdc3bc2022-09-14 15:31:42 -050091[cortex-a65aex8]="${fvp_arm_std_library};FVP_Base_Cortex-A65AE"
92[cortex-a65x4]="${fvp_arm_std_library};FVP_Base_Cortex-A65"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060093[cortex-a72x4]="${fvp_arm_std_library};FVP_Base_Cortex-A72x4"
94[cortex-a72x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A72x4-A53x4"
95[cortex-a73x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73x4"
96[cortex-a73x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73x4-A53x4"
laurenw-armafdc3bc2022-09-14 15:31:42 -050097[cortex-a75x4]="${fvp_arm_std_library};FVP_Base_Cortex-A75"
98[cortex-a76aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A76AE"
99[cortex-a76aex2]="${fvp_arm_std_library};FVP_Base_Cortex-A76AE"
100[cortex-a76x4]="${fvp_arm_std_library};FVP_Base_Cortex-A76"
101[cortex-a77x4]="${fvp_arm_std_library};FVP_Base_Cortex-A77"
102[cortex-a78x4]="${fvp_arm_std_library};FVP_Base_Cortex-A78"
Juan Pablo Conded52a4752023-03-21 14:52:10 -0500103[cortex-a78aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A78AE"
laurenw-armafdc3bc2022-09-14 15:31:42 -0500104[cortex-a78cx4]="${fvp_arm_std_library};FVP_Base_Cortex-A78C"
105[cortex-x2]="${fvp_arm_std_library_11_17};FVP_Base_Cortex-X2x4"
106[cortex-a710]="${fvp_arm_std_library_11_17};FVP_Base_Cortex-A710x4"
107[neoverse_e1x1]="${fvp_arm_std_library};FVP_Base_Neoverse-E1"
108[neoverse_e1x2]="${fvp_arm_std_library};FVP_Base_Neoverse-E1"
109[neoverse_e1x4]="${fvp_arm_std_library};FVP_Base_Neoverse-E1"
110[neoverse_n1]="${fvp_arm_std_library};FVP_Base_Neoverse-N1"
111[neoverse_n2]="${fvp_arm_std_library_11_16};FVP_Base_Neoverse-N1x4"
112[neoverse-v1x4]="${fvp_arm_std_library};FVP_Base_Neoverse-V1"
Manish V Badarkhef65f9a32022-11-04 10:07:19 +0000113[morello]="${fvp_morello};FVP_Morello"
114[css-rde1edge]="${fvp_rd_e1_edge};FVP_RD_E1_edge"
115[css-rdn1edgex2]="${fvp_rd_n1_edge};FVP_RD_N1_edge_dual"
116[css-rdv1]="${fvp_rd_v1};FVP_RD_V1"
117[tc0]="${fvp_tc0};FVP_TC0"
118[tc1]="${fvp_tc1};FVP_TC1"
119[tc2]="${fvp_tc2};FVP_TC2"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600120)
121
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500122
Fathi Boudra422bf772019-12-02 11:10:16 +0200123# FVP Kernel URLs
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +0100124declare -A kernel_list
125kernel_list=(
Fathi Boudra422bf772019-12-02 11:10:16 +0200126[fvp-aarch32-zimage]="$linaro_release/fvp32-latest-busybox-uboot/Image"
127[fvp-busybox-uboot]="$linaro_release/fvp-latest-busybox-uboot/Image"
128[fvp-oe-uboot32]="$linaro_release/fvp32-latest-oe-uboot/Image"
129[fvp-oe-uboot]="$linaro_release/fvp-latest-oe-uboot/Image"
130[fvp-quad-busybox-uboot]="$tfa_downloads/quad_cluster/Image"
131)
132
Fathi Boudra422bf772019-12-02 11:10:16 +0200133# FVP initrd URLs
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +0100134declare -A initrd_list
135initrd_list=(
Fathi Boudra422bf772019-12-02 11:10:16 +0200136[aarch32-ramdisk]="$linaro_release/fvp32-latest-busybox-uboot/ramdisk.img"
Fathi Boudra422bf772019-12-02 11:10:16 +0200137[dummy-ramdisk]="$linaro_release/fvp-latest-oe-uboot/ramdisk.img"
138[dummy-ramdisk32]="$linaro_release/fvp32-latest-oe-uboot/ramdisk.img"
139[default]="$linaro_release/fvp-latest-busybox-uboot/ramdisk.img"
140)
141
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100142# For Measured Boot tests using a TA based on OPTEE, it is necessary to use a
143# specific build rather than the default one generated by Jenkins.
144get_ftpm_optee_bin() {
Javier Almansa Sobrinode647722020-10-08 19:17:44 +0100145 url="$tfa_downloads/ftpm/optee/tee-header_v2.bin" \
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100146 saveas="bl32.bin" fetch_file
147 archive_file "bl32.bin"
148
Javier Almansa Sobrinode647722020-10-08 19:17:44 +0100149 url="$tfa_downloads/ftpm/optee/tee-pager_v2.bin" \
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100150 saveas="bl32_extra1.bin" fetch_file
151 archive_file "bl32_extra1.bin"
152
Leonardo Sandovalda5f78d2021-03-18 11:09:30 -0600153 # tee-pageable_v2.bin is just a empty file, named as bl32_extra2.bin,
154 # so just create the file
155 touch "bl32_extra2.bin"
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100156 archive_file "bl32_extra2.bin"
157}
158
Fathi Boudra422bf772019-12-02 11:10:16 +0200159get_dtb() {
160 local dtb_type="${dtb_type:?}"
161 local dtb_url
162 local dtb_saveas="$workspace/dtb.bin"
Zelalem219df412020-05-17 19:21:20 -0500163 local cc="$(get_tf_opt CROSS_COMPILE)"
164 local pp_flags="-P -nostdinc -undef -x assembler-with-cpp"
Fathi Boudra422bf772019-12-02 11:10:16 +0200165
166 case "$dtb_type" in
167 "fvp-base-quad-cluster-gicv3-psci")
168 # Get the quad-cluster FDT from pdsw area
169 dtb_url="$tfa_downloads/quad_cluster/fvp-base-quad-cluster-gicv3-psci.dtb"
170 url="$dtb_url" saveas="$dtb_saveas" fetch_file
171 ;;
Fathi Boudra422bf772019-12-02 11:10:16 +0200172 *)
Zelalem219df412020-05-17 19:21:20 -0500173 # Preprocess DTS file
174 ${cc}gcc -E ${pp_flags} -I"$tf_root/fdts" -I"$tf_root/include" \
175 -o "$workspace/${dtb_type}.pre.dts" \
176 "$tf_root/fdts/${dtb_type}.dts"
177 # Generate DTB file from DTS
Fathi Boudra422bf772019-12-02 11:10:16 +0200178 dtc -I dts -O dtb \
Zelalem219df412020-05-17 19:21:20 -0500179 "$workspace/${dtb_type}.pre.dts" -o "$dtb_saveas"
Fathi Boudra422bf772019-12-02 11:10:16 +0200180 esac
181
182 archive_file "$dtb_saveas"
183}
184
185get_rootfs() {
186 local tmpdir
187 local fs_base="$(echo $(basename $rootfs_url) | sed 's/\.gz$//')"
188 local cached="$project_filer/ci-files/$fs_base"
189
190 if upon "$jenkins_run" && [ -f "$cached" ]; then
191 # Job workspace is limited in size, and the root file system is
192 # quite large. This means, parallel runs of root file system
193 # tests could fail. So, for Jenkins runs, copy and use the root
194 # file system image from the $CI_SCRATCH location
195 local private="$CI_SCRATCH/$JOB_NAME-$BUILD_NUMBER"
196 mkdir -p "$private"
197 rm -f "$private/rootfs.bin"
198 url="$cached" saveas="$private/rootfs.bin" fetch_file
199 ln -s "$private/rootfs.bin" "$archive/rootfs.bin"
200 return
201 fi
202
203 tmpdir="$(mktempdir)"
204 pushd "$tmpdir"
205 url="$rootfs_url" saveas="rootfs.bin" fetch_file
206
207 # Possibly, the filesystem image we just downloaded is compressed.
208 # Decompress it if required.
209 if file "rootfs.bin" | grep -iq 'gzip compressed data'; then
210 echo "Decompressing root file system image rootfs.bin ..."
211 gunzip --stdout "rootfs.bin" > uncompressed_fs.bin
212 mv uncompressed_fs.bin "rootfs.bin"
213 fi
214
215 archive_file "rootfs.bin"
216 popd
217}
218
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200219fvp_romlib_jmptbl_backup="$(mktempdir)/jmptbl.i"
220
Fathi Boudra422bf772019-12-02 11:10:16 +0200221fvp_romlib_runtime() {
222 local tmpdir="$(mktempdir)"
223
224 # Save BL1 and romlib binaries from original build
225 mv "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin" "$tmpdir/romlib.bin"
226 mv "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin" "$tmpdir/bl1.bin"
227
228 # Patch index file
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200229 cp "${tf_root:?}/plat/arm/board/fvp/jmptbl.i" "$fvp_romlib_jmptbl_backup"
230 sed -i '/fdt/ s/.$/&\ patch/' ${tf_root:?}/plat/arm/board/fvp/jmptbl.i
Fathi Boudra422bf772019-12-02 11:10:16 +0200231
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200232 # Rebuild with patched file
233 echo "Building patched romlib:"
234 build_tf
Fathi Boudra422bf772019-12-02 11:10:16 +0200235
Fathi Boudra422bf772019-12-02 11:10:16 +0200236 # Retrieve original BL1 and romlib binaries
237 mv "$tmpdir/romlib.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin"
238 mv "$tmpdir/bl1.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin"
239}
240
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200241fvp_romlib_cleanup() {
242 # Restore original index
243 mv "$fvp_romlib_jmptbl_backup" "${tf_root:?}/plat/arm/board/fvp/jmptbl.i"
244}
245
246
Chris Kayc9523b12022-10-10 18:32:20 +0100247# Generates the final YAML-based LAVA job definition from a template file.
248#
249# The job definition template is expanded with visibility of all variables that
250# are available from within the function, including those with local scope.
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500251gen_fvp_yaml() {
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600252 local model="${model:?}"
253
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500254 local yaml_template_file="$workspace/fvp_template.yaml"
255 local yaml_file="$workspace/fvp.yaml"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500256 local yaml_job_file="$workspace/job.yaml"
257 local lava_model_params="$workspace/lava_model_params"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500258
Leonardo Sandovalfda4f292020-10-06 15:59:26 -0500259 # this function expects a template, quit if it is not present
260 if [ ! -f "$yaml_template_file" ]; then
Paul Sokolovskya3c5a4c2023-01-24 18:33:58 +0700261 echo "warning: gen_fvp_yaml: template $yaml_template_file not available, skipping generating LAVA job"
Leonardo Sandovalfda4f292020-10-06 15:59:26 -0500262 return
263 fi
264
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600265 local model_params="${fvp_models[$model]}"
266 local model_name="$(echo "${model_params}" | awk -F ';' '{print $1}')"
267 local model_dir="$(echo "${model_params}" | awk -F ';' '{print $2}')"
268 local model_bin="$(echo "${model_params}" | awk -F ';' '{print $3}')"
269
270 # model params are required for correct yaml creation, quit if empty
271 if [ -z "${model_name}" ]; then
272 echo "FVP model param 'model_name' variable empty, yaml not produced"
273 return
274 elif [ -z "${model_dir}" ]; then
275 echo "FVP model param 'model_dir' variable empty, yaml not produced"
276 return
277 elif [ -z "${model_bin}" ]; then
278 echo "FVP model param 'model_bin' variable empty, yaml not produced"
279 return
280 fi
281
282 echo "FVP model params: model_name=$model_name model_dir=$model_dir model_bin=$model_bin"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500283
284 # optional parameters, defaults to globals
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500285 local model_dtb="${model_dtb:-$default_model_dtb}"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500286
Chris Kayc9523b12022-10-10 18:32:20 +0100287 if [ -n "${GERRIT_CHANGE_NUMBER}" ]; then
288 local gerrit_url="https://review.trustedfirmware.org/c/${GERRIT_CHANGE_NUMBER}/${GERRIT_PATCHSET_NUMBER}"
289 elif [ -n "${GERRIT_REFSPEC}" ]; then
290 local gerrit_url=$(echo ${GERRIT_REFSPEC} |
291 awk -F/ '{print "https://review.trustedfirmware.org/c/" $4 "/" $5}')
292 fi
293
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500294 docker_registry="${docker_registry:-}"
295 docker_registry="$(docker_registry_append)"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500296 docker_name="${docker_registry}$model_name"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600297 prompt1='/ #'
298 prompt2='root@genericarmv8:~#'
299 version_string="\"Fast Models"' [^\\n]+'"\""
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500300
Leonardo Sandoval5d87b702021-05-10 11:53:13 -0500301 test_config="${TEST_CONFIG}"
302
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100303 declare -A fvp_artefact_filters=(
Chris Kay4eb9ded2022-10-10 15:51:40 +0100304 [backup_fip]="backup_fip.bin"
305 [bl1]="bl1.bin"
306 [bl2]="bl2.bin"
307 [bl31]="bl31.bin"
308 [bl32]="bl32.bin"
309 [busybox]="busybox.bin"
310 [cactus_primary]="cactus-primary.pkg"
311 [cactus_secondary]="cactus-secondary.pkg"
312 [cactus_tertiary]="cactus-tertiary.pkg"
313 [coverage_trace_plugin]="coverage_trace.so"
314 [dtb]="dtb.bin"
315 [el3_payload]="el3_payload.bin"
Manish V Badarkhedbb9cb12022-11-16 12:30:41 +0000316 [ete_trace]="libete-plugin.so"
317 [etm_trace]="ETMv4ExamplePlugin.so"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100318 [fip_gpt]="fip_gpt.bin"
319 [fip]="fip.bin"
320 [fvp_spmc_manifest_dtb]="=fvp_spmc_manifest.dtb"
321 [fwu_fip]="fwu_fip.bin"
322 [generic_trace]="GenericTrace.so"
323 [hafnium]="hafnium.bin"
324 [image]="kernel.bin"
325 [ivy]="ivy.pkg"
326 [manifest_dtb]="=manifest.dtb"
Chris Kayfbdd0142022-11-08 12:24:30 +0000327 [mcp_fw]="mcp_fw.bin"
Manish V Badarkhe18c59782022-11-09 10:14:48 +0000328 [mcp_ram]="mcp_ram.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100329 [mcp_rom_hyphen]="mcp-rom.bin"
330 [mcp_rom]="mcp_rom.bin"
331 [ns_bl1u]="ns_bl1u.bin"
332 [ns_bl2u]="ns_bl2u.bin"
333 [ramdisk]="initrd.bin|initrd.img"
334 [romlib]="romlib.bin"
335 [rootfs]="rootfs.bin"
laurenw-arm60de2742023-03-08 10:50:15 -0600336 [host_flash_fip]="host_flash_fip.bin"
Manish V Badarkhe93093dd2022-11-09 10:29:27 +0000337 [rss_rom]="rss_rom.bin"
Chris Kayfbdd0142022-11-08 12:24:30 +0000338 [scp_fw]="scp_fw.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100339 [scp_ram_hyphen]="scp-ram.bin"
340 [scp_ram]="scp_ram.bin"
341 [scp_rom_hyphen]="scp-rom.bin"
342 [scp_rom]="scp_rom.bin"
343 [secure_hafnium]="secure_hafnium.bin"
344 [spm]="spm.bin"
345 [tftf]="tftf.bin"
346 [tmp]="tmp.bin"
347 [uboot]="uboot.bin"
348 )
349
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100350 declare -A fvp_artefact_urls=(
Harrison Mutaie5122542023-03-27 13:14:18 +0100351 [backup_fip]="$(gen_bin_url backup_fip.bin)"
352 [bl1]="$(gen_bin_url bl1.bin)"
353 [bl2]="$(gen_bin_url bl2.bin)"
354 [bl31]="$(gen_bin_url bl31.bin)"
355 [bl32]="$(gen_bin_url bl32.bin)"
356 [busybox]="$(gen_bin_url busybox.bin.gz)"
357 [cactus_primary]="$(gen_bin_url cactus-primary.pkg)"
358 [cactus_secondary]="$(gen_bin_url cactus-secondary.pkg)"
359 [cactus_tertiary]="$(gen_bin_url cactus-tertiary.pkg)"
Chris Kayc14743a2022-10-13 11:33:26 +0100360 [coverage_trace_plugin]="${coverage_trace_plugin}"
Harrison Mutaie5122542023-03-27 13:14:18 +0100361 [dtb]="$(gen_bin_url ${model_dtb})"
362 [el3_payload]="$(gen_bin_url el3_payload.bin)"
Manish V Badarkhedbb9cb12022-11-16 12:30:41 +0000363 [ete_trace]="${tfa_downloads}/FastModelsPortfolio_${model_version}/plugins/${model_flavour}/libete-plugin.so"
364 [etm_trace]="${tfa_downloads}/FastModelsPortfolio_${model_version}/plugins/${model_flavour}/ETMv4ExamplePlugin.so"
Harrison Mutaie5122542023-03-27 13:14:18 +0100365 [fip]="$(gen_bin_url fip.bin)"
366 [fip_gpt]="$(gen_bin_url fip_gpt.bin)"
367 [fvp_spmc_manifest_dtb]="$(gen_bin_url fvp_spmc_manifest.dtb)"
368 [fwu_fip]="$(gen_bin_url fwu_fip.bin)"
Chris Kayc14743a2022-10-13 11:33:26 +0100369 [generic_trace]="${tfa_downloads}/FastModelsPortfolio_${model_version}/plugins/${model_flavour}/GenericTrace.so"
Harrison Mutaie5122542023-03-27 13:14:18 +0100370 [hafnium]="$(gen_bin_url hafnium.bin)"
371 [image]="$(gen_bin_url kernel.bin)"
372 [ivy]="$(gen_bin_url ivy.pkg)"
373 [manifest_dtb]="$(gen_bin_url manifest.dtb)"
374 [mcp_fw]="$(gen_bin_url mcp_fw.bin)"
375 [mcp_ram]="$(gen_bin_url mcp_ram.bin)"
376 [mcp_rom]="$(gen_bin_url mcp_rom.bin)"
377 [mcp_rom_hyphen]="$(gen_bin_url mcp-rom.bin)"
378 [ns_bl1u]="$(gen_bin_url ns_bl1u.bin)"
379 [ns_bl2u]="$(gen_bin_url ns_bl2u.bin)"
380 [ramdisk]="$(gen_bin_url initrd.bin)"
381 [romlib]="$(gen_bin_url romlib.bin)"
382 [rootfs]="$(gen_bin_url rootfs.bin.gz)"
383 [host_flash_fip]="$(gen_bin_url host_flash_fip.bin)"
384 [rss_rom]="$(gen_bin_url rss_rom.bin)"
385 [secure_hafnium]="$(gen_bin_url secure_hafnium.bin)"
386 [scp_fw]="$(gen_bin_url scp_fw.bin)"
387 [scp_ram]="$(gen_bin_url scp_ram.bin)"
388 [scp_ram_hyphen]="$(gen_bin_url scp-ram.bin)"
389 [scp_rom]="$(gen_bin_url scp_rom.bin)"
390 [scp_rom_hyphen]="$(gen_bin_url scp-rom.bin)"
391 [spm]="$(gen_bin_url spm.bin)"
392 [tftf]="$(gen_bin_url tftf.bin)"
393 [tmp]="$(gen_bin_url tmp.bin)"
394 [uboot]="$(gen_bin_url uboot.bin)"
Chris Kayc14743a2022-10-13 11:33:26 +0100395 )
396
Chris Kay5d550d82022-10-12 17:20:31 +0100397 # In LAVA we don't provide the paths to the artefacts directly, but instead
398 # use macros of the form `{XYZ}`. This is a list of regular expression
399 # replacements to run on the model parameters file before we add them to the
400 # LAVA job definition.
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100401 declare -A fvp_artefact_macros=(
Chris Kay5d550d82022-10-12 17:20:31 +0100402 ["[= ]backup_fip.bin"]="={BACKUP_FIP}"
403 ["[= ]bl1.bin"]="={BL1}"
404 ["[= ]bl2.bin"]="={BL2}"
405 ["[= ]bl31.bin"]="={BL31}"
406 ["[= ]bl32.bin"]="={BL32}"
407 ["[= ]cactus-primary.pkg"]="={CACTUS_PRIMARY}"
408 ["[= ]cactus-secondary.pkg"]="={CACTUS_SECONDARY}"
409 ["[= ]cactus-tertiary.pkg"]="={CACTUS_TERTIARY}"
410 ["[= ].*coverage_trace.so"]="={COVERAGE_TRACE_PLUGIN}"
411 ["[= ]fvp_spmc_manifest.dtb"]="={FVP_SPMC_MANIFEST_DTB}"
412 ["[= ]busybox.bin"]="={BUSYBOX}"
413 ["[= ]dtb.bin"]="={DTB}"
414 ["[= ]el3_payload.bin"]="={EL3_PAYLOAD}"
Manish V Badarkhedbb9cb12022-11-16 12:30:41 +0000415 ["[= ].*libete-plugin.so"]="={ETE_TRACE}"
416 ["[= ].*ETMv4ExamplePlugin.so"]="={ETM_TRACE}"
Chris Kay5d550d82022-10-12 17:20:31 +0100417 ["[= ]fip_gpt.bin"]="={FIP_GPT}"
418 ["[= ]fwu_fip.bin"]="={FWU_FIP}"
419 ["[= ]fip.bin"]="={FIP}"
420 ["[= ].*GenericTrace.so"]="={GENERIC_TRACE}"
421 ["[= ].*/hafnium.bin"]="={HAFNIUM}"
422 ["[= ]kernel.bin"]="={IMAGE}"
423 ["[= ]ivy.pkg"]="={IVY}"
424 ["[= ]manifest.dtb"]="={MANIFEST_DTB}"
Chris Kayfbdd0142022-11-08 12:24:30 +0000425 ["[= ]mcp_fw.bin"]="={MCP_FW}"
Manish V Badarkhe18c59782022-11-09 10:14:48 +0000426 ["[= ]mcp_ram.bin"]="={MCP_RAM}"
Chris Kayef9cc802022-11-08 12:11:58 +0000427 ["[= ]mcp_rom.bin"]="={MCP_ROM}"
428 ["[= ]mcp-rom.bin"]="={MCP_ROM_HYPHEN}"
Chris Kay5d550d82022-10-12 17:20:31 +0100429 ["[= ]ns_bl1u.bin"]="={NS_BL1U}"
430 ["[= ]ns_bl2u.bin"]="={NS_BL2U}"
431 ["[= ]initrd.bin"]="={RAMDISK}"
432 ["[= ]initrd.img"]="={RAMDISK}"
433 ["[= ]romlib.bin"]="={ROMLIB}"
434 ["[= ]rootfs.bin"]="={ROOTFS}"
laurenw-arm60de2742023-03-08 10:50:15 -0600435 ["[= ]host_flash_fip.bin"]="={HOST_FLASH_FIP}"
Manish V Badarkhe93093dd2022-11-09 10:29:27 +0000436 ["[= ]rss_rom.bin"]="={RSS_ROM}"
Chris Kay5d550d82022-10-12 17:20:31 +0100437 ["[= ].*/secure_hafnium.bin"]="={SECURE_HAFNIUM}"
Chris Kayfbdd0142022-11-08 12:24:30 +0000438 ["[= ]scp_fw.bin"]="={SCP_FW}"
Chris Kay5d550d82022-10-12 17:20:31 +0100439 ["[= ]scp_ram.bin"]="={SCP_RAM}"
440 ["[= ]scp-ram.bin"]="={SCP_RAM_HYPHEN}"
441 ["[= ]scp_rom.bin"]="={SCP_ROM}"
442 ["[= ]scp-rom.bin"]="={SCP_ROM_HYPHEN}"
443 ["[= ]spm.bin"]="={SPM}"
444 ["[= ]tftf.bin"]="={TFTF}"
445 ["[= ].*/tmp.bin"]="={TMP}"
446 ["[= ]uboot.bin"]="={UBOOT}"
447 )
448
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100449 declare -a fvp_artefacts
450 filter_artefacts fvp_artefacts fvp_artefact_filters
Chris Kay4eb9ded2022-10-10 15:51:40 +0100451
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100452 lava_model_params="${lava_model_params}" \
453 gen_lava_model_params fvp_artefact_macros
Leonardo Sandovalbe690bd2020-10-12 17:59:39 -0500454
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100455 yaml_template_file="$yaml_template_file" \
456 yaml_file="$yaml_file" \
457 yaml_job_file="$yaml_job_file" \
458 gen_lava_job_def fvp_artefacts fvp_artefact_urls
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500459}
460
461docker_registry_append() {
462 # if docker_registry is empty, just use local docker registry
463 [ -z "$docker_registry" ] && return
464
465 local last=-1
466 local last_char="${docker_registry:last}"
467
468 if [ "$last_char" != '/' ]; then
469 docker_registry="${docker_registry}/";
470 fi
471 echo "$docker_registry"
472}
473
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000474# generate GPT image and archive it
475gen_gpt_bin() {
476 raw_image="fip_gpt.bin"
477 img_uuid="FB90808A-BA9A-4D42-B9A2-A7A937144AEE"
478 img_bank_uuid=`uuidgen`
479 disk_uuid=`uuidgen`
480 bin="${1:?}"
481
482 # maximum FIP size 2MB
483 fip_max_size=2097152
484 start_sector=34
485 sector_size=512
486 num_sectors=$(($fip_max_size/$sector_size))
487 bin_size=$(stat -c %s $bin)
488
489 if [[ $fip_max_size -lt $bin_size ]]
490 then
Manish V Badarkhe3640b062022-11-16 11:36:36 +0000491 echo "FIP binary ($bin_size bytes) larger than max partition 1" \
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000492 "size ($fip_max_size byte)"
493 return
494 fi
495
496 # create raw 5MB image
497 dd if=/dev/zero of=$raw_image bs=5M count=1
498
499 # create GPT image
500 sgdisk -a 1 -U $disk_uuid -n 1:$start_sector:+$num_sectors \
501 -c 1:FIP_A -t 1:$img_uuid $raw_image -u $img_bank_uuid
502
503 echo "write binary $bin at sector $start_sector"
504 dd if=$bin of=$raw_image bs=$sector_size seek=$start_sector \
505 count=$num_sectors conv=notrunc
506
507 archive_file "fip_gpt.bin"
508}
509
Fathi Boudra422bf772019-12-02 11:10:16 +0200510set +u