4 This module provides utilities for discover and check the availability of
7 # Copyright (C) 2015-2016 Red Hat Inc.
8 # Copyright (C) 2012 IBM Corp.
11 # Fam Zheng <famz@redhat.com>
13 # This work is licensed under the terms of the GNU GPL, version 2. See
14 # the COPYING file in the top-level directory.
21 LOG
= logging
.getLogger(__name__
)
23 # Mapping host architecture to any additional architectures it can
24 # support which often includes its 32 bit cousin.
32 def list_accel(qemu_bin
):
34 List accelerators enabled in the QEMU binary.
36 @param qemu_bin (str): path to the QEMU binary.
37 @raise Exception: if failed to run `qemu -accel help`
38 @return a list of accelerator names.
43 out
= subprocess
.check_output([qemu_bin
, '-accel', 'help'],
44 universal_newlines
=True)
46 LOG
.debug("Failed to get the list of accelerators in %s", qemu_bin
)
48 # Skip the first line which is the header.
49 return [acc
.strip() for acc
in out
.splitlines()[1:]]
52 def kvm_available(target_arch
=None, qemu_bin
=None):
54 Check if KVM is available using the following heuristic:
55 - Kernel module is present in the host;
56 - Target and host arches don't mismatch;
57 - KVM is enabled in the QEMU binary.
59 @param target_arch (str): target architecture
60 @param qemu_bin (str): path to the QEMU binary
61 @return True if kvm is available, otherwise False.
63 if not os
.access("/dev/kvm", os
.R_OK | os
.W_OK
):
66 host_arch
= os
.uname()[4]
67 if target_arch
!= host_arch
:
68 if target_arch
!= ADDITIONAL_ARCHES
.get(host_arch
):
70 if qemu_bin
and "kvm" not in list_accel(qemu_bin
):
75 def tcg_available(qemu_bin
):
77 Check if TCG is available.
79 @param qemu_bin (str): path to the QEMU binary
81 return 'tcg' in list_accel(qemu_bin
)