9c6c51
From 4b249d6de82cd42d29aeccccef4ae483c71b1528 Mon Sep 17 00:00:00 2001
9c6c51
Message-Id: <4b249d6de82cd42d29aeccccef4ae483c71b1528@dist-git>
9c6c51
From: Boris Fiuczynski <fiuczy@linux.ibm.com>
9c6c51
Date: Fri, 30 Nov 2018 15:49:24 +0100
9c6c51
Subject: [PATCH] qemu: vfio-ap device support
9c6c51
9c6c51
Adjusting domain format documentation, adding device address
9c6c51
support and adding command line generation for vfio-ap.
9c6c51
Since only one mediated hostdev with model vfio-ap is supported a check
9c6c51
disallows to define domains with more than one such hostdev device.
9c6c51
9c6c51
Signed-off-by: Boris Fiuczynski <fiuczy@linux.ibm.com>
9c6c51
Reviewed-by: Bjoern Walk <bwalk@linux.ibm.com>
9c6c51
Reviewed-by: Chris Venteicher <cventeic@redhat.com>
9c6c51
(cherry picked from commit 11708641983e9107a129c62fd343d0fec228342f)
9c6c51
9c6c51
https://bugzilla.redhat.com/show_bug.cgi?id=1508146
9c6c51
9c6c51
Signed-off-by: Pino Toscano <ptoscano@redhat.com>
9c6c51
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
9c6c51
---
9c6c51
 docs/formatdomain.html.in      |  3 ++-
9c6c51
 docs/schemas/domaincommon.rng  |  1 +
9c6c51
 src/conf/domain_conf.c         | 28 ++++++++++++++++++++++++++++
9c6c51
 src/qemu/qemu_command.c        |  8 ++++++++
9c6c51
 src/qemu/qemu_domain_address.c |  4 ++++
9c6c51
 src/util/virmdev.c             |  3 ++-
9c6c51
 src/util/virmdev.h             |  1 +
9c6c51
 7 files changed, 46 insertions(+), 2 deletions(-)
9c6c51
9c6c51
diff --git a/docs/formatdomain.html.in b/docs/formatdomain.html.in
9c6c51
index c019b26644..54eb298414 100644
9c6c51
--- a/docs/formatdomain.html.in
9c6c51
+++ b/docs/formatdomain.html.in
9c6c51
@@ -4528,8 +4528,9 @@
9c6c51
           
For mediated devices (Since 3.2.0)
9c6c51
           the model attribute specifies the device API which
9c6c51
           determines how the host's vfio driver will expose the device to the
9c6c51
-          guest. Currently, model='vfio-pci' and
9c6c51
+          guest. Currently, model='vfio-pci',
9c6c51
           model='vfio-ccw' (Since 4.4.0)
9c6c51
+          and model='vfio-ap' (Since 4.9.0)
9c6c51
           is supported. MDEV section
9c6c51
           provides more information about mediated devices as well as how to
9c6c51
           create mediated devices on the host.
9c6c51
diff --git a/docs/schemas/domaincommon.rng b/docs/schemas/domaincommon.rng
9c6c51
index 1c6f2a295d..e4ce7804b9 100644
9c6c51
--- a/docs/schemas/domaincommon.rng
9c6c51
+++ b/docs/schemas/domaincommon.rng
9c6c51
@@ -4578,6 +4578,7 @@
9c6c51
       <choice>
9c6c51
         <value>vfio-pci</value>
9c6c51
         <value>vfio-ccw</value>
9c6c51
+        <value>vfio-ap</value>
9c6c51
       </choice>
9c6c51
     </attribute>
9c6c51
     <optional>
9c6c51
diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c
9c6c51
index e013e9f0c5..ea7152eb94 100644
9c6c51
--- a/src/conf/domain_conf.c
9c6c51
+++ b/src/conf/domain_conf.c
9c6c51
@@ -4325,6 +4325,31 @@ virDomainDefPostParseGraphics(virDomainDef *def)
9c6c51
 }
9c6c51
 
9c6c51
 
