From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
To: Denis Plotnikov <dplotnikov@virtuozzo.com>, aarcange@redhat.com
Cc: quintela@redhat.com, pbonzini@redhat.com, qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH v0 0/7] Background snapshots
Date: Fri, 29 Jun 2018 12:53:59 +0100 [thread overview]
Message-ID: <20180629115359.GH2568@work-vm> (raw)
In-Reply-To: <20180629080320.320144-1-dplotnikov@virtuozzo.com>
* Denis Plotnikov (dplotnikov@virtuozzo.com) wrote:
> The patch set adds the ability to make external snapshots while VM is running.
cc'ing in Andrea since this uses sigsegv's to avoid userfault-wp that
isn't there yet.
Hi Denis,
How robust are you finding this SEGV based trick; for example what
about things like the kernel walking vhost queues or similar kernel
nasties?
Dave
> The workflow to make a snapshot is the following:
> 1. Pause the vm
> 2. Make a snapshot of block devices using the scheme of your choice
> 3. Turn on background-snapshot migration capability
> 4. Start the migration using the destination (migration stream) of your choice.
> The migration will resume the vm execution by itself
> when it has the devices' states saved and is ready to start ram writing
> to the migration stream.
> 5. Listen to the migration finish event
>
> The feature relies on KVM unapplied ability to report the faulting address.
> Please find the KVM patch snippet to make the patchset work below:
>
> +++ b/arch/x86/kvm/vmx.c
> @@ -XXXX,X +XXXX,XX @@ static int handle_ept_violation(struct kvm_vcpu *vcpu)
>
> vcpu->arch.exit_qualification = exit_qualification;
>
> - return kvm_mmu_page_fault(vcpu, gpa, error_code, NULL, 0);
> + r = kvm_mmu_page_fault(vcpu, gpa, error_code, NULL, 0);
> + if (r == -EFAULT) {
> + unsigned long hva = kvm_vcpu_gfn_to_hva(vcpu, gpa >> PAGE_SHIFT);
> +
> + vcpu->run->exit_reason = KVM_EXIT_FAIL_MEM_ACCESS;
> + vcpu->run->hw.hardware_exit_reason = EXIT_REASON_EPT_VIOLATION;
> + vcpu->run->fail_mem_access.hva = hva | (gpa & (PAGE_SIZE-1));
> + r = 0;
> +
> + }
> + return r;
>
> The patch to KVM can be sent if the patch set approved
>
> Denis Plotnikov (7):
> migration: add background snapshot capability
> bitops: add some atomic versions of bitmap operations
> threads: add infrastructure to process sigsegv
> migration: add background snapshot infrastructure
> kvm: add failed memeory access exit reason
> kvm: add vCPU failed memeory access processing
> migration: add background snapshotting
>
> include/exec/ram_addr.h | 7 +
> include/exec/ramlist.h | 4 +-
> include/qemu/bitops.h | 24 +++
> include/qemu/thread.h | 5 +
> linux-headers/linux/kvm.h | 5 +
> migration/migration.c | 141 +++++++++++++++-
> migration/migration.h | 1 +
> migration/ram.c | 333 ++++++++++++++++++++++++++++++++++++--
> migration/ram.h | 11 +-
> migration/savevm.c | 91 ++++++-----
> migration/savevm.h | 2 +
> qapi/migration.json | 6 +-
> target/i386/kvm.c | 18 +++
> util/qemu-thread-posix.c | 50 ++++++
> 14 files changed, 635 insertions(+), 63 deletions(-)
>
> --
> 2.17.0
>
--
Dr. David Alan Gilbert / dgilbert@redhat.com / Manchester, UK
next prev parent reply other threads:[~2018-06-29 11:54 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-06-29 8:03 [Qemu-devel] [PATCH v0 0/7] Background snapshots Denis Plotnikov
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 1/7] migration: add background snapshot capability Denis Plotnikov
2018-06-29 16:02 ` Eric Blake
2018-07-12 9:03 ` Dr. David Alan Gilbert
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 2/7] bitops: add some atomic versions of bitmap operations Denis Plotnikov
2018-07-12 9:21 ` Dr. David Alan Gilbert
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 3/7] threads: add infrastructure to process sigsegv Denis Plotnikov
2018-07-12 9:53 ` Dr. David Alan Gilbert
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 4/7] migration: add background snapshot infrastructure Denis Plotnikov
2018-07-12 11:46 ` Dr. David Alan Gilbert
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 5/7] kvm: add failed memeory access exit reason Denis Plotnikov
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 6/7] kvm: add vCPU failed memeory access processing Denis Plotnikov
2018-06-29 8:03 ` [Qemu-devel] [PATCH v0 7/7] migration: add background snapshotting Denis Plotnikov
2018-07-12 18:59 ` Dr. David Alan Gilbert
2018-06-29 11:53 ` Dr. David Alan Gilbert [this message]
2018-07-25 10:18 ` [Qemu-devel] [PATCH v0 0/7] Background snapshots Peter Xu
2018-07-25 19:17 ` Dr. David Alan Gilbert
2018-07-25 20:04 ` Andrea Arcangeli
2018-07-26 8:51 ` Paolo Bonzini
2018-07-26 9:23 ` Peter Xu
2018-08-13 12:55 ` Denis Plotnikov
2018-08-13 19:00 ` Dr. David Alan Gilbert
2018-08-14 5:45 ` Peter Xu
2018-08-14 6:13 ` Mike Rapoport
2018-08-14 23:16 ` Mike Kravetz
2018-07-26 15:13 ` Dr. David Alan Gilbert
2018-07-02 11:23 ` Peter Xu
2018-07-02 12:40 ` Denis Plotnikov
2018-07-03 5:54 ` Peter Xu
2018-07-13 5:20 ` Peter Xu
2018-07-16 15:00 ` Denis Plotnikov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180629115359.GH2568@work-vm \
--to=dgilbert@redhat.com \
--cc=aarcange@redhat.com \
--cc=dplotnikov@virtuozzo.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=quintela@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.