From patchwork Tue Jul 18 23:44:53 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sean Christopherson X-Patchwork-Id: 13317879 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 1A829C001DC for ; Tue, 18 Jul 2023 23:48:55 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 5E1CF8D0028; Tue, 18 Jul 2023 19:48:54 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 590F08D0012; Tue, 18 Jul 2023 19:48:54 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 459778D0028; Tue, 18 Jul 2023 19:48:54 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 332968D0012 for ; Tue, 18 Jul 2023 19:48:54 -0400 (EDT) Received: from smtpin11.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id 05D211C8E50 for ; Tue, 18 Jul 2023 23:48:54 +0000 (UTC) X-FDA: 81026375388.11.987D299 Received: from mail-oa1-f73.google.com (mail-oa1-f73.google.com [209.85.160.73]) by imf06.hostedemail.com (Postfix) with ESMTP id 0C1F7180018 for ; Tue, 18 Jul 2023 23:48:51 +0000 (UTC) Authentication-Results: imf06.hostedemail.com; dkim=pass header.d=google.com header.s=20221208 header.b="dy1/NFlQ"; dmarc=pass (policy=reject) header.from=google.com; spf=pass (imf06.hostedemail.com: domain of 34yS3ZAYKCDYkWSfbUYggYdW.Ugedafmp-eecnSUc.gjY@flex--seanjc.bounces.google.com designates 209.85.160.73 as permitted sender) smtp.mailfrom=34yS3ZAYKCDYkWSfbUYggYdW.Ugedafmp-eecnSUc.gjY@flex--seanjc.bounces.google.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1689724132; h=from:from:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=muvilKyoWvn1tarN80afquV4Wd3ZvyUZATzGD2ucPnA=; b=qWqR8CzwnTOBWjYw5n2InI5/bfuC5eBcgItFMKV3QyrrMBV2wj6k/nKb+wmmx4AAgyAiwL DcwLhzf9DZdGc6wyjz5nS9WAfHzJF5EBUbMUum2TwSUi3+v1fObylhJx/asPK/FZEWCrT5 aTuMERmNRnKKtgIuul48HArS4TKCXzU= ARC-Authentication-Results: i=1; imf06.hostedemail.com; dkim=pass header.d=google.com header.s=20221208 header.b="dy1/NFlQ"; dmarc=pass (policy=reject) header.from=google.com; spf=pass (imf06.hostedemail.com: domain of 34yS3ZAYKCDYkWSfbUYggYdW.Ugedafmp-eecnSUc.gjY@flex--seanjc.bounces.google.com designates 209.85.160.73 as permitted sender) smtp.mailfrom=34yS3ZAYKCDYkWSfbUYggYdW.Ugedafmp-eecnSUc.gjY@flex--seanjc.bounces.google.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1689724132; a=rsa-sha256; cv=none; b=G9biWOro50AOnScLH6d+c+jAYkl0X0Giz5DfxoPF+fsEgGTchvM+UyuKI8etYqqSvUdBFZ xwIiYbRp+Pu7xVW8yqD3J+F8opAJtzyj8REfhLXvnheLAfbm4uwSqRZCt3sNxMhyIlGikL yXwJemfCm4Yf3YKxZK/z/za5H1X5GDQ= Received: by mail-oa1-f73.google.com with SMTP id 586e51a60fabf-1b78a4797e1so9610987fac.3 for ; Tue, 18 Jul 2023 16:48:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1689724131; x=1692316131; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:reply-to:from:to:cc:subject:date:message-id:reply-to; bh=muvilKyoWvn1tarN80afquV4Wd3ZvyUZATzGD2ucPnA=; b=dy1/NFlQGuJqswhd4jyp5/5Y2DKjXWq8ZhDnL7jyfQUkTP7A9Hvq/HvrZglV4JQg4M 0K4GnyosjYX3JEla9t9lm8LJXLHv4GUKKzg9xFm9cJWrlQ5Qmy5LmSHitAR/Xzi9H8/Y MjJIFDOPL8g3wik3LCZjllYyd45Gr2H0qgazCaqc+yiHTFw7sn+VQEAa9DzzRpRQoil4 OF2suL13dOrJbxrD1Es2a+3MSZoSnJ4hgva3/KXiELtegBBB1WkzGy/iAanliFh6iYW0 B8x8MynR4QN8rTTnTiUPKbxJnJ7ZIBs38bI6aS2sGXphM22HDrUDYnhUpurmEDIvnFzg o5tw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1689724131; x=1692316131; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:reply-to:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=muvilKyoWvn1tarN80afquV4Wd3ZvyUZATzGD2ucPnA=; b=Bu5HCA05lyfadXTOoV82k5ReLbafpw+LEXEs3AHxtGxotIXahA8sHbQ2/wX4gAFKK6 LLVz1b551fuzAMA8naNTlJokCzGD1nm2MKzXLU9LOuJqw7EPRHJlcdx5KmFB6dS6UaB9 +86IyAw0z2sS1IwGfBbiW6sQz/jwX597p4tTb6VwbfRczitxtY/VwYABKbMFIuHWAJHs adf6EWE3PO0fRwTH7XzrmJzBO6xbIhTvmcRLWg6nXHsao4WRgDPlxKOd7ML4SZv/To9K PbRjZBdeRTEYOTK7k7Be99uAKlhPgRdGgUq3Akun7LDb0Y3/oIsNh2BadXHVT5l36ApK oZBA== X-Gm-Message-State: ABy/qLbEioUXtUMFZjX8XfnTCIML4WEsWozO5irtKH17UvCpNA1Tgjxs nLBQDOXv/tMMSy03H9x/WnzaDX9mjRk= X-Google-Smtp-Source: APBJJlE49QI+GKjHT7/jwtmKHpb+kXt66N6K7QDVRkzJgeGH+MWu0bF/51TSJcseqrb6U54aALrx+EClwNQ= X-Received: from zagreus.c.googlers.com ([fda3:e722:ac3:cc00:7f:e700:c0a8:5c37]) (user=seanjc job=sendgmr) by 2002:a05:6870:c796:b0:1b0:20bd:eef with SMTP id dy22-20020a056870c79600b001b020bd0eefmr758790oab.2.1689724131216; Tue, 18 Jul 2023 16:48:51 -0700 (PDT) Reply-To: Sean Christopherson Date: Tue, 18 Jul 2023 16:44:53 -0700 In-Reply-To: <20230718234512.1690985-1-seanjc@google.com> Mime-Version: 1.0 References: <20230718234512.1690985-1-seanjc@google.com> X-Mailer: git-send-email 2.41.0.255.g8b1d071c50-goog Message-ID: <20230718234512.1690985-11-seanjc@google.com> Subject: [RFC PATCH v11 10/29] mm: Add AS_UNMOVABLE to mark mapping as completely unmovable From: Sean Christopherson To: Paolo Bonzini , Marc Zyngier , Oliver Upton , Huacai Chen , Michael Ellerman , Anup Patel , Paul Walmsley , Palmer Dabbelt , Albert Ou , Sean Christopherson , "Matthew Wilcox (Oracle)" , Andrew Morton , Paul Moore , James Morris , "Serge E. Hallyn" Cc: kvm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.linux.dev, linux-mips@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, kvm-riscv@lists.infradead.org, linux-riscv@lists.infradead.org, linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-security-module@vger.kernel.org, linux-kernel@vger.kernel.org, Chao Peng , Fuad Tabba , Jarkko Sakkinen , Yu Zhang , Vishal Annapurve , Ackerley Tng , Maciej Szmigiero , Vlastimil Babka , David Hildenbrand , Quentin Perret , Michael Roth , Wang , Liam Merwick , Isaku Yamahata , "Kirill A . Shutemov" X-Rspam-User: X-Stat-Signature: gbpdy8rfzeinogm7nyds4u9s7wtksh1g X-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: 0C1F7180018 X-HE-Tag: 1689724131-824829 X-HE-Meta: U2FsdGVkX19QCX0h/bVTbNfcjRiU4YwoDbJl04g+v8ZrVDboBOtIDGadYrXe2d291QQ+LxFXONpk60lmHKZUDHINBARAXUe+6+8hjj4cBJXfNDyUq/MpRbBVINgYy3JjoLbImFRKxmGNfZ/uLfuFoaHFCMbpGQoRDIRxHc4jdnc6FNA5Eh5yoGr6+LAq08+5Cdj9TbBvzhN8cdTjrwFoLNTgZ9PAEkvLsmof98rMY/XlkYS5Ano2GkdTDZeyzTyAHcnkU283paOHocHxqzh+q+U5O0uxzaUxh8MTypAi4+R5slL0wCjhRYqdQPB1n2w+3eU0IIzC7DZNCli855Za8DwpN+CyyDkSPQmCyrZXoJRQHFOrQZjnM55bF0TnW3XlkINf35YylELbj6Dlm/UJdOvBu5L6sbxN8vnLWhFNltemsYYdQJRljZBJNVAevZmo/dFjMX3QJPQTL32eQZcMv3fpGHPb0TqY9gZhGUIqclr8ZQB6zkLmf7R/oU5lnRte8U6uwkAMJz809WOpqAqgWSplPkiZlKlLuRqSXVtBXVdLv0YJYca7LJFLvvRu8em7EQa9OGJwLx/1m0pC9YL7MnwN7V0FyJpgUnsl88YxLiL40vo+kDjK5rgRZa1r2al2WokqkDvFpuW6yalAHWHcqhlldT5gbyQm7OhbTIelVjB9DsUnYZ6fydRRHMicblEXIEmFANPET2PTYAVVMSuroGnHEBe/nbFOmlH38ZUBX2zeH6YHnBh/Pmp2oxs3m6ZU5J4WJ7mJEm1pr/XgKZU47zyYUhRQDafqTcmXvZrhfrnYFKA8uI7ebb4nj4513C0P1g9IxBvPoy1b000dP4tzROisxGIgDl1YUmmB3z37PVX7uolEWIg5zn7BfZ4DQGQP1kPxl9D2ahBnn5hhkZnIz2K4qkYAMU9TuiSz8EVTB74TlIjHvZzdq+x+hklI0qPzaKB3RYeRVQ2beMM+tMn X2DTceM8 XL0te/m9ZGxpzf2pK4shPeziAHOD2+JFfXTqtlMO4ijvSSxVkXwAZNaB2MydJnA3YvcEIQGC91o6SwPJ0pSglrnlJfXjorh5zI/seWudH+vmpEU3rX5ZtWzfrPheIcvAmReoN8JB8roNY8IfcQtxzqAm5gUs21n3jg2OF1c2Dp/YqCVIPcJnPRIfTCU9WumdJQ6+ibKqRda8oFEBQ5jNdcg8yi9ryIi0jOSviyLqJKETrfzy+Ofqsmb4t0y73SdKNfISN/8ZKJpKJfGwBBybxWHnSKHj4aTbkSm/ZMavbG7NNBrj5PHmVAOcmsrA0zqRIaXvNF5YLBfOthLCx1+Dk8ivyEsP/8WCPIWYs5lnKj60m4PlJfToQ347jDKXODD+a3p8Y4S5CtJYPR82/PBBHTviBN+4TumhvsWFLT2jMcnf9MISbI8dbEhV4ItR+Qpv9+JcTTvLr5OUDkPbPszQRxWNBHzn115tqZZmqxlnm4+A7AulGGOioBXvab7IGB9VNFsd6odB9FCZuv0vi7LGX5zOzksf0kubjxbsQCUdzmcb2FIgq86GXXel9zB5ldquTlBJndyGdJQWeQS4T3wAB1SNeTxbqs1wQrW2zTLWNbcdBz+4Z+52r5zcPf9lbpJ7u/NXGFim/OA4yOK8ZwPSTOek88UVvfUbFU7T/iqytzqEZ3CV3ITTBov+AOyPBlOuNKzImrYx2VrroR/4IEhLdQEJkb2+hIR8jNVk4Q9uqaNpYypKWAM/NGoRF4qBg4T51GeYDdHnd5WZD3y7GDLHhRrSkOnt45Q1eSYZ2KT4/pRtr8Q25xVAQjlW4her5yBoMcbE8 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: Signed-off-by: Sean Christopherson --- include/linux/pagemap.h | 11 +++++++++++ mm/compaction.c | 4 ++++ mm/migrate.c | 2 ++ 3 files changed, 17 insertions(+) diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h index 716953ee1ebd..931d2f1da7d5 100644 --- a/include/linux/pagemap.h +++ b/include/linux/pagemap.h @@ -203,6 +203,7 @@ enum mapping_flags { /* writeback related tags are not used */ AS_NO_WRITEBACK_TAGS = 5, AS_LARGE_FOLIO_SUPPORT = 6, + AS_UNMOVABLE = 7, /* The mapping cannot be moved, ever */ }; /** @@ -273,6 +274,16 @@ static inline int mapping_use_writeback_tags(struct address_space *mapping) return !test_bit(AS_NO_WRITEBACK_TAGS, &mapping->flags); } +static inline void mapping_set_unmovable(struct address_space *mapping) +{ + set_bit(AS_UNMOVABLE, &mapping->flags); +} + +static inline bool mapping_unmovable(struct address_space *mapping) +{ + return test_bit(AS_UNMOVABLE, &mapping->flags); +} + static inline gfp_t mapping_gfp_mask(struct address_space * mapping) { return mapping->gfp_mask; diff --git a/mm/compaction.c b/mm/compaction.c index dbc9f86b1934..a3d2b132df52 100644 --- a/mm/compaction.c +++ b/mm/compaction.c @@ -1047,6 +1047,10 @@ isolate_migratepages_block(struct compact_control *cc, unsigned long low_pfn, if (!mapping && (folio_ref_count(folio) - 1) > folio_mapcount(folio)) goto isolate_fail_put; + /* The mapping truly isn't movable. */ + if (mapping && mapping_unmovable(mapping)) + goto isolate_fail_put; + /* * Only allow to migrate anonymous pages in GFP_NOFS context * because those do not depend on fs locks. diff --git a/mm/migrate.c b/mm/migrate.c index 24baad2571e3..c00a4ca86698 100644 --- a/mm/migrate.c +++ b/mm/migrate.c @@ -954,6 +954,8 @@ static int move_to_new_folio(struct folio *dst, struct folio *src, if (!mapping) rc = migrate_folio(mapping, dst, src, mode); + else if (mapping_unmovable(mapping)) + rc = -EOPNOTSUPP; else if (mapping->a_ops->migrate_folio) /* * Most folios have a mapping and most filesystems