mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-10-30 01:43:23 +00:00
Add locking for thread safety to storage driver
This commit is contained in:
parent
c38d4d54c6
commit
b6ee63d8bb
@ -1,3 +1,8 @@
|
|||||||
|
Thu Dec 4 21:40:41 GMT 2008 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
|
* src/storage_conf.h: Add driver lock
|
||||||
|
* src/storage_driver.c: Add locking for thread safety
|
||||||
|
|
||||||
Thu Dec 4 21:39:41 GMT 2008 Daniel P. Berrange <berrange@redhat.com>
|
Thu Dec 4 21:39:41 GMT 2008 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
* src/storage_driver.c: Merge all return paths driver storage
|
* src/storage_driver.c: Merge all return paths driver storage
|
||||||
|
@ -248,6 +248,8 @@ typedef struct _virStorageDriverState virStorageDriverState;
|
|||||||
typedef virStorageDriverState *virStorageDriverStatePtr;
|
typedef virStorageDriverState *virStorageDriverStatePtr;
|
||||||
|
|
||||||
struct _virStorageDriverState {
|
struct _virStorageDriverState {
|
||||||
|
PTHREAD_MUTEX_T(lock);
|
||||||
|
|
||||||
virStoragePoolObjList pools;
|
virStoragePoolObjList pools;
|
||||||
|
|
||||||
char *configDir;
|
char *configDir;
|
||||||
|
@ -47,6 +47,14 @@ static virStorageDriverStatePtr driverState;
|
|||||||
|
|
||||||
static int storageDriverShutdown(void);
|
static int storageDriverShutdown(void);
|
||||||
|
|
||||||
|
static void storageDriverLock(virStorageDriverStatePtr driver)
|
||||||
|
{
|
||||||
|
pthread_mutex_lock(&driver->lock);
|
||||||
|
}
|
||||||
|
static void storageDriverUnlock(virStorageDriverStatePtr driver)
|
||||||
|
{
|
||||||
|
pthread_mutex_unlock(&driver->lock);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
storageDriverAutostart(virStorageDriverStatePtr driver) {
|
storageDriverAutostart(virStorageDriverStatePtr driver) {
|
||||||
@ -55,12 +63,14 @@ storageDriverAutostart(virStorageDriverStatePtr driver) {
|
|||||||
for (i = 0 ; i < driver->pools.count ; i++) {
|
for (i = 0 ; i < driver->pools.count ; i++) {
|
||||||
virStoragePoolObjPtr pool = driver->pools.objs[i];
|
virStoragePoolObjPtr pool = driver->pools.objs[i];
|
||||||
|
|
||||||
|
virStoragePoolObjLock(pool);
|
||||||
if (pool->autostart &&
|
if (pool->autostart &&
|
||||||
!virStoragePoolObjIsActive(pool)) {
|
!virStoragePoolObjIsActive(pool)) {
|
||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
if ((backend = virStorageBackendForType(pool->def->type)) == NULL) {
|
if ((backend = virStorageBackendForType(pool->def->type)) == NULL) {
|
||||||
storageLog("Missing backend %d",
|
storageLog("Missing backend %d",
|
||||||
pool->def->type);
|
pool->def->type);
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,6 +79,7 @@ storageDriverAutostart(virStorageDriverStatePtr driver) {
|
|||||||
virErrorPtr err = virGetLastError();
|
virErrorPtr err = virGetLastError();
|
||||||
storageLog("Failed to autostart storage pool '%s': %s",
|
storageLog("Failed to autostart storage pool '%s': %s",
|
||||||
pool->def->name, err ? err->message : NULL);
|
pool->def->name, err ? err->message : NULL);
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,10 +89,12 @@ storageDriverAutostart(virStorageDriverStatePtr driver) {
|
|||||||
backend->stopPool(NULL, pool);
|
backend->stopPool(NULL, pool);
|
||||||
storageLog("Failed to autostart storage pool '%s': %s",
|
storageLog("Failed to autostart storage pool '%s': %s",
|
||||||
pool->def->name, err ? err->message : NULL);
|
pool->def->name, err ? err->message : NULL);
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
pool->active = 1;
|
pool->active = 1;
|
||||||
}
|
}
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -100,6 +113,9 @@ storageDriverStartup(void) {
|
|||||||
if (VIR_ALLOC(driverState) < 0)
|
if (VIR_ALLOC(driverState) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
pthread_mutex_init(&driverState->lock, NULL);
|
||||||
|
storageDriverLock(driverState);
|
||||||
|
|
||||||
if (!uid) {
|
if (!uid) {
|
||||||
if ((base = strdup (SYSCONF_DIR "/libvirt")) == NULL)
|
if ((base = strdup (SYSCONF_DIR "/libvirt")) == NULL)
|
||||||
goto out_of_memory;
|
goto out_of_memory;
|
||||||
@ -132,8 +148,7 @@ storageDriverStartup(void) {
|
|||||||
"%s/storage/autostart", base) == -1)
|
"%s/storage/autostart", base) == -1)
|
||||||
goto out_of_memory;
|
goto out_of_memory;
|
||||||
|
|
||||||
free(base);
|
VIR_FREE(base);
|
||||||
base = NULL;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
if (virStorageLoadDriverConfig(driver, driverConf) < 0) {
|
if (virStorageLoadDriverConfig(driver, driverConf) < 0) {
|
||||||
@ -145,19 +160,19 @@ storageDriverStartup(void) {
|
|||||||
if (virStoragePoolLoadAllConfigs(NULL,
|
if (virStoragePoolLoadAllConfigs(NULL,
|
||||||
&driverState->pools,
|
&driverState->pools,
|
||||||
driverState->configDir,
|
driverState->configDir,
|
||||||
driverState->autostartDir) < 0) {
|
driverState->autostartDir) < 0)
|
||||||
storageDriverShutdown();
|
goto error;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
storageDriverAutostart(driverState);
|
storageDriverAutostart(driverState);
|
||||||
|
|
||||||
|
storageDriverUnlock(driverState);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
out_of_memory:
|
out_of_memory:
|
||||||
storageLog("virStorageStartup: out of memory");
|
storageLog("virStorageStartup: out of memory");
|
||||||
free(base);
|
error:
|
||||||
free(driverState);
|
VIR_FREE(base);
|
||||||
driverState = NULL;
|
storageDriverUnlock(driverState);
|
||||||
|
storageDriverShutdown();
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,11 +187,13 @@ storageDriverReload(void) {
|
|||||||
if (!driverState)
|
if (!driverState)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
storageDriverLock(driverState);
|
||||||
virStoragePoolLoadAllConfigs(NULL,
|
virStoragePoolLoadAllConfigs(NULL,
|
||||||
&driverState->pools,
|
&driverState->pools,
|
||||||
driverState->configDir,
|
driverState->configDir,
|
||||||
driverState->autostartDir);
|
driverState->autostartDir);
|
||||||
storageDriverAutostart(driverState);
|
storageDriverAutostart(driverState);
|
||||||
|
storageDriverUnlock(driverState);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -191,19 +208,22 @@ storageDriverReload(void) {
|
|||||||
static int
|
static int
|
||||||
storageDriverActive(void) {
|
storageDriverActive(void) {
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
int active = 0;
|
||||||
|
|
||||||
if (!driverState)
|
if (!driverState)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* If we've any active networks or guests, then we
|
storageDriverLock(driverState);
|
||||||
* mark this driver as active
|
|
||||||
*/
|
|
||||||
for (i = 0 ; i < driverState->pools.count ; i++)
|
|
||||||
if (virStoragePoolObjIsActive(driverState->pools.objs[i]))
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
/* Otherwise we're happy to deal with a shutdown */
|
for (i = 0 ; i < driverState->pools.count ; i++) {
|
||||||
return 0;
|
virStoragePoolObjLock(driverState->pools.objs[i]);
|
||||||
|
if (virStoragePoolObjIsActive(driverState->pools.objs[i]))
|
||||||
|
active = 1;
|
||||||
|
virStoragePoolObjUnlock(driverState->pools.objs[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
storageDriverUnlock(driverState);
|
||||||
|
return active;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -218,6 +238,7 @@ storageDriverShutdown(void) {
|
|||||||
if (!driverState)
|
if (!driverState)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
storageDriverLock(driverState);
|
||||||
/* shutdown active pools */
|
/* shutdown active pools */
|
||||||
for (i = 0 ; i < driverState->pools.count ; i++) {
|
for (i = 0 ; i < driverState->pools.count ; i++) {
|
||||||
virStoragePoolObjPtr pool = driverState->pools.objs[i];
|
virStoragePoolObjPtr pool = driverState->pools.objs[i];
|
||||||
@ -244,6 +265,7 @@ storageDriverShutdown(void) {
|
|||||||
|
|
||||||
VIR_FREE(driverState->configDir);
|
VIR_FREE(driverState->configDir);
|
||||||
VIR_FREE(driverState->autostartDir);
|
VIR_FREE(driverState->autostartDir);
|
||||||
|
storageDriverUnlock(driverState);
|
||||||
VIR_FREE(driverState);
|
VIR_FREE(driverState);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -258,7 +280,10 @@ storagePoolLookupByUUID(virConnectPtr conn,
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
virStoragePoolPtr ret = NULL;
|
virStoragePoolPtr ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(conn, VIR_ERR_NO_STORAGE_POOL,
|
virStorageReportError(conn, VIR_ERR_NO_STORAGE_POOL,
|
||||||
"%s", _("no pool with matching uuid"));
|
"%s", _("no pool with matching uuid"));
|
||||||
@ -268,6 +293,8 @@ storagePoolLookupByUUID(virConnectPtr conn,
|
|||||||
ret = virGetStoragePool(conn, pool->def->name, pool->def->uuid);
|
ret = virGetStoragePool(conn, pool->def->name, pool->def->uuid);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -278,7 +305,10 @@ storagePoolLookupByName(virConnectPtr conn,
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
virStoragePoolPtr ret = NULL;
|
virStoragePoolPtr ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByName(&driver->pools, name);
|
pool = virStoragePoolObjFindByName(&driver->pools, name);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(conn, VIR_ERR_NO_STORAGE_POOL,
|
virStorageReportError(conn, VIR_ERR_NO_STORAGE_POOL,
|
||||||
"%s", _("no pool with matching name"));
|
"%s", _("no pool with matching name"));
|
||||||
@ -288,6 +318,8 @@ storagePoolLookupByName(virConnectPtr conn,
|
|||||||
ret = virGetStoragePool(conn, pool->def->name, pool->def->uuid);
|
ret = virGetStoragePool(conn, pool->def->name, pool->def->uuid);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -318,9 +350,14 @@ storageNumPools(virConnectPtr conn) {
|
|||||||
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
||||||
unsigned int i, nactive = 0;
|
unsigned int i, nactive = 0;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->pools.count ; i++)
|
storageDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->pools.count ; i++) {
|
||||||
|
virStoragePoolObjLock(driver->pools.objs[i]);
|
||||||
if (virStoragePoolObjIsActive(driver->pools.objs[i]))
|
if (virStoragePoolObjIsActive(driver->pools.objs[i]))
|
||||||
nactive++;
|
nactive++;
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
|
}
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
return nactive;
|
return nactive;
|
||||||
}
|
}
|
||||||
@ -332,23 +369,27 @@ storageListPools(virConnectPtr conn,
|
|||||||
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
||||||
int got = 0, i;
|
int got = 0, i;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
for (i = 0 ; i < driver->pools.count && got < nnames ; i++) {
|
for (i = 0 ; i < driver->pools.count && got < nnames ; i++) {
|
||||||
|
virStoragePoolObjLock(driver->pools.objs[i]);
|
||||||
if (virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
if (virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
||||||
if (!(names[got] = strdup(driver->pools.objs[i]->def->name))) {
|
if (!(names[got] = strdup(driver->pools.objs[i]->def->name))) {
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
virStorageReportError(conn, VIR_ERR_NO_MEMORY,
|
virStorageReportError(conn, VIR_ERR_NO_MEMORY,
|
||||||
"%s", _("names"));
|
"%s", _("names"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
got++;
|
got++;
|
||||||
}
|
}
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
}
|
}
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return got;
|
return got;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
for (i = 0 ; i < got ; i++) {
|
storageDriverUnlock(driver);
|
||||||
free(names[i]);
|
for (i = 0 ; i < got ; i++)
|
||||||
names[i] = NULL;
|
VIR_FREE(names[i]);
|
||||||
}
|
|
||||||
memset(names, 0, nnames * sizeof(*names));
|
memset(names, 0, nnames * sizeof(*names));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -358,9 +399,14 @@ storageNumDefinedPools(virConnectPtr conn) {
|
|||||||
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
||||||
unsigned int i, nactive = 0;
|
unsigned int i, nactive = 0;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->pools.count ; i++)
|
storageDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->pools.count ; i++) {
|
||||||
|
virStoragePoolObjLock(driver->pools.objs[i]);
|
||||||
if (!virStoragePoolObjIsActive(driver->pools.objs[i]))
|
if (!virStoragePoolObjIsActive(driver->pools.objs[i]))
|
||||||
nactive++;
|
nactive++;
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
|
}
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
return nactive;
|
return nactive;
|
||||||
}
|
}
|
||||||
@ -372,19 +418,25 @@ storageListDefinedPools(virConnectPtr conn,
|
|||||||
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
||||||
int got = 0, i;
|
int got = 0, i;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
for (i = 0 ; i < driver->pools.count && got < nnames ; i++) {
|
for (i = 0 ; i < driver->pools.count && got < nnames ; i++) {
|
||||||
|
virStoragePoolObjLock(driver->pools.objs[i]);
|
||||||
if (!virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
if (!virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
||||||
if (!(names[got] = strdup(driver->pools.objs[i]->def->name))) {
|
if (!(names[got] = strdup(driver->pools.objs[i]->def->name))) {
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
virStorageReportError(conn, VIR_ERR_NO_MEMORY,
|
virStorageReportError(conn, VIR_ERR_NO_MEMORY,
|
||||||
"%s", _("names"));
|
"%s", _("names"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
got++;
|
got++;
|
||||||
}
|
}
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
}
|
}
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return got;
|
return got;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
storageDriverUnlock(driver);
|
||||||
for (i = 0 ; i < got ; i++) {
|
for (i = 0 ; i < got ; i++) {
|
||||||
free(names[i]);
|
free(names[i]);
|
||||||
names[i] = NULL;
|
names[i] = NULL;
|
||||||
@ -393,6 +445,8 @@ storageListDefinedPools(virConnectPtr conn,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* This method is required to be re-entrant / thread safe, so
|
||||||
|
uses no driver lock */
|
||||||
static char *
|
static char *
|
||||||
storageFindPoolSources(virConnectPtr conn,
|
storageFindPoolSources(virConnectPtr conn,
|
||||||
const char *type,
|
const char *type,
|
||||||
@ -425,10 +479,11 @@ storagePoolCreate(virConnectPtr conn,
|
|||||||
unsigned int flags ATTRIBUTE_UNUSED) {
|
unsigned int flags ATTRIBUTE_UNUSED) {
|
||||||
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
||||||
virStoragePoolDefPtr def;
|
virStoragePoolDefPtr def;
|
||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool = NULL;
|
||||||
virStoragePoolPtr ret = NULL;
|
virStoragePoolPtr ret = NULL;
|
||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
if (!(def = virStoragePoolDefParse(conn, xml, NULL)))
|
if (!(def = virStoragePoolDefParse(conn, xml, NULL)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -464,6 +519,9 @@ storagePoolCreate(virConnectPtr conn,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virStoragePoolDefFree(def);
|
virStoragePoolDefFree(def);
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -473,10 +531,11 @@ storagePoolDefine(virConnectPtr conn,
|
|||||||
unsigned int flags ATTRIBUTE_UNUSED) {
|
unsigned int flags ATTRIBUTE_UNUSED) {
|
||||||
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
virStorageDriverStatePtr driver = conn->storagePrivateData;
|
||||||
virStoragePoolDefPtr def;
|
virStoragePoolDefPtr def;
|
||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool = NULL;
|
||||||
virStoragePoolPtr ret = NULL;
|
virStoragePoolPtr ret = NULL;
|
||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
if (!(def = virStoragePoolDefParse(conn, xml, NULL)))
|
if (!(def = virStoragePoolDefParse(conn, xml, NULL)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -496,6 +555,9 @@ storagePoolDefine(virConnectPtr conn,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virStoragePoolDefFree(def);
|
virStoragePoolDefFree(def);
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -505,6 +567,7 @@ storagePoolUndefine(virStoragePoolPtr obj) {
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
@ -529,9 +592,13 @@ storagePoolUndefine(virStoragePoolPtr obj) {
|
|||||||
VIR_FREE(pool->autostartLink);
|
VIR_FREE(pool->autostartLink);
|
||||||
|
|
||||||
virStoragePoolObjRemove(&driver->pools, pool);
|
virStoragePoolObjRemove(&driver->pools, pool);
|
||||||
|
pool = NULL;
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -543,7 +610,10 @@ storagePoolStart(virStoragePoolPtr obj,
|
|||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -572,6 +642,8 @@ storagePoolStart(virStoragePoolPtr obj,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -583,7 +655,10 @@ storagePoolBuild(virStoragePoolPtr obj,
|
|||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -605,6 +680,8 @@ storagePoolBuild(virStoragePoolPtr obj,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -616,7 +693,9 @@ storagePoolDestroy(virStoragePoolPtr obj) {
|
|||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -640,11 +719,16 @@ storagePoolDestroy(virStoragePoolPtr obj) {
|
|||||||
|
|
||||||
pool->active = 0;
|
pool->active = 0;
|
||||||
|
|
||||||
if (pool->configFile == NULL)
|
if (pool->configFile == NULL) {
|
||||||
virStoragePoolObjRemove(&driver->pools, pool);
|
virStoragePoolObjRemove(&driver->pools, pool);
|
||||||
|
pool = NULL;
|
||||||
|
}
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -657,7 +741,10 @@ storagePoolDelete(virStoragePoolPtr obj,
|
|||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -683,6 +770,8 @@ storagePoolDelete(virStoragePoolPtr obj,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -695,7 +784,10 @@ storagePoolRefresh(virStoragePoolPtr obj,
|
|||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -718,13 +810,17 @@ storagePoolRefresh(virStoragePoolPtr obj,
|
|||||||
|
|
||||||
pool->active = 0;
|
pool->active = 0;
|
||||||
|
|
||||||
if (pool->configFile == NULL)
|
if (pool->configFile == NULL) {
|
||||||
virStoragePoolObjRemove(&driver->pools, pool);
|
virStoragePoolObjRemove(&driver->pools, pool);
|
||||||
|
pool = NULL;
|
||||||
|
}
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -737,7 +833,10 @@ storagePoolGetInfo(virStoragePoolPtr obj,
|
|||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -758,6 +857,8 @@ storagePoolGetInfo(virStoragePoolPtr obj,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -768,7 +869,10 @@ storagePoolDumpXML(virStoragePoolPtr obj,
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -778,6 +882,8 @@ storagePoolDumpXML(virStoragePoolPtr obj,
|
|||||||
ret = virStoragePoolDefFormat(obj->conn, pool->def);
|
ret = virStoragePoolDefFormat(obj->conn, pool->def);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -788,7 +894,10 @@ storagePoolGetAutostart(virStoragePoolPtr obj,
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no pool with matching uuid"));
|
"%s", _("no pool with matching uuid"));
|
||||||
@ -814,7 +923,10 @@ storagePoolSetAutostart(virStoragePoolPtr obj,
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no pool with matching uuid"));
|
"%s", _("no pool with matching uuid"));
|
||||||
@ -861,6 +973,8 @@ storagePoolSetAutostart(virStoragePoolPtr obj,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -871,7 +985,10 @@ storagePoolNumVolumes(virStoragePoolPtr obj) {
|
|||||||
virStoragePoolObjPtr pool;
|
virStoragePoolObjPtr pool;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -886,6 +1003,8 @@ storagePoolNumVolumes(virStoragePoolPtr obj) {
|
|||||||
ret = pool->volumes.count;
|
ret = pool->volumes.count;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -899,7 +1018,10 @@ storagePoolListVolumes(virStoragePoolPtr obj,
|
|||||||
|
|
||||||
memset(names, 0, maxnames * sizeof(*names));
|
memset(names, 0, maxnames * sizeof(*names));
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -920,9 +1042,12 @@ storagePoolListVolumes(virStoragePoolPtr obj,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return n;
|
return n;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
for (n = 0 ; n < maxnames ; n++)
|
for (n = 0 ; n < maxnames ; n++)
|
||||||
VIR_FREE(names[n]);
|
VIR_FREE(names[n]);
|
||||||
|
|
||||||
@ -939,7 +1064,10 @@ storageVolumeLookupByName(virStoragePoolPtr obj,
|
|||||||
virStorageVolDefPtr vol;
|
virStorageVolDefPtr vol;
|
||||||
virStorageVolPtr ret = NULL;
|
virStorageVolPtr ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -963,6 +1091,8 @@ storageVolumeLookupByName(virStoragePoolPtr obj,
|
|||||||
ret = virGetStorageVol(obj->conn, pool->def->name, vol->name, vol->key);
|
ret = virGetStorageVol(obj->conn, pool->def->name, vol->name, vol->key);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -974,20 +1104,22 @@ storageVolumeLookupByKey(virConnectPtr conn,
|
|||||||
unsigned int i;
|
unsigned int i;
|
||||||
virStorageVolPtr ret = NULL;
|
virStorageVolPtr ret = NULL;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->pools.count ; i++) {
|
storageDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->pools.count && !ret ; i++) {
|
||||||
|
virStoragePoolObjLock(driver->pools.objs[i]);
|
||||||
if (virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
if (virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
||||||
virStorageVolDefPtr vol =
|
virStorageVolDefPtr vol =
|
||||||
virStorageVolDefFindByKey(driver->pools.objs[i], key);
|
virStorageVolDefFindByKey(driver->pools.objs[i], key);
|
||||||
|
|
||||||
if (vol) {
|
if (vol)
|
||||||
ret = virGetStorageVol(conn,
|
ret = virGetStorageVol(conn,
|
||||||
driver->pools.objs[i]->def->name,
|
driver->pools.objs[i]->def->name,
|
||||||
vol->name,
|
vol->name,
|
||||||
vol->key);
|
vol->key);
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
}
|
}
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!ret)
|
if (!ret)
|
||||||
virStorageReportError(conn, VIR_ERR_INVALID_STORAGE_VOL,
|
virStorageReportError(conn, VIR_ERR_INVALID_STORAGE_VOL,
|
||||||
@ -1003,7 +1135,9 @@ storageVolumeLookupByPath(virConnectPtr conn,
|
|||||||
unsigned int i;
|
unsigned int i;
|
||||||
virStorageVolPtr ret = NULL;
|
virStorageVolPtr ret = NULL;
|
||||||
|
|
||||||
for (i = 0 ; i < driver->pools.count ; i++) {
|
storageDriverLock(driver);
|
||||||
|
for (i = 0 ; i < driver->pools.count && !ret ; i++) {
|
||||||
|
virStoragePoolObjLock(driver->pools.objs[i]);
|
||||||
if (virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
if (virStoragePoolObjIsActive(driver->pools.objs[i])) {
|
||||||
virStorageVolDefPtr vol;
|
virStorageVolDefPtr vol;
|
||||||
const char *stable_path;
|
const char *stable_path;
|
||||||
@ -1016,21 +1150,22 @@ storageVolumeLookupByPath(virConnectPtr conn,
|
|||||||
* virStorageReportError if it fails; we just need to keep
|
* virStorageReportError if it fails; we just need to keep
|
||||||
* propagating the return code
|
* propagating the return code
|
||||||
*/
|
*/
|
||||||
if (stable_path == NULL)
|
if (stable_path == NULL) {
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
vol = virStorageVolDefFindByPath(driver->pools.objs[i],
|
vol = virStorageVolDefFindByPath(driver->pools.objs[i],
|
||||||
stable_path);
|
stable_path);
|
||||||
VIR_FREE(stable_path);
|
VIR_FREE(stable_path);
|
||||||
|
|
||||||
if (vol) {
|
if (vol)
|
||||||
ret = virGetStorageVol(conn,
|
ret = virGetStorageVol(conn,
|
||||||
driver->pools.objs[i]->def->name,
|
driver->pools.objs[i]->def->name,
|
||||||
vol->name,
|
vol->name,
|
||||||
vol->key);
|
vol->key);
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
virStoragePoolObjUnlock(driver->pools.objs[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ret)
|
if (!ret)
|
||||||
@ -1038,6 +1173,7 @@ storageVolumeLookupByPath(virConnectPtr conn,
|
|||||||
"%s", _("no storage vol with matching path"));
|
"%s", _("no storage vol with matching path"));
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
storageDriverUnlock(driver);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1051,7 +1187,10 @@ storageVolumeCreateXML(virStoragePoolPtr obj,
|
|||||||
virStorageVolDefPtr vol = NULL;
|
virStorageVolDefPtr vol = NULL;
|
||||||
virStorageVolPtr ret = NULL;
|
virStorageVolPtr ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
pool = virStoragePoolObjFindByUUID(&driver->pools, obj->uuid);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -1089,6 +1228,7 @@ storageVolumeCreateXML(virStoragePoolPtr obj,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* XXX ought to drop pool lock while creating instance */
|
||||||
if (backend->createVol(obj->conn, pool, vol) < 0) {
|
if (backend->createVol(obj->conn, pool, vol) < 0) {
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
@ -1100,6 +1240,8 @@ storageVolumeCreateXML(virStoragePoolPtr obj,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virStorageVolDefFree(vol);
|
virStorageVolDefFree(vol);
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1113,7 +1255,10 @@ storageVolumeDelete(virStorageVolPtr obj,
|
|||||||
unsigned int i;
|
unsigned int i;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -1168,6 +1313,8 @@ storageVolumeDelete(virStorageVolPtr obj,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virStorageVolDefFree(vol);
|
virStorageVolDefFree(vol);
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1180,7 +1327,10 @@ storageVolumeGetInfo(virStorageVolPtr obj,
|
|||||||
virStorageVolDefPtr vol;
|
virStorageVolDefPtr vol;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -1215,6 +1365,8 @@ storageVolumeGetInfo(virStorageVolPtr obj,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1227,7 +1379,10 @@ storageVolumeGetXMLDesc(virStorageVolPtr obj,
|
|||||||
virStorageVolDefPtr vol;
|
virStorageVolDefPtr vol;
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -1254,16 +1409,22 @@ storageVolumeGetXMLDesc(virStorageVolPtr obj,
|
|||||||
ret = virStorageVolDefFormat(obj->conn, pool->def, vol);
|
ret = virStorageVolDefFormat(obj->conn, pool->def, vol);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *
|
static char *
|
||||||
storageVolumeGetPath(virStorageVolPtr obj) {
|
storageVolumeGetPath(virStorageVolPtr obj) {
|
||||||
virStorageDriverStatePtr driver = obj->conn->storagePrivateData;
|
virStorageDriverStatePtr driver = obj->conn->storagePrivateData;
|
||||||
virStoragePoolObjPtr pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
virStoragePoolObjPtr pool;
|
||||||
virStorageVolDefPtr vol;
|
virStorageVolDefPtr vol;
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
|
||||||
|
storageDriverLock(driver);
|
||||||
|
pool = virStoragePoolObjFindByName(&driver->pools, obj->pool);
|
||||||
|
storageDriverUnlock(driver);
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
virStorageReportError(obj->conn, VIR_ERR_INVALID_STORAGE_POOL,
|
||||||
"%s", _("no storage pool with matching uuid"));
|
"%s", _("no storage pool with matching uuid"));
|
||||||
@ -1289,6 +1450,8 @@ storageVolumeGetPath(virStorageVolPtr obj) {
|
|||||||
virStorageReportError(obj->conn, VIR_ERR_NO_MEMORY, "%s", _("path"));
|
virStorageReportError(obj->conn, VIR_ERR_NO_MEMORY, "%s", _("path"));
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (pool)
|
||||||
|
virStoragePoolObjUnlock(pool);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user