aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 1 | /* |
| 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 | |
Luiz Capitulino | f96fc8a | 2009-08-28 15:27:12 -0300 | [diff] [blame] | 17 | #include "qdict.h" |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 18 | #include "qemu-common.h" |
| 19 | |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 20 | #define MIG_STATE_ERROR -1 |
| 21 | #define MIG_STATE_COMPLETED 0 |
| 22 | #define MIG_STATE_CANCELLED 1 |
| 23 | #define MIG_STATE_ACTIVE 2 |
| 24 | |
| 25 | typedef struct MigrationState MigrationState; |
| 26 | |
| 27 | struct MigrationState |
| 28 | { |
| 29 | /* FIXME: add more accessors to print migration info */ |
| 30 | void (*cancel)(MigrationState *s); |
| 31 | int (*get_status)(MigrationState *s); |
| 32 | void (*release)(MigrationState *s); |
lirans@il.ibm.com | c163b5c | 2009-11-02 15:40:58 +0200 | [diff] [blame] | 33 | int blk; |
| 34 | int shared; |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 35 | }; |
| 36 | |
aliguori | 065e281 | 2008-11-11 16:46:33 +0000 | [diff] [blame] | 37 | typedef struct FdMigrationState FdMigrationState; |
| 38 | |
| 39 | struct FdMigrationState |
| 40 | { |
| 41 | MigrationState mig_state; |
| 42 | int64_t bandwidth_limit; |
| 43 | QEMUFile *file; |
| 44 | int fd; |
Jan Kiszka | f327aa0 | 2009-11-30 18:21:21 +0100 | [diff] [blame] | 45 | Monitor *mon; |
aliguori | 065e281 | 2008-11-11 16:46:33 +0000 | [diff] [blame] | 46 | int state; |
| 47 | int (*get_error)(struct FdMigrationState*); |
| 48 | int (*close)(struct FdMigrationState*); |
| 49 | int (*write)(struct FdMigrationState*, const void *, size_t); |
| 50 | void *opaque; |
| 51 | }; |
| 52 | |
Juan Quintela | 511c023 | 2010-06-09 14:10:55 +0200 | [diff] [blame] | 53 | void process_incoming_migration(QEMUFile *f); |
| 54 | |
Juan Quintela | 8ca5e80 | 2010-06-09 14:10:54 +0200 | [diff] [blame] | 55 | int qemu_start_incoming_migration(const char *uri); |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 56 | |
Luiz Capitulino | b5d17ad | 2010-02-10 23:49:57 -0200 | [diff] [blame] | 57 | int do_migrate(Monitor *mon, const QDict *qdict, QObject **ret_data); |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 58 | |
Luiz Capitulino | ef4b7ee | 2010-02-10 23:49:48 -0200 | [diff] [blame] | 59 | int do_migrate_cancel(Monitor *mon, const QDict *qdict, QObject **ret_data); |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 60 | |
Luiz Capitulino | ef4b7ee | 2010-02-10 23:49:48 -0200 | [diff] [blame] | 61 | int do_migrate_set_speed(Monitor *mon, const QDict *qdict, QObject **ret_data); |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 62 | |
Glauber Costa | a0a3fd6 | 2009-05-28 15:22:57 -0400 | [diff] [blame] | 63 | uint64_t migrate_max_downtime(void); |
| 64 | |
Luiz Capitulino | ef4b7ee | 2010-02-10 23:49:48 -0200 | [diff] [blame] | 65 | int do_migrate_set_downtime(Monitor *mon, const QDict *qdict, |
| 66 | QObject **ret_data); |
Glauber Costa | 2ea4295 | 2009-05-28 15:22:58 -0400 | [diff] [blame] | 67 | |
Luiz Capitulino | c86a668 | 2009-12-10 17:16:05 -0200 | [diff] [blame] | 68 | void do_info_migrate_print(Monitor *mon, const QObject *data); |
| 69 | |
| 70 | void do_info_migrate(Monitor *mon, QObject **ret_data); |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 71 | |
aliguori | 065e281 | 2008-11-11 16:46:33 +0000 | [diff] [blame] | 72 | int exec_start_incoming_migration(const char *host_port); |
| 73 | |
Jan Kiszka | f327aa0 | 2009-11-30 18:21:21 +0100 | [diff] [blame] | 74 | MigrationState *exec_start_outgoing_migration(Monitor *mon, |
| 75 | const char *host_port, |
lirans@il.ibm.com | c163b5c | 2009-11-02 15:40:58 +0200 | [diff] [blame] | 76 | int64_t bandwidth_limit, |
| 77 | int detach, |
| 78 | int blk, |
| 79 | int inc); |
aliguori | 065e281 | 2008-11-11 16:46:33 +0000 | [diff] [blame] | 80 | |
aliguori | 34c9dd8 | 2008-10-13 03:14:31 +0000 | [diff] [blame] | 81 | int tcp_start_incoming_migration(const char *host_port); |
| 82 | |
Jan Kiszka | f327aa0 | 2009-11-30 18:21:21 +0100 | [diff] [blame] | 83 | MigrationState *tcp_start_outgoing_migration(Monitor *mon, |
| 84 | const char *host_port, |
aliguori | 34c9dd8 | 2008-10-13 03:14:31 +0000 | [diff] [blame] | 85 | int64_t bandwidth_limit, |
lirans@il.ibm.com | c163b5c | 2009-11-02 15:40:58 +0200 | [diff] [blame] | 86 | int detach, |
| 87 | int blk, |
| 88 | int inc); |
aliguori | 34c9dd8 | 2008-10-13 03:14:31 +0000 | [diff] [blame] | 89 | |
Chris Lalancette | 4951f65 | 2009-08-05 17:24:29 +0200 | [diff] [blame] | 90 | int unix_start_incoming_migration(const char *path); |
| 91 | |
Jan Kiszka | f327aa0 | 2009-11-30 18:21:21 +0100 | [diff] [blame] | 92 | MigrationState *unix_start_outgoing_migration(Monitor *mon, |
| 93 | const char *path, |
Chris Lalancette | 4951f65 | 2009-08-05 17:24:29 +0200 | [diff] [blame] | 94 | int64_t bandwidth_limit, |
lirans@il.ibm.com | c163b5c | 2009-11-02 15:40:58 +0200 | [diff] [blame] | 95 | int detach, |
| 96 | int blk, |
| 97 | int inc); |
Chris Lalancette | 4951f65 | 2009-08-05 17:24:29 +0200 | [diff] [blame] | 98 | |
Paolo Bonzini | 5ac1fad | 2009-08-18 15:56:25 +0200 | [diff] [blame] | 99 | int fd_start_incoming_migration(const char *path); |
| 100 | |
| 101 | MigrationState *fd_start_outgoing_migration(Monitor *mon, |
| 102 | const char *fdname, |
| 103 | int64_t bandwidth_limit, |
lirans@il.ibm.com | c163b5c | 2009-11-02 15:40:58 +0200 | [diff] [blame] | 104 | int detach, |
| 105 | int blk, |
| 106 | int inc); |
Paolo Bonzini | 5ac1fad | 2009-08-18 15:56:25 +0200 | [diff] [blame] | 107 | |
Jan Kiszka | f327aa0 | 2009-11-30 18:21:21 +0100 | [diff] [blame] | 108 | void migrate_fd_monitor_suspend(FdMigrationState *s, Monitor *mon); |
aliguori | 731b036 | 2009-03-05 23:01:42 +0000 | [diff] [blame] | 109 | |
aliguori | 065e281 | 2008-11-11 16:46:33 +0000 | [diff] [blame] | 110 | void migrate_fd_error(FdMigrationState *s); |
| 111 | |
Anthony Liguori | 41ef56e | 2010-06-02 14:55:25 -0500 | [diff] [blame] | 112 | int migrate_fd_cleanup(FdMigrationState *s); |
aliguori | 065e281 | 2008-11-11 16:46:33 +0000 | [diff] [blame] | 113 | |
| 114 | void migrate_fd_put_notify(void *opaque); |
| 115 | |
| 116 | ssize_t migrate_fd_put_buffer(void *opaque, const void *data, size_t size); |
| 117 | |
| 118 | void migrate_fd_connect(FdMigrationState *s); |
| 119 | |
| 120 | void migrate_fd_put_ready(void *opaque); |
| 121 | |
| 122 | int migrate_fd_get_status(MigrationState *mig_state); |
| 123 | |
| 124 | void migrate_fd_cancel(MigrationState *mig_state); |
| 125 | |
| 126 | void migrate_fd_release(MigrationState *mig_state); |
| 127 | |
| 128 | void migrate_fd_wait_for_unfreeze(void *opaque); |
| 129 | |
| 130 | int migrate_fd_close(void *opaque); |
| 131 | |
| 132 | static inline FdMigrationState *migrate_to_fms(MigrationState *mig_state) |
| 133 | { |
| 134 | return container_of(mig_state, FdMigrationState, mig_state); |
| 135 | } |
| 136 | |
aliguori | 5bb7910 | 2008-10-13 03:12:02 +0000 | [diff] [blame] | 137 | #endif |