blob: 37c7f8e1587367277b705432c6f9d334abb5dd92 [file] [log] [blame]
aliguori5bb79102008-10-13 03:12:02 +00001/*
2 * QEMU live migration
3 *
4 * Copyright IBM, Corp. 2008
5 *
6 * Authors:
7 * Anthony Liguori <aliguori@us.ibm.com>
8 *
9 * This work is licensed under the terms of the GNU GPL, version 2. See
10 * the COPYING file in the top-level directory.
11 *
12 */
13
14#ifndef QEMU_MIGRATION_H
15#define QEMU_MIGRATION_H
16
aliguori376253e2009-03-05 23:01:23 +000017#include "qemu-common.h"
18
aliguori5bb79102008-10-13 03:12:02 +000019#define MIG_STATE_ERROR -1
20#define MIG_STATE_COMPLETED 0
21#define MIG_STATE_CANCELLED 1
22#define MIG_STATE_ACTIVE 2
23
24typedef struct MigrationState MigrationState;
25
26struct MigrationState
27{
28 /* FIXME: add more accessors to print migration info */
29 void (*cancel)(MigrationState *s);
30 int (*get_status)(MigrationState *s);
31 void (*release)(MigrationState *s);
32};
33
aliguori065e2812008-11-11 16:46:33 +000034typedef struct FdMigrationState FdMigrationState;
35
36struct FdMigrationState
37{
38 MigrationState mig_state;
39 int64_t bandwidth_limit;
40 QEMUFile *file;
41 int fd;
aliguori731b0362009-03-05 23:01:42 +000042 Monitor *mon_resume;
aliguori065e2812008-11-11 16:46:33 +000043 int state;
44 int (*get_error)(struct FdMigrationState*);
45 int (*close)(struct FdMigrationState*);
46 int (*write)(struct FdMigrationState*, const void *, size_t);
47 void *opaque;
48};
49
aliguori5bb79102008-10-13 03:12:02 +000050void qemu_start_incoming_migration(const char *uri);
51
aliguori376253e2009-03-05 23:01:23 +000052void do_migrate(Monitor *mon, int detach, const char *uri);
aliguori5bb79102008-10-13 03:12:02 +000053
aliguori376253e2009-03-05 23:01:23 +000054void do_migrate_cancel(Monitor *mon);
aliguori5bb79102008-10-13 03:12:02 +000055
aliguori376253e2009-03-05 23:01:23 +000056void do_migrate_set_speed(Monitor *mon, const char *value);
aliguori5bb79102008-10-13 03:12:02 +000057
Glauber Costaa0a3fd62009-05-28 15:22:57 -040058uint64_t migrate_max_downtime(void);
59
Glauber Costa2ea42952009-05-28 15:22:58 -040060void do_migrate_set_downtime(Monitor *mon, const char *value);
61
aliguori376253e2009-03-05 23:01:23 +000062void do_info_migrate(Monitor *mon);
aliguori5bb79102008-10-13 03:12:02 +000063
aliguori065e2812008-11-11 16:46:33 +000064int exec_start_incoming_migration(const char *host_port);
65
66MigrationState *exec_start_outgoing_migration(const char *host_port,
67 int64_t bandwidth_limit,
68 int detach);
69
aliguori34c9dd82008-10-13 03:14:31 +000070int tcp_start_incoming_migration(const char *host_port);
71
72MigrationState *tcp_start_outgoing_migration(const char *host_port,
73 int64_t bandwidth_limit,
74 int detach);
75
aliguori731b0362009-03-05 23:01:42 +000076void migrate_fd_monitor_suspend(FdMigrationState *s);
77
aliguori065e2812008-11-11 16:46:33 +000078void migrate_fd_error(FdMigrationState *s);
79
80void migrate_fd_cleanup(FdMigrationState *s);
81
82void migrate_fd_put_notify(void *opaque);
83
84ssize_t migrate_fd_put_buffer(void *opaque, const void *data, size_t size);
85
86void migrate_fd_connect(FdMigrationState *s);
87
88void migrate_fd_put_ready(void *opaque);
89
90int migrate_fd_get_status(MigrationState *mig_state);
91
92void migrate_fd_cancel(MigrationState *mig_state);
93
94void migrate_fd_release(MigrationState *mig_state);
95
96void migrate_fd_wait_for_unfreeze(void *opaque);
97
98int migrate_fd_close(void *opaque);
99
100static inline FdMigrationState *migrate_to_fms(MigrationState *mig_state)
101{
102 return container_of(mig_state, FdMigrationState, mig_state);
103}
104
aliguori5bb79102008-10-13 03:12:02 +0000105#endif