nwfilter: remove virt driver callback layer for rebuilding filters

Now that the nwfilter driver keeps a list of bindings that it has
created, there is no need for the complex virt driver callbacks. It is
possible to simply iterate of the list of recorded filter bindings.

This means that rebuilding filters no longer has to acquire any locks on
the virDomainObj objects, as they're never touched.

Reviewed-by: John Ferlan <jferlan@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
Daniel P. Berrangé 2018-04-27 13:25:10 +01:00
parent 57f5621f46
commit 3df907bfff
10 changed files with 143 additions and 328 deletions

View File

@ -2819,121 +2819,6 @@ virNWFilterSaveConfig(const char *configDir,
} }
int nCallbackDriver;
#define MAX_CALLBACK_DRIVER 10
static virNWFilterCallbackDriverPtr callbackDrvArray[MAX_CALLBACK_DRIVER];
void
virNWFilterRegisterCallbackDriver(virNWFilterCallbackDriverPtr cbd)
{
if (nCallbackDriver < MAX_CALLBACK_DRIVER)
callbackDrvArray[nCallbackDriver++] = cbd;
}
void
virNWFilterUnRegisterCallbackDriver(virNWFilterCallbackDriverPtr cbd)
{
size_t i = 0;
while (i < nCallbackDriver && callbackDrvArray[i] != cbd)
i++;
if (i < nCallbackDriver) {
memmove(&callbackDrvArray[i], &callbackDrvArray[i+1],
(nCallbackDriver - i - 1) * sizeof(callbackDrvArray[i]));
callbackDrvArray[i] = 0;
nCallbackDriver--;
}
}
void
virNWFilterCallbackDriversLock(void)
{
size_t i;
for (i = 0; i < nCallbackDriver; i++)
callbackDrvArray[i]->vmDriverLock();
}
void
virNWFilterCallbackDriversUnlock(void)
{
size_t i;
for (i = 0; i < nCallbackDriver; i++)
callbackDrvArray[i]->vmDriverUnlock();
}
static virDomainObjListIterator virNWFilterDomainFWUpdateCB;
static void *virNWFilterDomainFWUpdateOpaque;
/**
* virNWFilterInstFiltersOnAllVMs:
* Apply all filters on all running VMs. Don't terminate in case of an
* error. This should be called upon reloading of the driver.
*/
int
virNWFilterInstFiltersOnAllVMs(void)
{
size_t i;
struct domUpdateCBStruct cb = {
.opaque = virNWFilterDomainFWUpdateOpaque,
.step = STEP_APPLY_CURRENT,
.skipInterfaces = NULL, /* not needed */
};
for (i = 0; i < nCallbackDriver; i++)
callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
&cb);
return 0;
}
int
virNWFilterTriggerVMFilterRebuild(void)
{
size_t i;
int ret = 0;
struct domUpdateCBStruct cb = {
.opaque = virNWFilterDomainFWUpdateOpaque,
.step = STEP_APPLY_NEW,
.skipInterfaces = virHashCreate(0, NULL),
};
if (!cb.skipInterfaces)
return -1;
for (i = 0; i < nCallbackDriver; i++) {
if (callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
&cb) < 0)
ret = -1;
}
if (ret < 0) {
cb.step = STEP_TEAR_NEW; /* rollback */
for (i = 0; i < nCallbackDriver; i++)
callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
&cb);
} else {
cb.step = STEP_TEAR_OLD; /* switch over */
for (i = 0; i < nCallbackDriver; i++)
callbackDrvArray[i]->vmFilterRebuild(virNWFilterDomainFWUpdateCB,
&cb);
}
virHashFree(cb.skipInterfaces);
return ret;
}
int int
virNWFilterDeleteDef(const char *configDir, virNWFilterDeleteDef(const char *configDir,
virNWFilterDefPtr def) virNWFilterDefPtr def)
@ -3204,16 +3089,18 @@ virNWFilterDefFormat(const virNWFilterDef *def)
return NULL; return NULL;
} }
static virNWFilterTriggerRebuildCallback rebuildCallback;
static void *rebuildOpaque;
int int
virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB, virNWFilterConfLayerInit(virNWFilterTriggerRebuildCallback cb,
void *opaque) void *opaque)
{ {
if (initialized) if (initialized)
return -1; return -1;
virNWFilterDomainFWUpdateCB = domUpdateCB; rebuildCallback = cb;
virNWFilterDomainFWUpdateOpaque = opaque; rebuildOpaque = opaque;
initialized = true; initialized = true;
@ -3233,8 +3120,17 @@ virNWFilterConfLayerShutdown(void)
virRWLockDestroy(&updateLock); virRWLockDestroy(&updateLock);
initialized = false; initialized = false;
virNWFilterDomainFWUpdateOpaque = NULL; rebuildCallback = NULL;
virNWFilterDomainFWUpdateCB = NULL; rebuildOpaque = NULL;
}
int
virNWFilterTriggerRebuild(void)
{
if (rebuildCallback)
return rebuildCallback(rebuildOpaque);
return 0;
} }

