From patchwork Tue Jan 7 03:42:24 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13928085 Received: from NAM11-DM6-obe.outbound.protection.outlook.com (mail-dm6nam11on2068.outbound.protection.outlook.com [40.107.223.68]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 429B41E3DC2 for ; Tue, 7 Jan 2025 03:43:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.223.68 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736221424; cv=fail; b=AZiZdCUfcEMo0QWcVOlzWKu6dpFpoFxC0VlAPkMVBelgEcKYtwtCulIySxdzZbXUJ17sVnmPVzm7zDhWJ1IjCj5/5AYl9/0Udps3z9EO4qyWKoIwDUGX6sqwQagkKye4FaqSu9i0qIAj+ydu0jGLr0sjtDW33oC01Hf/oxwfIaU= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736221424; c=relaxed/simple; bh=gtsNCsuKCwTpoZDokSF2SejDHPLBULeizXRl++MOi9k=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=WOb7Zt7X9JrgFurswmhkGjY2/zS5qppo+SYjJ2R7a7SJTPOvsWAcgSsoXzgdTsw2tSbPYQKLYFAvMgrr4SAIqNsYKl8ayrIqSOH3EYovjKVhsdcK41dnJPtOEbwueP8rF/c9noK3Qspg6RcfWD+r7HZ2YspOyI4WPWemWXdtdRs= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com; spf=fail smtp.mailfrom=nvidia.com; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b=GpQ/dAyd; arc=fail smtp.client-ip=40.107.223.68 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=nvidia.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=nvidia.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com header.b="GpQ/dAyd" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=a8AxxZypybfHCCUGjDjB8MjMNO9RCnMsZk1JiJXJUgu5lFRmYkPcOTvJ92UWTSkVLh3MQOxevhFA6JL4d+JMQElGrhM0Qy7QV+FOEiLJlMBBno1DWPVnL3WFPaEnK+seF+IluQFJ9IFXBMgWDN55qnFJJM6AUR1N1NFG0Z0z6MIzS6vY75c5lkOcWrguPad1fSsGNzQnkQ4uqLQKw04yHKokI/+KodsxLsiBxxCDgrbt7I9gapABrFGeEv8+8WArC2CwrDEBQ7lFbotp2/AyOxJlaWvWfZw0n/cVjRKZ2m81hjz+rVo971fss+iQlNEIJv2JaJ4ZQDLphH8cUolhRg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=4H9hB2g8rzafAqa/zeAsIl2dT4+WYKiRfFC4nbvu/P4=; b=o+qjNUTJz0KyVxa44HqnDuZqDarLQZGGaITAkc33ykiZCIpSOemKm9MV4zVmHYoX3BH9WduW3//vD8REuQuO+nZBlWmv9ohj1tAys2JHg+4TbSoAbrZKNG3f9KGshEi0dMp2QyH1zpZ40Qbc7AYByaRSVLYs4I69J+1jMbQ3PZorbSSEFVQ8XY4zLY1zBSO7rGyqSy02mD7UpRn3/SGtsqEXEk1ts4rla3ZaN9miWAV/tLk7VfWJHJnlO6utPBymCNq22yUNshlbzQlBwz4hP6AdoEiMUTi/WjimIF6PJ2NqsE3cqM6tdFIfSFKHeXp1z7V7Fu7YR5NdPSXrohPZBA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nvidia.com; dmarc=pass action=none header.from=nvidia.com; dkim=pass header.d=nvidia.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=4H9hB2g8rzafAqa/zeAsIl2dT4+WYKiRfFC4nbvu/P4=; b=GpQ/dAydlZ7Bsryp7lISom0x7gHkqLcTk46yIgi0oGX7SX73nk4yDFG9/lANrutUR/m2Z5+BeL74lZHKHDs4PEhr8oR35LIgCoh8bmn0y60CKrgB/jntVZqyMAvFLsj39UKLk6pO8wlsBT9qz84Vq6QxuoyB/Khkuc9PfP+tdQ3qbfImG9dOoOsX7+/VlMS7EnTPnIv6bMjzXYVMTb4HcEE5aUXHMGtoAHvR+LMwVKyobCtns8aINFXGfEuLjn9Q3EftyA2EC3J23VsWfo6FUN+bBbvLTLaDlbHgkg1cZ4phJBpCzDZh7pckcwAv2iR4vQqH1SPTyxgtyJSYic2Rjg== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nvidia.com; Received: from DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) by CY5PR12MB6129.namprd12.prod.outlook.com (2603:10b6:930:27::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8314.15; Tue, 7 Jan 2025 03:43:35 +0000 Received: from DS0PR12MB7726.namprd12.prod.outlook.com ([fe80::953f:2f80:90c5:67fe]) by DS0PR12MB7726.namprd12.prod.outlook.com ([fe80::953f:2f80:90c5:67fe%6]) with mapi id 15.20.8314.015; Tue, 7 Jan 2025 03:43:35 +0000 From: Alistair Popple To: akpm@linux-foundation.org, dan.j.williams@intel.com, linux-mm@kvack.org Cc: Alistair Popple , lina@asahilina.net, zhang.lyra@gmail.com, gerald.schaefer@linux.ibm.com, vishal.l.verma@intel.com, dave.jiang@intel.com, logang@deltatee.com, bhelgaas@google.com, jack@suse.cz, jgg@ziepe.ca, catalin.marinas@arm.com, will@kernel.org, mpe@ellerman.id.au, npiggin@gmail.com, dave.hansen@linux.intel.com, ira.weiny@intel.com, willy@infradead.org, djwong@kernel.org, tytso@mit.edu, linmiaohe@huawei.com, david@redhat.com, peterx@redhat.com, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linuxppc-dev@lists.ozlabs.org, nvdimm@lists.linux.dev, linux-cxl@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, jhubbard@nvidia.com, hch@lst.de, david@fromorbit.com Subject: [PATCH v5 08/25] fs/dax: Remove PAGE_MAPPING_DAX_SHARED mapping flag Date: Tue, 7 Jan 2025 14:42:24 +1100 Message-ID: <792742e7339dcc088fcbfb0daa9b5ab82534f557.1736221254.git-series.apopple@nvidia.com> X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SY5PR01CA0095.ausprd01.prod.outlook.com (2603:10c6:10:207::20) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) Precedence: bulk X-Mailing-List: nvdimm@lists.linux.dev List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|CY5PR12MB6129:EE_ X-MS-Office365-Filtering-Correlation-Id: 74e47718-51f1-4b81-6796-08dd2ecd76b1 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|7416014|376014|1800799024|366016; X-Microsoft-Antispam-Message-Info: WKItfRxEt/toDpqO/+Qjjea9ZBFya9zkqOl5TMbY3qKCkALgjV7VlLE35NKU3LOC+I8gwU7XMgFfgwNcAbX44Izk2Iop34gWJc4DKvFO8oRcV6o0gUKcOHvZFCeoln9X13V3gjytEADL+ntGH2hfEu8elNkQa6D/u9/b62/XZZ7ufoiuOsz64QIGmNNLqkgMPazMbUYF0rrnKYUROJ+wAKKp6FzAJ6NFgvdpkZaiQHEwv6OOWLpqr+DP5Ppw6S3fZ1rp0W+o7TgkVCwUi8tyq2SkvHKNi2g9u/81m+RQ1zp7Z76PkzR1eDicb6i4nUFSgKiXPKo1XhTxkfYCPL+dDqHPW3lnHzDNGnthHxoR6P6dCpGnfoHIbMzVxA+gviaxrPHP2Kz8mY5UHJgYZSpb7j6mxrCXoJAfYwAcCmnS4/BAdJJemz6H/bkDG8rN6CMOb6Mw6CY4Dp2tJ/9um5X03aBfsTPEmlJj36yzqoKtkzwEj+ywSn+10uGhyAwXzRPqIOKzGFLV215jaUETzIt89u7/lQWpf2SMR64S3bPShBKOkiEc545oUguvd5rkaiyLVZHLmTePBAYsI5tGH75F91i/u+RhvrTgxPKcYiNjBrWjdlc72gLvwJySIdZD3+/n+KKugqPm09Ze0o7duoRZ4waIXbU8XV6tACEW2zTABmFLlWOqsQujCP0ehSVW5VmVD2CFjbMFv40+rpeDuHkCRIUhA0Qp8kRBiyZHxrEJmqkL1/5b5CjOP2IgHOFmhNb621vOWACwwPYK3bQQlKyYxpu+02rGTrkDp9ILkTqfjxxVleSyPxp1VYXHqggHctPptInQx1ogZ8KoVfpnkppEZLJYnCC2mMfIIQI+oNVtEeIMbOsJh8am6IYwR5IGgHxvUT5tJwwpVHcGkoeI0eJHgEU+DefWeRTKIjyEKbWkmTsgvigMpFrPH5iE9EPH1cclZEArbgTjVHYSzlu0LwFSeSYkjSqmcqPjTLaYyc0XAZ527y29kn+hzUyqg98BOXgs9RaQm0SFA9rDL+QQFuXz5Z17PePGAoDWfvTTPw5kOzMZmYHW5AgkBwaxSQBNzexXT05E6LswvInpThlN5SWEj4CmRC8PJML6of761C95KZ7Dz0Rqy2PJBdqAHkk4vMoFF0TpW00Q3GEZSmuiZBv5FQHMR5olU6qq1E73pxgyrQaPvs0r5ZFmx3hrm2BKP5xmDop/UkX1GlJ0L2taqIPkMwHrIxVyLGxi2droD/Qa7fF4CErDakdPy0WGtgslyogx0ViqBRsZq6zvVnOpX1u00Do8s89vhC6Q6K15XGOITggRcz4ovubD2Eyi1nWyK8J00t/RYE72O2udPw2z9qUDd415LMfuWllQWqlMwBXdTTx4/kzYCEOKHcSpoNffawhG X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:DS0PR12MB7726.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(7416014)(376014)(1800799024)(366016);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: wS5eVbgCVOdwzm5acXMaTunX4r9yohCpZIDEg3Gtzo49ZzcAnXv1dCgvXgcvKdvlqcVx7RmhZwsQAd2GIvGi5l2qYKngNqdsu2vve3a7j5eB3qe5LyLwSimkhzUCa0v0fPHm95gfH12G3f9kchV8i0dmmgkCbZwCildDoEecQPAt3TEk2u6vZkXqO4Ff3FBe63+NTR67oomLf8RldJdnqcPsKT/0TDKtbD9OJ1qpeDLvuiveP7cMsniKtBGD5xf6ddZ2nvwWZ5vRYA4c2fn9ONFrMQ/LylzHe+zC3kvmAjG/GlVOhyFr746tCDX2q/hUOoQDp9t5Tk7Hi/MovxCRgsxwnBALqNzAcptVyrIJSWIRnbYimcM+yN9wyVSl1cuXKx9T1bsude7vqAnDqNMIJlp9k6tFouQN78IQREXSlY3M2I5qugnlqiGIhNYhq13yJvhSRYL0QOpHSBmUsgUKwHFEMzENFlUHi2O6htgzY+K7l7QEiCYBJbGrIHOLlIDPNEHT3O1xIM3TdRYM1dBr20cgpMpOGMjudRK5X63/7ZOXtvM7fgvJx+GykcPl8E6KqCTTy6lJ02dDnVBGm61XsBeo7yTinb9Vzy0p2NNIZbTzqWqnbvNWX3waSM8dUE9cJNVGC0KKl0w3xMgejM5osTfX6A1iTfMdODN2ZRJPa/dMy/0XNW/1u+e+wO7OLj1i3RPD+mClkXG1YMZXIbVGN/UJ0oerL/7Cdjgowhz7LEh+NQekLmqmeTHRZevqhAZcKsw7B1ihdA7/yS4XKMguf+3buzJ2nXfUVCsZYUYMt3a/rE3p1AN4JJLdwDqx9363mO9mnHsYcb3qi80aRUwDzndtdRJJnYjB9BPpr+nbP6w0W/dgkuh5uNai9u3+Bxk7U59P9ZSgSeAd5qlXHAQ7lmtY97dTz2WzvUz1W/pYLxo2Qbz6T7iFRuRKEsBPuFZyrPGeAviwVNwp2eqCUWZC+uQbqjZc06VU2jOUVtoo8ftTxcop3NMYGCxOlD2YGpUVZQdPO1HNtK/xrawqLDqJJq7s8M9hhucigFVWgxMXfYamdS7dHnmaXJ4gyiZG8V6z0mqm9KzTrgHJSctSZbntWom5yDbSYdEpCprypO3bwOWdTNREuvcyk1NgI7AI6BiLJVRoTTH4Z9eO0wGGPoKQ1VekXc6qxdn+U7qQfB3mEcjZb9bCQE9Adv/dr23p79uaVYPVb10P8bUZf187sBZKnWHlXyZO7XcbKVOXtX1yMO196iSaBVh9tiK6blsuxVgwqdWt+PEgGWN7QGzRSn01vL4ezn6s48PvO757efle2+gAJAoOKTQwh88uAB1d1ArAbml2ogLnPKT42W+NfTyO/riQ4TorfHozRVpwf/KMgLBjrjcLVK+HlL3XVM3CY99ldm1TjFqUzBtlS6VEtevm2koUhNh9VBPvak6LLiVGZJrROBrMw7fH+kC9qYkPBeDl3FSlMgKO3r8/l6rtzW4TDOqsgjwoEkSMgFRlnnJkWWhdMxBpi+VCgjqhwAapAHSWStC8IniQ2+zd6enHgGRoay6C5zFlHxZ1xHahQX5/CaJ3dLYT6UPhMXPDsNSiSqoI X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: 74e47718-51f1-4b81-6796-08dd2ecd76b1 X-MS-Exchange-CrossTenant-AuthSource: DS0PR12MB7726.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 07 Jan 2025 03:43:35.4322 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: HumOWgPUHYMO5EKsNxc5uSwrUicz7ObR2t9cST9BtkDd3oT/CIVMzWJKIkkHjRwxxnh4A73HyxdCas/N5SIp/Q== X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY5PR12MB6129 PAGE_MAPPING_DAX_SHARED is the same as PAGE_MAPPING_ANON. This isn't currently a problem because FS DAX pages are treated specially. However a future change will make FS DAX pages more like normal pages, so folio_test_anon() must not return true for a FS DAX page. We could explicitly test for a FS DAX page in folio_test_anon(), etc. however the PAGE_MAPPING_DAX_SHARED flag isn't actually needed. Instead we can use the page->mapping field to implicitly track the first mapping of a page. If page->mapping is non-NULL it implies the page is associated with a single mapping at page->index. If the page is associated with a second mapping clear page->mapping and set page->share to 1. This is possible because a shared mapping implies the file-system implements dax_holder_operations which makes the ->mapping and ->index, which is a union with ->share, unused. The page is considered shared when page->mapping == NULL and page->share > 0 or page->mapping != NULL, implying it is present in at least one address space. This also makes it easier for a future change to detect when a page is first mapped into an address space which requires special handling. Signed-off-by: Alistair Popple --- fs/dax.c | 45 +++++++++++++++++++++++++-------------- include/linux/page-flags.h | 6 +----- 2 files changed, 29 insertions(+), 22 deletions(-) diff --git a/fs/dax.c b/fs/dax.c index 4e49cc4..3346658 100644 --- a/fs/dax.c +++ b/fs/dax.c @@ -351,38 +351,41 @@ static unsigned long dax_end_pfn(void *entry) for (pfn = dax_to_pfn(entry); \ pfn < dax_end_pfn(entry); pfn++) +/* + * A DAX page is considered shared if it has no mapping set and ->share (which + * shares the ->index field) is non-zero. Note this may return false even if the + * page if shared between multiple files but has not yet actually been mapped + * into multiple address spaces. + */ static inline bool dax_page_is_shared(struct page *page) { - return page->mapping == PAGE_MAPPING_DAX_SHARED; + return !page->mapping && page->share; } /* - * Set the page->mapping with PAGE_MAPPING_DAX_SHARED flag, increase the - * refcount. + * Increase the page share refcount, warning if the page is not marked as shared. */ static inline void dax_page_share_get(struct page *page) { - if (page->mapping != PAGE_MAPPING_DAX_SHARED) { - /* - * Reset the index if the page was already mapped - * regularly before. - */ - if (page->mapping) - page->share = 1; - page->mapping = PAGE_MAPPING_DAX_SHARED; - } + WARN_ON_ONCE(!page->share); + WARN_ON_ONCE(page->mapping); page->share++; } static inline unsigned long dax_page_share_put(struct page *page) { + WARN_ON_ONCE(!page->share); return --page->share; } /* - * When it is called in dax_insert_entry(), the shared flag will indicate that - * whether this entry is shared by multiple files. If so, set the page->mapping - * PAGE_MAPPING_DAX_SHARED, and use page->share as refcount. + * When it is called in dax_insert_entry(), the shared flag will indicate + * whether this entry is shared by multiple files. If the page has not + * previously been associated with any mappings the ->mapping and ->index + * fields will be set. If it has already been associated with a mapping + * the mapping will be cleared and the share count set. It's then up the + * file-system to track which mappings contain which pages, ie. by implementing + * dax_holder_operations. */ static void dax_associate_entry(void *entry, struct address_space *mapping, struct vm_area_struct *vma, unsigned long address, bool shared) @@ -397,7 +400,17 @@ static void dax_associate_entry(void *entry, struct address_space *mapping, for_each_mapped_pfn(entry, pfn) { struct page *page = pfn_to_page(pfn); - if (shared) { + if (shared && page->mapping && page->share) { + if (page->mapping) { + page->mapping = NULL; + + /* + * Page has already been mapped into one address + * space so set the share count. + */ + page->share = 1; + } + dax_page_share_get(page); } else { WARN_ON_ONCE(page->mapping); diff --git a/include/linux/page-flags.h b/include/linux/page-flags.h index 691506b..598334e 100644 --- a/include/linux/page-flags.h +++ b/include/linux/page-flags.h @@ -668,12 +668,6 @@ PAGEFLAG_FALSE(VmemmapSelfHosted, vmemmap_self_hosted) #define PAGE_MAPPING_KSM (PAGE_MAPPING_ANON | PAGE_MAPPING_MOVABLE) #define PAGE_MAPPING_FLAGS (PAGE_MAPPING_ANON | PAGE_MAPPING_MOVABLE) -/* - * Different with flags above, this flag is used only for fsdax mode. It - * indicates that this page->mapping is now under reflink case. - */ -#define PAGE_MAPPING_DAX_SHARED ((void *)0x1) - static __always_inline bool folio_mapping_flags(const struct folio *folio) { return ((unsigned long)folio->mapping & PAGE_MAPPING_FLAGS) != 0;