]> xenbits.xensource.com Git - libvirt.git/commitdiff
libxl: default to qemu driver for network disks
authorJim Fehlig <jfehlig@suse.com>
Mon, 23 May 2016 21:56:01 +0000 (15:56 -0600)
committerJim Fehlig <jfehlig@suse.com>
Wed, 25 May 2016 14:28:22 +0000 (08:28 -0600)
Xen only supports network-based disks with the qemu (aka qdisk) driver.
Set the driverName to 'qemu' in libxlDomainDeviceDefPostParse() if
not already set. When starting a domain with network-based disks,
ensure the driverName is 'qemu'.

Resolves: https://bugzilla.opensuse.org/show_bug.cgi?id=981094

src/libxl/libxl_conf.c
src/libxl/libxl_domain.c

index 13e56ac1ffaf168d91b97de164c075a06bd4cd40..a64b4c17d804d498210c4ea9d879bdfd5643f602 100644 (file)
@@ -1058,13 +1058,18 @@ libxlMakeNetworkDiskSrc(virStorageSourcePtr src, char **srcstr)
 int
 libxlMakeDisk(virDomainDiskDefPtr l_disk, libxl_device_disk *x_disk)
 {
-    const char *driver;
-    int format;
+    const char *driver = virDomainDiskGetDriver(l_disk);
+    int format = virDomainDiskGetFormat(l_disk);
     int actual_type = virStorageSourceGetActualType(l_disk->src);
 
     libxl_device_disk_init(x_disk);
 
     if (actual_type == VIR_STORAGE_TYPE_NETWORK) {
+        if (STRNEQ_NULLABLE(driver, "qemu")) {
+            virReportError(VIR_ERR_OPERATION_INVALID, "%s",
+                           _("only the 'qemu' driver can be used with network disks"));
+            return -1;
+        }
         if (libxlMakeNetworkDiskSrc(l_disk->src, &x_disk->pdev_path) < 0)
             return -1;
     } else {
@@ -1075,8 +1080,6 @@ libxlMakeDisk(virDomainDiskDefPtr l_disk, libxl_device_disk *x_disk)
     if (VIR_STRDUP(x_disk->vdev, l_disk->dst) < 0)
         return -1;
 
-    driver = virDomainDiskGetDriver(l_disk);
-    format = virDomainDiskGetFormat(l_disk);
     if (driver) {
         if (STREQ(driver, "tap") || STREQ(driver, "tap2")) {
             switch (format) {
index 113942bb8e03fb1cc15c5f1d3d8b9e755dbd5b8e..8a3866f90f8ce74f934c7ba2223806087a6a4980 100644 (file)
@@ -364,6 +364,18 @@ libxlDomainDeviceDefPostParse(virDomainDeviceDefPtr dev,
         }
     }
 
+    /* for network-based disks, set 'qemu' as the default driver */
+    if (dev->type == VIR_DOMAIN_DEVICE_DISK) {
+        virDomainDiskDefPtr disk = dev->data.disk;
+        int actual_type = virStorageSourceGetActualType(disk->src);
+
+        if (actual_type == VIR_STORAGE_TYPE_NETWORK) {
+            if (!virDomainDiskGetDriver(disk) &&
+                virDomainDiskSetDriver(disk, "qemu") < 0)
+                return -1;
+        }
+    }
+
     return 0;
 }