Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp5416936pxv; Wed, 21 Jul 2021 05:06:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz8xrS6FRrkWFaiLGPppbAh3A1CaXINvXODXQoaLUHMw/TgVZ2+Gi3RKn/A/yXBruOl95RT X-Received: by 2002:aa7:d990:: with SMTP id u16mr47288170eds.263.1626869193038; Wed, 21 Jul 2021 05:06:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626869193; cv=none; d=google.com; s=arc-20160816; b=ebqsGw+REi3gm79LG7Eo0MAuTZSvoUeXsiZrdXOktEuWfuTjGHHbMnFMjHAiXQ9j3U mydBQ2axl2gmffrvENZxb9AP6m4tpevvVLHzve+gDe+eUswJhaQAddo52Qr6d2kKmXcx Hk6iILfCsfY0W7tPKKxFn+8FxwE/I4VmspIqLtbXAClKeS+0S4z4A1mugvi3r90u6aHv MZoB8BhHE1A6alF3Qowm+st7QwyBumpSdcWmm3ogkdzd8XDhm2qs37J/xWR72hN7ih/s nWFIuyW6Ro+C4Vec48D6bBiUYilTEm503vUBqqHzWq3FfqmzIJYtGt+tSX26X1RfBk2Q Kd+g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:reply-to:dkim-signature; bh=JryZWvFrlLKi66Vw/QCUncxWD6JA1zMCqHqq9QMD1os=; b=Bdo13nXCXcw435tFOhXPSDbt54wiZwsXQBQnfanY/91WEWzoEl+sJdbxwxiRvUHguR jYhewS5k+8fgWtr9UJyCX3qzK5GiNhT00EAgNTeBuKljpKMoCGuEc9BTZJtG2nyUUGhe ezJT1XN59idc4VeZsqqS1DkMGA3ZxfXTVFizmyOjcqoorXGdswHQvEM4UP0Ot3T90D2a hE2FuAEyhl81h3oBFcd1Nc5Fi4fd4b3zlZVPHfb5K75USBSsI3GXunToz1vfbVnidsZu UvZVGR71X8kjBwBR1NqG8xL35Ss49OXi/UtOgLE3urLk7jZLDBBKeol5mVf+WsX/lAiP GfPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=JgNK2r4C; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i11si35628913edb.418.2021.07.21.05.06.09; Wed, 21 Jul 2021 05:06:33 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=JgNK2r4C; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233812AbhGULXj (ORCPT + 99 others); Wed, 21 Jul 2021 07:23:39 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:39572 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234910AbhGULQu (ORCPT ); Wed, 21 Jul 2021 07:16:50 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1626868647; h=from:from:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JryZWvFrlLKi66Vw/QCUncxWD6JA1zMCqHqq9QMD1os=; b=JgNK2r4CZgqmqcuZcnzgvoB1noLuMK11AOT56CsqK64pruXsLV1O09efxqfmnFh0hIenV6 Vs/TV40cew/Feiq9hBL05K8+SYH+KCMKmQs/27gvgQKb0gy3Vqn4r83mtPZO1EgR+EmuVE XstCWIcpcPCGGipydXtBtqAY8neazI8= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-300-plQpfmPYNF-sQtRIQWSFjg-1; Wed, 21 Jul 2021 07:57:26 -0400 X-MC-Unique: plQpfmPYNF-sQtRIQWSFjg-1 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id BAB7C363AD; Wed, 21 Jul 2021 11:57:24 +0000 (UTC) Received: from [10.64.54.195] (vpn2-54-195.bne.redhat.com [10.64.54.195]) by smtp.corp.redhat.com (Postfix) with ESMTPS id C00EF19C79; Wed, 21 Jul 2021 11:57:21 +0000 (UTC) Reply-To: Gavin Shan Subject: Re: [PATCH v3 02/12] mm/debug_vm_pgtable: Use struct pgtable_debug_args in basic tests To: Anshuman Khandual , linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org, catalin.marinas@arm.com, will@kernel.org, akpm@linux-foundation.org, chuhu@redhat.com, shan.gavin@gmail.com References: <20210719130613.334901-1-gshan@redhat.com> <20210719130613.334901-3-gshan@redhat.com> <20c7be76-661b-6e75-3721-7b577fb4e05d@arm.com> From: Gavin Shan Message-ID: Date: Wed, 21 Jul 2021 21:57:37 +1000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.0 MIME-Version: 1.0 In-Reply-To: <20c7be76-661b-6e75-3721-7b577fb4e05d@arm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Anshuman, On 7/21/21 3:57 PM, Anshuman Khandual wrote: > On 7/19/21 6:36 PM, Gavin Shan wrote: >> This uses struct pgtable_debug_args in the basic test functions. There >> are more cleanups applied: >> >> * Move hugetlb_basic_tests() so that the basic tests are treated >> as a bundle. > > Please dont move this test as it is placed near to the THP functions. > Also please don't club any non-related changes here while converting > various tests into this new arg structure. > Yes. I won't move hugetlb_basic_tests() around in v4. >> >> * Drop parameters to {pgd, p4d}_basic_tests() as they're never >> used. > > Right, they are not getting used right now. But then it might be just > better to replace them with this new structure in order not to do any > unrelated changes. > Sure. I will pass &args to these two functions in v4, even they are not used. Hopefully, I understand your comments correctly. >> >> * Drop unused variables @{pgd, p4d}_aligned in debug_vm_pgtable(). >> >> Signed-off-by: Gavin Shan >> --- >> mm/debug_vm_pgtable.c | 51 ++++++++++++++++++++----------------------- >> 1 file changed, 24 insertions(+), 27 deletions(-) >> >> diff --git a/mm/debug_vm_pgtable.c b/mm/debug_vm_pgtable.c >> index ea153ff40d23..5f79d725f8d8 100644 >> --- a/mm/debug_vm_pgtable.c >> +++ b/mm/debug_vm_pgtable.c >> @@ -88,10 +88,10 @@ struct pgtable_debug_args { >> unsigned long fixed_pte_pfn; >> }; >> >> -static void __init pte_basic_tests(unsigned long pfn, int idx) >> +static void __init pte_basic_tests(struct pgtable_debug_args *args, int idx) >> { >> pgprot_t prot = protection_map[idx]; >> - pte_t pte = pfn_pte(pfn, prot); >> + pte_t pte = pfn_pte(args->fixed_pte_pfn, prot); >> unsigned long val = idx, *ptr = &val; >> >> pr_debug("Validating PTE basic (%pGv)\n", ptr); >> @@ -173,7 +173,7 @@ static void __init pte_savedwrite_tests(unsigned long pfn, pgprot_t prot) >> } >> >> #ifdef CONFIG_TRANSPARENT_HUGEPAGE >> -static void __init pmd_basic_tests(unsigned long pfn, int idx) >> +static void __init pmd_basic_tests(struct pgtable_debug_args *args, int idx) >> { >> pgprot_t prot = protection_map[idx]; >> unsigned long val = idx, *ptr = &val; >> @@ -183,7 +183,7 @@ static void __init pmd_basic_tests(unsigned long pfn, int idx) >> return; >> >> pr_debug("Validating PMD basic (%pGv)\n", ptr); >> - pmd = pfn_pmd(pfn, prot); >> + pmd = pfn_pmd(args->fixed_pmd_pfn, prot); >> >> /* >> * This test needs to be executed after the given page table entry >> @@ -295,7 +295,7 @@ static void __init pmd_savedwrite_tests(unsigned long pfn, pgprot_t prot) >> } >> >> #ifdef CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD >> -static void __init pud_basic_tests(struct mm_struct *mm, unsigned long pfn, int idx) >> +static void __init pud_basic_tests(struct pgtable_debug_args *args, int idx) >> { >> pgprot_t prot = protection_map[idx]; >> unsigned long val = idx, *ptr = &val; >> @@ -305,7 +305,7 @@ static void __init pud_basic_tests(struct mm_struct *mm, unsigned long pfn, int >> return; >> >> pr_debug("Validating PUD basic (%pGv)\n", ptr); >> - pud = pfn_pud(pfn, prot); >> + pud = pfn_pud(args->fixed_pud_pfn, prot); >> >> /* >> * This test needs to be executed after the given page table entry >> @@ -326,7 +326,7 @@ static void __init pud_basic_tests(struct mm_struct *mm, unsigned long pfn, int >> WARN_ON(pud_dirty(pud_wrprotect(pud_mkclean(pud)))); >> WARN_ON(!pud_dirty(pud_wrprotect(pud_mkdirty(pud)))); >> >> - if (mm_pmd_folded(mm)) >> + if (mm_pmd_folded(args->mm)) >> return; >> >> /* >> @@ -403,7 +403,7 @@ static void __init pud_leaf_tests(unsigned long pfn, pgprot_t prot) >> WARN_ON(!pud_leaf(pud)); >> } >> #else /* !CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD */ >> -static void __init pud_basic_tests(struct mm_struct *mm, unsigned long pfn, int idx) { } >> +static void __init pud_basic_tests(struct pgtable_debug_args *args, int idx) { } >> static void __init pud_advanced_tests(struct mm_struct *mm, >> struct vm_area_struct *vma, pud_t *pudp, >> unsigned long pfn, unsigned long vaddr, >> @@ -413,8 +413,8 @@ static void __init pud_advanced_tests(struct mm_struct *mm, >> static void __init pud_leaf_tests(unsigned long pfn, pgprot_t prot) { } >> #endif /* CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD */ >> #else /* !CONFIG_TRANSPARENT_HUGEPAGE */ >> -static void __init pmd_basic_tests(unsigned long pfn, int idx) { } >> -static void __init pud_basic_tests(struct mm_struct *mm, unsigned long pfn, int idx) { } >> +static void __init pmd_basic_tests(struct pgtable_debug_args *args, int idx) { } >> +static void __init pud_basic_tests(struct pgtable_debug_args *args, int idx) { } >> static void __init pmd_advanced_tests(struct mm_struct *mm, >> struct vm_area_struct *vma, pmd_t *pmdp, >> unsigned long pfn, unsigned long vaddr, >> @@ -475,7 +475,7 @@ static void __init pmd_huge_tests(pmd_t *pmdp, unsigned long pfn, pgprot_t prot) >> static void __init pud_huge_tests(pud_t *pudp, unsigned long pfn, pgprot_t prot) { } >> #endif /* CONFIG_HAVE_ARCH_HUGE_VMAP */ >> >> -static void __init p4d_basic_tests(unsigned long pfn, pgprot_t prot) >> +static void __init p4d_basic_tests(void) >> { >> p4d_t p4d; >> >> @@ -484,7 +484,7 @@ static void __init p4d_basic_tests(unsigned long pfn, pgprot_t prot) >> WARN_ON(!p4d_same(p4d, p4d)); >> } >> >> -static void __init pgd_basic_tests(unsigned long pfn, pgprot_t prot) >> +static void __init pgd_basic_tests(void) >> { >> pgd_t pgd; >> >> @@ -889,7 +889,7 @@ static void __init swap_migration_tests(void) >> } >> >> #ifdef CONFIG_HUGETLB_PAGE >> -static void __init hugetlb_basic_tests(unsigned long pfn, pgprot_t prot) >> +static void __init hugetlb_basic_tests(struct pgtable_debug_args *args) >> { >> struct page *page; >> pte_t pte; >> @@ -899,21 +899,21 @@ static void __init hugetlb_basic_tests(unsigned long pfn, pgprot_t prot) >> * Accessing the page associated with the pfn is safe here, >> * as it was previously derived from a real kernel symbol. >> */ >> - page = pfn_to_page(pfn); >> - pte = mk_huge_pte(page, prot); >> + page = pfn_to_page(args->fixed_pmd_pfn); >> + pte = mk_huge_pte(page, args->page_prot); >> >> WARN_ON(!huge_pte_dirty(huge_pte_mkdirty(pte))); >> WARN_ON(!huge_pte_write(huge_pte_mkwrite(huge_pte_wrprotect(pte)))); >> WARN_ON(huge_pte_write(huge_pte_wrprotect(huge_pte_mkwrite(pte)))); >> >> #ifdef CONFIG_ARCH_WANT_GENERAL_HUGETLB >> - pte = pfn_pte(pfn, prot); >> + pte = pfn_pte(args->fixed_pmd_pfn, args->page_prot); >> >> WARN_ON(!pte_huge(pte_mkhuge(pte))); >> #endif /* CONFIG_ARCH_WANT_GENERAL_HUGETLB */ >> } >> #else /* !CONFIG_HUGETLB_PAGE */ >> -static void __init hugetlb_basic_tests(unsigned long pfn, pgprot_t prot) { } >> +static void __init hugetlb_basic_tests(struct pgtable_debug_args *args) { } >> #endif /* CONFIG_HUGETLB_PAGE */ >> >> #ifdef CONFIG_TRANSPARENT_HUGEPAGE >> @@ -1157,7 +1157,7 @@ static int __init debug_vm_pgtable(void) >> pgprot_t prot, protnone; >> phys_addr_t paddr; >> unsigned long vaddr, pte_aligned, pmd_aligned; >> - unsigned long pud_aligned, p4d_aligned, pgd_aligned; >> + unsigned long pud_aligned; >> spinlock_t *ptl = NULL; >> int idx, ret; >> >> @@ -1200,8 +1200,6 @@ static int __init debug_vm_pgtable(void) >> pte_aligned = (paddr & PAGE_MASK) >> PAGE_SHIFT; >> pmd_aligned = (paddr & PMD_MASK) >> PAGE_SHIFT; >> pud_aligned = (paddr & PUD_MASK) >> PAGE_SHIFT; >> - p4d_aligned = (paddr & P4D_MASK) >> PAGE_SHIFT; >> - pgd_aligned = (paddr & PGDIR_MASK) >> PAGE_SHIFT; >> WARN_ON(!pfn_valid(pte_aligned)); >> >> pgdp = pgd_offset(mm, vaddr); >> @@ -1235,9 +1233,9 @@ static int __init debug_vm_pgtable(void) >> * given page table entry. >> */ >> for (idx = 0; idx < ARRAY_SIZE(protection_map); idx++) { >> - pte_basic_tests(pte_aligned, idx); >> - pmd_basic_tests(pmd_aligned, idx); >> - pud_basic_tests(mm, pud_aligned, idx); >> + pte_basic_tests(&args, idx); >> + pmd_basic_tests(&args, idx); >> + pud_basic_tests(&args, idx); >> } >> >> /* >> @@ -1247,8 +1245,9 @@ static int __init debug_vm_pgtable(void) >> * the above iteration for now to save some test execution >> * time. >> */ >> - p4d_basic_tests(p4d_aligned, prot); >> - pgd_basic_tests(pgd_aligned, prot); >> + p4d_basic_tests(); >> + pgd_basic_tests(); >> + hugetlb_basic_tests(&args); >> >> pmd_leaf_tests(pmd_aligned, prot); >> pud_leaf_tests(pud_aligned, prot); >> @@ -1277,8 +1276,6 @@ static int __init debug_vm_pgtable(void) >> pmd_thp_tests(pmd_aligned, prot); >> pud_thp_tests(pud_aligned, prot); >> >> - hugetlb_basic_tests(pte_aligned, prot); >> - >> /* >> * Page table modifying tests. They need to hold >> * proper page table lock. >> Thanks, Gavin