mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-09-13 11:15:08 +00:00
Add locking for thread safety to LXC driver
This commit is contained in:
parent
5305c55849
commit
965c1bfee4
@ -1,3 +1,8 @@
|
|||||||
|
Thu Dec 4 21:11:41 GMT 2008 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
|
* src/lxc_conf.h: Add driver lock variable
|
||||||
|
* src/lxc_driver.c: Add locking for thread safety
|
||||||
|
|
||||||
Thu Dec 4 21:10:41 GMT 2008 Daniel P. Berrange <berrange@redhat.com>
|
Thu Dec 4 21:10:41 GMT 2008 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
* src/lxc_driver.c: Merge all return paths from driver APIs
|
* src/lxc_driver.c: Merge all return paths from driver APIs
|
||||||
|
@ -36,6 +36,8 @@
|
|||||||
|
|
||||||
typedef struct __lxc_driver lxc_driver_t;
|
typedef struct __lxc_driver lxc_driver_t;
|
||||||
struct __lxc_driver {
|
struct __lxc_driver {
|
||||||
|
PTHREAD_MUTEX_T(lock);
|
||||||
|
|
||||||
virCapsPtr caps;
|
virCapsPtr caps;
|
||||||
|
|
||||||
virDomainObjList domains;
|
virDomainObjList domains;
|
||||||
|
216
src/lxc_driver.c
216
src/lxc_driver.c
@ -55,6 +55,16 @@ static lxc_driver_t *lxc_driver = NULL;
|
|||||||
|
|
||||||
/* Functions */
|
/* Functions */
|
||||||
|
|
||||||
|
static void lxcDriverLock(lxc_driver_t *driver)
|
||||||
|
{
|
||||||
|
pthread_mutex_lock(&driver->lock);
|
||||||
|
}
|
||||||
|
static void lxcDriverUnlock(lxc_driver_t *driver)
|
||||||
|
{
|
||||||
|
pthread_mutex_unlock(&driver->lock);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int lxcProbe(void)
|
static int lxcProbe(void)
|
||||||
{
|
{
|
||||||
if (getuid() != 0 ||
|
if (getuid() != 0 ||
|
||||||
@ -107,7 +117,10 @@ static virDomainPtr lxcDomainLookupByID(virConnectPtr conn,
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
virDomainPtr dom = NULL;
|
virDomainPtr dom = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByID(&driver->domains, id);
|
vm = virDomainFindByID(&driver->domains, id);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(conn, NULL, VIR_ERR_NO_DOMAIN, NULL);
|
lxcError(conn, NULL, VIR_ERR_NO_DOMAIN, NULL);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -118,6 +131,8 @@ static virDomainPtr lxcDomainLookupByID(virConnectPtr conn,
|
|||||||
dom->id = vm->def->id;
|
dom->id = vm->def->id;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +143,10 @@ static virDomainPtr lxcDomainLookupByUUID(virConnectPtr conn,
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
virDomainPtr dom = NULL;
|
virDomainPtr dom = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByUUID(&driver->domains, uuid);
|
vm = virDomainFindByUUID(&driver->domains, uuid);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(conn, NULL, VIR_ERR_NO_DOMAIN, NULL);
|
lxcError(conn, NULL, VIR_ERR_NO_DOMAIN, NULL);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -139,6 +157,8 @@ static virDomainPtr lxcDomainLookupByUUID(virConnectPtr conn,
|
|||||||
dom->id = vm->def->id;
|
dom->id = vm->def->id;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -149,7 +169,9 @@ static virDomainPtr lxcDomainLookupByName(virConnectPtr conn,
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
virDomainPtr dom = NULL;
|
virDomainPtr dom = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByName(&driver->domains, name);
|
vm = virDomainFindByName(&driver->domains, name);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(conn, NULL, VIR_ERR_NO_DOMAIN, NULL);
|
lxcError(conn, NULL, VIR_ERR_NO_DOMAIN, NULL);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -160,6 +182,8 @@ static virDomainPtr lxcDomainLookupByName(virConnectPtr conn,
|
|||||||
dom->id = vm->def->id;
|
dom->id = vm->def->id;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,9 +191,14 @@ static int lxcListDomains(virConnectPtr conn, int *ids, int nids) {
|
|||||||
lxc_driver_t *driver = conn->privateData;
|
lxc_driver_t *driver = conn->privateData;
|
||||||
int got = 0, i;
|
int got = 0, i;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->domains.count && got < nids ; i++)
|
lxcDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->domains.count && got < nids ; i++) {
|
||||||
|
virDomainObjLock(driver->domains.objs[i]);
|
||||||
if (virDomainIsActive(driver->domains.objs[i]))
|
if (virDomainIsActive(driver->domains.objs[i]))
|
||||||
ids[got++] = driver->domains.objs[i]->def->id;
|
ids[got++] = driver->domains.objs[i]->def->id;
|
||||||
|
virDomainObjUnlock(driver->domains.objs[i]);
|
||||||
|
}
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
return got;
|
return got;
|
||||||
}
|
}
|
||||||
@ -178,9 +207,14 @@ static int lxcNumDomains(virConnectPtr conn) {
|
|||||||
lxc_driver_t *driver = conn->privateData;
|
lxc_driver_t *driver = conn->privateData;
|
||||||
int n = 0, i;
|
int n = 0, i;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->domains.count ; i++)
|
lxcDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->domains.count ; i++) {
|
||||||
|
virDomainObjLock(driver->domains.objs[i]);
|
||||||
if (virDomainIsActive(driver->domains.objs[i]))
|
if (virDomainIsActive(driver->domains.objs[i]))
|
||||||
n++;
|
n++;
|
||||||
|
virDomainObjUnlock(driver->domains.objs[i]);
|
||||||
|
}
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -190,21 +224,27 @@ static int lxcListDefinedDomains(virConnectPtr conn,
|
|||||||
lxc_driver_t *driver = conn->privateData;
|
lxc_driver_t *driver = conn->privateData;
|
||||||
int got = 0, i;
|
int got = 0, i;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
for (i = 0 ; i < driver->domains.count && got < nnames ; i++) {
|
for (i = 0 ; i < driver->domains.count && got < nnames ; i++) {
|
||||||
|
virDomainObjLock(driver->domains.objs[i]);
|
||||||
if (!virDomainIsActive(driver->domains.objs[i])) {
|
if (!virDomainIsActive(driver->domains.objs[i])) {
|
||||||
if (!(names[got++] = strdup(driver->domains.objs[i]->def->name))) {
|
if (!(names[got++] = strdup(driver->domains.objs[i]->def->name))) {
|
||||||
lxcError(conn, NULL, VIR_ERR_NO_MEMORY,
|
lxcError(conn, NULL, VIR_ERR_NO_MEMORY,
|
||||||
"%s", _("failed to allocate space for VM name string"));
|
"%s", _("failed to allocate space for VM name string"));
|
||||||
|
virDomainObjUnlock(driver->domains.objs[i]);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
virDomainObjUnlock(driver->domains.objs[i]);
|
||||||
}
|
}
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
return got;
|
return got;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
for (i = 0 ; i < got ; i++)
|
for (i = 0 ; i < got ; i++)
|
||||||
VIR_FREE(names[i]);
|
VIR_FREE(names[i]);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -213,9 +253,14 @@ static int lxcNumDefinedDomains(virConnectPtr conn) {
|
|||||||
lxc_driver_t *driver = conn->privateData;
|
lxc_driver_t *driver = conn->privateData;
|
||||||
int n = 0, i;
|
int n = 0, i;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->domains.count ; i++)
|
lxcDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->domains.count ; i++) {
|
||||||
|
virDomainObjLock(driver->domains.objs[i]);
|
||||||
if (!virDomainIsActive(driver->domains.objs[i]))
|
if (!virDomainIsActive(driver->domains.objs[i]))
|
||||||
n++;
|
n++;
|
||||||
|
virDomainObjUnlock(driver->domains.objs[i]);
|
||||||
|
}
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -226,9 +271,10 @@ static virDomainPtr lxcDomainDefine(virConnectPtr conn, const char *xml)
|
|||||||
{
|
{
|
||||||
lxc_driver_t *driver = conn->privateData;
|
lxc_driver_t *driver = conn->privateData;
|
||||||
virDomainDefPtr def = NULL;
|
virDomainDefPtr def = NULL;
|
||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm = NULL;
|
||||||
virDomainPtr dom = NULL;
|
virDomainPtr dom = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
if (!(def = virDomainDefParseString(conn, driver->caps, xml)))
|
if (!(def = virDomainDefParseString(conn, driver->caps, xml)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -247,6 +293,7 @@ static virDomainPtr lxcDomainDefine(virConnectPtr conn, const char *xml)
|
|||||||
driver->configDir,
|
driver->configDir,
|
||||||
vm->newDef ? vm->newDef : vm->def) < 0) {
|
vm->newDef ? vm->newDef : vm->def) < 0) {
|
||||||
virDomainRemoveInactive(&driver->domains, vm);
|
virDomainRemoveInactive(&driver->domains, vm);
|
||||||
|
vm = NULL;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,6 +303,9 @@ static virDomainPtr lxcDomainDefine(virConnectPtr conn, const char *xml)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -265,6 +315,7 @@ static int lxcDomainUndefine(virDomainPtr dom)
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
@ -291,9 +342,13 @@ static int lxcDomainUndefine(virDomainPtr dom)
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
virDomainRemoveInactive(&driver->domains, vm);
|
virDomainRemoveInactive(&driver->domains, vm);
|
||||||
|
vm = NULL;
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,7 +359,10 @@ static int lxcDomainGetInfo(virDomainPtr dom,
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
"%s", _("no domain with matching uuid"));
|
"%s", _("no domain with matching uuid"));
|
||||||
@ -325,6 +383,8 @@ static int lxcDomainGetInfo(virDomainPtr dom,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -334,7 +394,10 @@ static char *lxcGetOSType(virDomainPtr dom)
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
"%s", _("no domain with matching uuid"));
|
"%s", _("no domain with matching uuid"));
|
||||||
@ -344,6 +407,8 @@ static char *lxcGetOSType(virDomainPtr dom)
|
|||||||
ret = strdup(vm->def->os.type);
|
ret = strdup(vm->def->os.type);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -354,7 +419,10 @@ static char *lxcDomainDumpXML(virDomainPtr dom,
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
vm = virDomainFindByUUID(&driver->domains, dom->uuid);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
"%s", _("no domain with matching uuid"));
|
"%s", _("no domain with matching uuid"));
|
||||||
@ -367,6 +435,8 @@ static char *lxcDomainDumpXML(virDomainPtr dom,
|
|||||||
flags);
|
flags);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -612,24 +682,33 @@ static void lxcMonitorEvent(int watch,
|
|||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
for (i = 0 ; i < driver->domains.count ; i++) {
|
for (i = 0 ; i < driver->domains.count ; i++) {
|
||||||
if (driver->domains.objs[i]->monitorWatch == watch) {
|
virDomainObjPtr tmpvm = driver->domains.objs[i];
|
||||||
vm = driver->domains.objs[i];
|
virDomainObjLock(tmpvm);
|
||||||
|
if (tmpvm->monitorWatch == watch) {
|
||||||
|
vm = tmpvm;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
virDomainObjUnlock(tmpvm);
|
||||||
}
|
}
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
virEventRemoveHandle(watch);
|
virEventRemoveHandle(watch);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vm->monitor != fd) {
|
if (vm->monitor != fd) {
|
||||||
virEventRemoveHandle(watch);
|
virEventRemoveHandle(watch);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lxcVmTerminate(NULL, driver, vm, SIGINT) < 0)
|
if (lxcVmTerminate(NULL, driver, vm, SIGINT) < 0)
|
||||||
virEventRemoveHandle(watch);
|
virEventRemoveHandle(watch);
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -880,6 +959,7 @@ static int lxcDomainStart(virDomainPtr dom)
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByName(&driver->domains, dom->name);
|
vm = virDomainFindByName(&driver->domains, dom->name);
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
@ -896,6 +976,9 @@ static int lxcDomainStart(virDomainPtr dom)
|
|||||||
ret = lxcVmStart(dom->conn, driver, vm);
|
ret = lxcVmStart(dom->conn, driver, vm);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -914,10 +997,11 @@ lxcDomainCreateAndStart(virConnectPtr conn,
|
|||||||
const char *xml,
|
const char *xml,
|
||||||
unsigned int flags ATTRIBUTE_UNUSED) {
|
unsigned int flags ATTRIBUTE_UNUSED) {
|
||||||
lxc_driver_t *driver = conn->privateData;
|
lxc_driver_t *driver = conn->privateData;
|
||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm = NULL;
|
||||||
virDomainDefPtr def;
|
virDomainDefPtr def;
|
||||||
virDomainPtr dom = NULL;
|
virDomainPtr dom = NULL;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
if (!(def = virDomainDefParseString(conn, driver->caps, xml)))
|
if (!(def = virDomainDefParseString(conn, driver->caps, xml)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -934,6 +1018,7 @@ lxcDomainCreateAndStart(virConnectPtr conn,
|
|||||||
|
|
||||||
if (lxcVmStart(conn, driver, vm) < 0) {
|
if (lxcVmStart(conn, driver, vm) < 0) {
|
||||||
virDomainRemoveInactive(&driver->domains, vm);
|
virDomainRemoveInactive(&driver->domains, vm);
|
||||||
|
vm = NULL;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -943,6 +1028,9 @@ lxcDomainCreateAndStart(virConnectPtr conn,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -960,6 +1048,7 @@ static int lxcDomainShutdown(virDomainPtr dom)
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByID(&driver->domains, dom->id);
|
vm = virDomainFindByID(&driver->domains, dom->id);
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
@ -968,8 +1057,15 @@ static int lxcDomainShutdown(virDomainPtr dom)
|
|||||||
}
|
}
|
||||||
|
|
||||||
ret = lxcVmTerminate(dom->conn, driver, vm, 0);
|
ret = lxcVmTerminate(dom->conn, driver, vm, 0);
|
||||||
|
if (!vm->persistent) {
|
||||||
|
virDomainRemoveInactive(&driver->domains, vm);
|
||||||
|
vm = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -988,6 +1084,7 @@ static int lxcDomainDestroy(virDomainPtr dom)
|
|||||||
virDomainObjPtr vm;
|
virDomainObjPtr vm;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
vm = virDomainFindByID(&driver->domains, dom->id);
|
vm = virDomainFindByID(&driver->domains, dom->id);
|
||||||
if (!vm) {
|
if (!vm) {
|
||||||
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
lxcError(dom->conn, dom, VIR_ERR_INVALID_DOMAIN,
|
||||||
@ -996,8 +1093,15 @@ static int lxcDomainDestroy(virDomainPtr dom)
|
|||||||
}
|
}
|
||||||
|
|
||||||
ret = lxcVmTerminate(dom->conn, driver, vm, SIGKILL);
|
ret = lxcVmTerminate(dom->conn, driver, vm, SIGKILL);
|
||||||
|
if (!vm->persistent) {
|
||||||
|
virDomainRemoveInactive(&driver->domains, vm);
|
||||||
|
vm = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1029,53 +1133,56 @@ static int lxcStartup(void)
|
|||||||
if (VIR_ALLOC(lxc_driver) < 0) {
|
if (VIR_ALLOC(lxc_driver) < 0) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
pthread_mutex_init(&lxc_driver->lock, NULL);
|
||||||
|
lxcDriverLock(lxc_driver);
|
||||||
|
|
||||||
/* Check that this is a container enabled kernel */
|
/* Check that this is a container enabled kernel */
|
||||||
if(lxcContainerAvailable(0) < 0)
|
if(lxcContainerAvailable(0) < 0)
|
||||||
return -1;
|
goto cleanup;
|
||||||
|
|
||||||
lxc_driver->have_netns = lxcCheckNetNsSupport();
|
lxc_driver->have_netns = lxcCheckNetNsSupport();
|
||||||
|
|
||||||
/* Call function to load lxc driver configuration information */
|
/* Call function to load lxc driver configuration information */
|
||||||
if (lxcLoadDriverConfig(lxc_driver) < 0) {
|
if (lxcLoadDriverConfig(lxc_driver) < 0)
|
||||||
lxcShutdown();
|
goto cleanup;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((lxc_driver->caps = lxcCapsInit()) == NULL) {
|
if ((lxc_driver->caps = lxcCapsInit()) == NULL)
|
||||||
lxcShutdown();
|
goto cleanup;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (virDomainLoadAllConfigs(NULL,
|
if (virDomainLoadAllConfigs(NULL,
|
||||||
lxc_driver->caps,
|
lxc_driver->caps,
|
||||||
&lxc_driver->domains,
|
&lxc_driver->domains,
|
||||||
lxc_driver->configDir,
|
lxc_driver->configDir,
|
||||||
lxc_driver->autostartDir,
|
lxc_driver->autostartDir,
|
||||||
NULL, NULL) < 0) {
|
NULL, NULL) < 0)
|
||||||
lxcShutdown();
|
goto cleanup;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0 ; i < lxc_driver->domains.count ; i++) {
|
for (i = 0 ; i < lxc_driver->domains.count ; i++) {
|
||||||
virDomainObjPtr vm = lxc_driver->domains.objs[i];
|
virDomainObjPtr vm = lxc_driver->domains.objs[i];
|
||||||
char *config = NULL;
|
char *config = NULL;
|
||||||
virDomainDefPtr tmp;
|
virDomainDefPtr tmp;
|
||||||
int rc;
|
int rc;
|
||||||
if ((vm->monitor = lxcMonitorClient(NULL, lxc_driver, vm)) < 0)
|
|
||||||
|
virDomainObjLock(vm);
|
||||||
|
if ((vm->monitor = lxcMonitorClient(NULL, lxc_driver, vm)) < 0) {
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* Read pid from controller */
|
/* Read pid from controller */
|
||||||
if ((rc = virFileReadPid(lxc_driver->stateDir, vm->def->name, &vm->pid)) != 0) {
|
if ((rc = virFileReadPid(lxc_driver->stateDir, vm->def->name, &vm->pid)) != 0) {
|
||||||
close(vm->monitor);
|
close(vm->monitor);
|
||||||
vm->monitor = -1;
|
vm->monitor = -1;
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((config = virDomainConfigFile(NULL,
|
if ((config = virDomainConfigFile(NULL,
|
||||||
lxc_driver->stateDir,
|
lxc_driver->stateDir,
|
||||||
vm->def->name)) == NULL)
|
vm->def->name)) == NULL) {
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* Try and load the live config */
|
/* Try and load the live config */
|
||||||
tmp = virDomainDefParseFile(NULL, lxc_driver->caps, config, 0);
|
tmp = virDomainDefParseFile(NULL, lxc_driver->caps, config, 0);
|
||||||
@ -1093,19 +1200,16 @@ static int lxcStartup(void)
|
|||||||
close(vm->monitor);
|
close(vm->monitor);
|
||||||
vm->monitor = -1;
|
vm->monitor = -1;
|
||||||
}
|
}
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
lxcDriverUnlock(lxc_driver);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
static void lxcFreeDriver(lxc_driver_t *driver)
|
cleanup:
|
||||||
{
|
lxcDriverUnlock(lxc_driver);
|
||||||
virCapabilitiesFree(driver->caps);
|
lxcShutdown();
|
||||||
VIR_FREE(driver->configDir);
|
return -1;
|
||||||
VIR_FREE(driver->autostartDir);
|
|
||||||
VIR_FREE(driver->stateDir);
|
|
||||||
VIR_FREE(driver->logDir);
|
|
||||||
VIR_FREE(driver);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lxcShutdown(void)
|
static int lxcShutdown(void)
|
||||||
@ -1113,8 +1217,16 @@ static int lxcShutdown(void)
|
|||||||
if (lxc_driver == NULL)
|
if (lxc_driver == NULL)
|
||||||
return(-1);
|
return(-1);
|
||||||
|
|
||||||
|
lxcDriverLock(lxc_driver);
|
||||||
virDomainObjListFree(&lxc_driver->domains);
|
virDomainObjListFree(&lxc_driver->domains);
|
||||||
lxcFreeDriver(lxc_driver);
|
|
||||||
|
virCapabilitiesFree(lxc_driver->caps);
|
||||||
|
VIR_FREE(lxc_driver->configDir);
|
||||||
|
VIR_FREE(lxc_driver->autostartDir);
|
||||||
|
VIR_FREE(lxc_driver->stateDir);
|
||||||
|
VIR_FREE(lxc_driver->logDir);
|
||||||
|
lxcDriverUnlock(lxc_driver);
|
||||||
|
VIR_FREE(lxc_driver);
|
||||||
lxc_driver = NULL;
|
lxc_driver = NULL;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -1130,16 +1242,21 @@ static int lxcShutdown(void)
|
|||||||
static int
|
static int
|
||||||
lxcActive(void) {
|
lxcActive(void) {
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
int active = 0;
|
||||||
|
|
||||||
if (lxc_driver == NULL)
|
if (lxc_driver == NULL)
|
||||||
return(0);
|
return(0);
|
||||||
|
|
||||||
for (i = 0 ; i < lxc_driver->domains.count ; i++)
|
lxcDriverLock(lxc_driver);
|
||||||
|
for (i = 0 ; i < lxc_driver->domains.count ; i++) {
|
||||||
|
virDomainObjLock(lxc_driver->domains.objs[i]);
|
||||||
if (virDomainIsActive(lxc_driver->domains.objs[i]))
|
if (virDomainIsActive(lxc_driver->domains.objs[i]))
|
||||||
return 1;
|
active = 1;
|
||||||
|
virDomainObjUnlock(lxc_driver->domains.objs[i]);
|
||||||
|
}
|
||||||
|
lxcDriverUnlock(lxc_driver);
|
||||||
|
|
||||||
/* Otherwise we're happy to deal with a shutdown */
|
return active;
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lxcVersion(virConnectPtr conn, unsigned long *version)
|
static int lxcVersion(virConnectPtr conn, unsigned long *version)
|
||||||
@ -1179,15 +1296,19 @@ static int lxcSetSchedulerParameters(virDomainPtr domain,
|
|||||||
virSchedParameterPtr params,
|
virSchedParameterPtr params,
|
||||||
int nparams)
|
int nparams)
|
||||||
{
|
{
|
||||||
|
lxc_driver_t *driver = domain->conn->privateData;
|
||||||
int i;
|
int i;
|
||||||
virCgroupPtr group = NULL;
|
virCgroupPtr group = NULL;
|
||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (virCgroupHaveSupport() != 0)
|
if (virCgroupHaveSupport() != 0)
|
||||||
goto cleanup;
|
return -1;
|
||||||
|
|
||||||
|
lxcDriverLock(driver);
|
||||||
|
vm = virDomainFindByUUID(&driver->domains, domain->uuid);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
vm = virDomainFindByUUID(&lxc_driver->domains, domain->uuid);
|
|
||||||
if (vm == NULL) {
|
if (vm == NULL) {
|
||||||
lxcError(NULL, domain, VIR_ERR_INTERNAL_ERROR,
|
lxcError(NULL, domain, VIR_ERR_INTERNAL_ERROR,
|
||||||
_("No such domain %s"), domain->uuid);
|
_("No such domain %s"), domain->uuid);
|
||||||
@ -1213,7 +1334,8 @@ static int lxcSetSchedulerParameters(virDomainPtr domain,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virCgroupFree(&group);
|
virCgroupFree(&group);
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1221,21 +1343,25 @@ static int lxcGetSchedulerParameters(virDomainPtr domain,
|
|||||||
virSchedParameterPtr params,
|
virSchedParameterPtr params,
|
||||||
int *nparams)
|
int *nparams)
|
||||||
{
|
{
|
||||||
|
lxc_driver_t *driver = domain->conn->privateData;
|
||||||
virCgroupPtr group = NULL;
|
virCgroupPtr group = NULL;
|
||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (virCgroupHaveSupport() != 0)
|
if (virCgroupHaveSupport() != 0)
|
||||||
goto cleanup;
|
return -1;
|
||||||
|
|
||||||
if ((*nparams) != 1) {
|
if ((*nparams) != 1) {
|
||||||
lxcError(NULL, domain, VIR_ERR_INVALID_ARG,
|
lxcError(NULL, domain, VIR_ERR_INVALID_ARG,
|
||||||
"%s", _("Invalid parameter count"));
|
"%s", _("Invalid parameter count"));
|
||||||
goto cleanup;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
vm = virDomainFindByUUID(&lxc_driver->domains, domain->uuid);
|
lxcDriverLock(driver);
|
||||||
|
vm = virDomainFindByUUID(&driver->domains, domain->uuid);
|
||||||
|
lxcDriverUnlock(driver);
|
||||||
|
|
||||||
if (vm == NULL) {
|
if (vm == NULL) {
|
||||||
lxcError(NULL, domain, VIR_ERR_INTERNAL_ERROR,
|
lxcError(NULL, domain, VIR_ERR_INTERNAL_ERROR,
|
||||||
_("No such domain %s"), domain->uuid);
|
_("No such domain %s"), domain->uuid);
|
||||||
@ -1255,6 +1381,8 @@ static int lxcGetSchedulerParameters(virDomainPtr domain,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virCgroupFree(&group);
|
virCgroupFree(&group);
|
||||||
|
if (vm)
|
||||||
|
virDomainObjUnlock(vm);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user