blob: 0f29414df542a085c587a70796278ed876762abf [file] [log] [blame]
Brad Bishopc342db32019-05-15 21:57:59 -04001#
Brad Bishop6e60e8b2018-02-01 10:27:11 -05002# Copyright (C) 2016 Intel Corporation
Brad Bishopc342db32019-05-15 21:57:59 -04003#
4# SPDX-License-Identifier: MIT
5#
Brad Bishop6e60e8b2018-02-01 10:27:11 -05006
7import os
8import sys
9import signal
10import time
Andrew Geissler82c905d2020-04-13 13:39:40 -050011from collections import defaultdict
Brad Bishop6e60e8b2018-02-01 10:27:11 -050012
13from .ssh import OESSHTarget
14from oeqa.utils.qemurunner import QemuRunner
Andrew Geisslerc3d88e42020-10-02 09:45:00 -050015from oeqa.utils.dump import TargetDumper
Brad Bishop6e60e8b2018-02-01 10:27:11 -050016
Brad Bishop316dfdd2018-06-25 12:45:53 -040017supported_fstypes = ['ext3', 'ext4', 'cpio.gz', 'wic']
Brad Bishop6e60e8b2018-02-01 10:27:11 -050018
19class OEQemuTarget(OESSHTarget):
Brad Bishop977dc1a2019-02-06 16:01:43 -050020 def __init__(self, logger, server_ip, timeout=300, user='root',
Brad Bishop19323692019-04-05 15:28:33 -040021 port=None, machine='', rootfs='', kernel='', kvm=False, slirp=False,
Brad Bishop6e60e8b2018-02-01 10:27:11 -050022 dump_dir='', dump_host_cmds='', display='', bootlog='',
Andrew Geissler82c905d2020-04-13 13:39:40 -050023 tmpdir='', dir_image='', boottime=60, serial_ports=2,
24 boot_patterns = defaultdict(str), ovmf=False, **kwargs):
Brad Bishop6e60e8b2018-02-01 10:27:11 -050025
Brad Bishop977dc1a2019-02-06 16:01:43 -050026 super(OEQemuTarget, self).__init__(logger, None, server_ip, timeout,
Brad Bishop6e60e8b2018-02-01 10:27:11 -050027 user, port)
28
Brad Bishop6e60e8b2018-02-01 10:27:11 -050029 self.server_ip = server_ip
Andrew Geissler82c905d2020-04-13 13:39:40 -050030 self.server_port = 0
Brad Bishop6e60e8b2018-02-01 10:27:11 -050031 self.machine = machine
32 self.rootfs = rootfs
33 self.kernel = kernel
34 self.kvm = kvm
Andrew Geissler82c905d2020-04-13 13:39:40 -050035 self.ovmf = ovmf
Brad Bishop19323692019-04-05 15:28:33 -040036 self.use_slirp = slirp
Andrew Geissler82c905d2020-04-13 13:39:40 -050037 self.boot_patterns = boot_patterns
Brad Bishop6e60e8b2018-02-01 10:27:11 -050038
39 self.runner = QemuRunner(machine=machine, rootfs=rootfs, tmpdir=tmpdir,
40 deploy_dir_image=dir_image, display=display,
41 logfile=bootlog, boottime=boottime,
Brad Bishop19323692019-04-05 15:28:33 -040042 use_kvm=kvm, use_slirp=slirp, dump_dir=dump_dir,
Andrew Geissler82c905d2020-04-13 13:39:40 -050043 dump_host_cmds=dump_host_cmds, logger=logger,
44 serial_ports=serial_ports, boot_patterns = boot_patterns,
45 use_ovmf=ovmf)
Andrew Geisslerc3d88e42020-10-02 09:45:00 -050046 dump_target_cmds = kwargs.get("testimage_dump_target")
47 self.target_dumper = TargetDumper(dump_target_cmds, dump_dir, self.runner)
48 self.target_dumper.create_dir("qemu")
Brad Bishop6e60e8b2018-02-01 10:27:11 -050049
Brad Bishop19323692019-04-05 15:28:33 -040050 def start(self, params=None, extra_bootparams=None, runqemuparams=''):
51 if self.use_slirp and not self.server_ip:
52 self.logger.error("Could not start qemu with slirp without server ip - provide 'TEST_SERVER_IP'")
53 raise RuntimeError("FAILED to start qemu - check the task log and the boot log")
54 if self.runner.start(params, extra_bootparams=extra_bootparams, runqemuparams=runqemuparams):
Brad Bishop6e60e8b2018-02-01 10:27:11 -050055 self.ip = self.runner.ip
Brad Bishop19323692019-04-05 15:28:33 -040056 if self.use_slirp:
57 target_ip_port = self.runner.ip.split(':')
58 if len(target_ip_port) == 2:
59 target_ip = target_ip_port[0]
60 port = target_ip_port[1]
61 self.ip = target_ip
62 self.ssh = self.ssh + ['-p', port]
63 self.scp = self.scp + ['-P', port]
64 else:
65 self.logger.error("Could not get host machine port to connect qemu with slirp, ssh will not be "
66 "able to connect to qemu with slirp")
67 if self.runner.server_ip:
68 self.server_ip = self.runner.server_ip
Brad Bishop6e60e8b2018-02-01 10:27:11 -050069 else:
70 self.stop()
71 raise RuntimeError("FAILED to start qemu - check the task log and the boot log")
72
73 def stop(self):
74 self.runner.stop()