blob: e2acec64c0b1c95e53fdccaa2a64657509bb9d06 [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
Paolo Bonzini7b1b5d12012-12-17 18:19:43 +010017#include "qapi/qmp/qdict.h"
aliguori376253e2009-03-05 23:01:23 +000018#include "qemu-common.h"
Juan Quintela9848a402012-12-19 09:55:50 +010019#include "qemu/thread.h"
Paolo Bonzini1de7afc2012-12-17 18:20:00 +010020#include "qemu/notify.h"
Paolo Bonzini7b1b5d12012-12-17 18:19:43 +010021#include "qapi/error.h"
Paolo Bonzinicaf71f82012-12-17 18:19:50 +010022#include "migration/vmstate.h"
Orit Wassermanbbf6da32012-08-06 21:42:47 +030023#include "qapi-types.h"
aliguori376253e2009-03-05 23:01:23 +000024
Isaku Yamahata6607ae22012-06-19 18:43:09 +030025struct MigrationParams {
26 bool blk;
27 bool shared;
28};
29
Juan Quintela22f00a42010-05-11 15:56:35 +020030typedef struct MigrationState MigrationState;
Juan Quinteladc7acc62010-05-11 15:46:39 +020031
Juan Quintela22f00a42010-05-11 15:56:35 +020032struct MigrationState
aliguori065e2812008-11-11 16:46:33 +000033{
aliguori065e2812008-11-11 16:46:33 +000034 int64_t bandwidth_limit;
Juan Quintela9848a402012-12-19 09:55:50 +010035 size_t bytes_xfer;
36 size_t xfer_limit;
Juan Quintela9848a402012-12-19 09:55:50 +010037 QemuThread thread;
Paolo Bonzinibb1fadc2013-02-22 17:36:21 +010038 QEMUBH *cleanup_bh;
aliguori065e2812008-11-11 16:46:33 +000039 QEMUFile *file;
Paolo Bonzinif8bbc122013-02-22 17:36:41 +010040
Paolo Bonzinif8bbc122013-02-22 17:36:41 +010041 int state;
Isaku Yamahata6607ae22012-06-19 18:43:09 +030042 MigrationParams params;
Juan Quintelad5f8a572012-05-21 22:01:07 +020043 int64_t total_time;
Juan Quintela9c5a9fc2012-08-13 09:35:16 +020044 int64_t downtime;
Juan Quintela2c52ddf2012-08-13 09:53:12 +020045 int64_t expected_downtime;
Juan Quintela8d017192012-08-13 12:31:25 +020046 int64_t dirty_pages_rate;
Juan Quintela90f8ae72013-02-01 13:22:37 +010047 int64_t dirty_bytes_rate;
Orit Wassermanbbf6da32012-08-06 21:42:47 +030048 bool enabled_capabilities[MIGRATION_CAPABILITY_MAX];
Orit Wasserman17ad9b32012-08-06 21:42:53 +030049 int64_t xbzrle_cache_size;
aliguori065e2812008-11-11 16:46:33 +000050};
51
Juan Quintela511c0232010-06-09 14:10:55 +020052void process_incoming_migration(QEMUFile *f);
53
Paolo Bonzini43eaae22012-10-02 18:21:18 +020054void qemu_start_incoming_migration(const char *uri, Error **errp);
aliguori5bb79102008-10-13 03:12:02 +000055
Glauber Costaa0a3fd62009-05-28 15:22:57 -040056uint64_t migrate_max_downtime(void);
57
Luiz Capitulinoc86a6682009-12-10 17:16:05 -020058void do_info_migrate_print(Monitor *mon, const QObject *data);
59
60void do_info_migrate(Monitor *mon, QObject **ret_data);
aliguori5bb79102008-10-13 03:12:02 +000061
Paolo Bonzini43eaae22012-10-02 18:21:18 +020062void exec_start_incoming_migration(const char *host_port, Error **errp);
aliguori065e2812008-11-11 16:46:33 +000063
Paolo Bonzinif37afb52012-10-02 10:02:46 +020064void exec_start_outgoing_migration(MigrationState *s, const char *host_port, Error **errp);
aliguori065e2812008-11-11 16:46:33 +000065
Paolo Bonzini43eaae22012-10-02 18:21:18 +020066void tcp_start_incoming_migration(const char *host_port, Error **errp);
aliguori34c9dd82008-10-13 03:14:31 +000067
Paolo Bonzinif37afb52012-10-02 10:02:46 +020068void tcp_start_outgoing_migration(MigrationState *s, const char *host_port, Error **errp);
aliguori34c9dd82008-10-13 03:14:31 +000069
Paolo Bonzini43eaae22012-10-02 18:21:18 +020070void unix_start_incoming_migration(const char *path, Error **errp);
Chris Lalancette4951f652009-08-05 17:24:29 +020071
Paolo Bonzinif37afb52012-10-02 10:02:46 +020072void unix_start_outgoing_migration(MigrationState *s, const char *path, Error **errp);
Chris Lalancette4951f652009-08-05 17:24:29 +020073
Paolo Bonzini43eaae22012-10-02 18:21:18 +020074void fd_start_incoming_migration(const char *path, Error **errp);
Paolo Bonzini5ac1fad2009-08-18 15:56:25 +020075
Paolo Bonzinif37afb52012-10-02 10:02:46 +020076void fd_start_outgoing_migration(MigrationState *s, const char *fdname, Error **errp);
Paolo Bonzini5ac1fad2009-08-18 15:56:25 +020077
Juan Quintela22f00a42010-05-11 15:56:35 +020078void migrate_fd_error(MigrationState *s);
aliguori065e2812008-11-11 16:46:33 +000079
Juan Quintela22f00a42010-05-11 15:56:35 +020080void migrate_fd_connect(MigrationState *s);
aliguori065e2812008-11-11 16:46:33 +000081
Juan Quintela11c76742012-07-20 13:19:36 +020082int migrate_fd_close(MigrationState *s);
Juan Quintelac87b0152012-07-20 13:10:54 +020083
Gerd Hoffmann99a0db92010-12-13 17:30:12 +010084void add_migration_state_change_notifier(Notifier *notify);
85void remove_migration_state_change_notifier(Notifier *notify);
Gerd Hoffmannafe2df62011-10-25 13:50:11 +020086bool migration_is_active(MigrationState *);
Juan Quintela70736932011-02-23 00:43:59 +010087bool migration_has_finished(MigrationState *);
Gerd Hoffmannafe2df62011-10-25 13:50:11 +020088bool migration_has_failed(MigrationState *);
Juan Quintela859bc752012-08-13 09:42:49 +020089MigrationState *migrate_get_current(void);
Gerd Hoffmann99a0db92010-12-13 17:30:12 +010090
Blue Swirladc56dd2011-04-03 08:23:19 +000091uint64_t ram_bytes_remaining(void);
92uint64_t ram_bytes_transferred(void);
93uint64_t ram_bytes_total(void);
94
Juan Quintela7908c782012-06-26 18:46:10 +020095extern SaveVMHandlers savevm_ram_handlers;
Blue Swirladc56dd2011-04-03 08:23:19 +000096
Orit Wasserman004d4c12012-08-06 21:42:56 +030097uint64_t dup_mig_bytes_transferred(void);
98uint64_t dup_mig_pages_transferred(void);
Peter Lievenf1c72792013-03-26 10:58:37 +010099uint64_t skipped_mig_bytes_transferred(void);
100uint64_t skipped_mig_pages_transferred(void);
Orit Wasserman004d4c12012-08-06 21:42:56 +0300101uint64_t norm_mig_bytes_transferred(void);
102uint64_t norm_mig_pages_transferred(void);
Orit Wassermanf36d55a2012-08-06 21:42:57 +0300103uint64_t xbzrle_mig_bytes_transferred(void);
104uint64_t xbzrle_mig_pages_transferred(void);
105uint64_t xbzrle_mig_pages_overflow(void);
106uint64_t xbzrle_mig_pages_cache_miss(void);
Orit Wasserman004d4c12012-08-06 21:42:56 +0300107
Anthony Liguorifa2756b2011-11-14 15:09:43 -0600108/**
109 * @migrate_add_blocker - prevent migration from proceeding
110 *
111 * @reason - an error to be returned whenever migration is attempted
112 */
113void migrate_add_blocker(Error *reason);
114
115/**
116 * @migrate_del_blocker - remove a blocking error from migration
117 *
118 * @reason - the error blocking migration
119 */
120void migrate_del_blocker(Error *reason);
121
Orit Wasserman302dfbe2012-08-06 21:42:52 +0300122int xbzrle_encode_buffer(uint8_t *old_buf, uint8_t *new_buf, int slen,
123 uint8_t *dst, int dlen);
124int xbzrle_decode_buffer(uint8_t *src, int slen, uint8_t *dst, int dlen);
125
Orit Wasserman17ad9b32012-08-06 21:42:53 +0300126int migrate_use_xbzrle(void);
127int64_t migrate_xbzrle_cache_size(void);
128
Orit Wasserman9e1ba4c2012-08-06 21:42:54 +0300129int64_t xbzrle_cache_resize(int64_t new_size);
aliguori5bb79102008-10-13 03:12:02 +0000130#endif