]> git.proxmox.com Git - qemu.git/blobdiff - migration.h
target-alpha: Move integer overflow helpers to int_helper.c.
[qemu.git] / migration.h
index 61f77bd89a47521b1744d671e307972206816c83..691b3673890bc025b63f16d45968779306536566 100644 (file)
 #ifndef QEMU_MIGRATION_H
 #define QEMU_MIGRATION_H
 
-#define MIG_STATE_ERROR                -1
-#define MIG_STATE_COMPLETED    0
-#define MIG_STATE_CANCELLED    1
-#define MIG_STATE_ACTIVE       2
+#include "qdict.h"
+#include "qemu-common.h"
+#include "notify.h"
+#include "error.h"
 
 typedef struct MigrationState MigrationState;
 
 struct MigrationState
 {
-    /* FIXME: add more accessors to print migration info */
-    void (*cancel)(MigrationState *s);
-    int (*get_status)(MigrationState *s);
-    void (*release)(MigrationState *s);
+    int64_t bandwidth_limit;
+    QEMUFile *file;
+    int fd;
+    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 qemu_start_incoming_migration(const char *uri);
+void process_incoming_migration(QEMUFile *f);
 
-void do_migrate(int detach, const char *uri);
+int qemu_start_incoming_migration(const char *uri);
 
-void do_migrate_cancel(void);
+uint64_t migrate_max_downtime(void);
 
-void do_migrate_set_speed(const char *value);
+void do_info_migrate_print(Monitor *mon, const QObject *data);
 
-void do_info_migrate(void);
+void do_info_migrate(Monitor *mon, QObject **ret_data);
 
-#endif
+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(QEMUFile *f, int stage, void *opaque);
+int ram_load(QEMUFile *f, void *opaque, int version_id);
+
+/**
+ * @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