Received: by 10.223.164.221 with SMTP id h29csp284042wrb; Fri, 3 Nov 2017 09:05:20 -0700 (PDT) X-Google-Smtp-Source: ABhQp+SwEhCRKTF1Jx514Y0nHvFpG2/PCGMbNl/GDf2uhq2uoRI7sD7FFhz/KP7pLHT12msDhm/3 X-Received: by 10.99.45.67 with SMTP id t64mr7509206pgt.108.1509725119888; Fri, 03 Nov 2017 09:05:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509725119; cv=none; d=google.com; s=arc-20160816; b=pQr1KBERKqzG8Y/wjV+sUnSloDb4c48xSjFajFcV09LhWo73MInLIdsUxupRusIexE VdCa53lv2Q8dZUDxCV43ltS3DrPKy/jCjSqlAgsCepTrBZiCDbQ4BBXpG4JCOcuzDn5v isOBS4CoCQMasd8hL+4dh7rPb7LFOvIFCG3bvI/xXZjzds0FUko2KwuKyqloeHL7oLab v7wAYLi3TIIP1j+FvxbwwUbdiO2FLhrVeBM6HeTNKqhQULmGfzz59+lE3oEp4u3g5xbf RWd/RoaB5Whs3/BNKn1+jYcoh9SyPL3TyToMne2KsO68lnkPSY48FQxRWzdxEGh3V6q3 OeJw== 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:cc:to:subject :message-id:date:from:references:in-reply-to:mime-version :dkim-signature:arc-authentication-results; bh=gcrhPih2G+08yPtQo8ceXVeJpyQ0pX0OMYDqIdjOL4k=; b=BG8E/Le+WbQAFrv9p44I9FGuGdvmA50Hw/eolxhf+99pv72xZf3HhbUpjtFkIBJsuM BcgzuDdHwPPkzdJEPiP8JsoY36bp6IrI9h6bVf3T1TF+gygU9i9EAI3yYYj1yN9zHDo0 5W2YiClSqlNJ7ea/WO0+PRRoexRPiSAAzKnLXzKZjaJfTlkEiROcTl7JqhMy1oa+Cqr9 pFP52xEUX54JaZMLt9wOUKnnyS+qcn3DjO26IgwC/o2k3mS54taA7Y05BdZbnFhnDULT BXow0HTuW+Vm1XolD5brsVvNpcy6B03oihz1qEFa06RZMWOLOTCXJOXnrnsvZ3maFArB BZPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=k6Lgvvk1; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 3si5305976plu.523.2017.11.03.09.05.00; Fri, 03 Nov 2017 09:05:19 -0700 (PDT) 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=@google.com header.s=20161025 header.b=k6Lgvvk1; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756046AbdKCQBt (ORCPT + 94 others); Fri, 3 Nov 2017 12:01:49 -0400 Received: from mail-wr0-f196.google.com ([209.85.128.196]:48727 "EHLO mail-wr0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755883AbdKCQBr (ORCPT ); Fri, 3 Nov 2017 12:01:47 -0400 Received: by mail-wr0-f196.google.com with SMTP id 15so2933865wrb.5 for ; Fri, 03 Nov 2017 09:01:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=gcrhPih2G+08yPtQo8ceXVeJpyQ0pX0OMYDqIdjOL4k=; b=k6Lgvvk12jdZWPZim/5XRO9p2387A1pjaVQoDh7y6uoiYyrKZybTKGi5wcksPeq+Ui 0yoEMf+cc2ACU61TJMimILcy7GUgcQDpCqQ+mkL+qtO2wU+wggFvPVc/2cc+VdLerxL8 3oGbZ5Kd317jx61lQlZRO2iz0uUiOydGH5r7UlF5VGnWDaRPE1XHtCtNC9Y9CtTcJtL2 UvMWvHfhqgyeTMi26NYnOpFUBxcHx33sIPZ8uyHp1tF5hu1YgsTsidJf4Lg0Ddl95YAs 38ssbKpQLRNNHSDpaJNdOFdKZ71Bz1hpg1V6wvCRpy7h8uiKGr8qEunRQCyH0mJdrlQe OiTw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=gcrhPih2G+08yPtQo8ceXVeJpyQ0pX0OMYDqIdjOL4k=; b=BSK5WBOPmlgvZBuzA4XuZ1DtHI3H/ubjQq3KEOzO/G1m0LqTinLlulrmY0KtJkipv7 Du8TnW2/m/p/FtAafRnoJcmy3vwBUzk++NdA7hfHhNcfHd8Gu3FtUYYZM7n+XPK58hpx nCN3KPRndZ2YqC1VSqnSy6MVmToHpPObe3HizSEXgXGwqG/+pU0cP5hwP3sIM1NUJJeX SyIUMyIl2vVVJsvG1PIx8JTk+dmi+7PGq2ZypuySsqbziwoitUlx7If4oZSiBKT2vl8q 8IUxyKmguX5wFdeiKY4xozS1kwDApRTV5Pp+F+YgZYiHvWu505Qd1YMyx7M3+2pKXrqX Gyzg== X-Gm-Message-State: AMCzsaV+rwErS4KeoUZiYv/rLVXSpFgPNBKXg0V7iH7VwRNYubFn0TKx BpqLScm7NgHAEubILQJJ4nSjWilYV0EyiLiahN8ceg== X-Received: by 10.223.153.234 with SMTP id y97mr6196836wrb.165.1509724905120; Fri, 03 Nov 2017 09:01:45 -0700 (PDT) MIME-Version: 1.0 Received: by 10.223.155.157 with HTTP; Fri, 3 Nov 2017 09:01:44 -0700 (PDT) In-Reply-To: <1509670249-4907-3-git-send-email-wanpeng.li@hotmail.com> References: <1509670249-4907-1-git-send-email-wanpeng.li@hotmail.com> <1509670249-4907-3-git-send-email-wanpeng.li@hotmail.com> From: Jim Mattson Date: Fri, 3 Nov 2017 09:01:44 -0700 Message-ID: Subject: Re: [PATCH v5 3/3] KVM: nVMX: Fix mmu context after VMLAUNCH/VMRESUME failure To: Wanpeng Li Cc: LKML , kvm list , Paolo Bonzini , =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= , Wanpeng Li 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 That seems reasonable to me. Thanks for the fix. Reviewed-by: Jim Mattson On Thu, Nov 2, 2017 at 5:50 PM, Wanpeng Li wrote: > From: Wanpeng Li > > Commit 4f350c6dbcb (kvm: nVMX: Handle deferred early VMLAUNCH/VMRESUME fa= ilure > properly) can result in L1(run kvm-unit-tests/run_tests.sh vmx_controls i= n L1) > null pointer deference and also L0 calltrace when EPT=3D0 on both L0 and = L1. > > In L1: > > BUG: unable to handle kernel paging request at ffffffffc015bf8f > IP: vmx_vcpu_run+0x202/0x510 [kvm_intel] > PGD 146e13067 P4D 146e13067 PUD 146e15067 PMD 3d2686067 PTE 3d4af9161 > Oops: 0003 [#1] PREEMPT SMP > CPU: 2 PID: 1798 Comm: qemu-system-x86 Not tainted 4.14.0-rc4+ #6 > RIP: 0010:vmx_vcpu_run+0x202/0x510 [kvm_intel] > Call Trace: > WARNING: kernel stack frame pointer at ffffb86f4988bc18 in qemu-system-x= 86:1798 has bad value 0000000000000002 > > In L0: > > -----------[ cut here ]------------ > WARNING: CPU: 6 PID: 4460 at /home/kernel/linux/arch/x86/kvm//vmx.c:9845= vmx_inject_page_fault_nested+0x130/0x140 [kvm_intel] > CPU: 6 PID: 4460 Comm: qemu-system-x86 Tainted: G OE 4.14.0-= rc7+ #25 > RIP: 0010:vmx_inject_page_fault_nested+0x130/0x140 [kvm_intel] > Call Trace: > paging64_page_fault+0x500/0xde0 [kvm] > ? paging32_gva_to_gpa_nested+0x120/0x120 [kvm] > ? nonpaging_page_fault+0x3b0/0x3b0 [kvm] > ? __asan_storeN+0x12/0x20 > ? paging64_gva_to_gpa+0xb0/0x120 [kvm] > ? paging64_walk_addr_generic+0x11a0/0x11a0 [kvm] > ? lock_acquire+0x2c0/0x2c0 > ? vmx_read_guest_seg_ar+0x97/0x100 [kvm_intel] > ? vmx_get_segment+0x2a6/0x310 [kvm_intel] > ? sched_clock+0x1f/0x30 > ? check_chain_key+0x137/0x1e0 > ? __lock_acquire+0x83c/0x2420 > ? kvm_multiple_exception+0xf2/0x220 [kvm] > ? debug_check_no_locks_freed+0x240/0x240 > ? debug_smp_processor_id+0x17/0x20 > ? __lock_is_held+0x9e/0x100 > kvm_mmu_page_fault+0x90/0x180 [kvm] > kvm_handle_page_fault+0x15c/0x310 [kvm] > ? __lock_is_held+0x9e/0x100 > handle_exception+0x3c7/0x4d0 [kvm_intel] > vmx_handle_exit+0x103/0x1010 [kvm_intel] > ? kvm_arch_vcpu_ioctl_run+0x1628/0x2e20 [kvm] > > The commit avoids to load host state of vmcs12 as vmcs01's guest state > since vmcs12 is not modified (except for the VM-instruction error field) > if the checking of vmcs control area fails. However, the mmu context is > switched to nested mmu in prepare_vmcs02() and it will not be reloaded > since load_vmcs12_host_state() is skipped when nested VMLAUNCH/VMRESUME > fails. This patch fixes it by reloading mmu context when nested > VMLAUNCH/VMRESUME fails. > > Cc: Paolo Bonzini > Cc: Radim Kr=C4=8Dm=C3=A1=C5=99 > Cc: Jim Mattson > Signed-off-by: Wanpeng Li > --- > v3 -> v4: > * move it to a new function load_vmcs12_mmu_host_state > > arch/x86/kvm/vmx.c | 34 ++++++++++++++++++++++------------ > 1 file changed, 22 insertions(+), 12 deletions(-) > > diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c > index 6cf3972..8aefb91 100644 > --- a/arch/x86/kvm/vmx.c > +++ b/arch/x86/kvm/vmx.c > @@ -11259,6 +11259,24 @@ static void prepare_vmcs12(struct kvm_vcpu *vcpu= , struct vmcs12 *vmcs12, > kvm_clear_interrupt_queue(vcpu); > } > > +static void load_vmcs12_mmu_host_state(struct kvm_vcpu *vcpu, > + struct vmcs12 *vmcs12) > +{ > + u32 entry_failure_code; > + > + nested_ept_uninit_mmu_context(vcpu); > + > + /* > + * Only PDPTE load can fail as the value of cr3 was checked on en= try and > + * couldn't have changed. > + */ > + if (nested_vmx_load_cr3(vcpu, vmcs12->host_cr3, false, &entry_fai= lure_code)) > + nested_vmx_abort(vcpu, VMX_ABORT_LOAD_HOST_PDPTE_FAIL); > + > + if (!enable_ept) > + vcpu->arch.walk_mmu->inject_page_fault =3D kvm_inject_pag= e_fault; > +} > + > /* > * A part of what we need to when the nested L2 guest exits and we want = to > * run its L1 parent, is to reset L1's guest state to the host state spe= cified > @@ -11272,7 +11290,6 @@ static void load_vmcs12_host_state(struct kvm_vcp= u *vcpu, > struct vmcs12 *vmcs12) > { > struct kvm_segment seg; > - u32 entry_failure_code; > > if (vmcs12->vm_exit_controls & VM_EXIT_LOAD_IA32_EFER) > vcpu->arch.efer =3D vmcs12->host_ia32_efer; > @@ -11299,17 +11316,7 @@ static void load_vmcs12_host_state(struct kvm_vc= pu *vcpu, > vcpu->arch.cr4_guest_owned_bits =3D ~vmcs_readl(CR4_GUEST_HOST_MA= SK); > vmx_set_cr4(vcpu, vmcs12->host_cr4); > > - nested_ept_uninit_mmu_context(vcpu); > - > - /* > - * Only PDPTE load can fail as the value of cr3 was checked on en= try and > - * couldn't have changed. > - */ > - if (nested_vmx_load_cr3(vcpu, vmcs12->host_cr3, false, &entry_fai= lure_code)) > - nested_vmx_abort(vcpu, VMX_ABORT_LOAD_HOST_PDPTE_FAIL); > - > - if (!enable_ept) > - vcpu->arch.walk_mmu->inject_page_fault =3D kvm_inject_pag= e_fault; > + load_vmcs12_mmu_host_state(vcpu, vmcs12); > > if (enable_vpid) { > /* > @@ -11539,6 +11546,9 @@ static void nested_vmx_vmexit(struct kvm_vcpu *vc= pu, u32 exit_reason, > * accordingly. > */ > nested_vmx_failValid(vcpu, VMXERR_ENTRY_INVALID_CONTROL_FIELD); > + > + load_vmcs12_mmu_host_state(vcpu, vmcs12); > + > /* > * The emulated instruction was already skipped in > * nested_vmx_run, but the updated RIP was never > -- > 2.7.4 > From 1583004085682489797@xxx Fri Nov 03 00:52:19 +0000 2017 X-GM-THRID: 1583003100143951555 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread