mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-27 06:55:18 +00:00
qemu: Implement virSaveCookie object and callbacks
This patch implements a new save cookie object and callbacks for qemu driver. The actual useful content will be added in the object later. Signed-off-by: Jiri Denemark <jdenemar@redhat.com> Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
parent
25af7e950a
commit
215476b642
@ -911,7 +911,7 @@ virQEMUDriverCreateXMLConf(virQEMUDriverPtr driver)
|
||||
&virQEMUDriverPrivateDataCallbacks,
|
||||
&virQEMUDriverDomainXMLNamespace,
|
||||
&virQEMUDriverDomainABIStability,
|
||||
NULL);
|
||||
&virQEMUDriverDomainSaveCookie);
|
||||
}
|
||||
|
||||
|
||||
|
@ -122,11 +122,13 @@ struct _qemuDomainLogContext {
|
||||
};
|
||||
|
||||
static virClassPtr qemuDomainLogContextClass;
|
||||
static virClassPtr qemuDomainSaveCookieClass;
|
||||
|
||||
static void qemuDomainLogContextDispose(void *obj);
|
||||
static void qemuDomainSaveCookieDispose(void *obj);
|
||||
|
||||
static int
|
||||
qemuDomainLogContextOnceInit(void)
|
||||
qemuDomainOnceInit(void)
|
||||
{
|
||||
if (!(qemuDomainLogContextClass = virClassNew(virClassForObject(),
|
||||
"qemuDomainLogContext",
|
||||
@ -134,10 +136,16 @@ qemuDomainLogContextOnceInit(void)
|
||||
qemuDomainLogContextDispose)))
|
||||
return -1;
|
||||
|
||||
if (!(qemuDomainSaveCookieClass = virClassNew(virClassForObject(),
|
||||
"qemuDomainSaveCookie",
|
||||
sizeof(qemuDomainSaveCookie),
|
||||
qemuDomainSaveCookieDispose)))
|
||||
return -1;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
VIR_ONCE_GLOBAL_INIT(qemuDomainLogContext)
|
||||
VIR_ONCE_GLOBAL_INIT(qemuDomain)
|
||||
|
||||
static void
|
||||
qemuDomainLogContextDispose(void *obj)
|
||||
@ -4554,7 +4562,7 @@ qemuDomainLogContextPtr qemuDomainLogContextNew(virQEMUDriverPtr driver,
|
||||
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
|
||||
qemuDomainLogContextPtr ctxt = NULL;
|
||||
|
||||
if (qemuDomainLogContextInitialize() < 0)
|
||||
if (qemuDomainInitialize() < 0)
|
||||
goto cleanup;
|
||||
|
||||
if (!(ctxt = virObjectNew(qemuDomainLogContextClass)))
|
||||
@ -9105,3 +9113,68 @@ qemuDomainGetStorageSourceByDevstr(const char *devstr,
|
||||
VIR_FREE(target);
|
||||
return src;
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
qemuDomainSaveCookieDispose(void *obj)
|
||||
{
|
||||
qemuDomainSaveCookiePtr cookie = obj;
|
||||
|
||||
VIR_DEBUG("cookie=%p", cookie);
|
||||
}
|
||||
|
||||
|
||||
qemuDomainSaveCookiePtr
|
||||
qemuDomainSaveCookieNew(virDomainObjPtr vm ATTRIBUTE_UNUSED)
|
||||
{
|
||||
qemuDomainSaveCookiePtr cookie = NULL;
|
||||
|
||||
if (qemuDomainInitialize() < 0)
|
||||
goto error;
|
||||
|
||||
if (!(cookie = virObjectNew(qemuDomainSaveCookieClass)))
|
||||
goto error;
|
||||
|
||||
VIR_DEBUG("Save cookie %p", cookie);
|
||||
|
||||
return cookie;
|
||||
|
||||
error:
|
||||
virObjectUnref(cookie);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
qemuDomainSaveCookieParse(xmlXPathContextPtr ctxt ATTRIBUTE_UNUSED,
|
||||
virObjectPtr *obj)
|
||||
{
|
||||
qemuDomainSaveCookiePtr cookie = NULL;
|
||||
|
||||
if (qemuDomainInitialize() < 0)
|
||||
goto error;
|
||||
|
||||
if (!(cookie = virObjectNew(qemuDomainSaveCookieClass)))
|
||||
goto error;
|
||||
|
||||
*obj = (virObjectPtr) cookie;
|
||||
return 0;
|
||||
|
||||
error:
|
||||
virObjectUnref(cookie);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
qemuDomainSaveCookieFormat(virBufferPtr buf ATTRIBUTE_UNUSED,
|
||||
virObjectPtr obj ATTRIBUTE_UNUSED)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
virSaveCookieCallbacks virQEMUDriverDomainSaveCookie = {
|
||||
.parse = qemuDomainSaveCookieParse,
|
||||
.format = qemuDomainSaveCookieFormat,
|
||||
};
|
||||
|
@ -416,6 +416,14 @@ struct qemuProcessEvent {
|
||||
typedef struct _qemuDomainLogContext qemuDomainLogContext;
|
||||
typedef qemuDomainLogContext *qemuDomainLogContextPtr;
|
||||
|
||||
typedef struct _qemuDomainSaveCookie qemuDomainSaveCookie;
|
||||
typedef qemuDomainSaveCookie *qemuDomainSaveCookiePtr;
|
||||
struct _qemuDomainSaveCookie {
|
||||
virObject parent;
|
||||
};
|
||||
|
||||
qemuDomainSaveCookiePtr qemuDomainSaveCookieNew(virDomainObjPtr vm);
|
||||
|
||||
const char *qemuDomainAsyncJobPhaseToString(qemuDomainAsyncJob job,
|
||||
int phase);
|
||||
int qemuDomainAsyncJobPhaseFromString(qemuDomainAsyncJob job,
|
||||
@ -638,6 +646,7 @@ extern virDomainXMLPrivateDataCallbacks virQEMUDriverPrivateDataCallbacks;
|
||||
extern virDomainXMLNamespace virQEMUDriverDomainXMLNamespace;
|
||||
extern virDomainDefParserConfig virQEMUDriverDomainDefParserConfig;
|
||||
extern virDomainABIStability virQEMUDriverDomainABIStability;
|
||||
extern virSaveCookieCallbacks virQEMUDriverDomainSaveCookie;
|
||||
|
||||
int qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
|
||||
virDomainObjPtr vm, int asyncJob);
|
||||
|
Loading…
x
Reference in New Issue
Block a user