blob: d1b829616328362017cd9c0abf151415cf8e8397 [file] [log] [blame]
Leonardo Sandoval9dfdd1b2020-08-06 17:08:11 -05001#!/usr/bin/env bash
Fathi Boudra422bf772019-12-02 11:10:16 +02002#
Govindraj Raja1d208f72025-02-11 12:20:32 -06003# Copyright (c) 2020-2025, 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}"
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +000018boot_script_addr="${boot_script_addr:-0x8fb00000}"
Fathi Boudra422bf772019-12-02 11:10:16 +020019el3_payload_addr="${el3_payload_addr:-0x80000000}"
20
Manish Pandey3c435582020-07-15 12:14:26 +010021# SPM requires following addresses for RESET_TO_BL31 case
22spm_addr="${spm_addr:-0x6000000}"
23spmc_manifest_addr="${spmc_addr:-0x0403f000}"
24sp1_addr="${sp1_addr:-0x7000000}"
25sp2_addr="${sp2_addr:-0x7100000}"
Olivier Deprez0b834092020-08-21 08:36:01 +020026sp3_addr="${sp3_addr:-0x7200000}"
Olivier Deprezdd9ed332021-07-02 12:07:17 +020027sp4_addr="${sp4_addr:-0x7600000}"
Manish Pandey1e7be852020-11-09 16:04:48 +000028# SPM out directories
J-Alves12d796c2023-02-27 10:30:58 +000029export spm_secure_out_dir="${spm_secure_out_dir:-secure_aem_v8a_fvp_vhe_clang}"
30export spm_non_secure_out_dir="${spm_non_secure_out_dir:-aem_v8a_fvp_vhe_clang}"
Manish Pandey3c435582020-07-15 12:14:26 +010031
Fathi Boudra422bf772019-12-02 11:10:16 +020032ns_bl1u_addr="${ns_bl1u_addr:-0x0beb8000}"
33fwu_fip_addr="${fwu_fip_addr:-0x08400000}"
34backup_fip_addr="${backup_fip_addr:-0x09000000}"
35romlib_addr="${romlib_addr:-0x03ff2000}"
36
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +010037uefi_downloads="${uefi_downloads:-http://files.oss.arm.com/downloads/uefi}"
38uefi_ci_bin_url="${uefi_ci_bin_url:-$uefi_downloads/Artifacts/Linux/github/fvp/static/DEBUG_GCC5/FVP_AARCH64_EFI.fd}"
39
Fathi Boudra422bf772019-12-02 11:10:16 +020040uboot32_fip_url="$linaro_release/fvp32-latest-busybox-uboot/fip.bin"
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +000041if [[ "$test_config" == *handoff* ]]; then
Harrison Mutai6eb2c7f2025-05-06 10:01:11 +000042 optee_path=$tfa_downloads/optee/handoff/4.6.0
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +000043 uboot_url="${tfa_downloads}/handoff/fvp/u-boot.bin"
44else
Harrison Mutai6eb2c7f2025-05-06 10:01:11 +000045 optee_version="4.5.0"
46
47 optee_path=$tfa_downloads/optee/${optee_version}
Harrison Mutai00a29472024-11-04 10:16:31 +000048 uboot_url="${tfa_downloads}/linux_boot/fvp/u-boot.bin"
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +000049fi
50uboot_script_url="${tfa_downloads}/linux_boot/fvp/boot.scr"
Fathi Boudra422bf772019-12-02 11:10:16 +020051
Harrison Mutai00a29472024-11-04 10:16:31 +000052rootfs_url="${tfa_downloads}/linux_boot/fvp/rootfs.ext4"
Fathi Boudra422bf772019-12-02 11:10:16 +020053
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050054# Default FVP model variables
Leonardo Sandovale1460662021-05-27 16:05:38 -050055default_model_dtb="dtb.bin"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050056
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060057# FVP containers and model paths
Maksims Svecovs284a50d2021-11-02 11:09:47 +000058fvp_arm_std_library="fvp:fvp_arm_std_library_${model_version}_${model_build};/opt/model/FVP_ARM_Std_Library/FVP_Base"
Govindraj Raja7d80d932025-06-30 14:25:38 -050059fvp_base_revc_2xaemva="fvp:fvp_base_revc-2xaemva_${model_version}_${model_build}_linux64;/opt/model/Base_RevC_AEMvA_pkg/models/${model_flavour}"
johpow01936638d2021-11-08 18:22:24 -060060fvp_base_aemv8r="fvp:fvp_base_aemv8r_${model_version}_${model_build};/opt/model/AEMv8R_base_pkg/models/${model_flavour}"
Govindraj Rajafa86cf62025-02-19 14:55:48 -060061fvp_rd_1_ae="fvp:fvp_rd_1_ae_${model_version}_${model_build};/opt/model/FVP_RD_1_AE/models/${model_flavour}"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -050062
Manish V Badarkhef65f9a32022-11-04 10:07:19 +000063# CSS model list
Govindraj Rajafa86cf62025-02-19 14:55:48 -060064fvp_tc4="fvp:fvp_tc4_${model_version}_${model_build};/opt/model/FVP_TC4/models/${model_flavour}"
Manish V Badarkhef65f9a32022-11-04 10:07:19 +000065
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060066# FVP associate array, run_config are keys and fvp container parameters are the values
67# Container parameters syntax: <model name>;<model dir>;<model bin>
68# FIXMEs: fix those ;;; values with real values
69
70declare -A fvp_models
71fvp_models=(
laurenw-armafdc3bc2022-09-14 15:31:42 -050072[base-aemv8a-revb]="${fvp_arm_std_library};FVP_Base_AEMvA-AEMvA"
Manish Pandeya60d8072024-03-11 09:58:53 +000073[base-aemva]="${fvp_base_revc_2xaemva};FVP_Base_RevC-2xAEMvA"
laurenw-armf414aba2021-04-26 15:58:56 -050074[base-aemv8a]="${fvp_base_revc_2xaemva};FVP_Base_RevC-2xAEMvA"
Govindraj Rajafa86cf62025-02-19 14:55:48 -060075[cortex-a32x4]="${fvp_arm_std_library};FVP_Base_Cortex-A32"
76[cortex-a35x4]="${fvp_arm_std_library};FVP_Base_Cortex-A35"
77[cortex-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A53"
laurenw-armafdc3bc2022-09-14 15:31:42 -050078[cortex-a55x4]="${fvp_arm_std_library};FVP_Base_Cortex-A55"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060079[cortex-a57x1-a53x1]="${fvp_arm_std_library};FVP_Base_Cortex-A57x1-A53x1"
80[cortex-a57x2-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x2-A53x4"
Govindraj Rajafa86cf62025-02-19 14:55:48 -060081[cortex-a57x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060082[cortex-a57x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x4-A53x4"
Govindraj Rajafa86cf62025-02-19 14:55:48 -060083[cortex-a65aex8]="${fvp_arm_std_library};FVP_Base_Cortex-A65AE"
84[cortex-a65x4]="${fvp_arm_std_library};FVP_Base_Cortex-A65"
85[cortex-a72x4]="${fvp_arm_std_library};FVP_Base_Cortex-A72"
86[cortex-a73x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -060087[cortex-a73x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73x4-A53x4"
laurenw-armafdc3bc2022-09-14 15:31:42 -050088[cortex-a75x4]="${fvp_arm_std_library};FVP_Base_Cortex-A75"
89[cortex-a76aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A76AE"
laurenw-armafdc3bc2022-09-14 15:31:42 -050090[cortex-a76x4]="${fvp_arm_std_library};FVP_Base_Cortex-A76"
91[cortex-a77x4]="${fvp_arm_std_library};FVP_Base_Cortex-A77"
92[cortex-a78x4]="${fvp_arm_std_library};FVP_Base_Cortex-A78"
Juan Pablo Conded52a4752023-03-21 14:52:10 -050093[cortex-a78aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A78AE"
laurenw-armafdc3bc2022-09-14 15:31:42 -050094[cortex-a78cx4]="${fvp_arm_std_library};FVP_Base_Cortex-A78C"
Govindraj Raja8962c452024-06-04 14:50:28 -050095[cortex-x2]="${fvp_arm_std_library};FVP_Base_Cortex-X2"
Govindraj Raja1d208f72025-02-11 12:20:32 -060096[cortex-x4]="${fvp_arm_std_library};FVP_Base_Cortex-X4"
97[cortex-x925]="${fvp_arm_std_library};FVP_Base_Cortex-X925"
Govindraj Raja268a2be2024-07-01 14:31:31 -050098[cortex-a710x8]="${fvp_arm_std_library};FVP_Base_Cortex-A710"
Govindraj Rajafa86cf62025-02-19 14:55:48 -060099[neoverse_e1]="${fvp_arm_std_library};FVP_Base_Neoverse-E1"
laurenw-armafdc3bc2022-09-14 15:31:42 -0500100[neoverse_n1]="${fvp_arm_std_library};FVP_Base_Neoverse-N1"
Govindraj Raja8962c452024-06-04 14:50:28 -0500101[neoverse_n2]="${fvp_arm_std_library};FVP_Base_Neoverse-N2"
laurenw-armafdc3bc2022-09-14 15:31:42 -0500102[neoverse-v1x4]="${fvp_arm_std_library};FVP_Base_Neoverse-V1"
Icen Zeyadab68a5612024-11-08 07:35:44 +0000103[tc4]="${fvp_tc4};FVP_TC4"
Divin Rajb0071052023-07-04 14:35:07 +0100104[baser-aemv8r]="${fvp_base_aemv8r};FVP_BaseR_AEMv8R"
Divin Raj5eb69482024-10-02 11:36:04 +0100105[rd1ae]="${fvp_rd_1_ae};FVP_RD_1_AE"
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600106)
107
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500108
Fathi Boudra422bf772019-12-02 11:10:16 +0200109# FVP Kernel URLs
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +0100110declare -A kernel_list
111kernel_list=(
Fathi Boudra422bf772019-12-02 11:10:16 +0200112[fvp-aarch32-zimage]="$linaro_release/fvp32-latest-busybox-uboot/Image"
113[fvp-busybox-uboot]="$linaro_release/fvp-latest-busybox-uboot/Image"
114[fvp-oe-uboot32]="$linaro_release/fvp32-latest-oe-uboot/Image"
115[fvp-oe-uboot]="$linaro_release/fvp-latest-oe-uboot/Image"
116[fvp-quad-busybox-uboot]="$tfa_downloads/quad_cluster/Image"
117)
118
Fathi Boudra422bf772019-12-02 11:10:16 +0200119# FVP initrd URLs
Harrison Mutai6f4fd6c2023-03-27 13:22:41 +0100120declare -A initrd_list
121initrd_list=(
Fathi Boudra422bf772019-12-02 11:10:16 +0200122[aarch32-ramdisk]="$linaro_release/fvp32-latest-busybox-uboot/ramdisk.img"
Fathi Boudra422bf772019-12-02 11:10:16 +0200123[dummy-ramdisk]="$linaro_release/fvp-latest-oe-uboot/ramdisk.img"
124[dummy-ramdisk32]="$linaro_release/fvp32-latest-oe-uboot/ramdisk.img"
125[default]="$linaro_release/fvp-latest-busybox-uboot/ramdisk.img"
126)
127
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100128# For Measured Boot tests using a TA based on OPTEE, it is necessary to use a
129# specific build rather than the default one generated by Jenkins.
130get_ftpm_optee_bin() {
Javier Almansa Sobrinode647722020-10-08 19:17:44 +0100131 url="$tfa_downloads/ftpm/optee/tee-header_v2.bin" \
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100132 saveas="bl32.bin" fetch_file
133 archive_file "bl32.bin"
134
Javier Almansa Sobrinode647722020-10-08 19:17:44 +0100135 url="$tfa_downloads/ftpm/optee/tee-pager_v2.bin" \
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100136 saveas="bl32_extra1.bin" fetch_file
137 archive_file "bl32_extra1.bin"
138
Leonardo Sandovalda5f78d2021-03-18 11:09:30 -0600139 # tee-pageable_v2.bin is just a empty file, named as bl32_extra2.bin,
140 # so just create the file
141 touch "bl32_extra2.bin"
Javier Almansa Sobrino98de5032020-09-17 12:47:05 +0100142 archive_file "bl32_extra2.bin"
143}
144
Fathi Boudra422bf772019-12-02 11:10:16 +0200145get_dtb() {
146 local dtb_type="${dtb_type:?}"
147 local dtb_url
Boyan Karatotev802cec12025-08-01 13:07:42 +0100148 local dtb_saveas="$archive/dtb.bin"
Zelalem219df412020-05-17 19:21:20 -0500149 local cc="$(get_tf_opt CROSS_COMPILE)"
150 local pp_flags="-P -nostdinc -undef -x assembler-with-cpp"
Fathi Boudra422bf772019-12-02 11:10:16 +0200151
152 case "$dtb_type" in
153 "fvp-base-quad-cluster-gicv3-psci")
154 # Get the quad-cluster FDT from pdsw area
155 dtb_url="$tfa_downloads/quad_cluster/fvp-base-quad-cluster-gicv3-psci.dtb"
156 url="$dtb_url" saveas="$dtb_saveas" fetch_file
157 ;;
Fathi Boudra422bf772019-12-02 11:10:16 +0200158 *)
Zelalem219df412020-05-17 19:21:20 -0500159 # Preprocess DTS file
160 ${cc}gcc -E ${pp_flags} -I"$tf_root/fdts" -I"$tf_root/include" \
Boyan Karatotev802cec12025-08-01 13:07:42 +0100161 -o "$archive/${dtb_type}.pre.dts" \
Zelalem219df412020-05-17 19:21:20 -0500162 "$tf_root/fdts/${dtb_type}.dts"
163 # Generate DTB file from DTS
Fathi Boudra422bf772019-12-02 11:10:16 +0200164 dtc -I dts -O dtb \
Boyan Karatotev802cec12025-08-01 13:07:42 +0100165 "$archive/${dtb_type}.pre.dts" -o "$dtb_saveas"
Fathi Boudra422bf772019-12-02 11:10:16 +0200166 esac
167
168 archive_file "$dtb_saveas"
169}
170
171get_rootfs() {
172 local tmpdir
173 local fs_base="$(echo $(basename $rootfs_url) | sed 's/\.gz$//')"
174 local cached="$project_filer/ci-files/$fs_base"
175
176 if upon "$jenkins_run" && [ -f "$cached" ]; then
177 # Job workspace is limited in size, and the root file system is
178 # quite large. This means, parallel runs of root file system
179 # tests could fail. So, for Jenkins runs, copy and use the root
180 # file system image from the $CI_SCRATCH location
181 local private="$CI_SCRATCH/$JOB_NAME-$BUILD_NUMBER"
182 mkdir -p "$private"
183 rm -f "$private/rootfs.bin"
184 url="$cached" saveas="$private/rootfs.bin" fetch_file
185 ln -s "$private/rootfs.bin" "$archive/rootfs.bin"
186 return
187 fi
188
189 tmpdir="$(mktempdir)"
190 pushd "$tmpdir"
191 url="$rootfs_url" saveas="rootfs.bin" fetch_file
192
193 # Possibly, the filesystem image we just downloaded is compressed.
194 # Decompress it if required.
195 if file "rootfs.bin" | grep -iq 'gzip compressed data'; then
196 echo "Decompressing root file system image rootfs.bin ..."
197 gunzip --stdout "rootfs.bin" > uncompressed_fs.bin
198 mv uncompressed_fs.bin "rootfs.bin"
199 fi
200
201 archive_file "rootfs.bin"
202 popd
203}
204
205fvp_romlib_runtime() {
206 local tmpdir="$(mktempdir)"
207
208 # Save BL1 and romlib binaries from original build
209 mv "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin" "$tmpdir/romlib.bin"
210 mv "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin" "$tmpdir/bl1.bin"
211
212 # Patch index file
Boyan Karatotev32b09f92025-08-01 13:32:32 +0100213 apply_tf_patch "fvp_romlib_runtime/jmptbl_i_patch.patch"
Fathi Boudra422bf772019-12-02 11:10:16 +0200214
Sandrine Bailleux14a692d2022-06-29 15:39:42 +0200215 # Rebuild with patched file
216 echo "Building patched romlib:"
217 build_tf
Fathi Boudra422bf772019-12-02 11:10:16 +0200218
Fathi Boudra422bf772019-12-02 11:10:16 +0200219 # Retrieve original BL1 and romlib binaries
220 mv "$tmpdir/romlib.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin"
221 mv "$tmpdir/bl1.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin"
222}
223
Chris Kayc9523b12022-10-10 18:32:20 +0100224# Generates the final YAML-based LAVA job definition from a template file.
225#
226# The job definition template is expanded with visibility of all variables that
227# are available from within the function, including those with local scope.
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500228gen_fvp_yaml() {
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600229 local model="${model:?}"
230
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500231 local yaml_template_file="$workspace/fvp_template.yaml"
232 local yaml_file="$workspace/fvp.yaml"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500233 local yaml_job_file="$workspace/job.yaml"
234 local lava_model_params="$workspace/lava_model_params"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500235
Leonardo Sandovalfda4f292020-10-06 15:59:26 -0500236 # this function expects a template, quit if it is not present
237 if [ ! -f "$yaml_template_file" ]; then
Paul Sokolovskya3c5a4c2023-01-24 18:33:58 +0700238 echo "warning: gen_fvp_yaml: template $yaml_template_file not available, skipping generating LAVA job"
Leonardo Sandovalfda4f292020-10-06 15:59:26 -0500239 return
240 fi
241
Leonardo Sandoval00ced1f2020-12-07 12:55:08 -0600242 local model_params="${fvp_models[$model]}"
243 local model_name="$(echo "${model_params}" | awk -F ';' '{print $1}')"
244 local model_dir="$(echo "${model_params}" | awk -F ';' '{print $2}')"
245 local model_bin="$(echo "${model_params}" | awk -F ';' '{print $3}')"
246
247 # model params are required for correct yaml creation, quit if empty
248 if [ -z "${model_name}" ]; then
249 echo "FVP model param 'model_name' variable empty, yaml not produced"
250 return
251 elif [ -z "${model_dir}" ]; then
252 echo "FVP model param 'model_dir' variable empty, yaml not produced"
253 return
254 elif [ -z "${model_bin}" ]; then
255 echo "FVP model param 'model_bin' variable empty, yaml not produced"
256 return
257 fi
258
259 echo "FVP model params: model_name=$model_name model_dir=$model_dir model_bin=$model_bin"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500260
261 # optional parameters, defaults to globals
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500262 local model_dtb="${model_dtb:-$default_model_dtb}"
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500263
Chris Kayc9523b12022-10-10 18:32:20 +0100264 if [ -n "${GERRIT_CHANGE_NUMBER}" ]; then
265 local gerrit_url="https://review.trustedfirmware.org/c/${GERRIT_CHANGE_NUMBER}/${GERRIT_PATCHSET_NUMBER}"
266 elif [ -n "${GERRIT_REFSPEC}" ]; then
267 local gerrit_url=$(echo ${GERRIT_REFSPEC} |
268 awk -F/ '{print "https://review.trustedfirmware.org/c/" $4 "/" $5}')
269 fi
270
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500271 docker_registry="${docker_registry:-}"
272 docker_registry="$(docker_registry_append)"
Leonardo Sandoval5d90dff2020-10-12 17:59:39 -0500273 docker_name="${docker_registry}$model_name"
Leonardo Sandoval850a4862021-02-16 13:56:18 -0600274 prompt1='/ #'
275 prompt2='root@genericarmv8:~#'
276 version_string="\"Fast Models"' [^\\n]+'"\""
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500277
Leonardo Sandoval5d87b702021-05-10 11:53:13 -0500278 test_config="${TEST_CONFIG}"
279
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100280 declare -A fvp_artefact_filters=(
Chris Kay4eb9ded2022-10-10 15:51:40 +0100281 [backup_fip]="backup_fip.bin"
282 [bl1]="bl1.bin"
283 [bl2]="bl2.bin"
284 [bl31]="bl31.bin"
285 [bl32]="bl32.bin"
286 [busybox]="busybox.bin"
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +0000287 [boot_script]="boot_script.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100288 [cactus_primary]="cactus-primary.pkg"
289 [cactus_secondary]="cactus-secondary.pkg"
290 [cactus_tertiary]="cactus-tertiary.pkg"
291 [coverage_trace_plugin]="coverage_trace.so"
292 [dtb]="dtb.bin"
293 [el3_payload]="el3_payload.bin"
294 [fip_gpt]="fip_gpt.bin"
295 [fip]="fip.bin"
296 [fvp_spmc_manifest_dtb]="=fvp_spmc_manifest.dtb"
297 [fwu_fip]="fwu_fip.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100298 [hafnium]="hafnium.bin"
299 [image]="kernel.bin"
300 [ivy]="ivy.pkg"
301 [manifest_dtb]="=manifest.dtb"
Chris Kayfbdd0142022-11-08 12:24:30 +0000302 [mcp_fw]="mcp_fw.bin"
Manish V Badarkhe18c59782022-11-09 10:14:48 +0000303 [mcp_ram]="mcp_ram.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100304 [mcp_rom_hyphen]="mcp-rom.bin"
305 [mcp_rom]="mcp_rom.bin"
306 [ns_bl1u]="ns_bl1u.bin"
307 [ns_bl2u]="ns_bl2u.bin"
308 [ramdisk]="initrd.bin|initrd.img"
309 [romlib]="romlib.bin"
310 [rootfs]="rootfs.bin"
laurenw-arm60de2742023-03-08 10:50:15 -0600311 [host_flash_fip]="host_flash_fip.bin"
Divin Raj5eb69482024-10-02 11:36:04 +0100312 [rse_flash]="rse_flash.bin"
David Vinczed8ed5622024-02-23 17:00:12 +0100313 [rse_rom]="rse_rom.bin"
314 [rse_encrypted_cm_provisioning_bundle_0]="rse_encrypted_cm_provisioning_bundle_0.bin"
315 [rse_encrypted_dm_provisioning_bundle]="rse_encrypted_dm_provisioning_bundle.bin"
Chris Kayfbdd0142022-11-08 12:24:30 +0000316 [scp_fw]="scp_fw.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100317 [scp_ram_hyphen]="scp-ram.bin"
318 [scp_ram]="scp_ram.bin"
319 [scp_rom_hyphen]="scp-rom.bin"
320 [scp_rom]="scp_rom.bin"
321 [secure_hafnium]="secure_hafnium.bin"
322 [spm]="spm.bin"
Manish V Badarkhe9589d402024-01-29 16:46:41 +0000323 [tc_fitimage]="tc_fitimage.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100324 [tftf]="tftf.bin"
Harrison Mutai3ad377a2024-05-20 15:28:52 +0000325 [tl]="tl.bin"
Chris Kay4eb9ded2022-10-10 15:51:40 +0100326 [tmp]="tmp.bin"
327 [uboot]="uboot.bin"
328 )
329
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100330 declare -A fvp_artefact_urls=(
Harrison Mutaie5122542023-03-27 13:14:18 +0100331 [backup_fip]="$(gen_bin_url backup_fip.bin)"
332 [bl1]="$(gen_bin_url bl1.bin)"
333 [bl2]="$(gen_bin_url bl2.bin)"
334 [bl31]="$(gen_bin_url bl31.bin)"
335 [bl32]="$(gen_bin_url bl32.bin)"
336 [busybox]="$(gen_bin_url busybox.bin.gz)"
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +0000337 [boot_script]="$(gen_bin_url boot_script.bin)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100338 [cactus_primary]="$(gen_bin_url cactus-primary.pkg)"
339 [cactus_secondary]="$(gen_bin_url cactus-secondary.pkg)"
340 [cactus_tertiary]="$(gen_bin_url cactus-tertiary.pkg)"
Thaddeus Gonzalez-Serna211688c2025-03-21 19:12:37 -0500341 [coverage_trace_plugin]="$(gen_cc_url)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100342 [dtb]="$(gen_bin_url ${model_dtb})"
343 [el3_payload]="$(gen_bin_url el3_payload.bin)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100344 [fip]="$(gen_bin_url fip.bin)"
345 [fip_gpt]="$(gen_bin_url fip_gpt.bin)"
346 [fvp_spmc_manifest_dtb]="$(gen_bin_url fvp_spmc_manifest.dtb)"
347 [fwu_fip]="$(gen_bin_url fwu_fip.bin)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100348 [hafnium]="$(gen_bin_url hafnium.bin)"
349 [image]="$(gen_bin_url kernel.bin)"
350 [ivy]="$(gen_bin_url ivy.pkg)"
351 [manifest_dtb]="$(gen_bin_url manifest.dtb)"
352 [mcp_fw]="$(gen_bin_url mcp_fw.bin)"
353 [mcp_ram]="$(gen_bin_url mcp_ram.bin)"
354 [mcp_rom]="$(gen_bin_url mcp_rom.bin)"
355 [mcp_rom_hyphen]="$(gen_bin_url mcp-rom.bin)"
356 [ns_bl1u]="$(gen_bin_url ns_bl1u.bin)"
357 [ns_bl2u]="$(gen_bin_url ns_bl2u.bin)"
358 [ramdisk]="$(gen_bin_url initrd.bin)"
359 [romlib]="$(gen_bin_url romlib.bin)"
360 [rootfs]="$(gen_bin_url rootfs.bin.gz)"
361 [host_flash_fip]="$(gen_bin_url host_flash_fip.bin)"
Divin Raj5eb69482024-10-02 11:36:04 +0100362 [rse_flash]="$(gen_bin_url rse_flash.bin)"
David Vinczed8ed5622024-02-23 17:00:12 +0100363 [rse_rom]="$(gen_bin_url rse_rom.bin)"
364 [rse_encrypted_cm_provisioning_bundle_0]="$(gen_bin_url rse_encrypted_cm_provisioning_bundle_0.bin)"
365 [rse_encrypted_dm_provisioning_bundle]="$(gen_bin_url rse_encrypted_dm_provisioning_bundle.bin)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100366 [secure_hafnium]="$(gen_bin_url secure_hafnium.bin)"
367 [scp_fw]="$(gen_bin_url scp_fw.bin)"
368 [scp_ram]="$(gen_bin_url scp_ram.bin)"
369 [scp_ram_hyphen]="$(gen_bin_url scp-ram.bin)"
370 [scp_rom]="$(gen_bin_url scp_rom.bin)"
371 [scp_rom_hyphen]="$(gen_bin_url scp-rom.bin)"
372 [spm]="$(gen_bin_url spm.bin)"
Manish V Badarkhe9589d402024-01-29 16:46:41 +0000373 [tc_fitimage]="$(gen_bin_url tc_fitimage.bin)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100374 [tftf]="$(gen_bin_url tftf.bin)"
Harrison Mutai3ad377a2024-05-20 15:28:52 +0000375 [tl]="$(gen_bin_url tl.bin)"
Harrison Mutaie5122542023-03-27 13:14:18 +0100376 [tmp]="$(gen_bin_url tmp.bin)"
377 [uboot]="$(gen_bin_url uboot.bin)"
Chris Kayc14743a2022-10-13 11:33:26 +0100378 )
379
Chris Kay5d550d82022-10-12 17:20:31 +0100380 # In LAVA we don't provide the paths to the artefacts directly, but instead
381 # use macros of the form `{XYZ}`. This is a list of regular expression
382 # replacements to run on the model parameters file before we add them to the
383 # LAVA job definition.
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100384 declare -A fvp_artefact_macros=(
Chris Kay5d550d82022-10-12 17:20:31 +0100385 ["[= ]backup_fip.bin"]="={BACKUP_FIP}"
386 ["[= ]bl1.bin"]="={BL1}"
387 ["[= ]bl2.bin"]="={BL2}"
388 ["[= ]bl31.bin"]="={BL31}"
389 ["[= ]bl32.bin"]="={BL32}"
Harrison Mutai3dcd1fe2025-03-24 13:19:29 +0000390 ["[= ]boot_script.bin"]="={BOOT_SCRIPT}"
Chris Kay5d550d82022-10-12 17:20:31 +0100391 ["[= ]cactus-primary.pkg"]="={CACTUS_PRIMARY}"
392 ["[= ]cactus-secondary.pkg"]="={CACTUS_SECONDARY}"
393 ["[= ]cactus-tertiary.pkg"]="={CACTUS_TERTIARY}"
394 ["[= ].*coverage_trace.so"]="={COVERAGE_TRACE_PLUGIN}"
395 ["[= ]fvp_spmc_manifest.dtb"]="={FVP_SPMC_MANIFEST_DTB}"
396 ["[= ]busybox.bin"]="={BUSYBOX}"
397 ["[= ]dtb.bin"]="={DTB}"
398 ["[= ]el3_payload.bin"]="={EL3_PAYLOAD}"
399 ["[= ]fip_gpt.bin"]="={FIP_GPT}"
400 ["[= ]fwu_fip.bin"]="={FWU_FIP}"
401 ["[= ]fip.bin"]="={FIP}"
Chris Kay5d550d82022-10-12 17:20:31 +0100402 ["[= ].*/hafnium.bin"]="={HAFNIUM}"
403 ["[= ]kernel.bin"]="={IMAGE}"
404 ["[= ]ivy.pkg"]="={IVY}"
405 ["[= ]manifest.dtb"]="={MANIFEST_DTB}"
Chris Kayfbdd0142022-11-08 12:24:30 +0000406 ["[= ]mcp_fw.bin"]="={MCP_FW}"
Manish V Badarkhe18c59782022-11-09 10:14:48 +0000407 ["[= ]mcp_ram.bin"]="={MCP_RAM}"
Chris Kayef9cc802022-11-08 12:11:58 +0000408 ["[= ]mcp_rom.bin"]="={MCP_ROM}"
409 ["[= ]mcp-rom.bin"]="={MCP_ROM_HYPHEN}"
Chris Kay5d550d82022-10-12 17:20:31 +0100410 ["[= ]ns_bl1u.bin"]="={NS_BL1U}"
411 ["[= ]ns_bl2u.bin"]="={NS_BL2U}"
412 ["[= ]initrd.bin"]="={RAMDISK}"
413 ["[= ]initrd.img"]="={RAMDISK}"
414 ["[= ]romlib.bin"]="={ROMLIB}"
415 ["[= ]rootfs.bin"]="={ROOTFS}"
laurenw-arm60de2742023-03-08 10:50:15 -0600416 ["[= ]host_flash_fip.bin"]="={HOST_FLASH_FIP}"
Divin Raj5eb69482024-10-02 11:36:04 +0100417 ["[= ]rse_flash.bin"]="={RSE_FLASH}"
David Vinczed8ed5622024-02-23 17:00:12 +0100418 ["[= ]rse_rom.bin"]="={RSE_ROM}"
419 ["[= ]rse_encrypted_cm_provisioning_bundle_0.bin"]="={RSE_ENCRYPTED_CM_PROVISIONING_BUNDLE_0}"
420 ["[= ]rse_encrypted_dm_provisioning_bundle.bin"]="={RSE_ENCRYPTED_DM_PROVISIONING_BUNDLE}"
Chris Kay5d550d82022-10-12 17:20:31 +0100421 ["[= ].*/secure_hafnium.bin"]="={SECURE_HAFNIUM}"
Chris Kayfbdd0142022-11-08 12:24:30 +0000422 ["[= ]scp_fw.bin"]="={SCP_FW}"
Chris Kay5d550d82022-10-12 17:20:31 +0100423 ["[= ]scp_ram.bin"]="={SCP_RAM}"
424 ["[= ]scp-ram.bin"]="={SCP_RAM_HYPHEN}"
425 ["[= ]scp_rom.bin"]="={SCP_ROM}"
426 ["[= ]scp-rom.bin"]="={SCP_ROM_HYPHEN}"
427 ["[= ]spm.bin"]="={SPM}"
Manish V Badarkhe9589d402024-01-29 16:46:41 +0000428 ["[= ]tc_fitimage.bin"]="={TC_FITIMAGE}"
Chris Kay5d550d82022-10-12 17:20:31 +0100429 ["[= ]tftf.bin"]="={TFTF}"
Harrison Mutai3ad377a2024-05-20 15:28:52 +0000430 ["[= ]tl.bin"]="={TL}"
Chris Kay5d550d82022-10-12 17:20:31 +0100431 ["[= ].*/tmp.bin"]="={TMP}"
432 ["[= ]uboot.bin"]="={UBOOT}"
433 )
434
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100435 declare -a fvp_artefacts
436 filter_artefacts fvp_artefacts fvp_artefact_filters
Chris Kay4eb9ded2022-10-10 15:51:40 +0100437
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100438 lava_model_params="${lava_model_params}" \
439 gen_lava_model_params fvp_artefact_macros
Leonardo Sandovalbe690bd2020-10-12 17:59:39 -0500440
Harrison Mutaia6d6e682023-03-27 13:20:33 +0100441 yaml_template_file="$yaml_template_file" \
442 yaml_file="$yaml_file" \
443 yaml_job_file="$yaml_job_file" \
444 gen_lava_job_def fvp_artefacts fvp_artefact_urls
Leonardo Sandovald76d1e22020-10-06 16:02:52 -0500445}
446
447docker_registry_append() {
448 # if docker_registry is empty, just use local docker registry
449 [ -z "$docker_registry" ] && return
450
451 local last=-1
452 local last_char="${docker_registry:last}"
453
454 if [ "$last_char" != '/' ]; then
455 docker_registry="${docker_registry}/";
456 fi
457 echo "$docker_registry"
458}
459
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000460# generate GPT image and archive it
461gen_gpt_bin() {
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000462 fip_bin="$1"
Xialin Liu33fc9812025-06-26 16:18:07 -0500463 bl2_fip_bin="$(dirname "$fip_bin")/bl2_$(basename "$fip_bin")"
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000464 gpt_image="fip_gpt.bin"
465 # the FIP partition type is not standardized, so generate one
466 fip_type_uuid=`uuidgen --sha1 --namespace @dns --name "fip_type_uuid"`
Manish V Badarkhe02bcfb12024-01-25 14:14:31 +0000467 # metadata partition type UUID, specified by the document:
468 # Platform Security Firmware Update for the A-profile Arm Architecture
469 # version: 1.0BET0
470 metadata_type_uuid="8a7a84a0-8387-40f6-ab41-a8b9a5a60d23"
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000471 location_uuid=`uuidgen`
472 FIP_A_uuid=`uuidgen`
473 FIP_B_uuid=`uuidgen`
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000474
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000475 fip_max_size=$2
Manish V Badarkhee79bc952024-01-25 14:34:37 +0000476 partition_alignment=${3:-1}
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000477 fip_bin_size=$(stat -c %s $fip_bin)
478 if [ $fip_max_size -lt $fip_bin_size ]; then
479 bberror "fip.bin ($fip_bin_size bytes) is larger than the GPT partition ($fip_max_size bytes)"
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000480 fi
481
Xialin Liu33fc9812025-06-26 16:18:07 -0500482 has_bl2_fip=0
483 if [ -f "$bl2_fip_bin" ]; then
484 has_bl2_fip=1
485 echo "BL2 FIP detected: $bl2_fip_bin"
486
487 bl2_fip_type_uuid=$(uuidgen --sha1 --namespace @dns --name "bl2_fip_type_uuid")
488 bl2_fip_bin_size=$(stat -c %s $bl2_fip_bin)
489 FIP_BL2_uuid=$(uuidgen)
490 bl2_fip_max_size=$fip_max_size
491
492 if [ $bl2_fip_max_size -lt $bl2_fip_bin_size ]; then
493 bberror "bl2_fip.bin ($bl2_fip_bin_size bytes) is larger than the GPT partition ($bl2_fip_max_size bytes)"
494 fi
495
496 else
497 echo "No BL2 FIP found. Proceeding without it."
498 fi
499
Manish V Badarkhe02bcfb12024-01-25 14:14:31 +0000500 # maximum metadata size 512B.
501 # This is the current size of the metadata rounded up to an integer number of sectors.
502 metadata_max_size=512
503 metadata_file="metadata.bin"
504
505 # generate_fwu_metadata.py --metadata_file <file> \
506 # --image_data "[(image_type_uuid, location_uuid, [image_uuid1, image_uuid2,...])]"
507 python3 $ci_root/generate_fwu_metadata.py --metadata_file $metadata_file \
508 --image_data "[('$fip_type_uuid', '$location_uuid', ['$FIP_A_uuid', '$FIP_B_uuid'])]"
509
Xialin Liu33fc9812025-06-26 16:18:07 -0500510 # create GPT image. If BL2_FIP does not exists, the GPT contains 1 FIP partition: FIP_A.
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000511 # the GPT layout is the following:
512 #
513 # +----------------------+
514 # LBA0 | Protective MBR |
515 # ------------------------
516 # LBA1 | Primary GPT Header |
517 # ------------------------
518 # LBA34| FIP_A |
519 # ------------------------
Manish V Badarkhe02bcfb12024-01-25 14:14:31 +0000520 # | FIP_B |
521 # ------------------------
522 # | FWU-Metadata |
523 # ------------------------
524 # | Bkup-FWU-Metadata |
525 # ------------------------
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000526 # LBA-1| Secondary GPT Header |
527 # +----------------------+
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000528
Xialin Liu33fc9812025-06-26 16:18:07 -0500529 # create GPT image. If BL2_FIP exists, The GPT contains 2 FIP partitions: FIP_BL2 and FIP_A.
530 # the GPT layout is the following:
531 #
532 # +----------------------+
533 # LBA0 | Protective MBR |
534 # ------------------------
535 # LBA1 | Primary GPT Header |
536 # ------------------------
537 # LBA34| FIP_BL2 |
538 # ------------------------
539 # | FIP_A |
540 # ------------------------
541 # | FIP_B |
542 # ------------------------
543 # | FWU-Metadata |
544 # ------------------------
545 # | Bkup-FWU-Metadata |
546 # ------------------------
547 # LBA-1| Secondary GPT Header |
548 # +----------------------+
549
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000550 sector_size=512 # in bytes
551 gpt_header_size=33 # in sectors
552 num_sectors_fip=`expr $fip_max_size / $sector_size`
Manish V Badarkhe02bcfb12024-01-25 14:14:31 +0000553 num_sectors_metadata=`expr $metadata_max_size / $sector_size`
Xialin Liu33fc9812025-06-26 16:18:07 -0500554
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000555 start_sector_1=`expr 1 + $gpt_header_size` # size of MBR is 1 sector
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000556
Xialin Liu33fc9812025-06-26 16:18:07 -0500557 if [ "$has_bl2_fip" -eq 1 ]; then
558 num_sectors_bl2_fip=$(expr $bl2_fip_max_size / $sector_size)
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000559
Xialin Liu33fc9812025-06-26 16:18:07 -0500560 start_sector_2=`expr $start_sector_1 + $num_sectors_bl2_fip`
561 start_sector_3=`expr $start_sector_2 + $num_sectors_fip`
562 start_sector_4=`expr $start_sector_3 + $num_sectors_fip`
563 start_sector_5=`expr $start_sector_4 + $num_sectors_metadata`
564 num_sectors_gpt=`expr $start_sector_5 + $num_sectors_metadata + $gpt_header_size`
565 gpt_size=`expr $num_sectors_gpt \* $sector_size`
566
567 # create raw image
568 dd if=/dev/zero of=$gpt_image bs=$gpt_size count=1
569
570 sgdisk $gpt_image \
571 --set-alignment $partition_alignment \
572 --disk-guid $location_uuid \
573 \
574 --new 1:$start_sector_1:+$num_sectors_bl2_fip \
575 --change-name 1:FIP_BL2 \
576 --typecode 1:$bl2_fip_type_uuid \
577 --partition-guid 1:$FIP_BL2_uuid \
578 \
579 --new 2:$start_sector_2:+$num_sectors_fip \
580 --change-name 2:FIP_A \
581 --typecode 2:$fip_type_uuid \
582 --partition-guid 2:$FIP_A_uuid \
583 \
584 --new 3:$start_sector_3:+$num_sectors_fip \
585 --change-name 3:FIP_B \
586 --typecode 3:$fip_type_uuid \
587 --partition-guid 3:$FIP_B_uuid \
588 \
589 --new 4:$start_sector_4:+$num_sectors_metadata \
590 --change-name 4:FWU-Metadata \
591 --typecode 4:$metadata_type_uuid \
592 \
593 --new 5:$start_sector_5:+$num_sectors_metadata \
594 --change-name 5:Bkup-FWU-Metadata \
595 --typecode 5:$metadata_type_uuid
596
597 else
598 start_sector_2=`expr $start_sector_1 + $num_sectors_fip`
599 start_sector_3=`expr $start_sector_2 + $num_sectors_fip`
600 start_sector_4=`expr $start_sector_3 + $num_sectors_metadata`
601 num_sectors_gpt=`expr $start_sector_4 + $num_sectors_metadata + $gpt_header_size`
602 gpt_size=`expr $num_sectors_gpt \* $sector_size`
603
604 # create raw image
605 dd if=/dev/zero of=$gpt_image bs=$gpt_size count=1
606
607 sgdisk $gpt_image \
608 --set-alignment $partition_alignment \
609 --disk-guid $location_uuid \
610 \
611 --new 1:$start_sector_1:+$num_sectors_fip \
612 --change-name 1:FIP_A \
613 --typecode 1:$fip_type_uuid \
614 --partition-guid 1:$FIP_A_uuid \
615 \
616 --new 2:$start_sector_2:+$num_sectors_fip \
617 --change-name 2:FIP_B \
618 --typecode 2:$fip_type_uuid \
619 --partition-guid 2:$FIP_B_uuid \
620 \
621 --new 3:$start_sector_3:+$num_sectors_metadata \
622 --change-name 3:FWU-Metadata \
623 --typecode 3:$metadata_type_uuid \
624 \
625 --new 4:$start_sector_4:+$num_sectors_metadata \
626 --change-name 4:Bkup-FWU-Metadata \
627 --typecode 4:$metadata_type_uuid
628
629 fi
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000630
631 # populate the GPT partitions
Xialin Liu33fc9812025-06-26 16:18:07 -0500632 if [ "$has_bl2_fip" -eq 1 ]; then
633 dd if=$bl2_fip_bin of=$gpt_image bs=$sector_size seek=$(gdisk -l $gpt_image | grep " FIP_BL2$" | awk '{print $2}') count=$num_sectors_bl2_fip conv=notrunc
634 fi
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000635 dd if=$fip_bin of=$gpt_image bs=$sector_size seek=$(gdisk -l $gpt_image | grep " FIP_A$" | awk '{print $2}') count=$num_sectors_fip conv=notrunc
Manish V Badarkhe02bcfb12024-01-25 14:14:31 +0000636 dd if=$fip_bin of=$gpt_image bs=$sector_size seek=$(gdisk -l $gpt_image | grep " FIP_B$" | awk '{print $2}') count=$num_sectors_fip conv=notrunc
637 dd if=$metadata_file of=$gpt_image bs=$sector_size seek=$(gdisk -l $gpt_image | grep " FWU-Metadata$" | awk '{print $2}') count=$num_sectors_metadata conv=notrunc
638 dd if=$metadata_file of=$gpt_image bs=$sector_size seek=$(gdisk -l $gpt_image | grep " Bkup-FWU-Metadata$" | awk '{print $2}') count=$num_sectors_metadata conv=notrunc
Manish V Badarkhe048c9682024-01-22 10:11:49 +0000639
640 echo "Built $gpt_image"
641
642 archive_file "$gpt_image"
Manish V Badarkheea3e0942021-03-05 11:51:48 +0000643}
644
Govindraj Raja67501732023-09-22 16:27:06 -0500645#corrupt GPT image header and archive it
646corrupt_gpt_bin() {
647 bin="${1:?}"
laurenw-arm2c6665f2024-02-09 16:08:34 -0600648 corrupt_data=$2
Govindraj Raja67501732023-09-22 16:27:06 -0500649
laurenw-arm2c6665f2024-02-09 16:08:34 -0600650 # Check if parameters are provided
651 if [ -z "$bin" ] || [ -z "$corrupt_data" ]; then
652 echo "Usage: corrupt_gpt_bin <bin> <corrupt_data>"
653 return 1
654 fi
655
656 case "$corrupt_data" in
657 "header")
658 # Primary GPT header is present in LBA-1 second block after MBR
659 # empty the primary GPT header forcing to use backup GPT header
660 # and backup GPT entries.
661 seek=1
662 count=1
663 ;;
664 "partition-entries")
665 # GPT partition entry array is present in LBA-2 through LBA-34
666 # blocks empty the GPT partition entry array forcing to use backup
667 # GPT header and backup GPT entries.
668 seek=2
669 count=32
670 ;;
Manish V Badarkheb473c402024-02-14 16:50:08 +0000671 "fwu-metadata")
672 # Get the LBA number for the FWU metadata. Size of which is always
673 # 1 sector (512 bytes).
674 seek=$(gdisk -l $bin | grep " FWU-Metadata$" | awk '{print $2}')
675 count=1
676 ;;
Xialin Liu2d0a3032025-07-10 16:02:22 -0500677 "mbr")
678 seek=0
679 count=1
680 ;;
Xialin Liu67229612025-07-10 14:58:05 -0500681 "secondary-header")
682 # Secondary GPT header is present in LBA-1 last block before the
683 # end of the GPT image.
684 # Secondary GPT header is located after the backup FWU metadata,
685 # which is 1 sector in size.
686 seek=$(( $(gdisk -l "$bin" | grep " Bkup-FWU-Metadata$" | awk '{print $2}') + 1 ))
687 count=1
688 ;;
laurenw-arm2c6665f2024-02-09 16:08:34 -0600689 *)
Xialin Liu67229612025-07-10 14:58:05 -0500690 echo "Invalid $corrupt_data. Use 'header', 'partition-entries', 'fwu-metadata' or 'mbr', 'fwu-metadata' or 'secondary-header'."
laurenw-arm2c6665f2024-02-09 16:08:34 -0600691 return 1
692 ;;
693 esac
694
695 # Use parameters in the dd command
696 dd if=/dev/zero of=$bin bs=512 seek=$seek count=$count conv=notrunc
Govindraj Raja67501732023-09-22 16:27:06 -0500697}
698
Fathi Boudra422bf772019-12-02 11:10:16 +0200699set +u