9c6c51
+static int
9c6c51
+virDomainDefPostParseHostdev(virDomainDefPtr def)
9c6c51
+{
9c6c51
+    size_t i;
9c6c51
+    bool vfioap_found = false;
9c6c51
+
9c6c51
+    /* verify settings of hostdevs vfio-ap */
9c6c51
+    for (i = 0; i < def->nhostdevs; i++) {
9c6c51
+        virDomainHostdevDefPtr hostdev = def->hostdevs[i];
9c6c51
+
9c6c51
+        if (virHostdevIsMdevDevice(hostdev) &&
9c6c51
+            hostdev->source.subsys.u.mdev.model == VIR_MDEV_MODEL_TYPE_VFIO_AP) {
9c6c51
+            if (vfioap_found) {
9c6c51
+                virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
9c6c51
+                               _("Only one hostdev of model vfio-ap is "
9c6c51
+                                 "supported"));
9c6c51
+                return -1;
9c6c51
+            }
9c6c51
+            vfioap_found = true;
9c6c51
+        }
9c6c51
+    }
9c6c51
+    return 0;
9c6c51
+}
9c6c51
+
9c6c51
+
9c6c51
 /**
9c6c51
  * virDomainDriveAddressIsUsedByDisk:
9c6c51
  * @def: domain definition containing the disks to check
9c6c51
@@ -5237,6 +5262,9 @@ virDomainDefPostParseCommon(virDomainDefPtr def,
9c6c51
 
9c6c51
     virDomainDefPostParseGraphics(def);
9c6c51
 
9c6c51
+    if (virDomainDefPostParseHostdev(def) < 0)
9c6c51
+        return -1;
9c6c51
+
9c6c51
     if (virDomainDefPostParseCPU(def) < 0)
9c6c51
         return -1;
9c6c51
 
9c6c51
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
9c6c51
index a3d605c00f..320ecd902c 100644
9c6c51
--- a/src/qemu/qemu_command.c
9c6c51
+++ b/src/qemu/qemu_command.c
9c6c51
@@ -5430,6 +5430,14 @@ qemuBuildHostdevCommandLine(virCommandPtr cmd,
9c6c51
                     return -1;
9c6c51
                 }
9c6c51
                 break;
9c6c51
+            case VIR_MDEV_MODEL_TYPE_VFIO_AP:
9c6c51
+                if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VFIO_AP)) {
9c6c51
+                    virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
9c6c51
+                                   _("VFIO AP device assignment is not "
9c6c51
+                                     "supported by this version of QEMU"));
9c6c51
+                    return -1;
9c6c51
+                }
9c6c51
+                break;
9c6c51
             case VIR_MDEV_MODEL_TYPE_LAST:
9c6c51
                 virReportError(VIR_ERR_INTERNAL_ERROR,
9c6c51
                                _("unexpected vfio type '%d'"), subsys->u.mdev.model);
9c6c51
diff --git a/src/qemu/qemu_domain_address.c b/src/qemu/qemu_domain_address.c
9c6c51
index 0cb5af4a87..3e50521c11 100644
9c6c51
--- a/src/qemu/qemu_domain_address.c
9c6c51
+++ b/src/qemu/qemu_domain_address.c
9c6c51
@@ -294,6 +294,10 @@ qemuDomainPrimeVfioDeviceAddresses(virDomainDefPtr def,
9c6c51
             subsys->u.mdev.model == VIR_MDEV_MODEL_TYPE_VFIO_CCW &&
9c6c51
             def->hostdevs[i]->info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE)
9c6c51
             def->hostdevs[i]->info->type = type;
9c6c51
+
9c6c51
+        if (virHostdevIsMdevDevice(def->hostdevs[i]) &&
9c6c51
+            subsys->u.mdev.model == VIR_MDEV_MODEL_TYPE_VFIO_AP)
9c6c51
+            def->hostdevs[i]->info->type = VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE;
9c6c51
     }
9c6c51
 }
9c6c51
 
9c6c51
diff --git a/src/util/virmdev.c b/src/util/virmdev.c
9c6c51
index 6c513884b8..1b5897c654 100644
9c6c51
--- a/src/util/virmdev.c
9c6c51
+++ b/src/util/virmdev.c
9c6c51
@@ -49,7 +49,8 @@ struct _virMediatedDeviceList {
9c6c51
 
9c6c51
 VIR_ENUM_IMPL(virMediatedDeviceModel, VIR_MDEV_MODEL_TYPE_LAST,
9c6c51
               "vfio-pci",
9c6c51
-              "vfio-ccw")
9c6c51
+              "vfio-ccw",
9c6c51
+              "vfio-ap")
9c6c51
 
9c6c51
 static virClassPtr virMediatedDeviceListClass;
9c6c51
 
9c6c51
diff --git a/src/util/virmdev.h b/src/util/virmdev.h
9c6c51
index cfda2cacab..ba411a933a 100644
9c6c51
--- a/src/util/virmdev.h
9c6c51
+++ b/src/util/virmdev.h
9c6c51
@@ -26,6 +26,7 @@
9c6c51
 typedef enum {
9c6c51
     VIR_MDEV_MODEL_TYPE_VFIO_PCI = 0,
9c6c51
     VIR_MDEV_MODEL_TYPE_VFIO_CCW = 1,
9c6c51
+    VIR_MDEV_MODEL_TYPE_VFIO_AP  = 2,
9c6c51
 
9c6c51
     VIR_MDEV_MODEL_TYPE_LAST
9c6c51
 } virMediatedDeviceModelType;
9c6c51
-- 
9c6c51
2.19.2
9c6c51