 9867d4ddd0
			
		
	
	
		9867d4ddd0
		
	
	
	
	
		
			
			When migration for cpr is initiated, stop the vm and set state RUN_STATE_FINISH_MIGRATE before ram is saved. This eliminates the possibility of ram and device state being out of sync, and guarantees that a guest in the suspended state remains suspended, because qmp_cont rejects a cont command in the RUN_STATE_FINISH_MIGRATE state. Signed-off-by: Steve Sistare <steven.sistare@oracle.com> Reviewed-by: Peter Xu <peterx@redhat.com> Link: https://lore.kernel.org/r/1708622920-68779-11-git-send-email-steven.sistare@oracle.com Signed-off-by: Peter Xu <peterx@redhat.com>
		
			
				
	
	
		
			119 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * QEMU migration miscellaneus exported functions
 | |
|  *
 | |
|  * Copyright IBM, Corp. 2008
 | |
|  *
 | |
|  * Authors:
 | |
|  *  Anthony Liguori   <aliguori@us.ibm.com>
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2.  See
 | |
|  * the COPYING file in the top-level directory.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef MIGRATION_MISC_H
 | |
| #define MIGRATION_MISC_H
 | |
| 
 | |
| #include "qemu/notify.h"
 | |
| #include "qapi/qapi-types-migration.h"
 | |
| #include "qapi/qapi-types-net.h"
 | |
| 
 | |
| /* migration/ram.c */
 | |
| 
 | |
| typedef enum PrecopyNotifyReason {
 | |
|     PRECOPY_NOTIFY_SETUP = 0,
 | |
|     PRECOPY_NOTIFY_BEFORE_BITMAP_SYNC = 1,
 | |
|     PRECOPY_NOTIFY_AFTER_BITMAP_SYNC = 2,
 | |
|     PRECOPY_NOTIFY_COMPLETE = 3,
 | |
|     PRECOPY_NOTIFY_CLEANUP = 4,
 | |
|     PRECOPY_NOTIFY_MAX = 5,
 | |
| } PrecopyNotifyReason;
 | |
| 
 | |
| typedef struct PrecopyNotifyData {
 | |
|     enum PrecopyNotifyReason reason;
 | |
| } PrecopyNotifyData;
 | |
| 
 | |
| void precopy_infrastructure_init(void);
 | |
| void precopy_add_notifier(NotifierWithReturn *n);
 | |
| void precopy_remove_notifier(NotifierWithReturn *n);
 | |
| int precopy_notify(PrecopyNotifyReason reason, Error **errp);
 | |
| 
 | |
| void ram_mig_init(void);
 | |
| void qemu_guest_free_page_hint(void *addr, size_t len);
 | |
| bool migrate_ram_is_ignored(RAMBlock *block);
 | |
| 
 | |
| /* migration/block.c */
 | |
| 
 | |
| #ifdef CONFIG_LIVE_BLOCK_MIGRATION
 | |
| void blk_mig_init(void);
 | |
| #else
 | |
| static inline void blk_mig_init(void) {}
 | |
| #endif
 | |
| 
 | |
| AnnounceParameters *migrate_announce_params(void);
 | |
| /* migration/savevm.c */
 | |
| 
 | |
| void dump_vmstate_json_to_file(FILE *out_fp);
 | |
| 
 | |
| /* migration/migration.c */
 | |
| void migration_object_init(void);
 | |
| void migration_shutdown(void);
 | |
| bool migration_is_idle(void);
 | |
| bool migration_is_active(MigrationState *);
 | |
| bool migrate_mode_is_cpr(MigrationState *);
 | |
| 
 | |
| typedef enum MigrationEventType {
 | |
|     MIG_EVENT_PRECOPY_SETUP,
 | |
|     MIG_EVENT_PRECOPY_DONE,
 | |
|     MIG_EVENT_PRECOPY_FAILED,
 | |
|     MIG_EVENT_MAX
 | |
| } MigrationEventType;
 | |
| 
 | |
| typedef struct MigrationEvent {
 | |
|     MigrationEventType type;
 | |
| } MigrationEvent;
 | |
| 
 | |
| /*
 | |
|  * A MigrationNotifyFunc may return an error code and an Error object,
 | |
|  * but only when @e->type is MIG_EVENT_PRECOPY_SETUP.  The code is an int
 | |
|  * to allow for different failure modes and recovery actions.
 | |
|  */
 | |
| typedef int (*MigrationNotifyFunc)(NotifierWithReturn *notify,
 | |
|                                    MigrationEvent *e, Error **errp);
 | |
| 
 | |
| /*
 | |
|  * Register the notifier @notify to be called when a migration event occurs
 | |
|  * for MIG_MODE_NORMAL, as specified by the MigrationEvent passed to @func.
 | |
|  * Notifiers may receive events in any of the following orders:
 | |
|  *    - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_DONE
 | |
|  *    - MIG_EVENT_PRECOPY_SETUP -> MIG_EVENT_PRECOPY_FAILED
 | |
|  *    - MIG_EVENT_PRECOPY_FAILED
 | |
|  */
 | |
| void migration_add_notifier(NotifierWithReturn *notify,
 | |
|                             MigrationNotifyFunc func);
 | |
| 
 | |
| /*
 | |
|  * Same as migration_add_notifier, but applies to be specified @mode.
 | |
|  */
 | |
| void migration_add_notifier_mode(NotifierWithReturn *notify,
 | |
|                                  MigrationNotifyFunc func, MigMode mode);
 | |
| 
 | |
| void migration_remove_notifier(NotifierWithReturn *notify);
 | |
| int migration_call_notifiers(MigrationState *s, MigrationEventType type,
 | |
|                              Error **errp);
 | |
| bool migration_in_setup(MigrationState *);
 | |
| bool migration_has_finished(MigrationState *);
 | |
| bool migration_has_failed(MigrationState *);
 | |
| /* ...and after the device transmission */
 | |
| /* True if incoming migration entered POSTCOPY_INCOMING_DISCARD */
 | |
| bool migration_in_incoming_postcopy(void);
 | |
| /* True if incoming migration entered POSTCOPY_INCOMING_ADVISE */
 | |
| bool migration_incoming_postcopy_advised(void);
 | |
| /* True if background snapshot is active */
 | |
| bool migration_in_bg_snapshot(void);
 | |
| 
 | |
| /* migration/block-dirty-bitmap.c */
 | |
| void dirty_bitmap_mig_init(void);
 | |
| 
 | |
| #endif
 |