Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2343027ybt; Sun, 21 Jun 2020 17:18:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwAHqFU+xlZ9TjlTicCggBxgt/swIAF7CPyD6j2q5Bra2KxRYGb+cYyByPBQD7LWPoQeFRX X-Received: by 2002:a17:906:f10a:: with SMTP id gv10mr13008368ejb.309.1592785121767; Sun, 21 Jun 2020 17:18:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592785121; cv=none; d=google.com; s=arc-20160816; b=XKQVE0bmdbW3h7p0tI2KmpAsXAHd2wucHtL3qoMzQgKtMpsJ/qr/qQ4D4VVR3P5o8Q hmkwySfzZVGQGk0ZntvJP6UVhRrrgz9rIcioSnLLe1mbPe6XpmsPbUEnKGTLWCLSH+Ow 38bAPLTKml2Ih8jFg0eN+wrkr5sYNRPZRdmNN1MYkTVByPvZdWQVQ2SkGG7UdjBjxyDk 1PEslNJbC3OgK7qFnoS0hyDAiLF/B9b7Tvzghivw7gbzWbzcKB9lN4WwtzYnHd8DM5tO Vff3xgSYwtkN7vHhOX4AYcPL8hvuOuQtK/8x0/1zHERagP3zyc1rrh1cGrWGu/48vOkD vxqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:mime-version:references :in-reply-to:message-id:date:subject:cc:to:from; bh=Lr8iQ6hREjxuIrrKajV9oQHe0CBRPThD6DDsvzRvG88=; b=dZoH+M0VCvZDRURMo/riPNc7Yl57aMWbw4ZpaEkIobgjIPiCmYA4C31dx+l4Yq+iPy 6fis5W5arNTtSgref2iwd0I3H9zr4c+KbOpjOzJ8n6DKLv39T8gVQ2OQugHrc7ZljWUm opWrQnThhCiv8W0JclEik2TdghwS0SJrqtFLF80QlO853wggw3yx03JT5mGndzqaT/dt aelm/gtEQuxCNwF46x7Jh5qaMCoKpKTB/UIDtLFeA3ZXuvUAn88HUFAKLY2F807UwEzp uEIppKido/ZF+Bm1I1kwNzZeayV6Eyg8AjjV1t1RfmN8gCxeIGtYLXhzI4uVqDdBMqWb P3Lg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=kcNK9B7k; 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 s21si7568525ejz.9.2020.06.21.17.18.17; Sun, 21 Jun 2020 17:18:41 -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=kcNK9B7k; 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 S1730960AbgFVAQ1 (ORCPT + 99 others); Sun, 21 Jun 2020 20:16:27 -0400 Received: from hqnvemgate25.nvidia.com ([216.228.121.64]:1216 "EHLO hqnvemgate25.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726515AbgFVAQ1 (ORCPT ); Sun, 21 Jun 2020 20:16:27 -0400 Received: from hqpgpgate102.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate25.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Sun, 21 Jun 2020 17:15:42 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate102.nvidia.com (PGP Universal service); Sun, 21 Jun 2020 17:16:26 -0700 X-PGP-Universal: processed; by hqpgpgate102.nvidia.com on Sun, 21 Jun 2020 17:16:26 -0700 Received: from [10.2.167.171] (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 00:16:18 +0000 From: Zi Yan To: Ralph Campbell CC: , , , , , Jerome Glisse , "John Hubbard" , Christoph Hellwig , "Jason Gunthorpe" , Ben Skeggs , Andrew Morton , Shuah Khan Subject: Re: [PATCH 14/16] mm/thp: add THP allocation helper Date: Sun, 21 Jun 2020 20:15:45 -0400 X-Mailer: MailMate (1.13.1r5690) Message-ID: <9948121A-CA52-494F-9B68-6C0089E15057@nvidia.com> In-Reply-To: <20200619215649.32297-15-rcampbell@nvidia.com> References: <20200619215649.32297-1-rcampbell@nvidia.com> <20200619215649.32297-15-rcampbell@nvidia.com> MIME-Version: 1.0 X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL105.nvidia.com (172.20.187.12) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: multipart/signed; boundary="=_MailMate_4C36EFB0-847C-4A5D-A41C-B10AE0145101_="; micalg=pgp-sha1; protocol="application/pgp-signature" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1592784942; bh=Lr8iQ6hREjxuIrrKajV9oQHe0CBRPThD6DDsvzRvG88=; h=X-PGP-Universal:From:To:CC:Subject:Date:X-Mailer:Message-ID: In-Reply-To:References:MIME-Version:X-Originating-IP: X-ClientProxiedBy:Content-Type; b=kcNK9B7kDcnIj5KTg2K7ZI3H/ITfv/fVhMe6LNHevMFvtR9mrnxySOqp8KItN6/zU uPApsdYyrDEwN9Sdw+J33HBTV6bTaWPReJ7agzPv3XDX1T3jara8+nBSWZCN3Xs7W2 w26R03Vzir/ckhxS6NkSV4lYEZkuiT4PraqoF+zbtY2f8cnFY7xck3U/xS2wTQsoEZ VGQ+i5dfa1qqKFIOZDjoZYuzcOi7z9Tk4SO2qk9YdVUMv5BKQgjNTYfecpvQMIL/kK jJPBH28+w+yCFuzHuNrpJZ/vXnn6QNbuqrckX3VMU2Nebqjmp4mgfMcMgRZJfotG4G rMSkddnkNVykw== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --=_MailMate_4C36EFB0-847C-4A5D-A41C-B10AE0145101_= Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On 19 Jun 2020, at 17:56, Ralph Campbell wrote: > 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 *= vma, > + 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_fa= ult *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) > -- = > 2.20.1 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? -- Best Regards, Yan Zi --=_MailMate_4C36EFB0-847C-4A5D-A41C-B10AE0145101_= Content-Description: OpenPGP digital signature Content-Disposition: attachment; filename="signature.asc" Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQJDBAEBAgAtFiEEh7yFAW3gwjwQ4C9anbJR82th+ooFAl7v+DEPHHppeUBudmlk aWEuY29tAAoJEJ2yUfNrYfqKQCQP/R4abSW0mnepE+hQxnoAry2FCsgoq4kfwbLS z61PThcPrmTTEvbT9kRmqtarVtKhK1u0NxFkzhBYEZA4jfrs9JOufIXWBdhEEI+L Lp0xXMwc4qEugDb2whgdiTWIWfwhDqzYExaaZMuWlpr2H9Uw+qEENzlBvTBnd2Xa 4cj2nAipD6ggJ4qz/h7pt+2JTNKhNBirkfXqYjoXeWZpj/N0AfUs8IziaHyOwqxZ 1p2KvBeqsOB5M67Mr6TVzOHh1EZEbN7VMRHbXEgw6mBt179v67IGmP129Xp/zzFh U0KDQiMGUh7rt8rScMpv9v9xbvTXA5Ztpe/ExGARRK9cmOWOr3UHK2fDLwl3WSTl IN7swIwEBTpKPSWpCEi0f4fiQOqOk9PuexRM6ZxI5W/GYPKR99Fn7cHEMjgESOw1 fKCXPMXx95DDabWoRdMmTPEKkReI8k/RWSJhBq5mIUH8kHNilWgbPhUH/l7pbgMB W636ZixfVK0q7F95lwwU+fEH5BTfMwwk/usVT0ugRoTsiAFOFEZ3GXi6W8mmp8fo 6oaOysR1M3K01IXl8RRlDrWqK3oPsv2MnNTH2adPCxKKXU8PSRgs9Zcc7d9EIIO1 I7bnvmSZ7pTWK0RaHfv/yIbcfqpyyUt9wJy9kc83VXknBsOjJs9QtOBchjzpBWq1 q2tbBUmt =CvYf -----END PGP SIGNATURE----- --=_MailMate_4C36EFB0-847C-4A5D-A41C-B10AE0145101_=--