xref: /openbmc/qemu/include/migration/misc.h (revision f3bff6c4)
1 /*
2  * QEMU migration miscellaneus exported functions
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 MIGRATION_MISC_H
15 #define MIGRATION_MISC_H
16 
17 #include "qemu/notify.h"
18 #include "qapi/qapi-types-migration.h"
19 #include "qapi/qapi-types-net.h"
20 #include "migration/client-options.h"
21 
22 /* migration/ram.c */
23 
24 typedef enum PrecopyNotifyReason {
25     PRECOPY_NOTIFY_SETUP = 0,
26     PRECOPY_NOTIFY_BEFORE_BITMAP_SYNC = 1,
27     PRECOPY_NOTIFY_AFTER_BITMAP_SYNC = 2,
28     PRECOPY_NOTIFY_COMPLETE = 3,
29     PRECOPY_NOTIFY_CLEANUP = 4,
30     PRECOPY_NOTIFY_MAX = 5,
31 } PrecopyNotifyReason;
32 
33 typedef struct PrecopyNotifyData {
34     enum PrecopyNotifyReason reason;
35 } PrecopyNotifyData;
36 
37 void precopy_infrastructure_init(void);
38 void precopy_add_notifier(NotifierWithReturn *n);
39 void precopy_remove_notifier(NotifierWithReturn *n);
40 int precopy_notify(PrecopyNotifyReason reason, Error **errp);
41 
42 void ram_mig_init(void);
43 void qemu_guest_free_page_hint(void *addr, size_t len);
44 bool migrate_ram_is_ignored(RAMBlock *block);
45 
46 /* migration/block.c */
47 
48 #ifdef CONFIG_LIVE_BLOCK_MIGRATION
49 void blk_mig_init(void);
50 #else
51 static inline void blk_mig_init(void) {}
52 #endif
53 
54 AnnounceParameters *migrate_announce_params(void);
55 /* migration/savevm.c */
56 
57 void dump_vmstate_json_to_file(FILE *out_fp);
58 
59 /* migration/migration.c */
60 void migration_object_init(void);
61 void migration_shutdown(void);
62 bool migration_is_idle(void);
63 bool migration_is_active(MigrationState *);
64 bool migrate_mode_is_cpr(MigrationState *);
65 
66 typedef enum MigrationEventType {
67     MIG_EVENT_PRECOPY_SETUP,
68     MIG_EVENT_PRECOPY_DONE,
69     MIG_EVENT_PRECOPY_FAILED,
70     MIG_EVENT_MAX
71 } MigrationEventType;
72 
73 typedef struct MigrationEvent {
74     MigrationEventType type;
75 } MigrationEvent;
76 
77 /*
78  * A MigrationNotifyFunc may return an error code and an Error object,
79  * but only when @e->type is MIG_EVENT_PRECOPY_SETUP.  The code is an int
80  * to allow for different failure modes and recovery actions.
81  */
82 typedef int (*MigrationNotifyFunc)(NotifierWithReturn *notify,
83                                    MigrationEvent *e, Error **errp);
84 
85 /*
86  * Register the notifier @notify to be called when a migration event occurs
87  * for MIG_MODE_NORMAL, as specified by the MigrationEvent passed to @func.
88  * Notifiers may receive events in any of the following orders:
89  *    - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_DONE
90  *    - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_FAILED
91  *    - MIG_EVENT_PRECOPY_FAILED
92  */
93 void migration_add_notifier(NotifierWithReturn *notify,
94                             MigrationNotifyFunc func);
95 
96 /*
97  * Same as migration_add_notifier, but applies to be specified @mode.
98  */
99 void migration_add_notifier_mode(NotifierWithReturn *notify,
100                                  MigrationNotifyFunc func, MigMode mode);
101 
102 void migration_remove_notifier(NotifierWithReturn *notify);
103 int migration_call_notifiers(MigrationState *s, MigrationEventType type,
104                              Error **errp);
105 bool migration_in_setup(MigrationState *);
106 bool migration_has_finished(MigrationState *);
107 bool migration_has_failed(MigrationState *);
108 /* ...and after the device transmission */
109 /* True if incoming migration entered POSTCOPY_INCOMING_DISCARD */
110 bool migration_in_incoming_postcopy(void);
111 /* True if incoming migration entered POSTCOPY_INCOMING_ADVISE */
112 bool migration_incoming_postcopy_advised(void);
113 /* True if background snapshot is active */
114 bool migration_in_bg_snapshot(void);
115 
116 /* migration/block-dirty-bitmap.c */
117 void dirty_bitmap_mig_init(void);
118 
119 #endif
120