diff options
author | Martin Kletzander <mkletzan@redhat.com> | 2012-10-15 12:10:45 +0200 |
---|---|---|
committer | Jiri Denemark <jdenemar@redhat.com> | 2012-10-15 12:29:00 +0200 |
commit | 2508c934bc82e40a1b35271e6ad8bcd73c05a73b (patch) | |
tree | 3605803d8a853f449997e21da40de4fb44f712e9 /libvirt-override.c | |
parent | cd4d093eef4a3a5ff7e2df436ba52501186634ec (diff) | |
download | libvirt-python-v6-2508c934bc82e40a1b35271e6ad8bcd73c05a73b.tar.gz libvirt-python-v6-2508c934bc82e40a1b35271e6ad8bcd73c05a73b.tar.xz libvirt-python-v6-2508c934bc82e40a1b35271e6ad8bcd73c05a73b.zip |
Add support for SUSPEND_DISK eventlibvirt-0.10.2-9.el6libvirt-0.10.2-8.el6libvirt-0.10.2-7.el6libvirt-0.10.2-6.el6libvirt-0.10.2-5.el6libvirt-0.10.2-4.el6libvirt-0.10.2-3.el6libvirt-0.10.2-18.el6libvirt-0.10.2-17.el6libvirt-0.10.2-16.el6libvirt-0.10.2-15.el6libvirt-0.10.2-14.el6libvirt-0.10.2-13.el6libvirt-0.10.2-12.el6libvirt-0.10.2-11.el6libvirt-0.10.2-10.el6
https://bugzilla.redhat.com/show_bug.cgi?id=839661
This patch adds support for SUSPEND_DISK event; both lifecycle and
separated. The support is added for QEMU, machines are changed to
PMSUSPENDED, but as QEMU sends SHUTDOWN afterwards, the state changes
to shut-off. This and much more needs to be done in order for libvirt
to work with transient devices, wake-ups etc. This patch is not
aiming for that functionality.
(cherry picked from commit 7ba5defb5a34bb82de2f16467c2b8d157cd14d2d)
Diffstat (limited to 'libvirt-override.c')
-rw-r--r-- | libvirt-override.c | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/libvirt-override.c b/libvirt-override.c index 25f9d3f..4d261e8 100644 --- a/libvirt-override.c +++ b/libvirt-override.c @@ -5733,6 +5733,53 @@ libvirt_virConnectDomainEventBalloonChangeCallback(virConnectPtr conn ATTRIBUTE_ return ret; } +static int +libvirt_virConnectDomainEventPMSuspendDiskCallback(virConnectPtr conn ATTRIBUTE_UNUSED, + virDomainPtr dom, + int reason, + void *opaque) +{ + PyObject *pyobj_cbData = (PyObject*)opaque; + PyObject *pyobj_dom; + PyObject *pyobj_ret; + PyObject *pyobj_conn; + PyObject *dictKey; + int ret = -1; + + LIBVIRT_ENSURE_THREAD_STATE; + /* Create a python instance of this virDomainPtr */ + virDomainRef(dom); + + pyobj_dom = libvirt_virDomainPtrWrap(dom); + Py_INCREF(pyobj_cbData); + + dictKey = libvirt_constcharPtrWrap("conn"); + pyobj_conn = PyDict_GetItem(pyobj_cbData, dictKey); + Py_DECREF(dictKey); + + /* Call the Callback Dispatcher */ + pyobj_ret = PyObject_CallMethod(pyobj_conn, + (char*)"_dispatchDomainEventPMSuspendDiskCallback", + (char*)"OiO", + pyobj_dom, + reason, + pyobj_cbData); + + Py_DECREF(pyobj_cbData); + Py_DECREF(pyobj_dom); + + if(!pyobj_ret) { + DEBUG("%s - ret:%p\n", __FUNCTION__, pyobj_ret); + PyErr_Print(); + } else { + Py_DECREF(pyobj_ret); + ret = 0; + } + + LIBVIRT_RELEASE_THREAD_STATE; + return ret; +} + static PyObject * libvirt_virConnectDomainEventRegisterAny(ATTRIBUTE_UNUSED PyObject * self, PyObject * args) @@ -5805,6 +5852,9 @@ libvirt_virConnectDomainEventRegisterAny(ATTRIBUTE_UNUSED PyObject * self, case VIR_DOMAIN_EVENT_ID_BALLOON_CHANGE: cb = VIR_DOMAIN_EVENT_CALLBACK(libvirt_virConnectDomainEventBalloonChangeCallback); break; + case VIR_DOMAIN_EVENT_ID_PMSUSPEND_DISK: + cb = VIR_DOMAIN_EVENT_CALLBACK(libvirt_virConnectDomainEventPMSuspendDiskCallback); + break; } if (!cb) { |