From: Marek Marczykowski-Górecki Date: Thu, 13 Jun 2013 01:54:09 +0000 (+0200) Subject: libxl: fix deadlock in libxlReconnectDomain X-Git-Tag: CVE-2013-2230~62 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=1d76326536692baa0f7a0ae2f0554be4e95484b6;p=thirdparty%2Flibvirt.git libxl: fix deadlock in libxlReconnectDomain Use virDomainObjListRemoveLocked instead of virDomainObjListRemove, as driver->domains is already taken by virDomainObjListForEach. Above deadlock can be triggered when libvirtd is started after some domain have been started by hand (in which case driver will not find libvirt-xml domain config). Signed-off-by: Marek Marczykowski-Górecki --- diff --git a/src/libxl/libxl_driver.c b/src/libxl/libxl_driver.c index 2428623b52..1bae3d65a3 100644 --- a/src/libxl/libxl_driver.c +++ b/src/libxl/libxl_driver.c @@ -1117,7 +1117,7 @@ libxlReconnectDomain(virDomainObjPtr vm, out: libxlVmCleanup(driver, vm, VIR_DOMAIN_SHUTOFF_UNKNOWN); if (!vm->persistent) - virDomainObjListRemove(driver->domains, vm); + virDomainObjListRemoveLocked(driver->domains, vm); else virObjectUnlock(vm);