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" 20f3bff6c4SSteve Sistare #include "migration/client-options.h" 211adc1ceeSJuan Quintela 227b1e1a22SJuan Quintela /* migration/ram.c */ 237b1e1a22SJuan Quintela 24bd227060SWei Wang typedef enum PrecopyNotifyReason { 25bd227060SWei Wang PRECOPY_NOTIFY_SETUP = 0, 26bd227060SWei Wang PRECOPY_NOTIFY_BEFORE_BITMAP_SYNC = 1, 27bd227060SWei Wang PRECOPY_NOTIFY_AFTER_BITMAP_SYNC = 2, 28bd227060SWei Wang PRECOPY_NOTIFY_COMPLETE = 3, 29bd227060SWei Wang PRECOPY_NOTIFY_CLEANUP = 4, 30bd227060SWei Wang PRECOPY_NOTIFY_MAX = 5, 31bd227060SWei Wang } PrecopyNotifyReason; 32bd227060SWei Wang 33bd227060SWei Wang typedef struct PrecopyNotifyData { 34bd227060SWei Wang enum PrecopyNotifyReason reason; 35bd227060SWei Wang } PrecopyNotifyData; 36bd227060SWei Wang 37bd227060SWei Wang void precopy_infrastructure_init(void); 38bd227060SWei Wang void precopy_add_notifier(NotifierWithReturn *n); 39bd227060SWei Wang void precopy_remove_notifier(NotifierWithReturn *n); 40bd227060SWei Wang int precopy_notify(PrecopyNotifyReason reason, Error **errp); 41bd227060SWei Wang 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 47ee3d96baSDr. David Alan Gilbert AnnounceParameters *migrate_announce_params(void); 48b1937fd1SMaciej S. Szmigiero 49b7722747SJuan Quintela /* migration/savevm.c */ 50b7722747SJuan Quintela 51b7722747SJuan Quintela void dump_vmstate_json_to_file(FILE *out_fp); 52b1937fd1SMaciej S. Szmigiero void qemu_loadvm_start_load_thread(MigrationLoadThread function, 53b1937fd1SMaciej S. Szmigiero void *opaque); 54b7722747SJuan Quintela 55c4b63b7cSJuan Quintela /* migration/migration.c */ 56e5cb7e76SPeter Xu void migration_object_init(void); 57892ae715SDr. David Alan Gilbert void migration_shutdown(void); 58f018eb62SPeter Xu 59f018eb62SPeter Xu bool migration_is_running(void); 606e785639SSteve Sistare bool migration_thread_is_self(void); 619d9babf7SSteve Sistare 629d9babf7SSteve Sistare typedef enum MigrationEventType { 639d9babf7SSteve Sistare MIG_EVENT_PRECOPY_SETUP, 649d9babf7SSteve Sistare MIG_EVENT_PRECOPY_DONE, 659d9babf7SSteve Sistare MIG_EVENT_PRECOPY_FAILED, 669d9babf7SSteve Sistare MIG_EVENT_MAX 679d9babf7SSteve Sistare } MigrationEventType; 689d9babf7SSteve Sistare 699d9babf7SSteve Sistare typedef struct MigrationEvent { 709d9babf7SSteve Sistare MigrationEventType type; 719d9babf7SSteve Sistare } MigrationEvent; 729d9babf7SSteve Sistare 734af667f8SSteve Sistare /* 744af667f8SSteve Sistare * A MigrationNotifyFunc may return an error code and an Error object, 754af667f8SSteve Sistare * but only when @e->type is MIG_EVENT_PRECOPY_SETUP. The code is an int 764af667f8SSteve Sistare * to allow for different failure modes and recovery actions. 774af667f8SSteve Sistare */ 785663dd3fSSteve Sistare typedef int (*MigrationNotifyFunc)(NotifierWithReturn *notify, 795663dd3fSSteve Sistare MigrationEvent *e, Error **errp); 805663dd3fSSteve Sistare 819d9babf7SSteve Sistare /* 829d9babf7SSteve Sistare * Register the notifier @notify to be called when a migration event occurs 839d9babf7SSteve Sistare * for MIG_MODE_NORMAL, as specified by the MigrationEvent passed to @func. 849d9babf7SSteve Sistare * Notifiers may receive events in any of the following orders: 859d9babf7SSteve Sistare * - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_DONE 869d9babf7SSteve Sistare * - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_FAILED 879d9babf7SSteve Sistare * - MIG_EVENT_PRECOPY_FAILED 889d9babf7SSteve Sistare */ 893e775730SSteve Sistare void migration_add_notifier(NotifierWithReturn *notify, 905663dd3fSSteve Sistare MigrationNotifyFunc func); 919d9babf7SSteve Sistare 926835f5a1SSteve Sistare /* 936835f5a1SSteve Sistare * Same as migration_add_notifier, but applies to be specified @mode. 946835f5a1SSteve Sistare */ 956835f5a1SSteve Sistare void migration_add_notifier_mode(NotifierWithReturn *notify, 966835f5a1SSteve Sistare MigrationNotifyFunc func, MigMode mode); 976835f5a1SSteve Sistare 983e775730SSteve Sistare void migration_remove_notifier(NotifierWithReturn *notify); 99019d9e6cSCédric Le Goater void migration_file_set_error(int ret, Error *err); 10020c64c8aSSteve Sistare 10180fe315cSDavid Hildenbrand /* True if incoming migration entered POSTCOPY_INCOMING_DISCARD */ 10206df2e69SDavid Hildenbrand bool migration_in_incoming_postcopy(void); 103c9539d9bSSteve Sistare 10480fe315cSDavid Hildenbrand /* True if incoming migration entered POSTCOPY_INCOMING_ADVISE */ 10580fe315cSDavid Hildenbrand bool migration_incoming_postcopy_advised(void); 106c9539d9bSSteve Sistare 1071a8e44a8SAndrey Gruzdev /* True if background snapshot is active */ 1081a8e44a8SAndrey Gruzdev bool migration_in_bg_snapshot(void); 1093df663e5SPeter Xu 1108597af76SPeter Xu /* Wrapper for block active/inactive operations */ 1118597af76SPeter Xu bool migration_block_activate(Error **errp); 1128597af76SPeter Xu bool migration_block_inactivate(void); 1138597af76SPeter Xu 114f2374f0fSSteve Sistare /* True if @uri starts with a syntactically valid URI prefix */ 115f2374f0fSSteve Sistare bool migrate_is_uri(const char *uri); 116f2374f0fSSteve Sistare 117f2374f0fSSteve Sistare /* Parse @uri and return @channel, returning true on success */ 118f2374f0fSSteve Sistare bool migrate_uri_parse(const char *uri, MigrationChannel **channel, 119f2374f0fSSteve Sistare Error **errp); 120f2374f0fSSteve Sistare 1210525b91aSMaciej S. Szmigiero /* migration/multifd-device-state.c */ 122*8305921aSMaciej S. Szmigiero typedef struct SaveLiveCompletePrecopyThreadData { 123*8305921aSMaciej S. Szmigiero SaveLiveCompletePrecopyThreadHandler hdlr; 124*8305921aSMaciej S. Szmigiero char *idstr; 125*8305921aSMaciej S. Szmigiero uint32_t instance_id; 126*8305921aSMaciej S. Szmigiero void *handler_opaque; 127*8305921aSMaciej S. Szmigiero } SaveLiveCompletePrecopyThreadData; 128*8305921aSMaciej S. Szmigiero 1290525b91aSMaciej S. Szmigiero bool multifd_queue_device_state(char *idstr, uint32_t instance_id, 1300525b91aSMaciej S. Szmigiero char *data, size_t len); 131a1131aa9SMaciej S. Szmigiero bool multifd_device_state_supported(void); 1320525b91aSMaciej S. Szmigiero 133*8305921aSMaciej S. Szmigiero void 134*8305921aSMaciej S. Szmigiero multifd_spawn_device_state_save_thread(SaveLiveCompletePrecopyThreadHandler hdlr, 135*8305921aSMaciej S. Szmigiero char *idstr, uint32_t instance_id, 136*8305921aSMaciej S. Szmigiero void *opaque); 137*8305921aSMaciej S. Szmigiero 138*8305921aSMaciej S. Szmigiero bool multifd_device_state_save_thread_should_exit(void); 139*8305921aSMaciej S. Szmigiero 140*8305921aSMaciej S. Szmigiero void multifd_abort_device_state_save_threads(void); 141*8305921aSMaciej S. Szmigiero bool multifd_join_device_state_save_threads(void); 142*8305921aSMaciej S. Szmigiero 1437b1e1a22SJuan Quintela #endif 144