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=-13.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham 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 1BF95C2D0E4 for ; Tue, 24 Nov 2020 11:08:37 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 7F53B2083E for ; Tue, 24 Nov 2020 11:08:36 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=bytedance-com.20150623.gappssmtp.com header.i=@bytedance-com.20150623.gappssmtp.com header.b="KRxaSswN" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 7F53B2083E Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=bytedance.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id C648C6B00B3; Tue, 24 Nov 2020 06:08:35 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id C14676B00B4; Tue, 24 Nov 2020 06:08:35 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id B028B6B00B5; Tue, 24 Nov 2020 06:08:35 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0222.hostedemail.com [216.40.44.222]) by kanga.kvack.org (Postfix) with ESMTP id 96A636B00B3 for ; Tue, 24 Nov 2020 06:08:35 -0500 (EST) Received: from smtpin30.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id 56BF43632 for ; Tue, 24 Nov 2020 11:08:35 +0000 (UTC) X-FDA: 77519038590.30.laugh40_2f1003b2736d Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin30.hostedemail.com (Postfix) with ESMTP id 37E31180B3C83 for ; Tue, 24 Nov 2020 11:08:35 +0000 (UTC) X-HE-Tag: laugh40_2f1003b2736d X-Filterd-Recvd-Size: 9443 Received: from mail-pg1-f196.google.com (mail-pg1-f196.google.com [209.85.215.196]) by imf49.hostedemail.com (Postfix) with ESMTP for ; Tue, 24 Nov 2020 11:08:34 +0000 (UTC) Received: by mail-pg1-f196.google.com with SMTP id 81so17168546pgf.0 for ; Tue, 24 Nov 2020 03:08:34 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=kj0WDd7GW3ZafwLkwvjtKCJlLdXVHYFvSyIRNFPhhJs=; b=KRxaSswNMnKDHkOWQ7Yc2KKjW2HjaY2VS0HOZmr6HNo+sMe//hXQfRkdpcncexV+GB JNUIxmzzFkT6MTPkf4NqWlctVnyRv7+Wsj3ahOikwnyEBCjv2+jtNf6X5nLSRVdZ+hHt ndhQCPoIPTrbnq+kmZk8kYoqKILIn1jIWn6ZnsDksipGyj27T1XAg3MTx2Lh95/UhNxj R4HwdbqimHJKyGsbNpzDBXDd7fkC0bNlekbpPDrdb+NMRnbRT2uzlqoDbVxbAEsUW4un xMXoSO9WPO3KLYzfQGQw9kR0BXMZ3qqKrLr3dUUfRvpGC+1GTVqPfyuxBvvgWtQmGPIr 1gQA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=kj0WDd7GW3ZafwLkwvjtKCJlLdXVHYFvSyIRNFPhhJs=; b=Oj469NYllqoB0MRoRHJ0yqgbKvT5lT8dBZywIi5wVlLI4c0omSW8tq/leUCQhFaCf3 rA1jvslKYQGT2xTkkIBn3Xrn4jKrhV4JK/JcFnNgSx9hCWErhD7oUadgmxGpvV6lP+a6 kf4N3ngiCWNQ4HWMC6iP0bTkYfYY7FuR8X0iOdlAhvodud8UGERDdEF+K9q0odIKEnFS BZTOTCaTxZGoeVJv4pwcfz1Cl0IODjEINw5GmQjH3I+Bifa9Vs9u4pEwIEinsTfnggp9 c2ofPSaXjPHnAMCTgGQFd/iNOGUGCqVXVTsdikpmNUGSoIpwHfPr5iPAXm5n0kX2RAFc DyNA== X-Gm-Message-State: AOAM532C30VlFrMWJuaZL9giTzVzChMCSDarfIMgxZez+CVo5zGCAE1h n/Pp2cowg0VoZs7GcIi5WIDG852N1ZjJ1v3+g2Ak0A== X-Google-Smtp-Source: ABdhPJwAnnOF1DfZ6tU3qBpyxbXObsyrOi0H0yApKcnJAOa41sGtBxbjPtLnlPuc9h4FZRo23mRNTy2PVNoHj1uSHWE= X-Received: by 2002:a62:16c1:0:b029:18c:8a64:fc04 with SMTP id 184-20020a6216c10000b029018c8a64fc04mr3535171pfw.59.1606216113637; Tue, 24 Nov 2020 03:08:33 -0800 (PST) MIME-Version: 1.0 References: <20201124095259.58755-1-songmuchun@bytedance.com> <20201124095259.58755-15-songmuchun@bytedance.com> <5f6443f10292405d813ffb444ef315fc@hisilicon.com> In-Reply-To: <5f6443f10292405d813ffb444ef315fc@hisilicon.com> From: Muchun Song Date: Tue, 24 Nov 2020 19:07:56 +0800 Message-ID: Subject: Re: [External] RE: [PATCH v6 14/16] mm/hugetlb: Add a kernel parameter hugetlb_free_vmemmap To: "Song Bao Hua (Barry Song)" Cc: "corbet@lwn.net" , "mike.kravetz@oracle.com" , "tglx@linutronix.de" , "mingo@redhat.com" , "bp@alien8.de" , "x86@kernel.org" , "hpa@zytor.com" , "dave.hansen@linux.intel.com" , "luto@kernel.org" , "peterz@infradead.org" , "viro@zeniv.linux.org.uk" , "akpm@linux-foundation.org" , "paulmck@kernel.org" , "mchehab+huawei@kernel.org" , "pawan.kumar.gupta@linux.intel.com" , "rdunlap@infradead.org" , "oneukum@suse.com" , "anshuman.khandual@arm.com" , "jroedel@suse.de" , "almasrymina@google.com" , "rientjes@google.com" , "willy@infradead.org" , "osalvador@suse.de" , "mhocko@suse.com" , "duanxiongchun@bytedance.com" , "linux-doc@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "linux-mm@kvack.org" , "linux-fsdevel@vger.kernel.org" Content-Type: text/plain; charset="UTF-8" X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Tue, Nov 24, 2020 at 6:54 PM Song Bao Hua (Barry Song) wrote: > > > > > -----Original Message----- > > From: Muchun Song [mailto:songmuchun@bytedance.com] > > Sent: Tuesday, November 24, 2020 10:53 PM > > To: corbet@lwn.net; mike.kravetz@oracle.com; tglx@linutronix.de; > > mingo@redhat.com; bp@alien8.de; x86@kernel.org; hpa@zytor.com; > > dave.hansen@linux.intel.com; luto@kernel.org; peterz@infradead.org; > > viro@zeniv.linux.org.uk; akpm@linux-foundation.org; paulmck@kernel.org; > > mchehab+huawei@kernel.org; pawan.kumar.gupta@linux.intel.com; > > rdunlap@infradead.org; oneukum@suse.com; anshuman.khandual@arm.com; > > jroedel@suse.de; almasrymina@google.com; rientjes@google.com; > > willy@infradead.org; osalvador@suse.de; mhocko@suse.com; Song Bao Hua > > (Barry Song) > > Cc: duanxiongchun@bytedance.com; linux-doc@vger.kernel.org; > > linux-kernel@vger.kernel.org; linux-mm@kvack.org; > > linux-fsdevel@vger.kernel.org; Muchun Song > > Subject: [PATCH v6 14/16] mm/hugetlb: Add a kernel parameter > > hugetlb_free_vmemmap > > > > Add a kernel parameter hugetlb_free_vmemmap to disable the feature of > > freeing unused vmemmap pages associated with each hugetlb page on boot. > > > > Signed-off-by: Muchun Song > > --- > > Documentation/admin-guide/kernel-parameters.txt | 9 +++++++++ > > Documentation/admin-guide/mm/hugetlbpage.rst | 3 +++ > > mm/hugetlb_vmemmap.c | 19 > > ++++++++++++++++++- > > 3 files changed, 30 insertions(+), 1 deletion(-) > > > > diff --git a/Documentation/admin-guide/kernel-parameters.txt > > b/Documentation/admin-guide/kernel-parameters.txt > > index 5debfe238027..d28c3acde965 100644 > > --- a/Documentation/admin-guide/kernel-parameters.txt > > +++ b/Documentation/admin-guide/kernel-parameters.txt > > @@ -1551,6 +1551,15 @@ > > Documentation/admin-guide/mm/hugetlbpage.rst. > > Format: size[KMG] > > > > + hugetlb_free_vmemmap= > > + [KNL] When CONFIG_HUGETLB_PAGE_FREE_VMEMMAP is set, > > + this controls freeing unused vmemmap pages associated > > + with each HugeTLB page. > > + Format: { on | off (default) } > > + > > + on: enable the feature > > + off: disable the feature > > + > > We've a parameter here. but wouldn't it be applied to "x86/mm/64/:disable > Pmd page mapping of vmemmap" as well? > If (hugetlb_free_vmemmap_enabled) > Do Basepage mapping? Oh, yeah, we can. Thanks. > > > hung_task_panic= > > [KNL] Should the hung task detector generate panics. > > Format: 0 | 1 > > diff --git a/Documentation/admin-guide/mm/hugetlbpage.rst > > b/Documentation/admin-guide/mm/hugetlbpage.rst > > index f7b1c7462991..6a8b57f6d3b7 100644 > > --- a/Documentation/admin-guide/mm/hugetlbpage.rst > > +++ b/Documentation/admin-guide/mm/hugetlbpage.rst > > @@ -145,6 +145,9 @@ default_hugepagesz > > > > will all result in 256 2M huge pages being allocated. Valid default > > huge page size is architecture dependent. > > +hugetlb_free_vmemmap > > + When CONFIG_HUGETLB_PAGE_FREE_VMEMMAP is set, this enables > > freeing > > + unused vmemmap pages associated each HugeTLB page. > > > > When multiple huge page sizes are supported, ``/proc/sys/vm/nr_hugepages`` > > indicates the current number of pre-allocated huge pages of the default size. > > diff --git a/mm/hugetlb_vmemmap.c b/mm/hugetlb_vmemmap.c > > index 509ca451e232..b2222f8d1245 100644 > > --- a/mm/hugetlb_vmemmap.c > > +++ b/mm/hugetlb_vmemmap.c > > @@ -131,6 +131,22 @@ typedef void (*vmemmap_pte_remap_func_t)(struct > > page *reuse, pte_t *ptep, > > unsigned long start, unsigned long end, > > void *priv); > > > > +static bool hugetlb_free_vmemmap_enabled __initdata; > > + > > +static int __init early_hugetlb_free_vmemmap_param(char *buf) > > +{ > > + if (!buf) > > + return -EINVAL; > > + > > + if (!strcmp(buf, "on")) > > + hugetlb_free_vmemmap_enabled = true; > > + else if (strcmp(buf, "off")) > > + return -EINVAL; > > + > > + return 0; > > +} > > +early_param("hugetlb_free_vmemmap", > > early_hugetlb_free_vmemmap_param); > > + > > static inline unsigned int vmemmap_pages_per_hpage(struct hstate *h) > > { > > return free_vmemmap_pages_per_hpage(h) + RESERVE_VMEMMAP_NR; > > @@ -322,7 +338,8 @@ void __init hugetlb_vmemmap_init(struct hstate *h) > > unsigned int order = huge_page_order(h); > > unsigned int vmemmap_pages; > > > > - if (!is_power_of_2(sizeof(struct page))) { > > + if (!is_power_of_2(sizeof(struct page)) || > > + !hugetlb_free_vmemmap_enabled) { > > pr_info("disable freeing vmemmap pages for %s\n", h->name); > > return; > > } > > -- > > 2.11.0 > > Thanks > Barry > -- Yours, Muchun