123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- import os
- import infra.basetest
- class TestEdk2(infra.basetest.BRTest):
- config = \
- """
- BR2_aarch64=y
- BR2_neoverse_n1=y
- BR2_TOOLCHAIN_EXTERNAL=y
- BR2_TARGET_GENERIC_GETTY_PORT="ttyAMA0"
- BR2_TARGET_ROOTFS_EXT2=y
- BR2_TARGET_ROOTFS_EXT2_4=y
- # BR2_TARGET_ROOTFS_TAR is not set
- BR2_ROOTFS_POST_IMAGE_SCRIPT="board/qemu/aarch64-sbsa/assemble-flash-images support/scripts/genimage.sh"
- BR2_ROOTFS_POST_SCRIPT_ARGS="-c board/qemu/aarch64-sbsa/genimage.cfg"
- BR2_LINUX_KERNEL=y
- BR2_LINUX_KERNEL_CUSTOM_VERSION=y
- BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE="6.6.58"
- BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y
- BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="support/testing/tests/boot/test_edk2/linux.config"
- BR2_TARGET_EDK2=y
- BR2_TARGET_EDK2_PLATFORM_QEMU_SBSA=y
- BR2_TARGET_GRUB2=y
- BR2_TARGET_GRUB2_ARM64_EFI=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_CUSTOM_VERSION=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_CUSTOM_VERSION_VALUE="v2.12"
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_PLATFORM="qemu_sbsa"
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_FIP=y
- BR2_PACKAGE_HOST_GENIMAGE=y
- BR2_PACKAGE_HOST_DOSFSTOOLS=y
- BR2_PACKAGE_HOST_MTOOLS=y
- BR2_PACKAGE_HOST_QEMU=y
- BR2_PACKAGE_HOST_QEMU_SYSTEM_MODE=y
- """
- def test_run(self):
- hda = os.path.join(self.builddir, "images", "disk.img")
- flash0 = os.path.join(self.builddir, "images", "SBSA_FLASH0.fd")
- flash1 = os.path.join(self.builddir, "images", "SBSA_FLASH1.fd")
- self.emulator.boot(arch="aarch64",
- options=["-M", "sbsa-ref",
- "-cpu", "neoverse-n1",
- "-m", "512M",
- "-pflash", flash0,
- "-pflash", flash1,
- "-hda", hda])
- self.emulator.login()
- class TestEdk2BuildBase(infra.basetest.BRTest):
- """A class to test the build of various edk2 platforms."""
- base_config = \
- """
- # BR2_PACKAGE_BUSYBOX is not set
- # BR2_PACKAGE_IFUPDOWN_SCRIPTS is not set
- # BR2_TARGET_ROOTFS_TAR is not set
- BR2_INIT_NONE=y
- BR2_SYSTEM_BIN_SH_NONE=y
- BR2_TARGET_EDK2=y
- BR2_TOOLCHAIN_EXTERNAL=y
- """
- def assertBinariesExist(self, *binaries: str) -> None:
- """Assert that the binaries passed as argument exist
- under the images folder.
- We print a message to the emulator logfile for each binary found.
- """
- for binary in binaries:
- binpath = os.path.join(self.builddir, "images", binary)
- self.assertTrue(os.path.exists(binpath), f"Missing {binpath}!")
- print(f"{binary} exists: {binpath}", file=self.emulator.logfile,
- flush=True)
- class TestEdk2BuildArmVirtQemu(TestEdk2BuildBase):
- config = TestEdk2BuildBase.base_config + \
- """
- BR2_aarch64=y
- BR2_TARGET_EDK2_PLATFORM_ARM_VIRT_QEMU=y
- """
- def test_run(self) -> None:
- self.assertBinariesExist("QEMU_EFI.fd", "QEMU_VARS.fd")
- class TestEdk2BuildArmVirtQemuKernel(TestEdk2BuildBase):
- config = TestEdk2BuildBase.base_config + \
- """
- BR2_aarch64=y
- BR2_TARGET_EDK2_PLATFORM_ARM_VIRT_QEMU_KERNEL=y
- """
- def test_run(self) -> None:
- self.assertBinariesExist("QEMU_EFI.fd", "QEMU_VARS.fd")
- class TestEdk2BuildArmSgi575(TestEdk2BuildBase):
- config = TestEdk2BuildBase.base_config + \
- """
- BR2_aarch64=y
- BR2_TARGET_EDK2_PLATFORM_ARM_SGI575=y
- """
- def test_run(self) -> None:
- self.assertBinariesExist("BL33_AP_UEFI.fd")
- class TestEdk2BuildArmVexpressFvpAarch64(TestEdk2BuildBase):
- config = TestEdk2BuildBase.base_config + \
- """
- BR2_aarch64=y
- BR2_TARGET_EDK2_PLATFORM_ARM_VEXPRESS_FVP_AARCH64=y
- """
- def test_run(self) -> None:
- self.assertBinariesExist("FVP_AARCH64_EFI.fd")
- class TestEdk2BuildQemuSbsa(TestEdk2BuildBase):
- # This configuration is not exactly identical to the configuration built
- # during TestEdk2, as we use the latest arm-trusted-firmware version, among
- # other things.
- config = TestEdk2BuildBase.base_config + \
- """
- BR2_aarch64=y
- BR2_TARGET_EDK2_PLATFORM_QEMU_SBSA=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_PLATFORM="qemu_sbsa"
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_FIP=y
- """
- def test_run(self) -> None:
- self.assertBinariesExist("SBSA_FLASH0.fd", "SBSA_FLASH1.fd", "fip.bin")
- class TestEdk2BuildSolidrunArmada80x0mcbin(TestEdk2BuildBase):
- config = TestEdk2BuildBase.base_config + \
- """
- BR2_aarch64=y
- BR2_cortex_a72=y
- BR2_TARGET_EDK2_PLATFORM_SOLIDRUN_ARMADA80X0MCBIN=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE=y
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_PLATFORM="a80x0_mcbin"
- BR2_TARGET_ARM_TRUSTED_FIRMWARE_EDK2_AS_BL33=y
- BR2_TARGET_BINARIES_MARVELL=y
- BR2_TARGET_MV_DDR_MARVELL=y
- """
- def test_run(self) -> None:
- self.assertBinariesExist("ARMADA_EFI.fd", "fip.bin", "ble.bin",
- "scp-fw.bin")
|