08fc4cb517
Add a new .save_prepare() handler to struct SaveVMHandlers. This handler is called early, even before migration starts, and can be used by devices to perform early checks. Refactor migrate_init() to be able to return errors and call .save_prepare() from there. Suggested-by: Peter Xu <peterx@redhat.com> Signed-off-by: Avihai Horon <avihaih@nvidia.com> Reviewed-by: Peter Xu <peterx@redhat.com> Reviewed-by: Cédric Le Goater <clg@redhat.com> Signed-off-by: Cédric Le Goater <clg@redhat.com>
74 lines
2.9 KiB
C
74 lines
2.9 KiB
C
/*
|
|
* QEMU save vm functions
|
|
*
|
|
* Copyright (c) 2003-2008 Fabrice Bellard
|
|
* Copyright (c) 2009-2017 Red Hat Inc
|
|
*
|
|
* Authors:
|
|
* Juan Quintela <quintela@redhat.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*/
|
|
|
|
#ifndef MIGRATION_SAVEVM_H
|
|
#define MIGRATION_SAVEVM_H
|
|
|
|
#define QEMU_VM_FILE_MAGIC 0x5145564d
|
|
#define QEMU_VM_FILE_VERSION_COMPAT 0x00000002
|
|
#define QEMU_VM_FILE_VERSION 0x00000003
|
|
|
|
#define QEMU_VM_EOF 0x00
|
|
#define QEMU_VM_SECTION_START 0x01
|
|
#define QEMU_VM_SECTION_PART 0x02
|
|
#define QEMU_VM_SECTION_END 0x03
|
|
#define QEMU_VM_SECTION_FULL 0x04
|
|
#define QEMU_VM_SUBSECTION 0x05
|
|
#define QEMU_VM_VMDESCRIPTION 0x06
|
|
#define QEMU_VM_CONFIGURATION 0x07
|
|
#define QEMU_VM_COMMAND 0x08
|
|
#define QEMU_VM_SECTION_FOOTER 0x7e
|
|
|
|
bool qemu_savevm_state_blocked(Error **errp);
|
|
void qemu_savevm_non_migratable_list(strList **reasons);
|
|
int qemu_savevm_state_prepare(Error **errp);
|
|
void qemu_savevm_state_setup(QEMUFile *f);
|
|
bool qemu_savevm_state_guest_unplug_pending(void);
|
|
int qemu_savevm_state_resume_prepare(MigrationState *s);
|
|
void qemu_savevm_state_header(QEMUFile *f);
|
|
int qemu_savevm_state_iterate(QEMUFile *f, bool postcopy);
|
|
void qemu_savevm_state_cleanup(void);
|
|
void qemu_savevm_state_complete_postcopy(QEMUFile *f);
|
|
int qemu_savevm_state_complete_precopy(QEMUFile *f, bool iterable_only,
|
|
bool inactivate_disks);
|
|
void qemu_savevm_state_pending_exact(uint64_t *must_precopy,
|
|
uint64_t *can_postcopy);
|
|
void qemu_savevm_state_pending_estimate(uint64_t *must_precopy,
|
|
uint64_t *can_postcopy);
|
|
void qemu_savevm_send_ping(QEMUFile *f, uint32_t value);
|
|
void qemu_savevm_send_open_return_path(QEMUFile *f);
|
|
int qemu_savevm_send_packaged(QEMUFile *f, const uint8_t *buf, size_t len);
|
|
void qemu_savevm_send_postcopy_advise(QEMUFile *f);
|
|
void qemu_savevm_send_postcopy_listen(QEMUFile *f);
|
|
void qemu_savevm_send_postcopy_run(QEMUFile *f);
|
|
void qemu_savevm_send_postcopy_resume(QEMUFile *f);
|
|
void qemu_savevm_send_recv_bitmap(QEMUFile *f, char *block_name);
|
|
|
|
void qemu_savevm_send_postcopy_ram_discard(QEMUFile *f, const char *name,
|
|
uint16_t len,
|
|
uint64_t *start_list,
|
|
uint64_t *length_list);
|
|
void qemu_savevm_send_colo_enable(QEMUFile *f);
|
|
void qemu_savevm_live_state(QEMUFile *f);
|
|
int qemu_save_device_state(QEMUFile *f);
|
|
|
|
int qemu_loadvm_state(QEMUFile *f);
|
|
void qemu_loadvm_state_cleanup(void);
|
|
int qemu_loadvm_state_main(QEMUFile *f, MigrationIncomingState *mis);
|
|
int qemu_load_device_state(QEMUFile *f);
|
|
int qemu_loadvm_approve_switchover(void);
|
|
int qemu_savevm_state_complete_precopy_non_iterable(QEMUFile *f,
|
|
bool in_postcopy, bool inactivate_disks);
|
|
|
|
#endif
|