1547738beSPhilippe Mathieu-Daudé#!/usr/bin/env python3 2547738beSPhilippe Mathieu-Daudé# 3547738beSPhilippe Mathieu-Daudé# Functional test that boots a Linux kernel on a Raspberry Pi machine 4547738beSPhilippe Mathieu-Daudé# and checks the console 5547738beSPhilippe Mathieu-Daudé# 6547738beSPhilippe Mathieu-Daudé# SPDX-License-Identifier: GPL-2.0-or-later 7547738beSPhilippe Mathieu-Daudé 8547738beSPhilippe Mathieu-Daudéfrom qemu_test import LinuxKernelTest, Asset 9547738beSPhilippe Mathieu-Daudéfrom qemu_test import exec_command_and_wait_for_pattern 10547738beSPhilippe Mathieu-Daudé 11547738beSPhilippe Mathieu-Daudé 12547738beSPhilippe Mathieu-Daudéclass Aarch64Raspi4Machine(LinuxKernelTest): 13547738beSPhilippe Mathieu-Daudé 14547738beSPhilippe Mathieu-Daudé """ 15547738beSPhilippe Mathieu-Daudé The kernel can be rebuilt using the kernel source referenced 16547738beSPhilippe Mathieu-Daudé and following the instructions on the on: 17547738beSPhilippe Mathieu-Daudé https://www.raspberrypi.org/documentation/linux/kernel/building.md 18547738beSPhilippe Mathieu-Daudé """ 19547738beSPhilippe Mathieu-Daudé ASSET_KERNEL_20190215 = Asset( 20547738beSPhilippe Mathieu-Daudé ('http://archive.raspberrypi.org/debian/' 21547738beSPhilippe Mathieu-Daudé 'pool/main/r/raspberrypi-firmware/' 22547738beSPhilippe Mathieu-Daudé 'raspberrypi-kernel_1.20230106-1_arm64.deb'), 23547738beSPhilippe Mathieu-Daudé '56d5713c8f6eee8a0d3f0e73600ec11391144fef318b08943e9abd94c0a9baf7') 24547738beSPhilippe Mathieu-Daudé 25547738beSPhilippe Mathieu-Daudé ASSET_INITRD = Asset( 26547738beSPhilippe Mathieu-Daudé ('https://github.com/groeck/linux-build-test/raw/' 27547738beSPhilippe Mathieu-Daudé '86b2be1384d41c8c388e63078a847f1e1c4cb1de/rootfs/' 28547738beSPhilippe Mathieu-Daudé 'arm64/rootfs.cpio.gz'), 29547738beSPhilippe Mathieu-Daudé '7c0b16d1853772f6f4c3ca63e789b3b9ff4936efac9c8a01fb0c98c05c7a7648') 30547738beSPhilippe Mathieu-Daudé 31547738beSPhilippe Mathieu-Daudé def test_arm_raspi4(self): 325831ed84SDaniel P. Berrangé kernel_path = self.archive_extract(self.ASSET_KERNEL_20190215, 335831ed84SDaniel P. Berrangé member='boot/kernel8.img') 345831ed84SDaniel P. Berrangé dtb_path = self.archive_extract(self.ASSET_KERNEL_20190215, 355831ed84SDaniel P. Berrangé member='boot/bcm2711-rpi-4-b.dtb') 36547738beSPhilippe Mathieu-Daudé 37547738beSPhilippe Mathieu-Daudé self.set_machine('raspi4b') 38547738beSPhilippe Mathieu-Daudé self.vm.set_console() 39547738beSPhilippe Mathieu-Daudé kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE + 40547738beSPhilippe Mathieu-Daudé 'earlycon=pl011,mmio32,0xfe201000 ' + 41547738beSPhilippe Mathieu-Daudé 'console=ttyAMA0,115200 ' + 42547738beSPhilippe Mathieu-Daudé 'root=/dev/mmcblk1p2 rootwait ' + 43547738beSPhilippe Mathieu-Daudé 'dwc_otg.fiq_fsm_enable=0') 44547738beSPhilippe Mathieu-Daudé self.vm.add_args('-kernel', kernel_path, 45547738beSPhilippe Mathieu-Daudé '-dtb', dtb_path, 46547738beSPhilippe Mathieu-Daudé '-append', kernel_command_line) 47547738beSPhilippe Mathieu-Daudé # When PCI is supported we can add a USB controller: 48547738beSPhilippe Mathieu-Daudé # '-device', 'qemu-xhci,bus=pcie.1,id=xhci', 49547738beSPhilippe Mathieu-Daudé # '-device', 'usb-kbd,bus=xhci.0', 50547738beSPhilippe Mathieu-Daudé self.vm.launch() 51547738beSPhilippe Mathieu-Daudé console_pattern = 'Kernel command line: %s' % kernel_command_line 52547738beSPhilippe Mathieu-Daudé self.wait_for_console_pattern(console_pattern) 53547738beSPhilippe Mathieu-Daudé # When USB is enabled we can look for this 54547738beSPhilippe Mathieu-Daudé # console_pattern = 'Product: QEMU USB Keyboard' 55547738beSPhilippe Mathieu-Daudé # self.wait_for_console_pattern(console_pattern) 56547738beSPhilippe Mathieu-Daudé console_pattern = 'Waiting for root device' 57547738beSPhilippe Mathieu-Daudé self.wait_for_console_pattern(console_pattern) 58547738beSPhilippe Mathieu-Daudé 59547738beSPhilippe Mathieu-Daudé 60547738beSPhilippe Mathieu-Daudé def test_arm_raspi4_initrd(self): 615831ed84SDaniel P. Berrangé kernel_path = self.archive_extract(self.ASSET_KERNEL_20190215, 625831ed84SDaniel P. Berrangé member='boot/kernel8.img') 635831ed84SDaniel P. Berrangé dtb_path = self.archive_extract(self.ASSET_KERNEL_20190215, 645831ed84SDaniel P. Berrangé member='boot/bcm2711-rpi-4-b.dtb') 65*65d35a4eSDaniel P. Berrangé initrd_path = self.uncompress(self.ASSET_INITRD) 66547738beSPhilippe Mathieu-Daudé 67547738beSPhilippe Mathieu-Daudé self.set_machine('raspi4b') 68547738beSPhilippe Mathieu-Daudé self.vm.set_console() 69547738beSPhilippe Mathieu-Daudé kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE + 70547738beSPhilippe Mathieu-Daudé 'earlycon=pl011,mmio32,0xfe201000 ' + 71547738beSPhilippe Mathieu-Daudé 'console=ttyAMA0,115200 ' + 72547738beSPhilippe Mathieu-Daudé 'panic=-1 noreboot ' + 73547738beSPhilippe Mathieu-Daudé 'dwc_otg.fiq_fsm_enable=0') 74547738beSPhilippe Mathieu-Daudé self.vm.add_args('-kernel', kernel_path, 75547738beSPhilippe Mathieu-Daudé '-dtb', dtb_path, 76547738beSPhilippe Mathieu-Daudé '-initrd', initrd_path, 77547738beSPhilippe Mathieu-Daudé '-append', kernel_command_line, 78547738beSPhilippe Mathieu-Daudé '-no-reboot') 79547738beSPhilippe Mathieu-Daudé # When PCI is supported we can add a USB controller: 80547738beSPhilippe Mathieu-Daudé # '-device', 'qemu-xhci,bus=pcie.1,id=xhci', 81547738beSPhilippe Mathieu-Daudé # '-device', 'usb-kbd,bus=xhci.0', 82547738beSPhilippe Mathieu-Daudé self.vm.launch() 83547738beSPhilippe Mathieu-Daudé self.wait_for_console_pattern('Boot successful.') 84547738beSPhilippe Mathieu-Daudé 85547738beSPhilippe Mathieu-Daudé exec_command_and_wait_for_pattern(self, 'cat /proc/cpuinfo', 86547738beSPhilippe Mathieu-Daudé 'BCM2835') 87547738beSPhilippe Mathieu-Daudé exec_command_and_wait_for_pattern(self, 'cat /proc/iomem', 88547738beSPhilippe Mathieu-Daudé 'cprman@7e101000') 89547738beSPhilippe Mathieu-Daudé exec_command_and_wait_for_pattern(self, 'halt', 'reboot: System halted') 90547738beSPhilippe Mathieu-Daudé # TODO: Raspberry Pi4 doesn't shut down properly with recent kernels 91547738beSPhilippe Mathieu-Daudé # Wait for VM to shut down gracefully 92547738beSPhilippe Mathieu-Daudé #self.vm.wait() 93547738beSPhilippe Mathieu-Daudé 94547738beSPhilippe Mathieu-Daudé 95547738beSPhilippe Mathieu-Daudéif __name__ == '__main__': 96547738beSPhilippe Mathieu-Daudé LinuxKernelTest.main() 97