coreboot-kgpe-d16/Documentation/mainboard/emulation/qemu-aarch64.md
Asami Doi a5d9e7a628 mainboard/emulation/qemu-aarch64: Update DRAM_SIZE_MB
DRAM_SIZE_MB should be the maximum size (255GiB / -m 261120M)
that’s possible with QEMU on AArch64 virt because it tries to search
the DRAM_SIZE_MB range to find the true memory size.

Signed-off-by: Asami Doi <d0iasm.pub@gmail.com>
Change-Id: Id479c0b18d1e1adceecdcca13e36119b95617e6d
Reviewed-on: https://review.coreboot.org/c/coreboot/+/35024
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Raul Rangel <rrangel@chromium.org>
2019-08-26 07:15:06 +00:00

1.8 KiB

QEMU AArch64 emulator

This page discribes how to build and run coreboot for QEMU/AArch64. You can use LinuxBoot via make menuconfig or an arbitrary FIT image as a payload for QEMU/AArch64.

Running coreboot in QEMU

qemu-system-aarch64 -bios ./build/coreboot.rom \
    -M virt,secure=on,virtualization=on -cpu cortex-a53 \
    -nographic -m 8192M
  • The default CPU in QEMU for AArch64 is a cortex-a15 which is 32-bit ARM CPU. You need to specify 64-bit ARM CPU via -cpu cortex-a53.
  • The default privilege level in QEMU for AArch64 is EL1 that we can't have the right to access EL3/EL2 registers. You need to enable EL3/EL2 via -machine secure=on,virtualization=on.
  • You need to specify the size of memory more than 544 MiB because 512 MiB is reserved for the kernel.
  • The maximum size of memory is 255GiB (-m 261120).

Building coreboot with an arbitrary FIT payload

There are 3 steps to make coreboot.rom for QEMU/AArch64. If you select LinuxBoot, step 2 and 3 have done by LinuxBoot.

  1. Get a DTB (Device Tree Blob)
  2. Build a FIT image with a DTB
  3. Add a FIT image to coreboot.rom

1. Get a DTB

You can get the DTB from QEMU with the following command.

$ qemu-system-aarch64 \
    -M virt,dumpdtb=virt.dtb,secure=on,virtualization=on \
    -cpu cortex-a53 -nographic -m 8192M

2. Build a FIT image with a DTB

You need to write an image source file that has an .its extension to configure kernels, ramdisks, and DTBs. See Flattened uImage Tree documentation for more details.

3. Add a FIT image to coreboot.rom

You can use cbfstool to add the payload you created in step 2 to the coreboot.rom.

$ ./build/cbfstool ./build/coreboot.rom add -f <path-to-a-payload>/uImage \
    -n fallback/payload -t fit -c lzma