Add a macro timeval_to_ms to compute micro seconds from timeval

This commit is contained in:
Hu Tao 2010-12-14 15:40:12 +08:00 committed by Eric Blake
parent 8806c0db63
commit 54c6833392

View File

@ -96,6 +96,8 @@
#define QEMU_NAMESPACE_HREF "http://libvirt.org/schemas/domain/qemu/1.0" #define QEMU_NAMESPACE_HREF "http://libvirt.org/schemas/domain/qemu/1.0"
#define timeval_to_ms(tv) (((tv).tv_sec * 1000ull) + ((tv).tv_usec / 1000))
/* Only 1 job is allowed at any time /* Only 1 job is allowed at any time
* A job includes *all* monitor commands, even those just querying * A job includes *all* monitor commands, even those just querying
* information, not merely actions */ * information, not merely actions */
@ -376,8 +378,7 @@ static int qemuDomainObjBeginJob(virDomainObjPtr obj)
_("cannot get time of day")); _("cannot get time of day"));
return -1; return -1;
} }
then = (now.tv_sec * 1000ull) + (now.tv_usec / 1000); then = timeval_to_ms(now) + QEMU_JOB_WAIT_TIME;
then += QEMU_JOB_WAIT_TIME;
virDomainObjRef(obj); virDomainObjRef(obj);
@ -396,7 +397,7 @@ static int qemuDomainObjBeginJob(virDomainObjPtr obj)
priv->jobActive = QEMU_JOB_UNSPECIFIED; priv->jobActive = QEMU_JOB_UNSPECIFIED;
priv->jobSignals = 0; priv->jobSignals = 0;
memset(&priv->jobSignalsData, 0, sizeof(priv->jobSignalsData)); memset(&priv->jobSignalsData, 0, sizeof(priv->jobSignalsData));
priv->jobStart = (now.tv_sec * 1000ull) + (now.tv_usec / 1000); priv->jobStart = timeval_to_ms(now);
memset(&priv->jobInfo, 0, sizeof(priv->jobInfo)); memset(&priv->jobInfo, 0, sizeof(priv->jobInfo));
return 0; return 0;
@ -422,8 +423,7 @@ static int qemuDomainObjBeginJobWithDriver(struct qemud_driver *driver,
_("cannot get time of day")); _("cannot get time of day"));
return -1; return -1;
} }
then = (now.tv_sec * 1000ull) + (now.tv_usec / 1000); then = timeval_to_ms(now) + QEMU_JOB_WAIT_TIME;
then += QEMU_JOB_WAIT_TIME;
virDomainObjRef(obj); virDomainObjRef(obj);
qemuDriverUnlock(driver); qemuDriverUnlock(driver);
@ -444,7 +444,7 @@ static int qemuDomainObjBeginJobWithDriver(struct qemud_driver *driver,
priv->jobActive = QEMU_JOB_UNSPECIFIED; priv->jobActive = QEMU_JOB_UNSPECIFIED;
priv->jobSignals = 0; priv->jobSignals = 0;
memset(&priv->jobSignalsData, 0, sizeof(priv->jobSignalsData)); memset(&priv->jobSignalsData, 0, sizeof(priv->jobSignalsData));
priv->jobStart = (now.tv_sec * 1000ull) + (now.tv_usec / 1000); priv->jobStart = timeval_to_ms(now);
memset(&priv->jobInfo, 0, sizeof(priv->jobInfo)); memset(&priv->jobInfo, 0, sizeof(priv->jobInfo));
virDomainObjUnlock(obj); virDomainObjUnlock(obj);
@ -5469,9 +5469,7 @@ qemuDomainWaitForMigrationComplete(struct qemud_driver *driver, virDomainObjPtr
_("cannot get time of day")); _("cannot get time of day"));
goto cleanup; goto cleanup;
} }
priv->jobInfo.timeElapsed = priv->jobInfo.timeElapsed = timeval_to_ms(now) - priv->jobStart;
((now.tv_sec * 1000ull) + (now.tv_usec / 1000)) -
priv->jobStart;
switch (status) { switch (status) {
case QEMU_MONITOR_MIGRATION_STATUS_INACTIVE: case QEMU_MONITOR_MIGRATION_STATUS_INACTIVE:
@ -11154,7 +11152,7 @@ endjob:
virDomainObjIsActive(vm)) { virDomainObjIsActive(vm)) {
priv->jobActive = QEMU_JOB_MIGRATION_IN; priv->jobActive = QEMU_JOB_MIGRATION_IN;
priv->jobInfo.type = VIR_DOMAIN_JOB_UNBOUNDED; priv->jobInfo.type = VIR_DOMAIN_JOB_UNBOUNDED;
priv->jobStart = (now.tv_sec * 1000ull) + (now.tv_usec / 1000); priv->jobStart = timeval_to_ms(now);
} }
cleanup: cleanup:
@ -11382,7 +11380,7 @@ endjob:
virDomainObjIsActive(vm)) { virDomainObjIsActive(vm)) {
priv->jobActive = QEMU_JOB_MIGRATION_IN; priv->jobActive = QEMU_JOB_MIGRATION_IN;
priv->jobInfo.type = VIR_DOMAIN_JOB_UNBOUNDED; priv->jobInfo.type = VIR_DOMAIN_JOB_UNBOUNDED;
priv->jobStart = (now.tv_sec * 1000ull) + (now.tv_usec / 1000); priv->jobStart = timeval_to_ms(now);
} }
cleanup: cleanup:
@ -12371,9 +12369,7 @@ static int qemuDomainGetJobInfo(virDomainPtr dom,
_("cannot get time of day")); _("cannot get time of day"));
goto cleanup; goto cleanup;
} }
info->timeElapsed = info->timeElapsed = timeval_to_ms(now) - priv->jobStart;
((now.tv_sec * 1000ull) + (now.tv_usec / 1000)) -
priv->jobStart;
} else { } else {
memset(info, 0, sizeof(*info)); memset(info, 0, sizeof(*info));
info->type = VIR_DOMAIN_JOB_NONE; info->type = VIR_DOMAIN_JOB_NONE;