xref: /qemu/tests/functional/test_aarch64_raspi4.py (revision 5831ed84e7e450a652f215721aba34ed4e1ffb97)
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éfrom qemu_test.utils import gzip_uncompress
11547738beSPhilippe Mathieu-Daudé
12547738beSPhilippe Mathieu-Daudé
13547738beSPhilippe Mathieu-Daudéclass Aarch64Raspi4Machine(LinuxKernelTest):
14547738beSPhilippe Mathieu-Daudé
15547738beSPhilippe Mathieu-Daudé    """
16547738beSPhilippe Mathieu-Daudé    The kernel can be rebuilt using the kernel source referenced
17547738beSPhilippe Mathieu-Daudé    and following the instructions on the on:
18547738beSPhilippe Mathieu-Daudé    https://www.raspberrypi.org/documentation/linux/kernel/building.md
19547738beSPhilippe Mathieu-Daudé    """
20547738beSPhilippe Mathieu-Daudé    ASSET_KERNEL_20190215 = Asset(
21547738beSPhilippe Mathieu-Daudé        ('http://archive.raspberrypi.org/debian/'
22547738beSPhilippe Mathieu-Daudé         'pool/main/r/raspberrypi-firmware/'
23547738beSPhilippe Mathieu-Daudé         'raspberrypi-kernel_1.20230106-1_arm64.deb'),
24547738beSPhilippe Mathieu-Daudé        '56d5713c8f6eee8a0d3f0e73600ec11391144fef318b08943e9abd94c0a9baf7')
25547738beSPhilippe Mathieu-Daudé
26547738beSPhilippe Mathieu-Daudé    ASSET_INITRD = Asset(
27547738beSPhilippe Mathieu-Daudé        ('https://github.com/groeck/linux-build-test/raw/'
28547738beSPhilippe Mathieu-Daudé         '86b2be1384d41c8c388e63078a847f1e1c4cb1de/rootfs/'
29547738beSPhilippe Mathieu-Daudé         'arm64/rootfs.cpio.gz'),
30547738beSPhilippe Mathieu-Daudé        '7c0b16d1853772f6f4c3ca63e789b3b9ff4936efac9c8a01fb0c98c05c7a7648')
31547738beSPhilippe Mathieu-Daudé
32547738beSPhilippe Mathieu-Daudé    def test_arm_raspi4(self):
33*5831ed84SDaniel P. Berrangé        kernel_path = self.archive_extract(self.ASSET_KERNEL_20190215,
34*5831ed84SDaniel P. Berrangé                                           member='boot/kernel8.img')
35*5831ed84SDaniel P. Berrangé        dtb_path = self.archive_extract(self.ASSET_KERNEL_20190215,
36*5831ed84SDaniel P. Berrangé                                        member='boot/bcm2711-rpi-4-b.dtb')
37547738beSPhilippe Mathieu-Daudé
38547738beSPhilippe Mathieu-Daudé        self.set_machine('raspi4b')
39547738beSPhilippe Mathieu-Daudé        self.vm.set_console()
40547738beSPhilippe Mathieu-Daudé        kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE +
41547738beSPhilippe Mathieu-Daudé                               'earlycon=pl011,mmio32,0xfe201000 ' +
42547738beSPhilippe Mathieu-Daudé                               'console=ttyAMA0,115200 ' +
43547738beSPhilippe Mathieu-Daudé                               'root=/dev/mmcblk1p2 rootwait ' +
44547738beSPhilippe Mathieu-Daudé                               'dwc_otg.fiq_fsm_enable=0')
45547738beSPhilippe Mathieu-Daudé        self.vm.add_args('-kernel', kernel_path,
46547738beSPhilippe Mathieu-Daudé                         '-dtb', dtb_path,
47547738beSPhilippe Mathieu-Daudé                         '-append', kernel_command_line)
48547738beSPhilippe Mathieu-Daudé        # When PCI is supported we can add a USB controller:
49547738beSPhilippe Mathieu-Daudé        #                '-device', 'qemu-xhci,bus=pcie.1,id=xhci',
50547738beSPhilippe Mathieu-Daudé        #                '-device', 'usb-kbd,bus=xhci.0',
51547738beSPhilippe Mathieu-Daudé        self.vm.launch()
52547738beSPhilippe Mathieu-Daudé        console_pattern = 'Kernel command line: %s' % kernel_command_line
53547738beSPhilippe Mathieu-Daudé        self.wait_for_console_pattern(console_pattern)
54547738beSPhilippe Mathieu-Daudé        # When USB is enabled we can look for this
55547738beSPhilippe Mathieu-Daudé        # console_pattern = 'Product: QEMU USB Keyboard'
56547738beSPhilippe Mathieu-Daudé        # self.wait_for_console_pattern(console_pattern)
57547738beSPhilippe Mathieu-Daudé        console_pattern = 'Waiting for root device'
58547738beSPhilippe Mathieu-Daudé        self.wait_for_console_pattern(console_pattern)
59547738beSPhilippe Mathieu-Daudé
60547738beSPhilippe Mathieu-Daudé
61547738beSPhilippe Mathieu-Daudé    def test_arm_raspi4_initrd(self):
62*5831ed84SDaniel P. Berrangé        kernel_path = self.archive_extract(self.ASSET_KERNEL_20190215,
63*5831ed84SDaniel P. Berrangé                                           member='boot/kernel8.img')
64*5831ed84SDaniel P. Berrangé        dtb_path = self.archive_extract(self.ASSET_KERNEL_20190215,
65*5831ed84SDaniel P. Berrangé                                        member='boot/bcm2711-rpi-4-b.dtb')
66547738beSPhilippe Mathieu-Daudé        initrd_path_gz = self.ASSET_INITRD.fetch()
67beaf88c8SDaniel P. Berrangé        initrd_path = self.scratch_file('rootfs.cpio')
68547738beSPhilippe Mathieu-Daudé        gzip_uncompress(initrd_path_gz, initrd_path)
69547738beSPhilippe Mathieu-Daudé
70547738beSPhilippe Mathieu-Daudé        self.set_machine('raspi4b')
71547738beSPhilippe Mathieu-Daudé        self.vm.set_console()
72547738beSPhilippe Mathieu-Daudé        kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE +
73547738beSPhilippe Mathieu-Daudé                               'earlycon=pl011,mmio32,0xfe201000 ' +
74547738beSPhilippe Mathieu-Daudé                               'console=ttyAMA0,115200 ' +
75547738beSPhilippe Mathieu-Daudé                               'panic=-1 noreboot ' +
76547738beSPhilippe Mathieu-Daudé                               'dwc_otg.fiq_fsm_enable=0')
77547738beSPhilippe Mathieu-Daudé        self.vm.add_args('-kernel', kernel_path,
78547738beSPhilippe Mathieu-Daudé                         '-dtb', dtb_path,
79547738beSPhilippe Mathieu-Daudé                         '-initrd', initrd_path,
80547738beSPhilippe Mathieu-Daudé                         '-append', kernel_command_line,
81547738beSPhilippe Mathieu-Daudé                         '-no-reboot')
82547738beSPhilippe Mathieu-Daudé        # When PCI is supported we can add a USB controller:
83547738beSPhilippe Mathieu-Daudé        #                '-device', 'qemu-xhci,bus=pcie.1,id=xhci',
84547738beSPhilippe Mathieu-Daudé        #                '-device', 'usb-kbd,bus=xhci.0',
85547738beSPhilippe Mathieu-Daudé        self.vm.launch()
86547738beSPhilippe Mathieu-Daudé        self.wait_for_console_pattern('Boot successful.')
87547738beSPhilippe Mathieu-Daudé
88547738beSPhilippe Mathieu-Daudé        exec_command_and_wait_for_pattern(self, 'cat /proc/cpuinfo',
89547738beSPhilippe Mathieu-Daudé                                                'BCM2835')
90547738beSPhilippe Mathieu-Daudé        exec_command_and_wait_for_pattern(self, 'cat /proc/iomem',
91547738beSPhilippe Mathieu-Daudé                                                'cprman@7e101000')
92547738beSPhilippe Mathieu-Daudé        exec_command_and_wait_for_pattern(self, 'halt', 'reboot: System halted')
93547738beSPhilippe Mathieu-Daudé        # TODO: Raspberry Pi4 doesn't shut down properly with recent kernels
94547738beSPhilippe Mathieu-Daudé        # Wait for VM to shut down gracefully
95547738beSPhilippe Mathieu-Daudé        #self.vm.wait()
96547738beSPhilippe Mathieu-Daudé
97547738beSPhilippe Mathieu-Daudé
98547738beSPhilippe Mathieu-Daudéif __name__ == '__main__':
99547738beSPhilippe Mathieu-Daudé    LinuxKernelTest.main()
100