100 lines
4.2 KiB
Python
100 lines
4.2 KiB
Python
|
#!/usr/bin/env python3
|
||
|
#
|
||
|
# Functional test that boots a Linux kernel on a Raspberry Pi machine
|
||
|
# and checks the console
|
||
|
#
|
||
|
# SPDX-License-Identifier: GPL-2.0-or-later
|
||
|
|
||
|
import os
|
||
|
|
||
|
from qemu_test import LinuxKernelTest, Asset
|
||
|
from qemu_test import exec_command_and_wait_for_pattern
|
||
|
from qemu_test.utils import gzip_uncompress
|
||
|
|
||
|
|
||
|
class Aarch64Raspi4Machine(LinuxKernelTest):
|
||
|
|
||
|
"""
|
||
|
The kernel can be rebuilt using the kernel source referenced
|
||
|
and following the instructions on the on:
|
||
|
https://www.raspberrypi.org/documentation/linux/kernel/building.md
|
||
|
"""
|
||
|
ASSET_KERNEL_20190215 = Asset(
|
||
|
('http://archive.raspberrypi.org/debian/'
|
||
|
'pool/main/r/raspberrypi-firmware/'
|
||
|
'raspberrypi-kernel_1.20230106-1_arm64.deb'),
|
||
|
'56d5713c8f6eee8a0d3f0e73600ec11391144fef318b08943e9abd94c0a9baf7')
|
||
|
|
||
|
ASSET_INITRD = Asset(
|
||
|
('https://github.com/groeck/linux-build-test/raw/'
|
||
|
'86b2be1384d41c8c388e63078a847f1e1c4cb1de/rootfs/'
|
||
|
'arm64/rootfs.cpio.gz'),
|
||
|
'7c0b16d1853772f6f4c3ca63e789b3b9ff4936efac9c8a01fb0c98c05c7a7648')
|
||
|
|
||
|
def test_arm_raspi4(self):
|
||
|
deb_path = self.ASSET_KERNEL_20190215.fetch()
|
||
|
kernel_path = self.extract_from_deb(deb_path, '/boot/kernel8.img')
|
||
|
dtb_path = self.extract_from_deb(deb_path, '/boot/bcm2711-rpi-4-b.dtb')
|
||
|
|
||
|
self.set_machine('raspi4b')
|
||
|
self.vm.set_console()
|
||
|
kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE +
|
||
|
'earlycon=pl011,mmio32,0xfe201000 ' +
|
||
|
'console=ttyAMA0,115200 ' +
|
||
|
'root=/dev/mmcblk1p2 rootwait ' +
|
||
|
'dwc_otg.fiq_fsm_enable=0')
|
||
|
self.vm.add_args('-kernel', kernel_path,
|
||
|
'-dtb', dtb_path,
|
||
|
'-append', kernel_command_line)
|
||
|
# When PCI is supported we can add a USB controller:
|
||
|
# '-device', 'qemu-xhci,bus=pcie.1,id=xhci',
|
||
|
# '-device', 'usb-kbd,bus=xhci.0',
|
||
|
self.vm.launch()
|
||
|
console_pattern = 'Kernel command line: %s' % kernel_command_line
|
||
|
self.wait_for_console_pattern(console_pattern)
|
||
|
# When USB is enabled we can look for this
|
||
|
# console_pattern = 'Product: QEMU USB Keyboard'
|
||
|
# self.wait_for_console_pattern(console_pattern)
|
||
|
console_pattern = 'Waiting for root device'
|
||
|
self.wait_for_console_pattern(console_pattern)
|
||
|
|
||
|
|
||
|
def test_arm_raspi4_initrd(self):
|
||
|
deb_path = self.ASSET_KERNEL_20190215.fetch()
|
||
|
kernel_path = self.extract_from_deb(deb_path, '/boot/kernel8.img')
|
||
|
dtb_path = self.extract_from_deb(deb_path, '/boot/bcm2711-rpi-4-b.dtb')
|
||
|
initrd_path_gz = self.ASSET_INITRD.fetch()
|
||
|
initrd_path = os.path.join(self.workdir, 'rootfs.cpio')
|
||
|
gzip_uncompress(initrd_path_gz, initrd_path)
|
||
|
|
||
|
self.set_machine('raspi4b')
|
||
|
self.vm.set_console()
|
||
|
kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE +
|
||
|
'earlycon=pl011,mmio32,0xfe201000 ' +
|
||
|
'console=ttyAMA0,115200 ' +
|
||
|
'panic=-1 noreboot ' +
|
||
|
'dwc_otg.fiq_fsm_enable=0')
|
||
|
self.vm.add_args('-kernel', kernel_path,
|
||
|
'-dtb', dtb_path,
|
||
|
'-initrd', initrd_path,
|
||
|
'-append', kernel_command_line,
|
||
|
'-no-reboot')
|
||
|
# When PCI is supported we can add a USB controller:
|
||
|
# '-device', 'qemu-xhci,bus=pcie.1,id=xhci',
|
||
|
# '-device', 'usb-kbd,bus=xhci.0',
|
||
|
self.vm.launch()
|
||
|
self.wait_for_console_pattern('Boot successful.')
|
||
|
|
||
|
exec_command_and_wait_for_pattern(self, 'cat /proc/cpuinfo',
|
||
|
'BCM2835')
|
||
|
exec_command_and_wait_for_pattern(self, 'cat /proc/iomem',
|
||
|
'cprman@7e101000')
|
||
|
exec_command_and_wait_for_pattern(self, 'halt', 'reboot: System halted')
|
||
|
# TODO: Raspberry Pi4 doesn't shut down properly with recent kernels
|
||
|
# Wait for VM to shut down gracefully
|
||
|
#self.vm.wait()
|
||
|
|
||
|
|
||
|
if __name__ == '__main__':
|
||
|
LinuxKernelTest.main()
|