Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp3097744ybc; Thu, 14 Nov 2019 04:02:22 -0800 (PST) X-Google-Smtp-Source: APXvYqxBtVtzw3KmJaGczRot/DQfrYtU+j4QJ+HtW27c66sppSFcvZtgqLI8zQ7gRdsnuS+AGKu/ X-Received: by 2002:a17:906:f10:: with SMTP id z16mr8224635eji.211.1573732942801; Thu, 14 Nov 2019 04:02:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573732942; cv=none; d=google.com; s=arc-20160816; b=JStMfAYtqFi85ulCkf/siqJjlH+y8srU+562/a4oFyYLF2uF3on9wYSGGivKLYt0F4 BzpU5ttBF4XFQGDuWozZpLT2+VKvA25BNy3ufdKJsCKbieZCVHxeSHH3WyPTXDv9lfsq WR8VP7fD4HUCDJL6DdRqkQfxxruw01EZSo74JzIxaKQBPKzNqfsCKVtk1gYidsXq/EE1 5AAeOAIab9w3jL5fW5LvJdGy79Vb8xEYLL1sme51iCbMVnejxyexuUEoHRdCOMIVYgKV UmtSmqkhR7FmhUmg/Tka51wLeDI4cQgvsmDonou7SnRHe417QJke2vgv2KT+DxLj6GK9 MJjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=4US+hVaXhjSiBbdSE96WD7Ru4CXdoh15YX5CrSFyPiQ=; b=x+Ufu6DDNejsT0XG5+GK5JsWg/WpgcX6pTazpC5ah3ZgRj/E8pVcCZezHFL9tMeMN3 jGlvVkHwlPnL+NqpW5zb8LLoighzhjXghh2iGCFmW+DdPcxSNw/YJl3KKTlQLM9MSace 0dv6B9NbStrf4qv9ozt6PahIhhxoVVpZ8SI+HlFxPpFea2xKSn0U5u8OwTyiNdaBRvXY w2xGzeBx0OV8QQ6/mNcOW7mhs8nFbfIRP0iEo6HzZoYGaEc2Wgnv2OurW74x+NYBV26+ 9MTutIKRS1FZrwgj1rBTDugRH9QcBOxNZl5uoFc39M3Ec4nYh1zLB+/vnLFlRGnufe8R 7IsQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=M1cRtYqH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id ca22si3233686ejb.22.2019.11.14.04.01.56; Thu, 14 Nov 2019 04:02:22 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=M1cRtYqH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726263AbfKNL7D (ORCPT + 99 others); Thu, 14 Nov 2019 06:59:03 -0500 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:53182 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726057AbfKNL7C (ORCPT ); Thu, 14 Nov 2019 06:59:02 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1573732740; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=4US+hVaXhjSiBbdSE96WD7Ru4CXdoh15YX5CrSFyPiQ=; b=M1cRtYqHgF3aZeDn4Tlthk0FAs2alcAyFtcrEntQCWAFXM+9km0yM3/LTonBTYjVnwvGhW EI3D8BKGB6N6ued8DnfH7Sz6CGWBba0TCjiCLkkuesK3dxdWu/BiyifEsniEMY7gfZZ8Zs Ks5JjS+N93xxLoEfY9nKYrr+AHgu9Yc= Received: from mail-wr1-f70.google.com (mail-wr1-f70.google.com [209.85.221.70]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-371-XuyUh46nMr2DVtIprUzxTg-1; Thu, 14 Nov 2019 06:58:57 -0500 Received: by mail-wr1-f70.google.com with SMTP id w4so4269709wro.10 for ; Thu, 14 Nov 2019 03:58:57 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=0g9kY8U3aDWmWJZUL7RMmE4YKOXbneFc8qmjFB/A0xY=; b=Qe1yOhLaxvl2OhEbO8QqueWJfbq2VeXGWK17Bs2EIPC8bx3g3oF/4jLiK5cKTy9bei xhfSGNOjGY2WtFDgk7SVMRHAzHC4RdH5Zy5E/MUxrFEr3/FDOAhk3Aw9XfY2yL6J5cmG T6UKxY7JA7D1tG10h7bkysNuLdd3PEU1esddukiVCfIYr53uF18osEEOFPnKzoToqQL/ boAWzMH2Y2Efs1r5mRFgsbz9ARZwak1SLuwPo3n1W70VaXaq7fiQg+W3Y7uJMu4uTX8u PZq3HeZzag71ECY/km6HDj+cUpd8GpGJhBkczSCKaCy/RoSmElHBwUWHTqAOqmPGjaZj 8gTA== X-Gm-Message-State: APjAAAUEt3L+7hsf96MoLLLp4oLsur62oWkaQm6sp4nOMb0InPYuTg71 aLGlh4dKwudl79//EiFtKfhrDxp9jDLNGI5UveiCPFdCG7U5ReTRRPxjR1HgxGJKb8gub5EE0YR Ryi31375UgkMOPOS4F+Op7Kmm X-Received: by 2002:a05:600c:20e:: with SMTP id 14mr7190772wmi.107.1573732736498; Thu, 14 Nov 2019 03:58:56 -0800 (PST) X-Received: by 2002:a05:600c:20e:: with SMTP id 14mr7190748wmi.107.1573732736192; Thu, 14 Nov 2019 03:58:56 -0800 (PST) Received: from ?IPv6:2001:b07:6468:f312:a15b:f753:1ac4:56dc? ([2001:b07:6468:f312:a15b:f753:1ac4:56dc]) by smtp.gmail.com with ESMTPSA id z14sm6685230wrl.60.2019.11.14.03.58.55 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 14 Nov 2019 03:58:55 -0800 (PST) Subject: Re: [PATCH 1/2] KVM: X86: Single target IPI fastpath To: Wanpeng Li , linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= , Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel References: <1573283135-5502-1-git-send-email-wanpengli@tencent.com> From: Paolo Bonzini Message-ID: <6c2c7bbb-39f4-2a77-632e-7730e9887fc5@redhat.com> Date: Thu, 14 Nov 2019 12:58:56 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <1573283135-5502-1-git-send-email-wanpengli@tencent.com> Content-Language: en-US X-MC-Unique: XuyUh46nMr2DVtIprUzxTg-1 X-Mimecast-Spam-Score: 0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Ok, it's not _so_ ugly after all. > --- > arch/x86/kvm/vmx/vmx.c | 39 +++++++++++++++++++++++++++++++++++++-- > include/linux/kvm_host.h | 1 + > 2 files changed, 38 insertions(+), 2 deletions(-) >=20 > diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c > index 5d21a4a..5c67061 100644 > --- a/arch/x86/kvm/vmx/vmx.c > +++ b/arch/x86/kvm/vmx/vmx.c > @@ -5924,7 +5924,9 @@ static int vmx_handle_exit(struct kvm_vcpu *vcpu) > =09=09} > =09} > =20 > -=09if (exit_reason < kvm_vmx_max_exit_handlers > +=09if (vcpu->fast_vmexit) > +=09=09return 1; > +=09else if (exit_reason < kvm_vmx_max_exit_handlers Instead of a separate vcpu->fast_vmexit, perhaps you can set exit_reason to vmx->exit_reason to -1 if the fast path succeeds. > +=09=09=09if (ret =3D=3D 0) > +=09=09=09=09ret =3D kvm_skip_emulated_instruction(vcpu); Please move the "kvm_skip_emulated_instruction(vcpu)" to vmx_handle_exit, so that this basically is #define EXIT_REASON_NEED_SKIP_EMULATED_INSN -1 =09if (ret =3D=3D 0) =09=09vcpu->exit_reason =3D EXIT_REASON_NEED_SKIP_EMULATED_INSN; and handle_ipi_fastpath can return void. Thanks, Paolo > +=09=09}; > +=09}; > + > +=09return ret; > +} > + > static void vmx_vcpu_run(struct kvm_vcpu *vcpu) > { > =09struct vcpu_vmx *vmx =3D to_vmx(vcpu); > @@ -6615,6 +6645,12 @@ static void vmx_vcpu_run(struct kvm_vcpu *vcpu) > =09=09=09=09 | (1 << VCPU_EXREG_CR3)); > =09vcpu->arch.regs_dirty =3D 0; > =20 > +=09vmx->exit_reason =3D vmx->fail ? 0xdead : vmcs_read32(VM_EXIT_REASON)= ; > +=09vcpu->fast_vmexit =3D false; > +=09if (!is_guest_mode(vcpu) && > +=09=09vmx->exit_reason =3D=3D EXIT_REASON_MSR_WRITE) > +=09=09vcpu->fast_vmexit =3D handle_ipi_fastpath(vcpu); This should be done later, at least after kvm_put_guest_xcr0, because running with partially-loaded guest state is harder to audit. The best place to put it actually is right after the existing vmx->exit_reason assignment, where we already handle EXIT_REASON_MCE_DURING_VMENTRY. > =09pt_guest_exit(vmx); > =20 > =09/* > @@ -6634,7 +6670,6 @@ static void vmx_vcpu_run(struct kvm_vcpu *vcpu) > =09vmx->nested.nested_run_pending =3D 0; > =09vmx->idt_vectoring_info =3D 0; > =20 > -=09vmx->exit_reason =3D vmx->fail ? 0xdead : vmcs_read32(VM_EXIT_REASON)= ; > =09if ((u16)vmx->exit_reason =3D=3D EXIT_REASON_MCE_DURING_VMENTRY) > =09=09kvm_machine_check(); > =20 > diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h > index 719fc3e..7a7358b 100644 > --- a/include/linux/kvm_host.h > +++ b/include/linux/kvm_host.h > @@ -319,6 +319,7 @@ struct kvm_vcpu { > #endif > =09bool preempted; > =09bool ready; > +=09bool fast_vmexit; > =09struct kvm_vcpu_arch arch; > =09struct dentry *debugfs_dentry; > }; >=20