mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-08 22:15:21 +00:00
qemu: Consolidate {Enter,Exit}Monitor{,WithDriver}
EnterMonitor and ExitMonitor methods are very similar to their *WithDriver variants; consolidate them into EnterMonitorInternal and ExitMonitorInternal to avoid (mainly future) code duplication.
This commit is contained in:
parent
cec1d280ad
commit
24f717ac22
@ -622,6 +622,43 @@ int qemuDomainObjEndJob(virDomainObjPtr obj)
|
|||||||
return virDomainObjUnref(obj);
|
return virDomainObjUnref(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
qemuDomainObjEnterMonitorInternal(struct qemud_driver *driver,
|
||||||
|
virDomainObjPtr obj)
|
||||||
|
{
|
||||||
|
qemuDomainObjPrivatePtr priv = obj->privateData;
|
||||||
|
|
||||||
|
qemuMonitorLock(priv->mon);
|
||||||
|
qemuMonitorRef(priv->mon);
|
||||||
|
ignore_value(virTimeMs(&priv->monStart));
|
||||||
|
virDomainObjUnlock(obj);
|
||||||
|
if (driver)
|
||||||
|
qemuDriverUnlock(driver);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
qemuDomainObjExitMonitorInternal(struct qemud_driver *driver,
|
||||||
|
virDomainObjPtr obj)
|
||||||
|
{
|
||||||
|
qemuDomainObjPrivatePtr priv = obj->privateData;
|
||||||
|
int refs;
|
||||||
|
|
||||||
|
refs = qemuMonitorUnref(priv->mon);
|
||||||
|
|
||||||
|
if (refs > 0)
|
||||||
|
qemuMonitorUnlock(priv->mon);
|
||||||
|
|
||||||
|
if (driver)
|
||||||
|
qemuDriverLock(driver);
|
||||||
|
virDomainObjLock(obj);
|
||||||
|
|
||||||
|
priv->monStart = 0;
|
||||||
|
if (refs == 0) {
|
||||||
|
priv->mon = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* obj must be locked before calling, qemud_driver must be unlocked
|
* obj must be locked before calling, qemud_driver must be unlocked
|
||||||
*
|
*
|
||||||
@ -633,38 +670,18 @@ int qemuDomainObjEndJob(virDomainObjPtr obj)
|
|||||||
*/
|
*/
|
||||||
void qemuDomainObjEnterMonitor(virDomainObjPtr obj)
|
void qemuDomainObjEnterMonitor(virDomainObjPtr obj)
|
||||||
{
|
{
|
||||||
qemuDomainObjPrivatePtr priv = obj->privateData;
|
qemuDomainObjEnterMonitorInternal(NULL, obj);
|
||||||
|
|
||||||
qemuMonitorLock(priv->mon);
|
|
||||||
qemuMonitorRef(priv->mon);
|
|
||||||
ignore_value(virTimeMs(&priv->monStart));
|
|
||||||
virDomainObjUnlock(obj);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* obj must NOT be locked before calling, qemud_driver must be unlocked
|
/* obj must NOT be locked before calling, qemud_driver must be unlocked
|
||||||
*
|
*
|
||||||
* Should be paired with an earlier qemuDomainObjEnterMonitor() call
|
* Should be paired with an earlier qemuDomainObjEnterMonitor() call
|
||||||
*/
|
*/
|
||||||
void qemuDomainObjExitMonitor(virDomainObjPtr obj)
|
void qemuDomainObjExitMonitor(virDomainObjPtr obj)
|
||||||
{
|
{
|
||||||
qemuDomainObjPrivatePtr priv = obj->privateData;
|
qemuDomainObjExitMonitorInternal(NULL, obj);
|
||||||
int refs;
|
|
||||||
|
|
||||||
refs = qemuMonitorUnref(priv->mon);
|
|
||||||
|
|
||||||
if (refs > 0)
|
|
||||||
qemuMonitorUnlock(priv->mon);
|
|
||||||
|
|
||||||
virDomainObjLock(obj);
|
|
||||||
|
|
||||||
priv->monStart = 0;
|
|
||||||
if (refs == 0) {
|
|
||||||
priv->mon = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* obj must be locked before calling, qemud_driver must be locked
|
* obj must be locked before calling, qemud_driver must be locked
|
||||||
*
|
*
|
||||||
@ -676,16 +693,9 @@ void qemuDomainObjExitMonitor(virDomainObjPtr obj)
|
|||||||
void qemuDomainObjEnterMonitorWithDriver(struct qemud_driver *driver,
|
void qemuDomainObjEnterMonitorWithDriver(struct qemud_driver *driver,
|
||||||
virDomainObjPtr obj)
|
virDomainObjPtr obj)
|
||||||
{
|
{
|
||||||
qemuDomainObjPrivatePtr priv = obj->privateData;
|
qemuDomainObjEnterMonitorInternal(driver, obj);
|
||||||
|
|
||||||
qemuMonitorLock(priv->mon);
|
|
||||||
qemuMonitorRef(priv->mon);
|
|
||||||
ignore_value(virTimeMs(&priv->monStart));
|
|
||||||
virDomainObjUnlock(obj);
|
|
||||||
qemuDriverUnlock(driver);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* obj must NOT be locked before calling, qemud_driver must be unlocked,
|
/* obj must NOT be locked before calling, qemud_driver must be unlocked,
|
||||||
* and will be locked after returning
|
* and will be locked after returning
|
||||||
*
|
*
|
||||||
@ -694,21 +704,7 @@ void qemuDomainObjEnterMonitorWithDriver(struct qemud_driver *driver,
|
|||||||
void qemuDomainObjExitMonitorWithDriver(struct qemud_driver *driver,
|
void qemuDomainObjExitMonitorWithDriver(struct qemud_driver *driver,
|
||||||
virDomainObjPtr obj)
|
virDomainObjPtr obj)
|
||||||
{
|
{
|
||||||
qemuDomainObjPrivatePtr priv = obj->privateData;
|
qemuDomainObjExitMonitorInternal(driver, obj);
|
||||||
int refs;
|
|
||||||
|
|
||||||
refs = qemuMonitorUnref(priv->mon);
|
|
||||||
|
|
||||||
if (refs > 0)
|
|
||||||
qemuMonitorUnlock(priv->mon);
|
|
||||||
|
|
||||||
qemuDriverLock(driver);
|
|
||||||
virDomainObjLock(obj);
|
|
||||||
|
|
||||||
priv->monStart = 0;
|
|
||||||
if (refs == 0) {
|
|
||||||
priv->mon = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void qemuDomainObjEnterRemoteWithDriver(struct qemud_driver *driver,
|
void qemuDomainObjEnterRemoteWithDriver(struct qemud_driver *driver,
|
||||||
|
Loading…
Reference in New Issue
Block a user