[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH V7 RESEND 17/17] COLO: quick failover process by
From: |
Dr. David Alan Gilbert |
Subject: |
Re: [Qemu-devel] [PATCH V7 RESEND 17/17] COLO: quick failover process by kick COLO thread |
Date: |
Thu, 17 May 2018 10:53:46 +0100 |
User-agent: |
Mutt/1.9.5 (2018-04-13) |
* Zhang Chen (address@hidden) wrote:
> From: zhanghailiang <address@hidden>
>
> COLO thread may sleep at qemu_sem_wait(&s->colo_checkpoint_sem),
> while failover works begin, It's better to wakeup it to quick
> the process.
>
> Signed-off-by: zhanghailiang <address@hidden>
Reviewed-by: Dr. David Alan Gilbert <address@hidden>
> ---
> migration/colo.c | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/migration/colo.c b/migration/colo.c
> index 15463e2823..16def4865c 100644
> --- a/migration/colo.c
> +++ b/migration/colo.c
> @@ -135,6 +135,11 @@ static void primary_vm_do_failover(void)
>
> migrate_set_state(&s->state, MIGRATION_STATUS_COLO,
> MIGRATION_STATUS_COMPLETED);
> + /*
> + * kick COLO thread which might wait at
> + * qemu_sem_wait(&s->colo_checkpoint_sem).
> + */
> + colo_checkpoint_notify(migrate_get_current());
>
> /*
> * Wake up COLO thread which may blocked in recv() or send(),
> @@ -552,6 +557,9 @@ static void colo_process_checkpoint(MigrationState *s)
>
> qemu_sem_wait(&s->colo_checkpoint_sem);
>
> + if (s->state != MIGRATION_STATUS_COLO) {
> + goto out;
> + }
> ret = colo_do_checkpoint_transaction(s, bioc, fb);
> if (ret < 0) {
> goto out;
> --
> 2.17.0
>
--
Dr. David Alan Gilbert / address@hidden / Manchester, UK
- [Qemu-devel] [PATCH V7 RESEND 11/17] qapi: Add new command to query colo status, (continued)
- [Qemu-devel] [PATCH V7 RESEND 11/17] qapi: Add new command to query colo status, Zhang Chen, 2018/05/14
- [Qemu-devel] [PATCH V7 RESEND 12/17] savevm: split the process of different stages for loadvm/savevm, Zhang Chen, 2018/05/14
- [Qemu-devel] [PATCH V7 RESEND 13/17] COLO: flush host dirty ram from cache, Zhang Chen, 2018/05/14
- [Qemu-devel] [PATCH V7 RESEND 14/17] filter: Add handle_event method for NetFilterClass, Zhang Chen, 2018/05/14
- [Qemu-devel] [PATCH V7 RESEND 16/17] COLO: notify net filters about checkpoint/failover event, Zhang Chen, 2018/05/14
- [Qemu-devel] [PATCH V7 RESEND 15/17] filter-rewriter: handle checkpoint and failover event, Zhang Chen, 2018/05/14
- [Qemu-devel] [PATCH V7 RESEND 17/17] COLO: quick failover process by kick COLO thread, Zhang Chen, 2018/05/14
- Re: [Qemu-devel] [PATCH V7 RESEND 17/17] COLO: quick failover process by kick COLO thread,
Dr. David Alan Gilbert <=
- Re: [Qemu-devel] [PATCH V7 RESEND 00/17] COLO: integrate colo frame with block replication and COLO proxy, Dr. David Alan Gilbert, 2018/05/16