Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp868933lqp; Thu, 21 Mar 2024 19:51:23 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUhOh8rOd5tkpFhfOjTg5F6D9Fapv0/T9O0OtZmBZ8ga9m1UCFtp58ZgfKsar1wQhBLCwxs/Gie2JoPvEhjNYlQokTEvUJwz8XC4qiPCw== X-Google-Smtp-Source: AGHT+IHCO9bnouTT1Glacf/LOyAKeYesH2MJM/twswkielTVyzaS9RtIKaowGa8q4a6GvCpgUPxA X-Received: by 2002:ad4:5948:0:b0:696:1e4f:4124 with SMTP id eo8-20020ad45948000000b006961e4f4124mr901616qvb.26.1711075882950; Thu, 21 Mar 2024 19:51:22 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711075882; cv=pass; d=google.com; s=arc-20160816; b=TZI6var1tzT8wiwRADc0jWy6I/LHcYpp6RTaoqLFF5Q2FmimDhwobWTzKwXLKJm0i8 PJ+eeHCjhk3Luj8DWjbzDae5Y80AX/WxG8lUllOLdZFeJD827OLz5juNSKp0Lr/xPoEG t125YhNYc3369PJiFmvsLGS+HGs1B34R+ZmOcRYfI9x7xl3zzlipfc+Fe5qW1Fg5kqw0 WASX9fPb28S8YTfeXX+9MeiWkD5P9KuVzz6Z3ixLxbvF79kP/IDUfCHUS0lC2fXBXibF HYu53CsotXMBYgdiO2Ve0oxFnEkQmfQdAYfeR1rJGo/+hfcm06FVyUUcKVSeNuFc616W KoiQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:list-unsubscribe:list-subscribe :list-id:precedence:dkim-signature; bh=ui8J3jwhgVwUBohP86gKySPzBpYeTdjDebBsw2pygnU=; fh=xO01eeylntYGEAMgn0XVTixlOTbGfgi8aorX98bfEQg=; b=L0Rg5B4ff/uapEHieHwJaso/JIYDXM25Osn7p1M0yfw9iGIK8tZsFWyHw/YvK6bVnL SaTsq3xDCvnhfBzTztKU6r1DE1nS72aZCPD+HH3bLDxCPTWeQQDcMDj9XK+0sFvaXTvY KqUT8p9juFBIhsVnMfvE/8r3IUH7NY+PkCA7TIo3EVu5OjYzjLXOH6E+YhjDqT6p8qNJ 4ku3BdTyHlzIqQuWyeoeqYUzQqupT7Wubi3YMux38uX+2p+xg+k7uZ+9Xb2kx8KCXtpn Z9Su98pise6o74zdFAsMTE+xRROJB//aMp5YlBAReegknFsUio5BwD7PGTc1zqI1xsTZ plbw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=mMC9YBPC; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-110891-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-110891-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id e12-20020a0562141d0c00b0069611eff2besi1178126qvd.175.2024.03.21.19.51.22 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Mar 2024 19:51:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-110891-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=mMC9YBPC; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-110891-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-110891-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 95FC71C22C78 for ; Fri, 22 Mar 2024 02:51:22 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C05A44A2C; Fri, 22 Mar 2024 02:51:17 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="mMC9YBPC" Received: from mail-vs1-f46.google.com (mail-vs1-f46.google.com [209.85.217.46]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6B8EB3C17 for ; Fri, 22 Mar 2024 02:51:14 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.217.46 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711075876; cv=none; b=HbAf5+ij9p3m/kHBagqinUgapCfOinzvT1Pt3vlOjwT8J6q/kmOSmM5YXVFRDUv/iG8/i7xpDNE2AWcOLlLwMbjkKpytruCwWBcxIGdraHRDG71YogMvndmmA9DXk5MQ2QiIyFEoANKCKLLkj7tKMy++Pww3iuKFXRu/W5YlzF0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711075876; c=relaxed/simple; bh=NqQv+/F1tWp09wDygcJ/YZ3G+/VnK1EcZZBpsV4aZyQ=; h=MIME-Version:References:In-Reply-To:From:Date:Message-ID:Subject: To:Cc:Content-Type; b=loXB9G9E8BFYBd0JpWM7+i6P/M29qGjvrCsFf0N7F9D7wIXZ4DpXZtTunXAgFf7XxeHg8fUMqdm+wkGFi2tHolKkGTV3XqJhenhBRohE9LBURF6zagZdJWCa7Q0YbxumkU043enVgcImI/GwharX+fBtPzZnzYWFzRrSONrp+9M= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=mMC9YBPC; arc=none smtp.client-ip=209.85.217.46 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-vs1-f46.google.com with SMTP id ada2fe7eead31-4765e6cf37aso564542137.1 for ; Thu, 21 Mar 2024 19:51:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1711075873; x=1711680673; darn=vger.kernel.org; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=ui8J3jwhgVwUBohP86gKySPzBpYeTdjDebBsw2pygnU=; b=mMC9YBPC6Mk0ZjzNisYyUJPRlNIG3Aw3NeseduwXPHKtG0TaEPxGdWMZrapQZCma9h 4u2XWeHGYq4VEqw+WOb/l+S/O6ABREhIg5Ffc4AzzyW9xkN74LwyoAeLoTKvG32HhtYn cjnx18JkGBD85oMB6pRFpwsd20e+i60/ZQ+D+f4Hiqd+N7y6uhL+Ghp3rsYKZ9v3Nu8D vKaHi5fh6FVX4mfv4XHmYKyptPdOd1TGVsCYXaShmK34m74YJuwBcww+5FYPsY8NO229 S6R+K9SQGsLaPRUe7YF+tgILRT+74Vinne9/S7NANViWBRHsAQLp08Df/JfSe5pCYo9t NsYw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1711075873; x=1711680673; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=ui8J3jwhgVwUBohP86gKySPzBpYeTdjDebBsw2pygnU=; b=IAoHVZ3FkYd7yKwVzlMeeacU0TnNHO86iGt9n92iwlNtL/BoIURNurBDDS6JuOLST7 PYkpnVuY5SRagE4gmcxgvYNFOJLsbDCp1T6ZxivDcEYjMZAzdI8NXh/MC4TI4NNMNROj NJFRMK95ldiZuvOwVlExEsr0FUhg0HcDEgXtgSzL5jAhmdz/rE1oTEJkYqPHJe+3MCwB ketwsSqoKOSc/Qg5jvkZMaLGG1x9LdHUBYN7X2GQblhEq1eIufq3MNmmKN77pOxqC1YA 5AolX61aQQEa/pGOOo7a/xABBG49BaMadSD3MlwIzav1C7cqpmeN/GOqTAth5NrJq8+Z uLSw== X-Forwarded-Encrypted: i=1; AJvYcCXOaLJB9kc/EjTsNF7QBlgDnOrIwHzum34K9mNR1wzNY7bynBLyAhDqiyVGUojCEWWZ2+2Rl1A/vM0ZhUPh4qbyhOCBRfS81VV65/gK X-Gm-Message-State: AOJu0YzZlFi5V1voCGENTheYofYsZpX0+Am4B8yeamHBc4MzY7071MYd XJ6WWru6R3ET8yAaO8crqTyzwhVu2uW/mmyFxG8UlwZ8BnLVnZjei8IfNq89nuecGd7jUfQRmAz beeVWIlCi2FGYArlaoyHtr3wNpdg= X-Received: by 2002:a67:fd11:0:b0:475:fe59:f33 with SMTP id f17-20020a67fd11000000b00475fe590f33mr1252338vsr.29.1711075873175; Thu, 21 Mar 2024 19:51:13 -0700 (PDT) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 References: <20240304081348.197341-1-21cnbao@gmail.com> <20240304081348.197341-2-21cnbao@gmail.com> <01c61b90-df90-4819-978b-414bb717ef64@arm.com> In-Reply-To: From: Barry Song <21cnbao@gmail.com> Date: Fri, 22 Mar 2024 15:51:01 +1300 Message-ID: Subject: Re: [RFC PATCH v3 1/5] arm64: mm: swap: support THP_SWAP on hardware with MTE To: Ryan Roberts Cc: akpm@linux-foundation.org, linux-mm@kvack.org, chengming.zhou@linux.dev, chrisl@kernel.org, david@redhat.com, hannes@cmpxchg.org, kasong@tencent.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, mhocko@suse.com, nphamcs@gmail.com, shy828301@gmail.com, steven.price@arm.com, surenb@google.com, wangkefeng.wang@huawei.com, willy@infradead.org, xiang@kernel.org, ying.huang@intel.com, yosryahmed@google.com, yuzhao@google.com, Barry Song , Catalin Marinas , Will Deacon , Mark Rutland , Kemeng Shi , Anshuman Khandual , Peter Collingbourne , Peter Xu , Lorenzo Stoakes , "Mike Rapoport (IBM)" , Hugh Dickins , "Aneesh Kumar K.V" , Rick Edgecombe Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Thu, Mar 21, 2024 at 11:31=E2=80=AFPM Ryan Roberts wrote: > > On 21/03/2024 08:42, Barry Song wrote: > > Hi Ryan, > > Sorry for the late reply. > > No problem! > > > > > On Tue, Mar 12, 2024 at 5:56=E2=80=AFAM Ryan Roberts wrote: > >> > >> On 04/03/2024 08:13, Barry Song wrote: > >>> From: Barry Song > >>> > >>> Commit d0637c505f8a1 ("arm64: enable THP_SWAP for arm64") brings up > >>> THP_SWAP on ARM64, but it doesn't enable THP_SWP on hardware with > >>> MTE as the MTE code works with the assumption tags save/restore is > >>> always handling a folio with only one page. > >>> > >>> The limitation should be removed as more and more ARM64 SoCs have > >>> this feature. Co-existence of MTE and THP_SWAP becomes more and > >>> more important. > >>> > >>> This patch makes MTE tags saving support large folios, then we don't > >>> need to split large folios into base pages for swapping out on ARM64 > >>> SoCs with MTE any more. > >>> > >>> arch_prepare_to_swap() should take folio rather than page as paramete= r > >>> because we support THP swap-out as a whole. It saves tags for all > >>> pages in a large folio. > >>> > >>> As now we are restoring tags based-on folio, in arch_swap_restore(), > >>> we may increase some extra loops and early-exitings while refaulting > >>> a large folio which is still in swapcache in do_swap_page(). In case > >>> a large folio has nr pages, do_swap_page() will only set the PTE of > >>> the particular page which is causing the page fault. > >>> Thus do_swap_page() runs nr times, and each time, arch_swap_restore() > >>> will loop nr times for those subpages in the folio. So right now the > >>> algorithmic complexity becomes O(nr^2). > >>> > >>> Once we support mapping large folios in do_swap_page(), extra loops > >>> and early-exitings will decrease while not being completely removed > >>> as a large folio might get partially tagged in corner cases such as, > >>> 1. a large folio in swapcache can be partially unmapped, thus, MTE > >>> tags for the unmapped pages will be invalidated; > >>> 2. users might use mprotect() to set MTEs on a part of a large folio. > >>> > >>> arch_thp_swp_supported() is dropped since ARM64 MTE was the only one > >>> who needed it. > > I think we should decouple this patch from your swap-in series. I suspect= this > one could be ready and go in sooner than the swap-in series based on the = current > discussions :) > > >>> > >>> Cc: Catalin Marinas > >>> Cc: Will Deacon > >>> Cc: Ryan Roberts > >>> Cc: Mark Rutland > >>> Cc: David Hildenbrand > >>> Cc: Kemeng Shi > >>> Cc: "Matthew Wilcox (Oracle)" > >>> Cc: Anshuman Khandual > >>> Cc: Peter Collingbourne > >>> Cc: Steven Price > >>> Cc: Yosry Ahmed > >>> Cc: Peter Xu > >>> Cc: Lorenzo Stoakes > >>> Cc: "Mike Rapoport (IBM)" > >>> Cc: Hugh Dickins > >>> CC: "Aneesh Kumar K.V" > >>> Cc: Rick Edgecombe > >>> Signed-off-by: Barry Song > >>> Reviewed-by: Steven Price > >>> Acked-by: Chris Li > >>> --- > >>> arch/arm64/include/asm/pgtable.h | 19 ++------------ > >>> arch/arm64/mm/mteswap.c | 43 ++++++++++++++++++++++++++++++= ++ > >>> include/linux/huge_mm.h | 12 --------- > >>> include/linux/pgtable.h | 2 +- > >>> mm/page_io.c | 2 +- > >>> mm/swap_slots.c | 2 +- > >>> 6 files changed, 48 insertions(+), 32 deletions(-) > >>> > >>> diff --git a/arch/arm64/include/asm/pgtable.h b/arch/arm64/include/as= m/pgtable.h > >>> index 401087e8a43d..7a54750770b8 100644 > >>> --- a/arch/arm64/include/asm/pgtable.h > >>> +++ b/arch/arm64/include/asm/pgtable.h > >>> @@ -45,12 +45,6 @@ > >>> __flush_tlb_range(vma, addr, end, PUD_SIZE, false, 1) > >>> #endif /* CONFIG_TRANSPARENT_HUGEPAGE */ > >>> > >>> -static inline bool arch_thp_swp_supported(void) > >>> -{ > >>> - return !system_supports_mte(); > >>> -} > >>> -#define arch_thp_swp_supported arch_thp_swp_supported > >>> - > >>> /* > >>> * Outside of a few very special situations (e.g. hibernation), we a= lways > >>> * use broadcast TLB invalidation instructions, therefore a spurious= page > >>> @@ -1095,12 +1089,7 @@ static inline pmd_t pmdp_establish(struct vm_a= rea_struct *vma, > >>> #ifdef CONFIG_ARM64_MTE > >>> > >>> #define __HAVE_ARCH_PREPARE_TO_SWAP > >>> -static inline int arch_prepare_to_swap(struct page *page) > >>> -{ > >>> - if (system_supports_mte()) > >>> - return mte_save_tags(page); > >>> - return 0; > >>> -} > >>> +extern int arch_prepare_to_swap(struct folio *folio); > >>> > >>> #define __HAVE_ARCH_SWAP_INVALIDATE > >>> static inline void arch_swap_invalidate_page(int type, pgoff_t offse= t) > >>> @@ -1116,11 +1105,7 @@ static inline void arch_swap_invalidate_area(i= nt type) > >>> } > >>> > >>> #define __HAVE_ARCH_SWAP_RESTORE > >>> -static inline void arch_swap_restore(swp_entry_t entry, struct folio= *folio) > >>> -{ > >>> - if (system_supports_mte()) > >>> - mte_restore_tags(entry, &folio->page); > >>> -} > >>> +extern void arch_swap_restore(swp_entry_t entry, struct folio *folio= ); > >>> > >>> #endif /* CONFIG_ARM64_MTE */ > >>> > >>> diff --git a/arch/arm64/mm/mteswap.c b/arch/arm64/mm/mteswap.c > >>> index a31833e3ddc5..295836fef620 100644 > >>> --- a/arch/arm64/mm/mteswap.c > >>> +++ b/arch/arm64/mm/mteswap.c > >>> @@ -68,6 +68,13 @@ void mte_invalidate_tags(int type, pgoff_t offset) > >>> mte_free_tag_storage(tags); > >>> } > >>> > >>> +static inline void __mte_invalidate_tags(struct page *page) > >>> +{ > >>> + swp_entry_t entry =3D page_swap_entry(page); > >>> + > >>> + mte_invalidate_tags(swp_type(entry), swp_offset(entry)); > >>> +} > >>> + > >>> void mte_invalidate_tags_area(int type) > >>> { > >>> swp_entry_t entry =3D swp_entry(type, 0); > >>> @@ -83,3 +90,39 @@ void mte_invalidate_tags_area(int type) > >>> } > >>> xa_unlock(&mte_pages); > >>> } > >>> + > >>> +int arch_prepare_to_swap(struct folio *folio) > >>> +{ > >>> + long i, nr; > >>> + int err; > >>> + > >>> + if (!system_supports_mte()) > >>> + return 0; > >>> + > >>> + nr =3D folio_nr_pages(folio); > >>> + > >>> + for (i =3D 0; i < nr; i++) { > >>> + err =3D mte_save_tags(folio_page(folio, i)); > >>> + if (err) > >>> + goto out; > >>> + } > >>> + return 0; > >>> + > >>> +out: > >>> + while (i--) > >>> + __mte_invalidate_tags(folio_page(folio, i)); > >>> + return err; > >>> +} > >>> + > >>> +void arch_swap_restore(swp_entry_t entry, struct folio *folio) > >> > >> I'm still not a fan of the fact that entry could be anywhere within fo= lio. > >> > >>> +{ > >>> + if (system_supports_mte()) { > >> > >> nit: if you do: > >> > >> if (!system_supports_mte()) > >> return; > > > > Acked > > > >> > >> It will be consistent with arch_prepare_to_swap() and reduce the inden= tation of > >> the main body. > >> > >>> + long i, nr =3D folio_nr_pages(folio); > >>> + > >>> + entry.val -=3D swp_offset(entry) & (nr - 1); > >> > >> This assumes that folios are always stored in swap with natural alignm= ent. Is > >> that definitely a safe assumption? My swap-out series is currently ens= uring that > >> folios are swapped-out naturally aligned, but that is an implementatio= n detail. > >> > > > > I concur that this is an implementation detail. However, we should be > > bold enough > > to state that swap slots will be contiguous, considering we are > > currently utilizing > > folio->swap instead of subpage->swap ? > > Yes, I agree about contiguity. My objection is about assuming natural ali= gnment > though. It can still be contiguous while not naturally aligned in swap. Hi Ryan, While working on the new version of this patch, I've come to recognize that, for the time being, it's imperative to maintain a natural alignment. The following code operates on the basis of this assumption. /** * folio_file_page - The page for a particular index. * @folio: The folio which contains this index. * @index: The index we want to look up. * * Sometimes after looking up a folio in the page cache, we need to * obtain the specific page for an index (eg a page fault). * * Return: The page containing the file data for this index. */ static inline struct page *folio_file_page(struct folio *folio, pgoff_t ind= ex) { return folio_page(folio, index & (folio_nr_pages(folio) - 1)); } It's invoked everywhere, particularly within do_swap_page(). Nonetheless, I remain confident that I can consistently pass the first entry to arch_swap_restore(). > > > > >> Your cover note for swap-in says that you could technically swap in a = large > >> folio without it having been swapped-out large. If you chose to do tha= t in > >> future, this would break, right? I don't think it's good to couple the= swap > > > > Right. technically I agree. Given that we still have many tasks involvi= ng even > > swapping in contiguous swap slots, it's unlikely that swapping in large= folios > > for non-contiguous entries will occur in the foreseeable future :-) > > > >> storage layout to the folio order that you want to swap into. Perhaps = that's an > >> argument for passing each *page* to this function with its exact, corr= esponding > >> swap entry? > > > > I recall Matthew Wilcox strongly objected to using "page" as the > > parameter, so I've > > discarded that approach. Alternatively, it appears I can consistently p= ass > > folio->swap to this function and ensure the function always retrieves > > the first entry? > > Yes, if we must pass a folio here, I'd prefer that entry always correspon= ds to > the first entry for the folio. That will remove the need for this functio= n to do > the alignment above too. So win-win. > > > > >> > >>> + for (i =3D 0; i < nr; i++) { > >>> + mte_restore_tags(entry, folio_page(folio, i)); > >>> + entry.val++; > >>> + } > >>> + } > >>> +} > >>> diff --git a/include/linux/huge_mm.h b/include/linux/huge_mm.h > >>> index de0c89105076..e04b93c43965 100644 > >>> --- a/include/linux/huge_mm.h > >>> +++ b/include/linux/huge_mm.h > >>> @@ -535,16 +535,4 @@ static inline int split_folio_to_order(struct fo= lio *folio, int new_order) > >>> #define split_folio_to_list(f, l) split_folio_to_list_to_order(f, l,= 0) > >>> #define split_folio(f) split_folio_to_order(f, 0) > >>> > >>> -/* > >>> - * archs that select ARCH_WANTS_THP_SWAP but don't support THP_SWP d= ue to > >>> - * limitations in the implementation like arm64 MTE can override thi= s to > >>> - * false > >>> - */ > >>> -#ifndef arch_thp_swp_supported > >>> -static inline bool arch_thp_swp_supported(void) > >>> -{ > >>> - return true; > >>> -} > >>> -#endif > >>> - > >>> #endif /* _LINUX_HUGE_MM_H */ > >>> diff --git a/include/linux/pgtable.h b/include/linux/pgtable.h > >>> index e1b22903f709..bfcfe3386934 100644 > >>> --- a/include/linux/pgtable.h > >>> +++ b/include/linux/pgtable.h > >>> @@ -1106,7 +1106,7 @@ static inline int arch_unmap_one(struct mm_stru= ct *mm, > >>> * prototypes must be defined in the arch-specific asm/pgtable.h fil= e. > >>> */ > >>> #ifndef __HAVE_ARCH_PREPARE_TO_SWAP > >>> -static inline int arch_prepare_to_swap(struct page *page) > >>> +static inline int arch_prepare_to_swap(struct folio *folio) > >>> { > >>> return 0; > >>> } > >>> diff --git a/mm/page_io.c b/mm/page_io.c > >>> index ae2b49055e43..a9a7c236aecc 100644 > >>> --- a/mm/page_io.c > >>> +++ b/mm/page_io.c > >>> @@ -189,7 +189,7 @@ int swap_writepage(struct page *page, struct writ= eback_control *wbc) > >>> * Arch code may have to preserve more data than just the page > >>> * contents, e.g. memory tags. > >>> */ > >>> - ret =3D arch_prepare_to_swap(&folio->page); > >>> + ret =3D arch_prepare_to_swap(folio); > >>> if (ret) { > >>> folio_mark_dirty(folio); > >>> folio_unlock(folio); > >>> diff --git a/mm/swap_slots.c b/mm/swap_slots.c > >>> index 90973ce7881d..53abeaf1371d 100644 > >>> --- a/mm/swap_slots.c > >>> +++ b/mm/swap_slots.c > >>> @@ -310,7 +310,7 @@ swp_entry_t folio_alloc_swap(struct folio *folio) > >>> entry.val =3D 0; > >>> > >>> if (folio_test_large(folio)) { > >>> - if (IS_ENABLED(CONFIG_THP_SWAP) && arch_thp_swp_support= ed()) > >>> + if (IS_ENABLED(CONFIG_THP_SWAP)) > >>> get_swap_pages(1, &entry, folio_nr_pages(folio)= ); > >>> goto out; > >>> } > >> > > > > Thanks > > Barry >