View File

@ -546,20 +546,6 @@ struct _virNWFilterDef {
}; };
typedef enum {
STEP_APPLY_NEW,
STEP_TEAR_NEW,
STEP_TEAR_OLD,
STEP_APPLY_CURRENT,
} UpdateStep;
struct domUpdateCBStruct {
void *opaque;
UpdateStep step;
virHashTablePtr skipInterfaces;
};
void void
virNWFilterRuleDefFree(virNWFilterRuleDefPtr def); virNWFilterRuleDefFree(virNWFilterRuleDefPtr def);
@ -567,7 +553,7 @@ void
virNWFilterDefFree(virNWFilterDefPtr def); virNWFilterDefFree(virNWFilterDefPtr def);
int int
virNWFilterTriggerVMFilterRebuild(void); virNWFilterTriggerRebuild(void);
int int
virNWFilterDeleteDef(const char *configDir, virNWFilterDeleteDef(const char *configDir,
@ -599,44 +585,15 @@ virNWFilterReadLockFilterUpdates(void);
void void
virNWFilterUnlockFilterUpdates(void); virNWFilterUnlockFilterUpdates(void);
typedef int (*virNWFilterTriggerRebuildCallback)(void *opaque);
int int
virNWFilterConfLayerInit(virDomainObjListIterator domUpdateCB, virNWFilterConfLayerInit(virNWFilterTriggerRebuildCallback cb,
void *opaque); void *opaque);
void void
virNWFilterConfLayerShutdown(void); virNWFilterConfLayerShutdown(void);
int
virNWFilterInstFiltersOnAllVMs(void);
typedef int
(*virNWFilterRebuild)(virDomainObjListIterator domUpdateCB,
void *data);
typedef void
(*virNWFilterVoidCall)(void);
typedef struct _virNWFilterCallbackDriver virNWFilterCallbackDriver;
typedef virNWFilterCallbackDriver *virNWFilterCallbackDriverPtr;
struct _virNWFilterCallbackDriver {
const char *name;
virNWFilterRebuild vmFilterRebuild;
virNWFilterVoidCall vmDriverLock;
virNWFilterVoidCall vmDriverUnlock;
};
void
virNWFilterRegisterCallbackDriver(virNWFilterCallbackDriverPtr);
void
virNWFilterUnRegisterCallbackDriver(virNWFilterCallbackDriverPtr);
void
virNWFilterCallbackDriversLock(void);
void
virNWFilterCallbackDriversUnlock(void);
char * char *
virNWFilterPrintTCPFlags(uint8_t flags); virNWFilterPrintTCPFlags(uint8_t flags);

View File

@ -276,7 +276,7 @@ virNWFilterObjTestUnassignDef(virNWFilterObjPtr obj)
obj->wantRemoved = true; obj->wantRemoved = true;
/* trigger the update on VMs referencing the filter */ /* trigger the update on VMs referencing the filter */
if (virNWFilterTriggerVMFilterRebuild() < 0) if (virNWFilterTriggerRebuild() < 0)
rc = -1; rc = -1;
obj->wantRemoved = false; obj->wantRemoved = false;
@ -358,7 +358,7 @@ virNWFilterObjListAssignDef(virNWFilterObjListPtr nwfilters,
obj->newDef = def; obj->newDef = def;
/* trigger the update on VMs referencing the filter */ /* trigger the update on VMs referencing the filter */
if (virNWFilterTriggerVMFilterRebuild() < 0) { if (virNWFilterTriggerRebuild() < 0) {
obj->newDef = NULL; obj->newDef = NULL;
virNWFilterObjUnlock(obj); virNWFilterObjUnlock(obj);
return NULL; return NULL;

View File

@ -787,8 +787,6 @@ virDomainNumatuneSpecifiedMaxNode;
# conf/nwfilter_conf.h # conf/nwfilter_conf.h
virNWFilterCallbackDriversLock;
virNWFilterCallbackDriversUnlock;
virNWFilterChainSuffixTypeToString; virNWFilterChainSuffixTypeToString;
virNWFilterConfLayerInit; virNWFilterConfLayerInit;
virNWFilterConfLayerShutdown; virNWFilterConfLayerShutdown;
@ -797,12 +795,10 @@ virNWFilterDefFree;
virNWFilterDefParseFile; virNWFilterDefParseFile;
virNWFilterDefParseString; virNWFilterDefParseString;
virNWFilterDeleteDef; virNWFilterDeleteDef;
virNWFilterInstFiltersOnAllVMs;
virNWFilterJumpTargetTypeToString; virNWFilterJumpTargetTypeToString;
virNWFilterPrintStateMatchFlags; virNWFilterPrintStateMatchFlags;
virNWFilterPrintTCPFlags; virNWFilterPrintTCPFlags;
virNWFilterReadLockFilterUpdates; virNWFilterReadLockFilterUpdates;
virNWFilterRegisterCallbackDriver;
virNWFilterRuleActionTypeToString; virNWFilterRuleActionTypeToString;
virNWFilterRuleDirectionTypeToString; virNWFilterRuleDirectionTypeToString;
virNWFilterRuleIsProtocolEthernet; virNWFilterRuleIsProtocolEthernet;
@ -810,9 +806,8 @@ virNWFilterRuleIsProtocolIPv4;
virNWFilterRuleIsProtocolIPv6; virNWFilterRuleIsProtocolIPv6;
virNWFilterRuleProtocolTypeToString; virNWFilterRuleProtocolTypeToString;
virNWFilterSaveConfig; virNWFilterSaveConfig;
virNWFilterTriggerVMFilterRebuild; virNWFilterTriggerRebuild;
virNWFilterUnlockFilterUpdates; virNWFilterUnlockFilterUpdates;
virNWFilterUnRegisterCallbackDriver;
virNWFilterWriteLockFilterUpdates; virNWFilterWriteLockFilterUpdates;

View File

@ -66,7 +66,6 @@
#include "virfdstream.h" #include "virfdstream.h"
#include "domain_audit.h" #include "domain_audit.h"
#include "domain_nwfilter.h" #include "domain_nwfilter.h"
#include "nwfilter_conf.h"
#include "virinitctl.h" #include "virinitctl.h"
#include "virnetdev.h" #include "virnetdev.h"
#include "virnetdevtap.h" #include "virnetdevtap.h"
@ -95,31 +94,6 @@ static int lxcStateInitialize(bool privileged,
static int lxcStateCleanup(void); static int lxcStateCleanup(void);
virLXCDriverPtr lxc_driver = NULL; virLXCDriverPtr lxc_driver = NULL;
/* callbacks for nwfilter */
static int
lxcVMFilterRebuild(virDomainObjListIterator iter, void *data)
{
return virDomainObjListForEach(lxc_driver->domains, iter, data);
}
static void
lxcVMDriverLock(void)
{
lxcDriverLock(lxc_driver);
}
static void
lxcVMDriverUnlock(void)
{
lxcDriverUnlock(lxc_driver);
}
static virNWFilterCallbackDriver lxcCallbackDriver = {
.name = "LXC",
.vmFilterRebuild = lxcVMFilterRebuild,
.vmDriverLock = lxcVMDriverLock,
.vmDriverUnlock = lxcVMDriverUnlock,
};
/** /**
* lxcDomObjFromDomain: * lxcDomObjFromDomain:
@ -1672,7 +1646,6 @@ static int lxcStateInitialize(bool privileged,
NULL, NULL) < 0) NULL, NULL) < 0)
goto cleanup; goto cleanup;
virNWFilterRegisterCallbackDriver(&lxcCallbackDriver);
virObjectUnref(caps); virObjectUnref(caps);
return 0; return 0;
@ -1744,7 +1717,6 @@ static int lxcStateCleanup(void)
if (lxc_driver == NULL) if (lxc_driver == NULL)
return -1; return -1;
virNWFilterUnRegisterCallbackDriver(&lxcCallbackDriver);
virObjectUnref(lxc_driver->domains); virObjectUnref(lxc_driver->domains);
virObjectUnref(lxc_driver->domainEventState); virObjectUnref(lxc_driver->domainEventState);

View File

@ -163,6 +163,15 @@ nwfilterDriverInstallDBusMatches(DBusConnection *sysbus ATTRIBUTE_UNUSED)
#endif /* HAVE_FIREWALLD */ #endif /* HAVE_FIREWALLD */
static int
virNWFilterTriggerRebuildImpl(void *opaque)
{
virNWFilterDriverStatePtr nwdriver = opaque;
return virNWFilterBuildAll(nwdriver, true);
}
/** /**
* nwfilterStateInitialize: * nwfilterStateInitialize:
* *
@ -207,7 +216,7 @@ nwfilterStateInitialize(bool privileged,
if (virNWFilterTechDriversInit(privileged) < 0) if (virNWFilterTechDriversInit(privileged) < 0)
goto err_dhcpsnoop_shutdown; goto err_dhcpsnoop_shutdown;
if (virNWFilterConfLayerInit(virNWFilterDomainFWUpdateCB, if (virNWFilterConfLayerInit(virNWFilterTriggerRebuildImpl,
driver) < 0) driver) < 0)
goto err_techdrivers_shutdown; goto err_techdrivers_shutdown;
@ -302,15 +311,14 @@ nwfilterStateReload(void)
nwfilterDriverLock(); nwfilterDriverLock();
virNWFilterWriteLockFilterUpdates(); virNWFilterWriteLockFilterUpdates();
virNWFilterCallbackDriversLock();
virNWFilterObjListLoadAllConfigs(driver->nwfilters, driver->configDir); virNWFilterObjListLoadAllConfigs(driver->nwfilters, driver->configDir);
virNWFilterCallbackDriversUnlock();
virNWFilterUnlockFilterUpdates(); virNWFilterUnlockFilterUpdates();
nwfilterDriverUnlock();
virNWFilterInstFiltersOnAllVMs(); virNWFilterBuildAll(driver, false);
nwfilterDriverUnlock();
return 0; return 0;
} }
@ -547,7 +555,6 @@ nwfilterDefineXML(virConnectPtr conn,
nwfilterDriverLock(); nwfilterDriverLock();
virNWFilterWriteLockFilterUpdates(); virNWFilterWriteLockFilterUpdates();
virNWFilterCallbackDriversLock();
if (!(def = virNWFilterDefParseString(xml))) if (!(def = virNWFilterDefParseString(xml)))
goto cleanup; goto cleanup;
@ -572,7 +579,6 @@ nwfilterDefineXML(virConnectPtr conn,
if (obj) if (obj)
virNWFilterObjUnlock(obj); virNWFilterObjUnlock(obj);
virNWFilterCallbackDriversUnlock();
virNWFilterUnlockFilterUpdates(); virNWFilterUnlockFilterUpdates();
nwfilterDriverUnlock(); nwfilterDriverUnlock();
return nwfilter; return nwfilter;
@ -588,7 +594,6 @@ nwfilterUndefine(virNWFilterPtr nwfilter)
nwfilterDriverLock(); nwfilterDriverLock();
virNWFilterWriteLockFilterUpdates(); virNWFilterWriteLockFilterUpdates();
virNWFilterCallbackDriversLock();
if (!(obj = nwfilterObjFromNWFilter(nwfilter->uuid))) if (!(obj = nwfilterObjFromNWFilter(nwfilter->uuid)))
goto cleanup; goto cleanup;
@ -615,7 +620,6 @@ nwfilterUndefine(virNWFilterPtr nwfilter)
if (obj) if (obj)
virNWFilterObjUnlock(obj); virNWFilterObjUnlock(obj);
virNWFilterCallbackDriversUnlock();
virNWFilterUnlockFilterUpdates(); virNWFilterUnlockFilterUpdates();
nwfilterDriverUnlock(); nwfilterDriverUnlock();
return ret; return ret;

View File

@ -153,9 +153,9 @@ virNWFilterVarHashmapAddStdValues(virHashTablePtr table,
if (!val) if (!val)
return -1; return -1;
if (virHashAddEntry(table, if (virHashUpdateEntry(table,
NWFILTER_STD_VAR_MAC, NWFILTER_STD_VAR_MAC,
val) < 0) { val) < 0) {
virNWFilterVarValueFree(val); virNWFilterVarValueFree(val);
virReportError(VIR_ERR_INTERNAL_ERROR, virReportError(VIR_ERR_INTERNAL_ERROR,
"%s", _("Could not add variable 'MAC' to hashmap")); "%s", _("Could not add variable 'MAC' to hashmap"));
@ -168,9 +168,9 @@ virNWFilterVarHashmapAddStdValues(virHashTablePtr table,
if (!val) if (!val)
return -1; return -1;
if (virHashAddEntry(table, if (virHashUpdateEntry(table,
NWFILTER_STD_VAR_IP, NWFILTER_STD_VAR_IP,
val) < 0) { val) < 0) {
virNWFilterVarValueFree(val); virNWFilterVarValueFree(val);
virReportError(VIR_ERR_INTERNAL_ERROR, virReportError(VIR_ERR_INTERNAL_ERROR,
"%s", _("Could not add variable 'IP' to hashmap")); "%s", _("Could not add variable 'IP' to hashmap"));
@ -973,68 +973,113 @@ virNWFilterTeardownFilter(virNWFilterBindingDefPtr binding)
return ret; return ret;
} }
enum {
STEP_APPLY_NEW,
STEP_ROLLBACK,
STEP_SWITCH,
STEP_APPLY_CURRENT,
};
int static int
virNWFilterDomainFWUpdateCB(virDomainObjPtr obj, virNWFilterBuildOne(virNWFilterDriverStatePtr driver,
void *data) virNWFilterBindingDefPtr binding,
virHashTablePtr skipInterfaces,
int step)
{ {
virDomainDefPtr vm = obj->def;
struct domUpdateCBStruct *cb = data;
size_t i;
bool skipIface; bool skipIface;
int ret = 0; int ret = 0;
VIR_DEBUG("Building filter for portdev=%s step=%d", binding->portdevname, step);
virObjectLock(obj); switch (step) {
case STEP_APPLY_NEW:
if (virDomainObjIsActive(obj)) { ret = virNWFilterUpdateInstantiateFilter(driver,
for (i = 0; i < vm->nnets; i++) { binding,
virDomainNetDefPtr net = vm->nets[i]; &skipIface);
virNWFilterBindingDefPtr binding; if (ret == 0 && skipIface) {
/* filter tree unchanged -- no update needed */
if ((net->filter) && (net->ifname) && ret = virHashAddEntry(skipInterfaces,
(binding = virNWFilterBindingDefForNet( binding->portdevname,
vm->name, vm->uuid, net))) { (void *)~0);
switch (cb->step) {
case STEP_APPLY_NEW:
ret = virNWFilterUpdateInstantiateFilter(cb->opaque,
binding,
&skipIface);
if (ret == 0 && skipIface) {
/* filter tree unchanged -- no update needed */
ret = virHashAddEntry(cb->skipInterfaces,
net->ifname,
(void *)~0);
}
break;
case STEP_TEAR_NEW:
if (!virHashLookup(cb->skipInterfaces, net->ifname))
ret = virNWFilterRollbackUpdateFilter(binding);
break;
case STEP_TEAR_OLD:
if (!virHashLookup(cb->skipInterfaces, net->ifname))
ret = virNWFilterTearOldFilter(binding);
break;
case STEP_APPLY_CURRENT:
ret = virNWFilterInstantiateFilter(cb->opaque,
binding);
if (ret)
virReportError(VIR_ERR_INTERNAL_ERROR,
_("Failure while applying current filter on "
"VM %s"), vm->name);
break;
}
virNWFilterBindingDefFree(binding);
if (ret)
break;
}
} }
break;
case STEP_ROLLBACK:
if (!virHashLookup(skipInterfaces, binding->portdevname))
ret = virNWFilterRollbackUpdateFilter(binding);
break;
case STEP_SWITCH:
if (!virHashLookup(skipInterfaces, binding->portdevname))
ret = virNWFilterTearOldFilter(binding);
break;
case STEP_APPLY_CURRENT:
ret = virNWFilterInstantiateFilter(driver,
binding);
break;
} }
virObjectUnlock(obj); return ret;
}
struct virNWFilterBuildData {
virNWFilterDriverStatePtr driver;
virHashTablePtr skipInterfaces;
int step;
};
static int
virNWFilterBuildIter(virNWFilterBindingObjPtr binding, void *opaque)
{
struct virNWFilterBuildData *data = opaque;
virNWFilterBindingDefPtr def = virNWFilterBindingObjGetDef(binding);
return virNWFilterBuildOne(data->driver, def,
data->skipInterfaces, data->step);
}
int
virNWFilterBuildAll(virNWFilterDriverStatePtr driver,
bool newFilters)
{
struct virNWFilterBuildData data = {
.driver = driver,
};
int ret = 0;
VIR_DEBUG("Build all filters newFilters=%d", newFilters);
if (newFilters) {
if (!(data.skipInterfaces = virHashCreate(0, NULL)))
return -1;
data.step = STEP_APPLY_NEW;
if (virNWFilterBindingObjListForEach(driver->bindings,
virNWFilterBuildIter,
&data) < 0)
ret = -1;
if (ret == -1) {
data.step = STEP_ROLLBACK;
virNWFilterBindingObjListForEach(driver->bindings,
virNWFilterBuildIter,
&data);
} else {
data.step = STEP_SWITCH;
virNWFilterBindingObjListForEach(driver->bindings,
virNWFilterBuildIter,
&data);
}
virHashFree(data.skipInterfaces);
} else {
data.step = STEP_APPLY_CURRENT;
if (virNWFilterBindingObjListForEach(driver->bindings,
virNWFilterBuildIter,
&data) < 0)
ret = -1;
}
return ret; return ret;
} }

