0a7476
From e40f255c06b69af3bc9df5d0e6cbd0eb253e0650 Mon Sep 17 00:00:00 2001
0a7476
Message-Id: <e40f255c06b69af3bc9df5d0e6cbd0eb253e0650@dist-git>
0a7476
From: Laine Stump <laine@laine.org>
0a7476
Date: Thu, 11 Apr 2019 15:14:39 -0400
0a7476
Subject: [PATCH] qemu_hotplug: move (Attach|Detach)Lease functions with others
0a7476
 of same type
0a7476
0a7476
The Attach and Detach Lease functions were together in the middle of
0a7476
the Detach functions. Put them at the end of their respective
0a7476
sections, since they behave differently from the other attach/detach
0a7476
functions (DetachLease doesn't use qemuDomainDeleteDevice(), and is
0a7476
always synchronous).
0a7476
0a7476
Signed-off-by: Laine Stump <laine@laine.org>
0a7476
ACKed-by: Peter Krempa <pkrempa@redhat.com>
0a7476
(cherry picked from commit 015e71c54ddf8d133905a85514239b21bc7e552e)
0a7476
0a7476
Partially-Resolves: https://bugzilla.redhat.com/1658198
0a7476
Signed-off-by: Laine Stump <laine@redhat.com>
0a7476
Signed-off-by: Laine Stump <laine@laine.org>
0a7476
Message-Id: <20190411191453.24055-28-laine@redhat.com>
0a7476
Acked-by: Michal Privoznik <mprivozn@redhat.com>
0a7476
---
0a7476
 src/qemu/qemu_hotplug.c | 96 +++++++++++++++++++++--------------------
0a7476
 1 file changed, 50 insertions(+), 46 deletions(-)
0a7476
0a7476
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
0a7476
index 77237a895e..d55a68e4ad 100644
0a7476
--- a/src/qemu/qemu_hotplug.c
0a7476
+++ b/src/qemu/qemu_hotplug.c
0a7476
@@ -2980,6 +2980,32 @@ qemuDomainAttachVsockDevice(virQEMUDriverPtr driver,
0a7476
 }
0a7476
 
0a7476
 
0a7476
+int
0a7476
+qemuDomainAttachLease(virQEMUDriverPtr driver,
0a7476
+                      virDomainObjPtr vm,
0a7476
+                      virDomainLeaseDefPtr lease)
0a7476
+{
0a7476
+    int ret = -1;
0a7476
+    virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
0a7476
+
0a7476
+    if (virDomainLeaseInsertPreAlloc(vm->def) < 0)
0a7476
+        goto cleanup;
0a7476
+
0a7476
+    if (virDomainLockLeaseAttach(driver->lockManager, cfg->uri,
0a7476
+                                 vm, lease) < 0) {
0a7476
+        virDomainLeaseInsertPreAlloced(vm->def, NULL);
0a7476
+        goto cleanup;
0a7476
+    }
0a7476
+
0a7476
+    virDomainLeaseInsertPreAlloced(vm->def, lease);
0a7476
+    ret = 0;
0a7476
+
0a7476
+ cleanup:
0a7476
+    virObjectUnref(cfg);
0a7476
+    return ret;
0a7476
+}
0a7476
+
0a7476
+
0a7476
 static int
0a7476
 qemuDomainChangeNetBridge(virDomainObjPtr vm,
0a7476
                           virDomainNetDefPtr olddev,
0a7476
@@ -5350,52 +5376,6 @@ qemuDomainDetachNetDevice(virQEMUDriverPtr driver,
0a7476
 }
0a7476
 
0a7476
 
0a7476
-int qemuDomainAttachLease(virQEMUDriverPtr driver,
0a7476
-                          virDomainObjPtr vm,
0a7476
-                          virDomainLeaseDefPtr lease)
0a7476
-{
0a7476
-    int ret = -1;
0a7476
-    virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
0a7476
-
0a7476
-    if (virDomainLeaseInsertPreAlloc(vm->def) < 0)
0a7476
-        goto cleanup;
0a7476
-
0a7476
-    if (virDomainLockLeaseAttach(driver->lockManager, cfg->uri,
0a7476
-                                 vm, lease) < 0) {
0a7476
-        virDomainLeaseInsertPreAlloced(vm->def, NULL);
0a7476
-        goto cleanup;
0a7476
-    }
0a7476
-
0a7476
-    virDomainLeaseInsertPreAlloced(vm->def, lease);
0a7476
-    ret = 0;
0a7476
-
0a7476
- cleanup:
0a7476
-    virObjectUnref(cfg);
0a7476
-    return ret;
0a7476
-}
0a7476
-
0a7476
-int qemuDomainDetachLease(virQEMUDriverPtr driver,
0a7476
-                          virDomainObjPtr vm,
0a7476
-                          virDomainLeaseDefPtr lease)
0a7476
-{
0a7476
-    virDomainLeaseDefPtr det_lease;
0a7476
-    int idx;
0a7476
-
0a7476
-    if ((idx = virDomainLeaseIndex(vm->def, lease)) < 0) {
0a7476
-        virReportError(VIR_ERR_INVALID_ARG,
0a7476
-                       _("Lease %s in lockspace %s does not exist"),
0a7476
-                       lease->key, NULLSTR(lease->lockspace));
0a7476
-        return -1;
0a7476
-    }
0a7476
-
0a7476
-    if (virDomainLockLeaseDetach(driver->lockManager, vm, lease) < 0)
0a7476
-        return -1;
0a7476
-
0a7476
-    det_lease = virDomainLeaseRemoveAt(vm->def, idx);
0a7476
-    virDomainLeaseDefFree(det_lease);
0a7476
-    return 0;
0a7476
-}
0a7476
-
0a7476
 int qemuDomainDetachChrDevice(virQEMUDriverPtr driver,
0a7476
                               virDomainObjPtr vm,
0a7476
                               virDomainChrDefPtr chr,
0a7476
@@ -5634,6 +5614,30 @@ qemuDomainDetachVsockDevice(virDomainObjPtr vm,
0a7476
 }
0a7476
 
0a7476
 
0a7476
+int
0a7476
+qemuDomainDetachLease(virQEMUDriverPtr driver,
0a7476
+                      virDomainObjPtr vm,
0a7476
+                      virDomainLeaseDefPtr lease)
0a7476
+{
0a7476
+    virDomainLeaseDefPtr det_lease;
0a7476
+    int idx;
0a7476
+
0a7476
+    if ((idx = virDomainLeaseIndex(vm->def, lease)) < 0) {
0a7476
+        virReportError(VIR_ERR_INVALID_ARG,
0a7476
+                       _("Lease %s in lockspace %s does not exist"),
0a7476
+                       lease->key, NULLSTR(lease->lockspace));
0a7476
+        return -1;
0a7476
+    }
0a7476
+
0a7476
+    if (virDomainLockLeaseDetach(driver->lockManager, vm, lease) < 0)
0a7476
+        return -1;
0a7476
+
0a7476
+    det_lease = virDomainLeaseRemoveAt(vm->def, idx);
0a7476
+    virDomainLeaseDefFree(det_lease);
0a7476
+    return 0;
0a7476
+}
0a7476
+
0a7476
+
0a7476
 static int
0a7476
 qemuDomainRemoveVcpu(virQEMUDriverPtr driver,
0a7476
                      virDomainObjPtr vm,
0a7476
-- 
0a7476
2.21.0
0a7476