[PATCH 3/7] efi: test: Create a disk image with and EFI app in it
Heinrich Schuchardt
xypron.glpk at gmx.de
Tue Nov 21 18:32:01 CET 2023
On 11/21/23 12:35, Simon Glass wrote:
> Create a new disk for use with test, which contains the sandbox
> helloworld app. This will be used to test the EFI boot bootmeth.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
>
> test/py/tests/test_ut.py | 32 ++++++++++++++++++++++++++++++++
> 1 file changed, 32 insertions(+)
>
> diff --git a/test/py/tests/test_ut.py b/test/py/tests/test_ut.py
> index 1d9149a3f683..f6220c05238a 100644
> --- a/test/py/tests/test_ut.py
> +++ b/test/py/tests/test_ut.py
> @@ -468,6 +468,37 @@ def test_ut_dm_init(u_boot_console):
> with open(fn, 'wb') as fh:
> fh.write(data)
>
> +
> +def setup_efi_image(cons):
> + """Create a 20MB disk image with an EFI app on it"""
> + mmc_dev = 7
> + fname, mnt = setup_image(cons, mmc_dev, 0xc, second_part=True)
If you would set the partition type GUID to ESP, U-Boot would stop to
complain about EFI variable that cannot be persisted.
There is a pending patch that wants to make the failure to persist EFI
variable fatal.
[RESEND,v2] efi_loader: Fix UEFI variable error handling
https://patchwork.ozlabs.org/project/uboot/patch/20231113161031.138304-1-o451686892@gmail.com/
Best regards
Heinrich
> +
> + loop = None
> + mounted = False
> + try:
> + loop = mount_image(cons, fname, mnt, 'ext4')
> + mounted = True
> + efi_dir = os.path.join(mnt, 'efi')
> + mkdir_cond(efi_dir)
> + bootdir = os.path.join(efi_dir, 'boot')
> + mkdir_cond(bootdir)
> + efi_src = os.path.join(cons.config.build_dir,
> + f'lib/efi_loader/helloworld.efi')
> + efi_dst = os.path.join(bootdir, 'bootsbox.efi')
> + with open(efi_src, 'rb') as inf:
> + with open(efi_dst, 'wb') as outf:
> + outf.write(inf.read())
> +
> + finally:
> + if mounted:
> + u_boot_utils.run_and_log(cons, 'sudo umount --lazy %s' % mnt)
> + if loop:
> + u_boot_utils.run_and_log(cons, 'sudo losetup -d %s' % loop)
> +
> +
> +
> +
> @pytest.mark.buildconfigspec('cmd_bootflow')
> def test_ut_dm_init_bootstd(u_boot_console):
> """Initialise data for bootflow tests"""
> @@ -476,6 +507,7 @@ def test_ut_dm_init_bootstd(u_boot_console):
> setup_bootmenu_image(u_boot_console)
> setup_cedit_file(u_boot_console)
> setup_cros_image(u_boot_console)
> + setup_efi_image(u_boot_console)
>
> # Restart so that the new mmc1.img is picked up
> u_boot_console.restart_uboot()
More information about the U-Boot
mailing list