xref: /openbmc/qemu/migration/colo.c (revision b89350e83044ee6e6e6628dd99845f3d1f53bd52)
1 /*
2  * COarse-grain LOck-stepping Virtual Machines for Non-stop Service (COLO)
3  * (a.k.a. Fault Tolerance or Continuous Replication)
4  *
5  * Copyright (c) 2016 HUAWEI TECHNOLOGIES CO., LTD.
6  * Copyright (c) 2016 FUJITSU LIMITED
7  * Copyright (c) 2016 Intel Corporation
8  *
9  * This work is licensed under the terms of the GNU GPL, version 2 or
10  * later.  See the COPYING file in the top-level directory.
11  */
12 
13 #include "qemu/osdep.h"
14 #include "sysemu/sysemu.h"
15 #include "qapi/error.h"
16 #include "qapi/qapi-commands-migration.h"
17 #include "migration.h"
18 #include "qemu-file.h"
19 #include "savevm.h"
20 #include "migration/colo.h"
21 #include "block.h"
22 #include "io/channel-buffer.h"
23 #include "trace.h"
24 #include "qemu/error-report.h"
25 #include "qemu/main-loop.h"
26 #include "qemu/rcu.h"
27 #include "migration/failover.h"
28 #include "migration/ram.h"
29 #ifdef CONFIG_REPLICATION
30 #include "block/replication.h"
31 #endif
32 #include "net/colo-compare.h"
33 #include "net/colo.h"
34 #include "block/block.h"
35 #include "qapi/qapi-events-migration.h"
36 #include "qapi/qmp/qerror.h"
37 #include "sysemu/cpus.h"
38 #include "sysemu/runstate.h"
39 #include "net/filter.h"
40 
41 static bool vmstate_loading;
42 static Notifier packets_compare_notifier;
43 
44 /* User need to know colo mode after COLO failover */
45 static COLOMode last_colo_mode;
46 
47 #define COLO_BUFFER_BASE_SIZE (4 * 1024 * 1024)
48 
49 bool migration_in_colo_state(void)
50 {
51     MigrationState *s = migrate_get_current();
52 
53     return (s->state == MIGRATION_STATUS_COLO);
54 }
55 
56 bool migration_incoming_in_colo_state(void)
57 {
58     MigrationIncomingState *mis = migration_incoming_get_current();
59 
60     return mis && (mis->state == MIGRATION_STATUS_COLO);
61 }
62 
63 static bool colo_runstate_is_stopped(void)
64 {
65     return runstate_check(RUN_STATE_COLO) || !runstate_is_running();
66 }
67 
68 static void secondary_vm_do_failover(void)
69 {
70 /* COLO needs enable block-replication */
71 #ifdef CONFIG_REPLICATION
72     int old_state;
73     MigrationIncomingState *mis = migration_incoming_get_current();
74     Error *local_err = NULL;
75 
76     /* Can not do failover during the process of VM's loading VMstate, Or
77      * it will break the secondary VM.
78      */
79     if (vmstate_loading) {
80         old_state = failover_set_state(FAILOVER_STATUS_ACTIVE,
81                         FAILOVER_STATUS_RELAUNCH);
82         if (old_state != FAILOVER_STATUS_ACTIVE) {
83             error_report("Unknown error while do failover for secondary VM,"
84                          "old_state: %s", FailoverStatus_str(old_state));
85         }
86         return;
87     }
88 
89     migrate_set_state(&mis->state, MIGRATION_STATUS_COLO,
90                       MIGRATION_STATUS_COMPLETED);
91 
92     replication_stop_all(true, &local_err);
93     if (local_err) {
94         error_report_err(local_err);
95         local_err = NULL;
96     }
97 
98     /* Notify all filters of all NIC to do checkpoint */
99     colo_notify_filters_event(COLO_EVENT_FAILOVER, &local_err);
100     if (local_err) {
101         error_report_err(local_err);
102     }
103 
104     if (!autostart) {
105         error_report("\"-S\" qemu option will be ignored in secondary side");
106         /* recover runstate to normal migration finish state */
107         autostart = true;
108     }
109     /*
110      * Make sure COLO incoming thread not block in recv or send,
111      * If mis->from_src_file and mis->to_src_file use the same fd,
112      * The second shutdown() will return -1, we ignore this value,
113      * It is harmless.
114      */
115     if (mis->from_src_file) {
116         qemu_file_shutdown(mis->from_src_file);
117     }
118     if (mis->to_src_file) {
119         qemu_file_shutdown(mis->to_src_file);
120     }
121 
122     old_state = failover_set_state(FAILOVER_STATUS_ACTIVE,
123                                    FAILOVER_STATUS_COMPLETED);
124     if (old_state != FAILOVER_STATUS_ACTIVE) {
125         error_report("Incorrect state (%s) while doing failover for "
126                      "secondary VM", FailoverStatus_str(old_state));
127         return;
128     }
129     /* Notify COLO incoming thread that failover work is finished */
130     qemu_sem_post(&mis->colo_incoming_sem);
131 
132     /* For Secondary VM, jump to incoming co */
133     if (mis->migration_incoming_co) {
134         qemu_coroutine_enter(mis->migration_incoming_co);
135     }
136 #else
137     abort();
138 #endif
139 }
140 
141 static void primary_vm_do_failover(void)
142 {
143 #ifdef CONFIG_REPLICATION
144     MigrationState *s = migrate_get_current();
145     int old_state;
146     Error *local_err = NULL;
147 
148     migrate_set_state(&s->state, MIGRATION_STATUS_COLO,
149                       MIGRATION_STATUS_COMPLETED);
150     /*
151      * kick COLO thread which might wait at
152      * qemu_sem_wait(&s->colo_checkpoint_sem).
153      */
154     colo_checkpoint_notify(s);
155 
156     /*
157      * Wake up COLO thread which may blocked in recv() or send(),
158      * The s->rp_state.from_dst_file and s->to_dst_file may use the
159      * same fd, but we still shutdown the fd for twice, it is harmless.
160      */
161     if (s->to_dst_file) {
162         qemu_file_shutdown(s->to_dst_file);
163     }
164     if (s->rp_state.from_dst_file) {
165         qemu_file_shutdown(s->rp_state.from_dst_file);
166     }
167 
168     old_state = failover_set_state(FAILOVER_STATUS_ACTIVE,
169                                    FAILOVER_STATUS_COMPLETED);
170     if (old_state != FAILOVER_STATUS_ACTIVE) {
171         error_report("Incorrect state (%s) while doing failover for Primary VM",
172                      FailoverStatus_str(old_state));
173         return;
174     }
175 
176     replication_stop_all(true, &local_err);
177     if (local_err) {
178         error_report_err(local_err);
179         local_err = NULL;
180     }
181 
182     /* Notify COLO thread that failover work is finished */
183     qemu_sem_post(&s->colo_exit_sem);
184 #else
185     abort();
186 #endif
187 }
188 
189 COLOMode get_colo_mode(void)
190 {
191     if (migration_in_colo_state()) {
192         return COLO_MODE_PRIMARY;
193     } else if (migration_incoming_in_colo_state()) {
194         return COLO_MODE_SECONDARY;
195     } else {
196         return COLO_MODE_NONE;
197     }
198 }
199 
200 void colo_do_failover(void)
201 {
202     /* Make sure VM stopped while failover happened. */
203     if (!colo_runstate_is_stopped()) {
204         vm_stop_force_state(RUN_STATE_COLO);
205     }
206 
207     switch (last_colo_mode = get_colo_mode()) {
208     case COLO_MODE_PRIMARY:
209         primary_vm_do_failover();
210         break;
211     case COLO_MODE_SECONDARY:
212         secondary_vm_do_failover();
213         break;
214     default:
215         error_report("colo_do_failover failed because the colo mode"
216                      " could not be obtained");
217     }
218 }
219 
220 #ifdef CONFIG_REPLICATION
221 void qmp_xen_set_replication(bool enable, bool primary,
222                              bool has_failover, bool failover,
223                              Error **errp)
224 {
225     ReplicationMode mode = primary ?
226                            REPLICATION_MODE_PRIMARY :
227                            REPLICATION_MODE_SECONDARY;
228 
229     if (has_failover && enable) {
230         error_setg(errp, "Parameter 'failover' is only for"
231                    " stopping replication");
232         return;
233     }
234 
235     if (enable) {
236         replication_start_all(mode, errp);
237     } else {
238         if (!has_failover) {
239             failover = NULL;
240         }
241         replication_stop_all(failover, failover ? NULL : errp);
242     }
243 }
244 
245 ReplicationStatus *qmp_query_xen_replication_status(Error **errp)
246 {
247     Error *err = NULL;
248     ReplicationStatus *s = g_new0(ReplicationStatus, 1);
249 
250     replication_get_error_all(&err);
251     if (err) {
252         s->error = true;
253         s->has_desc = true;
254         s->desc = g_strdup(error_get_pretty(err));
255     } else {
256         s->error = false;
257     }
258 
259     error_free(err);
260     return s;
261 }
262 
263 void qmp_xen_colo_do_checkpoint(Error **errp)
264 {
265     Error *err = NULL;
266 
267     replication_do_checkpoint_all(&err);
268     if (err) {
269         error_propagate(errp, err);
270         return;
271     }
272     /* Notify all filters of all NIC to do checkpoint */
273     colo_notify_filters_event(COLO_EVENT_CHECKPOINT, errp);
274 }
275 #endif
276 
277 COLOStatus *qmp_query_colo_status(Error **errp)
278 {
279     COLOStatus *s = g_new0(COLOStatus, 1);
280 
281     s->mode = get_colo_mode();
282     s->last_mode = last_colo_mode;
283 
284     switch (failover_get_state()) {
285     case FAILOVER_STATUS_NONE:
286         s->reason = COLO_EXIT_REASON_NONE;
287         break;
288     case FAILOVER_STATUS_COMPLETED:
289         s->reason = COLO_EXIT_REASON_REQUEST;
290         break;
291     default:
292         if (migration_in_colo_state()) {
293             s->reason = COLO_EXIT_REASON_PROCESSING;
294         } else {
295             s->reason = COLO_EXIT_REASON_ERROR;
296         }
297     }
298 
299     return s;
300 }
301 
302 static void colo_send_message(QEMUFile *f, COLOMessage msg,
303                               Error **errp)
304 {
305     int ret;
306 
307     if (msg >= COLO_MESSAGE__MAX) {
308         error_setg(errp, "%s: Invalid message", __func__);
309         return;
310     }
311     qemu_put_be32(f, msg);
312     qemu_fflush(f);
313 
314     ret = qemu_file_get_error(f);
315     if (ret < 0) {
316         error_setg_errno(errp, -ret, "Can't send COLO message");
317     }
318     trace_colo_send_message(COLOMessage_str(msg));
319 }
320 
321 static void colo_send_message_value(QEMUFile *f, COLOMessage msg,
322                                     uint64_t value, Error **errp)
323 {
324     Error *local_err = NULL;
325     int ret;
326 
327     colo_send_message(f, msg, &local_err);
328     if (local_err) {
329         error_propagate(errp, local_err);
330         return;
331     }
332     qemu_put_be64(f, value);
333     qemu_fflush(f);
334 
335     ret = qemu_file_get_error(f);
336     if (ret < 0) {
337         error_setg_errno(errp, -ret, "Failed to send value for message:%s",
338                          COLOMessage_str(msg));
339     }
340 }
341 
342 static COLOMessage colo_receive_message(QEMUFile *f, Error **errp)
343 {
344     COLOMessage msg;
345     int ret;
346 
347     msg = qemu_get_be32(f);
348     ret = qemu_file_get_error(f);
349     if (ret < 0) {
350         error_setg_errno(errp, -ret, "Can't receive COLO message");
351         return msg;
352     }
353     if (msg >= COLO_MESSAGE__MAX) {
354         error_setg(errp, "%s: Invalid message", __func__);
355         return msg;
356     }
357     trace_colo_receive_message(COLOMessage_str(msg));
358     return msg;
359 }
360 
361 static void colo_receive_check_message(QEMUFile *f, COLOMessage expect_msg,
362                                        Error **errp)
363 {
364     COLOMessage msg;
365     Error *local_err = NULL;
366 
367     msg = colo_receive_message(f, &local_err);
368     if (local_err) {
369         error_propagate(errp, local_err);
370         return;
371     }
372     if (msg != expect_msg) {
373         error_setg(errp, "Unexpected COLO message %d, expected %d",
374                           msg, expect_msg);
375     }
376 }
377 
378 static uint64_t colo_receive_message_value(QEMUFile *f, uint32_t expect_msg,
379                                            Error **errp)
380 {
381     Error *local_err = NULL;
382     uint64_t value;
383     int ret;
384 
385     colo_receive_check_message(f, expect_msg, &local_err);
386     if (local_err) {
387         error_propagate(errp, local_err);
388         return 0;
389     }
390 
391     value = qemu_get_be64(f);
392     ret = qemu_file_get_error(f);
393     if (ret < 0) {
394         error_setg_errno(errp, -ret, "Failed to get value for COLO message: %s",
395                          COLOMessage_str(expect_msg));
396     }
397     return value;
398 }
399 
400 static int colo_do_checkpoint_transaction(MigrationState *s,
401                                           QIOChannelBuffer *bioc,
402                                           QEMUFile *fb)
403 {
404     Error *local_err = NULL;
405     int ret = -1;
406 
407     colo_send_message(s->to_dst_file, COLO_MESSAGE_CHECKPOINT_REQUEST,
408                       &local_err);
409     if (local_err) {
410         goto out;
411     }
412 
413     colo_receive_check_message(s->rp_state.from_dst_file,
414                     COLO_MESSAGE_CHECKPOINT_REPLY, &local_err);
415     if (local_err) {
416         goto out;
417     }
418     /* Reset channel-buffer directly */
419     qio_channel_io_seek(QIO_CHANNEL(bioc), 0, 0, NULL);
420     bioc->usage = 0;
421 
422     qemu_mutex_lock_iothread();
423     if (failover_get_state() != FAILOVER_STATUS_NONE) {
424         qemu_mutex_unlock_iothread();
425         goto out;
426     }
427     vm_stop_force_state(RUN_STATE_COLO);
428     qemu_mutex_unlock_iothread();
429     trace_colo_vm_state_change("run", "stop");
430     /*
431      * Failover request bh could be called after vm_stop_force_state(),
432      * So we need check failover_request_is_active() again.
433      */
434     if (failover_get_state() != FAILOVER_STATUS_NONE) {
435         goto out;
436     }
437     qemu_mutex_lock_iothread();
438 
439 #ifdef CONFIG_REPLICATION
440     replication_do_checkpoint_all(&local_err);
441     if (local_err) {
442         qemu_mutex_unlock_iothread();
443         goto out;
444     }
445 #else
446         abort();
447 #endif
448 
449     colo_send_message(s->to_dst_file, COLO_MESSAGE_VMSTATE_SEND, &local_err);
450     if (local_err) {
451         qemu_mutex_unlock_iothread();
452         goto out;
453     }
454     /* Note: device state is saved into buffer */
455     ret = qemu_save_device_state(fb);
456 
457     qemu_mutex_unlock_iothread();
458     if (ret < 0) {
459         goto out;
460     }
461 
462     if (migrate_auto_converge()) {
463         mig_throttle_counter_reset();
464     }
465     /*
466      * Only save VM's live state, which not including device state.
467      * TODO: We may need a timeout mechanism to prevent COLO process
468      * to be blocked here.
469      */
470     qemu_savevm_live_state(s->to_dst_file);
471 
472     qemu_fflush(fb);
473 
474     /*
475      * We need the size of the VMstate data in Secondary side,
476      * With which we can decide how much data should be read.
477      */
478     colo_send_message_value(s->to_dst_file, COLO_MESSAGE_VMSTATE_SIZE,
479                             bioc->usage, &local_err);
480     if (local_err) {
481         goto out;
482     }
483 
484     qemu_put_buffer(s->to_dst_file, bioc->data, bioc->usage);
485     qemu_fflush(s->to_dst_file);
486     ret = qemu_file_get_error(s->to_dst_file);
487     if (ret < 0) {
488         goto out;
489     }
490 
491     colo_receive_check_message(s->rp_state.from_dst_file,
492                        COLO_MESSAGE_VMSTATE_RECEIVED, &local_err);
493     if (local_err) {
494         goto out;
495     }
496 
497     qemu_event_reset(&s->colo_checkpoint_event);
498     colo_notify_compares_event(NULL, COLO_EVENT_CHECKPOINT, &local_err);
499     if (local_err) {
500         goto out;
501     }
502 
503     colo_receive_check_message(s->rp_state.from_dst_file,
504                        COLO_MESSAGE_VMSTATE_LOADED, &local_err);
505     if (local_err) {
506         goto out;
507     }
508 
509     ret = 0;
510 
511     qemu_mutex_lock_iothread();
512     vm_start();
513     qemu_mutex_unlock_iothread();
514     trace_colo_vm_state_change("stop", "run");
515 
516 out:
517     if (local_err) {
518         error_report_err(local_err);
519     }
520     return ret;
521 }
522 
523 static void colo_compare_notify_checkpoint(Notifier *notifier, void *data)
524 {
525     colo_checkpoint_notify(data);
526 }
527 
528 static void colo_process_checkpoint(MigrationState *s)
529 {
530     QIOChannelBuffer *bioc;
531     QEMUFile *fb = NULL;
532     Error *local_err = NULL;
533     int ret;
534 
535     if (get_colo_mode() != COLO_MODE_PRIMARY) {
536         error_report("COLO mode must be COLO_MODE_PRIMARY");
537         return;
538     }
539 
540     failover_init_state();
541 
542     s->rp_state.from_dst_file = qemu_file_get_return_path(s->to_dst_file);
543     if (!s->rp_state.from_dst_file) {
544         error_report("Open QEMUFile from_dst_file failed");
545         goto out;
546     }
547 
548     packets_compare_notifier.notify = colo_compare_notify_checkpoint;
549     colo_compare_register_notifier(&packets_compare_notifier);
550 
551     /*
552      * Wait for Secondary finish loading VM states and enter COLO
553      * restore.
554      */
555     colo_receive_check_message(s->rp_state.from_dst_file,
556                        COLO_MESSAGE_CHECKPOINT_READY, &local_err);
557     if (local_err) {
558         goto out;
559     }
560     bioc = qio_channel_buffer_new(COLO_BUFFER_BASE_SIZE);
561     fb = qemu_file_new_output(QIO_CHANNEL(bioc));
562     object_unref(OBJECT(bioc));
563 
564     qemu_mutex_lock_iothread();
565 #ifdef CONFIG_REPLICATION
566     replication_start_all(REPLICATION_MODE_PRIMARY, &local_err);
567     if (local_err) {
568         qemu_mutex_unlock_iothread();
569         goto out;
570     }
571 #else
572         abort();
573 #endif
574 
575     vm_start();
576     qemu_mutex_unlock_iothread();
577     trace_colo_vm_state_change("stop", "run");
578 
579     timer_mod(s->colo_delay_timer, qemu_clock_get_ms(QEMU_CLOCK_HOST) +
580               s->parameters.x_checkpoint_delay);
581 
582     while (s->state == MIGRATION_STATUS_COLO) {
583         if (failover_get_state() != FAILOVER_STATUS_NONE) {
584             error_report("failover request");
585             goto out;
586         }
587 
588         qemu_event_wait(&s->colo_checkpoint_event);
589 
590         if (s->state != MIGRATION_STATUS_COLO) {
591             goto out;
592         }
593         ret = colo_do_checkpoint_transaction(s, bioc, fb);
594         if (ret < 0) {
595             goto out;
596         }
597     }
598 
599 out:
600     /* Throw the unreported error message after exited from loop */
601     if (local_err) {
602         error_report_err(local_err);
603     }
604 
605     if (fb) {
606         qemu_fclose(fb);
607     }
608 
609     /*
610      * There are only two reasons we can get here, some error happened
611      * or the user triggered failover.
612      */
613     switch (failover_get_state()) {
614     case FAILOVER_STATUS_COMPLETED:
615         qapi_event_send_colo_exit(COLO_MODE_PRIMARY,
616                                   COLO_EXIT_REASON_REQUEST);
617         break;
618     default:
619         qapi_event_send_colo_exit(COLO_MODE_PRIMARY,
620                                   COLO_EXIT_REASON_ERROR);
621     }
622 
623     /* Hope this not to be too long to wait here */
624     qemu_sem_wait(&s->colo_exit_sem);
625     qemu_sem_destroy(&s->colo_exit_sem);
626 
627     /*
628      * It is safe to unregister notifier after failover finished.
629      * Besides, colo_delay_timer and colo_checkpoint_sem can't be
630      * released before unregister notifier, or there will be use-after-free
631      * error.
632      */
633     colo_compare_unregister_notifier(&packets_compare_notifier);
634     timer_free(s->colo_delay_timer);
635     qemu_event_destroy(&s->colo_checkpoint_event);
636 
637     /*
638      * Must be called after failover BH is completed,
639      * Or the failover BH may shutdown the wrong fd that
640      * re-used by other threads after we release here.
641      */
642     if (s->rp_state.from_dst_file) {
643         qemu_fclose(s->rp_state.from_dst_file);
644         s->rp_state.from_dst_file = NULL;
645     }
646 }
647 
648 void colo_checkpoint_notify(void *opaque)
649 {
650     MigrationState *s = opaque;
651     int64_t next_notify_time;
652 
653     qemu_event_set(&s->colo_checkpoint_event);
654     s->colo_checkpoint_time = qemu_clock_get_ms(QEMU_CLOCK_HOST);
655     next_notify_time = s->colo_checkpoint_time +
656                     s->parameters.x_checkpoint_delay;
657     timer_mod(s->colo_delay_timer, next_notify_time);
658 }
659 
660 void migrate_start_colo_process(MigrationState *s)
661 {
662     qemu_mutex_unlock_iothread();
663     qemu_event_init(&s->colo_checkpoint_event, false);
664     s->colo_delay_timer =  timer_new_ms(QEMU_CLOCK_HOST,
665                                 colo_checkpoint_notify, s);
666 
667     qemu_sem_init(&s->colo_exit_sem, 0);
668     colo_process_checkpoint(s);
669     qemu_mutex_lock_iothread();
670 }
671 
672 static void colo_incoming_process_checkpoint(MigrationIncomingState *mis,
673                       QEMUFile *fb, QIOChannelBuffer *bioc, Error **errp)
674 {
675     uint64_t total_size;
676     uint64_t value;
677     Error *local_err = NULL;
678     int ret;
679 
680     qemu_mutex_lock_iothread();
681     vm_stop_force_state(RUN_STATE_COLO);
682     qemu_mutex_unlock_iothread();
683     trace_colo_vm_state_change("run", "stop");
684 
685     /* FIXME: This is unnecessary for periodic checkpoint mode */
686     colo_send_message(mis->to_src_file, COLO_MESSAGE_CHECKPOINT_REPLY,
687                  &local_err);
688     if (local_err) {
689         error_propagate(errp, local_err);
690         return;
691     }
692 
693     colo_receive_check_message(mis->from_src_file,
694                        COLO_MESSAGE_VMSTATE_SEND, &local_err);
695     if (local_err) {
696         error_propagate(errp, local_err);
697         return;
698     }
699 
700     qemu_mutex_lock_iothread();
701     cpu_synchronize_all_states();
702     ret = qemu_loadvm_state_main(mis->from_src_file, mis);
703     qemu_mutex_unlock_iothread();
704 
705     if (ret < 0) {
706         error_setg(errp, "Load VM's live state (ram) error");
707         return;
708     }
709 
710     value = colo_receive_message_value(mis->from_src_file,
711                              COLO_MESSAGE_VMSTATE_SIZE, &local_err);
712     if (local_err) {
713         error_propagate(errp, local_err);
714         return;
715     }
716 
717     /*
718      * Read VM device state data into channel buffer,
719      * It's better to re-use the memory allocated.
720      * Here we need to handle the channel buffer directly.
721      */
722     if (value > bioc->capacity) {
723         bioc->capacity = value;
724         bioc->data = g_realloc(bioc->data, bioc->capacity);
725     }
726     total_size = qemu_get_buffer(mis->from_src_file, bioc->data, value);
727     if (total_size != value) {
728         error_setg(errp, "Got %" PRIu64 " VMState data, less than expected"
729                     " %" PRIu64, total_size, value);
730         return;
731     }
732     bioc->usage = total_size;
733     qio_channel_io_seek(QIO_CHANNEL(bioc), 0, 0, NULL);
734 
735     colo_send_message(mis->to_src_file, COLO_MESSAGE_VMSTATE_RECEIVED,
736                  &local_err);
737     if (local_err) {
738         error_propagate(errp, local_err);
739         return;
740     }
741 
742     qemu_mutex_lock_iothread();
743     vmstate_loading = true;
744     colo_flush_ram_cache();
745     ret = qemu_load_device_state(fb);
746     if (ret < 0) {
747         error_setg(errp, "COLO: load device state failed");
748         vmstate_loading = false;
749         qemu_mutex_unlock_iothread();
750         return;
751     }
752 
753 #ifdef CONFIG_REPLICATION
754     replication_get_error_all(&local_err);
755     if (local_err) {
756         error_propagate(errp, local_err);
757         vmstate_loading = false;
758         qemu_mutex_unlock_iothread();
759         return;
760     }
761 
762     /* discard colo disk buffer */
763     replication_do_checkpoint_all(&local_err);
764     if (local_err) {
765         error_propagate(errp, local_err);
766         vmstate_loading = false;
767         qemu_mutex_unlock_iothread();
768         return;
769     }
770 #else
771     abort();
772 #endif
773     /* Notify all filters of all NIC to do checkpoint */
774     colo_notify_filters_event(COLO_EVENT_CHECKPOINT, &local_err);
775 
776     if (local_err) {
777         error_propagate(errp, local_err);
778         vmstate_loading = false;
779         qemu_mutex_unlock_iothread();
780         return;
781     }
782 
783     vmstate_loading = false;
784     vm_start();
785     qemu_mutex_unlock_iothread();
786     trace_colo_vm_state_change("stop", "run");
787 
788     if (failover_get_state() == FAILOVER_STATUS_RELAUNCH) {
789         return;
790     }
791 
792     colo_send_message(mis->to_src_file, COLO_MESSAGE_VMSTATE_LOADED,
793                  &local_err);
794     error_propagate(errp, local_err);
795 }
796 
797 static void colo_wait_handle_message(MigrationIncomingState *mis,
798                 QEMUFile *fb, QIOChannelBuffer *bioc, Error **errp)
799 {
800     COLOMessage msg;
801     Error *local_err = NULL;
802 
803     msg = colo_receive_message(mis->from_src_file, &local_err);
804     if (local_err) {
805         error_propagate(errp, local_err);
806         return;
807     }
808 
809     switch (msg) {
810     case COLO_MESSAGE_CHECKPOINT_REQUEST:
811         colo_incoming_process_checkpoint(mis, fb, bioc, errp);
812         break;
813     default:
814         error_setg(errp, "Got unknown COLO message: %d", msg);
815         break;
816     }
817 }
818 
819 void colo_shutdown(void)
820 {
821     MigrationIncomingState *mis = NULL;
822     MigrationState *s = NULL;
823 
824     switch (get_colo_mode()) {
825     case COLO_MODE_PRIMARY:
826         s = migrate_get_current();
827         qemu_event_set(&s->colo_checkpoint_event);
828         qemu_sem_post(&s->colo_exit_sem);
829         break;
830     case COLO_MODE_SECONDARY:
831         mis = migration_incoming_get_current();
832         qemu_sem_post(&mis->colo_incoming_sem);
833         break;
834     default:
835         break;
836     }
837 }
838 
839 void *colo_process_incoming_thread(void *opaque)
840 {
841     MigrationIncomingState *mis = opaque;
842     QEMUFile *fb = NULL;
843     QIOChannelBuffer *bioc = NULL; /* Cache incoming device state */
844     Error *local_err = NULL;
845 
846     rcu_register_thread();
847     qemu_sem_init(&mis->colo_incoming_sem, 0);
848 
849     migrate_set_state(&mis->state, MIGRATION_STATUS_ACTIVE,
850                       MIGRATION_STATUS_COLO);
851 
852     if (get_colo_mode() != COLO_MODE_SECONDARY) {
853         error_report("COLO mode must be COLO_MODE_SECONDARY");
854         return NULL;
855     }
856 
857     failover_init_state();
858 
859     mis->to_src_file = qemu_file_get_return_path(mis->from_src_file);
860     if (!mis->to_src_file) {
861         error_report("COLO incoming thread: Open QEMUFile to_src_file failed");
862         goto out;
863     }
864     /*
865      * Note: the communication between Primary side and Secondary side
866      * should be sequential, we set the fd to unblocked in migration incoming
867      * coroutine, and here we are in the COLO incoming thread, so it is ok to
868      * set the fd back to blocked.
869      */
870     qemu_file_set_blocking(mis->from_src_file, true);
871 
872     colo_incoming_start_dirty_log();
873 
874     bioc = qio_channel_buffer_new(COLO_BUFFER_BASE_SIZE);
875     fb = qemu_file_new_input(QIO_CHANNEL(bioc));
876     object_unref(OBJECT(bioc));
877 
878     qemu_mutex_lock_iothread();
879 #ifdef CONFIG_REPLICATION
880     replication_start_all(REPLICATION_MODE_SECONDARY, &local_err);
881     if (local_err) {
882         qemu_mutex_unlock_iothread();
883         goto out;
884     }
885 #else
886         abort();
887 #endif
888     vm_start();
889     qemu_mutex_unlock_iothread();
890     trace_colo_vm_state_change("stop", "run");
891 
892     colo_send_message(mis->to_src_file, COLO_MESSAGE_CHECKPOINT_READY,
893                       &local_err);
894     if (local_err) {
895         goto out;
896     }
897 
898     while (mis->state == MIGRATION_STATUS_COLO) {
899         colo_wait_handle_message(mis, fb, bioc, &local_err);
900         if (local_err) {
901             error_report_err(local_err);
902             break;
903         }
904 
905         if (failover_get_state() == FAILOVER_STATUS_RELAUNCH) {
906             failover_set_state(FAILOVER_STATUS_RELAUNCH,
907                             FAILOVER_STATUS_NONE);
908             failover_request_active(NULL);
909             break;
910         }
911 
912         if (failover_get_state() != FAILOVER_STATUS_NONE) {
913             error_report("failover request");
914             break;
915         }
916     }
917 
918 out:
919     /*
920      * There are only two reasons we can get here, some error happened
921      * or the user triggered failover.
922      */
923     switch (failover_get_state()) {
924     case FAILOVER_STATUS_COMPLETED:
925         qapi_event_send_colo_exit(COLO_MODE_SECONDARY,
926                                   COLO_EXIT_REASON_REQUEST);
927         break;
928     default:
929         qapi_event_send_colo_exit(COLO_MODE_SECONDARY,
930                                   COLO_EXIT_REASON_ERROR);
931     }
932 
933     if (fb) {
934         qemu_fclose(fb);
935     }
936 
937     /* Hope this not to be too long to loop here */
938     qemu_sem_wait(&mis->colo_incoming_sem);
939     qemu_sem_destroy(&mis->colo_incoming_sem);
940 
941     rcu_unregister_thread();
942     return NULL;
943 }
944