Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp368360pxa; Fri, 31 Jul 2020 14:26:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy7ldJ/4cNdUKr6OV8mbekt7r1tQYiU8or6wJlxiTBuFygzjbfdi21NQUvgYHPzWdIxfQed X-Received: by 2002:a17:906:c143:: with SMTP id dp3mr5927434ejc.504.1596230784230; Fri, 31 Jul 2020 14:26:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596230784; cv=none; d=google.com; s=arc-20160816; b=Y/k4sHkfVVW+7QVTML/mtC2fZlf3tR3Yve7a0j+fjiG9B+bwgPn1oqIT7LVZLzon59 IWCVJnNVR9AlGk4EZUteGp5Ep3dH+H1tMcCgvGUQoLR4PR12GRY8feE4xDJB8uhYj9UG iC4uyNgsUXgKlqR+jroeYvh1l9Kc1vgvSlB1aP2q13FKkmPA1LtFJHImUpOlgWxjh4QM j8kfq07QB7OjVRz8w7w1YOvrESIqV479sNLlfj0LGniywwbE8TRUf3mHvv6+S7qrfF3A rrhiV0OQ4QE+DVprcw+5F0aRkDM93moRoqVNcPpRBUIQ4A0Iw+BHjYgM1p4t2uWZ7TXI uiXQ== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=U+927nCOawLWrrt1LANhwOKy1SqBW20V2yXYmhpw/iY=; b=oWjvgncFTQpyEPPEGS2Qk/MBJ/O8feXTXL1V1jE2XE5MZZUwn5RTIDUblnS8X89Qpv EuQALBo/0d5iVhJIaIKUrzk/6jZu7P+3pyGa+VHKl7Eg8UGIZ5lnx4m0xBCSrtoESkSi F9Et7YGkuqfFDdjfBEZ3ES71FqmPh6ieOcFcBCTU3I7Z70xIm/j7BuIdA5EcY6srksyQ 9WZgikxIzPjTAgmQqy2dn3cYvXQqKdeRNnnAqQHXgtoqCDyWDno+lsToC9IQ5W3KhpcI lhKnK1viPOgm5rarvaxYC2rwS1Us4d77zYjyLjigXiTpxx5gq4YKmGiM3v1JVowwKdrz zmQA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v12si5966851edy.197.2020.07.31.14.26.02; Fri, 31 Jul 2020 14:26:24 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729840AbgGaVXj (ORCPT + 99 others); Fri, 31 Jul 2020 17:23:39 -0400 Received: from mga14.intel.com ([192.55.52.115]:50227 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728655AbgGaVX3 (ORCPT ); Fri, 31 Jul 2020 17:23:29 -0400 IronPort-SDR: 6U13IaOWIutveJZigExAcIaX+/xN9fxwDw2b9eZyQD0mwUtcTqVENFG4APuxcKr3Es883OV1zB 0C8Xzx/56SsQ== X-IronPort-AV: E=McAfee;i="6000,8403,9699"; a="151075132" X-IronPort-AV: E=Sophos;i="5.75,419,1589266800"; d="scan'208";a="151075132" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 31 Jul 2020 14:23:27 -0700 IronPort-SDR: 0dxITT+mw/DBoc2cD0a1KPHakQR7T57+QAoK254zJ3Nu/6obst6UuBtT9jiCX5LntxjXmx4SjO 70KVutgnY2sw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,419,1589266800"; d="scan'208";a="331191311" Received: from sjchrist-coffee.jf.intel.com ([10.54.74.160]) by orsmga007.jf.intel.com with ESMTP; 31 Jul 2020 14:23:26 -0700 From: Sean Christopherson To: Paolo Bonzini Cc: Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, eric van tassell , Tom Lendacky Subject: [RFC PATCH 6/8] KVM: x86/mmu: Move 'pfn' variable to caller of direct_page_fault() Date: Fri, 31 Jul 2020 14:23:21 -0700 Message-Id: <20200731212323.21746-7-sean.j.christopherson@intel.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200731212323.21746-1-sean.j.christopherson@intel.com> References: <20200731212323.21746-1-sean.j.christopherson@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When adding pages prior to boot, SEV needs to pin the resulting host pfn so that the pages that are consumed by sev_launch_update_data() are not moved after the memory is encrypted, which would corrupt the guest data. Signed-off-by: Sean Christopherson --- arch/x86/kvm/mmu/mmu.c | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/arch/x86/kvm/mmu/mmu.c b/arch/x86/kvm/mmu/mmu.c index cab3b2f2f49c3..92b133d7b1713 100644 --- a/arch/x86/kvm/mmu/mmu.c +++ b/arch/x86/kvm/mmu/mmu.c @@ -4156,7 +4156,8 @@ static bool try_async_pf(struct kvm_vcpu *vcpu, bool prefault, gfn_t gfn, } static int direct_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, - bool prefault, int max_level, bool is_tdp) + bool prefault, int max_level, bool is_tdp, + kvm_pfn_t *pfn) { bool write = error_code & PFERR_WRITE_MASK; bool exec = error_code & PFERR_FETCH_MASK; @@ -4165,7 +4166,6 @@ static int direct_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, gfn_t gfn = gpa >> PAGE_SHIFT; unsigned long mmu_seq; - kvm_pfn_t pfn; int r; if (page_fault_handle_page_track(vcpu, error_code, gfn)) @@ -4184,10 +4184,10 @@ static int direct_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, mmu_seq = vcpu->kvm->mmu_notifier_seq; smp_rmb(); - if (try_async_pf(vcpu, prefault, gfn, gpa, &pfn, write, &map_writable)) + if (try_async_pf(vcpu, prefault, gfn, gpa, pfn, write, &map_writable)) return RET_PF_RETRY; - if (handle_abnormal_pfn(vcpu, is_tdp ? 0 : gpa, gfn, pfn, ACC_ALL, &r)) + if (handle_abnormal_pfn(vcpu, is_tdp ? 0 : gpa, gfn, *pfn, ACC_ALL, &r)) return r; r = RET_PF_RETRY; @@ -4197,23 +4197,25 @@ static int direct_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, r = make_mmu_pages_available(vcpu); if (r) goto out_unlock; - r = __direct_map(vcpu, gpa, write, map_writable, max_level, pfn, + r = __direct_map(vcpu, gpa, write, map_writable, max_level, *pfn, prefault, is_tdp && lpage_disallowed); out_unlock: spin_unlock(&vcpu->kvm->mmu_lock); - kvm_release_pfn_clean(pfn); + kvm_release_pfn_clean(*pfn); return r; } static int nonpaging_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, bool prefault) { + kvm_pfn_t pfn; + pgprintk("%s: gva %lx error %x\n", __func__, gpa, error_code); /* This path builds a PAE pagetable, we can map 2mb pages at maximum. */ return direct_page_fault(vcpu, gpa & PAGE_MASK, error_code, prefault, - PG_LEVEL_2M, false); + PG_LEVEL_2M, false, &pfn); } int kvm_handle_page_fault(struct kvm_vcpu *vcpu, u64 error_code, @@ -4252,6 +4254,7 @@ EXPORT_SYMBOL_GPL(kvm_handle_page_fault); int kvm_tdp_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, bool prefault) { + kvm_pfn_t pfn; int max_level; for (max_level = KVM_MAX_HUGEPAGE_LEVEL; @@ -4265,7 +4268,7 @@ int kvm_tdp_page_fault(struct kvm_vcpu *vcpu, gpa_t gpa, u32 error_code, } return direct_page_fault(vcpu, gpa, error_code, prefault, - max_level, true); + max_level, true, &pfn); } static void nonpaging_init_context(struct kvm_vcpu *vcpu, -- 2.28.0