From patchwork Thu Jan 27 08:56:06 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mike Rapoport X-Patchwork-Id: 12726420 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 16198C433FE for ; Thu, 27 Jan 2022 08:56:26 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 995176B0072; Thu, 27 Jan 2022 03:56:25 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 91E0E6B0073; Thu, 27 Jan 2022 03:56:25 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 7E6B96B0075; Thu, 27 Jan 2022 03:56:25 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (relay025.a.hostedemail.com [64.99.140.25]) by kanga.kvack.org (Postfix) with ESMTP id 6F6D06B0072 for ; Thu, 27 Jan 2022 03:56:25 -0500 (EST) Received: from smtpin02.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id 3F32A20344 for ; Thu, 27 Jan 2022 08:56:25 +0000 (UTC) X-FDA: 79075460730.02.F5EA5D7 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by imf09.hostedemail.com (Postfix) with ESMTP id A179A140009 for ; Thu, 27 Jan 2022 08:56:24 +0000 (UTC) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 799D9B821E8; Thu, 27 Jan 2022 08:56:22 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 91B87C340EB; Thu, 27 Jan 2022 08:56:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643273781; bh=I6Lml67mMk2bEDGtoWeFKAaRqTkT3XAvz34UG78eTJg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NfkytKX71EBL9008d5+S9NdWVxs0Ug/kMXoZCg6bE9Z1Ur3j9L8Fykz6sD9Y48fPQ 2Maz2A6OwogWPgldiV3rj3uTw4W1p/TybH+D6z5W+kpyN5woFrsSh0SkKWB5SU9ter 7CStMgXAzE6vM17fS/lz06mjnqFtQUrH7jJqWakLcJSIsUeMj87ci4ZYQSO048PRVm r08wi2Og7E7kuq46kd4WE6X+6SqTRCOUuc5eRTFB09iO22GjJbGu5zSUKbfGe3nrVT B8FfDlhteW3agBIqC5DfCeLQA3zE0E0Ces2ulVC1K6jz/8heMhcAxgH3z/yIBpvv09 hv/L/+W030twg== From: Mike Rapoport To: linux-mm@kvack.org Cc: Andrew Morton , Andy Lutomirski , Dave Hansen , Ira Weiny , Kees Cook , Mike Rapoport , Mike Rapoport , Peter Zijlstra , Rick Edgecombe , Vlastimil Babka , linux-kernel@vger.kernel.org, x86@kernel.org Subject: [RFC PATCH 1/3] mm/page_alloc: introduce __GFP_UNMAPPED and MIGRATE_UNMAPPED Date: Thu, 27 Jan 2022 10:56:06 +0200 Message-Id: <20220127085608.306306-2-rppt@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220127085608.306306-1-rppt@kernel.org> References: <20220127085608.306306-1-rppt@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam09 X-Rspamd-Queue-Id: A179A140009 X-Stat-Signature: zki3mkdwbsasijba56igrb7e64bj3tu9 X-Rspam-User: nil Authentication-Results: imf09.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=NfkytKX7; spf=pass (imf09.hostedemail.com: domain of rppt@kernel.org designates 145.40.68.75 as permitted sender) smtp.mailfrom=rppt@kernel.org; dmarc=pass (policy=none) header.from=kernel.org X-HE-Tag: 1643273784-669613 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: From: Mike Rapoport When set_memory or set_direct_map APIs used to change attribute or permissions for chunks of several pages, the large PMD that maps these pages in the direct map must be split. Fragmenting the direct map in such manner causes TLB pressure and, eventually, performance degradation. To avoid excessive direct map fragmentation, add ability to allocate "unmapped" pages with __GFP_UNMAPPED flag and a new migrate type MIGRATE_UNMAPPED that will contain pages that are mapped with PTEs in the direct map. When allocation flags include __GFP_UNMAPPED, the allocated page(s) are remapped at PTE level in the direct map along with the other free pages in the same pageblock. The free pages in that pageblock are placed on MIGRATE_UNMAPPED free lists and subsequent __GFP_UNMAPPED request are served from the MIGRATE_UNMAPPED free lists. This way, a single split of a large PMD creates a cache of PTE-mapped pages that can be used without the need to split another PMD. The pages are removed from the direct map late during allocation to keep the existing logic in prep_new_page() for clearing, poisoning and other page content accesses. When a page from MIGRATE_UNMAPPED pageblock is freed, it is restored in the direct map to allow proper page contents access in free_pages_prepare(). Signed-off-by: Mike Rapoport --- arch/Kconfig | 7 ++ arch/x86/Kconfig | 1 + include/linux/gfp.h | 13 +++- include/linux/mmzone.h | 11 +++ include/trace/events/mmflags.h | 3 +- mm/internal.h | 2 +- mm/page_alloc.c | 129 ++++++++++++++++++++++++++++++++- 7 files changed, 160 insertions(+), 6 deletions(-) diff --git a/arch/Kconfig b/arch/Kconfig index 678a80713b21..e16a70ed0b2d 100644 --- a/arch/Kconfig +++ b/arch/Kconfig @@ -1321,6 +1321,13 @@ config DYNAMIC_SIGFRAME # Select, if arch has a named attribute group bound to NUMA device nodes. config HAVE_ARCH_NODE_DEV_GROUP bool +# +# Select if the architecture wants to minimize fragmentation of its +# direct/linear map cauesd by set_memory and set_direct_map operations +# +config ARCH_WANTS_GFP_UNMAPPED + bool + depends on ARCH_HAS_SET_MEMORY || ARCH_HAS_SET_DIRECT_MAP source "kernel/gcov/Kconfig" diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index ebe8fc76949a..564e97c88ef0 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig @@ -120,6 +120,7 @@ config X86 select ARCH_WANTS_NO_INSTR select ARCH_WANT_HUGE_PMD_SHARE select ARCH_WANT_LD_ORPHAN_WARN + select ARCH_WANTS_GFP_UNMAPPED select ARCH_WANTS_THP_SWAP if X86_64 select ARCH_HAS_PARANOID_L1D_FLUSH select BUILDTIME_TABLE_SORT diff --git a/include/linux/gfp.h b/include/linux/gfp.h index 80f63c862be5..63b8d3b2711d 100644 --- a/include/linux/gfp.h +++ b/include/linux/gfp.h @@ -55,8 +55,9 @@ struct vm_area_struct; #define ___GFP_ACCOUNT 0x400000u #define ___GFP_ZEROTAGS 0x800000u #define ___GFP_SKIP_KASAN_POISON 0x1000000u +#define ___GFP_UNMAPPED 0x2000000u #ifdef CONFIG_LOCKDEP -#define ___GFP_NOLOCKDEP 0x2000000u +#define ___GFP_NOLOCKDEP 0x4000000u #else #define ___GFP_NOLOCKDEP 0 #endif @@ -101,12 +102,15 @@ struct vm_area_struct; * node with no fallbacks or placement policy enforcements. * * %__GFP_ACCOUNT causes the allocation to be accounted to kmemcg. + * + * %__GFP_UNMAPPED removes the allocated pages from the direct map. */ #define __GFP_RECLAIMABLE ((__force gfp_t)___GFP_RECLAIMABLE) #define __GFP_WRITE ((__force gfp_t)___GFP_WRITE) #define __GFP_HARDWALL ((__force gfp_t)___GFP_HARDWALL) #define __GFP_THISNODE ((__force gfp_t)___GFP_THISNODE) #define __GFP_ACCOUNT ((__force gfp_t)___GFP_ACCOUNT) +#define __GFP_UNMAPPED ((__force gfp_t)___GFP_UNMAPPED) /** * DOC: Watermark modifiers @@ -249,7 +253,7 @@ struct vm_area_struct; #define __GFP_NOLOCKDEP ((__force gfp_t)___GFP_NOLOCKDEP) /* Room for N __GFP_FOO bits */ -#define __GFP_BITS_SHIFT (25 + IS_ENABLED(CONFIG_LOCKDEP)) +#define __GFP_BITS_SHIFT (26 + IS_ENABLED(CONFIG_LOCKDEP)) #define __GFP_BITS_MASK ((__force gfp_t)((1 << __GFP_BITS_SHIFT) - 1)) /** @@ -348,6 +352,11 @@ static inline int gfp_migratetype(const gfp_t gfp_flags) BUILD_BUG_ON((1UL << GFP_MOVABLE_SHIFT) != ___GFP_MOVABLE); BUILD_BUG_ON((___GFP_MOVABLE >> GFP_MOVABLE_SHIFT) != MIGRATE_MOVABLE); +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED + if (unlikely(gfp_flags & __GFP_UNMAPPED)) + return MIGRATE_UNMAPPED; +#endif + if (unlikely(page_group_by_mobility_disabled)) return MIGRATE_UNMOVABLE; diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h index aed44e9b5d89..7971af97b6cf 100644 --- a/include/linux/mmzone.h +++ b/include/linux/mmzone.h @@ -43,6 +43,9 @@ enum migratetype { MIGRATE_UNMOVABLE, MIGRATE_MOVABLE, MIGRATE_RECLAIMABLE, +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED + MIGRATE_UNMAPPED, +#endif MIGRATE_PCPTYPES, /* the number of types on the pcp lists */ MIGRATE_HIGHATOMIC = MIGRATE_PCPTYPES, #ifdef CONFIG_CMA @@ -78,6 +81,14 @@ extern const char * const migratetype_names[MIGRATE_TYPES]; # define is_migrate_cma_page(_page) false #endif +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED +# define is_migrate_unmapped(migratetype) unlikely((migratetype) == MIGRATE_UNMAPPED) +# define is_migrate_unmapped_page(_page) (get_pageblock_migratetype(_page) == MIGRATE_UNMAPPED) +#else +# define is_migrate_unmapped(migratetype) false +# define is_migrate_unmapped_page(_page) false +#endif + static inline bool is_migrate_movable(int mt) { return is_migrate_cma(mt) || mt == MIGRATE_MOVABLE; diff --git a/include/trace/events/mmflags.h b/include/trace/events/mmflags.h index 116ed4d5d0f8..501f37f4095d 100644 --- a/include/trace/events/mmflags.h +++ b/include/trace/events/mmflags.h @@ -50,7 +50,8 @@ {(unsigned long)__GFP_DIRECT_RECLAIM, "__GFP_DIRECT_RECLAIM"},\ {(unsigned long)__GFP_KSWAPD_RECLAIM, "__GFP_KSWAPD_RECLAIM"},\ {(unsigned long)__GFP_ZEROTAGS, "__GFP_ZEROTAGS"}, \ - {(unsigned long)__GFP_SKIP_KASAN_POISON,"__GFP_SKIP_KASAN_POISON"}\ + {(unsigned long)__GFP_SKIP_KASAN_POISON,"__GFP_SKIP_KASAN_POISON"},\ + {(unsigned long)__GFP_UNMAPPED, "__GFP_UNMAPPED"} \ #define show_gfp_flags(flags) \ (flags) ? __print_flags(flags, "|", \ diff --git a/mm/internal.h b/mm/internal.h index d80300392a19..3edc3abf3f56 100644 --- a/mm/internal.h +++ b/mm/internal.h @@ -32,7 +32,7 @@ struct folio_batch; #define GFP_CONSTRAINT_MASK (__GFP_HARDWALL|__GFP_THISNODE) /* Do not use these with a slab allocator */ -#define GFP_SLAB_BUG_MASK (__GFP_DMA32|__GFP_HIGHMEM|~__GFP_BITS_MASK) +#define GFP_SLAB_BUG_MASK (__GFP_DMA32|__GFP_HIGHMEM|__GFP_UNMAPPED|~__GFP_BITS_MASK) void page_writeback_init(void); diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 3589febc6d31..da6b1bb912a8 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -75,6 +75,7 @@ #include #include #include +#include #include #include #include @@ -82,6 +83,12 @@ #include "shuffle.h" #include "page_reporting.h" +/* + * FIXME: add a proper definition in include/linux/mm.h once remaining + * definitions of PMD_ORDER in arch/ are updated + */ +#define PMD_ORDER (PMD_SHIFT - PAGE_SHIFT) + /* Free Page Internal flags: for internal, non-pcp variants of free_pages(). */ typedef int __bitwise fpi_t; @@ -319,6 +326,9 @@ const char * const migratetype_names[MIGRATE_TYPES] = { "Unmovable", "Movable", "Reclaimable", +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED + "Unmapped", +#endif "HighAtomic", #ifdef CONFIG_CMA "CMA", @@ -938,9 +948,10 @@ compaction_capture(struct capture_control *capc, struct page *page, if (!capc || order != capc->cc->order) return false; - /* Do not accidentally pollute CMA or isolated regions*/ + /* Do not accidentally pollute CMA or isolated or unmapped regions */ if (is_migrate_cma(migratetype) || - is_migrate_isolate(migratetype)) + is_migrate_isolate(migratetype) || + is_migrate_unmapped(migratetype)) return false; /* @@ -1143,6 +1154,17 @@ static inline void __free_one_page(struct page *page, done_merging: set_buddy_order(page, order); +#if 0 + /* + * FIXME: collapse PMD-size page in the direct map and move the + * pageblock from MIGRATE_UNMAPPED to another migrate type. + */ + if ((order == PMD_ORDER) && is_migrate_unmapped_page(page)) { + set_direct_map_PMD(page); + set_pageblock_migratetype(page, MIGRATE_MOVABLE); + } +#endif + if (fpi_flags & FPI_TO_TAIL) to_tail = true; else if (is_shuffle_order(order)) @@ -1271,6 +1293,40 @@ static int free_tail_pages_check(struct page *head_page, struct page *page) return ret; } +static void migrate_unmapped_map_pages(struct page *page, unsigned int nr) +{ +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED + int i; + + if (!is_migrate_unmapped_page(page)) + return; + + for (i = 0; i < nr; i++) + set_direct_map_default_noflush(page + i); +#endif +} + +static void migrate_unmapped_unmap_pages(struct page *page, unsigned int nr, + gfp_t gfp) +{ +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED + unsigned long start = (unsigned long)page_address(page); + unsigned long end = start + nr * PAGE_SIZE; + int i; + + if (!(gfp & __GFP_UNMAPPED)) + return; + + if (!is_migrate_unmapped_page(page)) + return; + + for (i = 0; i < nr; i++) + set_direct_map_invalid_noflush(page + i); + + flush_tlb_kernel_range(start, end); +#endif +} + static void kernel_init_free_pages(struct page *page, int numpages, bool zero_tags) { int i; @@ -1359,6 +1415,7 @@ static __always_inline bool free_pages_prepare(struct page *page, PAGE_SIZE << order); } + migrate_unmapped_map_pages(page, 1 << order); kernel_poison_pages(page, 1 << order); /* @@ -2426,6 +2483,7 @@ inline void post_alloc_hook(struct page *page, unsigned int order, set_page_owner(page, order, gfp_flags); page_table_check_alloc(page, order); + migrate_unmapped_unmap_pages(page, 1 << order, gfp_flags); } static void prep_new_page(struct page *page, unsigned int order, gfp_t gfp_flags, @@ -2480,6 +2538,7 @@ struct page *__rmqueue_smallest(struct zone *zone, unsigned int order, * This array describes the order lists are fallen back to when * the free lists for the desirable migrate type are depleted */ +#ifndef CONFIG_ARCH_WANTS_GFP_UNMAPPED static int fallbacks[MIGRATE_TYPES][3] = { [MIGRATE_UNMOVABLE] = { MIGRATE_RECLAIMABLE, MIGRATE_MOVABLE, MIGRATE_TYPES }, [MIGRATE_MOVABLE] = { MIGRATE_RECLAIMABLE, MIGRATE_UNMOVABLE, MIGRATE_TYPES }, @@ -2492,6 +2551,22 @@ static int fallbacks[MIGRATE_TYPES][3] = { #endif }; +#else /* CONFIG_ARCH_WANTS_GFP_UNMAPPED */ + +static int fallbacks[MIGRATE_TYPES][4] = { + [MIGRATE_UNMOVABLE] = { MIGRATE_RECLAIMABLE, MIGRATE_MOVABLE, MIGRATE_UNMAPPED, MIGRATE_TYPES }, + [MIGRATE_MOVABLE] = { MIGRATE_RECLAIMABLE, MIGRATE_UNMOVABLE, MIGRATE_UNMAPPED, MIGRATE_TYPES }, + [MIGRATE_RECLAIMABLE] = { MIGRATE_UNMOVABLE, MIGRATE_MOVABLE, MIGRATE_UNMAPPED, MIGRATE_TYPES }, + [MIGRATE_UNMAPPED] = { MIGRATE_UNMOVABLE, MIGRATE_RECLAIMABLE, MIGRATE_MOVABLE, MIGRATE_TYPES }, +#ifdef CONFIG_CMA + [MIGRATE_CMA] = { MIGRATE_TYPES }, /* Never used */ +#endif +#ifdef CONFIG_MEMORY_ISOLATION + [MIGRATE_ISOLATE] = { MIGRATE_TYPES }, /* Never used */ +#endif +}; +#endif /* CONFIG_ARCH_WANTS_GFP_UNMAPPED */ + #ifdef CONFIG_CMA static __always_inline struct page *__rmqueue_cma_fallback(struct zone *zone, unsigned int order) @@ -2567,6 +2642,39 @@ int move_freepages_block(struct zone *zone, struct page *page, num_movable); } +static int set_pageblock_unmapped(struct zone *zone, struct page *page, + unsigned int order) +{ +#ifdef CONFIG_ARCH_WANTS_GFP_UNMAPPED + int migratetype = get_pageblock_migratetype(page); + unsigned long err; + + BUILD_BUG_ON(pageblock_order != PMD_ORDER); + + if (is_migrate_unmapped_page(page)) + return 0; + + /* + * Calling set_direct_map_invalid_noflush() for any page in a + * pageblock will split PMD entry and the split may fail to allocate the + * PMD page. + * Subsequent calls to set_direct_map APIs within the same + * pageblock will only update the PTEs, so they cannot fail. + */ + err = set_direct_map_invalid_noflush(page); + if (err) { + move_to_free_list(page, zone, order, migratetype); + return err; + } + + set_direct_map_default_noflush(page); + set_pageblock_migratetype(page, MIGRATE_UNMAPPED); + move_freepages_block(zone, page, MIGRATE_UNMAPPED, NULL); +#endif + + return 0; +} + static void change_pageblock_range(struct page *pageblock_page, int start_order, int migratetype) { @@ -2605,6 +2713,7 @@ static bool can_steal_fallback(unsigned int order, int start_mt) if (order >= pageblock_order / 2 || start_mt == MIGRATE_RECLAIMABLE || start_mt == MIGRATE_UNMOVABLE || + is_migrate_unmapped(start_mt) || page_group_by_mobility_disabled) return true; @@ -2672,6 +2781,14 @@ static void steal_suitable_fallback(struct zone *zone, struct page *page, if (is_migrate_highatomic(old_block_type)) goto single_page; + /* + * If the new migrate type is MIGRATE_UNMAPPED, the entire + * pageblock will be moved, but it is handled later in + * get_page_from_freelist() to allow error handling and recovery + */ + if (is_migrate_unmapped(start_type)) + goto single_page; + /* Take ownership for orders >= pageblock_order */ if (current_order >= pageblock_order) { change_pageblock_range(page, current_order, start_type); @@ -4162,6 +4279,10 @@ get_page_from_freelist(gfp_t gfp_mask, unsigned int order, int alloc_flags, page = rmqueue(ac->preferred_zoneref->zone, zone, order, gfp_mask, alloc_flags, ac->migratetype); if (page) { + if ((gfp_mask & __GFP_UNMAPPED) && + set_pageblock_unmapped(zone, page, order)) + return NULL; + prep_new_page(page, order, gfp_mask, alloc_flags); /* @@ -5241,6 +5362,10 @@ unsigned long __alloc_pages_bulk(gfp_t gfp, int preferred_nid, if (nr_pages - nr_populated == 1) goto failed; + /* Bulk allocator does not support __GFP_UNMAPPED */ + if (gfp & __GFP_UNMAPPED) + goto failed; + #ifdef CONFIG_PAGE_OWNER /* * PAGE_OWNER may recurse into the allocator to allocate space to From patchwork Thu Jan 27 08:56:07 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mike Rapoport X-Patchwork-Id: 12726421 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 15F1DC433FE for ; Thu, 27 Jan 2022 08:56:29 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 947E66B0073; Thu, 27 Jan 2022 03:56:28 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 91E7B6B0075; Thu, 27 Jan 2022 03:56:28 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 80D336B0078; Thu, 27 Jan 2022 03:56:28 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0181.hostedemail.com [216.40.44.181]) by kanga.kvack.org (Postfix) with ESMTP id 725266B0073 for ; Thu, 27 Jan 2022 03:56:28 -0500 (EST) Received: from smtpin07.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id 289F892743 for ; Thu, 27 Jan 2022 08:56:28 +0000 (UTC) X-FDA: 79075460856.07.9FDFBE9 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by imf19.hostedemail.com (Postfix) with ESMTP id 51CC21A000B for ; Thu, 27 Jan 2022 08:56:27 +0000 (UTC) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 94C5F61B41; Thu, 27 Jan 2022 08:56:26 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C5EE1C340E4; Thu, 27 Jan 2022 08:56:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643273785; bh=lNqF3mJPDGw233av00HH2FDJ+SSvpcSySTuoi9rmynY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sJub49UhZPTd7ncg8oXuofMZCo6X6gobjlkjNoRy1y+1HXcBHY+U6J8JKdChxUTlV R0xl4kpRAEkFcrTPU6gRBfYM2BxXOpQfX0BtpGfzuTwNcRpzrCWaJ3MmUQBMghVCTG OJFATAVFmYipeykdrlEZh2HYxm7jdb1pXj5tnJIhqIMdphYOG3rB3n7imGJu7/k7J/ rn77s05xi4g8Zw3XSc5a2YXu5jj4cgL2/P/zPqnr5yAe0MevN/qqGNbO6QJsGtTWR5 RE2fUvXkZAa2V4Huqd6ilml4no4fCJ25F1FDH8W5K0+EfZI6s0cKz6wMJ2deM3cgez XB8H56ynUjqzg== From: Mike Rapoport To: linux-mm@kvack.org Cc: Andrew Morton , Andy Lutomirski , Dave Hansen , Ira Weiny , Kees Cook , Mike Rapoport , Mike Rapoport , Peter Zijlstra , Rick Edgecombe , Vlastimil Babka , linux-kernel@vger.kernel.org, x86@kernel.org Subject: [RFC PATCH 2/3] mm/secretmem: use __GFP_UNMAPPED to allocate pages Date: Thu, 27 Jan 2022 10:56:07 +0200 Message-Id: <20220127085608.306306-3-rppt@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220127085608.306306-1-rppt@kernel.org> References: <20220127085608.306306-1-rppt@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: 51CC21A000B X-Rspam-User: nil Authentication-Results: imf19.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=sJub49Uh; dmarc=pass (policy=none) header.from=kernel.org; spf=pass (imf19.hostedemail.com: domain of rppt@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=rppt@kernel.org X-Stat-Signature: 74mxxb65goxy8ts6ogo9xaazipptfc8x X-HE-Tag: 1643273787-524964 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: From: Mike Rapoport Currently secertmem explicitly removes allocated pages from the direct map. This fragments direct map because allocated pages may reside in different pageblocks. Use __GFP_UNMAPPED to utilize caching of unmapped pages done by the page allocator. Signed-off-by: Mike Rapoport --- mm/secretmem.c | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/mm/secretmem.c b/mm/secretmem.c index 22b310adb53d..878ef004d7a7 100644 --- a/mm/secretmem.c +++ b/mm/secretmem.c @@ -63,16 +63,10 @@ static vm_fault_t secretmem_fault(struct vm_fault *vmf) retry: page = find_lock_page(mapping, offset); if (!page) { - page = alloc_page(gfp | __GFP_ZERO); + page = alloc_page(gfp | __GFP_ZERO | __GFP_UNMAPPED); if (!page) return VM_FAULT_OOM; - err = set_direct_map_invalid_noflush(page); - if (err) { - put_page(page); - return vmf_error(err); - } - __SetPageUptodate(page); err = add_to_page_cache_lru(page, mapping, offset, gfp); if (unlikely(err)) { From patchwork Thu Jan 27 08:56:08 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mike Rapoport X-Patchwork-Id: 12726422 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 240ECC433F5 for ; Thu, 27 Jan 2022 08:56:32 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id B1B8D6B0075; Thu, 27 Jan 2022 03:56:31 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id ACDD26B0078; Thu, 27 Jan 2022 03:56:31 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 9BACF6B007B; Thu, 27 Jan 2022 03:56:31 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0057.hostedemail.com [216.40.44.57]) by kanga.kvack.org (Postfix) with ESMTP id 8C0D46B0075 for ; Thu, 27 Jan 2022 03:56:31 -0500 (EST) Received: from smtpin12.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay01.hostedemail.com (Postfix) with ESMTP id 4EB38181C9B9B for ; Thu, 27 Jan 2022 08:56:31 +0000 (UTC) X-FDA: 79075460982.12.B229196 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by imf27.hostedemail.com (Postfix) with ESMTP id EF3D94000A for ; Thu, 27 Jan 2022 08:56:30 +0000 (UTC) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 3512E61B23; Thu, 27 Jan 2022 08:56:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 0387EC340EF; Thu, 27 Jan 2022 08:56:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643273789; bh=CdUM/xw3G6lznVQt3NFsLntFbhnkWNalr2oPO1cWbtc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=PdeB0IOjH7cl+p7r/DVrnXMzWGpLTAqd7OeqfmR5lN0cQswaE9TQ6aDaVI3nQVMWG XoHl9bO+SG272yKyOFDqISU2IJw45i5Pq/n+j/ppeWnbAzxPVYRLz/NWmQpY4kSMvB xUEOdmh4J1oeda569iz0hqKGdwsogExt4lJCnta6F7gS2WpvPBTmm98TirE4gY4pV9 ilrA1lVskayUfHi3CDPLv25yxIFGYn1H+WjpHtr3OmSeg6BB+NXpIg1xgEUBvsMt7R SbZATL97Cpcc10wh9AMIHkhf0kCazy/3u2l4zKjEo6pIl0BjvXau/bg5zp51XEUcwg bRq46RA7wqkFQ== From: Mike Rapoport To: linux-mm@kvack.org Cc: Andrew Morton , Andy Lutomirski , Dave Hansen , Ira Weiny , Kees Cook , Mike Rapoport , Mike Rapoport , Peter Zijlstra , Rick Edgecombe , Vlastimil Babka , linux-kernel@vger.kernel.org, x86@kernel.org Subject: [RFC PATCH 3/3] EXPERIMENTAL: x86/module: use __GFP_UNMAPPED in module_alloc Date: Thu, 27 Jan 2022 10:56:08 +0200 Message-Id: <20220127085608.306306-4-rppt@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220127085608.306306-1-rppt@kernel.org> References: <20220127085608.306306-1-rppt@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam11 X-Rspamd-Queue-Id: EF3D94000A X-Stat-Signature: d3m9gqi4bagoixpgpocx5yy8wck64iy3 Authentication-Results: imf27.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=PdeB0IOj; dmarc=pass (policy=none) header.from=kernel.org; spf=pass (imf27.hostedemail.com: domain of rppt@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=rppt@kernel.org X-Rspam-User: nil X-HE-Tag: 1643273790-873803 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: From: Mike Rapoport The permissions of pages allocated by module_alloc() are frequently updated using set_memory and set_direct_map APIs. Such permission changes cause fragmentation of the direct map. Since module_alloc() essentially wraps vmalloc(), the memory allocated by it is mapped in the vmalloc area and it can be completely removed from the direct map. Use __GFP_UNMAPPED to utilize caching of unmapped pages done by the page allocator. Signed-off-by: Mike Rapoport --- arch/x86/kernel/module.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/x86/kernel/module.c b/arch/x86/kernel/module.c index 95fa745e310a..70aa6ec0cc16 100644 --- a/arch/x86/kernel/module.c +++ b/arch/x86/kernel/module.c @@ -75,7 +75,7 @@ void *module_alloc(unsigned long size) p = __vmalloc_node_range(size, MODULE_ALIGN, MODULES_VADDR + get_module_load_offset(), - MODULES_END, gfp_mask, + MODULES_END, gfp_mask | __GFP_UNMAPPED, PAGE_KERNEL, VM_DEFER_KMEMLEAK, NUMA_NO_NODE, __builtin_return_address(0)); if (p && (kasan_module_alloc(p, size, gfp_mask) < 0)) {