[virt-tools-list] [virt-manager PATCH 3/5] virtinst: prepare XML parsers to handle GIC for ARM
Cole Robinson
crobinso at redhat.com
Sat Jun 11 14:49:23 UTC 2016
ACK 1-3
- Cole
On 06/10/2016 01:30 PM, Pavel Hrdina wrote:
> GIC is used instead of APIC on ARM and libvirt allows configure specific
> version of GIC for guests.
>
> Signed-off-by: Pavel Hrdina <phrdina at redhat.com>
> ---
> tests/xmlparse.py | 1 +
> virtinst/domainfeatures.py | 3 ++-
> virtinst/domcapabilities.py | 17 +++++++++++++++++
> 3 files changed, 20 insertions(+), 1 deletion(-)
>
> diff --git a/tests/xmlparse.py b/tests/xmlparse.py
> index fa7eb5a..7a763b8 100644
> --- a/tests/xmlparse.py
> +++ b/tests/xmlparse.py
> @@ -165,6 +165,7 @@ class XMLParseTest(unittest.TestCase):
> check("vmport", False, True)
> check("kvm_hidden", None, True)
> check("pvspinlock", None, True)
> + check("gic_version", None, False)
>
> check = self._make_checker(guest.cpu)
> check("match", "exact", "strict")
> diff --git a/virtinst/domainfeatures.py b/virtinst/domainfeatures.py
> index 8515943..8113568 100644
> --- a/virtinst/domainfeatures.py
> +++ b/virtinst/domainfeatures.py
> @@ -25,7 +25,7 @@ class DomainFeatures(XMLBuilder):
> Class for generating <features> XML
> """
> _XML_ROOT_NAME = "features"
> - _XML_PROP_ORDER = ["acpi", "apic", "pae"]
> + _XML_PROP_ORDER = ["acpi", "apic", "pae", "gic_version"]
>
> acpi = XMLProperty("./acpi", is_bool=True,
> default_name="default", default_cb=lambda s: False)
> @@ -33,6 +33,7 @@ class DomainFeatures(XMLBuilder):
> default_name="default", default_cb=lambda s: False)
> pae = XMLProperty("./pae", is_bool=True,
> default_name="default", default_cb=lambda s: False)
> + gic_version = XMLProperty("./gic/@version")
>
> hap = XMLProperty("./hap", is_bool=True)
> viridian = XMLProperty("./viridian", is_bool=True)
> diff --git a/virtinst/domcapabilities.py b/virtinst/domcapabilities.py
> index 1bf3c60..d872d7a 100644
> --- a/virtinst/domcapabilities.py
> +++ b/virtinst/domcapabilities.py
> @@ -71,6 +71,11 @@ class _Devices(_CapsBlock):
> disk = XMLChildProperty(_make_capsblock("disk"), is_single=True)
>
>
> +class _Features(_CapsBlock):
> + _XML_ROOT_NAME = "features"
> + gic = XMLChildProperty(_make_capsblock("gic"), is_single=True)
> +
> +
> class DomainCapabilities(XMLBuilder):
> @staticmethod
> def build_from_params(conn, emulator, arch, machine, hvtype):
> @@ -155,9 +160,21 @@ class DomainCapabilities(XMLBuilder):
> return ("readonly" in self.os.loader.enum_names() and
> "yes" in self.os.loader.get_enum("readonly").get_values())
>
> + def supports_gic(self, guest):
> + """
> + Return True if guest os is arm and libvirt advertises support for GIC
> + """
> + return self.features.gic.supported and guest.os.is_arm()
> +
> + def get_gic_versions(self):
> + """
> + Return a list of supported GIC versions provided by libvirt
> + """
> + return self.features.gic.get_enum("version").get_values()
>
> _XML_ROOT_NAME = "domainCapabilities"
> os = XMLChildProperty(_OS, is_single=True)
> devices = XMLChildProperty(_Devices, is_single=True)
>
> arch = XMLProperty("./arch")
> + features = XMLChildProperty(_Features, is_single=True)
>
More information about the virt-tools-list
mailing list