Received: by 10.223.164.221 with SMTP id h29csp1807470wrb; Thu, 2 Nov 2017 00:57:11 -0700 (PDT) X-Google-Smtp-Source: ABhQp+QP97TpFiXBbkzfeMFgvyKUUuzvVSANt6EnQA/oyFYmfZC+EBDrUwucjewuZ0Nw6nTxtMSD X-Received: by 10.159.203.133 with SMTP id ay5mr2347739plb.12.1509609430947; Thu, 02 Nov 2017 00:57:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509609430; cv=none; d=google.com; s=arc-20160816; b=ZgkH48kMdoVb+8t9aT2UW9jgcCG5B0d/AlnPDQhJypD6n7zrPcKx8mKgPdU7cMvx5u 0xB3QbNyzmXVSkjUt+mD5xKtI5ELvgudVVt69YZcG1V9XAcoqGX/4dG6YDDobXOlghFK zPxBiI2xFVH3NerXiSMJy0lF/7nTotMYirRvAR4pAY1oj/zYEMsrjUqM/kSEjtXoUP3q bZkWHjcMSzEE85r4i5nprs6FfA87x/xNo4IB5uQg47c2cupA7efnR6Pw06LPLVzmG1TV mxeuHS7izSjOU2xv7FoTvL0w8yynWE8cBwxHoRJ2p0rP4wly5TEFynj1vlV/gEYXl7PK qnOQ== 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 :arc-authentication-results; bh=fQ28sS3RVgFR/36OB8/nD8UNlFHJlK+E4jEMJovRi10=; b=G5/JGdP6uN7amBpOAool4b4z1DMgwJoabdu701a8hqxSkvIl41NfL1mNbGkhvCiPYX W3gPV7dlWylYecWJF/PBbDbfuSvbs0PwDQ2bsX9ogDPPw//rvNzp3gSxRymYz1GYrjMe yHH8n8ZoV47aY27LLkI5q1M/7NUsi18Ho22V8fge3alQXpZcflOrpY/E4AHlHZkCv7Ne 2tD8WL/V7GiPgfw8VH964Op9DVDRHkk/A88fTOHcpL2M7CVHZEGnAFno4M3FcVtDWpbI Cd/xHmxt9pct5NxWDXJso7evNva445M0sUSyoqhcsSowcuZ6pK9vO2p5wFxnqOX1RLTD QFnA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=NS7V/rpD; 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=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 3si1708459plb.469.2017.11.02.00.56.57; Thu, 02 Nov 2017 00:57:10 -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=@gmail.com header.s=20161025 header.b=NS7V/rpD; 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=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755175AbdKBH4Q (ORCPT + 99 others); Thu, 2 Nov 2017 03:56:16 -0400 Received: from mail-pg0-f65.google.com ([74.125.83.65]:51870 "EHLO mail-pg0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751587AbdKBH4O (ORCPT ); Thu, 2 Nov 2017 03:56:14 -0400 Received: by mail-pg0-f65.google.com with SMTP id p9so4364343pgc.8; Thu, 02 Nov 2017 00:56:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=fQ28sS3RVgFR/36OB8/nD8UNlFHJlK+E4jEMJovRi10=; b=NS7V/rpDQ4TOqIG/KP8hsEz6tybYWdzyR3g+rw24rHp0C61rda0hEpjat2Bqz8imL/ JSqoy8Rm/7If2DTPctbR3jonLv8jhEKs7nBd3F/LMhhgJvrCe2rzHEXpxJg/zvGHqekv YBczqtzilQ0DIFP84WsO6v12kZcSvDgGH+OkyHqGpIuEDvyHSRh3LnmU7P5IZDt+I+A8 mIZqPHBHacHBd/BIO6s7wsYdc53d4WGl8bQq4op+haUanHGWgCHYHs6UI86p69QpO5RC L6TW5Qm8YFMzFcjoOmkH4hH3+T8b89o7xbaGM9Hckgv/Uwo0KfCnaWUdcMeofAGK/cPq AWKA== 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=fQ28sS3RVgFR/36OB8/nD8UNlFHJlK+E4jEMJovRi10=; b=BJMiedC3+hMyT6K8QtWzDmPYUzi7KfaIHQvmhoGxwbMDPmw0fnKSqV51QSGaraVsWh 8TIGNnc6WQKq6YDje51rBgPFAihms74W17GUTUyyLU1AP4DUl63Ssm0cDChhEQ6aQHgz hE/Q7qDy1V8Q7GkwsK0/N8p0EMGJBTlVRjOZqoRMY4frpSe4x7jBmqHr5Uz47NLi7C2/ ScIlQm+p11JvFaCY4SZxfZLaKCptEoeU7ds/q6JR7tLXXxGBigAXOsIcVvI7fz/TAbDH XUknpduOUxn3wSLi72i0hUA6NLFoKJJDm8XLQpIQrI10qbJ/XuOty1k3CkvWcvl1r4/R cxlg== X-Gm-Message-State: AMCzsaWA/CC0DeQLTwSek6IGT9N9K7mXOvw5pH1KwItUzZmXsbmEK/YL TMo03CzICpk/3ueJtB+DTeU= X-Received: by 10.98.74.149 with SMTP id c21mr2832196pfj.200.1509609373868; Thu, 02 Nov 2017 00:56:13 -0700 (PDT) Received: from eric.tencent.com ([203.205.141.38]) by smtp.gmail.com with ESMTPSA id g16sm5075348pfd.87.2017.11.02.00.56.08 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 02 Nov 2017 00:56:13 -0700 (PDT) Subject: Re: [PATCH v2 2/2] KVM: MMU: consider host cache mode in MMIO page check To: Haozhong Zhang , kvm@vger.kernel.org, x86@kernel.org Cc: linux-kernel@vger.kernel.org, Paolo Bonzini , rkrcmar@redhat.com, Dan Williams , ivan.d.cuevas.escareno@intel.com, karthik.kumar@intel.com, Ingo Molnar References: <20171031114840.12615-1-haozhong.zhang@intel.com> <20171031114840.12615-3-haozhong.zhang@intel.com> From: Xiao Guangrong Message-ID: <824e2162-a6f0-9ca3-e45c-2dbf09a01f1a@gmail.com> Date: Thu, 2 Nov 2017 15:56:31 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.3.0 MIME-Version: 1.0 In-Reply-To: <20171031114840.12615-3-haozhong.zhang@intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/31/2017 07:48 PM, Haozhong Zhang wrote: > Some reserved pages, such as those from NVDIMM DAX devices, are > not for MMIO, and can be mapped with cached memory type for better > performance. However, the above check misconceives those pages as > MMIO. Because KVM maps MMIO pages with UC memory type, the > performance of guest accesses to those pages would be harmed. > Therefore, we check the host memory type by lookup_memtype() in > addition and only treat UC/UC- pages as MMIO. > > Signed-off-by: Haozhong Zhang > Reported-by: Cuevas Escareno, Ivan D > Reported-by: Kumar, Karthik > --- > arch/x86/kvm/mmu.c | 30 +++++++++++++++++++++++++++--- > 1 file changed, 27 insertions(+), 3 deletions(-) > > diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c > index 0b481cc9c725..206828d18857 100644 > --- a/arch/x86/kvm/mmu.c > +++ b/arch/x86/kvm/mmu.c > @@ -2707,10 +2707,34 @@ static bool mmu_need_write_protect(struct kvm_vcpu *vcpu, gfn_t gfn, > > static bool kvm_is_mmio_pfn(kvm_pfn_t pfn) > { > - if (pfn_valid(pfn)) > - return !is_zero_pfn(pfn) && PageReserved(pfn_to_page(pfn)); > + bool is_mmio = true; > > - return true; > + if (pfn_valid(pfn)) { > + is_mmio = !is_zero_pfn(pfn) && PageReserved(pfn_to_page(pfn)); > + > + /* > + * Some reserved pages, such as those from NVDIMM DAX > + * devices, are not for MMIO, and can be mapped with > + * cached memory type for better performance. However, > + * the above check misconceives those pages as MMIO. > + * Because KVM maps MMIO pages with UC memory type, > + * the performance of guest accesses to those pages > + * would be harmed. Therefore, we check the host > + * memory type by lookup_memtype() in addition and > + * only treat UC/UC- pages as MMIO. > + * > + * lookup_memtype() works only when PAT is enabled, so > + * add pat_enabled() check here. > + */ > + if (is_mmio && pat_enabled()) { > + enum page_cache_mode cm = lookup_memtype(PFN_PHYS(pfn)); > + > + is_mmio = (cm == _PAGE_CACHE_MODE_UC || > + cm == _PAGE_CACHE_MODE_UC_MINUS); > + } > + } You can move all of these detailed stuffs to pat.c and abstract them by introducing a function, maybe named pat_pfn_is_uc(). I think this is what Ingo wants. From 1582773766176775393@xxx Tue Oct 31 11:51:29 +0000 2017 X-GM-THRID: 1582773766176775393 X-Gmail-Labels: Inbox,Category Forums