Leonardo Sandoval | 9dfdd1b | 2020-08-06 17:08:11 -0500 | [diff] [blame] | 1 | #!/usr/bin/env bash |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 2 | # |
Govindraj Raja | 1d208f7 | 2025-02-11 12:20:32 -0600 | [diff] [blame] | 3 | # Copyright (c) 2020-2025, Arm Limited. All rights reserved. |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 4 | # |
| 5 | # SPDX-License-Identifier: BSD-3-Clause |
| 6 | # |
| 7 | |
| 8 | set -u |
| 9 | |
| 10 | bl1_addr="${bl1_addr:-0x0}" |
Zelalem | 219df41 | 2020-05-17 19:21:20 -0500 | [diff] [blame] | 11 | bl31_addr="${bl31_addr:-0x04001000}" |
Zelalem | 1b87461 | 2020-08-04 18:08:18 -0500 | [diff] [blame] | 12 | bl32_addr="${bl32_addr:-0x04003000}" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 13 | bl33_addr="${bl33_addr:-0x88000000}" |
| 14 | dtb_addr="${dtb_addr:-0x82000000}" |
| 15 | fip_addr="${fip_addr:-0x08000000}" |
| 16 | initrd_addr="${initrd_addr:-0x84000000}" |
| 17 | kernel_addr="${kernel_addr:-0x80080000}" |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 18 | boot_script_addr="${boot_script_addr:-0x8fb00000}" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 19 | el3_payload_addr="${el3_payload_addr:-0x80000000}" |
| 20 | |
Manish Pandey | 3c43558 | 2020-07-15 12:14:26 +0100 | [diff] [blame] | 21 | # SPM requires following addresses for RESET_TO_BL31 case |
| 22 | spm_addr="${spm_addr:-0x6000000}" |
| 23 | spmc_manifest_addr="${spmc_addr:-0x0403f000}" |
| 24 | sp1_addr="${sp1_addr:-0x7000000}" |
| 25 | sp2_addr="${sp2_addr:-0x7100000}" |
Olivier Deprez | 0b83409 | 2020-08-21 08:36:01 +0200 | [diff] [blame] | 26 | sp3_addr="${sp3_addr:-0x7200000}" |
Olivier Deprez | dd9ed33 | 2021-07-02 12:07:17 +0200 | [diff] [blame] | 27 | sp4_addr="${sp4_addr:-0x7600000}" |
Manish Pandey | 1e7be85 | 2020-11-09 16:04:48 +0000 | [diff] [blame] | 28 | # SPM out directories |
J-Alves | 12d796c | 2023-02-27 10:30:58 +0000 | [diff] [blame] | 29 | export spm_secure_out_dir="${spm_secure_out_dir:-secure_aem_v8a_fvp_vhe_clang}" |
| 30 | export spm_non_secure_out_dir="${spm_non_secure_out_dir:-aem_v8a_fvp_vhe_clang}" |
Manish Pandey | 3c43558 | 2020-07-15 12:14:26 +0100 | [diff] [blame] | 31 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 32 | ns_bl1u_addr="${ns_bl1u_addr:-0x0beb8000}" |
| 33 | fwu_fip_addr="${fwu_fip_addr:-0x08400000}" |
| 34 | backup_fip_addr="${backup_fip_addr:-0x09000000}" |
| 35 | romlib_addr="${romlib_addr:-0x03ff2000}" |
| 36 | |
Harrison Mutai | 6f4fd6c | 2023-03-27 13:22:41 +0100 | [diff] [blame] | 37 | uefi_downloads="${uefi_downloads:-http://files.oss.arm.com/downloads/uefi}" |
| 38 | uefi_ci_bin_url="${uefi_ci_bin_url:-$uefi_downloads/Artifacts/Linux/github/fvp/static/DEBUG_GCC5/FVP_AARCH64_EFI.fd}" |
| 39 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 40 | uboot32_fip_url="$linaro_release/fvp32-latest-busybox-uboot/fip.bin" |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 41 | if [[ "$test_config" == *handoff* ]]; then |
Harrison Mutai | 6eb2c7f | 2025-05-06 10:01:11 +0000 | [diff] [blame] | 42 | optee_path=$tfa_downloads/optee/handoff/4.6.0 |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 43 | uboot_url="${tfa_downloads}/handoff/fvp/u-boot.bin" |
| 44 | else |
Harrison Mutai | 6eb2c7f | 2025-05-06 10:01:11 +0000 | [diff] [blame] | 45 | optee_version="4.5.0" |
| 46 | |
| 47 | optee_path=$tfa_downloads/optee/${optee_version} |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 48 | uboot_url="$linaro_release/fvp-latest-busybox-uboot/bl33-uboot.bin" |
| 49 | fi |
| 50 | uboot_script_url="${tfa_downloads}/linux_boot/fvp/boot.scr" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 51 | |
Alexei Fedorov | e405cc3 | 2020-09-30 18:13:55 +0100 | [diff] [blame] | 52 | rootfs_url="$linaro_release/lt-vexpress64-openembedded_minimal-armv8-gcc-5.2_20170127-761.img.gz" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 53 | |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 54 | # Default FVP model variables |
Leonardo Sandoval | e146066 | 2021-05-27 16:05:38 -0500 | [diff] [blame] | 55 | default_model_dtb="dtb.bin" |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 56 | |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 57 | # FVP containers and model paths |
Maksims Svecovs | 284a50d | 2021-11-02 11:09:47 +0000 | [diff] [blame] | 58 | fvp_arm_std_library="fvp:fvp_arm_std_library_${model_version}_${model_build};/opt/model/FVP_ARM_Std_Library/FVP_Base" |
Govindraj Raja | 7d80d93 | 2025-06-30 14:25:38 -0500 | [diff] [blame] | 59 | fvp_base_revc_2xaemva="fvp:fvp_base_revc-2xaemva_${model_version}_${model_build}_linux64;/opt/model/Base_RevC_AEMvA_pkg/models/${model_flavour}" |
johpow01 | 936638d | 2021-11-08 18:22:24 -0600 | [diff] [blame] | 60 | fvp_base_aemv8r="fvp:fvp_base_aemv8r_${model_version}_${model_build};/opt/model/AEMv8R_base_pkg/models/${model_flavour}" |
Govindraj Raja | fa86cf6 | 2025-02-19 14:55:48 -0600 | [diff] [blame] | 61 | fvp_rd_1_ae="fvp:fvp_rd_1_ae_${model_version}_${model_build};/opt/model/FVP_RD_1_AE/models/${model_flavour}" |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 62 | |
Manish V Badarkhe | f65f9a3 | 2022-11-04 10:07:19 +0000 | [diff] [blame] | 63 | # CSS model list |
Govindraj Raja | fa86cf6 | 2025-02-19 14:55:48 -0600 | [diff] [blame] | 64 | fvp_tc4="fvp:fvp_tc4_${model_version}_${model_build};/opt/model/FVP_TC4/models/${model_flavour}" |
Manish V Badarkhe | f65f9a3 | 2022-11-04 10:07:19 +0000 | [diff] [blame] | 65 | |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 66 | # 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 | |
| 70 | declare -A fvp_models |
| 71 | fvp_models=( |
laurenw-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 72 | [base-aemv8a-revb]="${fvp_arm_std_library};FVP_Base_AEMvA-AEMvA" |
Manish Pandey | a60d807 | 2024-03-11 09:58:53 +0000 | [diff] [blame] | 73 | [base-aemva]="${fvp_base_revc_2xaemva};FVP_Base_RevC-2xAEMvA" |
laurenw-arm | f414aba | 2021-04-26 15:58:56 -0500 | [diff] [blame] | 74 | [base-aemv8a]="${fvp_base_revc_2xaemva};FVP_Base_RevC-2xAEMvA" |
Govindraj Raja | fa86cf6 | 2025-02-19 14:55:48 -0600 | [diff] [blame] | 75 | [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-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 78 | [cortex-a55x4]="${fvp_arm_std_library};FVP_Base_Cortex-A55" |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 79 | [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 Raja | fa86cf6 | 2025-02-19 14:55:48 -0600 | [diff] [blame] | 81 | [cortex-a57x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57" |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 82 | [cortex-a57x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A57x4-A53x4" |
Govindraj Raja | fa86cf6 | 2025-02-19 14:55:48 -0600 | [diff] [blame] | 83 | [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 Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 87 | [cortex-a73x4-a53x4]="${fvp_arm_std_library};FVP_Base_Cortex-A73x4-A53x4" |
laurenw-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 88 | [cortex-a75x4]="${fvp_arm_std_library};FVP_Base_Cortex-A75" |
| 89 | [cortex-a76aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A76AE" |
laurenw-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 90 | [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 Conde | d52a475 | 2023-03-21 14:52:10 -0500 | [diff] [blame] | 93 | [cortex-a78aex4]="${fvp_arm_std_library};FVP_Base_Cortex-A78AE" |
laurenw-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 94 | [cortex-a78cx4]="${fvp_arm_std_library};FVP_Base_Cortex-A78C" |
Govindraj Raja | 8962c45 | 2024-06-04 14:50:28 -0500 | [diff] [blame] | 95 | [cortex-x2]="${fvp_arm_std_library};FVP_Base_Cortex-X2" |
Govindraj Raja | 1d208f7 | 2025-02-11 12:20:32 -0600 | [diff] [blame] | 96 | [cortex-x4]="${fvp_arm_std_library};FVP_Base_Cortex-X4" |
| 97 | [cortex-x925]="${fvp_arm_std_library};FVP_Base_Cortex-X925" |
Govindraj Raja | 268a2be | 2024-07-01 14:31:31 -0500 | [diff] [blame] | 98 | [cortex-a710x8]="${fvp_arm_std_library};FVP_Base_Cortex-A710" |
Govindraj Raja | fa86cf6 | 2025-02-19 14:55:48 -0600 | [diff] [blame] | 99 | [neoverse_e1]="${fvp_arm_std_library};FVP_Base_Neoverse-E1" |
laurenw-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 100 | [neoverse_n1]="${fvp_arm_std_library};FVP_Base_Neoverse-N1" |
Govindraj Raja | 8962c45 | 2024-06-04 14:50:28 -0500 | [diff] [blame] | 101 | [neoverse_n2]="${fvp_arm_std_library};FVP_Base_Neoverse-N2" |
laurenw-arm | afdc3bc | 2022-09-14 15:31:42 -0500 | [diff] [blame] | 102 | [neoverse-v1x4]="${fvp_arm_std_library};FVP_Base_Neoverse-V1" |
Icen Zeyada | b68a561 | 2024-11-08 07:35:44 +0000 | [diff] [blame] | 103 | [tc4]="${fvp_tc4};FVP_TC4" |
Divin Raj | b007105 | 2023-07-04 14:35:07 +0100 | [diff] [blame] | 104 | [baser-aemv8r]="${fvp_base_aemv8r};FVP_BaseR_AEMv8R" |
Divin Raj | 5eb6948 | 2024-10-02 11:36:04 +0100 | [diff] [blame] | 105 | [rd1ae]="${fvp_rd_1_ae};FVP_RD_1_AE" |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 106 | ) |
| 107 | |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 108 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 109 | # FVP Kernel URLs |
Harrison Mutai | 6f4fd6c | 2023-03-27 13:22:41 +0100 | [diff] [blame] | 110 | declare -A kernel_list |
| 111 | kernel_list=( |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 112 | [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 Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 119 | # FVP initrd URLs |
Harrison Mutai | 6f4fd6c | 2023-03-27 13:22:41 +0100 | [diff] [blame] | 120 | declare -A initrd_list |
| 121 | initrd_list=( |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 122 | [aarch32-ramdisk]="$linaro_release/fvp32-latest-busybox-uboot/ramdisk.img" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 123 | [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 Sobrino | 98de503 | 2020-09-17 12:47:05 +0100 | [diff] [blame] | 128 | # 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. |
| 130 | get_ftpm_optee_bin() { |
Javier Almansa Sobrino | de64772 | 2020-10-08 19:17:44 +0100 | [diff] [blame] | 131 | url="$tfa_downloads/ftpm/optee/tee-header_v2.bin" \ |
Javier Almansa Sobrino | 98de503 | 2020-09-17 12:47:05 +0100 | [diff] [blame] | 132 | saveas="bl32.bin" fetch_file |
| 133 | archive_file "bl32.bin" |
| 134 | |
Javier Almansa Sobrino | de64772 | 2020-10-08 19:17:44 +0100 | [diff] [blame] | 135 | url="$tfa_downloads/ftpm/optee/tee-pager_v2.bin" \ |
Javier Almansa Sobrino | 98de503 | 2020-09-17 12:47:05 +0100 | [diff] [blame] | 136 | saveas="bl32_extra1.bin" fetch_file |
| 137 | archive_file "bl32_extra1.bin" |
| 138 | |
Leonardo Sandoval | da5f78d | 2021-03-18 11:09:30 -0600 | [diff] [blame] | 139 | # 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 Sobrino | 98de503 | 2020-09-17 12:47:05 +0100 | [diff] [blame] | 142 | archive_file "bl32_extra2.bin" |
| 143 | } |
| 144 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 145 | get_dtb() { |
| 146 | local dtb_type="${dtb_type:?}" |
| 147 | local dtb_url |
| 148 | local dtb_saveas="$workspace/dtb.bin" |
Zelalem | 219df41 | 2020-05-17 19:21:20 -0500 | [diff] [blame] | 149 | local cc="$(get_tf_opt CROSS_COMPILE)" |
| 150 | local pp_flags="-P -nostdinc -undef -x assembler-with-cpp" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 151 | |
| 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 Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 158 | *) |
Zelalem | 219df41 | 2020-05-17 19:21:20 -0500 | [diff] [blame] | 159 | # Preprocess DTS file |
| 160 | ${cc}gcc -E ${pp_flags} -I"$tf_root/fdts" -I"$tf_root/include" \ |
| 161 | -o "$workspace/${dtb_type}.pre.dts" \ |
| 162 | "$tf_root/fdts/${dtb_type}.dts" |
| 163 | # Generate DTB file from DTS |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 164 | dtc -I dts -O dtb \ |
Zelalem | 219df41 | 2020-05-17 19:21:20 -0500 | [diff] [blame] | 165 | "$workspace/${dtb_type}.pre.dts" -o "$dtb_saveas" |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 166 | esac |
| 167 | |
| 168 | archive_file "$dtb_saveas" |
| 169 | } |
| 170 | |
| 171 | get_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 | |
Sandrine Bailleux | 14a692d | 2022-06-29 15:39:42 +0200 | [diff] [blame] | 205 | fvp_romlib_jmptbl_backup="$(mktempdir)/jmptbl.i" |
| 206 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 207 | fvp_romlib_runtime() { |
| 208 | local tmpdir="$(mktempdir)" |
| 209 | |
| 210 | # Save BL1 and romlib binaries from original build |
| 211 | mv "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin" "$tmpdir/romlib.bin" |
| 212 | mv "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin" "$tmpdir/bl1.bin" |
| 213 | |
| 214 | # Patch index file |
Sandrine Bailleux | 14a692d | 2022-06-29 15:39:42 +0200 | [diff] [blame] | 215 | cp "${tf_root:?}/plat/arm/board/fvp/jmptbl.i" "$fvp_romlib_jmptbl_backup" |
| 216 | sed -i '/fdt/ s/.$/&\ patch/' ${tf_root:?}/plat/arm/board/fvp/jmptbl.i |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 217 | |
Sandrine Bailleux | 14a692d | 2022-06-29 15:39:42 +0200 | [diff] [blame] | 218 | # Rebuild with patched file |
| 219 | echo "Building patched romlib:" |
| 220 | build_tf |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 221 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 222 | # Retrieve original BL1 and romlib binaries |
| 223 | mv "$tmpdir/romlib.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/romlib/romlib.bin" |
| 224 | mv "$tmpdir/bl1.bin" "${tf_build_root:?}/${plat:?}/${mode:?}/bl1.bin" |
| 225 | } |
| 226 | |
Sandrine Bailleux | 14a692d | 2022-06-29 15:39:42 +0200 | [diff] [blame] | 227 | fvp_romlib_cleanup() { |
| 228 | # Restore original index |
| 229 | mv "$fvp_romlib_jmptbl_backup" "${tf_root:?}/plat/arm/board/fvp/jmptbl.i" |
| 230 | } |
| 231 | |
| 232 | |
Chris Kay | c9523b1 | 2022-10-10 18:32:20 +0100 | [diff] [blame] | 233 | # Generates the final YAML-based LAVA job definition from a template file. |
| 234 | # |
| 235 | # The job definition template is expanded with visibility of all variables that |
| 236 | #Â are available from within the function, including those with local scope. |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 237 | gen_fvp_yaml() { |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 238 | local model="${model:?}" |
| 239 | |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 240 | local yaml_template_file="$workspace/fvp_template.yaml" |
| 241 | local yaml_file="$workspace/fvp.yaml" |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 242 | local yaml_job_file="$workspace/job.yaml" |
| 243 | local lava_model_params="$workspace/lava_model_params" |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 244 | |
Leonardo Sandoval | fda4f29 | 2020-10-06 15:59:26 -0500 | [diff] [blame] | 245 | # this function expects a template, quit if it is not present |
| 246 | if [ ! -f "$yaml_template_file" ]; then |
Paul Sokolovsky | a3c5a4c | 2023-01-24 18:33:58 +0700 | [diff] [blame] | 247 | echo "warning: gen_fvp_yaml: template $yaml_template_file not available, skipping generating LAVA job" |
Leonardo Sandoval | fda4f29 | 2020-10-06 15:59:26 -0500 | [diff] [blame] | 248 | return |
| 249 | fi |
| 250 | |
Leonardo Sandoval | 00ced1f | 2020-12-07 12:55:08 -0600 | [diff] [blame] | 251 | local model_params="${fvp_models[$model]}" |
| 252 | local model_name="$(echo "${model_params}" | awk -F ';' '{print $1}')" |
| 253 | local model_dir="$(echo "${model_params}" | awk -F ';' '{print $2}')" |
| 254 | local model_bin="$(echo "${model_params}" | awk -F ';' '{print $3}')" |
| 255 | |
| 256 | # model params are required for correct yaml creation, quit if empty |
| 257 | if [ -z "${model_name}" ]; then |
| 258 | echo "FVP model param 'model_name' variable empty, yaml not produced" |
| 259 | return |
| 260 | elif [ -z "${model_dir}" ]; then |
| 261 | echo "FVP model param 'model_dir' variable empty, yaml not produced" |
| 262 | return |
| 263 | elif [ -z "${model_bin}" ]; then |
| 264 | echo "FVP model param 'model_bin' variable empty, yaml not produced" |
| 265 | return |
| 266 | fi |
| 267 | |
| 268 | echo "FVP model params: model_name=$model_name model_dir=$model_dir model_bin=$model_bin" |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 269 | |
| 270 | # optional parameters, defaults to globals |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 271 | local model_dtb="${model_dtb:-$default_model_dtb}" |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 272 | |
Chris Kay | c9523b1 | 2022-10-10 18:32:20 +0100 | [diff] [blame] | 273 | if [ -n "${GERRIT_CHANGE_NUMBER}" ]; then |
| 274 | local gerrit_url="https://review.trustedfirmware.org/c/${GERRIT_CHANGE_NUMBER}/${GERRIT_PATCHSET_NUMBER}" |
| 275 | elif [ -n "${GERRIT_REFSPEC}" ]; then |
| 276 | local gerrit_url=$(echo ${GERRIT_REFSPEC} | |
| 277 | awk -F/ '{print "https://review.trustedfirmware.org/c/" $4 "/" $5}') |
| 278 | fi |
| 279 | |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 280 | docker_registry="${docker_registry:-}" |
| 281 | docker_registry="$(docker_registry_append)" |
Leonardo Sandoval | 5d90dff | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 282 | docker_name="${docker_registry}$model_name" |
Leonardo Sandoval | 850a486 | 2021-02-16 13:56:18 -0600 | [diff] [blame] | 283 | prompt1='/ #' |
| 284 | prompt2='root@genericarmv8:~#' |
| 285 | version_string="\"Fast Models"' [^\\n]+'"\"" |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 286 | |
Leonardo Sandoval | 5d87b70 | 2021-05-10 11:53:13 -0500 | [diff] [blame] | 287 | test_config="${TEST_CONFIG}" |
| 288 | |
Harrison Mutai | a6d6e68 | 2023-03-27 13:20:33 +0100 | [diff] [blame] | 289 | declare -A fvp_artefact_filters=( |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 290 | [backup_fip]="backup_fip.bin" |
| 291 | [bl1]="bl1.bin" |
| 292 | [bl2]="bl2.bin" |
| 293 | [bl31]="bl31.bin" |
| 294 | [bl32]="bl32.bin" |
| 295 | [busybox]="busybox.bin" |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 296 | [boot_script]="boot_script.bin" |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 297 | [cactus_primary]="cactus-primary.pkg" |
| 298 | [cactus_secondary]="cactus-secondary.pkg" |
| 299 | [cactus_tertiary]="cactus-tertiary.pkg" |
| 300 | [coverage_trace_plugin]="coverage_trace.so" |
| 301 | [dtb]="dtb.bin" |
| 302 | [el3_payload]="el3_payload.bin" |
| 303 | [fip_gpt]="fip_gpt.bin" |
| 304 | [fip]="fip.bin" |
| 305 | [fvp_spmc_manifest_dtb]="=fvp_spmc_manifest.dtb" |
| 306 | [fwu_fip]="fwu_fip.bin" |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 307 | [hafnium]="hafnium.bin" |
| 308 | [image]="kernel.bin" |
| 309 | [ivy]="ivy.pkg" |
| 310 | [manifest_dtb]="=manifest.dtb" |
Chris Kay | fbdd014 | 2022-11-08 12:24:30 +0000 | [diff] [blame] | 311 | [mcp_fw]="mcp_fw.bin" |
Manish V Badarkhe | 18c5978 | 2022-11-09 10:14:48 +0000 | [diff] [blame] | 312 | [mcp_ram]="mcp_ram.bin" |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 313 | [mcp_rom_hyphen]="mcp-rom.bin" |
| 314 | [mcp_rom]="mcp_rom.bin" |
| 315 | [ns_bl1u]="ns_bl1u.bin" |
| 316 | [ns_bl2u]="ns_bl2u.bin" |
| 317 | [ramdisk]="initrd.bin|initrd.img" |
| 318 | [romlib]="romlib.bin" |
| 319 | [rootfs]="rootfs.bin" |
laurenw-arm | 60de274 | 2023-03-08 10:50:15 -0600 | [diff] [blame] | 320 | [host_flash_fip]="host_flash_fip.bin" |
Divin Raj | 5eb6948 | 2024-10-02 11:36:04 +0100 | [diff] [blame] | 321 | [rse_flash]="rse_flash.bin" |
David Vincze | d8ed562 | 2024-02-23 17:00:12 +0100 | [diff] [blame] | 322 | [rse_rom]="rse_rom.bin" |
| 323 | [rse_encrypted_cm_provisioning_bundle_0]="rse_encrypted_cm_provisioning_bundle_0.bin" |
| 324 | [rse_encrypted_dm_provisioning_bundle]="rse_encrypted_dm_provisioning_bundle.bin" |
Chris Kay | fbdd014 | 2022-11-08 12:24:30 +0000 | [diff] [blame] | 325 | [scp_fw]="scp_fw.bin" |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 326 | [scp_ram_hyphen]="scp-ram.bin" |
| 327 | [scp_ram]="scp_ram.bin" |
| 328 | [scp_rom_hyphen]="scp-rom.bin" |
| 329 | [scp_rom]="scp_rom.bin" |
| 330 | [secure_hafnium]="secure_hafnium.bin" |
| 331 | [spm]="spm.bin" |
Manish V Badarkhe | 9589d40 | 2024-01-29 16:46:41 +0000 | [diff] [blame] | 332 | [tc_fitimage]="tc_fitimage.bin" |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 333 | [tftf]="tftf.bin" |
Harrison Mutai | 3ad377a | 2024-05-20 15:28:52 +0000 | [diff] [blame] | 334 | [tl]="tl.bin" |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 335 | [tmp]="tmp.bin" |
| 336 | [uboot]="uboot.bin" |
| 337 | ) |
| 338 | |
Harrison Mutai | a6d6e68 | 2023-03-27 13:20:33 +0100 | [diff] [blame] | 339 | declare -A fvp_artefact_urls=( |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 340 | [backup_fip]="$(gen_bin_url backup_fip.bin)" |
| 341 | [bl1]="$(gen_bin_url bl1.bin)" |
| 342 | [bl2]="$(gen_bin_url bl2.bin)" |
| 343 | [bl31]="$(gen_bin_url bl31.bin)" |
| 344 | [bl32]="$(gen_bin_url bl32.bin)" |
| 345 | [busybox]="$(gen_bin_url busybox.bin.gz)" |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 346 | [boot_script]="$(gen_bin_url boot_script.bin)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 347 | [cactus_primary]="$(gen_bin_url cactus-primary.pkg)" |
| 348 | [cactus_secondary]="$(gen_bin_url cactus-secondary.pkg)" |
| 349 | [cactus_tertiary]="$(gen_bin_url cactus-tertiary.pkg)" |
Thaddeus Gonzalez-Serna | 211688c | 2025-03-21 19:12:37 -0500 | [diff] [blame] | 350 | [coverage_trace_plugin]="$(gen_cc_url)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 351 | [dtb]="$(gen_bin_url ${model_dtb})" |
| 352 | [el3_payload]="$(gen_bin_url el3_payload.bin)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 353 | [fip]="$(gen_bin_url fip.bin)" |
| 354 | [fip_gpt]="$(gen_bin_url fip_gpt.bin)" |
| 355 | [fvp_spmc_manifest_dtb]="$(gen_bin_url fvp_spmc_manifest.dtb)" |
| 356 | [fwu_fip]="$(gen_bin_url fwu_fip.bin)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 357 | [hafnium]="$(gen_bin_url hafnium.bin)" |
| 358 | [image]="$(gen_bin_url kernel.bin)" |
| 359 | [ivy]="$(gen_bin_url ivy.pkg)" |
| 360 | [manifest_dtb]="$(gen_bin_url manifest.dtb)" |
| 361 | [mcp_fw]="$(gen_bin_url mcp_fw.bin)" |
| 362 | [mcp_ram]="$(gen_bin_url mcp_ram.bin)" |
| 363 | [mcp_rom]="$(gen_bin_url mcp_rom.bin)" |
| 364 | [mcp_rom_hyphen]="$(gen_bin_url mcp-rom.bin)" |
| 365 | [ns_bl1u]="$(gen_bin_url ns_bl1u.bin)" |
| 366 | [ns_bl2u]="$(gen_bin_url ns_bl2u.bin)" |
| 367 | [ramdisk]="$(gen_bin_url initrd.bin)" |
| 368 | [romlib]="$(gen_bin_url romlib.bin)" |
| 369 | [rootfs]="$(gen_bin_url rootfs.bin.gz)" |
| 370 | [host_flash_fip]="$(gen_bin_url host_flash_fip.bin)" |
Divin Raj | 5eb6948 | 2024-10-02 11:36:04 +0100 | [diff] [blame] | 371 | [rse_flash]="$(gen_bin_url rse_flash.bin)" |
David Vincze | d8ed562 | 2024-02-23 17:00:12 +0100 | [diff] [blame] | 372 | [rse_rom]="$(gen_bin_url rse_rom.bin)" |
| 373 | [rse_encrypted_cm_provisioning_bundle_0]="$(gen_bin_url rse_encrypted_cm_provisioning_bundle_0.bin)" |
| 374 | [rse_encrypted_dm_provisioning_bundle]="$(gen_bin_url rse_encrypted_dm_provisioning_bundle.bin)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 375 | [secure_hafnium]="$(gen_bin_url secure_hafnium.bin)" |
| 376 | [scp_fw]="$(gen_bin_url scp_fw.bin)" |
| 377 | [scp_ram]="$(gen_bin_url scp_ram.bin)" |
| 378 | [scp_ram_hyphen]="$(gen_bin_url scp-ram.bin)" |
| 379 | [scp_rom]="$(gen_bin_url scp_rom.bin)" |
| 380 | [scp_rom_hyphen]="$(gen_bin_url scp-rom.bin)" |
| 381 | [spm]="$(gen_bin_url spm.bin)" |
Manish V Badarkhe | 9589d40 | 2024-01-29 16:46:41 +0000 | [diff] [blame] | 382 | [tc_fitimage]="$(gen_bin_url tc_fitimage.bin)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 383 | [tftf]="$(gen_bin_url tftf.bin)" |
Harrison Mutai | 3ad377a | 2024-05-20 15:28:52 +0000 | [diff] [blame] | 384 | [tl]="$(gen_bin_url tl.bin)" |
Harrison Mutai | e512254 | 2023-03-27 13:14:18 +0100 | [diff] [blame] | 385 | [tmp]="$(gen_bin_url tmp.bin)" |
| 386 | [uboot]="$(gen_bin_url uboot.bin)" |
Chris Kay | c14743a | 2022-10-13 11:33:26 +0100 | [diff] [blame] | 387 | ) |
| 388 | |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 389 | # In LAVA we don't provide the paths to the artefacts directly, but instead |
| 390 | #Â use macros of the form `{XYZ}`. This is a list of regular expression |
| 391 | #Â replacements to run on the model parameters file before we add them to the |
| 392 | #Â LAVA job definition. |
Harrison Mutai | a6d6e68 | 2023-03-27 13:20:33 +0100 | [diff] [blame] | 393 | declare -A fvp_artefact_macros=( |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 394 | ["[= ]backup_fip.bin"]="={BACKUP_FIP}" |
| 395 | ["[= ]bl1.bin"]="={BL1}" |
| 396 | ["[= ]bl2.bin"]="={BL2}" |
| 397 | ["[= ]bl31.bin"]="={BL31}" |
| 398 | ["[= ]bl32.bin"]="={BL32}" |
Harrison Mutai | 3dcd1fe | 2025-03-24 13:19:29 +0000 | [diff] [blame] | 399 | ["[= ]boot_script.bin"]="={BOOT_SCRIPT}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 400 | ["[= ]cactus-primary.pkg"]="={CACTUS_PRIMARY}" |
| 401 | ["[= ]cactus-secondary.pkg"]="={CACTUS_SECONDARY}" |
| 402 | ["[= ]cactus-tertiary.pkg"]="={CACTUS_TERTIARY}" |
| 403 | ["[= ].*coverage_trace.so"]="={COVERAGE_TRACE_PLUGIN}" |
| 404 | ["[= ]fvp_spmc_manifest.dtb"]="={FVP_SPMC_MANIFEST_DTB}" |
| 405 | ["[= ]busybox.bin"]="={BUSYBOX}" |
| 406 | ["[= ]dtb.bin"]="={DTB}" |
| 407 | ["[= ]el3_payload.bin"]="={EL3_PAYLOAD}" |
| 408 | ["[= ]fip_gpt.bin"]="={FIP_GPT}" |
| 409 | ["[= ]fwu_fip.bin"]="={FWU_FIP}" |
| 410 | ["[= ]fip.bin"]="={FIP}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 411 | ["[= ].*/hafnium.bin"]="={HAFNIUM}" |
| 412 | ["[= ]kernel.bin"]="={IMAGE}" |
| 413 | ["[= ]ivy.pkg"]="={IVY}" |
| 414 | ["[= ]manifest.dtb"]="={MANIFEST_DTB}" |
Chris Kay | fbdd014 | 2022-11-08 12:24:30 +0000 | [diff] [blame] | 415 | ["[= ]mcp_fw.bin"]="={MCP_FW}" |
Manish V Badarkhe | 18c5978 | 2022-11-09 10:14:48 +0000 | [diff] [blame] | 416 | ["[= ]mcp_ram.bin"]="={MCP_RAM}" |
Chris Kay | ef9cc80 | 2022-11-08 12:11:58 +0000 | [diff] [blame] | 417 | ["[= ]mcp_rom.bin"]="={MCP_ROM}" |
| 418 | ["[= ]mcp-rom.bin"]="={MCP_ROM_HYPHEN}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 419 | ["[= ]ns_bl1u.bin"]="={NS_BL1U}" |
| 420 | ["[= ]ns_bl2u.bin"]="={NS_BL2U}" |
| 421 | ["[= ]initrd.bin"]="={RAMDISK}" |
| 422 | ["[= ]initrd.img"]="={RAMDISK}" |
| 423 | ["[= ]romlib.bin"]="={ROMLIB}" |
| 424 | ["[= ]rootfs.bin"]="={ROOTFS}" |
laurenw-arm | 60de274 | 2023-03-08 10:50:15 -0600 | [diff] [blame] | 425 | ["[= ]host_flash_fip.bin"]="={HOST_FLASH_FIP}" |
Divin Raj | 5eb6948 | 2024-10-02 11:36:04 +0100 | [diff] [blame] | 426 | ["[= ]rse_flash.bin"]="={RSE_FLASH}" |
David Vincze | d8ed562 | 2024-02-23 17:00:12 +0100 | [diff] [blame] | 427 | ["[= ]rse_rom.bin"]="={RSE_ROM}" |
| 428 | ["[= ]rse_encrypted_cm_provisioning_bundle_0.bin"]="={RSE_ENCRYPTED_CM_PROVISIONING_BUNDLE_0}" |
| 429 | ["[= ]rse_encrypted_dm_provisioning_bundle.bin"]="={RSE_ENCRYPTED_DM_PROVISIONING_BUNDLE}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 430 | ["[= ].*/secure_hafnium.bin"]="={SECURE_HAFNIUM}" |
Chris Kay | fbdd014 | 2022-11-08 12:24:30 +0000 | [diff] [blame] | 431 | ["[= ]scp_fw.bin"]="={SCP_FW}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 432 | ["[= ]scp_ram.bin"]="={SCP_RAM}" |
| 433 | ["[= ]scp-ram.bin"]="={SCP_RAM_HYPHEN}" |
| 434 | ["[= ]scp_rom.bin"]="={SCP_ROM}" |
| 435 | ["[= ]scp-rom.bin"]="={SCP_ROM_HYPHEN}" |
| 436 | ["[= ]spm.bin"]="={SPM}" |
Manish V Badarkhe | 9589d40 | 2024-01-29 16:46:41 +0000 | [diff] [blame] | 437 | ["[= ]tc_fitimage.bin"]="={TC_FITIMAGE}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 438 | ["[= ]tftf.bin"]="={TFTF}" |
Harrison Mutai | 3ad377a | 2024-05-20 15:28:52 +0000 | [diff] [blame] | 439 | ["[= ]tl.bin"]="={TL}" |
Chris Kay | 5d550d8 | 2022-10-12 17:20:31 +0100 | [diff] [blame] | 440 | ["[= ].*/tmp.bin"]="={TMP}" |
| 441 | ["[= ]uboot.bin"]="={UBOOT}" |
| 442 | ) |
| 443 | |
Harrison Mutai | a6d6e68 | 2023-03-27 13:20:33 +0100 | [diff] [blame] | 444 | declare -a fvp_artefacts |
| 445 | filter_artefacts fvp_artefacts fvp_artefact_filters |
Chris Kay | 4eb9ded | 2022-10-10 15:51:40 +0100 | [diff] [blame] | 446 | |
Harrison Mutai | a6d6e68 | 2023-03-27 13:20:33 +0100 | [diff] [blame] | 447 | lava_model_params="${lava_model_params}" \ |
| 448 | gen_lava_model_params fvp_artefact_macros |
Leonardo Sandoval | be690bd | 2020-10-12 17:59:39 -0500 | [diff] [blame] | 449 | |
Harrison Mutai | a6d6e68 | 2023-03-27 13:20:33 +0100 | [diff] [blame] | 450 | yaml_template_file="$yaml_template_file" \ |
| 451 | yaml_file="$yaml_file" \ |
| 452 | yaml_job_file="$yaml_job_file" \ |
| 453 | gen_lava_job_def fvp_artefacts fvp_artefact_urls |
Leonardo Sandoval | d76d1e2 | 2020-10-06 16:02:52 -0500 | [diff] [blame] | 454 | } |
| 455 | |
| 456 | docker_registry_append() { |
| 457 | # if docker_registry is empty, just use local docker registry |
| 458 | [ -z "$docker_registry" ] && return |
| 459 | |
| 460 | local last=-1 |
| 461 | local last_char="${docker_registry:last}" |
| 462 | |
| 463 | if [ "$last_char" != '/' ]; then |
| 464 | docker_registry="${docker_registry}/"; |
| 465 | fi |
| 466 | echo "$docker_registry" |
| 467 | } |
| 468 | |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 469 | # generate GPT image and archive it |
| 470 | gen_gpt_bin() { |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 471 | fip_bin="$1" |
| 472 | gpt_image="fip_gpt.bin" |
| 473 | # the FIP partition type is not standardized, so generate one |
| 474 | fip_type_uuid=`uuidgen --sha1 --namespace @dns --name "fip_type_uuid"` |
Manish V Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 475 | # metadata partition type UUID, specified by the document: |
| 476 | # Platform Security Firmware Update for the A-profile Arm Architecture |
| 477 | # version: 1.0BET0 |
| 478 | metadata_type_uuid="8a7a84a0-8387-40f6-ab41-a8b9a5a60d23" |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 479 | location_uuid=`uuidgen` |
| 480 | FIP_A_uuid=`uuidgen` |
| 481 | FIP_B_uuid=`uuidgen` |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 482 | |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 483 | fip_max_size=$2 |
Manish V Badarkhe | e79bc95 | 2024-01-25 14:34:37 +0000 | [diff] [blame] | 484 | partition_alignment=${3:-1} |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 485 | fip_bin_size=$(stat -c %s $fip_bin) |
| 486 | if [ $fip_max_size -lt $fip_bin_size ]; then |
| 487 | bberror "fip.bin ($fip_bin_size bytes) is larger than the GPT partition ($fip_max_size bytes)" |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 488 | fi |
| 489 | |
Manish V Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 490 | # maximum metadata size 512B. |
| 491 | # This is the current size of the metadata rounded up to an integer number of sectors. |
| 492 | metadata_max_size=512 |
| 493 | metadata_file="metadata.bin" |
| 494 | |
| 495 | # generate_fwu_metadata.py --metadata_file <file> \ |
| 496 | # --image_data "[(image_type_uuid, location_uuid, [image_uuid1, image_uuid2,...])]" |
| 497 | python3 $ci_root/generate_fwu_metadata.py --metadata_file $metadata_file \ |
| 498 | --image_data "[('$fip_type_uuid', '$location_uuid', ['$FIP_A_uuid', '$FIP_B_uuid'])]" |
| 499 | |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 500 | # create GPT image. The GPT contains 1 FIP partition: FIP_A. |
| 501 | # the GPT layout is the following: |
| 502 | # |
| 503 | # +----------------------+ |
| 504 | # LBA0 | Protective MBR | |
| 505 | # ------------------------ |
| 506 | # LBA1 | Primary GPT Header | |
| 507 | # ------------------------ |
| 508 | # LBA34| FIP_A | |
| 509 | # ------------------------ |
Manish V Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 510 | # | FIP_B | |
| 511 | # ------------------------ |
| 512 | # | FWU-Metadata | |
| 513 | # ------------------------ |
| 514 | # | Bkup-FWU-Metadata | |
| 515 | # ------------------------ |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 516 | # LBA-1| Secondary GPT Header | |
| 517 | # +----------------------+ |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 518 | |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 519 | sector_size=512 # in bytes |
| 520 | gpt_header_size=33 # in sectors |
| 521 | num_sectors_fip=`expr $fip_max_size / $sector_size` |
Manish V Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 522 | num_sectors_metadata=`expr $metadata_max_size / $sector_size` |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 523 | start_sector_1=`expr 1 + $gpt_header_size` # size of MBR is 1 sector |
Manish V Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 524 | start_sector_2=`expr $start_sector_1 + $num_sectors_fip` |
| 525 | start_sector_3=`expr $start_sector_2 + $num_sectors_fip` |
| 526 | start_sector_4=`expr $start_sector_3 + $num_sectors_metadata` |
| 527 | num_sectors_gpt=`expr $start_sector_4 + $num_sectors_metadata + $gpt_header_size` |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 528 | gpt_size=`expr $num_sectors_gpt \* $sector_size` |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 529 | |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 530 | # create raw image |
| 531 | dd if=/dev/zero of=$gpt_image bs=$gpt_size count=1 |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 532 | |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 533 | # create the GPT layout |
| 534 | sgdisk $gpt_image \ |
Manish V Badarkhe | e79bc95 | 2024-01-25 14:34:37 +0000 | [diff] [blame] | 535 | --set-alignment $partition_alignment \ |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 536 | --disk-guid $location_uuid \ |
| 537 | \ |
| 538 | --new 1:$start_sector_1:+$num_sectors_fip \ |
| 539 | --change-name 1:FIP_A \ |
| 540 | --typecode 1:$fip_type_uuid \ |
Manish V Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 541 | --partition-guid 1:$FIP_A_uuid \ |
| 542 | \ |
| 543 | --new 2:$start_sector_2:+$num_sectors_fip \ |
| 544 | --change-name 2:FIP_B \ |
| 545 | --typecode 2:$fip_type_uuid \ |
| 546 | --partition-guid 2:$FIP_B_uuid \ |
| 547 | \ |
| 548 | --new 3:$start_sector_3:+$num_sectors_metadata \ |
| 549 | --change-name 3:FWU-Metadata \ |
| 550 | --typecode 3:$metadata_type_uuid \ |
| 551 | \ |
| 552 | --new 4:$start_sector_4:+$num_sectors_metadata \ |
| 553 | --change-name 4:Bkup-FWU-Metadata \ |
| 554 | --typecode 4:$metadata_type_uuid |
Manish V Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 555 | |
| 556 | # populate the GPT partitions |
| 557 | 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 Badarkhe | 02bcfb1 | 2024-01-25 14:14:31 +0000 | [diff] [blame] | 558 | 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 |
| 559 | 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 |
| 560 | 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 Badarkhe | 048c968 | 2024-01-22 10:11:49 +0000 | [diff] [blame] | 561 | |
| 562 | echo "Built $gpt_image" |
| 563 | |
| 564 | archive_file "$gpt_image" |
Manish V Badarkhe | ea3e094 | 2021-03-05 11:51:48 +0000 | [diff] [blame] | 565 | } |
| 566 | |
Govindraj Raja | 6750173 | 2023-09-22 16:27:06 -0500 | [diff] [blame] | 567 | #corrupt GPT image header and archive it |
| 568 | corrupt_gpt_bin() { |
| 569 | bin="${1:?}" |
laurenw-arm | 2c6665f | 2024-02-09 16:08:34 -0600 | [diff] [blame] | 570 | corrupt_data=$2 |
Govindraj Raja | 6750173 | 2023-09-22 16:27:06 -0500 | [diff] [blame] | 571 | |
laurenw-arm | 2c6665f | 2024-02-09 16:08:34 -0600 | [diff] [blame] | 572 | # Check if parameters are provided |
| 573 | if [ -z "$bin" ] || [ -z "$corrupt_data" ]; then |
| 574 | echo "Usage: corrupt_gpt_bin <bin> <corrupt_data>" |
| 575 | return 1 |
| 576 | fi |
| 577 | |
| 578 | case "$corrupt_data" in |
| 579 | "header") |
| 580 | # Primary GPT header is present in LBA-1 second block after MBR |
| 581 | # empty the primary GPT header forcing to use backup GPT header |
| 582 | # and backup GPT entries. |
| 583 | seek=1 |
| 584 | count=1 |
| 585 | ;; |
| 586 | "partition-entries") |
| 587 | # GPT partition entry array is present in LBA-2 through LBA-34 |
| 588 | # blocks empty the GPT partition entry array forcing to use backup |
| 589 | # GPT header and backup GPT entries. |
| 590 | seek=2 |
| 591 | count=32 |
| 592 | ;; |
Manish V Badarkhe | b473c40 | 2024-02-14 16:50:08 +0000 | [diff] [blame] | 593 | "fwu-metadata") |
| 594 | # Get the LBA number for the FWU metadata. Size of which is always |
| 595 | # 1 sector (512 bytes). |
| 596 | seek=$(gdisk -l $bin | grep " FWU-Metadata$" | awk '{print $2}') |
| 597 | count=1 |
| 598 | ;; |
laurenw-arm | 2c6665f | 2024-02-09 16:08:34 -0600 | [diff] [blame] | 599 | *) |
| 600 | echo "Invalid $corrupt_data. Use 'header', 'partition-entries'" |
| 601 | return 1 |
| 602 | ;; |
| 603 | esac |
| 604 | |
| 605 | # Use parameters in the dd command |
| 606 | dd if=/dev/zero of=$bin bs=512 seek=$seek count=$count conv=notrunc |
Govindraj Raja | 6750173 | 2023-09-22 16:27:06 -0500 | [diff] [blame] | 607 | } |
| 608 | |
Fathi Boudra | 422bf77 | 2019-12-02 11:10:16 +0200 | [diff] [blame] | 609 | set +u |