xref: /qemu/tests/functional/test_aarch64_raspi4.py (revision ba182a693fe15a4f6f2a04e8ecb865c2630e5a16)
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