xref: /qemu/include/migration/misc.h (revision 9d9babf78d8f0a2f26b8dd5de3767bd4a4e2020e)
17b1e1a22SJuan Quintela /*
27b1e1a22SJuan Quintela  * QEMU migration miscellaneus exported functions
37b1e1a22SJuan Quintela  *
47b1e1a22SJuan Quintela  * Copyright IBM, Corp. 2008
57b1e1a22SJuan Quintela  *
67b1e1a22SJuan Quintela  * Authors:
77b1e1a22SJuan Quintela  *  Anthony Liguori   <aliguori@us.ibm.com>
87b1e1a22SJuan Quintela  *
97b1e1a22SJuan Quintela  * This work is licensed under the terms of the GNU GPL, version 2.  See
107b1e1a22SJuan Quintela  * the COPYING file in the top-level directory.
117b1e1a22SJuan Quintela  *
127b1e1a22SJuan Quintela  */
137b1e1a22SJuan Quintela 
147b1e1a22SJuan Quintela #ifndef MIGRATION_MISC_H
157b1e1a22SJuan Quintela #define MIGRATION_MISC_H
167b1e1a22SJuan Quintela 
171adc1ceeSJuan Quintela #include "qemu/notify.h"
18eea1e5c9SSteve Sistare #include "qapi/qapi-types-migration.h"
19ee3d96baSDr. David Alan Gilbert #include "qapi/qapi-types-net.h"
201adc1ceeSJuan Quintela 
217b1e1a22SJuan Quintela /* migration/ram.c */
227b1e1a22SJuan Quintela 
23bd227060SWei Wang typedef enum PrecopyNotifyReason {
24bd227060SWei Wang     PRECOPY_NOTIFY_SETUP = 0,
25bd227060SWei Wang     PRECOPY_NOTIFY_BEFORE_BITMAP_SYNC = 1,
26bd227060SWei Wang     PRECOPY_NOTIFY_AFTER_BITMAP_SYNC = 2,
27bd227060SWei Wang     PRECOPY_NOTIFY_COMPLETE = 3,
28bd227060SWei Wang     PRECOPY_NOTIFY_CLEANUP = 4,
29bd227060SWei Wang     PRECOPY_NOTIFY_MAX = 5,
30bd227060SWei Wang } PrecopyNotifyReason;
31bd227060SWei Wang 
32bd227060SWei Wang typedef struct PrecopyNotifyData {
33bd227060SWei Wang     enum PrecopyNotifyReason reason;
34bd227060SWei Wang } PrecopyNotifyData;
35bd227060SWei Wang 
36bd227060SWei Wang void precopy_infrastructure_init(void);
37bd227060SWei Wang void precopy_add_notifier(NotifierWithReturn *n);
38bd227060SWei Wang void precopy_remove_notifier(NotifierWithReturn *n);
39bd227060SWei Wang int precopy_notify(PrecopyNotifyReason reason, Error **errp);
40bd227060SWei Wang 
417b1e1a22SJuan Quintela void ram_mig_init(void);
426bcb05fcSWei Wang void qemu_guest_free_page_hint(void *addr, size_t len);
43f161c88aSDavid Hildenbrand bool migrate_ram_is_ignored(RAMBlock *block);
447b1e1a22SJuan Quintela 
452c9e6fecSJuan Quintela /* migration/block.c */
462c9e6fecSJuan Quintela 
472c9e6fecSJuan Quintela #ifdef CONFIG_LIVE_BLOCK_MIGRATION
482c9e6fecSJuan Quintela void blk_mig_init(void);
492c9e6fecSJuan Quintela #else
502c9e6fecSJuan Quintela static inline void blk_mig_init(void) {}
512c9e6fecSJuan Quintela #endif
522c9e6fecSJuan Quintela 
53ee3d96baSDr. David Alan Gilbert AnnounceParameters *migrate_announce_params(void);
54b7722747SJuan Quintela /* migration/savevm.c */
55b7722747SJuan Quintela 
56b7722747SJuan Quintela void dump_vmstate_json_to_file(FILE *out_fp);
57b7722747SJuan Quintela 
58c4b63b7cSJuan Quintela /* migration/migration.c */
59e5cb7e76SPeter Xu void migration_object_init(void);
60892ae715SDr. David Alan Gilbert void migration_shutdown(void);
61c4b63b7cSJuan Quintela bool migration_is_idle(void);
628f8d528eSWei Yang bool migration_is_active(MigrationState *);
63*9d9babf7SSteve Sistare 
64*9d9babf7SSteve Sistare typedef enum MigrationEventType {
65*9d9babf7SSteve Sistare     MIG_EVENT_PRECOPY_SETUP,
66*9d9babf7SSteve Sistare     MIG_EVENT_PRECOPY_DONE,
67*9d9babf7SSteve Sistare     MIG_EVENT_PRECOPY_FAILED,
68*9d9babf7SSteve Sistare     MIG_EVENT_MAX
69*9d9babf7SSteve Sistare } MigrationEventType;
70*9d9babf7SSteve Sistare 
71*9d9babf7SSteve Sistare typedef struct MigrationEvent {
72*9d9babf7SSteve Sistare     MigrationEventType type;
73*9d9babf7SSteve Sistare } MigrationEvent;
74*9d9babf7SSteve Sistare 
75*9d9babf7SSteve Sistare /*
76*9d9babf7SSteve Sistare  * Register the notifier @notify to be called when a migration event occurs
77*9d9babf7SSteve Sistare  * for MIG_MODE_NORMAL, as specified by the MigrationEvent passed to @func.
78*9d9babf7SSteve Sistare  * Notifiers may receive events in any of the following orders:
79*9d9babf7SSteve Sistare  *    - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_DONE
80*9d9babf7SSteve Sistare  *    - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_FAILED
81*9d9babf7SSteve Sistare  *    - MIG_EVENT_PRECOPY_FAILED
82*9d9babf7SSteve Sistare  */
833e775730SSteve Sistare void migration_add_notifier(NotifierWithReturn *notify,
843e775730SSteve Sistare                             NotifierWithReturnFunc func);
85*9d9babf7SSteve Sistare 
863e775730SSteve Sistare void migration_remove_notifier(NotifierWithReturn *notify);
87*9d9babf7SSteve Sistare void migration_call_notifiers(MigrationState *s, MigrationEventType type);
88c4b63b7cSJuan Quintela bool migration_in_setup(MigrationState *);
89c4b63b7cSJuan Quintela bool migration_has_finished(MigrationState *);
90c4b63b7cSJuan Quintela bool migration_has_failed(MigrationState *);
91c4b63b7cSJuan Quintela /* ...and after the device transmission */
92c4b63b7cSJuan Quintela bool migration_in_postcopy_after_devices(MigrationState *);
9380fe315cSDavid Hildenbrand /* True if incoming migration entered POSTCOPY_INCOMING_DISCARD */
9406df2e69SDavid Hildenbrand bool migration_in_incoming_postcopy(void);
9580fe315cSDavid Hildenbrand /* True if incoming migration entered POSTCOPY_INCOMING_ADVISE */
9680fe315cSDavid Hildenbrand bool migration_incoming_postcopy_advised(void);
971a8e44a8SAndrey Gruzdev /* True if background snapshot is active */
981a8e44a8SAndrey Gruzdev bool migration_in_bg_snapshot(void);
993df663e5SPeter Xu 
100b35ebdf0SVladimir Sementsov-Ogievskiy /* migration/block-dirty-bitmap.c */
101b35ebdf0SVladimir Sementsov-Ogievskiy void dirty_bitmap_mig_init(void);
102b35ebdf0SVladimir Sementsov-Ogievskiy 
1037b1e1a22SJuan Quintela #endif
104