Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp303907pxv; Wed, 21 Jul 2021 23:55:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzfqy4N36Sz9bokuQpEwLlY3vjVLgF3PYOKyOk8Uj0P0NKMD01GdKs6M8M8sOeqqDMYHY2d X-Received: by 2002:a6b:d108:: with SMTP id l8mr29194578iob.65.1626936901867; Wed, 21 Jul 2021 23:55:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626936901; cv=none; d=google.com; s=arc-20160816; b=re+SzTeR+mhC0lvWXtIkdldYuVAjmpmXqgvuJsgzpw9Lt/TBpcty0KOnSzCmZPp+0V FZalVh8sxHGAzJ3l7rJo78zuR8Efoe5P8vPTx7jYOo0IkrZ0Ul2ob6IIf5TKLRY5iiBb apnimzUk2n6bHqUlRKksLuYP0ypn8w3UkBuBVRUODmgVFwncGhcljRgXvm2O1y3vpSXw fcy+0WX8HYB/jePsBvZOzQhpEHlYKTj5SGXCchTNshy2lc2gbyjR82RvoPhr6pDDYpgM H+IAqchh/PJmRWcoJBdqfrUxfi41/IhJGemRMxz52CgnL2mdkcGU97UgCxvvcHaQcao/ Hgrw== 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=Ax6HkWFA5BWwvTOf3UZ5KXstCPRBEySKl51WxciY7is=; b=XMW4/53WK037e2y0+Hw3pZPtkXVE8QXdLPuGEL4k+OCjQqZmWcHocIAAlembjIH072 t3xnR8bmCQi1NoNdjeoP39NBb/Az4jfcv5otfpcihl9XiUsfXv5flTSoigAno/MFs6KW iBV6ZGA8DXN1hc53M30S+9KXlWFMk35H5JZPkJicpcyUUxStSC09/1/19zywxhqrpN2a uFYOq8esqNAvuJvuSeYNh5hRbmOc+Kb/z3uxzN7mjrlDUcHYD+gdFxQJ1fxZ0kOji7DB 5v/b4FaAdOEQGt873vIsU7JqwqSW9jxzi3BH0Oo4YN/UIJmNWcUbeDYV6uRJ61Fh7lOL nmwQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=OqQsximr; 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 t2si27406142ilp.31.2021.07.21.23.54.49; Wed, 21 Jul 2021 23:55:01 -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=OqQsximr; 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 S230438AbhGVGMY (ORCPT + 99 others); Thu, 22 Jul 2021 02:12:24 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:47054 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229573AbhGVGMX (ORCPT ); Thu, 22 Jul 2021 02:12:23 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1626936778; 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=Ax6HkWFA5BWwvTOf3UZ5KXstCPRBEySKl51WxciY7is=; b=OqQsximrS50BtujpRP2/TKuFobIirerI+6M32RiPIxbYTCctt+lKwzYmUMKyjP16KWSPtw jiO26FClh2JumjfhTPbeA4bOS1jyfIkNOtuv+06K52Wb7f2TnlNIrRbVQkMbq4mP4KZaJW w8vq5kl53N/N63D0EtQbdhwRoBWaNSE= 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-175-CqHssU_jO-S41fHuZ9o9tg-1; Thu, 22 Jul 2021 02:52:57 -0400 X-MC-Unique: CqHssU_jO-S41fHuZ9o9tg-1 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 714DC10086DA; Thu, 22 Jul 2021 06:52:55 +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 1DBDA752BB; Thu, 22 Jul 2021 06:52:52 +0000 (UTC) Reply-To: Gavin Shan Subject: Re: [PATCH v3 11/12] mm/debug_vm_pgtable: Remove unused code 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-12-gshan@redhat.com> From: Gavin Shan Message-ID: <54bd0724-90c3-564b-fa3a-2e6c86ec609b@redhat.com> Date: Thu, 22 Jul 2021 16:53:10 +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: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Anshuman, On 7/22/21 2:51 PM, Anshuman Khandual wrote: > Small nit for the subject line. > > s/Remove unused code/Remove unused page table debug elements/ > Ok. Will apply the replacement in v4, thanks! > On 7/19/21 6:36 PM, Gavin Shan wrote: >> The variables used by old implementation isn't needed as we switched >> to "struct pgtable_debug_args". Lets remove them and related code in >> debug_vm_pgtable(). >> >> Signed-off-by: Gavin Shan >> --- >> mm/debug_vm_pgtable.c | 54 ------------------------------------------- >> 1 file changed, 54 deletions(-) >> >> diff --git a/mm/debug_vm_pgtable.c b/mm/debug_vm_pgtable.c >> index 5ebacc940b68..4f7bf1c9724a 100644 >> --- a/mm/debug_vm_pgtable.c >> +++ b/mm/debug_vm_pgtable.c >> @@ -1124,14 +1124,6 @@ static int __init init_args(struct pgtable_debug_args *args) >> static int __init debug_vm_pgtable(void) >> { >> struct pgtable_debug_args args; >> - struct vm_area_struct *vma; >> - struct mm_struct *mm; >> - pgd_t *pgdp; >> - p4d_t *p4dp; >> - pud_t *pudp; >> - pmd_t *pmdp, *saved_pmdp, pmd; >> - pgtable_t saved_ptep; >> - unsigned long vaddr; >> spinlock_t *ptl = NULL; >> int idx, ret; >> >> @@ -1140,41 +1132,6 @@ static int __init debug_vm_pgtable(void) >> if (ret) >> return ret; >> >> - vaddr = get_random_vaddr(); >> - mm = mm_alloc(); >> - if (!mm) { >> - pr_err("mm_struct allocation failed\n"); >> - return 1; >> - } >> - >> - vma = vm_area_alloc(mm); >> - if (!vma) { >> - pr_err("vma allocation failed\n"); >> - return 1; >> - } >> - >> - pgdp = pgd_offset(mm, vaddr); >> - p4dp = p4d_alloc(mm, pgdp, vaddr); >> - pudp = pud_alloc(mm, p4dp, vaddr); >> - pmdp = pmd_alloc(mm, pudp, vaddr); >> - /* >> - * Allocate pgtable_t >> - */ >> - if (pte_alloc(mm, pmdp)) { >> - pr_err("pgtable allocation failed\n"); >> - return 1; >> - } >> - >> - /* >> - * Save all the page table page addresses as the page table >> - * entries will be used for testing with random or garbage >> - * values. These saved addresses will be used for freeing >> - * page table pages. >> - */ > > Please move this comment as is to the right place inside init_args() > in the first patch itself. If possible all comments should be moved > during the first patch and just the code gets dropped here. > In PATCH[v3 01/12], We already had the comments in init_args() as below: /* * The above page table entries will be modified. Lets save the * page table entries so that they can be released when the tests * are completed. */ >> - pmd = READ_ONCE(*pmdp); >> - saved_pmdp = pmd_offset(pudp, 0UL); >> - saved_ptep = pmd_pgtable(pmd); >> - >> /* >> * Iterate over the protection_map[] to make sure that all >> * the basic page table transformation validations just hold >> @@ -1256,17 +1213,6 @@ static int __init debug_vm_pgtable(void) >> pgd_populate_tests(&args); >> spin_unlock(&(args.mm->page_table_lock)); >> >> - p4d_free(mm, p4d_offset(pgdp, 0UL)); >> - pud_free(mm, pud_offset(p4dp, 0UL)); >> - pmd_free(mm, saved_pmdp); >> - pte_free(mm, saved_ptep); >> - >> - vm_area_free(vma); >> - mm_dec_nr_puds(mm); >> - mm_dec_nr_pmds(mm); >> - mm_dec_nr_ptes(mm); >> - mmdrop(mm); >> - >> destroy_args(&args); >> return 0; >> } >> Thanks, Gavin