xref: /qemu/tests/functional/test_ppc64_replay.py (revision f07a5674cf97b8473e5d06d7b1df9b51e97d553f)
1#!/usr/bin/env python3
2#
3# Replay test that boots a Linux kernel on ppc64 machines
4# and checks the console
5#
6# SPDX-License-Identifier: GPL-2.0-or-later
7
8from qemu_test import Asset
9from replay_kernel import ReplayKernelBase
10
11
12class Ppc64Replay(ReplayKernelBase):
13
14    ASSET_DAY19 = Asset(
15        ('https://qemu-advcal.gitlab.io/qac-best-of-multiarch/download/'
16         'day19.tar.xz'),
17        '20b1bb5a8488c664defbb5d283addc91a05335a936c63b3f5ff7eee74b725755')
18
19    def test_ppc64_e500(self):
20        self.set_machine('ppce500')
21        self.cpu = 'e5500'
22        kernel_path = self.archive_extract(self.ASSET_DAY19,
23                                           member='day19/uImage')
24        self.run_rr(kernel_path, self.REPLAY_KERNEL_COMMAND_LINE,
25                    'QEMU advent calendar')
26
27    ASSET_KERNEL = Asset(
28        ('https://archives.fedoraproject.org/pub/archive/fedora-secondary/'
29         'releases/29/Everything/ppc64le/os/ppc/ppc64/vmlinuz'),
30        '383c2f5c23bc0d9d32680c3924d3fd7ee25cc5ef97091ac1aa5e1d853422fc5f')
31
32    def test_ppc64_pseries(self):
33        self.set_machine('pseries')
34        kernel_path = self.ASSET_KERNEL.fetch()
35        kernel_command_line = self.KERNEL_COMMON_COMMAND_LINE + 'console=hvc0'
36        console_pattern = 'VFS: Cannot open root device'
37        self.run_rr(kernel_path, kernel_command_line, console_pattern)
38
39    def test_ppc64_powernv(self):
40        self.set_machine('powernv')
41        kernel_path = self.ASSET_KERNEL.fetch()
42        kernel_command_line = self.KERNEL_COMMON_COMMAND_LINE + \
43                              'console=tty0 console=hvc0'
44        console_pattern = 'VFS: Cannot open root device'
45        self.run_rr(kernel_path, kernel_command_line, console_pattern)
46
47
48if __name__ == '__main__':
49    ReplayKernelBase.main()
50