Received: by 10.223.164.221 with SMTP id h29csp3133767wrb; Fri, 3 Nov 2017 02:11:15 -0700 (PDT) X-Google-Smtp-Source: ABhQp+R6t5Uax/xkqhogu953o0eH7qVd58NnN/YlLG6T4+yZ5AUXIWo8bQ2lB7Qg6ve2AZ0mWWHq X-Received: by 10.98.68.8 with SMTP id r8mr6933418pfa.161.1509700275376; Fri, 03 Nov 2017 02:11:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509700275; cv=none; d=google.com; s=arc-20160816; b=lyjTPIxiifzHmSYj5+6SMWxiCT0b5fQ76v/w44+VbP9kQ94JV2rKd74scWYvl+13Sn RKQvHsQR2yLrNkmLEw0UXAnS/RjmtJKOrQUEYkWHWLiaVoOakVaet4pM+BsqMLH4YOM+ cIbS4BosMcfsWVAZw1MSKVuGujR6KYn0VPr/Sh6/GEFDYeokFSsxoOeyhtEOZMd/g4OF IbgDec5Kd2zYr6e87yxZSrJ8a3nA5rxiJckWyEgE4DXbIZz+guNxWuB163Af+yDogpmv YC3L4UPhZfoHUXZav/GSqkvmhpwZqnkH9pU1FZo7aGFYEQUgPsslwMjcKlb0eFSQTGO9 UQbg== 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:to:subject:dkim-signature :arc-authentication-results; bh=dWiPFhnhnsUnk4COmzUFTNb+MluCVUt9A5R1v/oWOg4=; b=pGQE9XzEldnnoJ52Qq3SPJtouDL/78zwrgSkIOLKyCoCmoYfebkI8EP0LXFIALFxyU zh3llpkcclm2CiICMPnuAgS6lh63JEBsjM2ueFcArwE3dPm2csoRtU/UseLDz/ank7b7 fya/s+BDM24ouvgVf+vL3Is4+cCCLDJjC2rTAxjShv4wC22MLC3T50XgcaWBeufQb9Zo lQcbkBqHONSmVNG9M/o1Uj6QWe8ziRGhNVTqHVeyPn7zR5SVr/vqdHGipTWBY2h3C1nH LP+cVSa/NmGMBOCNGQXKGPDAUDCcuo0D0DfE9/nQ+ZS7QommrigstpN+QLYW4W42ILms HOow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=aWzISeiF; 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 h6si3522404pll.197.2017.11.03.02.11.01; Fri, 03 Nov 2017 02:11:15 -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=aWzISeiF; 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 S1755845AbdKCJKT (ORCPT + 98 others); Fri, 3 Nov 2017 05:10:19 -0400 Received: from mail-io0-f195.google.com ([209.85.223.195]:46281 "EHLO mail-io0-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752309AbdKCJKR (ORCPT ); Fri, 3 Nov 2017 05:10:17 -0400 Received: by mail-io0-f195.google.com with SMTP id 101so4838378ioj.3; Fri, 03 Nov 2017 02:10:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-language:content-transfer-encoding; bh=dWiPFhnhnsUnk4COmzUFTNb+MluCVUt9A5R1v/oWOg4=; b=aWzISeiFSmU7DY+iedMQeI02NC289rt1LW71OH13tW/uYcMK2AkP6PhclotVn/1r8J AZC14MZ4whdrcjaRW95IzNTHQ1Wd9QsuoOhUaom+gGZAWgt3Vl8r5iUYktMwH1ZTGJWO Z9CyZUrwuYUcIXF5NCiLP5mTv/1D/W1+XePZYMNFme36DY08E9Oy5VBS5zw+9dALwFtt 2/NEgGBglDZk2hc0QK0+VDdtYx8IRf0DGt/qSX0SM6gO7DbT8VUOAc30Ih76KvB1bNRU qtunweZOd68yNgwrRHM4YLlDVkc/BFWUMOny6q5cl+KppDx0lovEApbzbcolzTGTOC4r Lb1g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=dWiPFhnhnsUnk4COmzUFTNb+MluCVUt9A5R1v/oWOg4=; b=qAo2fvLWXW1upDmQkQS3DRk12IOVWx7omjTmPPLPsDt1ULhZjgmEMM+sdOGy3uAyOv NquksivKondsokDDONOq1v5a6v/5lqJXfKUZYyWKxFiq8fNzsstnw3fL9b0CHJkBn72+ ou1nwacWW5NyV+Sx/GBYIE2cINj0tDzu/qOwl/Le5jbt5SbC+fRDtMzAJq7jcL2jVOHs l6hNRmpPySWzvAie+YIgzSlEO6jBVYQLv2Icqgg4QS+kh69Zvq15KFsU/1LaJTiCFUzU uvkAVU8tWWuIHhLHmCozs67oOPNj1xuvZyhfcrDenMFYUSrOt3sDBQoNTJZzK6WNOOnX 230w== X-Gm-Message-State: AMCzsaVIQwqXXTzjSu/uLnqB3m2i/aizX5i2+22C6H9SDM4XLUbD+1Im YyzeTLPrHl/TQgSN/RZAAsc= X-Received: by 10.36.33.23 with SMTP id e23mr6673928ita.109.1509700216544; Fri, 03 Nov 2017 02:10:16 -0700 (PDT) Received: from eric.tencent.com ([203.205.141.35]) by smtp.gmail.com with ESMTPSA id k2sm2551632iok.43.2017.11.03.02.10.12 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 03 Nov 2017 02:10:16 -0700 (PDT) Subject: Re: [PATCH v4 3/3] KVM: MMU: consider host cache mode in MMIO page check To: Xiao Guangrong , kvm@vger.kernel.org, x86@kernel.org, linux-kernel@vger.kernel.org, Paolo Bonzini , rkrcmar@redhat.com, Dan Williams , ivan.d.cuevas.escareno@intel.com, karthik.kumar@intel.com, Konrad Rzeszutek Wilk , Olif Chapman , Ingo Molnar References: <20171103055327.21684-1-haozhong.zhang@intel.com> <20171103055327.21684-4-haozhong.zhang@intel.com> <745df599-b65b-bcfe-a20c-05ae6d99a0b5@gmail.com> <20171103085130.itjzxoaorvw34vnm@hz-desktop> From: Xiao Guangrong Message-ID: Date: Fri, 3 Nov 2017 17:10:36 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 MIME-Version: 1.0 In-Reply-To: <20171103085130.itjzxoaorvw34vnm@hz-desktop> 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 11/03/2017 04:51 PM, Haozhong Zhang wrote: > On 11/03/17 14:54 +0800, Xiao Guangrong wrote: >> >> >> On 11/03/2017 01:53 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 | 19 ++++++++++++++++++- >>> 1 file changed, 18 insertions(+), 1 deletion(-) >>> >>> diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c >>> index 0b481cc9c725..e9ed0e666a83 100644 >>> --- a/arch/x86/kvm/mmu.c >>> +++ b/arch/x86/kvm/mmu.c >>> @@ -2708,7 +2708,24 @@ 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)); >>> + return !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 in addition and >>> + * only treat UC/UC- pages as MMIO. >>> + * >>> + * pat_pfn_is_uc() works only when PAT is enabled, >>> + * so check pat_enabled() as well. >>> + */ >>> + (!pat_enabled() || >>> + pat_pfn_is_uc(kvm_pfn_t_to_pfn_t(pfn))); >> >> Can it be compiled if !CONFIG_PAT? > > Yes. > > What I check via pat_enabled() is not only whether PAT support is > compiled, but also whether PAT is enabled at runtime. The issue is about pat_pfn_is_uc() which is implemented only if CONFIG_PAT is enabled, but you used it here unconditionally. I am not sure if gcc is smart enough to omit pat_pfn_is_uc() completely under this case. If you really have done the test to compile kernel and KVM module with CONFIG_PAT disabled, it is fine. From 1583035068466282099@xxx Fri Nov 03 09:04:46 +0000 2017 X-GM-THRID: 1583005689428392726 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread