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 13*9b45cc99SAlex 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 25*9b45cc99SAlex Bennée @skipUnless(os.getenv('QEMU_TEST_FLAKY_TESTS'), 'Test is unstable on GitLab') 26*9b45cc99SAlex 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 34bbbd9b6eSWillian Rampazzo """ 35bbbd9b6eSWillian Rampazzo uboot_url = ('https://acc.dl.osdn.jp/users/23/23888/u-boot.bin.gz') 36bbbd9b6eSWillian Rampazzo uboot_hash = '9b78dbd43b40b2526848c0b1ce9de02c24f4dcdb' 37bbbd9b6eSWillian Rampazzo uboot_path = self.fetch_asset(uboot_url, asset_hash=uboot_hash) 38bbbd9b6eSWillian Rampazzo uboot_path = archive.uncompress(uboot_path, self.workdir) 39bbbd9b6eSWillian Rampazzo 40bbbd9b6eSWillian Rampazzo self.vm.set_console() 41bbbd9b6eSWillian Rampazzo self.vm.add_args('-bios', uboot_path, 42bbbd9b6eSWillian Rampazzo '-no-reboot') 43bbbd9b6eSWillian Rampazzo self.vm.launch() 44bbbd9b6eSWillian Rampazzo uboot_version = 'U-Boot 2016.05-rc3-23705-ga1ef3c71cb-dirty' 45bbbd9b6eSWillian Rampazzo wait_for_console_pattern(self, uboot_version) 46bbbd9b6eSWillian Rampazzo gcc_version = 'rx-unknown-linux-gcc (GCC) 9.0.0 20181105 (experimental)' 47bbbd9b6eSWillian Rampazzo # FIXME limit baudrate on chardev, else we type too fast 48bbbd9b6eSWillian Rampazzo #exec_command_and_wait_for_pattern(self, 'version', gcc_version) 49bbbd9b6eSWillian Rampazzo 50*9b45cc99SAlex Bennée @skipUnless(os.getenv('QEMU_TEST_FLAKY_TESTS'), 'Test is unstable on GitLab') 51*9b45cc99SAlex Bennée 52bbbd9b6eSWillian Rampazzo def test_linux_sash(self): 53bbbd9b6eSWillian Rampazzo """ 54bbbd9b6eSWillian Rampazzo Boots a Linux kernel and checks that the console is operational. 55bbbd9b6eSWillian Rampazzo 56bbbd9b6eSWillian Rampazzo :avocado: tags=arch:rx 57bbbd9b6eSWillian Rampazzo :avocado: tags=machine:gdbsim-r5f562n7 58bbbd9b6eSWillian Rampazzo :avocado: tags=endian:little 59bbbd9b6eSWillian Rampazzo """ 60bbbd9b6eSWillian Rampazzo dtb_url = ('https://acc.dl.osdn.jp/users/23/23887/rx-virt.dtb') 61bbbd9b6eSWillian Rampazzo dtb_hash = '7b4e4e2c71905da44e86ce47adee2210b026ac18' 62bbbd9b6eSWillian Rampazzo dtb_path = self.fetch_asset(dtb_url, asset_hash=dtb_hash) 63bbbd9b6eSWillian Rampazzo kernel_url = ('http://acc.dl.osdn.jp/users/23/23845/zImage') 64bbbd9b6eSWillian Rampazzo kernel_hash = '39a81067f8d72faad90866ddfefa19165d68fc99' 65bbbd9b6eSWillian Rampazzo kernel_path = self.fetch_asset(kernel_url, asset_hash=kernel_hash) 66bbbd9b6eSWillian Rampazzo 67bbbd9b6eSWillian Rampazzo self.vm.set_console() 68bbbd9b6eSWillian Rampazzo kernel_command_line = self.KERNEL_COMMON_COMMAND_LINE + 'earlycon' 69bbbd9b6eSWillian Rampazzo self.vm.add_args('-kernel', kernel_path, 70bbbd9b6eSWillian Rampazzo '-dtb', dtb_path, 71bbbd9b6eSWillian Rampazzo '-no-reboot') 72bbbd9b6eSWillian Rampazzo self.vm.launch() 73bbbd9b6eSWillian Rampazzo wait_for_console_pattern(self, 'Sash command shell (version 1.1.1)', 74bbbd9b6eSWillian Rampazzo failure_message='Kernel panic - not syncing') 75bbbd9b6eSWillian Rampazzo exec_command_and_wait_for_pattern(self, 'printenv', 'TERM=linux') 76