fa2756b71b
This lets different subsystems register an Error that is thrown whenever migration is attempted. This works nicely because it gracefully supports things like hotplug. Right now, if multiple errors are registered, only one of them is reported. I expect that for 1.1, we'll extend query-migrate to return all of the reasons why migration is disabled at any given point in time. Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
108 lines
2.8 KiB
C
108 lines
2.8 KiB
C
/*
|
|
* QEMU live migration
|
|
*
|
|
* Copyright IBM, Corp. 2008
|
|
*
|
|
* Authors:
|
|
* Anthony Liguori <aliguori@us.ibm.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2. See
|
|
* the COPYING file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#ifndef QEMU_MIGRATION_H
|
|
#define QEMU_MIGRATION_H
|
|
|
|
#include "qdict.h"
|
|
#include "qemu-common.h"
|
|
#include "notify.h"
|
|
#include "error.h"
|
|
|
|
typedef struct MigrationState MigrationState;
|
|
|
|
struct MigrationState
|
|
{
|
|
int64_t bandwidth_limit;
|
|
QEMUFile *file;
|
|
int fd;
|
|
Monitor *mon;
|
|
int state;
|
|
int (*get_error)(MigrationState *s);
|
|
int (*close)(MigrationState *s);
|
|
int (*write)(MigrationState *s, const void *buff, size_t size);
|
|
void *opaque;
|
|
int blk;
|
|
int shared;
|
|
};
|
|
|
|
void process_incoming_migration(QEMUFile *f);
|
|
|
|
int qemu_start_incoming_migration(const char *uri);
|
|
|
|
int do_migrate(Monitor *mon, const QDict *qdict, QObject **ret_data);
|
|
|
|
int do_migrate_cancel(Monitor *mon, const QDict *qdict, QObject **ret_data);
|
|
|
|
int do_migrate_set_speed(Monitor *mon, const QDict *qdict, QObject **ret_data);
|
|
|
|
uint64_t migrate_max_downtime(void);
|
|
|
|
int do_migrate_set_downtime(Monitor *mon, const QDict *qdict,
|
|
QObject **ret_data);
|
|
|
|
void do_info_migrate_print(Monitor *mon, const QObject *data);
|
|
|
|
void do_info_migrate(Monitor *mon, QObject **ret_data);
|
|
|
|
int exec_start_incoming_migration(const char *host_port);
|
|
|
|
int exec_start_outgoing_migration(MigrationState *s, const char *host_port);
|
|
|
|
int tcp_start_incoming_migration(const char *host_port);
|
|
|
|
int tcp_start_outgoing_migration(MigrationState *s, const char *host_port);
|
|
|
|
int unix_start_incoming_migration(const char *path);
|
|
|
|
int unix_start_outgoing_migration(MigrationState *s, const char *path);
|
|
|
|
int fd_start_incoming_migration(const char *path);
|
|
|
|
int fd_start_outgoing_migration(MigrationState *s, const char *fdname);
|
|
|
|
void migrate_fd_error(MigrationState *s);
|
|
|
|
void migrate_fd_connect(MigrationState *s);
|
|
|
|
void add_migration_state_change_notifier(Notifier *notify);
|
|
void remove_migration_state_change_notifier(Notifier *notify);
|
|
bool migration_is_active(MigrationState *);
|
|
bool migration_has_finished(MigrationState *);
|
|
bool migration_has_failed(MigrationState *);
|
|
|
|
uint64_t ram_bytes_remaining(void);
|
|
uint64_t ram_bytes_transferred(void);
|
|
uint64_t ram_bytes_total(void);
|
|
|
|
int ram_save_live(Monitor *mon, QEMUFile *f, int stage, void *opaque);
|
|
int ram_load(QEMUFile *f, void *opaque, int version_id);
|
|
|
|
extern int incoming_expected;
|
|
|
|
/**
|
|
* @migrate_add_blocker - prevent migration from proceeding
|
|
*
|
|
* @reason - an error to be returned whenever migration is attempted
|
|
*/
|
|
void migrate_add_blocker(Error *reason);
|
|
|
|
/**
|
|
* @migrate_del_blocker - remove a blocking error from migration
|
|
*
|
|
* @reason - the error blocking migration
|
|
*/
|
|
void migrate_del_blocker(Error *reason);
|
|
|
|
#endif
|