]> git.proxmox.com Git - qemu.git/blame - include/migration/migration.h
Merge remote-tracking branch 'bonzini/iommu-for-anthony' into staging
[qemu.git] / include / migration / migration.h
CommitLineData
5bb7910a
AL
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
7b1b5d19 17#include "qapi/qmp/qdict.h"
376253ec 18#include "qemu-common.h"
9848a404 19#include "qemu/thread.h"
1de7afc9 20#include "qemu/notify.h"
7b1b5d19 21#include "qapi/error.h"
caf71f86 22#include "migration/vmstate.h"
bbf6da32 23#include "qapi-types.h"
43487c67 24#include "exec/cpu-common.h"
376253ec 25
6607ae23
IY
26struct MigrationParams {
27 bool blk;
28 bool shared;
29};
30
22f00a44 31typedef struct MigrationState MigrationState;
dc7acc61 32
22f00a44 33struct MigrationState
065e2813 34{
065e2813 35 int64_t bandwidth_limit;
9848a404
JQ
36 size_t bytes_xfer;
37 size_t xfer_limit;
9848a404 38 QemuThread thread;
bb1fadc4 39 QEMUBH *cleanup_bh;
065e2813 40 QEMUFile *file;
f8bbc128 41
f8bbc128 42 int state;
6607ae23 43 MigrationParams params;
7e114f8c 44 double mbps;
d5f8a570 45 int64_t total_time;
9c5a9fcf 46 int64_t downtime;
2c52ddf1 47 int64_t expected_downtime;
8d017193 48 int64_t dirty_pages_rate;
90f8ae72 49 int64_t dirty_bytes_rate;
bbf6da32 50 bool enabled_capabilities[MIGRATION_CAPABILITY_MAX];
17ad9b35 51 int64_t xbzrle_cache_size;
065e2813
AL
52};
53
511c0231
JQ
54void process_incoming_migration(QEMUFile *f);
55
43eaae28 56void qemu_start_incoming_migration(const char *uri, Error **errp);
5bb7910a 57
a0a3fd60
GC
58uint64_t migrate_max_downtime(void);
59
c86a6683
LC
60void do_info_migrate_print(Monitor *mon, const QObject *data);
61
62void do_info_migrate(Monitor *mon, QObject **ret_data);
5bb7910a 63
43eaae28 64void exec_start_incoming_migration(const char *host_port, Error **errp);
065e2813 65
f37afb5a 66void exec_start_outgoing_migration(MigrationState *s, const char *host_port, Error **errp);
065e2813 67
43eaae28 68void tcp_start_incoming_migration(const char *host_port, Error **errp);
34c9dd8e 69
f37afb5a 70void tcp_start_outgoing_migration(MigrationState *s, const char *host_port, Error **errp);
34c9dd8e 71
43eaae28 72void unix_start_incoming_migration(const char *path, Error **errp);
4951f65b 73
f37afb5a 74void unix_start_outgoing_migration(MigrationState *s, const char *path, Error **errp);
4951f65b 75
43eaae28 76void fd_start_incoming_migration(const char *path, Error **errp);
5ac1fad3 77
f37afb5a 78void fd_start_outgoing_migration(MigrationState *s, const char *fdname, Error **errp);
5ac1fad3 79
22f00a44 80void migrate_fd_error(MigrationState *s);
065e2813 81
22f00a44 82void migrate_fd_connect(MigrationState *s);
065e2813 83
11c76741 84int migrate_fd_close(MigrationState *s);
c87b015b 85
99a0db9b
GH
86void add_migration_state_change_notifier(Notifier *notify);
87void remove_migration_state_change_notifier(Notifier *notify);
afe2df69 88bool migration_is_active(MigrationState *);
7073693b 89bool migration_has_finished(MigrationState *);
afe2df69 90bool migration_has_failed(MigrationState *);
859bc756 91MigrationState *migrate_get_current(void);
99a0db9b 92
adc56dda
BS
93uint64_t ram_bytes_remaining(void);
94uint64_t ram_bytes_transferred(void);
95uint64_t ram_bytes_total(void);
96
2b0ce079
MH
97void acct_update_position(QEMUFile *f, size_t size, bool zero);
98
7908c78d 99extern SaveVMHandlers savevm_ram_handlers;
adc56dda 100
004d4c10
OW
101uint64_t dup_mig_bytes_transferred(void);
102uint64_t dup_mig_pages_transferred(void);
f1c72795
PL
103uint64_t skipped_mig_bytes_transferred(void);
104uint64_t skipped_mig_pages_transferred(void);
004d4c10
OW
105uint64_t norm_mig_bytes_transferred(void);
106uint64_t norm_mig_pages_transferred(void);
f36d55af
OW
107uint64_t xbzrle_mig_bytes_transferred(void);
108uint64_t xbzrle_mig_pages_transferred(void);
109uint64_t xbzrle_mig_pages_overflow(void);
110uint64_t xbzrle_mig_pages_cache_miss(void);
004d4c10 111
fa2756b7
AL
112/**
113 * @migrate_add_blocker - prevent migration from proceeding
114 *
115 * @reason - an error to be returned whenever migration is attempted
116 */
117void migrate_add_blocker(Error *reason);
118
119/**
120 * @migrate_del_blocker - remove a blocking error from migration
121 *
122 * @reason - the error blocking migration
123 */
124void migrate_del_blocker(Error *reason);
125
60d9222c 126bool migrate_rdma_pin_all(void);
323004a3 127bool migrate_zero_blocks(void);
60d9222c 128
bde1e2ec
CV
129bool migrate_auto_converge(void);
130
302dfbeb
OW
131int xbzrle_encode_buffer(uint8_t *old_buf, uint8_t *new_buf, int slen,
132 uint8_t *dst, int dlen);
133int xbzrle_decode_buffer(uint8_t *src, int slen, uint8_t *dst, int dlen);
134
17ad9b35
OW
135int migrate_use_xbzrle(void);
136int64_t migrate_xbzrle_cache_size(void);
137
9e1ba4cc 138int64_t xbzrle_cache_resize(int64_t new_size);
43487c67
MH
139
140void ram_control_before_iterate(QEMUFile *f, uint64_t flags);
141void ram_control_after_iterate(QEMUFile *f, uint64_t flags);
142void ram_control_load_hook(QEMUFile *f, uint64_t flags);
143
144/* Whenever this is found in the data stream, the flags
145 * will be passed to ram_control_load_hook in the incoming-migration
146 * side. This lets before_ram_iterate/after_ram_iterate add
147 * transport-specific sections to the RAM migration data.
148 */
149#define RAM_SAVE_FLAG_HOOK 0x80
150
151#define RAM_SAVE_CONTROL_NOT_SUPP -1000
152#define RAM_SAVE_CONTROL_DELAYED -2000
153
154size_t ram_control_save_page(QEMUFile *f, ram_addr_t block_offset,
155 ram_addr_t offset, size_t size,
156 int *bytes_sent);
157
5bb7910a 158#endif