mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-08 22:15:21 +00:00
vz: make vz driver more responsive
Current vz driver implementation is not usable when it comes to long runnig operations. Migration or saving a domain blocks all other operations even query ones which are expecteted to be available. This patch addresses this problem. All vz driver API calls fall into next 3 groups: 1. only query domain cache (virDomainObj, vz cache statistic) examples are vzDomainGetState, vzDomainGetXMLDesc etc. 2. use thread shared sdkdom object examples are vzDomainSetMemoryFlags, vzDomainAttachDevice etc. 3. use no thread shared sdkdom object nor domain cache examples are vzDomainSnapshotListNames, vzDomainSnapshotGetXMLDesc etc API calls from group 1 don't need to be changed as they hold domain lock only for short period of time. These calls [1] are easily distinguished. They query domain object thru libvirt common code or query vz sdk statistics handle thru vz sdk sync operations. vzDomainInterfaceStats is the only exception. It uses sdkdom object to convert interface name to its vz sdk stack index which could not be saved in domain cache. Interface statistics is available thru this stack index as a key rather than name. As a result we can have accidental 'not known interface' errors on quering intrerface stats. The reason is that in the process of updating domain configuration we drop all devices and then recreate them again in sdkdom object and domain lock can be dropped meanwhile (to remove networks for existing bridged interfaces and(or) (re)create new ones). We can fix this by changing the way we support bridged interfaces or by reordering operations and changing bridged networks beforehand. Anyway this is better than moving this API call into 2 group and making it an exclusive job. As to API calls from group 2, first thread shared sdkdom object needs to be explained. vz sdk has only one handle for a given domain, thus threads need exclusive access to operate on it. These calls are fixed to drop and reacquire domain lock on any lengthy operations - namely waiting the result of async vz sdk operation. As lock is dropped we need to take extra reference to domain object if it is not taken already as domain object can be deleted from list while lock is dropped. As this operations use thread shared sdkdom object, the simplest way to make calls from group 2 be consistent to each other is to make them mutually exclusive. This is done by taking/releasing job condition thru calling correspondent job routine. This approach makes group 1 and group 2 calls consistent to each other too. Not all calls of group 2 change the domain cache but those that do update it thru prlsdkUpdateDomain which holds the lock thoughout the update. API calls from group [2] are easily distinguished too. They use beginEdit/commit to change domain configuration (vzDomainSetMemoryFlags) or/and update domain cache from sdkdom at the end of operation (vzDomainSuspend). There is a known issue however. Frankly speaking it was introduced by ealier patch '[PATCH 6/9] vz: cleanup loading domain code' from a different series. The patch significantly reduced amount of time when the driver lock is held when creating domain from API call or as a result of domain added event from vz sdk. The problem is these two paths race on using thread shared sdkdom as we don't have libvirt domain object and can not lock on it. However this don't invalidates the patch as we can't use the former approach of preadding domain into the list as we need name at least and name is not given by event. Anyway i'm against adding half baked object into the list. Eventually this race can be fixed by extra measures. As to current situation races with different configurations are unlikely and race when adding domain thru vz driver and simultaneous event from vz sdk is not dangerous as configuration is the same. The last group [3] is API calls that need only sdkdom object to make vz sdk call and don't change thread shared sdkdom object or domain cache in any way. For now these are mostly domain snapshot API calls. The changes are similar to those of group 2 - they add extra reference and drop/reacquire the lock on waiting vz async call result. One can simply take the immutable sdkdom object from the cache and drop the lock for the rest of operations but the chosen approach makes implementation of these API calls somewhat similar to those of from group 2 and thus a bit futureproof. As calls of group 3 don't need vz driver domain/vz sdk cache in any way, they are consistent with respect to API calls from groups 1 and 3. There is another exception. Calls to make-snapshot/revert-to-snapshot/migrate are moved to group 2. That is they are made mutually exclusive. The reason is that libvirt API supports control/query only for one job per domain and these are jobs that are likely to be queried/aborted. Appendix. [1] API calls that only query domain cache. (marked [*] are included for a different reason) .domainLookupByID = vzDomainLookupByID, /* 0.10.0 */ .domainLookupByUUID = vzDomainLookupByUUID, /* 0.10.0 */ .domainLookupByName = vzDomainLookupByName, /* 0.10.0 */ .domainGetOSType = vzDomainGetOSType, /* 0.10.0 */ .domainGetInfo = vzDomainGetInfo, /* 0.10.0 */ .domainGetState = vzDomainGetState, /* 0.10.0 */ .domainGetXMLDesc = vzDomainGetXMLDesc, /* 0.10.0 */ .domainIsPersistent = vzDomainIsPersistent, /* 0.10.0 */ .domainGetAutostart = vzDomainGetAutostart, /* 0.10.0 */ .domainGetVcpus = vzDomainGetVcpus, /* 1.2.6 */ .domainIsActive = vzDomainIsActive, /* 1.2.10 */ .domainIsUpdated = vzDomainIsUpdated, /* 1.2.21 */ .domainGetVcpusFlags = vzDomainGetVcpusFlags, /* 1.2.21 */ .domainGetMaxVcpus = vzDomainGetMaxVcpus, /* 1.2.21 */ .domainHasManagedSaveImage = vzDomainHasManagedSaveImage, /* 1.2.13 */ .domainGetMaxMemory = vzDomainGetMaxMemory, /* 1.2.15 */ .domainBlockStats = vzDomainBlockStats, /* 1.2.17 */ .domainBlockStatsFlags = vzDomainBlockStatsFlags, /* 1.2.17 */ .domainInterfaceStats = vzDomainInterfaceStats, /* 1.2.17 */ [*] .domainMemoryStats = vzDomainMemoryStats, /* 1.2.17 */ .domainMigrateBegin3Params = vzDomainMigrateBegin3Params, /* 1.3.5 */ .domainMigrateConfirm3Params = vzDomainMigrateConfirm3Params, /* 1.3.5 */ [2] API calls that use thread shared sdkdom object (marked [*] are included for a different reason) .domainSuspend = vzDomainSuspend, /* 0.10.0 */ .domainResume = vzDomainResume, /* 0.10.0 */ .domainDestroy = vzDomainDestroy, /* 0.10.0 */ .domainShutdown = vzDomainShutdown, /* 0.10.0 */ .domainCreate = vzDomainCreate, /* 0.10.0 */ .domainCreateWithFlags = vzDomainCreateWithFlags, /* 1.2.10 */ .domainReboot = vzDomainReboot, /* 1.3.0 */ .domainDefineXML = vzDomainDefineXML, /* 0.10.0 */ .domainDefineXMLFlags = vzDomainDefineXMLFlags, /* 1.2.12 */ (update part) .domainUndefine = vzDomainUndefine, /* 1.2.10 */ .domainAttachDevice = vzDomainAttachDevice, /* 1.2.15 */ .domainAttachDeviceFlags = vzDomainAttachDeviceFlags, /* 1.2.15 */ .domainDetachDevice = vzDomainDetachDevice, /* 1.2.15 */ .domainDetachDeviceFlags = vzDomainDetachDeviceFlags, /* 1.2.15 */ .domainSetUserPassword = vzDomainSetUserPassword, /* 1.3.6 */ .domainManagedSave = vzDomainManagedSave, /* 1.2.14 */ .domainSetMemoryFlags = vzDomainSetMemoryFlags, /* 1.3.4 */ .domainSetMemory = vzDomainSetMemory, /* 1.3.4 */ .domainRevertToSnapshot = vzDomainRevertToSnapshot, /* 1.3.5 */ [*] .domainSnapshotCreateXML = vzDomainSnapshotCreateXML, /* 1.3.5 */ [*] .domainMigratePerform3Params = vzDomainMigratePerform3Params, /* 1.3.5 */ [*] .domainUpdateDeviceFlags = vzDomainUpdateDeviceFlags, /* 2.0.0 */ prlsdkHandleVmConfigEvent [3] API calls that do not use thread shared sdkdom object .domainManagedSaveRemove = vzDomainManagedSaveRemove, /* 1.2.14 */ .domainSnapshotNum = vzDomainSnapshotNum, /* 1.3.5 */ .domainSnapshotListNames = vzDomainSnapshotListNames, /* 1.3.5 */ .domainListAllSnapshots = vzDomainListAllSnapshots, /* 1.3.5 */ .domainSnapshotGetXMLDesc = vzDomainSnapshotGetXMLDesc, /* 1.3.5 */ .domainSnapshotNumChildren = vzDomainSnapshotNumChildren, /* 1.3.5 */ .domainSnapshotListChildrenNames = vzDomainSnapshotListChildrenNames, /* 1.3.5 */ .domainSnapshotListAllChildren = vzDomainSnapshotListAllChildren, /* 1.3.5 */ .domainSnapshotLookupByName = vzDomainSnapshotLookupByName, /* 1.3.5 */ .domainHasCurrentSnapshot = vzDomainHasCurrentSnapshot, /* 1.3.5 */ .domainSnapshotGetParent = vzDomainSnapshotGetParent, /* 1.3.5 */ .domainSnapshotCurrent = vzDomainSnapshotCurrent, /* 1.3.5 */ .domainSnapshotIsCurrent = vzDomainSnapshotIsCurrent, /* 1.3.5 */ .domainSnapshotHasMetadata = vzDomainSnapshotHasMetadata, /* 1.3.5 */ .domainSnapshotDelete = vzDomainSnapshotDelete, /* 1.3.5 */ [4] Known issues. 1. accidental errors on getting network statistics 2. race with simultaneous use of thread shared domain object on paths of adding domain thru API and adding domain on vz sdk domain added event.
This commit is contained in:
parent
5013ad4e0f
commit
8429923507
@ -723,6 +723,7 @@ vzDomainDefineXMLFlags(virConnectPtr conn, const char *xml, unsigned int flags)
|
|||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
unsigned int parse_flags = VIR_DOMAIN_DEF_PARSE_INACTIVE;
|
unsigned int parse_flags = VIR_DOMAIN_DEF_PARSE_INACTIVE;
|
||||||
vzDriverPtr driver = privconn->driver;
|
vzDriverPtr driver = privconn->driver;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_DEFINE_VALIDATE, NULL);
|
virCheckFlags(VIR_DOMAIN_DEFINE_VALIDATE, NULL);
|
||||||
|
|
||||||
@ -733,7 +734,7 @@ vzDomainDefineXMLFlags(virConnectPtr conn, const char *xml, unsigned int flags)
|
|||||||
parse_flags)) == NULL)
|
parse_flags)) == NULL)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
dom = virDomainObjListFindByUUID(driver->domains, def->uuid);
|
dom = virDomainObjListFindByUUIDRef(driver->domains, def->uuid);
|
||||||
if (dom == NULL) {
|
if (dom == NULL) {
|
||||||
virResetLastError();
|
virResetLastError();
|
||||||
if (def->os.type == VIR_DOMAIN_OSTYPE_HVM) {
|
if (def->os.type == VIR_DOMAIN_OSTYPE_HVM) {
|
||||||
@ -775,6 +776,10 @@ vzDomainDefineXMLFlags(virConnectPtr conn, const char *xml, unsigned int flags)
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
if (prlsdkApplyConfig(driver, dom, def))
|
if (prlsdkApplyConfig(driver, dom, def))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -788,8 +793,9 @@ vzDomainDefineXMLFlags(virConnectPtr conn, const char *xml, unsigned int flags)
|
|||||||
retdom->id = def->id;
|
retdom->id = def->id;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (dom)
|
if (job)
|
||||||
virObjectUnlock(dom);
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
return retdom;
|
return retdom;
|
||||||
}
|
}
|
||||||
@ -991,17 +997,26 @@ vzDomainUndefineFlags(virDomainPtr domain,
|
|||||||
{
|
{
|
||||||
vzConnPtr privconn = domain->conn->privateData;
|
vzConnPtr privconn = domain->conn->privateData;
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
int ret;
|
int ret = -1;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_UNDEFINE_MANAGED_SAVE |
|
virCheckFlags(VIR_DOMAIN_UNDEFINE_MANAGED_SAVE |
|
||||||
VIR_DOMAIN_UNDEFINE_SNAPSHOTS_METADATA, -1);
|
VIR_DOMAIN_UNDEFINE_SNAPSHOTS_METADATA, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
ret = prlsdkUnregisterDomain(privconn->driver, dom, flags);
|
ret = prlsdkUnregisterDomain(privconn->driver, dom, flags);
|
||||||
if (ret)
|
|
||||||
virObjectUnlock(dom);
|
cleanup:
|
||||||
|
|
||||||
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1039,13 +1054,18 @@ vzDomainManagedSave(virDomainPtr domain, unsigned int flags)
|
|||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
int state, reason;
|
int state, reason;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_SAVE_RUNNING |
|
virCheckFlags(VIR_DOMAIN_SAVE_RUNNING |
|
||||||
VIR_DOMAIN_SAVE_PAUSED, -1);
|
VIR_DOMAIN_SAVE_PAUSED, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
state = virDomainObjGetState(dom, &reason);
|
state = virDomainObjGetState(dom, &reason);
|
||||||
|
|
||||||
if (state == VIR_DOMAIN_RUNNING && (flags & VIR_DOMAIN_SAVE_PAUSED)) {
|
if (state == VIR_DOMAIN_RUNNING && (flags & VIR_DOMAIN_SAVE_PAUSED)) {
|
||||||
@ -1057,7 +1077,9 @@ vzDomainManagedSave(virDomainPtr domain, unsigned int flags)
|
|||||||
ret = prlsdkDomainChangeStateLocked(privconn->driver, dom, prlsdkSuspend);
|
ret = prlsdkDomainChangeStateLocked(privconn->driver, dom, prlsdkSuspend);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1070,7 +1092,7 @@ vzDomainManagedSaveRemove(virDomainPtr domain, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
state = virDomainObjGetState(dom, &reason);
|
state = virDomainObjGetState(dom, &reason);
|
||||||
@ -1081,7 +1103,7 @@ vzDomainManagedSaveRemove(virDomainPtr domain, unsigned int flags)
|
|||||||
ret = prlsdkDomainManagedSaveRemove(dom);
|
ret = prlsdkDomainManagedSaveRemove(dom);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1115,11 +1137,12 @@ static int vzDomainAttachDeviceFlags(virDomainPtr domain, const char *xml,
|
|||||||
virDomainDeviceDefPtr dev = NULL;
|
virDomainDeviceDefPtr dev = NULL;
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
vzDriverPtr driver = privconn->driver;
|
vzDriverPtr driver = privconn->driver;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
||||||
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (vzCheckConfigUpdateFlags(dom, &flags) < 0)
|
if (vzCheckConfigUpdateFlags(dom, &flags) < 0)
|
||||||
@ -1130,13 +1153,19 @@ static int vzDomainAttachDeviceFlags(virDomainPtr domain, const char *xml,
|
|||||||
if (dev == NULL)
|
if (dev == NULL)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
if (prlsdkAttachDevice(driver, dom, dev) < 0)
|
if (prlsdkAttachDevice(driver, dom, dev) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainDeviceDefFree(dev);
|
virDomainDeviceDefFree(dev);
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1154,11 +1183,12 @@ static int vzDomainDetachDeviceFlags(virDomainPtr domain, const char *xml,
|
|||||||
virDomainDeviceDefPtr dev = NULL;
|
virDomainDeviceDefPtr dev = NULL;
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
vzDriverPtr driver = privconn->driver;
|
vzDriverPtr driver = privconn->driver;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
||||||
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
||||||
|
|
||||||
dom = vzDomObjFromDomain(domain);
|
dom = vzDomObjFromDomainRef(domain);
|
||||||
if (dom == NULL)
|
if (dom == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -1172,13 +1202,19 @@ static int vzDomainDetachDeviceFlags(virDomainPtr domain, const char *xml,
|
|||||||
if (dev == NULL)
|
if (dev == NULL)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
if (prlsdkDetachDevice(driver, dom, dev) < 0)
|
if (prlsdkDetachDevice(driver, dom, dev) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainDeviceDefFree(dev);
|
virDomainDeviceDefFree(dev);
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1197,14 +1233,22 @@ vzDomainSetUserPassword(virDomainPtr domain,
|
|||||||
{
|
{
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
ret = prlsdkDomainSetUserPassword(dom, user, password);
|
ret = prlsdkDomainSetUserPassword(dom, user, password);
|
||||||
|
|
||||||
virObjectUnlock(dom);
|
cleanup:
|
||||||
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1217,11 +1261,12 @@ static int vzDomainUpdateDeviceFlags(virDomainPtr domain,
|
|||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
virDomainDeviceDefPtr dev = NULL;
|
virDomainDeviceDefPtr dev = NULL;
|
||||||
vzDriverPtr driver = privconn->driver;
|
vzDriverPtr driver = privconn->driver;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
||||||
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (vzCheckConfigUpdateFlags(dom, &flags) < 0)
|
if (vzCheckConfigUpdateFlags(dom, &flags) < 0)
|
||||||
@ -1232,6 +1277,10 @@ static int vzDomainUpdateDeviceFlags(virDomainPtr domain,
|
|||||||
VIR_DOMAIN_XML_INACTIVE)))
|
VIR_DOMAIN_XML_INACTIVE)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
if (prlsdkUpdateDevice(driver, dom, dev) < 0)
|
if (prlsdkUpdateDevice(driver, dom, dev) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -1239,7 +1288,9 @@ static int vzDomainUpdateDeviceFlags(virDomainPtr domain,
|
|||||||
cleanup:
|
cleanup:
|
||||||
|
|
||||||
virDomainDeviceDefFree(dev);
|
virDomainDeviceDefFree(dev);
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1553,21 +1604,28 @@ static int vzDomainSetMemoryFlagsImpl(virDomainPtr domain, unsigned long memory,
|
|||||||
{
|
{
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
||||||
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
VIR_DOMAIN_AFFECT_CONFIG, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (useflags && vzCheckConfigUpdateFlags(dom, &flags) < 0)
|
if (useflags && vzCheckConfigUpdateFlags(dom, &flags) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
ret = prlsdkSetMemsize(dom, memory >> 10);
|
ret = prlsdkSetMemsize(dom, memory >> 10);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1634,7 +1692,7 @@ vzDomainSnapshotNum(virDomainPtr domain, unsigned int flags)
|
|||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_ROOTS |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_ROOTS |
|
||||||
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1644,7 +1702,7 @@ vzDomainSnapshotNum(virDomainPtr domain, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -1662,7 +1720,7 @@ vzDomainSnapshotListNames(virDomainPtr domain,
|
|||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_ROOTS |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_ROOTS |
|
||||||
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1672,7 +1730,7 @@ vzDomainSnapshotListNames(virDomainPtr domain,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -1689,7 +1747,7 @@ vzDomainListAllSnapshots(virDomainPtr domain,
|
|||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_ROOTS |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_ROOTS |
|
||||||
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1699,7 +1757,7 @@ vzDomainListAllSnapshots(virDomainPtr domain,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -1716,7 +1774,7 @@ vzDomainSnapshotGetXMLDesc(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_XML_SECURE, NULL);
|
virCheckFlags(VIR_DOMAIN_XML_SECURE, NULL);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1733,7 +1791,7 @@ vzDomainSnapshotGetXMLDesc(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return xml;
|
return xml;
|
||||||
}
|
}
|
||||||
@ -1749,7 +1807,7 @@ vzDomainSnapshotNumChildren(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_DESCENDANTS |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_DESCENDANTS |
|
||||||
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1762,7 +1820,7 @@ vzDomainSnapshotNumChildren(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -1781,7 +1839,7 @@ vzDomainSnapshotListChildrenNames(virDomainSnapshotPtr snapshot,
|
|||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_DESCENDANTS |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_DESCENDANTS |
|
||||||
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1794,7 +1852,7 @@ vzDomainSnapshotListChildrenNames(virDomainSnapshotPtr snapshot,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -1812,7 +1870,7 @@ vzDomainSnapshotListAllChildren(virDomainSnapshotPtr snapshot,
|
|||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_DESCENDANTS |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_LIST_DESCENDANTS |
|
||||||
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
VIR_DOMAIN_SNAPSHOT_FILTERS_ALL, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1825,7 +1883,7 @@ vzDomainSnapshotListAllChildren(virDomainSnapshotPtr snapshot,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -1842,7 +1900,7 @@ vzDomainSnapshotLookupByName(virDomainPtr domain,
|
|||||||
|
|
||||||
virCheckFlags(0, NULL);
|
virCheckFlags(0, NULL);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1854,7 +1912,7 @@ vzDomainSnapshotLookupByName(virDomainPtr domain,
|
|||||||
snapshot = virGetDomainSnapshot(domain, snap->def->name);
|
snapshot = virGetDomainSnapshot(domain, snap->def->name);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
|
|
||||||
return snapshot;
|
return snapshot;
|
||||||
@ -1869,7 +1927,7 @@ vzDomainHasCurrentSnapshot(virDomainPtr domain, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1879,7 +1937,7 @@ vzDomainHasCurrentSnapshot(virDomainPtr domain, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1894,7 +1952,7 @@ vzDomainSnapshotGetParent(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(0, NULL);
|
virCheckFlags(0, NULL);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1914,7 +1972,7 @@ vzDomainSnapshotGetParent(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return parent;
|
return parent;
|
||||||
}
|
}
|
||||||
@ -1929,7 +1987,7 @@ vzDomainSnapshotCurrent(virDomainPtr domain, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(0, NULL);
|
virCheckFlags(0, NULL);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1945,7 +2003,7 @@ vzDomainSnapshotCurrent(virDomainPtr domain, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return snapshot;
|
return snapshot;
|
||||||
}
|
}
|
||||||
@ -1960,7 +2018,7 @@ vzDomainSnapshotIsCurrent(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -1971,7 +2029,7 @@ vzDomainSnapshotIsCurrent(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1987,7 +2045,7 @@ vzDomainSnapshotHasMetadata(virDomainSnapshotPtr snapshot,
|
|||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
if (!(snapshots = prlsdkLoadSnapshots(dom)))
|
||||||
@ -2000,7 +2058,8 @@ vzDomainSnapshotHasMetadata(virDomainSnapshotPtr snapshot,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2017,10 +2076,11 @@ vzDomainSnapshotCreateXML(virDomainPtr domain,
|
|||||||
unsigned int parse_flags = VIR_DOMAIN_SNAPSHOT_PARSE_DISKS;
|
unsigned int parse_flags = VIR_DOMAIN_SNAPSHOT_PARSE_DISKS;
|
||||||
virDomainSnapshotObjListPtr snapshots = NULL;
|
virDomainSnapshotObjListPtr snapshots = NULL;
|
||||||
virDomainSnapshotObjPtr current;
|
virDomainSnapshotObjPtr current;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(0, NULL);
|
virCheckFlags(0, NULL);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!(def = virDomainSnapshotDefParseString(xmlDesc, driver->caps,
|
if (!(def = virDomainSnapshotDefParseString(xmlDesc, driver->caps,
|
||||||
@ -2039,6 +2099,10 @@ vzDomainSnapshotCreateXML(virDomainPtr domain,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
/* snaphot name is ignored, it will be set to auto generated by sdk uuid */
|
/* snaphot name is ignored, it will be set to auto generated by sdk uuid */
|
||||||
if (prlsdkCreateSnapshot(dom, def->description) < 0)
|
if (prlsdkCreateSnapshot(dom, def->description) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -2057,8 +2121,10 @@ vzDomainSnapshotCreateXML(virDomainPtr domain,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainSnapshotObjListFree(snapshots);
|
virDomainSnapshotObjListFree(snapshots);
|
||||||
virObjectUnlock(dom);
|
|
||||||
virDomainSnapshotDefFree(def);
|
virDomainSnapshotDefFree(def);
|
||||||
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return snapshot;
|
return snapshot;
|
||||||
}
|
}
|
||||||
@ -2071,13 +2137,13 @@ vzDomainSnapshotDelete(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_DELETE_CHILDREN, -1);
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_DELETE_CHILDREN, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomainRef(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
ret = prlsdkDeleteSnapshot(dom, snapshot->name,
|
ret = prlsdkDeleteSnapshot(dom, snapshot->name,
|
||||||
flags & VIR_DOMAIN_SNAPSHOT_DELETE_CHILDREN);
|
flags & VIR_DOMAIN_SNAPSHOT_DELETE_CHILDREN);
|
||||||
|
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -2087,16 +2153,23 @@ vzDomainRevertToSnapshot(virDomainSnapshotPtr snapshot, unsigned int flags)
|
|||||||
{
|
{
|
||||||
virDomainObjPtr dom;
|
virDomainObjPtr dom;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED, -1);
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED, -1);
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
if (!(dom = vzDomObjFromDomain(snapshot->domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
ret = prlsdkSwitchToSnapshot(dom, snapshot->name,
|
ret = prlsdkSwitchToSnapshot(dom, snapshot->name,
|
||||||
flags & VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED);
|
flags & VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED);
|
||||||
|
cleanup:
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -2431,6 +2504,7 @@ vzDomainMigratePerformStep(virDomainPtr domain,
|
|||||||
const char *miguri = NULL;
|
const char *miguri = NULL;
|
||||||
const char *dname = NULL;
|
const char *dname = NULL;
|
||||||
vzMigrationCookiePtr mig = NULL;
|
vzMigrationCookiePtr mig = NULL;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
virCheckFlags(VZ_MIGRATION_FLAGS, -1);
|
virCheckFlags(VZ_MIGRATION_FLAGS, -1);
|
||||||
|
|
||||||
@ -2453,9 +2527,13 @@ vzDomainMigratePerformStep(virDomainPtr domain,
|
|||||||
VZ_MIGRATION_COOKIE_SESSION_UUID)))
|
VZ_MIGRATION_COOKIE_SESSION_UUID)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
if (!(vzuri = vzParseVzURI(miguri)))
|
if (!(vzuri = vzParseVzURI(miguri)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -2463,13 +2541,14 @@ vzDomainMigratePerformStep(virDomainPtr domain,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
virDomainObjListRemove(privconn->driver->domains, dom);
|
virDomainObjListRemove(privconn->driver->domains, dom);
|
||||||
dom = NULL;
|
virObjectLock(dom);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (dom)
|
if (job)
|
||||||
virObjectUnlock(dom);
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
virURIFree(vzuri);
|
virURIFree(vzuri);
|
||||||
vzMigrationCookieFree(mig);
|
vzMigrationCookieFree(mig);
|
||||||
|
|
||||||
@ -2635,8 +2714,7 @@ vzDomainMigrateFinish3Params(virConnectPtr dconn,
|
|||||||
* is already finished. */
|
* is already finished. */
|
||||||
if (!domain)
|
if (!domain)
|
||||||
VIR_WARN("Can't provide domain '%s' after successfull migration.", name);
|
VIR_WARN("Can't provide domain '%s' after successfull migration.", name);
|
||||||
if (dom)
|
virDomainObjEndAPI(&dom);
|
||||||
virObjectUnlock(dom);
|
|
||||||
return domain;
|
return domain;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
180
src/vz/vz_sdk.c
180
src/vz/vz_sdk.c
@ -197,6 +197,27 @@ getJobResultHelper(PRL_HANDLE job, unsigned int timeout, PRL_HANDLE *result,
|
|||||||
getJobResultHelper(job, JOB_INFINIT_WAIT_TIMEOUT, \
|
getJobResultHelper(job, JOB_INFINIT_WAIT_TIMEOUT, \
|
||||||
result, __FILE__, __FUNCTION__, __LINE__)
|
result, __FILE__, __FUNCTION__, __LINE__)
|
||||||
|
|
||||||
|
static PRL_RESULT
|
||||||
|
getDomainJobResultHelper(PRL_HANDLE job, virDomainObjPtr dom,
|
||||||
|
unsigned int timeout, PRL_HANDLE *result,
|
||||||
|
const char *filename, const char *funcname,
|
||||||
|
size_t linenr)
|
||||||
|
{
|
||||||
|
PRL_RESULT pret;
|
||||||
|
|
||||||
|
if (dom)
|
||||||
|
virObjectUnlock(dom);
|
||||||
|
pret = getJobResultHelper(job, timeout, result, filename, funcname, linenr);
|
||||||
|
if (dom)
|
||||||
|
virObjectLock(dom);
|
||||||
|
|
||||||
|
return pret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define getDomainJobResult(job, dom, result) \
|
||||||
|
getDomainJobResultHelper(job, dom, JOB_INFINIT_WAIT_TIMEOUT, \
|
||||||
|
result, __FILE__, __FUNCTION__, __LINE__)
|
||||||
|
|
||||||
static PRL_RESULT
|
static PRL_RESULT
|
||||||
waitJobHelper(PRL_HANDLE job, unsigned int timeout,
|
waitJobHelper(PRL_HANDLE job, unsigned int timeout,
|
||||||
const char *filename, const char *funcname,
|
const char *filename, const char *funcname,
|
||||||
@ -215,6 +236,26 @@ waitJobHelper(PRL_HANDLE job, unsigned int timeout,
|
|||||||
waitJobHelper(job, JOB_INFINIT_WAIT_TIMEOUT, __FILE__, \
|
waitJobHelper(job, JOB_INFINIT_WAIT_TIMEOUT, __FILE__, \
|
||||||
__FUNCTION__, __LINE__)
|
__FUNCTION__, __LINE__)
|
||||||
|
|
||||||
|
static PRL_RESULT
|
||||||
|
waitDomainJobHelper(PRL_HANDLE job, virDomainObjPtr dom, unsigned int timeout,
|
||||||
|
const char *filename, const char *funcname,
|
||||||
|
size_t linenr)
|
||||||
|
{
|
||||||
|
PRL_RESULT ret;
|
||||||
|
|
||||||
|
if (dom)
|
||||||
|
virObjectUnlock(dom);
|
||||||
|
ret = waitJobHelper(job, timeout, filename, funcname, linenr);
|
||||||
|
if (dom)
|
||||||
|
virObjectLock(dom);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define waitDomainJob(job, dom) \
|
||||||
|
waitDomainJobHelper(job, dom, JOB_INFINIT_WAIT_TIMEOUT, __FILE__, \
|
||||||
|
__FUNCTION__, __LINE__)
|
||||||
|
|
||||||
typedef PRL_RESULT (*prlsdkParamGetterType)(PRL_HANDLE, char*, PRL_UINT32*);
|
typedef PRL_RESULT (*prlsdkParamGetterType)(PRL_HANDLE, char*, PRL_UINT32*);
|
||||||
|
|
||||||
static char*
|
static char*
|
||||||
@ -418,7 +459,7 @@ prlsdkUUIDParse(const char *uuidstr, unsigned char *uuid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
prlsdkGetDomainState(PRL_HANDLE sdkdom, VIRTUAL_MACHINE_STATE_PTR vmState)
|
prlsdkGetDomainState(virDomainObjPtr dom, PRL_HANDLE sdkdom, VIRTUAL_MACHINE_STATE_PTR vmState)
|
||||||
{
|
{
|
||||||
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
||||||
PRL_HANDLE result = PRL_INVALID_HANDLE;
|
PRL_HANDLE result = PRL_INVALID_HANDLE;
|
||||||
@ -428,7 +469,7 @@ prlsdkGetDomainState(PRL_HANDLE sdkdom, VIRTUAL_MACHINE_STATE_PTR vmState)
|
|||||||
|
|
||||||
job = PrlVm_GetState(sdkdom);
|
job = PrlVm_GetState(sdkdom);
|
||||||
|
|
||||||
if (PRL_FAILED(getJobResult(job, &result)))
|
if (PRL_FAILED(getDomainJobResult(job, dom, &result)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
pret = PrlResult_GetParamByIndex(result, 0, &vmInfo);
|
pret = PrlResult_GetParamByIndex(result, 0, &vmInfo);
|
||||||
@ -1691,7 +1732,7 @@ prlsdkConvertBootOrder(PRL_HANDLE sdkdom, virDomainDefPtr def)
|
|||||||
/* if dom is NULL adds new domain into domain list
|
/* if dom is NULL adds new domain into domain list
|
||||||
* if dom not NULL updates given locked dom object.
|
* if dom not NULL updates given locked dom object.
|
||||||
*
|
*
|
||||||
* Returned object is locked.
|
* Returned object is locked and referenced.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static virDomainObjPtr
|
static virDomainObjPtr
|
||||||
@ -1771,7 +1812,7 @@ prlsdkLoadDomain(vzDriverPtr driver,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prlsdkGetDomainState(sdkdom, &domainState) < 0)
|
if (prlsdkGetDomainState(dom, sdkdom, &domainState) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (virDomainDefAddImplicitDevices(def) < 0)
|
if (virDomainDefAddImplicitDevices(def) < 0)
|
||||||
@ -1800,7 +1841,7 @@ prlsdkLoadDomain(vzDriverPtr driver,
|
|||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
virObjectLock(driver);
|
virObjectLock(driver);
|
||||||
if (!(olddom = virDomainObjListFindByUUID(driver->domains, def->uuid)))
|
if (!(olddom = virDomainObjListFindByUUIDRef(driver->domains, def->uuid)))
|
||||||
dom = virDomainObjListAdd(driver->domains, def, driver->xmlopt, 0, NULL);
|
dom = virDomainObjListAdd(driver->domains, def, driver->xmlopt, 0, NULL);
|
||||||
virObjectUnlock(driver);
|
virObjectUnlock(driver);
|
||||||
|
|
||||||
@ -1811,6 +1852,7 @@ prlsdkLoadDomain(vzDriverPtr driver,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virObjectRef(dom);
|
||||||
pdom = dom->privateData;
|
pdom = dom->privateData;
|
||||||
pdom->sdkdom = sdkdom;
|
pdom->sdkdom = sdkdom;
|
||||||
PrlHandle_AddRef(sdkdom);
|
PrlHandle_AddRef(sdkdom);
|
||||||
@ -1863,8 +1905,8 @@ prlsdkLoadDomains(vzDriverPtr driver)
|
|||||||
pret = PrlResult_GetParamByIndex(result, i, &sdkdom);
|
pret = PrlResult_GetParamByIndex(result, i, &sdkdom);
|
||||||
prlsdkCheckRetGoto(pret, error);
|
prlsdkCheckRetGoto(pret, error);
|
||||||
|
|
||||||
if ((dom = prlsdkLoadDomain(driver, sdkdom, NULL)))
|
dom = prlsdkLoadDomain(driver, sdkdom, NULL);
|
||||||
virObjectUnlock(dom);
|
virDomainObjEndAPI(&dom);
|
||||||
|
|
||||||
PrlHandle_Free(sdkdom);
|
PrlHandle_Free(sdkdom);
|
||||||
sdkdom = PRL_INVALID_HANDLE;
|
sdkdom = PRL_INVALID_HANDLE;
|
||||||
@ -1918,7 +1960,7 @@ prlsdkUpdateDomain(vzDriverPtr driver, virDomainObjPtr dom)
|
|||||||
vzDomObjPtr pdom = dom->privateData;
|
vzDomObjPtr pdom = dom->privateData;
|
||||||
|
|
||||||
job = PrlVm_RefreshConfig(pdom->sdkdom);
|
job = PrlVm_RefreshConfig(pdom->sdkdom);
|
||||||
if (waitJob(job))
|
if (waitDomainJob(job, dom))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return prlsdkLoadDomain(driver, pdom->sdkdom, dom) ? 0 : -1;
|
return prlsdkLoadDomain(driver, pdom->sdkdom, dom) ? 0 : -1;
|
||||||
@ -2015,11 +2057,16 @@ prlsdkHandleVmConfigEvent(vzDriverPtr driver,
|
|||||||
unsigned char *uuid)
|
unsigned char *uuid)
|
||||||
{
|
{
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
dom = virDomainObjListFindByUUID(driver->domains, uuid);
|
dom = virDomainObjListFindByUUIDRef(driver->domains, uuid);
|
||||||
if (dom == NULL)
|
if (dom == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
if (prlsdkUpdateDomain(driver, dom) < 0)
|
if (prlsdkUpdateDomain(driver, dom) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -2027,7 +2074,9 @@ prlsdkHandleVmConfigEvent(vzDriverPtr driver,
|
|||||||
VIR_DOMAIN_EVENT_DEFINED_UPDATED);
|
VIR_DOMAIN_EVENT_DEFINED_UPDATED);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virObjectUnlock(dom);
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2037,7 +2086,7 @@ prlsdkHandleVmAddedEvent(vzDriverPtr driver,
|
|||||||
{
|
{
|
||||||
virDomainObjPtr dom = NULL;
|
virDomainObjPtr dom = NULL;
|
||||||
|
|
||||||
if (!(dom = virDomainObjListFindByUUID(driver->domains, uuid)) &&
|
if (!(dom = virDomainObjListFindByUUIDRef(driver->domains, uuid)) &&
|
||||||
!(dom = prlsdkAddDomainByUUID(driver, uuid)))
|
!(dom = prlsdkAddDomainByUUID(driver, uuid)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -2045,8 +2094,7 @@ prlsdkHandleVmAddedEvent(vzDriverPtr driver,
|
|||||||
VIR_DOMAIN_EVENT_DEFINED_ADDED);
|
VIR_DOMAIN_EVENT_DEFINED_ADDED);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (dom)
|
virDomainObjEndAPI(&dom);
|
||||||
virObjectUnlock(dom);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2245,7 +2293,9 @@ prlsdkDomainChangeStateLocked(vzDriverPtr driver,
|
|||||||
virErrorNumber virerr;
|
virErrorNumber virerr;
|
||||||
|
|
||||||
pdom = dom->privateData;
|
pdom = dom->privateData;
|
||||||
|
virObjectUnlock(dom);
|
||||||
pret = chstate(pdom->sdkdom);
|
pret = chstate(pdom->sdkdom);
|
||||||
|
virObjectLock(dom);
|
||||||
if (PRL_FAILED(pret)) {
|
if (PRL_FAILED(pret)) {
|
||||||
virResetLastError();
|
virResetLastError();
|
||||||
|
|
||||||
@ -2274,12 +2324,21 @@ prlsdkDomainChangeState(virDomainPtr domain,
|
|||||||
vzConnPtr privconn = domain->conn->privateData;
|
vzConnPtr privconn = domain->conn->privateData;
|
||||||
virDomainObjPtr dom;
|
virDomainObjPtr dom;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
bool job = false;
|
||||||
|
|
||||||
if (!(dom = vzDomObjFromDomain(domain)))
|
if (!(dom = vzDomObjFromDomainRef(domain)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (vzDomainObjBeginJob(dom) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
job = true;
|
||||||
|
|
||||||
ret = prlsdkDomainChangeStateLocked(privconn->driver, dom, chstate);
|
ret = prlsdkDomainChangeStateLocked(privconn->driver, dom, chstate);
|
||||||
virObjectUnlock(dom);
|
|
||||||
|
cleanup:
|
||||||
|
if (job)
|
||||||
|
vzDomainObjEndJob(dom);
|
||||||
|
virDomainObjEndAPI(&dom);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3076,6 +3135,7 @@ static int prlsdkConfigureGateways(PRL_HANDLE sdknet, virDomainNetDefPtr net)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int prlsdkConfigureNet(vzDriverPtr driver,
|
static int prlsdkConfigureNet(vzDriverPtr driver,
|
||||||
|
virDomainObjPtr dom,
|
||||||
PRL_HANDLE sdkdom,
|
PRL_HANDLE sdkdom,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
bool isCt, bool create)
|
bool isCt, bool create)
|
||||||
@ -3215,7 +3275,7 @@ static int prlsdkConfigureNet(vzDriverPtr driver,
|
|||||||
job = PrlSrv_AddVirtualNetwork(driver->server,
|
job = PrlSrv_AddVirtualNetwork(driver->server,
|
||||||
vnet,
|
vnet,
|
||||||
PRL_USE_VNET_NAME_FOR_BRIDGE_NAME);
|
PRL_USE_VNET_NAME_FOR_BRIDGE_NAME);
|
||||||
if (PRL_FAILED(pret = waitJob(job)))
|
if (PRL_FAILED(pret = waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
pret = PrlVmDev_SetEmulatedType(sdknet, PNA_BRIDGED_ETHERNET);
|
pret = PrlVmDev_SetEmulatedType(sdknet, PNA_BRIDGED_ETHERNET);
|
||||||
@ -3239,7 +3299,9 @@ static int prlsdkConfigureNet(vzDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
prlsdkCleanupBridgedNet(vzDriverPtr driver, virDomainNetDefPtr net)
|
prlsdkCleanupBridgedNet(vzDriverPtr driver,
|
||||||
|
virDomainObjPtr dom,
|
||||||
|
virDomainNetDefPtr net)
|
||||||
{
|
{
|
||||||
PRL_RESULT pret;
|
PRL_RESULT pret;
|
||||||
PRL_HANDLE vnet = PRL_INVALID_HANDLE;
|
PRL_HANDLE vnet = PRL_INVALID_HANDLE;
|
||||||
@ -3255,8 +3317,7 @@ prlsdkCleanupBridgedNet(vzDriverPtr driver, virDomainNetDefPtr net)
|
|||||||
prlsdkCheckRetGoto(pret, cleanup);
|
prlsdkCheckRetGoto(pret, cleanup);
|
||||||
|
|
||||||
job = PrlSrv_DeleteVirtualNetwork(driver->server, vnet, 0);
|
job = PrlSrv_DeleteVirtualNetwork(driver->server, vnet, 0);
|
||||||
if (PRL_FAILED(pret = waitJob(job)))
|
ignore_value(waitDomainJob(job, dom));
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
PrlHandle_Free(vnet);
|
PrlHandle_Free(vnet);
|
||||||
@ -3449,7 +3510,7 @@ prlsdkAttachDevice(vzDriverPtr driver,
|
|||||||
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(privdom->sdkdom);
|
job = PrlVm_BeginEdit(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
switch (dev->type) {
|
switch (dev->type) {
|
||||||
@ -3466,7 +3527,7 @@ prlsdkAttachDevice(vzDriverPtr driver,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prlsdkConfigureNet(driver, privdom->sdkdom, dev->data.net,
|
if (prlsdkConfigureNet(driver, dom, privdom->sdkdom, dev->data.net,
|
||||||
IS_CT(dom->def), true) < 0)
|
IS_CT(dom->def), true) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -3490,7 +3551,7 @@ prlsdkAttachDevice(vzDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -3508,7 +3569,7 @@ prlsdkDetachDevice(vzDriverPtr driver,
|
|||||||
PRL_RESULT pret;
|
PRL_RESULT pret;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(privdom->sdkdom);
|
job = PrlVm_BeginEdit(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
switch (dev->type) {
|
switch (dev->type) {
|
||||||
@ -3532,7 +3593,7 @@ prlsdkDetachDevice(vzDriverPtr driver,
|
|||||||
if (sdkdev == PRL_INVALID_HANDLE)
|
if (sdkdev == PRL_INVALID_HANDLE)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
prlsdkCleanupBridgedNet(driver, dev->data.net);
|
prlsdkCleanupBridgedNet(driver, dom, dev->data.net);
|
||||||
|
|
||||||
pret = PrlVmDev_Remove(sdkdev);
|
pret = PrlVmDev_Remove(sdkdev);
|
||||||
prlsdkCheckRetGoto(pret, cleanup);
|
prlsdkCheckRetGoto(pret, cleanup);
|
||||||
@ -3557,7 +3618,7 @@ prlsdkDetachDevice(vzDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
@ -3577,7 +3638,7 @@ prlsdkUpdateDevice(vzDriverPtr driver,
|
|||||||
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(privdom->sdkdom);
|
job = PrlVm_BeginEdit(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
switch (dev->type) {
|
switch (dev->type) {
|
||||||
@ -3588,7 +3649,7 @@ prlsdkUpdateDevice(vzDriverPtr driver,
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
case VIR_DOMAIN_DEVICE_NET:
|
case VIR_DOMAIN_DEVICE_NET:
|
||||||
if (prlsdkConfigureNet(driver, privdom->sdkdom, dev->data.net,
|
if (prlsdkConfigureNet(driver, dom, privdom->sdkdom, dev->data.net,
|
||||||
IS_CT(dom->def), false) < 0)
|
IS_CT(dom->def), false) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -3612,7 +3673,7 @@ prlsdkUpdateDevice(vzDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -3754,7 +3815,7 @@ prlsdkDomainSetUserPassword(virDomainObjPtr dom,
|
|||||||
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
PRL_HANDLE job = PRL_INVALID_HANDLE;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(privdom->sdkdom);
|
job = PrlVm_BeginEdit(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
job = PrlVm_SetUserPasswd(privdom->sdkdom,
|
job = PrlVm_SetUserPasswd(privdom->sdkdom,
|
||||||
@ -3762,11 +3823,11 @@ prlsdkDomainSetUserPassword(virDomainObjPtr dom,
|
|||||||
password,
|
password,
|
||||||
0);
|
0);
|
||||||
|
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
job = PrlVm_CommitEx(privdom->sdkdom, 0);
|
job = PrlVm_CommitEx(privdom->sdkdom, 0);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
@ -3777,9 +3838,9 @@ prlsdkDomainSetUserPassword(virDomainObjPtr dom,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
prlsdkDoApplyConfig(vzDriverPtr driver,
|
prlsdkDoApplyConfig(vzDriverPtr driver,
|
||||||
|
virDomainObjPtr dom,
|
||||||
PRL_HANDLE sdkdom,
|
PRL_HANDLE sdkdom,
|
||||||
virDomainDefPtr def,
|
virDomainDefPtr def)
|
||||||
virDomainDefPtr olddef)
|
|
||||||
{
|
{
|
||||||
PRL_RESULT pret;
|
PRL_RESULT pret;
|
||||||
size_t i;
|
size_t i;
|
||||||
@ -3840,13 +3901,13 @@ prlsdkDoApplyConfig(vzDriverPtr driver,
|
|||||||
if (prlsdkRemoveBootDevices(sdkdom) < 0)
|
if (prlsdkRemoveBootDevices(sdkdom) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (olddef) {
|
if (dom) {
|
||||||
for (i = 0; i < olddef->nnets; i++)
|
for (i = 0; i < dom->def->nnets; i++)
|
||||||
prlsdkCleanupBridgedNet(driver, olddef->nets[i]);
|
prlsdkCleanupBridgedNet(driver, dom, dom->def->nets[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < def->nnets; i++) {
|
for (i = 0; i < def->nnets; i++) {
|
||||||
if (prlsdkConfigureNet(driver, sdkdom, def->nets[i],
|
if (prlsdkConfigureNet(driver, dom, sdkdom, def->nets[i],
|
||||||
IS_CT(def), true) < 0)
|
IS_CT(def), true) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
@ -3894,7 +3955,7 @@ prlsdkDoApplyConfig(vzDriverPtr driver,
|
|||||||
VIR_FREE(mask);
|
VIR_FREE(mask);
|
||||||
|
|
||||||
for (i = 0; i < def->nnets; i++)
|
for (i = 0; i < def->nnets; i++)
|
||||||
prlsdkCleanupBridgedNet(driver, def->nets[i]);
|
prlsdkCleanupBridgedNet(driver, dom, def->nets[i]);
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -3909,14 +3970,14 @@ prlsdkApplyConfig(vzDriverPtr driver,
|
|||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(privdom->sdkdom);
|
job = PrlVm_BeginEdit(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
ret = prlsdkDoApplyConfig(driver, privdom->sdkdom, new, dom->def);
|
ret = prlsdkDoApplyConfig(driver, dom, privdom->sdkdom, new);
|
||||||
|
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
job = PrlVm_CommitEx(privdom->sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3949,7 +4010,7 @@ prlsdkCreateVm(vzDriverPtr driver, virDomainDefPtr def)
|
|||||||
pret = PrlVmCfg_SetOfflineManagementEnabled(sdkdom, 0);
|
pret = PrlVmCfg_SetOfflineManagementEnabled(sdkdom, 0);
|
||||||
prlsdkCheckRetGoto(pret, cleanup);
|
prlsdkCheckRetGoto(pret, cleanup);
|
||||||
|
|
||||||
if (prlsdkDoApplyConfig(driver, sdkdom, def, NULL) < 0)
|
if (prlsdkDoApplyConfig(driver, NULL, sdkdom, def) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
job = PrlVm_Reg(sdkdom, "", 1);
|
job = PrlVm_Reg(sdkdom, "", 1);
|
||||||
@ -4063,7 +4124,7 @@ prlsdkCreateCt(virConnectPtr conn, virDomainDefPtr def)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prlsdkDoApplyConfig(driver, sdkdom, def, NULL) < 0)
|
if (prlsdkDoApplyConfig(driver, NULL, sdkdom, def) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
flags = PACF_NON_INTERACTIVE_MODE;
|
flags = PACF_NON_INTERACTIVE_MODE;
|
||||||
@ -4089,7 +4150,7 @@ prlsdkCreateCt(virConnectPtr conn, virDomainDefPtr def)
|
|||||||
* Returns 0 if hard disks were successfully detached or not detected.
|
* Returns 0 if hard disks were successfully detached or not detected.
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
prlsdkDetachDomainHardDisks(PRL_HANDLE sdkdom)
|
prlsdkDetachDomainHardDisks(virDomainObjPtr dom)
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
PRL_RESULT pret;
|
PRL_RESULT pret;
|
||||||
@ -4097,9 +4158,11 @@ prlsdkDetachDomainHardDisks(PRL_HANDLE sdkdom)
|
|||||||
PRL_UINT32 i;
|
PRL_UINT32 i;
|
||||||
PRL_HANDLE job;
|
PRL_HANDLE job;
|
||||||
PRL_HANDLE sdkdisk = PRL_INVALID_HANDLE;
|
PRL_HANDLE sdkdisk = PRL_INVALID_HANDLE;
|
||||||
|
vzDomObjPtr pdom = dom->privateData;
|
||||||
|
PRL_HANDLE sdkdom = pdom->sdkdom;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(sdkdom);
|
job = PrlVm_BeginEdit(sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
pret = PrlVmCfg_GetHardDisksCount(sdkdom, &hddCount);
|
pret = PrlVmCfg_GetHardDisksCount(sdkdom, &hddCount);
|
||||||
@ -4117,7 +4180,7 @@ prlsdkDetachDomainHardDisks(PRL_HANDLE sdkdom)
|
|||||||
}
|
}
|
||||||
|
|
||||||
job = PrlVm_CommitEx(sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
job = PrlVm_CommitEx(sdkdom, PVCF_DETACH_HDD_BUNDLE);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
@ -4138,7 +4201,7 @@ prlsdkUnregisterDomain(vzDriverPtr driver, virDomainObjPtr dom, unsigned int fla
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
int num;
|
int num;
|
||||||
|
|
||||||
if (prlsdkGetDomainState(privdom->sdkdom, &domainState) < 0)
|
if (prlsdkGetDomainState(dom, privdom->sdkdom, &domainState) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (VMS_SUSPENDED == domainState &&
|
if (VMS_SUSPENDED == domainState &&
|
||||||
@ -4162,20 +4225,21 @@ prlsdkUnregisterDomain(vzDriverPtr driver, virDomainObjPtr dom, unsigned int fla
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prlsdkDetachDomainHardDisks(privdom->sdkdom))
|
if (prlsdkDetachDomainHardDisks(dom))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
job = PrlVm_Delete(privdom->sdkdom, PRL_INVALID_HANDLE);
|
job = PrlVm_Delete(privdom->sdkdom, PRL_INVALID_HANDLE);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
for (i = 0; i < dom->def->nnets; i++)
|
for (i = 0; i < dom->def->nnets; i++)
|
||||||
prlsdkCleanupBridgedNet(driver, dom->def->nets[i]);
|
prlsdkCleanupBridgedNet(driver, dom, dom->def->nets[i]);
|
||||||
|
|
||||||
prlsdkSendEvent(driver, dom, VIR_DOMAIN_EVENT_UNDEFINED,
|
prlsdkSendEvent(driver, dom, VIR_DOMAIN_EVENT_UNDEFINED,
|
||||||
VIR_DOMAIN_EVENT_UNDEFINED_REMOVED);
|
VIR_DOMAIN_EVENT_UNDEFINED_REMOVED);
|
||||||
|
|
||||||
virDomainObjListRemove(driver->domains, dom);
|
virDomainObjListRemove(driver->domains, dom);
|
||||||
|
virObjectLock(dom);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
cleanup:
|
cleanup:
|
||||||
@ -4191,7 +4255,7 @@ prlsdkDomainManagedSaveRemove(virDomainObjPtr dom)
|
|||||||
PRL_HANDLE job;
|
PRL_HANDLE job;
|
||||||
|
|
||||||
job = PrlVm_DropSuspendedState(privdom->sdkdom);
|
job = PrlVm_DropSuspendedState(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -4449,14 +4513,14 @@ int prlsdkSetMemsize(virDomainObjPtr dom, unsigned int memsize)
|
|||||||
PRL_RESULT pret;
|
PRL_RESULT pret;
|
||||||
|
|
||||||
job = PrlVm_BeginEdit(privdom->sdkdom);
|
job = PrlVm_BeginEdit(privdom->sdkdom);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
pret = PrlVmCfg_SetRamSize(privdom->sdkdom, memsize);
|
pret = PrlVmCfg_SetRamSize(privdom->sdkdom, memsize);
|
||||||
prlsdkCheckRetGoto(pret, error);
|
prlsdkCheckRetGoto(pret, error);
|
||||||
|
|
||||||
job = PrlVm_CommitEx(privdom->sdkdom, 0);
|
job = PrlVm_CommitEx(privdom->sdkdom, 0);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -4626,7 +4690,7 @@ prlsdkLoadSnapshots(virDomainObjPtr dom)
|
|||||||
char *treexml = NULL;
|
char *treexml = NULL;
|
||||||
|
|
||||||
job = PrlVm_GetSnapshotsTreeEx(privdom->sdkdom, PGST_WITHOUT_SCREENSHOTS);
|
job = PrlVm_GetSnapshotsTreeEx(privdom->sdkdom, PGST_WITHOUT_SCREENSHOTS);
|
||||||
if (PRL_FAILED(getJobResult(job, &result)))
|
if (PRL_FAILED(getDomainJobResult(job, dom, &result)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(treexml = prlsdkGetStringParamVar(PrlResult_GetParamAsString, result)))
|
if (!(treexml = prlsdkGetStringParamVar(PrlResult_GetParamAsString, result)))
|
||||||
@ -4647,7 +4711,7 @@ int prlsdkCreateSnapshot(virDomainObjPtr dom, const char *description)
|
|||||||
|
|
||||||
job = PrlVm_CreateSnapshot(privdom->sdkdom, "",
|
job = PrlVm_CreateSnapshot(privdom->sdkdom, "",
|
||||||
description ? : "");
|
description ? : "");
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -4659,7 +4723,7 @@ int prlsdkDeleteSnapshot(virDomainObjPtr dom, const char *uuid, bool children)
|
|||||||
PRL_HANDLE job;
|
PRL_HANDLE job;
|
||||||
|
|
||||||
job = PrlVm_DeleteSnapshot(privdom->sdkdom, uuid, children);
|
job = PrlVm_DeleteSnapshot(privdom->sdkdom, uuid, children);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -4675,7 +4739,7 @@ int prlsdkSwitchToSnapshot(virDomainObjPtr dom, const char *uuid, bool paused)
|
|||||||
flags |= PSSF_SKIP_RESUME;
|
flags |= PSSF_SKIP_RESUME;
|
||||||
|
|
||||||
job = PrlVm_SwitchToSnapshotEx(privdom->sdkdom, uuid, flags);
|
job = PrlVm_SwitchToSnapshotEx(privdom->sdkdom, uuid, flags);
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -4714,7 +4778,7 @@ int prlsdkMigrate(virDomainObjPtr dom, virURIPtr uri,
|
|||||||
PRL_TRUE
|
PRL_TRUE
|
||||||
);
|
);
|
||||||
|
|
||||||
if (PRL_FAILED(waitJob(job)))
|
if (PRL_FAILED(waitDomainJob(job, dom)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include "virstring.h"
|
#include "virstring.h"
|
||||||
#include "datatypes.h"
|
#include "datatypes.h"
|
||||||
#include "virlog.h"
|
#include "virlog.h"
|
||||||
|
#include "virtime.h"
|
||||||
|
|
||||||
#define VIR_FROM_THIS VIR_FROM_PARALLELS
|
#define VIR_FROM_THIS VIR_FROM_PARALLELS
|
||||||
#define PRLSRVCTL "prlsrvctl"
|
#define PRLSRVCTL "prlsrvctl"
|
||||||
@ -587,9 +588,17 @@ vzDomObjAlloc(void)
|
|||||||
if (VIR_ALLOC(pdom) < 0)
|
if (VIR_ALLOC(pdom) < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
if (virCondInit(&pdom->jobCond) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
pdom->stats = PRL_INVALID_HANDLE;
|
pdom->stats = PRL_INVALID_HANDLE;
|
||||||
|
|
||||||
return pdom;
|
return pdom;
|
||||||
|
|
||||||
|
error:
|
||||||
|
VIR_FREE(pdom);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -602,5 +611,46 @@ vzDomObjFree(void* p)
|
|||||||
|
|
||||||
PrlHandle_Free(pdom->sdkdom);
|
PrlHandle_Free(pdom->sdkdom);
|
||||||
PrlHandle_Free(pdom->stats);
|
PrlHandle_Free(pdom->stats);
|
||||||
|
virCondDestroy(&pdom->jobCond);
|
||||||
VIR_FREE(pdom);
|
VIR_FREE(pdom);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define VZ_JOB_WAIT_TIME (1000 * 30)
|
||||||
|
|
||||||
|
int
|
||||||
|
vzDomainObjBeginJob(virDomainObjPtr dom)
|
||||||
|
{
|
||||||
|
vzDomObjPtr pdom = dom->privateData;
|
||||||
|
unsigned long long now;
|
||||||
|
unsigned long long then;
|
||||||
|
|
||||||
|
if (virTimeMillisNow(&now) < 0)
|
||||||
|
return -1;
|
||||||
|
then = now + VZ_JOB_WAIT_TIME;
|
||||||
|
|
||||||
|
while (pdom->job) {
|
||||||
|
if (virCondWaitUntil(&pdom->jobCond, &dom->parent.lock, then) < 0)
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
pdom->job = true;
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
error:
|
||||||
|
if (errno == ETIMEDOUT)
|
||||||
|
virReportError(VIR_ERR_OPERATION_TIMEOUT,
|
||||||
|
"%s", _("cannot acquire state change lock"));
|
||||||
|
else
|
||||||
|
virReportSystemError(errno,
|
||||||
|
"%s", _("cannot acquire job mutex"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
vzDomainObjEndJob(virDomainObjPtr dom)
|
||||||
|
{
|
||||||
|
vzDomObjPtr pdom = dom->privateData;
|
||||||
|
|
||||||
|
pdom->job = false;
|
||||||
|
virCondSignal(&pdom->jobCond);
|
||||||
|
}
|
||||||
|
@ -98,6 +98,8 @@ struct vzDomObj {
|
|||||||
int id;
|
int id;
|
||||||
PRL_HANDLE sdkdom;
|
PRL_HANDLE sdkdom;
|
||||||
PRL_HANDLE stats;
|
PRL_HANDLE stats;
|
||||||
|
bool job;
|
||||||
|
virCond jobCond;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct vzDomObj *vzDomObjPtr;
|
typedef struct vzDomObj *vzDomObjPtr;
|
||||||
@ -139,3 +141,8 @@ int vzCheckUnsupportedGraphics(virDomainGraphicsDefPtr gr);
|
|||||||
OP(wr_bytes, VIR_DOMAIN_BLOCK_STATS_WRITE_BYTES, "write_total")
|
OP(wr_bytes, VIR_DOMAIN_BLOCK_STATS_WRITE_BYTES, "write_total")
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
int
|
||||||
|
vzDomainObjBeginJob(virDomainObjPtr dom);
|
||||||
|
void
|
||||||
|
vzDomainObjEndJob(virDomainObjPtr dom);
|
||||||
|
Loading…
Reference in New Issue
Block a user