Compare commits
187 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 0aea5c88f2 | |||
| 1ab72850ed | |||
| 401f9087bc | |||
| dd3698988e | |||
| 3df49002c2 | |||
| 1bf0aedb9f | |||
| 79accd5a6e | |||
| 422d548fce | |||
| 20ec6e955c | |||
| 406a235cbc | |||
| 4d15e56a38 | |||
| 8693111790 | |||
| 8461a521f2 | |||
| 511e2c5124 | |||
| 749dc3d3cb | |||
| 73c9e38f2c | |||
| afe8184d3f | |||
| 7d77bf76aa | |||
| 7f0f1b831e | |||
| d964be0097 | |||
| a2479f539e | |||
| c2c89ec6a3 | |||
| d61e2404ba | |||
| a2be167dfe | |||
| 15ca09e1da | |||
| 2cc07e6366 | |||
| 4dd4fe78a4 | |||
| 0bc22fb6f7 | |||
| 76097a6961 | |||
| 98cbf39fd3 | |||
| d670e246d0 | |||
| 50e7b9a91d | |||
| 5cbc0451ce | |||
| b420054636 | |||
| 143fedee46 | |||
| 88887cac0f | |||
| 579afc99f2 | |||
| 7f5808b9d0 | |||
| 4df5f77071 | |||
| 1bdd527daf | |||
| e5fa1c00d2 | |||
| 18f7b8c79c | |||
| 782468f8e9 | |||
| 202e7d9569 | |||
| 0676a07265 | |||
| f57ce74947 | |||
| 851cfde15b | |||
| 06123137eb | |||
| 6ccf3cb58c | |||
| 030ddaa4ef | |||
| a8886736c4 | |||
| 4fd635e537 | |||
| 6210c457fc | |||
| 82926cfdf0 | |||
| e7a3ca6f6b | |||
| 1ae6f647b7 | |||
| 48941c011f | |||
| a3c4cc6f3d | |||
| 90fbcbd48f | |||
| 6efd96d995 | |||
| 21316e7a45 | |||
| 8adbb7a402 | |||
| 3f19d41908 | |||
| 34da93e0c9 | |||
| 208f506190 | |||
| 0ca715cad9 | |||
| 0f5d8c1c22 | |||
| a56bcbd063 | |||
| 89c3fa751c | |||
| 051644ffcb | |||
| 2a9c282548 | |||
| 2ae80af461 | |||
| 7335ede0e1 | |||
| 6c92ba3805 | |||
| 446f680673 | |||
| 3f56aa2870 | |||
| 3cec91694f | |||
| cb0cfa566f | |||
| a27acebf66 | |||
| 99d3a0ca1a | |||
| 9c962ebc4f | |||
| 99cbbf6606 | |||
| b73e509648 | |||
| b23ff9c0f7 | |||
| 20f9ed9c4c | |||
| 04cb28c315 | |||
| a74ea318d1 | |||
| 98ed6b4e36 | |||
| 2c49d1fd11 | |||
| 6e7bca6631 | |||
| 2fe145bb02 | |||
| 10b7d235e3 | |||
| 232e2e7de2 | |||
| fb1e4b061e | |||
| 0b1a013081 | |||
| a972457f43 | |||
| 67cfa34a05 | |||
| fc2ebb7646 | |||
| e92b461b4f | |||
| b1ac7b5791 | |||
| 88424efe85 | |||
| 4e2aab98a2 | |||
| f4bc1a2fe2 | |||
| a4bf2768b8 | |||
| 47cd44e9da | |||
| 731c6b90ff | |||
| 47ca46905d | |||
| 860ffc5b13 | |||
| 611b2ee520 | |||
| edcb926f9d | |||
| caebff8304 | |||
| 8fa41135ca | |||
| 0debbff964 | |||
| d6cc78be66 | |||
| 8d9645735e | |||
| 4c65f08330 | |||
| 2427f8f078 | |||
| d168e4f934 | |||
| 4dd365589f | |||
| 50e253df29 | |||
| cb71801a2b | |||
| 4a9c74e91d | |||
| 281508ec99 | |||
| feb92626e1 | |||
| 93cadb0880 | |||
| dd6b57aa60 | |||
| b8cb754e9d | |||
| dbe61507bd | |||
| ce7b23d9d0 | |||
| 8ded6ff93e | |||
| 1ef96f3488 | |||
| ee3bf37900 | |||
| 7452a06938 | |||
| fe8f9ed9c4 | |||
| 1b64f74c82 | |||
| c81949046d | |||
| 19dcb913e6 | |||
| e4b5ba1a9d | |||
| 5f1a422d83 | |||
| c5b0b3ef9d | |||
| c0a04cb876 | |||
| 3cc7cdf12f | |||
| 6b531d9967 | |||
| 4d05ac021c | |||
| d29aa84b17 | |||
| a075adc818 | |||
| 4d0e63f99c | |||
| 9e11936ec5 | |||
| a4075ec632 | |||
| dadb59c95f | |||
| e73cc6a9d8 | |||
| 10cd84e37f | |||
| e63e2040cd | |||
| 91063332d7 | |||
| 503330ba5d | |||
| 0a64085f47 | |||
| 1073e2447a | |||
| 5b1a906ace | |||
| aff97e0146 | |||
| a4b41a378b | |||
| 3ec523d168 | |||
| 622cf0d642 | |||
| a540751e83 | |||
| 11b596669a | |||
| fefbae879b | |||
| 695b281409 | |||
| 9f9eae34c1 | |||
| ae37ed3500 | |||
| f7f509999b | |||
| 419bcc4b2f | |||
| 7b59d4f7eb | |||
| 03326e9c04 | |||
| f40b464d1e | |||
| 810ca6c207 | |||
| 8df3aef6aa | |||
| 0223d5a656 | |||
| aad810a204 | |||
| 1b8b7567b1 | |||
| 442040caac | |||
| 65efaafca2 | |||
| e87c8ab0c7 | |||
| be6bda45b4 | |||
| 8c9e40d383 | |||
| 0f6f9b973a | |||
| 3db6039b2b | |||
| 4051217c8b | |||
| c5c28baba1 |
@@ -0,0 +1,31 @@
|
||||
[suppress_function]
|
||||
symbol_version_regexp = LIBVIRT_PRIVATE.*
|
||||
soname_regexp = libvirt\\.so.*
|
||||
|
||||
[suppress_function]
|
||||
symbol_version_regexp = LIBVIRT_ADMIN_PRIVATE.*
|
||||
soname_regexp = libvirt-admin\\.so.*
|
||||
|
||||
[suppress_variable]
|
||||
symbol_version_regexp = LIBVIRT_PRIVATE.*
|
||||
soname_regexp = libvirt\\.so.*
|
||||
|
||||
[suppress_variable]
|
||||
symbol_version_regexp = LIBVIRT_ADMIN_PRIVATE.*
|
||||
soname_regexp = libvirt-admin\\.so.*
|
||||
|
||||
[suppress_function]
|
||||
symbol_version_regexp = .*
|
||||
soname_regexp = libvirt_storage_.*\\.so.*
|
||||
|
||||
[suppress_variable]
|
||||
symbol_version_regexp = .*
|
||||
soname_regexp = libvirt_storage_.*\\.so.*
|
||||
|
||||
[suppress_function]
|
||||
symbol_version_regexp = .*
|
||||
soname_regexp = libvirt_driver_.*\\.so.*
|
||||
|
||||
[suppress_variable]
|
||||
symbol_version_regexp = .*
|
||||
soname_regexp = libvirt_driver_.*\\.so.*
|
||||
+1
-1
@@ -2,4 +2,4 @@
|
||||
*.rpm
|
||||
i686
|
||||
x86_64
|
||||
libvirt-*.tar.gz
|
||||
libvirt-*.tar.xz
|
||||
|
||||
@@ -1,66 +0,0 @@
|
||||
From d519f225d79a61451cfa62b463ea3083e9367353 Mon Sep 17 00:00:00 2001
|
||||
From: Michal Privoznik <mprivozn@redhat.com>
|
||||
Date: Tue, 1 Oct 2013 15:04:48 +0200
|
||||
Subject: [PATCH] qemu_hotplug: Allow QoS update in qemuDomainChangeNet
|
||||
|
||||
The qemuDomainChangeNet() is called when 'virsh update-device' is
|
||||
invoked on a NIC. Currently, we fail to update the QoS even though
|
||||
we have routines for that.
|
||||
|
||||
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
|
||||
(cherry picked from commit 9fa10d3901a14997f724fe50ad8a33d7f0d23abe)
|
||||
---
|
||||
src/qemu/qemu_hotplug.c | 19 +++++++++++++++++--
|
||||
1 file changed, 17 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
|
||||
index f06930e..818c726 100644
|
||||
--- a/src/qemu/qemu_hotplug.c
|
||||
+++ b/src/qemu/qemu_hotplug.c
|
||||
@@ -1799,6 +1799,7 @@ qemuDomainChangeNet(virQEMUDriverPtr driver,
|
||||
bool needFilterChange = false;
|
||||
bool needLinkStateChange = false;
|
||||
bool needReplaceDevDef = false;
|
||||
+ bool needBandwidthSet = false;
|
||||
int ret = -1;
|
||||
|
||||
if (!devslot || !(olddev = *devslot)) {
|
||||
@@ -2062,8 +2063,6 @@ qemuDomainChangeNet(virQEMUDriverPtr driver,
|
||||
virDomainNetGetActualDirectMode(olddev) != virDomainNetGetActualDirectMode(olddev) ||
|
||||
!virNetDevVPortProfileEqual(virDomainNetGetActualVirtPortProfile(olddev),
|
||||
virDomainNetGetActualVirtPortProfile(newdev)) ||
|
||||
- !virNetDevBandwidthEqual(virDomainNetGetActualBandwidth(olddev),
|
||||
- virDomainNetGetActualBandwidth(newdev)) ||
|
||||
!virNetDevVlanEqual(virDomainNetGetActualVlan(olddev),
|
||||
virDomainNetGetActualVlan(newdev))) {
|
||||
needReconnect = true;
|
||||
@@ -2072,6 +2071,10 @@ qemuDomainChangeNet(virQEMUDriverPtr driver,
|
||||
if (olddev->linkstate != newdev->linkstate)
|
||||
needLinkStateChange = true;
|
||||
|
||||
+ if (!virNetDevBandwidthEqual(virDomainNetGetActualBandwidth(olddev),
|
||||
+ virDomainNetGetActualBandwidth(newdev)))
|
||||
+ needBandwidthSet = true;
|
||||
+
|
||||
/* FINALLY - actually perform the required actions */
|
||||
|
||||
if (needReconnect) {
|
||||
@@ -2081,6 +2084,18 @@ qemuDomainChangeNet(virQEMUDriverPtr driver,
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
+ if (needBandwidthSet) {
|
||||
+ if (virNetDevBandwidthSet(newdev->ifname,
|
||||
+ virDomainNetGetActualBandwidth(newdev),
|
||||
+ false) < 0) {
|
||||
+ virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||
+ _("cannot set bandwidth limits on %s"),
|
||||
+ newdev->ifname);
|
||||
+ goto cleanup;
|
||||
+ }
|
||||
+ needReplaceDevDef = true;
|
||||
+ }
|
||||
+
|
||||
if (needBridgeChange) {
|
||||
if (qemuDomainChangeNetBridge(dom->conn, vm, olddev, newdev) < 0)
|
||||
goto cleanup;
|
||||
@@ -0,0 +1,36 @@
|
||||
From: Michal Privoznik <mprivozn@redhat.com>
|
||||
Date: Mon, 9 Mar 2020 16:40:57 +0100
|
||||
Subject: [PATCH] virDomainDiskTranslateSourcePool: Check for disk type
|
||||
correctly
|
||||
|
||||
When rewriting the virDomainDiskTranslateSourcePool() function in
|
||||
v6.1.0-rc1~184 a typo was introduced. Previously, we allowed
|
||||
startup policy only for those volumes which translated to
|
||||
VIR_STORAGE_TYPE_FILE. But starting with the referenced commit,
|
||||
the value we checked for was changed to VIR_STORAGE_VOL_FILE
|
||||
which comes from a different enum and has a different value too.
|
||||
This is wrong, because virStorageSourceGetActualType() returns a
|
||||
value from the original enum.
|
||||
|
||||
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1811728
|
||||
|
||||
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
|
||||
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
|
||||
(cherry picked from commit 3918dbd84e4951b43f93fbf50ef52be00274850c)
|
||||
---
|
||||
src/conf/domain_conf.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c
|
||||
index 17867eeece..fd2e8f4eb5 100644
|
||||
--- a/src/conf/domain_conf.c
|
||||
+++ b/src/conf/domain_conf.c
|
||||
@@ -31746,7 +31746,7 @@ virDomainDiskTranslateSourcePool(virDomainDiskDefPtr def)
|
||||
}
|
||||
|
||||
if (def->startupPolicy != 0 &&
|
||||
- virStorageSourceGetActualType(def->src) != VIR_STORAGE_VOL_FILE) {
|
||||
+ virStorageSourceGetActualType(def->src) != VIR_STORAGE_TYPE_FILE) {
|
||||
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||
_("'startupPolicy' is only valid for "
|
||||
"'file' type volume"));
|
||||
@@ -0,0 +1,55 @@
|
||||
From: Laine Stump <laine@redhat.com>
|
||||
Date: Thu, 7 May 2020 22:32:59 -0400
|
||||
Subject: [PATCH] network: make it safe to call networkSetupPrivateChains()
|
||||
multiple times
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
networkSetupPrivateChains() is currently called only once per run of
|
||||
libvirtd, so it can assume that errInitV4 and errInitV6 are empty/null
|
||||
when it is called. In preparation for potentially calling this
|
||||
function multiple times during one run, this patch moves the reset of
|
||||
errInitV[46] to the top of the function, to assure no memory is
|
||||
leaked.
|
||||
|
||||
Signed-off-by: Laine Stump <laine@redhat.com>
|
||||
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
|
||||
(cherry picked from commit de110f110fb917a31b9f33ad8e4b3c1d3284766a)
|
||||
---
|
||||
src/network/bridge_driver_linux.c | 8 ++++----
|
||||
1 file changed, 4 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/src/network/bridge_driver_linux.c b/src/network/bridge_driver_linux.c
|
||||
index 7bbde5c6a9..80bd2409e1 100644
|
||||
--- a/src/network/bridge_driver_linux.c
|
||||
+++ b/src/network/bridge_driver_linux.c
|
||||
@@ -48,6 +48,10 @@ static void networkSetupPrivateChains(void)
|
||||
VIR_DEBUG("Setting up global firewall chains");
|
||||
|
||||
createdChains = false;
|
||||
+ virFreeError(errInitV4);
|
||||
+ errInitV4 = NULL;
|
||||
+ virFreeError(errInitV6);
|
||||
+ errInitV6 = NULL;
|
||||
|
||||
rc = iptablesSetupPrivateChains(VIR_FIREWALL_LAYER_IPV4);
|
||||
if (rc < 0) {
|
||||
@@ -56,8 +60,6 @@ static void networkSetupPrivateChains(void)
|
||||
errInitV4 = virSaveLastError();
|
||||
virResetLastError();
|
||||
} else {
|
||||
- virFreeError(errInitV4);
|
||||
- errInitV4 = NULL;
|
||||
if (rc) {
|
||||
VIR_DEBUG("Created global IPv4 chains");
|
||||
createdChains = true;
|
||||
@@ -73,8 +75,6 @@ static void networkSetupPrivateChains(void)
|
||||
errInitV6 = virSaveLastError();
|
||||
virResetLastError();
|
||||
} else {
|
||||
- virFreeError(errInitV6);
|
||||
- errInitV6 = NULL;
|
||||
if (rc) {
|
||||
VIR_DEBUG("Created global IPv6 chains");
|
||||
createdChains = true;
|
||||
@@ -1,57 +0,0 @@
|
||||
From 658f4b3c39c9bdd490a44175742f8259dd10b84f Mon Sep 17 00:00:00 2001
|
||||
From: Michal Privoznik <mprivozn@redhat.com>
|
||||
Date: Wed, 2 Oct 2013 09:18:02 +0200
|
||||
Subject: [PATCH] virNetDevBandwidthEqual: Make it more robust
|
||||
|
||||
So far the virNetDevBandwidthEqual() expected both ->in and ->out items
|
||||
to be allocated for both @a and @b compared. This is not necessary true
|
||||
for all our code. For instance, running 'update-device' twice over a NIC
|
||||
with the very same XML results in SIGSEGV-ing in this function.
|
||||
|
||||
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
|
||||
(cherry picked from commit ee02fbc8e4a24c1347761ceff2ddb2c108e9611c)
|
||||
---
|
||||
src/util/virnetdevbandwidth.c | 26 ++++++++++++++++++++------
|
||||
1 file changed, 20 insertions(+), 6 deletions(-)
|
||||
|
||||
diff --git a/src/util/virnetdevbandwidth.c b/src/util/virnetdevbandwidth.c
|
||||
index 42b0a50..17f4fa3 100644
|
||||
--- a/src/util/virnetdevbandwidth.c
|
||||
+++ b/src/util/virnetdevbandwidth.c
|
||||
@@ -335,16 +335,30 @@ virNetDevBandwidthEqual(virNetDevBandwidthPtr a,
|
||||
return false;
|
||||
|
||||
/* in */
|
||||
- if (a->in->average != b->in->average ||
|
||||
- a->in->peak != b->in->peak ||
|
||||
- a->in->burst != b->in->burst)
|
||||
+ if (a->in) {
|
||||
+ if (!b->in)
|
||||
+ return false;
|
||||
+
|
||||
+ if (a->in->average != b->in->average ||
|
||||
+ a->in->peak != b->in->peak ||
|
||||
+ a->in->burst != b->in->burst)
|
||||
+ return false;
|
||||
+ } else if (b->in) {
|
||||
return false;
|
||||
+ }
|
||||
|
||||
/*out*/
|
||||
- if (a->out->average != b->out->average ||
|
||||
- a->out->peak != b->out->peak ||
|
||||
- a->out->burst != b->out->burst)
|
||||
+ if (a->out) {
|
||||
+ if (!b->out)
|
||||
+ return false;
|
||||
+
|
||||
+ if (a->out->average != b->out->average ||
|
||||
+ a->out->peak != b->out->peak ||
|
||||
+ a->out->burst != b->out->burst)
|
||||
+ return false;
|
||||
+ } else if (b->out) {
|
||||
return false;
|
||||
+ }
|
||||
|
||||
return true;
|
||||
}
|
||||
@@ -1,105 +0,0 @@
|
||||
From 56c170544f7a71749ef63fef650c71787c05e8af Mon Sep 17 00:00:00 2001
|
||||
From: "Daniel P. Berrange" <berrange@redhat.com>
|
||||
Date: Thu, 3 Oct 2013 14:06:58 +0100
|
||||
Subject: [PATCH] Remove virConnectPtr arg from virNWFilterDefParse*
|
||||
|
||||
None of the virNWFilterDefParse* methods require a virConnectPtr
|
||||
arg, so just drop it
|
||||
|
||||
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
|
||||
---
|
||||
src/conf/nwfilter_conf.c | 15 ++++++---------
|
||||
src/conf/nwfilter_conf.h | 6 ++----
|
||||
src/nwfilter/nwfilter_driver.c | 2 +-
|
||||
tests/nwfilterxml2xmltest.c | 2 +-
|
||||
4 files changed, 10 insertions(+), 15 deletions(-)
|
||||
|
||||
diff --git a/src/conf/nwfilter_conf.c b/src/conf/nwfilter_conf.c
|
||||
index 3456b77..c009921 100644
|
||||
--- a/src/conf/nwfilter_conf.c
|
||||
+++ b/src/conf/nwfilter_conf.c
|
||||
@@ -2634,8 +2634,7 @@ cleanup:
|
||||
|
||||
|
||||
static virNWFilterDefPtr
|
||||
-virNWFilterDefParse(virConnectPtr conn ATTRIBUTE_UNUSED,
|
||||
- const char *xmlStr,
|
||||
+virNWFilterDefParse(const char *xmlStr,
|
||||
const char *filename) {
|
||||
virNWFilterDefPtr def = NULL;
|
||||
xmlDocPtr xml;
|
||||
@@ -2650,18 +2649,16 @@ virNWFilterDefParse(virConnectPtr conn ATTRIBUTE_UNUSED,
|
||||
|
||||
|
||||
virNWFilterDefPtr
|
||||
-virNWFilterDefParseString(virConnectPtr conn,
|
||||
- const char *xmlStr)
|
||||
+virNWFilterDefParseString(const char *xmlStr)
|
||||
{
|
||||
- return virNWFilterDefParse(conn, xmlStr, NULL);
|
||||
+ return virNWFilterDefParse(xmlStr, NULL);
|
||||
}
|
||||
|
||||
|
||||
virNWFilterDefPtr
|
||||
-virNWFilterDefParseFile(virConnectPtr conn,
|
||||
- const char *filename)
|
||||
+virNWFilterDefParseFile(const char *filename)
|
||||
{
|
||||
- return virNWFilterDefParse(conn, NULL, filename);
|
||||
+ return virNWFilterDefParse(NULL, filename);
|
||||
}
|
||||
|
||||
|
||||
@@ -3056,7 +3053,7 @@ virNWFilterObjLoad(virConnectPtr conn,
|
||||
virNWFilterDefPtr def;
|
||||
virNWFilterObjPtr nwfilter;
|
||||
|
||||
- if (!(def = virNWFilterDefParseFile(conn, path))) {
|
||||
+ if (!(def = virNWFilterDefParseFile(path))) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
diff --git a/src/conf/nwfilter_conf.h b/src/conf/nwfilter_conf.h
|
||||
index 5d04cff..faa7527 100644
|
||||
--- a/src/conf/nwfilter_conf.h
|
||||
+++ b/src/conf/nwfilter_conf.h
|
||||
@@ -713,10 +713,8 @@ int virNWFilterLoadAllConfigs(virConnectPtr conn,
|
||||
char *virNWFilterConfigFile(const char *dir,
|
||||
const char *name);
|
||||
|
||||
-virNWFilterDefPtr virNWFilterDefParseString(virConnectPtr conn,
|
||||
- const char *xml);
|
||||
-virNWFilterDefPtr virNWFilterDefParseFile(virConnectPtr conn,
|
||||
- const char *filename);
|
||||
+virNWFilterDefPtr virNWFilterDefParseString(const char *xml);
|
||||
+virNWFilterDefPtr virNWFilterDefParseFile(const char *filename);
|
||||
|
||||
void virNWFilterObjLock(virNWFilterObjPtr obj);
|
||||
void virNWFilterObjUnlock(virNWFilterObjPtr obj);
|
||||
diff --git a/src/nwfilter/nwfilter_driver.c b/src/nwfilter/nwfilter_driver.c
|
||||
index 1ed28a2..c2afdfc 100644
|
||||
--- a/src/nwfilter/nwfilter_driver.c
|
||||
+++ b/src/nwfilter/nwfilter_driver.c
|
||||
@@ -566,7 +566,7 @@ nwfilterDefineXML(virConnectPtr conn,
|
||||
nwfilterDriverLock(driver);
|
||||
virNWFilterCallbackDriversLock();
|
||||
|
||||
- if (!(def = virNWFilterDefParseString(conn, xml)))
|
||||
+ if (!(def = virNWFilterDefParseString(xml)))
|
||||
goto cleanup;
|
||||
|
||||
if (virNWFilterDefineXMLEnsureACL(conn, def) < 0)
|
||||
diff --git a/tests/nwfilterxml2xmltest.c b/tests/nwfilterxml2xmltest.c
|
||||
index 84e61da..14191a6 100644
|
||||
--- a/tests/nwfilterxml2xmltest.c
|
||||
+++ b/tests/nwfilterxml2xmltest.c
|
||||
@@ -36,7 +36,7 @@ testCompareXMLToXMLFiles(const char *inxml, const char *outxml,
|
||||
|
||||
virResetLastError();
|
||||
|
||||
- if (!(dev = virNWFilterDefParseString(NULL, inXmlData))) {
|
||||
+ if (!(dev = virNWFilterDefParseString(inXmlData))) {
|
||||
if (expect_error) {
|
||||
virResetLastError();
|
||||
goto done;
|
||||
@@ -0,0 +1,265 @@
|
||||
From: Laine Stump <laine@redhat.com>
|
||||
Date: Thu, 7 May 2020 21:54:39 -0400
|
||||
Subject: [PATCH] network: force re-creation of iptables private chains on
|
||||
firewalld restart
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
When firewalld is stopped, it removes *all* iptables rules and chains,
|
||||
including those added by libvirt. Since restarting firewalld means
|
||||
stopping and then starting it, any time it is restarted, libvirt needs
|
||||
to recreate all the private iptables chains it uses, along with all
|
||||
the rules it adds.
|
||||
|
||||
We already have code in place to call networkReloadFirewallRules() any
|
||||
time we're notified of a firewalld start, and
|
||||
networkReloadFirewallRules() will call
|
||||
networkPreReloadFirewallRules(), which calls
|
||||
networkSetupPrivateChains(); unfortunately that last call is called
|
||||
using virOnce(), meaning that it will only be called the first time
|
||||
through networkPreReloadFirewallRules() after libvirtd starts - so of
|
||||
course when firewalld is later restarted, the call to
|
||||
networkSetupPrivateChains() is skipped.
|
||||
|
||||
The neat and tidy way to fix this would be if there was a standard way
|
||||
to reset a pthread_once_t object so that the next time virOnce was
|
||||
called, it would think the function hadn't been called, and call it
|
||||
again. Unfortunately, there isn't any official way of doing that (we
|
||||
*could* just fill it with 0 and hope for the best, but that doesn't
|
||||
seem very safe.
|
||||
|
||||
So instead, this patch just adds a static variable called
|
||||
chainInitDone, which is set to true after networkSetupPrivateChains()
|
||||
is called for the first time, and then during calls to
|
||||
networkPreReloadFirewallRules(), if chainInitDone is set, we call
|
||||
networkSetupPrivateChains() directly instead of via virOnce().
|
||||
|
||||
It may seem unsafe to directly call a function that is meant to be
|
||||
called only once, but I think in this case we're safe - there's
|
||||
nothing in the function that is inherently "once only" - it doesn't
|
||||
initialize anything that can't safely be re-initialized (as long as
|
||||
two threads don't try to do it at the same time), and it only happens
|
||||
when responding to a dbus message that firewalld has been started (and
|
||||
I don't think it's possible for us to be processing two of those at
|
||||
once), and even then only if the initial call to the function has
|
||||
already been completed (so we're safe if we receive a firewalld
|
||||
restart call at a time when we haven't yet called it, or even if
|
||||
another thread is already in the process of executing it. The only
|
||||
problematic bit I can think of is if another thread is in the process
|
||||
of adding an iptable rule at the time we're executing this function,
|
||||
but 1) none of those threads will be trying to add chains, and 2) if
|
||||
there was a concurrency problem with other threads adding iptables
|
||||
rules while firewalld was being restarted, it would still be a problem
|
||||
even without this change.
|
||||
|
||||
This is yet another patch that fixes an occurrence of this error:
|
||||
|
||||
COMMAND_FAILED: '/usr/sbin/iptables -w10 -w --table filter --insert LIBVIRT_INP --in-interface virbr0 --protocol tcp --destination-port 67 --jump ACCEPT' failed: iptables: No chain/target/match by that name.
|
||||
|
||||
In particular, this resolves: https://bugzilla.redhat.com/1813830
|
||||
|
||||
Signed-off-by: Laine Stump <laine@redhat.com>
|
||||
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
|
||||
(cherry picked from commit f5418b427e7d2f26803880309478de9103680826)
|
||||
---
|
||||
src/network/bridge_driver.c | 16 ++++---
|
||||
src/network/bridge_driver_linux.c | 69 ++++++++++++++++++----------
|
||||
src/network/bridge_driver_nop.c | 3 +-
|
||||
src/network/bridge_driver_platform.h | 2 +-
|
||||
4 files changed, 58 insertions(+), 32 deletions(-)
|
||||
|
||||
diff --git a/src/network/bridge_driver.c b/src/network/bridge_driver.c
|
||||
index 369e80a889..aaf14defe4 100644
|
||||
--- a/src/network/bridge_driver.c
|
||||
+++ b/src/network/bridge_driver.c
|
||||
@@ -273,7 +273,9 @@ static int
|
||||
networkShutdownNetworkExternal(virNetworkObjPtr obj);
|
||||
|
||||
static void
|
||||
-networkReloadFirewallRules(virNetworkDriverStatePtr driver, bool startup);
|
||||
+networkReloadFirewallRules(virNetworkDriverStatePtr driver,
|
||||
+ bool startup,
|
||||
+ bool force);
|
||||
|
||||
static void
|
||||
networkRefreshDaemons(virNetworkDriverStatePtr driver);
|
||||
@@ -689,7 +691,7 @@ firewalld_dbus_filter_bridge(DBusConnection *connection G_GNUC_UNUSED,
|
||||
|
||||
if (reload) {
|
||||
VIR_DEBUG("Reload in bridge_driver because of firewalld.");
|
||||
- networkReloadFirewallRules(driver, false);
|
||||
+ networkReloadFirewallRules(driver, false, true);
|
||||
}
|
||||
|
||||
return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
|
||||
@@ -798,7 +800,7 @@ networkStateInitialize(bool privileged,
|
||||
virNetworkObjListPrune(network_driver->networks,
|
||||
VIR_CONNECT_LIST_NETWORKS_INACTIVE |
|
||||
VIR_CONNECT_LIST_NETWORKS_TRANSIENT);
|
||||
- networkReloadFirewallRules(network_driver, true);
|
||||
+ networkReloadFirewallRules(network_driver, true, false);
|
||||
networkRefreshDaemons(network_driver);
|
||||
|
||||
if (virDriverShouldAutostart(network_driver->stateDir, &autostart) < 0)
|
||||
@@ -868,7 +870,7 @@ networkStateReload(void)
|
||||
network_driver->networkConfigDir,
|
||||
network_driver->networkAutostartDir,
|
||||
network_driver->xmlopt);
|
||||
- networkReloadFirewallRules(network_driver, false);
|
||||
+ networkReloadFirewallRules(network_driver, false, false);
|
||||
networkRefreshDaemons(network_driver);
|
||||
virNetworkObjListForEach(network_driver->networks,
|
||||
networkAutostartConfig,
|
||||
@@ -2236,14 +2238,16 @@ networkReloadFirewallRulesHelper(virNetworkObjPtr obj,
|
||||
|
||||
|
||||
static void
|
||||
-networkReloadFirewallRules(virNetworkDriverStatePtr driver, bool startup)
|
||||
+networkReloadFirewallRules(virNetworkDriverStatePtr driver,
|
||||
+ bool startup,
|
||||
+ bool force)
|
||||
{
|
||||
VIR_INFO("Reloading iptables rules");
|
||||
/* Ideally we'd not even register the driver when unprivilegd
|
||||
* but until we untangle the virt driver that's not viable */
|
||||
if (!driver->privileged)
|
||||
return;
|
||||
- networkPreReloadFirewallRules(driver, startup);
|
||||
+ networkPreReloadFirewallRules(driver, startup, force);
|
||||
virNetworkObjListForEach(driver->networks,
|
||||
networkReloadFirewallRulesHelper,
|
||||
NULL);
|
||||
diff --git a/src/network/bridge_driver_linux.c b/src/network/bridge_driver_linux.c
|
||||
index 80bd2409e1..b0bd207250 100644
|
||||
--- a/src/network/bridge_driver_linux.c
|
||||
+++ b/src/network/bridge_driver_linux.c
|
||||
@@ -36,11 +36,14 @@ VIR_LOG_INIT("network.bridge_driver_linux");
|
||||
#define PROC_NET_ROUTE "/proc/net/route"
|
||||
|
||||
static virOnceControl createdOnce;
|
||||
-static bool createdChains;
|
||||
+static bool chainInitDone; /* true iff networkSetupPrivateChains was ever called */
|
||||
+static bool createdChains; /* true iff networkSetupPrivateChains created chains during most recent call */
|
||||
static virErrorPtr errInitV4;
|
||||
static virErrorPtr errInitV6;
|
||||
|
||||
-/* Only call via virOnce */
|
||||
+/* Usually only called via virOnce, but can also be called directly in
|
||||
+ * response to firewalld reload (if chainInitDone == true)
|
||||
+ */
|
||||
static void networkSetupPrivateChains(void)
|
||||
{
|
||||
int rc;
|
||||
@@ -82,6 +85,8 @@ static void networkSetupPrivateChains(void)
|
||||
VIR_DEBUG("Global IPv6 chains already exist");
|
||||
}
|
||||
}
|
||||
+
|
||||
+ chainInitDone = true;
|
||||
}
|
||||
|
||||
|
||||
@@ -111,7 +116,10 @@ networkHasRunningNetworks(virNetworkDriverStatePtr driver)
|
||||
}
|
||||
|
||||
|
||||
-void networkPreReloadFirewallRules(virNetworkDriverStatePtr driver, bool startup)
|
||||
+void
|
||||
+networkPreReloadFirewallRules(virNetworkDriverStatePtr driver,
|
||||
+ bool startup,
|
||||
+ bool force)
|
||||
{
|
||||
/*
|
||||
* If there are any running networks, we need to
|
||||
@@ -130,29 +138,42 @@ void networkPreReloadFirewallRules(virNetworkDriverStatePtr driver, bool startup
|
||||
* of starting the network though as that makes them
|
||||
* more likely to be seen by a human
|
||||
*/
|
||||
- if (!networkHasRunningNetworks(driver)) {
|
||||
- VIR_DEBUG("Delayed global rule setup as no networks are running");
|
||||
- return;
|
||||
- }
|
||||
+ if (chainInitDone && force) {
|
||||
+ /* The Private chains have already been initialized once
|
||||
+ * during this run of libvirtd, so 1) we can't do it again via
|
||||
+ * virOnce(), and 2) we need to re-add the private chains even
|
||||
+ * if there are currently no running networks, because the
|
||||
+ * next time a network is started, libvirt will expect that
|
||||
+ * the chains have already been added. So we call directly
|
||||
+ * instead of via virOnce().
|
||||
+ */
|
||||
+ networkSetupPrivateChains();
|
||||
|
||||
- ignore_value(virOnce(&createdOnce, networkSetupPrivateChains));
|
||||
+ } else {
|
||||
+ if (!networkHasRunningNetworks(driver)) {
|
||||
+ VIR_DEBUG("Delayed global rule setup as no networks are running");
|
||||
+ return;
|
||||
+ }
|
||||
|
||||
- /*
|
||||
- * If this is initial startup, and we just created the
|
||||
- * top level private chains we either
|
||||
- *
|
||||
- * - upgraded from old libvirt
|
||||
- * - freshly booted from clean state
|
||||
- *
|
||||
- * In the first case we must delete the old rules from
|
||||
- * the built-in chains, instead of our new private chains.
|
||||
- * In the second case it doesn't matter, since no existing
|
||||
- * rules will be present. Thus we can safely just tell it
|
||||
- * to always delete from the builin chain
|
||||
- */
|
||||
- if (startup && createdChains) {
|
||||
- VIR_DEBUG("Requesting cleanup of legacy firewall rules");
|
||||
- iptablesSetDeletePrivate(false);
|
||||
+ ignore_value(virOnce(&createdOnce, networkSetupPrivateChains));
|
||||
+
|
||||
+ /*
|
||||
+ * If this is initial startup, and we just created the
|
||||
+ * top level private chains we either
|
||||
+ *
|
||||
+ * - upgraded from old libvirt
|
||||
+ * - freshly booted from clean state
|
||||
+ *
|
||||
+ * In the first case we must delete the old rules from
|
||||
+ * the built-in chains, instead of our new private chains.
|
||||
+ * In the second case it doesn't matter, since no existing
|
||||
+ * rules will be present. Thus we can safely just tell it
|
||||
+ * to always delete from the builin chain
|
||||
+ */
|
||||
+ if (startup && createdChains) {
|
||||
+ VIR_DEBUG("Requesting cleanup of legacy firewall rules");
|
||||
+ iptablesSetDeletePrivate(false);
|
||||
+ }
|
||||
}
|
||||
}
|
||||
|
||||
diff --git a/src/network/bridge_driver_nop.c b/src/network/bridge_driver_nop.c
|
||||
index 08d737511f..db89c10023 100644
|
||||
--- a/src/network/bridge_driver_nop.c
|
||||
+++ b/src/network/bridge_driver_nop.c
|
||||
@@ -20,7 +20,8 @@
|
||||
#include <config.h>
|
||||
|
||||
void networkPreReloadFirewallRules(virNetworkDriverStatePtr driver G_GNUC_UNUSED,
|
||||
- bool startup G_GNUC_UNUSED)
|
||||
+ bool startup G_GNUC_UNUSED,
|
||||
+ bool force G_GNUC_UNUSED)
|
||||
{
|
||||
}
|
||||
|
||||
diff --git a/src/network/bridge_driver_platform.h b/src/network/bridge_driver_platform.h
|
||||
index 169417a6c0..48ab52c160 100644
|
||||
--- a/src/network/bridge_driver_platform.h
|
||||
+++ b/src/network/bridge_driver_platform.h
|
||||
@@ -62,7 +62,7 @@ struct _virNetworkDriverState {
|
||||
typedef struct _virNetworkDriverState virNetworkDriverState;
|
||||
typedef virNetworkDriverState *virNetworkDriverStatePtr;
|
||||
|
||||
-void networkPreReloadFirewallRules(virNetworkDriverStatePtr driver, bool startup);
|
||||
+void networkPreReloadFirewallRules(virNetworkDriverStatePtr driver, bool startup, bool force);
|
||||
void networkPostReloadFirewallRules(bool startup);
|
||||
|
||||
int networkCheckRouteCollision(virNetworkDefPtr def);
|
||||
@@ -1,355 +0,0 @@
|
||||
From 0a5abfb22d5d030cc3780c44b805b5b92567b44a Mon Sep 17 00:00:00 2001
|
||||
From: "Daniel P. Berrange" <berrange@redhat.com>
|
||||
Date: Thu, 3 Oct 2013 14:06:59 +0100
|
||||
Subject: [PATCH] Don't pass virConnectPtr in nwfilter 'struct
|
||||
domUpdateCBStruct'
|
||||
|
||||
The nwfilter driver only needs a reference to its private
|
||||
state object, not a full virConnectPtr. Update the domUpdateCBStruct
|
||||
struct to have a 'void *opaque' field instead of a virConnectPtr.
|
||||
|
||||
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
|
||||
---
|
||||
src/conf/nwfilter_conf.c | 14 +++++++++++---
|
||||
src/conf/nwfilter_conf.h | 4 ++--
|
||||
src/nwfilter/nwfilter_dhcpsnoop.c | 12 ++++++------
|
||||
src/nwfilter/nwfilter_driver.c | 5 +++--
|
||||
src/nwfilter/nwfilter_gentech_driver.c | 32 ++++++++++++++++----------------
|
||||
src/nwfilter/nwfilter_gentech_driver.h | 10 +++++-----
|
||||
src/nwfilter/nwfilter_learnipaddr.c | 6 +++---
|
||||
7 files changed, 46 insertions(+), 37 deletions(-)
|
||||
|
||||
diff --git a/src/conf/nwfilter_conf.c b/src/conf/nwfilter_conf.c
|
||||
index c009921..9927f7e 100644
|
||||
--- a/src/conf/nwfilter_conf.c
|
||||
+++ b/src/conf/nwfilter_conf.c
|
||||
@@ -2850,6 +2850,7 @@ virNWFilterCallbackDriversUnlock(void)
|
||||
|
||||
|
||||
static virDomainObjListIterator virNWFilterDomainFWUpdateCB;
|
||||
+static void *virNWFilterDomainFWUpdateOpaque;
|
||||
|
||||
/**
|
||||
* virNWFilterInstFiltersOnAllVMs:
|
||||
@@ -2861,7 +2862,7 @@ virNWFilterInstFiltersOnAllVMs(virConnectPtr conn)
|
||||
{
|
||||
size_t i;
|
||||
struct domUpdateCBStruct cb = {
|
||||
- .conn = conn,
|
||||
+ .opaque = virNWFilterDomainFWUpdateOpaque,
|
||||
.step = STEP_APPLY_CURRENT,
|
||||
.skipInterfaces = NULL, /* not needed */
|
||||
};
|
||||
@@ -2880,7 +2881,7 @@ virNWFilterTriggerVMFilterRebuild(virConnectPtr conn)
|
||||
size_t i;
|
||||
int ret = 0;
|
||||
struct domUpdateCBStruct cb = {
|
||||
- .conn = conn,
|
||||
+ .opaque = virNWFilterDomainFWUpdateOpaque,
|
||||
.step = STEP_APPLY_NEW,
|
||||
.skipInterfaces = virHashCreate(0, NULL),
|
||||
};
|
||||
@@ -3474,9 +3475,14 @@ char *virNWFilterConfigFile(const char *dir,
|
||||
}
|
||||
|
||||
|
||||
-int virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB)
|
||||
+int virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB,
|
||||
+ void *opaque)
|
||||
{
|
||||
+ if (initialized)
|
||||
+ return -1;
|
||||
+
|
||||
virNWFilterDomainFWUpdateCB = domUpdateCB;
|
||||
+ virNWFilterDomainFWUpdateOpaque = opaque;
|
||||
|
||||
initialized = true;
|
||||
|
||||
@@ -3495,6 +3501,8 @@ void virNWFilterConfLayerShutdown(void)
|
||||
virMutexDestroy(&updateMutex);
|
||||
|
||||
initialized = false;
|
||||
+ virNWFilterDomainFWUpdateOpaque = NULL;
|
||||
+ virNWFilterDomainFWUpdateCB = NULL;
|
||||
}
|
||||
|
||||
|
||||
diff --git a/src/conf/nwfilter_conf.h b/src/conf/nwfilter_conf.h
|
||||
index faa7527..e470615 100644
|
||||
--- a/src/conf/nwfilter_conf.h
|
||||
+++ b/src/conf/nwfilter_conf.h
|
||||
@@ -586,7 +586,7 @@ enum UpdateStep {
|
||||
};
|
||||
|
||||
struct domUpdateCBStruct {
|
||||
- virConnectPtr conn;
|
||||
+ void *opaque;
|
||||
enum UpdateStep step;
|
||||
virHashTablePtr skipInterfaces;
|
||||
};
|
||||
@@ -722,7 +722,7 @@ void virNWFilterObjUnlock(virNWFilterObjPtr obj);
|
||||
void virNWFilterLockFilterUpdates(void);
|
||||
void virNWFilterUnlockFilterUpdates(void);
|
||||
|
||||
-int virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB);
|
||||
+int virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB, void *opaque);
|
||||
void virNWFilterConfLayerShutdown(void);
|
||||
|
||||
int virNWFilterInstFiltersOnAllVMs(virConnectPtr conn);
|
||||
diff --git a/src/nwfilter/nwfilter_dhcpsnoop.c b/src/nwfilter/nwfilter_dhcpsnoop.c
|
||||
index 3e9f046..2bc1686 100644
|
||||
--- a/src/nwfilter/nwfilter_dhcpsnoop.c
|
||||
+++ b/src/nwfilter/nwfilter_dhcpsnoop.c
|
||||
@@ -481,15 +481,15 @@ virNWFilterSnoopIPLeaseInstallRule(virNWFilterSnoopIPLeasePtr ipl,
|
||||
/* instantiate the filters */
|
||||
|
||||
if (req->ifname)
|
||||
- rc = virNWFilterInstantiateFilterLate(NULL,
|
||||
+ rc = virNWFilterInstantiateFilterLate(req->driver,
|
||||
+ NULL,
|
||||
req->ifname,
|
||||
req->ifindex,
|
||||
req->linkdev,
|
||||
req->nettype,
|
||||
&req->macaddr,
|
||||
req->filtername,
|
||||
- req->vars,
|
||||
- req->driver);
|
||||
+ req->vars);
|
||||
|
||||
exit_snooprequnlock:
|
||||
virNWFilterSnoopReqUnlock(req);
|
||||
@@ -867,15 +867,15 @@ virNWFilterSnoopReqLeaseDel(virNWFilterSnoopReqPtr req,
|
||||
goto skip_instantiate;
|
||||
|
||||
if (ipAddrLeft) {
|
||||
- ret = virNWFilterInstantiateFilterLate(NULL,
|
||||
+ ret = virNWFilterInstantiateFilterLate(req->driver,
|
||||
+ NULL,
|
||||
req->ifname,
|
||||
req->ifindex,
|
||||
req->linkdev,
|
||||
req->nettype,
|
||||
&req->macaddr,
|
||||
req->filtername,
|
||||
- req->vars,
|
||||
- req->driver);
|
||||
+ req->vars);
|
||||
} else {
|
||||
const virNWFilterVarValuePtr dhcpsrvrs =
|
||||
virHashLookup(req->vars->hashTable, NWFILTER_VARNAME_DHCPSERVER);
|
||||
diff --git a/src/nwfilter/nwfilter_driver.c b/src/nwfilter/nwfilter_driver.c
|
||||
index c2afdfc..6e20e03 100644
|
||||
--- a/src/nwfilter/nwfilter_driver.c
|
||||
+++ b/src/nwfilter/nwfilter_driver.c
|
||||
@@ -203,7 +203,8 @@ nwfilterStateInitialize(bool privileged,
|
||||
|
||||
virNWFilterTechDriversInit(privileged);
|
||||
|
||||
- if (virNWFilterConfLayerInit(virNWFilterDomainFWUpdateCB) < 0)
|
||||
+ if (virNWFilterConfLayerInit(virNWFilterDomainFWUpdateCB,
|
||||
+ driverState) < 0)
|
||||
goto err_techdrivers_shutdown;
|
||||
|
||||
/*
|
||||
@@ -681,7 +682,7 @@ nwfilterInstantiateFilter(virConnectPtr conn,
|
||||
const unsigned char *vmuuid,
|
||||
virDomainNetDefPtr net)
|
||||
{
|
||||
- return virNWFilterInstantiateFilter(conn, vmuuid, net);
|
||||
+ return virNWFilterInstantiateFilter(conn->nwfilterPrivateData, vmuuid, net);
|
||||
}
|
||||
|
||||
|
||||
diff --git a/src/nwfilter/nwfilter_gentech_driver.c b/src/nwfilter/nwfilter_gentech_driver.c
|
||||
index 382d73f..5961165 100644
|
||||
--- a/src/nwfilter/nwfilter_gentech_driver.c
|
||||
+++ b/src/nwfilter/nwfilter_gentech_driver.c
|
||||
@@ -800,7 +800,8 @@ err_unresolvable_vars:
|
||||
* Call this function while holding the NWFilter filter update lock
|
||||
*/
|
||||
static int
|
||||
-__virNWFilterInstantiateFilter(const unsigned char *vmuuid,
|
||||
+__virNWFilterInstantiateFilter(virNWFilterDriverStatePtr driver,
|
||||
+ const unsigned char *vmuuid,
|
||||
bool teardownOld,
|
||||
const char *ifname,
|
||||
int ifindex,
|
||||
@@ -810,7 +811,6 @@ __virNWFilterInstantiateFilter(const unsigned char *vmuuid,
|
||||
const char *filtername,
|
||||
virNWFilterHashTablePtr filterparams,
|
||||
enum instCase useNewFilter,
|
||||
- virNWFilterDriverStatePtr driver,
|
||||
bool forceWithPendingReq,
|
||||
bool *foundNewFilter)
|
||||
{
|
||||
@@ -921,7 +921,7 @@ err_exit:
|
||||
|
||||
|
||||
static int
|
||||
-_virNWFilterInstantiateFilter(virConnectPtr conn,
|
||||
+_virNWFilterInstantiateFilter(virNWFilterDriverStatePtr driver,
|
||||
const unsigned char *vmuuid,
|
||||
const virDomainNetDefPtr net,
|
||||
bool teardownOld,
|
||||
@@ -948,7 +948,8 @@ _virNWFilterInstantiateFilter(virConnectPtr conn,
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
- rc = __virNWFilterInstantiateFilter(vmuuid,
|
||||
+ rc = __virNWFilterInstantiateFilter(driver,
|
||||
+ vmuuid,
|
||||
teardownOld,
|
||||
net->ifname,
|
||||
ifindex,
|
||||
@@ -958,7 +959,6 @@ _virNWFilterInstantiateFilter(virConnectPtr conn,
|
||||
net->filter,
|
||||
net->filterparams,
|
||||
useNewFilter,
|
||||
- conn->nwfilterPrivateData,
|
||||
false,
|
||||
foundNewFilter);
|
||||
|
||||
@@ -970,22 +970,23 @@ cleanup:
|
||||
|
||||
|
||||
int
|
||||
-virNWFilterInstantiateFilterLate(const unsigned char *vmuuid,
|
||||
+virNWFilterInstantiateFilterLate(virNWFilterDriverStatePtr driver,
|
||||
+ const unsigned char *vmuuid,
|
||||
const char *ifname,
|
||||
int ifindex,
|
||||
const char *linkdev,
|
||||
enum virDomainNetType nettype,
|
||||
const virMacAddrPtr macaddr,
|
||||
const char *filtername,
|
||||
- virNWFilterHashTablePtr filterparams,
|
||||
- virNWFilterDriverStatePtr driver)
|
||||
+ virNWFilterHashTablePtr filterparams)
|
||||
{
|
||||
int rc;
|
||||
bool foundNewFilter = false;
|
||||
|
||||
virNWFilterLockFilterUpdates();
|
||||
|
||||
- rc = __virNWFilterInstantiateFilter(vmuuid,
|
||||
+ rc = __virNWFilterInstantiateFilter(driver,
|
||||
+ vmuuid,
|
||||
true,
|
||||
ifname,
|
||||
ifindex,
|
||||
@@ -995,7 +996,6 @@ virNWFilterInstantiateFilterLate(const unsigned char *vmuuid,
|
||||
filtername,
|
||||
filterparams,
|
||||
INSTANTIATE_ALWAYS,
|
||||
- driver,
|
||||
true,
|
||||
&foundNewFilter);
|
||||
if (rc < 0) {
|
||||
@@ -1015,13 +1015,13 @@ virNWFilterInstantiateFilterLate(const unsigned char *vmuuid,
|
||||
|
||||
|
||||
int
|
||||
-virNWFilterInstantiateFilter(virConnectPtr conn,
|
||||
+virNWFilterInstantiateFilter(virNWFilterDriverStatePtr driver,
|
||||
const unsigned char *vmuuid,
|
||||
const virDomainNetDefPtr net)
|
||||
{
|
||||
bool foundNewFilter = false;
|
||||
|
||||
- return _virNWFilterInstantiateFilter(conn, vmuuid, net,
|
||||
+ return _virNWFilterInstantiateFilter(driver, vmuuid, net,
|
||||
1,
|
||||
INSTANTIATE_ALWAYS,
|
||||
&foundNewFilter);
|
||||
@@ -1029,14 +1029,14 @@ virNWFilterInstantiateFilter(virConnectPtr conn,
|
||||
|
||||
|
||||
int
|
||||
-virNWFilterUpdateInstantiateFilter(virConnectPtr conn,
|
||||
+virNWFilterUpdateInstantiateFilter(virNWFilterDriverStatePtr driver,
|
||||
const unsigned char *vmuuid,
|
||||
const virDomainNetDefPtr net,
|
||||
bool *skipIface)
|
||||
{
|
||||
bool foundNewFilter = false;
|
||||
|
||||
- int rc = _virNWFilterInstantiateFilter(conn, vmuuid, net,
|
||||
+ int rc = _virNWFilterInstantiateFilter(driver, vmuuid, net,
|
||||
0,
|
||||
INSTANTIATE_FOLLOW_NEWFILTER,
|
||||
&foundNewFilter);
|
||||
@@ -1154,7 +1154,7 @@ virNWFilterDomainFWUpdateCB(virDomainObjPtr obj,
|
||||
if ((net->filter) && (net->ifname)) {
|
||||
switch (cb->step) {
|
||||
case STEP_APPLY_NEW:
|
||||
- ret = virNWFilterUpdateInstantiateFilter(cb->conn,
|
||||
+ ret = virNWFilterUpdateInstantiateFilter(cb->opaque,
|
||||
vm->uuid,
|
||||
net,
|
||||
&skipIface);
|
||||
@@ -1179,7 +1179,7 @@ virNWFilterDomainFWUpdateCB(virDomainObjPtr obj,
|
||||
break;
|
||||
|
||||
case STEP_APPLY_CURRENT:
|
||||
- ret = virNWFilterInstantiateFilter(cb->conn,
|
||||
+ ret = virNWFilterInstantiateFilter(cb->opaque,
|
||||
vm->uuid,
|
||||
net);
|
||||
if (ret)
|
||||
diff --git a/src/nwfilter/nwfilter_gentech_driver.h b/src/nwfilter/nwfilter_gentech_driver.h
|
||||
index 4b47b4a..8528e2a 100644
|
||||
--- a/src/nwfilter/nwfilter_gentech_driver.h
|
||||
+++ b/src/nwfilter/nwfilter_gentech_driver.h
|
||||
@@ -39,23 +39,23 @@ enum instCase {
|
||||
};
|
||||
|
||||
|
||||
-int virNWFilterInstantiateFilter(virConnectPtr conn,
|
||||
+int virNWFilterInstantiateFilter(virNWFilterDriverStatePtr driver,
|
||||
const unsigned char *vmuuid,
|
||||
const virDomainNetDefPtr net);
|
||||
-int virNWFilterUpdateInstantiateFilter(virConnectPtr conn,
|
||||
+int virNWFilterUpdateInstantiateFilter(virNWFilterDriverStatePtr driver,
|
||||
const unsigned char *vmuuid,
|
||||
const virDomainNetDefPtr net,
|
||||
bool *skipIface);
|
||||
|
||||
-int virNWFilterInstantiateFilterLate(const unsigned char *vmuuid,
|
||||
+int virNWFilterInstantiateFilterLate(virNWFilterDriverStatePtr driver,
|
||||
+ const unsigned char *vmuuid,
|
||||
const char *ifname,
|
||||
int ifindex,
|
||||
const char *linkdev,
|
||||
enum virDomainNetType nettype,
|
||||
const virMacAddrPtr macaddr,
|
||||
const char *filtername,
|
||||
- virNWFilterHashTablePtr filterparams,
|
||||
- virNWFilterDriverStatePtr driver);
|
||||
+ virNWFilterHashTablePtr filterparams);
|
||||
|
||||
int virNWFilterTeardownFilter(const virDomainNetDefPtr net);
|
||||
|
||||
diff --git a/src/nwfilter/nwfilter_learnipaddr.c b/src/nwfilter/nwfilter_learnipaddr.c
|
||||
index 7e67203..093158a 100644
|
||||
--- a/src/nwfilter/nwfilter_learnipaddr.c
|
||||
+++ b/src/nwfilter/nwfilter_learnipaddr.c
|
||||
@@ -612,15 +612,15 @@ learnIPAddressThread(void *arg)
|
||||
"cache for interface %s"), inetaddr, req->ifname);
|
||||
}
|
||||
|
||||
- ret = virNWFilterInstantiateFilterLate(NULL,
|
||||
+ ret = virNWFilterInstantiateFilterLate(req->driver,
|
||||
+ NULL,
|
||||
req->ifname,
|
||||
req->ifindex,
|
||||
req->linkdev,
|
||||
req->nettype,
|
||||
&req->macaddr,
|
||||
req->filtername,
|
||||
- req->filterparams,
|
||||
- req->driver);
|
||||
+ req->filterparams);
|
||||
VIR_DEBUG("Result from applying firewall rules on "
|
||||
"%s with IP addr %s : %d\n", req->ifname, inetaddr, ret);
|
||||
}
|
||||
@@ -0,0 +1,100 @@
|
||||
From: Laine Stump <laine@redhat.com>
|
||||
Date: Fri, 1 May 2020 00:05:50 -0400
|
||||
Subject: [PATCH] systemd: start libvirtd after firewalld/iptables services
|
||||
|
||||
When a system has enabled the iptables/ip6tables services rather than
|
||||
firewalld, there is no explicit ordering of the start of those
|
||||
services vs. libvirtd. This creates a problem when libvirtd.service is
|
||||
started before ip[6]tables, as the latter, when it finally is started,
|
||||
will remove all of the iptables rules that had previously been added
|
||||
by libvirt, including the custom chains where libvirt's rules are
|
||||
kept. This results in an error message similar to the following when a
|
||||
user subsequently tries to start a new libvirt network:
|
||||
|
||||
"Error while activating network: Call to virNetworkCreate failed:
|
||||
internal error: Failed to apply firewall rules
|
||||
/usr/sbin/ip6tables -w --table filter --insert LIBVIRT_FWO \
|
||||
--in-interface virbr2 --jump REJECT:
|
||||
ip6tables: No chain/target/match by that name."
|
||||
|
||||
(Prior to logging this error, it also would have caused failure to
|
||||
forward (or block) traffic in some cases, e.g. for guests on a NATed
|
||||
network, since libvirt's rules to forward/block had all been deleted
|
||||
and libvirt didn't know about it, so it couldn't fix the problem)
|
||||
|
||||
When this happens, the problem can be remedied by simply restarting
|
||||
libvirtd.service (which has the side-effect of reloading all
|
||||
libvirt-generated firewall rules)
|
||||
|
||||
Instead, we can just explicitly stating in the libvirtd.service file
|
||||
that libvirtd.service should start after ip6tables.service and
|
||||
ip6tables.service, eliminating the race condition that leads to the
|
||||
error.
|
||||
|
||||
There is also nothing (that I can see) in the systemd .service files
|
||||
to guarantee that firewalld.service will be started (if enabled) prior
|
||||
to libvirtd.service. The same error scenario given above would occur
|
||||
if libvirtd.service started before firewalld.service. Even before
|
||||
that, though libvirtd would have detected that firewalld.service was
|
||||
disabled, and then turn off all firewalld support. So, for example,
|
||||
firewalld's libvirt zone wouldn't be used, and most likely traffic
|
||||
from guests would therefore be blocked (all with no external
|
||||
indication of the source of the problem other than a debug-level log
|
||||
when libvirtd was started saying that firewalld wasn't in use); also
|
||||
libvirtd wouldn't notice when firewalld reloaded its rules (which also
|
||||
simultaneously deletes all of libvirt's rules).
|
||||
|
||||
I'm not aware of any reports that have been traced back to
|
||||
libvirtd.service starting before firewalld.service, but have seen that
|
||||
error reported multiple times, and also don't see an existing
|
||||
dependency that would guarantee firewalld.service starts before
|
||||
libvirtd.service, so it's possible it's been happening and we just
|
||||
haven't gotten to the bottom of it.
|
||||
|
||||
This patch adds an After= line to the libvirtd.service file for each
|
||||
of iptables.service, ip6tables.service, and firewalld.servicee, which
|
||||
should guarantee that libvirtd.service isn't started until systemd has
|
||||
started whichever of the others is enabled.
|
||||
|
||||
This race was diagnosed, and patch proposed, by Jason Montleon in
|
||||
https://bugzilla.redhat.com/1723698 . At the time (April 2019) danpb
|
||||
agreed with him that this change to libvirtd.service was a reasonable
|
||||
thing to do, but I guess everyone thought someone else was going to
|
||||
post a patch, so in the end nobody did.
|
||||
|
||||
Signed-off-by: Laine Stump <laine@redhat.com>
|
||||
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
|
||||
(cherry picked from commit 0756415f147dda15a417bd79eef9a62027d176e6)
|
||||
---
|
||||
src/network/virtnetworkd.service.in | 3 +++
|
||||
src/remote/libvirtd.service.in | 3 +++
|
||||
2 files changed, 6 insertions(+)
|
||||
|
||||
diff --git a/src/network/virtnetworkd.service.in b/src/network/virtnetworkd.service.in
|
||||
index 656e8b4f84..56182e1693 100644
|
||||
--- a/src/network/virtnetworkd.service.in
|
||||
+++ b/src/network/virtnetworkd.service.in
|
||||
@@ -5,6 +5,9 @@ Requires=virtnetworkd.socket
|
||||
Requires=virtnetworkd-ro.socket
|
||||
Requires=virtnetworkd-admin.socket
|
||||
After=network.target
|
||||
+After=firewalld.service
|
||||
+After=iptables.service
|
||||
+After=ip6tables.service
|
||||
After=dbus.service
|
||||
After=apparmor.service
|
||||
After=local-fs.target
|
||||
diff --git a/src/remote/libvirtd.service.in b/src/remote/libvirtd.service.in
|
||||
index 90b2cad5b0..cc0d4e3693 100644
|
||||
--- a/src/remote/libvirtd.service.in
|
||||
+++ b/src/remote/libvirtd.service.in
|
||||
@@ -11,6 +11,9 @@ Wants=libvirtd-admin.socket
|
||||
Wants=systemd-machined.service
|
||||
Before=libvirt-guests.service
|
||||
After=network.target
|
||||
+After=firewalld.service
|
||||
+After=iptables.service
|
||||
+After=ip6tables.service
|
||||
After=dbus.service
|
||||
After=iscsid.service
|
||||
After=apparmor.service
|
||||
@@ -1,382 +0,0 @@
|
||||
From 1766db28533e2b5a96792aa0811e5364e0bb54d4 Mon Sep 17 00:00:00 2001
|
||||
From: "Daniel P. Berrange" <berrange@redhat.com>
|
||||
Date: Thu, 3 Oct 2013 14:07:00 +0100
|
||||
Subject: [PATCH] Remove use of virConnectPtr from all remaining nwfilter code
|
||||
|
||||
The virConnectPtr is passed around loads of nwfilter code in
|
||||
order to provide it as a parameter to the callback registered
|
||||
by the virt drivers. None of the virt drivers use this param
|
||||
though, so it serves no purpose.
|
||||
|
||||
Avoiding the need to pass a virConnectPtr means that the
|
||||
nwfilterStateReload method no longer needs to open a bogus
|
||||
QEMU driver connection. This addresses a race condition that
|
||||
can lead to a crash on startup.
|
||||
|
||||
The nwfilter driver starts before the QEMU driver and registers
|
||||
some callbacks with DBus to detect firewalld reload. If the
|
||||
firewalld reload happens while the QEMU driver is still starting
|
||||
up though, the nwfilterStateReload method will open a connection
|
||||
to the partially initialized QEMU driver and cause a crash.
|
||||
|
||||
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
|
||||
---
|
||||
src/conf/nwfilter_conf.c | 49 ++++++++++++++++--------------------------
|
||||
src/conf/nwfilter_conf.h | 14 +++++-------
|
||||
src/lxc/lxc_driver.c | 3 +--
|
||||
src/nwfilter/nwfilter_driver.c | 42 ++++++++++++++----------------------
|
||||
src/qemu/qemu_driver.c | 3 +--
|
||||
src/uml/uml_driver.c | 3 +--
|
||||
6 files changed, 43 insertions(+), 71 deletions(-)
|
||||
|
||||
diff --git a/src/conf/nwfilter_conf.c b/src/conf/nwfilter_conf.c
|
||||
index 9927f7e..7152aae 100644
|
||||
--- a/src/conf/nwfilter_conf.c
|
||||
+++ b/src/conf/nwfilter_conf.c
|
||||
@@ -2744,8 +2744,7 @@ cleanup:
|
||||
|
||||
|
||||
static int
|
||||
-_virNWFilterDefLoopDetect(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+_virNWFilterDefLoopDetect(virNWFilterObjListPtr nwfilters,
|
||||
virNWFilterDefPtr def,
|
||||
const char *filtername)
|
||||
{
|
||||
@@ -2769,7 +2768,7 @@ _virNWFilterDefLoopDetect(virConnectPtr conn,
|
||||
obj = virNWFilterObjFindByName(nwfilters,
|
||||
entry->include->filterref);
|
||||
if (obj) {
|
||||
- rc = _virNWFilterDefLoopDetect(conn, nwfilters,
|
||||
+ rc = _virNWFilterDefLoopDetect(nwfilters,
|
||||
obj->def, filtername);
|
||||
|
||||
virNWFilterObjUnlock(obj);
|
||||
@@ -2785,7 +2784,6 @@ _virNWFilterDefLoopDetect(virConnectPtr conn,
|
||||
|
||||
/*
|
||||
* virNWFilterDefLoopDetect:
|
||||
- * @conn: pointer to virConnect object
|
||||
* @nwfilters : the nwfilters to search
|
||||
* @def : the filter definition that may add a loop and is to be tested
|
||||
*
|
||||
@@ -2795,11 +2793,10 @@ _virNWFilterDefLoopDetect(virConnectPtr conn,
|
||||
* Returns 0 in case no loop was detected, -1 otherwise.
|
||||
*/
|
||||
static int
|
||||
-virNWFilterDefLoopDetect(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+virNWFilterDefLoopDetect(virNWFilterObjListPtr nwfilters,
|
||||
virNWFilterDefPtr def)
|
||||
{
|
||||
- return _virNWFilterDefLoopDetect(conn, nwfilters, def, def->name);
|
||||
+ return _virNWFilterDefLoopDetect(nwfilters, def, def->name);
|
||||
}
|
||||
|
||||
int nCallbackDriver;
|
||||
@@ -2858,7 +2855,7 @@ static void *virNWFilterDomainFWUpdateOpaque;
|
||||
* error. This should be called upon reloading of the driver.
|
||||
*/
|
||||
int
|
||||
-virNWFilterInstFiltersOnAllVMs(virConnectPtr conn)
|
||||
+virNWFilterInstFiltersOnAllVMs(void)
|
||||
{
|
||||
size_t i;
|
||||
struct domUpdateCBStruct cb = {
|
||||
@@ -2868,15 +2865,14 @@ virNWFilterInstFiltersOnAllVMs(virConnectPtr conn)
|
||||
};
|
||||
|
||||
for (i = 0; i < nCallbackDriver; i++)
|
||||
- callbackDrvArray[i]->vmFilterRebuild(conn,
|
||||
- virNWFilterDomainFWUpdateCB,
|
||||
+ callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
|
||||
&cb);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int
|
||||
-virNWFilterTriggerVMFilterRebuild(virConnectPtr conn)
|
||||
+virNWFilterTriggerVMFilterRebuild(void)
|
||||
{
|
||||
size_t i;
|
||||
int ret = 0;
|
||||
@@ -2890,8 +2886,7 @@ virNWFilterTriggerVMFilterRebuild(virConnectPtr conn)
|
||||
return -1;
|
||||
|
||||
for (i = 0; i < nCallbackDriver; i++) {
|
||||
- if (callbackDrvArray[i]->vmFilterRebuild(conn,
|
||||
- virNWFilterDomainFWUpdateCB,
|
||||
+ if (callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
|
||||
&cb) < 0)
|
||||
ret = -1;
|
||||
}
|
||||
@@ -2900,15 +2895,13 @@ virNWFilterTriggerVMFilterRebuild(virConnectPtr conn)
|
||||
cb.step = STEP_TEAR_NEW; /* rollback */
|
||||
|
||||
for (i = 0; i < nCallbackDriver; i++)
|
||||
- callbackDrvArray[i]->vmFilterRebuild(conn,
|
||||
- virNWFilterDomainFWUpdateCB,
|
||||
+ callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
|
||||
&cb);
|
||||
} else {
|
||||
cb.step = STEP_TEAR_OLD; /* switch over */
|
||||
|
||||
for (i = 0; i < nCallbackDriver; i++)
|
||||
- callbackDrvArray[i]->vmFilterRebuild(conn,
|
||||
- virNWFilterDomainFWUpdateCB,
|
||||
+ callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
|
||||
&cb);
|
||||
}
|
||||
|
||||
@@ -2919,14 +2912,13 @@ virNWFilterTriggerVMFilterRebuild(virConnectPtr conn)
|
||||
|
||||
|
||||
int
|
||||
-virNWFilterTestUnassignDef(virConnectPtr conn,
|
||||
- virNWFilterObjPtr nwfilter)
|
||||
+virNWFilterTestUnassignDef(virNWFilterObjPtr nwfilter)
|
||||
{
|
||||
int rc = 0;
|
||||
|
||||
nwfilter->wantRemoved = 1;
|
||||
/* trigger the update on VMs referencing the filter */
|
||||
- if (virNWFilterTriggerVMFilterRebuild(conn))
|
||||
+ if (virNWFilterTriggerVMFilterRebuild())
|
||||
rc = -1;
|
||||
|
||||
nwfilter->wantRemoved = 0;
|
||||
@@ -2965,8 +2957,7 @@ cleanup:
|
||||
}
|
||||
|
||||
virNWFilterObjPtr
|
||||
-virNWFilterObjAssignDef(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+virNWFilterObjAssignDef(virNWFilterObjListPtr nwfilters,
|
||||
virNWFilterDefPtr def)
|
||||
{
|
||||
virNWFilterObjPtr nwfilter;
|
||||
@@ -2985,7 +2976,7 @@ virNWFilterObjAssignDef(virConnectPtr conn,
|
||||
virNWFilterObjUnlock(nwfilter);
|
||||
}
|
||||
|
||||
- if (virNWFilterDefLoopDetect(conn, nwfilters, def) < 0) {
|
||||
+ if (virNWFilterDefLoopDetect(nwfilters, def) < 0) {
|
||||
virReportError(VIR_ERR_OPERATION_FAILED,
|
||||
"%s", _("filter would introduce a loop"));
|
||||
return NULL;
|
||||
@@ -3004,7 +2995,7 @@ virNWFilterObjAssignDef(virConnectPtr conn,
|
||||
|
||||
nwfilter->newDef = def;
|
||||
/* trigger the update on VMs referencing the filter */
|
||||
- if (virNWFilterTriggerVMFilterRebuild(conn)) {
|
||||
+ if (virNWFilterTriggerVMFilterRebuild()) {
|
||||
nwfilter->newDef = NULL;
|
||||
virNWFilterUnlockFilterUpdates();
|
||||
virNWFilterObjUnlock(nwfilter);
|
||||
@@ -3046,8 +3037,7 @@ virNWFilterObjAssignDef(virConnectPtr conn,
|
||||
|
||||
|
||||
static virNWFilterObjPtr
|
||||
-virNWFilterObjLoad(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+virNWFilterObjLoad(virNWFilterObjListPtr nwfilters,
|
||||
const char *file,
|
||||
const char *path)
|
||||
{
|
||||
@@ -3066,7 +3056,7 @@ virNWFilterObjLoad(virConnectPtr conn,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
- if (!(nwfilter = virNWFilterObjAssignDef(conn, nwfilters, def))) {
|
||||
+ if (!(nwfilter = virNWFilterObjAssignDef(nwfilters, def))) {
|
||||
virNWFilterDefFree(def);
|
||||
return NULL;
|
||||
}
|
||||
@@ -3082,8 +3072,7 @@ virNWFilterObjLoad(virConnectPtr conn,
|
||||
|
||||
|
||||
int
|
||||
-virNWFilterLoadAllConfigs(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+virNWFilterLoadAllConfigs(virNWFilterObjListPtr nwfilters,
|
||||
const char *configDir)
|
||||
{
|
||||
DIR *dir;
|
||||
@@ -3111,7 +3100,7 @@ virNWFilterLoadAllConfigs(virConnectPtr conn,
|
||||
if (!(path = virFileBuildPath(configDir, entry->d_name, NULL)))
|
||||
continue;
|
||||
|
||||
- nwfilter = virNWFilterObjLoad(conn, nwfilters, entry->d_name, path);
|
||||
+ nwfilter = virNWFilterObjLoad(nwfilters, entry->d_name, path);
|
||||
if (nwfilter)
|
||||
virNWFilterObjUnlock(nwfilter);
|
||||
|
||||
diff --git a/src/conf/nwfilter_conf.h b/src/conf/nwfilter_conf.h
|
||||
index e470615..29906f1 100644
|
||||
--- a/src/conf/nwfilter_conf.h
|
||||
+++ b/src/conf/nwfilter_conf.h
|
||||
@@ -687,12 +687,10 @@ int virNWFilterObjSaveDef(virNWFilterDriverStatePtr driver,
|
||||
|
||||
int virNWFilterObjDeleteDef(virNWFilterObjPtr nwfilter);
|
||||
|
||||
-virNWFilterObjPtr virNWFilterObjAssignDef(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+virNWFilterObjPtr virNWFilterObjAssignDef(virNWFilterObjListPtr nwfilters,
|
||||
virNWFilterDefPtr def);
|
||||
|
||||
-int virNWFilterTestUnassignDef(virConnectPtr conn,
|
||||
- virNWFilterObjPtr nwfilter);
|
||||
+int virNWFilterTestUnassignDef(virNWFilterObjPtr nwfilter);
|
||||
|
||||
virNWFilterDefPtr virNWFilterDefParseNode(xmlDocPtr xml,
|
||||
xmlNodePtr root);
|
||||
@@ -706,8 +704,7 @@ int virNWFilterSaveXML(const char *configDir,
|
||||
int virNWFilterSaveConfig(const char *configDir,
|
||||
virNWFilterDefPtr def);
|
||||
|
||||
-int virNWFilterLoadAllConfigs(virConnectPtr conn,
|
||||
- virNWFilterObjListPtr nwfilters,
|
||||
+int virNWFilterLoadAllConfigs(virNWFilterObjListPtr nwfilters,
|
||||
const char *configDir);
|
||||
|
||||
char *virNWFilterConfigFile(const char *dir,
|
||||
@@ -725,11 +722,10 @@ void virNWFilterUnlockFilterUpdates(void);
|
||||
int virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB, void *opaque);
|
||||
void virNWFilterConfLayerShutdown(void);
|
||||
|
||||
-int virNWFilterInstFiltersOnAllVMs(virConnectPtr conn);
|
||||
+int virNWFilterInstFiltersOnAllVMs(void);
|
||||
|
||||
|
||||
-typedef int (*virNWFilterRebuild)(virConnectPtr conn,
|
||||
- virDomainObjListIterator domUpdateCB,
|
||||
+typedef int (*virNWFilterRebuild)(virDomainObjListIterator domUpdateCB,
|
||||
void *data);
|
||||
typedef void (*virNWFilterVoidCall)(void);
|
||||
|
||||
diff --git a/src/lxc/lxc_driver.c b/src/lxc/lxc_driver.c
|
||||
index 8b13f84..e3a34d6 100644
|
||||
--- a/src/lxc/lxc_driver.c
|
||||
+++ b/src/lxc/lxc_driver.c
|
||||
@@ -84,8 +84,7 @@ virLXCDriverPtr lxc_driver = NULL;
|
||||
|
||||
/* callbacks for nwfilter */
|
||||
static int
|
||||
-lxcVMFilterRebuild(virConnectPtr conn ATTRIBUTE_UNUSED,
|
||||
- virDomainObjListIterator iter, void *data)
|
||||
+lxcVMFilterRebuild(virDomainObjListIterator iter, void *data)
|
||||
{
|
||||
return virDomainObjListForEach(lxc_driver->domains, iter, data);
|
||||
}
|
||||
diff --git a/src/nwfilter/nwfilter_driver.c b/src/nwfilter/nwfilter_driver.c
|
||||
index 6e20e03..d25c6f2 100644
|
||||
--- a/src/nwfilter/nwfilter_driver.c
|
||||
+++ b/src/nwfilter/nwfilter_driver.c
|
||||
@@ -235,8 +235,7 @@ nwfilterStateInitialize(bool privileged,
|
||||
|
||||
VIR_FREE(base);
|
||||
|
||||
- if (virNWFilterLoadAllConfigs(NULL,
|
||||
- &driverState->nwfilters,
|
||||
+ if (virNWFilterLoadAllConfigs(&driverState->nwfilters,
|
||||
driverState->configDir) < 0)
|
||||
goto error;
|
||||
|
||||
@@ -272,37 +271,28 @@ err_free_driverstate:
|
||||
* files and update its state
|
||||
*/
|
||||
static int
|
||||
-nwfilterStateReload(void) {
|
||||
- virConnectPtr conn;
|
||||
-
|
||||
- if (!driverState) {
|
||||
+nwfilterStateReload(void)
|
||||
+{
|
||||
+ if (!driverState)
|
||||
return -1;
|
||||
- }
|
||||
|
||||
if (!driverState->privileged)
|
||||
return 0;
|
||||
|
||||
- conn = virConnectOpen("qemu:///system");
|
||||
-
|
||||
- if (conn) {
|
||||
- virNWFilterDHCPSnoopEnd(NULL);
|
||||
- /* shut down all threads -- they will be restarted if necessary */
|
||||
- virNWFilterLearnThreadsTerminate(true);
|
||||
-
|
||||
- nwfilterDriverLock(driverState);
|
||||
- virNWFilterCallbackDriversLock();
|
||||
+ virNWFilterDHCPSnoopEnd(NULL);
|
||||
+ /* shut down all threads -- they will be restarted if necessary */
|
||||
+ virNWFilterLearnThreadsTerminate(true);
|
||||
|
||||
- virNWFilterLoadAllConfigs(conn,
|
||||
- &driverState->nwfilters,
|
||||
- driverState->configDir);
|
||||
+ nwfilterDriverLock(driverState);
|
||||
+ virNWFilterCallbackDriversLock();
|
||||
|
||||
- virNWFilterCallbackDriversUnlock();
|
||||
- nwfilterDriverUnlock(driverState);
|
||||
+ virNWFilterLoadAllConfigs(&driverState->nwfilters,
|
||||
+ driverState->configDir);
|
||||
|
||||
- virNWFilterInstFiltersOnAllVMs(conn);
|
||||
+ virNWFilterCallbackDriversUnlock();
|
||||
+ nwfilterDriverUnlock(driverState);
|
||||
|
||||
- virConnectClose(conn);
|
||||
- }
|
||||
+ virNWFilterInstFiltersOnAllVMs();
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -573,7 +563,7 @@ nwfilterDefineXML(virConnectPtr conn,
|
||||
if (virNWFilterDefineXMLEnsureACL(conn, def) < 0)
|
||||
goto cleanup;
|
||||
|
||||
- if (!(nwfilter = virNWFilterObjAssignDef(conn, &driver->nwfilters, def)))
|
||||
+ if (!(nwfilter = virNWFilterObjAssignDef(&driver->nwfilters, def)))
|
||||
goto cleanup;
|
||||
|
||||
if (virNWFilterObjSaveDef(driver, nwfilter, def) < 0) {
|
||||
@@ -617,7 +607,7 @@ nwfilterUndefine(virNWFilterPtr obj) {
|
||||
if (virNWFilterUndefineEnsureACL(obj->conn, nwfilter->def) < 0)
|
||||
goto cleanup;
|
||||
|
||||
- if (virNWFilterTestUnassignDef(obj->conn, nwfilter) < 0) {
|
||||
+ if (virNWFilterTestUnassignDef(nwfilter) < 0) {
|
||||
virReportError(VIR_ERR_OPERATION_INVALID,
|
||||
"%s",
|
||||
_("nwfilter is in use"));
|
||||
diff --git a/src/qemu/qemu_driver.c b/src/qemu/qemu_driver.c
|
||||
index e8bc04d..068d29f 100644
|
||||
--- a/src/qemu/qemu_driver.c
|
||||
+++ b/src/qemu/qemu_driver.c
|
||||
@@ -177,8 +177,7 @@ static void
|
||||
qemuVMDriverUnlock(void) {}
|
||||
|
||||
static int
|
||||
-qemuVMFilterRebuild(virConnectPtr conn ATTRIBUTE_UNUSED,
|
||||
- virDomainObjListIterator iter, void *data)
|
||||
+qemuVMFilterRebuild(virDomainObjListIterator iter, void *data)
|
||||
{
|
||||
return virDomainObjListForEach(qemu_driver->domains, iter, data);
|
||||
}
|
||||
diff --git a/src/uml/uml_driver.c b/src/uml/uml_driver.c
|
||||
index 9ca352f..eb02542 100644
|
||||
--- a/src/uml/uml_driver.c
|
||||
+++ b/src/uml/uml_driver.c
|
||||
@@ -148,8 +148,7 @@ static int umlMonitorCommand(const struct uml_driver *driver,
|
||||
static struct uml_driver *uml_driver = NULL;
|
||||
|
||||
static int
|
||||
-umlVMFilterRebuild(virConnectPtr conn ATTRIBUTE_UNUSED,
|
||||
- virDomainObjListIterator iter, void *data)
|
||||
+umlVMFilterRebuild(virDomainObjListIterator iter, void *data)
|
||||
{
|
||||
return virDomainObjListForEach(uml_driver->domains, iter, data);
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
From: Jim Fehlig <jfehlig@suse.com>
|
||||
Date: Fri, 3 Apr 2020 15:51:48 -0600
|
||||
Subject: [PATCH] libxl: fix crash when initializing driver
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
Commit 54a401af478 split out DriverConfigInit from DriverConfigNew, but
|
||||
then called it a bit late from libxlStateInitialize. The cfg is used in
|
||||
libxlDriverConfigLoadFile and when uninitialized results in a crash.
|
||||
Calling DriverConfigInit immediately after DriverConfigNew fixes the
|
||||
crash.
|
||||
|
||||
Signed-off-by: Jim Fehlig <jfehlig@suse.com>
|
||||
Reviewed-by: Erik Skultety <eskultet@redhat.com>
|
||||
Reviewed-by: Ján Tomko <jtomko@redhat.com>
|
||||
(cherry picked from commit 88011ed280c4f946a7b8e7ffcea2335eb075de60)
|
||||
---
|
||||
src/libxl/libxl_driver.c | 6 +++---
|
||||
1 file changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/src/libxl/libxl_driver.c b/src/libxl/libxl_driver.c
|
||||
index f2387e2a20..c4fb791fa0 100644
|
||||
--- a/src/libxl/libxl_driver.c
|
||||
+++ b/src/libxl/libxl_driver.c
|
||||
@@ -703,14 +703,14 @@ libxlStateInitialize(bool privileged,
|
||||
if (!(cfg = libxlDriverConfigNew()))
|
||||
goto error;
|
||||
|
||||
+ if (libxlDriverConfigInit(cfg) < 0)
|
||||
+ goto error;
|
||||
+
|
||||
driverConf = g_strdup_printf("%s/libxl.conf", cfg->configBaseDir);
|
||||
|
||||
if (libxlDriverConfigLoadFile(cfg, driverConf) < 0)
|
||||
goto error;
|
||||
|
||||
- if (libxlDriverConfigInit(cfg) < 0)
|
||||
- goto error;
|
||||
-
|
||||
/* Register the callbacks providing access to libvirt's event loop */
|
||||
libxl_osevent_register_hooks(cfg->ctx, &libxl_osevent_callbacks, cfg->ctx);
|
||||
|
||||
@@ -1,31 +0,0 @@
|
||||
From 009332c5530a3f3419578b62b44a98ff8de31ca2 Mon Sep 17 00:00:00 2001
|
||||
From: Cole Robinson <crobinso@redhat.com>
|
||||
Date: Tue, 1 Oct 2013 07:55:19 -0400
|
||||
Subject: [PATCH] qemu: cgroup: Fix crash if starting nographics guest
|
||||
|
||||
We can dereference graphics[0] even if guest has no graphics device
|
||||
configured. I screwed this up in a216e6487255d3b65d97c7ec1fa5da63dbced902
|
||||
|
||||
https://bugzilla.redhat.com/show_bug.cgi?id=1014088
|
||||
(cherry picked from commit a924d9d083c215df6044387057c501d9aa338b96)
|
||||
---
|
||||
src/qemu/qemu_cgroup.c | 5 +++--
|
||||
1 file changed, 3 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/src/qemu/qemu_cgroup.c b/src/qemu/qemu_cgroup.c
|
||||
index f95c7f2..ace7e35 100644
|
||||
--- a/src/qemu/qemu_cgroup.c
|
||||
+++ b/src/qemu/qemu_cgroup.c
|
||||
@@ -490,9 +490,10 @@ qemuSetupDevicesCgroup(virQEMUDriverPtr driver,
|
||||
|
||||
if (vm->def->nsounds &&
|
||||
((!vm->def->ngraphics && cfg->nogfxAllowHostAudio) ||
|
||||
- ((vm->def->graphics[0]->type == VIR_DOMAIN_GRAPHICS_TYPE_VNC &&
|
||||
+ (vm->def->graphics &&
|
||||
+ ((vm->def->graphics[0]->type == VIR_DOMAIN_GRAPHICS_TYPE_VNC &&
|
||||
cfg->vncAllowHostAudio) ||
|
||||
- (vm->def->graphics[0]->type == VIR_DOMAIN_GRAPHICS_TYPE_SDL)))) {
|
||||
+ (vm->def->graphics[0]->type == VIR_DOMAIN_GRAPHICS_TYPE_SDL))))) {
|
||||
rv = virCgroupAllowDeviceMajor(priv->cgroup, 'c', DEVICE_SND_MAJOR,
|
||||
VIR_CGROUP_DEVICE_RW);
|
||||
virDomainAuditCgroupMajor(vm, priv->cgroup, "allow", DEVICE_SND_MAJOR,
|
||||
@@ -1,21 +0,0 @@
|
||||
# Makefile for source rpm: libvirt
|
||||
# $Id$
|
||||
NAME := libvirt
|
||||
SPECFILE = $(firstword $(wildcard *.spec))
|
||||
|
||||
define find-makefile-common
|
||||
for d in common ../common ../../common ; do if [ -f $$d/Makefile.common ] ; then if [ -f $$d/CVS/Root -a -w $$d/Makefile.common ] ; then cd $$d ; cvs -Q update ; fi ; echo "$$d/Makefile.common" ; break ; fi ; done
|
||||
endef
|
||||
|
||||
MAKEFILE_COMMON := $(shell $(find-makefile-common))
|
||||
|
||||
ifeq ($(MAKEFILE_COMMON),)
|
||||
# attempt a checkout
|
||||
define checkout-makefile-common
|
||||
test -f CVS/Root && { cvs -Q -d $$(cat CVS/Root) checkout common && echo "common/Makefile.common" ; } || { echo "ERROR: I can't figure out how to checkout the 'common' module." ; exit -1 ; } >&2
|
||||
endef
|
||||
|
||||
MAKEFILE_COMMON := $(shell $(checkout-makefile-common))
|
||||
endif
|
||||
|
||||
include $(MAKEFILE_COMMON)
|
||||
+1282
-2255
File diff suppressed because it is too large
Load Diff
@@ -1,2 +1 @@
|
||||
1835bbfa492099bce12e2934870e5611 libvirt-1.1.2.tar.gz
|
||||
b0dfe373ebe0c588b42a28c14d36a3e6 libvirt-1.1.3.tar.gz
|
||||
SHA512 (libvirt-6.1.0.tar.xz) = 17a2641f300a4a05149261bae74ac856e9a2511a259146595d2e2412c4a0601d88369b0544ba86edc80e433a47cf828317d8de38c6ec86a1b3efaca75294a606
|
||||
|
||||
Reference in New Issue
Block a user