Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2635179pxv; Sun, 11 Jul 2021 20:56:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwBAInJCD+i5McTRivyFaHhfOG7vUH+VrxgSACe+G2VTm4HS0tXu+7TUhaJOgYKcn1N/Ds0 X-Received: by 2002:a05:6402:14d4:: with SMTP id f20mr16396639edx.316.1626062217780; Sun, 11 Jul 2021 20:56:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626062217; cv=none; d=google.com; s=arc-20160816; b=vD9CEeuD7L4PpJFgcgvUdTbjacCfowRBKppi/ep1GJyrF6+JikQm2AXl297gJ99h6C zz9L1+x09IrXbshT2KMWlIYII7Qz06cUtc9308fSjEFLCYbXxYdpijSNdMMk738w8fBS /BmoAXFgxLJpseaOYN+pfpCT4L6DPGQsYwDx0TwyO+HhIO1wVCi40oh31agyo7huugYz dZDNSamLXfzLLEaJPni/Ugs2PdeXaZlGYFdS18Mc7M76e1FTn3LI2IK4kLTd8Z6EuDGa 6gz08qQk71KMWzPyb5u3U9Lvh+bOmNUpvzCeZ3SHGHJ7Dw8Ajvrqai4JUzzFjNrjAaOm IwhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=q9NmHAenqYTBxelcEw91o9UPmxVbgGrVj1KNyeBfTGA=; b=XMYH2cwLBQIaas1ZLC5g5z/K6kVKVKxVk4tNUfGjud1f4MF8CtM6o44RmO3A23ppG/ 9DHaaHCRHkBtDH7F+AKE7qtR3VUYJkztEbevtiIXdhPDIZnC1abzqHVNGJc5KU0Wua71 rGc9OTHkkRj7l7t8E+LRnCglmy+j3p9uAUhG2pfsuB+kkxziZtLidZTsqz9qe8wdqg8P daVzA8aQlWt2aa4330ct6qeWfOt9a7v7XDACTBIPETpKLCqQy7PpUBi6iqBvHcfDENF1 C+QErxBprnDp1/JAcIedE0anR6eJ5h0Ie7KaLsn2bVx8UmRgR1SpwKvgR3p6gqmexjss gkww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=BrZg6ig7; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z11si1868204edb.95.2021.07.11.20.56.35; Sun, 11 Jul 2021 20:56:57 -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=@infradead.org header.s=casper.20170209 header.b=BrZg6ig7; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232908AbhGLD4Q (ORCPT + 99 others); Sun, 11 Jul 2021 23:56:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233371AbhGLD4H (ORCPT ); Sun, 11 Jul 2021 23:56:07 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4D482C0613E8; Sun, 11 Jul 2021 20:52:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=Content-Transfer-Encoding:MIME-Version: References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender:Reply-To: Content-Type:Content-ID:Content-Description; bh=q9NmHAenqYTBxelcEw91o9UPmxVbgGrVj1KNyeBfTGA=; b=BrZg6ig71iKbtskl8zxErKUcjC 7iVxulyqf9SEqygQjUOKilyRvQHEz/yHj4Q0E5nRvHHkxMg5nSDBsRWL2uV9Ye4lhvc0MtgkMyqeK kO2TZ5ICYaFs6W2RJnYrpvuXulOQthy0IMxnYxInRj5NUqodCaaHkTDoK+pYDuV+XHEmUPkPAXYP9 MjABPTxT73ZnEeym8HFURCWMhLVivDp/G3La/0hr9hEbAk6v5o9b+6RjmSH3haqRzM5tv74CeB3mT QckyTpc9Bns1gvIF+Zspoh6cQizUldFqR/mQU4TvUCtSv/oW3g9KZ0fb80emmhL6sLwQYYLdWBdJz Pd8HolCw==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1m2myk-00GptO-Pv; Mon, 12 Jul 2021 03:51:45 +0000 From: "Matthew Wilcox (Oracle)" To: linux-kernel@vger.kernel.org Cc: "Matthew Wilcox (Oracle)" , linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, Christoph Hellwig Subject: [PATCH v13 083/137] mm/page_alloc: Add folio allocation functions Date: Mon, 12 Jul 2021 04:06:07 +0100 Message-Id: <20210712030701.4000097-84-willy@infradead.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210712030701.4000097-1-willy@infradead.org> References: <20210712030701.4000097-1-willy@infradead.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The __alloc_folio(), __alloc_folio_node() and alloc_folio() functions are mostly for type safety, but they also ensure that the page allocator allocates a compound page and initialises the deferred list if the page is large enough to have one. Signed-off-by: Matthew Wilcox (Oracle) Reviewed-by: Christoph Hellwig --- include/linux/gfp.h | 16 ++++++++++++++++ mm/mempolicy.c | 10 ++++++++++ mm/page_alloc.c | 12 ++++++++++++ 3 files changed, 38 insertions(+) diff --git a/include/linux/gfp.h b/include/linux/gfp.h index dc5ff40608ce..48b293f097f6 100644 --- a/include/linux/gfp.h +++ b/include/linux/gfp.h @@ -523,6 +523,8 @@ static inline void arch_alloc_page(struct page *page, int order) { } struct page *__alloc_pages(gfp_t gfp, unsigned int order, int preferred_nid, nodemask_t *nodemask); +struct folio *__alloc_folio(gfp_t gfp, unsigned int order, int preferred_nid, + nodemask_t *nodemask); unsigned long __alloc_pages_bulk(gfp_t gfp, int preferred_nid, nodemask_t *nodemask, int nr_pages, @@ -564,6 +566,15 @@ __alloc_pages_node(int nid, gfp_t gfp_mask, unsigned int order) return __alloc_pages(gfp_mask, order, nid, NULL); } +static inline +struct folio *__alloc_folio_node(gfp_t gfp, unsigned int order, int nid) +{ + VM_BUG_ON(nid < 0 || nid >= MAX_NUMNODES); + VM_WARN_ON((gfp & __GFP_THISNODE) && !node_online(nid)); + + return __alloc_folio(gfp, order, nid, NULL); +} + /* * Allocate pages, preferring the node given as nid. When nid == NUMA_NO_NODE, * prefer the current CPU's closest node. Otherwise node must be valid and @@ -580,6 +591,7 @@ static inline struct page *alloc_pages_node(int nid, gfp_t gfp_mask, #ifdef CONFIG_NUMA struct page *alloc_pages(gfp_t gfp, unsigned int order); +struct folio *alloc_folio(gfp_t gfp, unsigned order); extern struct page *alloc_pages_vma(gfp_t gfp_mask, int order, struct vm_area_struct *vma, unsigned long addr, int node, bool hugepage); @@ -590,6 +602,10 @@ static inline struct page *alloc_pages(gfp_t gfp_mask, unsigned int order) { return alloc_pages_node(numa_node_id(), gfp_mask, order); } +static inline struct folio *alloc_folio(gfp_t gfp, unsigned int order) +{ + return __alloc_folio_node(gfp, order, numa_node_id()); +} #define alloc_pages_vma(gfp_mask, order, vma, addr, node, false)\ alloc_pages(gfp_mask, order) #define alloc_hugepage_vma(gfp_mask, vma, addr, order) \ diff --git a/mm/mempolicy.c b/mm/mempolicy.c index e32360e90274..eb0ca234a4f8 100644 --- a/mm/mempolicy.c +++ b/mm/mempolicy.c @@ -2249,6 +2249,16 @@ struct page *alloc_pages(gfp_t gfp, unsigned order) } EXPORT_SYMBOL(alloc_pages); +struct folio *alloc_folio(gfp_t gfp, unsigned order) +{ + struct page *page = alloc_pages(gfp | __GFP_COMP, order); + + if (page && order > 1) + prep_transhuge_page(page); + return (struct folio *)page; +} +EXPORT_SYMBOL(alloc_folio); + int vma_dup_policy(struct vm_area_struct *src, struct vm_area_struct *dst) { struct mempolicy *pol = mpol_dup(vma_policy(src)); diff --git a/mm/page_alloc.c b/mm/page_alloc.c index d72a0d9d4184..33ad323b98fb 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -5399,6 +5399,18 @@ struct page *__alloc_pages(gfp_t gfp, unsigned int order, int preferred_nid, } EXPORT_SYMBOL(__alloc_pages); +struct folio *__alloc_folio(gfp_t gfp, unsigned int order, int preferred_nid, + nodemask_t *nodemask) +{ + struct page *page = __alloc_pages(gfp | __GFP_COMP, order, + preferred_nid, nodemask); + + if (page && order > 1) + prep_transhuge_page(page); + return (struct folio *)page; +} +EXPORT_SYMBOL(__alloc_folio); + /* * Common helper functions. Never use with __GFP_HIGHMEM because the returned * address cannot represent highmem pages. Use alloc_pages and then kmap if -- 2.30.2