[PATCH 07/32] scripts: Update build-efi to support arm64
Simon Glass
sjg at chromium.org
Sat Feb 15 13:05:06 CET 2025
Hi Heinrich,
On Sun, 9 Feb 2025 at 12:05, Heinrich Schuchardt <xypron.glpk at gmx.de> wrote:
>
> Am 3. Februar 2025 18:42:00 MEZ schrieb Simon Glass <sjg at chromium.org>:
> >Provide a -A flag to select ARM instead of x86. For now, only the app
> >is supported and only for 64-bit ARM.
> >
> >Signed-off-by: Simon Glass <sjg at chromium.org>
> >---
> >
> > scripts/build-efi.py | 49 +++++++++++++++++++++++++++++++-------------
> > 1 file changed, 35 insertions(+), 14 deletions(-)
> >
> >diff --git a/scripts/build-efi.py b/scripts/build-efi.py
> >index 3a1bf180ade..1ba37e86e88 100755
> >--- a/scripts/build-efi.py
> >+++ b/scripts/build-efi.py
> >@@ -48,6 +48,8 @@ def parse_args():
> > epilog='Script for running U-Boot as an EFI app/payload')
> > parser.add_argument('-a', '--app', action='store_true',
> > help='Package up the app')
> >+ parser.add_argument('-A', '--arm', action='store_true',
>
> Why have a flag per EFI architecture?
>
> Please add a parameterized flag instead.
>
> --arch i386
> --arch x64
> --arch arm
> --arch aarch64
> --arch riscv64
>
> and get rid of the bitness parameter.
Tom has rejected this for the tree. I'll apply it to my tree and then
deal with this comments with another patch. But I'm thinking a
contrib/ directory would be better.
>
> >+ help='Run on ARM architecture')
> > parser.add_argument('-B', '--no-build', action='store_true',
> > help="Don't build (an existing build must be present")
> > parser.add_argument('-k', '--kernel', action='store_true',
> >@@ -131,26 +133,43 @@ class BuildEfi:
> > """
> > extra = []
> > efi_dir = self.get_setting("efi_dir")
> >- if bitness == 64:
> >- qemu = 'qemu-system-x86_64'
> >- bios = 'OVMF-pure-efi.x64.fd'
> >- else:
> >- qemu = 'qemu-system-i386'
> >- bios = 'OVMF-pure-efi.i386.fd'
> >+ if self.args.arm:
> >+ qemu_arch = 'aarch64'
> >+ extra += ['--machine', 'virt', '-cpu', 'max']
> >+ bios = os.path.join(efi_dir, 'OVMF-pure-efi.aarch64.fd.64m')
> >+ var_store = os.path.join(efi_dir, 'varstore.img')
> >+ extra += [
> >+ '-drive', f'if=pflash,format=raw,file={bios},readonly=on',
> >+ '-drive', f'if=pflash,format=raw,file={var_store}'
> >+ ]
> >+ extra += ['-drive',
> >+ f'id=hd0,file={self.img},if=none,format=raw',
> >+ '-device', 'virtio-blk-device,drive=hd0']
> >+ else: # x86
> >+ if bitness == 64:
> >+ qemu_arch = 'x86_64'
> >+ bios = 'OVMF-pure-efi.x64.fd'
>
> Not a filename used by EDK II or by QEMU.
How best to handle this? The edk2.git-ovmf-x64 package has
/usr/share/edk2.git/ovmf-x64/OVMF-pure-efi.fd
but I cannot find similar packages for arm64. For ARM, the file has to
be extended to the correct size.
[..]
Regards,
Simon
More information about the U-Boot
mailing list