View File

@ -54,8 +54,8 @@ int virNWFilterTeardownFilter(virNWFilterBindingDefPtr binding);
virHashTablePtr virNWFilterCreateVarHashmap(const char *macaddr, virHashTablePtr virNWFilterCreateVarHashmap(const char *macaddr,
const virNWFilterVarValue *value); const virNWFilterVarValue *value);
int virNWFilterDomainFWUpdateCB(virDomainObjPtr vm, int virNWFilterBuildAll(virNWFilterDriverStatePtr driver,
void *data); bool newFilters);
virNWFilterBindingDefPtr virNWFilterBindingDefForNet(const char *vmname, virNWFilterBindingDefPtr virNWFilterBindingDefForNet(const char *vmname,
const unsigned char *vmuuid, const unsigned char *vmuuid,

View File

@ -84,7 +84,6 @@
#include "cpu/cpu.h" #include "cpu/cpu.h"
#include "virsysinfo.h" #include "virsysinfo.h"
#include "domain_nwfilter.h" #include "domain_nwfilter.h"
#include "nwfilter_conf.h"
#include "virhook.h" #include "virhook.h"
#include "virstoragefile.h" #include "virstoragefile.h"
#include "virfile.h" #include "virfile.h"
@ -164,28 +163,6 @@ static int qemuARPGetInterfaces(virDomainObjPtr vm,
static virQEMUDriverPtr qemu_driver; static virQEMUDriverPtr qemu_driver;
static void
qemuVMDriverLock(void)
{}
static void
qemuVMDriverUnlock(void)
{}
static int
qemuVMFilterRebuild(virDomainObjListIterator iter, void *data)
{
return virDomainObjListForEach(qemu_driver->domains, iter, data);
}
static virNWFilterCallbackDriver qemuCallbackDriver = {
.name = QEMU_DRIVER_NAME,
.vmFilterRebuild = qemuVMFilterRebuild,
.vmDriverLock = qemuVMDriverLock,
.vmDriverUnlock = qemuVMDriverUnlock,
};
/** /**
* qemuDomObjFromDomain: * qemuDomObjFromDomain:
* @domain: Domain pointer that has to be looked up * @domain: Domain pointer that has to be looked up
@ -941,7 +918,6 @@ qemuStateInitialize(bool privileged,
qemuProcessReconnectAll(qemu_driver); qemuProcessReconnectAll(qemu_driver);
virNWFilterRegisterCallbackDriver(&qemuCallbackDriver);
return 0; return 0;
error: error:
@ -1081,7 +1057,6 @@ qemuStateCleanup(void)
if (!qemu_driver) if (!qemu_driver)
return -1; return -1;
virNWFilterUnRegisterCallbackDriver(&qemuCallbackDriver);
virThreadPoolFree(qemu_driver->workerPool); virThreadPoolFree(qemu_driver->workerPool);
virObjectUnref(qemu_driver->config); virObjectUnref(qemu_driver->config);
virObjectUnref(qemu_driver->hostdevMgr); virObjectUnref(qemu_driver->hostdevMgr);

View File

@ -55,7 +55,6 @@
#include "datatypes.h" #include "datatypes.h"
#include "virlog.h" #include "virlog.h"
#include "domain_nwfilter.h" #include "domain_nwfilter.h"
#include "nwfilter_conf.h"
#include "virfile.h" #include "virfile.h"
#include "virfdstream.h" #include "virfdstream.h"
#include "configmake.h" #include "configmake.h"
@ -143,25 +142,6 @@ static int umlMonitorCommand(const struct uml_driver *driver,
static struct uml_driver *uml_driver; static struct uml_driver *uml_driver;
static int
umlVMFilterRebuild(virDomainObjListIterator iter, void *data)
{
return virDomainObjListForEach(uml_driver->domains, iter, data);
}
static void
umlVMDriverLock(void)
{
umlDriverLock(uml_driver);
}
static void
umlVMDriverUnlock(void)
{
umlDriverUnlock(uml_driver);
}
static virDomainObjPtr static virDomainObjPtr
umlDomObjFromDomainLocked(struct uml_driver *driver, umlDomObjFromDomainLocked(struct uml_driver *driver,
const unsigned char *uuid) const unsigned char *uuid)
@ -194,13 +174,6 @@ umlDomObjFromDomain(struct uml_driver *driver,
} }
static virNWFilterCallbackDriver umlCallbackDriver = {
.name = "UML",
.vmFilterRebuild = umlVMFilterRebuild,
.vmDriverLock = umlVMDriverLock,
.vmDriverUnlock = umlVMDriverUnlock,
};
struct umlAutostartData { struct umlAutostartData {
struct uml_driver *driver; struct uml_driver *driver;
virConnectPtr conn; virConnectPtr conn;
@ -604,7 +577,6 @@ umlStateInitialize(bool privileged,
VIR_FREE(userdir); VIR_FREE(userdir);
virNWFilterRegisterCallbackDriver(&umlCallbackDriver);
return 0; return 0;
out_of_memory: out_of_memory:
@ -697,7 +669,6 @@ umlStateCleanup(void)
return -1; return -1;
umlDriverLock(uml_driver); umlDriverLock(uml_driver);
virNWFilterRegisterCallbackDriver(&umlCallbackDriver);
if (uml_driver->inotifyWatch != -1) if (uml_driver->inotifyWatch != -1)
virEventRemoveHandle(uml_driver->inotifyWatch); virEventRemoveHandle(uml_driver->inotifyWatch);
VIR_FORCE_CLOSE(uml_driver->inotifyFD); VIR_FORCE_CLOSE(uml_driver->inotifyFD);