}
type = migration_has_failed(s) ? MIG_EVENT_PRECOPY_FAILED :
MIG_EVENT_PRECOPY_DONE;
- migration_call_notifiers(s, type, NULL);
+ migration_call_notifiers(type, NULL);
yank_unregister_instance(MIGRATION_YANK_INSTANCE);
}
}
}
-int migration_call_notifiers(MigrationState *s, MigrationEventType type,
- Error **errp)
+int migration_call_notifiers(MigrationEventType type, Error **errp)
{
- MigMode mode = s->parameters.mode;
+ MigMode mode = migrate_mode();
MigrationEvent e;
NotifierWithReturn *notifier;
GSList *elem, *next;
return qemu_thread_is_self(&s->thread);
}
-bool migrate_mode_is_cpr(MigrationState *s)
+bool migrate_mode_is_cpr(void)
{
- MigMode mode = s->parameters.mode;
+ MigMode mode = migrate_mode();
return mode == MIG_MODE_CPR_REBOOT ||
mode == MIG_MODE_CPR_TRANSFER ||
mode == MIG_MODE_CPR_EXEC;
}
}
- if (migrate_mode_is_cpr(s)) {
+ if (migrate_mode_is_cpr()) {
const char *conflict = NULL;
if (migrate_postcopy()) {
return;
}
- if (s->parameters.mode == MIG_MODE_CPR_TRANSFER && !cpr_channel) {
+ if (migrate_mode() == MIG_MODE_CPR_TRANSFER && !cpr_channel) {
error_setg(errp, "missing 'cpr' migration channel");
return;
}
* in which case the target will not listen for the incoming migration
* connection, so qmp_migrate_finish will fail to connect, and then recover.
*/
- if (s->parameters.mode == MIG_MODE_CPR_TRANSFER) {
+ if (migrate_mode() == MIG_MODE_CPR_TRANSFER) {
migrate_hup_add(s, cpr_state_ioc(), (GSourceFunc)qmp_migrate_finish_cb,
QAPI_CLONE(MigrationAddress, addr));
* at the transition to postcopy and after the device state; in particular
* spice needs to trigger a transition now
*/
- migration_call_notifiers(ms, MIG_EVENT_PRECOPY_DONE, NULL);
+ migration_call_notifiers(MIG_EVENT_PRECOPY_DONE, NULL);
migration_downtime_end(ms);
migrate_set_state(&ms->state, ms->state, MIGRATION_STATUS_FAILED);
}
migration_block_activate(NULL);
- migration_call_notifiers(ms, MIG_EVENT_PRECOPY_FAILED, NULL);
+ migration_call_notifiers(MIG_EVENT_PRECOPY_FAILED, NULL);
bql_unlock();
return -1;
}
bql_lock();
- if (!migrate_mode_is_cpr(s)) {
+ if (!migrate_mode_is_cpr()) {
ret = migration_stop_vm(s, RUN_STATE_FINISH_MIGRATE);
if (ret < 0) {
goto out_unlock;
rate_limit = migrate_max_bandwidth();
/* Notify before starting migration thread */
- if (migration_call_notifiers(s, MIG_EVENT_PRECOPY_SETUP, &local_err)) {
+ if (migration_call_notifiers(MIG_EVENT_PRECOPY_SETUP, &local_err)) {
goto fail;
}
}
return;
}
- if (migrate_mode_is_cpr(s)) {
+ if (migrate_mode_is_cpr()) {
ret = migration_stop_vm(s, RUN_STATE_FINISH_MIGRATE);
if (ret < 0) {
error_setg(&local_err, "migration_stop_vm failed, error %d", -ret);
void migration_connect(MigrationState *s, Error *error_in);
-int migration_call_notifiers(MigrationState *s, MigrationEventType type,
- Error **errp);
+int migration_call_notifiers(MigrationEventType type, Error **errp);
int migrate_init(MigrationState *s, Error **errp);
bool migration_is_blocked(Error **errp);
bool migration_postcopy_is_alive(MigrationStatus state);
MigrationState *migrate_get_current(void);
bool migration_has_failed(MigrationState *);
-bool migrate_mode_is_cpr(MigrationState *);
+bool migrate_mode_is_cpr(void);
uint64_t ram_get_total_transferred_pages(void);