blob: 0b38ddf0abf3d7cb229f40f87d61a02a57148c93 [file] [log] [blame]
Wainer dos Santos Moschetta8b272e02019-12-16 16:14:34 -03001"""
2QEMU accel module:
3
4This module provides utilities for discover and check the availability of
5accelerators.
6"""
7# Copyright (C) 2015-2016 Red Hat Inc.
8# Copyright (C) 2012 IBM Corp.
9#
10# Authors:
11# Fam Zheng <famz@redhat.com>
12#
13# This work is licensed under the terms of the GNU GPL, version 2. See
14# the COPYING file in the top-level directory.
15#
16
Wainer dos Santos Moschetta1650c3e2019-12-16 16:14:35 -030017import logging
Wainer dos Santos Moschetta8b272e02019-12-16 16:14:34 -030018import os
Wainer dos Santos Moschetta1650c3e2019-12-16 16:14:35 -030019import subprocess
20
21LOG = logging.getLogger(__name__)
Wainer dos Santos Moschetta8b272e02019-12-16 16:14:34 -030022
23# Mapping host architecture to any additional architectures it can
24# support which often includes its 32 bit cousin.
25ADDITIONAL_ARCHES = {
26 "x86_64" : "i386",
27 "aarch64" : "armhf"
28}
29
Wainer dos Santos Moschetta1650c3e2019-12-16 16:14:35 -030030def list_accel(qemu_bin):
31 """
32 List accelerators enabled in the QEMU binary.
33
34 @param qemu_bin (str): path to the QEMU binary.
35 @raise Exception: if failed to run `qemu -accel help`
36 @return a list of accelerator names.
37 """
38 if not qemu_bin:
39 return []
40 try:
41 out = subprocess.check_output([qemu_bin, '-accel', 'help'],
42 universal_newlines=True)
43 except:
44 LOG.debug("Failed to get the list of accelerators in %s", qemu_bin)
45 raise
46 # Skip the first line which is the header.
47 return [acc.strip() for acc in out.splitlines()[1:]]
48
Wainer dos Santos Moschetta53a049d2019-12-16 16:14:36 -030049def kvm_available(target_arch=None, qemu_bin=None):
50 """
51 Check if KVM is available using the following heuristic:
52 - Kernel module is present in the host;
53 - Target and host arches don't mismatch;
54 - KVM is enabled in the QEMU binary.
55
56 @param target_arch (str): target architecture
57 @param qemu_bin (str): path to the QEMU binary
58 @return True if kvm is available, otherwise False.
59 """
60 if not os.access("/dev/kvm", os.R_OK | os.W_OK):
61 return False
62 if target_arch:
63 host_arch = os.uname()[4]
64 if target_arch != host_arch:
65 if target_arch != ADDITIONAL_ARCHES.get(host_arch):
66 return False
67 if qemu_bin and "kvm" not in list_accel(qemu_bin):
68 return False
69 return True
Wainer dos Santos Moschettad3ca7bb2019-12-16 16:14:37 -030070
71def tcg_available(qemu_bin):
72 """
73 Check if TCG is available.
74
75 @param qemu_bin (str): path to the QEMU binary
76 """
77 return 'tcg' in list_accel(qemu_bin)