Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp926877imb; Fri, 1 Mar 2019 19:39:36 -0800 (PST) X-Google-Smtp-Source: APXvYqxH2yYPxkp+WMYOW1p/KF8So28gDBZgdFN22dHZRmxXrHr0PDK8yMWjOfVgXTdC/kxwnYGB X-Received: by 2002:a62:b618:: with SMTP id j24mr9016112pff.120.1551497976828; Fri, 01 Mar 2019 19:39:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551497976; cv=none; d=google.com; s=arc-20160816; b=zYOHHv2IKHKwROHBcmS8xqARpl6/RrY8Wo16ezV5P3Ghkm/clxN151fqQpMjh4Mrlg aS/DX2KFOD8zxCIT4py2LlkPfY1nzkhrXoMUhxXePN87pkBKaJicQ+KCuhVux3HoX0Z8 cddXwoKEOMO/LWjOorfGwQN9C4wL/4QyUxHtrIUTOJVILhgvslxfm+2Rsrc1l3xUwmuH VaK+ZDYRFwe23VrHV4IZUTVHGITgbe4OahCRuiPujM0WTfpIsDLcHSsRVEefU+Ayimau dYYXtmE2Yrli12pD0DHAY4ljRxoYiGTr6y7eEIaGQYpVzq0mFj7dk56UTr6z+tTuaAci 9Rug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=Z1GjJQhC2a4opH/zP0QtkjI3vUdXwupHviZSlWAIG9Q=; b=euWJrIQCvnuObvetGwlTriqs+h6MN1RPwERYbMXMsSrMbIVZROZnLeCRkmfYXHUZd7 FAvpNHvi8Rbq3ljvwh2wlApgQ1LmLc6G8/M1IyQROodQULprpfL+M9zUs+i5Uvd5QsHe CBCXcEA01WGanFTsn7JeJ7OvpFidgIap2vA17I8PutVXPmhP8k/0W1XTkg0BO08cSYB1 zhMhcDuaUGBbota6aPjWqy/MWN74yQXrwu2k48fa7P2Fdhj36Hc26QRD1cmDxJlwmH0g vEdFEdnWxSVR2ZBvm5ss4KSxm9pjN0duof7k4MMWTGf8oNUPARM9/bVfaM38IdeNsgg6 oYBw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w62si17486158pgd.330.2019.03.01.19.39.19; Fri, 01 Mar 2019 19:39:36 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727492AbfCBDi7 (ORCPT + 99 others); Fri, 1 Mar 2019 22:38:59 -0500 Received: from szxga07-in.huawei.com ([45.249.212.35]:53560 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726412AbfCBDi7 (ORCPT ); Fri, 1 Mar 2019 22:38:59 -0500 Received: from DGGEMS414-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id A4143D35FE599429F0AD; Sat, 2 Mar 2019 11:38:54 +0800 (CST) Received: from HGHY2Y004646261.china.huawei.com (10.184.12.158) by DGGEMS414-HUB.china.huawei.com (10.3.19.214) with Microsoft SMTP Server id 14.3.408.0; Sat, 2 Mar 2019 11:38:48 +0800 From: Zenghui Yu To: , CC: , , , , , , , Zenghui Yu , Punit Agrawal Subject: [RFC PATCH] KVM: arm64: Force a PTE mapping when logging is enabled Date: Sat, 2 Mar 2019 03:35:28 +0000 Message-ID: <1551497728-12576-1-git-send-email-yuzenghui@huawei.com> X-Mailer: git-send-email 2.6.4.windows.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.184.12.158] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The idea behind this is: we don't want to keep tracking of huge pages when logging_active is true, which will result in performance degradation. We still need to set vma_pagesize to PAGE_SIZE, so that we can make use of it to force a PTE mapping. Cc: Suzuki K Poulose Cc: Punit Agrawal Signed-off-by: Zenghui Yu --- Atfer looking into https://patchwork.codeaurora.org/patch/647985/ , the "vma_pagesize = PAGE_SIZE" logic was not intended to be deleted. As far as I can tell, we used to have "hugetlb" to force the PTE mapping, but we have "vma_pagesize" currently instead. We should set it properly for performance reasons (e.g, in VM migration). Did I miss something important? --- virt/kvm/arm/mmu.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/virt/kvm/arm/mmu.c b/virt/kvm/arm/mmu.c index 30251e2..7d41b16 100644 --- a/virt/kvm/arm/mmu.c +++ b/virt/kvm/arm/mmu.c @@ -1705,6 +1705,13 @@ static int user_mem_abort(struct kvm_vcpu *vcpu, phys_addr_t fault_ipa, (vma_pagesize == PUD_SIZE && kvm_stage2_has_pmd(kvm))) && !force_pte) { gfn = (fault_ipa & huge_page_mask(hstate_vma(vma))) >> PAGE_SHIFT; + } else { + /* + * Fallback to PTE if it's not one of the stage2 + * supported hugepage sizes or the corresponding level + * doesn't exist, or logging is enabled. + */ + vma_pagesize = PAGE_SIZE; } up_read(¤t->mm->mmap_sem); -- 1.8.3.1