1bbbd9b6eSWillian Rampazzo# Functional test that boots a Linux kernel and checks the console
2bbbd9b6eSWillian Rampazzo#
3bbbd9b6eSWillian Rampazzo# Copyright (c) 2018 Red Hat, Inc.
4bbbd9b6eSWillian Rampazzo#
5bbbd9b6eSWillian Rampazzo# Author:
6bbbd9b6eSWillian Rampazzo#  Cleber Rosa <crosa@redhat.com>
7bbbd9b6eSWillian Rampazzo#
8bbbd9b6eSWillian Rampazzo# This work is licensed under the terms of the GNU GPL, version 2 or
9bbbd9b6eSWillian Rampazzo# later.  See the COPYING file in the top-level directory.
10bbbd9b6eSWillian Rampazzo
11bbbd9b6eSWillian Rampazzoimport os
12bbbd9b6eSWillian Rampazzo
139b45cc99SAlex Bennéefrom avocado import skipUnless
142283b627SPhilippe Mathieu-Daudéfrom avocado_qemu import QemuSystemTest
15bbbd9b6eSWillian Rampazzofrom avocado_qemu import exec_command_and_wait_for_pattern
16bbbd9b6eSWillian Rampazzofrom avocado_qemu import wait_for_console_pattern
17bbbd9b6eSWillian Rampazzofrom avocado.utils import archive
18bbbd9b6eSWillian Rampazzo
19bbbd9b6eSWillian Rampazzo
202283b627SPhilippe Mathieu-Daudéclass RxGdbSimMachine(QemuSystemTest):
21bbbd9b6eSWillian Rampazzo
22bbbd9b6eSWillian Rampazzo    timeout = 30
23bbbd9b6eSWillian Rampazzo    KERNEL_COMMON_COMMAND_LINE = 'printk.time=0 '
24bbbd9b6eSWillian Rampazzo
259b45cc99SAlex Bennée    @skipUnless(os.getenv('QEMU_TEST_FLAKY_TESTS'), 'Test is unstable on GitLab')
269b45cc99SAlex Bennée
27bbbd9b6eSWillian Rampazzo    def test_uboot(self):
28bbbd9b6eSWillian Rampazzo        """
29bbbd9b6eSWillian Rampazzo        U-Boot and checks that the console is operational.
30bbbd9b6eSWillian Rampazzo
31bbbd9b6eSWillian Rampazzo        :avocado: tags=arch:rx
32bbbd9b6eSWillian Rampazzo        :avocado: tags=machine:gdbsim-r5f562n8
33bbbd9b6eSWillian Rampazzo        :avocado: tags=endian:little
34*5d25fcb7SAlex Bennée        :avocado: tags=flaky
35bbbd9b6eSWillian Rampazzo        """
36bbbd9b6eSWillian Rampazzo        uboot_url = ('https://acc.dl.osdn.jp/users/23/23888/u-boot.bin.gz')
37bbbd9b6eSWillian Rampazzo        uboot_hash = '9b78dbd43b40b2526848c0b1ce9de02c24f4dcdb'
38bbbd9b6eSWillian Rampazzo        uboot_path = self.fetch_asset(uboot_url, asset_hash=uboot_hash)
39bbbd9b6eSWillian Rampazzo        uboot_path = archive.uncompress(uboot_path, self.workdir)
40bbbd9b6eSWillian Rampazzo
41bbbd9b6eSWillian Rampazzo        self.vm.set_console()
42bbbd9b6eSWillian Rampazzo        self.vm.add_args('-bios', uboot_path,
43bbbd9b6eSWillian Rampazzo                         '-no-reboot')
44bbbd9b6eSWillian Rampazzo        self.vm.launch()
45bbbd9b6eSWillian Rampazzo        uboot_version = 'U-Boot 2016.05-rc3-23705-ga1ef3c71cb-dirty'
46bbbd9b6eSWillian Rampazzo        wait_for_console_pattern(self, uboot_version)
47bbbd9b6eSWillian Rampazzo        gcc_version = 'rx-unknown-linux-gcc (GCC) 9.0.0 20181105 (experimental)'
48bbbd9b6eSWillian Rampazzo        # FIXME limit baudrate on chardev, else we type too fast
49bbbd9b6eSWillian Rampazzo        #exec_command_and_wait_for_pattern(self, 'version', gcc_version)
50bbbd9b6eSWillian Rampazzo
519b45cc99SAlex Bennée    @skipUnless(os.getenv('QEMU_TEST_FLAKY_TESTS'), 'Test is unstable on GitLab')
529b45cc99SAlex Bennée
53bbbd9b6eSWillian Rampazzo    def test_linux_sash(self):
54bbbd9b6eSWillian Rampazzo        """
55bbbd9b6eSWillian Rampazzo        Boots a Linux kernel and checks that the console is operational.
56bbbd9b6eSWillian Rampazzo
57bbbd9b6eSWillian Rampazzo        :avocado: tags=arch:rx
58bbbd9b6eSWillian Rampazzo        :avocado: tags=machine:gdbsim-r5f562n7
59bbbd9b6eSWillian Rampazzo        :avocado: tags=endian:little
60*5d25fcb7SAlex Bennée        :avocado: tags=flaky
61bbbd9b6eSWillian Rampazzo        """
62bbbd9b6eSWillian Rampazzo        dtb_url = ('https://acc.dl.osdn.jp/users/23/23887/rx-virt.dtb')
63bbbd9b6eSWillian Rampazzo        dtb_hash = '7b4e4e2c71905da44e86ce47adee2210b026ac18'
64bbbd9b6eSWillian Rampazzo        dtb_path = self.fetch_asset(dtb_url, asset_hash=dtb_hash)
65bbbd9b6eSWillian Rampazzo        kernel_url = ('http://acc.dl.osdn.jp/users/23/23845/zImage')
66bbbd9b6eSWillian Rampazzo        kernel_hash = '39a81067f8d72faad90866ddfefa19165d68fc99'
67bbbd9b6eSWillian Rampazzo        kernel_path = self.fetch_asset(kernel_url, asset_hash=kernel_hash)
68bbbd9b6eSWillian Rampazzo
69bbbd9b6eSWillian Rampazzo        self.vm.set_console()
70bbbd9b6eSWillian Rampazzo        kernel_command_line = self.KERNEL_COMMON_COMMAND_LINE + 'earlycon'
71bbbd9b6eSWillian Rampazzo        self.vm.add_args('-kernel', kernel_path,
72bbbd9b6eSWillian Rampazzo                         '-dtb', dtb_path,
73bbbd9b6eSWillian Rampazzo                         '-no-reboot')
74bbbd9b6eSWillian Rampazzo        self.vm.launch()
75bbbd9b6eSWillian Rampazzo        wait_for_console_pattern(self, 'Sash command shell (version 1.1.1)',
76bbbd9b6eSWillian Rampazzo                                 failure_message='Kernel panic - not syncing')
77bbbd9b6eSWillian Rampazzo        exec_command_and_wait_for_pattern(self, 'printenv', 'TERM=linux')
78