Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3081129ybt; Mon, 22 Jun 2020 14:35:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzEQ26tjkitWhgdhmigDS7+dYJchnZAAz41MLmjU14niZ7R0kxeSyEWF5F99OSIPxdKBhCB X-Received: by 2002:a17:906:7f95:: with SMTP id f21mr17065016ejr.554.1592861726108; Mon, 22 Jun 2020 14:35:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592861726; cv=none; d=google.com; s=arc-20160816; b=REF5/3+/nAmkcC97YERArEePpEom+MTVhEPXVDsTVpezYK2EX1dZDG0ZeVpuhlGiVC LFVdttybm3JnprmnFVksh0+f3HgC6qE04PHHsaMkB/NOkYId0hOa5mPijtTFW4BBbQhj FcvvPo3Ekd2PEEiQ39cOKmJEGZ7zpQ8prg4BeJ0UBSoUIFd2ppdVwz4OEo5XmHQxVwLp KG3/8rsCYdTRxZcMM6yrR8xORJ7+po/IVu54Pr5NnREszMpTrGsvUIUzMplkjUEtXzD7 9qriocggyQQTZGzSJU3uJmJe1XCZHU1IPrRxcDHyQINhfhkmG+ex7hRZYjEDlHPGfyce lx4Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=kKhAiBb2dmKarFPnUN3DCh6t35CXVfyB9l3jASZ5HS0=; b=X/b68UCy+0Dl02OFKq2CfpAtcz1rrfhMgbGQiADWe4HPp/Z7oEh9Y6j7/3Q7GxVhTT 1OOgdwCC9L3rigJJyGi3dWw79TvjiJ4I2aY3qt6qNybxNRMf8wXoiqKYyf4iIQUSM2d+ jxfllQoe+OTP7QS0uGBgBNMAY81Q9fIiIkoBpdecXauffuhrakdhU2Kxp9IuMaJ1w1sJ z7/UlQ4cUzspZTQQ/lwCQDCJ7ijoctHO9xDjoYVKDjB+aXXqYdy7T5C8KfZIIdsXk3v6 CRlxQQ3LhjSXtawVQ7aVNc3L22v/j7lBcjanTJsWJStmyX1GdrC7ZwlRwiWH4G6EQ2PD Tabg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=HVvsXz7y; 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=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g4si10221911edn.411.2020.06.22.14.35.03; Mon, 22 Jun 2020 14:35:26 -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=@nvidia.com header.s=n1 header.b=HVvsXz7y; 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=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730670AbgFVVdN (ORCPT + 99 others); Mon, 22 Jun 2020 17:33:13 -0400 Received: from hqnvemgate24.nvidia.com ([216.228.121.143]:9672 "EHLO hqnvemgate24.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727006AbgFVVdN (ORCPT ); Mon, 22 Jun 2020 17:33:13 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate24.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Mon, 22 Jun 2020 14:31:41 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Mon, 22 Jun 2020 14:33:12 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Mon, 22 Jun 2020 14:33:12 -0700 Received: from rcampbell-dev.nvidia.com (10.124.1.5) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Mon, 22 Jun 2020 21:33:06 +0000 Subject: Re: [PATCH 14/16] mm/thp: add THP allocation helper To: Zi Yan CC: , , , , , Jerome Glisse , "John Hubbard" , Christoph Hellwig , "Jason Gunthorpe" , Ben Skeggs , Andrew Morton , Shuah Khan References: <20200619215649.32297-1-rcampbell@nvidia.com> <20200619215649.32297-15-rcampbell@nvidia.com> <9948121A-CA52-494F-9B68-6C0089E15057@nvidia.com> From: Ralph Campbell X-Nvconfidentiality: public Message-ID: <21d571c4-8442-82df-4baf-e5d1c2ced99d@nvidia.com> Date: Mon, 22 Jun 2020 14:33:06 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2 MIME-Version: 1.0 In-Reply-To: <9948121A-CA52-494F-9B68-6C0089E15057@nvidia.com> X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL101.nvidia.com (172.20.187.10) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1592861501; bh=kKhAiBb2dmKarFPnUN3DCh6t35CXVfyB9l3jASZ5HS0=; h=X-PGP-Universal:Subject:To:CC:References:From:X-Nvconfidentiality: Message-ID:Date:User-Agent:MIME-Version:In-Reply-To: X-Originating-IP:X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=HVvsXz7yZCRk/1Gi4xfI78UyQRxmdOWyHhToZ7q8RRU/XpEchdduB5J1EdR3hAspm hDsQe33+5+b43imv23uHWzdOtu/wdiCleINuTsdiXDSmSJnsULEXoDAOCobWjGExzN eEYNrUPKYEbPolDSt41vTQAjr9TmQMvXHxQaUcKq9R2q8xQ+UhWJYoTQMe2vhOrlQV JegU98QBSfPri8F2t4Ac/QXcgu6CafkAPjclLPvNhHAXExBGCRihESc6Ph8qBSsPkG duBtcb0Bqwxweelf1+NLa4tv72S5t5/a4Bt8LgxdyA7dpOkyk8XmwrLxCJ2QwYJKWx 6+r0Eu3vPylAg== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 6/21/20 5:15 PM, Zi Yan wrote: > On 19 Jun 2020, at 17:56, Ralph Campbell wrote: >=20 >> Transparent huge page allocation policy is controlled by several sysfs >> variables. Rather than expose these to each device driver that needs to >> allocate THPs, provide a helper function. >> >> Signed-off-by: Ralph Campbell >> --- >> include/linux/gfp.h | 10 ++++++++++ >> mm/huge_memory.c | 16 ++++++++++++++++ >> 2 files changed, 26 insertions(+) >> >> diff --git a/include/linux/gfp.h b/include/linux/gfp.h >> index 67a0774e080b..1c7d968a27d3 100644 >> --- a/include/linux/gfp.h >> +++ b/include/linux/gfp.h >> @@ -562,6 +562,16 @@ extern struct page *alloc_pages_vma(gfp_t gfp_mask,= int order, >> alloc_pages_vma(gfp_mask, 0, vma, addr, numa_node_id(), false) >> #define alloc_page_vma_node(gfp_mask, vma, addr, node) \ >> alloc_pages_vma(gfp_mask, 0, vma, addr, node, false) >> +#ifdef CONFIG_ARCH_ENABLE_THP_MIGRATION >> +extern struct page *alloc_transhugepage(struct vm_area_struct *vma, >> + unsigned long addr); >> +#else >> +static inline struct page *alloc_transhugepage(struct vm_area_struct *v= ma, >> + unsigned long addr) >> +{ >> + return NULL; >> +} >> +#endif >> >> extern unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int ord= er); >> extern unsigned long get_zeroed_page(gfp_t gfp_mask); >> diff --git a/mm/huge_memory.c b/mm/huge_memory.c >> index 25d95f7b1e98..f749633ed350 100644 >> --- a/mm/huge_memory.c >> +++ b/mm/huge_memory.c >> @@ -775,6 +775,22 @@ vm_fault_t do_huge_pmd_anonymous_page(struct vm_fau= lt *vmf) >> return __do_huge_pmd_anonymous_page(vmf, page, gfp); >> } >> >> +#ifdef CONFIG_ARCH_ENABLE_THP_MIGRATION >> +struct page *alloc_transhugepage(struct vm_area_struct *vma, >> + unsigned long haddr) >> +{ >> + gfp_t gfp; >> + struct page *page; >> + >> + gfp =3D alloc_hugepage_direct_gfpmask(vma); >> + page =3D alloc_hugepage_vma(gfp, vma, haddr, HPAGE_PMD_ORDER); >> + if (page) >> + prep_transhuge_page(page); >> + return page; >> +} >> +EXPORT_SYMBOL_GPL(alloc_transhugepage); >> +#endif >> + >> static void insert_pfn_pmd(struct vm_area_struct *vma, unsigned long a= ddr, >> pmd_t *pmd, pfn_t pfn, pgprot_t prot, bool write, >> pgtable_t pgtable) >> --=20 >> 2.20.1 >=20 > Why use CONFIG_ARCH_ENABLE_THP_MIGRATION to guard THP allocator helper? > Shouldn=E2=80=99t CONFIG_TRANSPARENT_HUGEPAGE be used? Also the helper st= ill allocates > a THP even if transparent_hugepage_enabled(vma) is false, which is wrong,= right? >=20 >=20 > -- > Best Regards, > Yan Zi >=20 Oops, I'm not sure why I thought that was needed. The whole file is only co= mpiled if CONFIG_TRANSPARENT_HUGEPAGE is defined and the calls to alloc_hugepage_v= ma() and alloc_hugepage_direct_gfpmask() are unprotected just above this in do_huge_pmd_anonymous_page(). I'll fix that in v2. The helper is intended to be called by a device driver to allocate a THP wh= en migrating device private memory back to system memory. The THP should never= be migrated to device private memory in the first place if transparent_hugepage_enabled(vma) is false. I suppose I could add a if (WARN_ON_ONCE()) return NULL as a sanity check. The real checks are in migrate_vma_setup() and migrate_vma_pages().