From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-20.2 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,MENTIONS_GIT_HOSTING,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 557CDC433ED for ; Fri, 16 Apr 2021 10:51:47 +0000 (UTC) Received: from lists.ozlabs.org (lists.ozlabs.org [112.213.38.117]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id CF90B610E7 for ; Fri, 16 Apr 2021 10:51:46 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org CF90B610E7 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=arm.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=linuxppc-dev-bounces+linuxppc-dev=archiver.kernel.org@lists.ozlabs.org Received: from boromir.ozlabs.org (localhost [IPv6:::1]) by lists.ozlabs.org (Postfix) with ESMTP id 4FMCh11NnRz3c4l for ; Fri, 16 Apr 2021 20:51:45 +1000 (AEST) Authentication-Results: lists.ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=arm.com (client-ip=217.140.110.172; helo=foss.arm.com; envelope-from=steven.price@arm.com; receiver=) Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lists.ozlabs.org (Postfix) with ESMTP id 4FMCgf2c3sz30Fb for ; Fri, 16 Apr 2021 20:51:24 +1000 (AEST) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 31375106F; Fri, 16 Apr 2021 03:51:21 -0700 (PDT) Received: from [192.168.1.179] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 6D9123F85F; Fri, 16 Apr 2021 03:51:19 -0700 (PDT) Subject: Re: [PATCH v1 3/5] mm: ptdump: Provide page size to notepage() To: Christophe Leroy , Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman , akpm@linux-foundation.org References: <1ef6b954fb7b0f4dfc78820f1e612d2166c13227.1618506910.git.christophe.leroy@csgroup.eu> <41819925-3ee5-4771-e98b-0073e8f095cf@arm.com> From: Steven Price Message-ID: <1102cda1-b00f-b6ef-6bf3-22068cc11510@arm.com> Date: Fri, 16 Apr 2021 11:51:14 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 8bit X-BeenThere: linuxppc-dev@lists.ozlabs.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Linux on PowerPC Developers Mail List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-arch@vger.kernel.org, linux-s390@vger.kernel.org, x86@kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-riscv@lists.infradead.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org Errors-To: linuxppc-dev-bounces+linuxppc-dev=archiver.kernel.org@lists.ozlabs.org Sender: "Linuxppc-dev" On 16/04/2021 11:38, Christophe Leroy wrote: > > > Le 16/04/2021 à 11:28, Steven Price a écrit : >> On 15/04/2021 18:18, Christophe Leroy wrote: >>> In order to support large pages on powerpc, notepage() >>> needs to know the page size of the page. >>> >>> Add a page_size argument to notepage(). >>> >>> Signed-off-by: Christophe Leroy >>> --- >>>   arch/arm64/mm/ptdump.c         |  2 +- >>>   arch/riscv/mm/ptdump.c         |  2 +- >>>   arch/s390/mm/dump_pagetables.c |  3 ++- >>>   arch/x86/mm/dump_pagetables.c  |  2 +- >>>   include/linux/ptdump.h         |  2 +- >>>   mm/ptdump.c                    | 16 ++++++++-------- >>>   6 files changed, 14 insertions(+), 13 deletions(-) >>> >> [...] >>> diff --git a/mm/ptdump.c b/mm/ptdump.c >>> index da751448d0e4..61cd16afb1c8 100644 >>> --- a/mm/ptdump.c >>> +++ b/mm/ptdump.c >>> @@ -17,7 +17,7 @@ static inline int note_kasan_page_table(struct >>> mm_walk *walk, >>>   { >>>       struct ptdump_state *st = walk->private; >>> -    st->note_page(st, addr, 4, pte_val(kasan_early_shadow_pte[0])); >>> +    st->note_page(st, addr, 4, pte_val(kasan_early_shadow_pte[0]), >>> PAGE_SIZE); >> >> I'm not completely sure what the page_size is going to be used for, >> but note that KASAN presents an interesting case here. We short-cut by >> detecting it's a KASAN region at a high level (PGD/P4D/PUD/PMD) and >> instead of walking the tree down just call note_page() *once* but with >> level==4 because we know KASAN sets up the page table like that. >> >> However the one call actually covers a much larger region - so while >> PAGE_SIZE matches the level it doesn't match the region covered. >> AFAICT this will lead to odd results if you enable KASAN on powerpc. > > Hum .... I successfully tested it with KASAN, I now realise that I > tested it with CONFIG_KASAN_VMALLOC selected. In this situation, since > https://github.com/torvalds/linux/commit/af3d0a686 we don't have any > common shadow page table anymore. > > I'll test again without CONFIG_KASAN_VMALLOC. > >> >> To be honest I don't fully understand why powerpc requires the >> page_size - it appears to be using it purely to find "holes" in the >> calls to note_page(), but I haven't worked out why such holes would >> occur. > > I was indeed introduced for KASAN. We have a first commit > https://github.com/torvalds/linux/commit/cabe8138 which uses page size > to detect whether it is a KASAN like stuff. > > Then came https://github.com/torvalds/linux/commit/b00ff6d8c as a fix. I > can't remember what the problem was exactly, something around the use of > hugepages for kernel memory, came as part of the series > https://patchwork.ozlabs.org/project/linuxppc-dev/cover/cover.1589866984.git.christophe.leroy@csgroup.eu/ Ah, that's useful context. So it looks like powerpc took a different route to reducing the KASAN output to x86. Given the generic ptdump code has handling for KASAN already it should be possible to drop that from the powerpc arch code, which I think means we don't actually need to provide page size to notepage(). Hopefully that means more code to delete ;) Steve