| ============= |
| D-Bus VMState |
| ============= |
| |
| Introduction |
| ============ |
| |
| The QEMU dbus-vmstate object's aim is to migrate helpers' data running |
| on a QEMU D-Bus bus. (refer to the :doc:`dbus` document for |
| some recommendations on D-Bus usage) |
| |
| Upon migration, QEMU will go through the queue of |
| ``org.qemu.VMState1`` D-Bus name owners and query their ``Id``. It |
| must be unique among the helpers. |
| |
| It will then save arbitrary data of each Id to be transferred in the |
| migration stream and restored/loaded at the corresponding destination |
| helper. |
| |
| For now, the data amount to be transferred is arbitrarily limited to |
| 1Mb. The state must be saved quickly (a fraction of a second). (D-Bus |
| imposes a time limit on reply anyway, and migration would fail if data |
| isn't given quickly enough.) |
| |
| dbus-vmstate object can be configured with the expected list of |
| helpers by setting its ``id-list`` property, with a comma-separated |
| ``Id`` list. |
| |
| Interface |
| ========= |
| |
| On object path ``/org/qemu/VMState1``, the following |
| ``org.qemu.VMState1`` interface should be implemented: |
| |
| .. code:: xml |
| |
| <interface name="org.qemu.VMState1"> |
| <property name="Id" type="s" access="read"/> |
| <method name="Load"> |
| <arg type="ay" name="data" direction="in"/> |
| </method> |
| <method name="Save"> |
| <arg type="ay" name="data" direction="out"/> |
| </method> |
| </interface> |
| |
| "Id" property |
| ------------- |
| |
| A string that identifies the helper uniquely. (maximum 256 bytes |
| including terminating NUL byte) |
| |
| .. note:: |
| |
| The helper ID namespace is a separate namespace. In particular, it is not |
| related to QEMU "id" used in -object/-device objects. |
| |
| Load(in u8[] bytes) method |
| -------------------------- |
| |
| The method called on destination with the state to restore. |
| |
| The helper may be initially started in a waiting state (with |
| an --incoming argument for example), and it may resume on success. |
| |
| An error may be returned to the caller. |
| |
| Save(out u8[] bytes) method |
| --------------------------- |
| |
| The method called on the source to get the current state to be |
| migrated. The helper should continue to run normally. |
| |
| An error may be returned to the caller. |