All of lore.kernel.org
 help / color / mirror / Atom feed
From: Michael Roth <michael.roth@amd.com>
To: Andy Lutomirski <luto@amacapital.net>
Cc: Sean Christopherson <seanjc@google.com>,
	kvm@vger.kernel.org, Paolo Bonzini <pbonzini@redhat.com>,
	Vitaly Kuznetsov <vkuznets@redhat.com>,
	Wanpeng Li <wanpengli@tencent.com>,
	Jim Mattson <jmattson@google.com>, Joerg Roedel <joro@8bytes.org>,
	Thomas Gleixner <tglx@linutronix.de>,
	Ingo Molnar <mingo@redhat.com>, Borislav Petkov <bp@alien8.de>,
	x86@kernel.org, "H . Peter Anvin" <hpa@zytor.com>,
	linux-kernel@vger.kernel.org,
	Tom Lendacky <thomas.lendacky@amd.com>,
	Andy Lutomirski <luto@kernel.org>
Subject: Re: [PATCH v2] KVM: SVM: use vmsave/vmload for saving/restoring additional host state
Date: Tue, 15 Dec 2020 12:17:47 -0600	[thread overview]
Message-ID: <20201215181747.jhozec5gpa4ud5qt@amd.com> (raw)
In-Reply-To: <98F09A9A-A768-4B01-A1FA-5EE681146BC5@amacapital.net>

On Mon, Dec 14, 2020 at 02:29:46PM -0800, Andy Lutomirski wrote:
> 
> 
> > On Dec 14, 2020, at 2:02 PM, Michael Roth <michael.roth@amd.com> wrote:
> > 
> > On Mon, Dec 14, 2020 at 11:38:23AM -0800, Sean Christopherson wrote:
> >> +Andy, who provided a lot of feedback on v1.
> >> On Mon, Dec 14, 2020, Michael Roth wrote:
> >> Cc: Andy Lutomirski <luto@kernel.org>
> >>> Suggested-by: Tom Lendacky <thomas.lendacky@amd.com>
> >>> Signed-off-by: Michael Roth <michael.roth@amd.com>
> >>> ---
> >>> v2:
> >>> * rebase on latest kvm/next
> >>> * move VMLOAD to just after vmexit so we can use it to handle all FS/GS
> >>> host state restoration and rather than relying on loadsegment() and
> >>> explicit write to MSR_GS_BASE (Andy)
> >>> * drop 'host' field from struct vcpu_svm since it is no longer needed
> >>> for storing FS/GS/LDT state (Andy)
> >>> ---
> >>> arch/x86/kvm/svm/svm.c | 44 ++++++++++++++++--------------------------
> >>> arch/x86/kvm/svm/svm.h | 14 +++-----------
> >>> 2 files changed, 20 insertions(+), 38 deletions(-)
> >>> diff --git a/arch/x86/kvm/svm/svm.c b/arch/x86/kvm/svm/svm.c
> >>> index 0e52fac4f5ae..fb15b7bd461f 100644
> >>> --- a/arch/x86/kvm/svm/svm.c
> >>> +++ b/arch/x86/kvm/svm/svm.c
> >>> @@ -1367,15 +1367,19 @@ static void svm_vcpu_load(struct kvm_vcpu *vcpu, int cpu)
> >>>       vmcb_mark_all_dirty(svm->vmcb);
> >>>   }
> >>> -#ifdef CONFIG_X86_64
> >>> -    rdmsrl(MSR_GS_BASE, to_svm(vcpu)->host.gs_base);
> >>> -#endif
> >>> -    savesegment(fs, svm->host.fs);
> >>> -    savesegment(gs, svm->host.gs);
> >>> -    svm->host.ldt = kvm_read_ldt();
> >>> -
> >>> -    for (i = 0; i < NR_HOST_SAVE_USER_MSRS; i++)
> >>> +    for (i = 0; i < NR_HOST_SAVE_USER_MSRS; i++) {
> >>>       rdmsrl(host_save_user_msrs[i], svm->host_user_msrs[i]);
> >>> +    }
> > 
> > Hi Sean,
> > 
> > Hopefully I've got my email situation sorted out now...
> > 
> >> Unnecessary change that violates preferred coding style.  Checkpatch explicitly
> >> complains about this.
> >> WARNING: braces {} are not necessary for single statement blocks
> >> #132: FILE: arch/x86/kvm/svm/svm.c:1370:
> >> +    for (i = 0; i < NR_HOST_SAVE_USER_MSRS; i++) {
> >>       rdmsrl(host_save_user_msrs[i], svm->host_user_msrs[i]);
> >> +
> > 
> > Sorry, that was an artifact from an earlier version of the patch that I
> > failed to notice. I'll make sure to run everything through checkpatch
> > going forward.
> > 
> >>> +
> >>> +    asm volatile(__ex("vmsave")
> >>> +             : : "a" (page_to_pfn(sd->save_area) << PAGE_SHIFT)
> >> I'm pretty sure this can be page_to_phys().
> >>> +             : "memory");
> >> I think we can defer this until we're actually planning on running the guest,
> >> i.e. put this in svm_prepare_guest_switch().
> > 
> > One downside to that is that we'd need to do the VMSAVE on every
> > iteration of vcpu_run(), as opposed to just once when we enter from
> > userspace via KVM_RUN. It ends up being a similar situation to Andy's
> > earlier suggestion of moving VMLOAD just after vmexit, but in that case
> > we were able to remove an MSR write to MSR_GS_BASE, which cancelled out
> > the overhead, but in this case I think it could only cost us extra.
> 
> If you want to micro-optimize, there is a trick you could play: use WRGSBASE if available.  If X86_FEATURE_GSBASE is available, you could use WRGSBASE to restore GSBASE and defer VMLOAD to vcpu_put().  This would need benchmarking on Zen 3 to see if it’s worthwhile.

I'll give this a try. The vmsave only seems to be 100-200 in and of itself so
I'm not sure there's much to be gained, but would be good to know either
way.

> 
> 

  parent reply	other threads:[~2020-12-15 18:58 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-12-14 17:41 [PATCH v2] KVM: SVM: use vmsave/vmload for saving/restoring additional host state Michael Roth
2020-12-14 19:38 ` Sean Christopherson
2020-12-14 20:08   ` Andy Lutomirski
2020-12-14 22:02   ` Michael Roth
2020-12-14 22:23     ` Sean Christopherson
2020-12-14 22:29     ` Andy Lutomirski
2020-12-15 10:15       ` Paolo Bonzini
2020-12-15 18:17       ` Michael Roth [this message]
2020-12-16 15:12         ` Michael Roth
2020-12-16 15:23           ` Paolo Bonzini
2020-12-16 17:07             ` Michael Roth
2020-12-15 18:55   ` Michael Roth
2020-12-16 23:48     ` Sean Christopherson
2020-12-17  8:29       ` Paolo Bonzini

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=20201215181747.jhozec5gpa4ud5qt@amd.com \
    --to=michael.roth@amd.com \
    --cc=bp@alien8.de \
    --cc=hpa@zytor.com \
    --cc=jmattson@google.com \
    --cc=joro@8bytes.org \
    --cc=kvm@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=luto@amacapital.net \
    --cc=luto@kernel.org \
    --cc=mingo@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=seanjc@google.com \
    --cc=tglx@linutronix.de \
    --cc=thomas.lendacky@amd.com \
    --cc=vkuznets@redhat.com \
    --cc=wanpengli@tencent.com \
    --cc=x86@kernel.org \
    /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.