From patchwork Tue Jan 7 03:42:30 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13928143 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 CDA50E77197 for ; Tue, 7 Jan 2025 03:45:23 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 6226D6B00B5; Mon, 6 Jan 2025 22:45:23 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 5D1E36B00B6; Mon, 6 Jan 2025 22:45:23 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3D61E6B00B7; Mon, 6 Jan 2025 22:45:23 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0017.hostedemail.com [216.40.44.17]) by kanga.kvack.org (Postfix) with ESMTP id 143386B00B5 for ; Mon, 6 Jan 2025 22:45:23 -0500 (EST) Received: from smtpin12.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id C06101C6E97 for ; Tue, 7 Jan 2025 03:45:22 +0000 (UTC) X-FDA: 82979265684.12.01C4084 Received: from NAM11-CO1-obe.outbound.protection.outlook.com (mail-co1nam11on2069.outbound.protection.outlook.com [40.107.220.69]) by imf19.hostedemail.com (Postfix) with ESMTP id EAC701A0017 for ; Tue, 7 Jan 2025 03:45:19 +0000 (UTC) Authentication-Results: imf19.hostedemail.com; dkim=pass header.d=Nvidia.com header.s=selector2 header.b=eLOxUWns; spf=pass (imf19.hostedemail.com: domain of apopple@nvidia.com designates 40.107.220.69 as permitted sender) smtp.mailfrom=apopple@nvidia.com; dmarc=pass (policy=reject) header.from=nvidia.com; arc=pass ("microsoft.com:s=arcselector10001:i=1") ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1736221520; h=from:from:sender: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:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=rXlKVA4UNAS6jz/FYVqiQsIbN6kjrNS3U8oMzkTS/a4=; b=4hTaFDe0HUkhzCJAjsf0laLYkV9mTKCZlkKkSUg+W8HaO0ADHULAMMT9z3Ekke3lM/NNYu WcTqudHI3wwgsgHvJVFjMqQVceCSiZ24iMAiVJyrPkDuRjk5HTq4uC9LzNVZqXiIL8k3FH e7SiC2NxW+XIBVj9MXxHcJIKRBDcfOY= ARC-Seal: i=2; s=arc-20220608; d=hostedemail.com; t=1736221520; a=rsa-sha256; cv=pass; b=VuYHUb0YVzrzieyWHeYQ9yL1B/Q+eQQR15IbRVHxdTgmlsiOGwCFPMhi0SgAeJ8vBfH36R bZGzY2VUvY6a5vJkFHAWmdzHfo0aoHzj2G/kkglgH7BJjSxsUMjZxslaQ4RkIxyh5bxcDc /RSnY1npl9iJdjdu1WmQNZkLafKs6Kc= ARC-Authentication-Results: i=2; imf19.hostedemail.com; dkim=pass header.d=Nvidia.com header.s=selector2 header.b=eLOxUWns; spf=pass (imf19.hostedemail.com: domain of apopple@nvidia.com designates 40.107.220.69 as permitted sender) smtp.mailfrom=apopple@nvidia.com; dmarc=pass (policy=reject) header.from=nvidia.com; arc=pass ("microsoft.com:s=arcselector10001:i=1") ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=BheF+p5rY9Uy1caatuW5UIEu0Z0+OxBSYHac0TPFhD8igs+mbPGlE27cYacIJDPq5hDTS4uJA9Pmu6uDx9SdC23n/n1VwLukk0ROM1VpWZCPLhR7B+2pcEUf+ASctNDep4VmeqZOYWTRCkopCOUrj2UpIH5VZfCBieSxJr50fh9oV72wQWOAUpBYUUB1R4ZEuMbJFTwaWO3SuT3+CS6qjc4c/NRJFqTNQD+q6qfqhizu5wpdAha6DwWLgbNZPUpwdNThZK0YdogdltTbFZdvdesKswOS0MycPbDyqupJlxq8qrNVltqyZoDRWRUcLeof9ucPbm0B/p+MT29I4/axZg== 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=rXlKVA4UNAS6jz/FYVqiQsIbN6kjrNS3U8oMzkTS/a4=; b=xzeRU1E9VsMPSod2CXfx6NzI3xu37Zfxm/FEUtdcUkAkcb1RcOVtNyKoEXzn6nU54wKQDuEtquk2VgsvrwoReMw96C2PwFupKZvgYYPs8ZE1FfFvc/E2Ht80eEnmx5aFPt8B7/T4cIFbxWWrXmi7FqHVRevb+/VP4//BQ9uz1b/hpKhb3MaHNaCeh6Gw6n+cAmEMyyEF6T3pkMCArA68X05V8+EvZiH5dHgh19KcrY0o7yPAg/JN0XRc5uahMU7BhUJFBlaG279nFbTt+Kr/8PQwtRJ4cveY8+xyjMCHQygPxwnmjH5luAu8zO65NxMIT9h6BbMi05eCNH33QNnZTQ== 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=rXlKVA4UNAS6jz/FYVqiQsIbN6kjrNS3U8oMzkTS/a4=; b=eLOxUWns7IIqcskCfzJEhBveQQUm8UBwxv/udxDghupc4kZ49YwGqwDgf1NN5q0fxSHE81of2uAoqmHkyi3rUSM1jMnDpWOx+mHYYB6H9iZMW2PG9MoC93w3d7cogN/lAcVY2VC1yI4alZydbXBUjAnDrGbkpzMj0gCG5Ls+g2f67bu28xF/1rNCLrK1rXyDMkYEOIrsoL5ZEd+XfTQ00xa55QEDJd4HKnBvvnhw578so3AhOloAa2fLGURalJQXfLt9HUw01Do1bWu5nDrwZGxScRZEI6+cObRr82ZzcLay8fIInrueCDcStGRFHUO8O7Qxt674Vyi3fWmGF9IzmA== 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:44:02 +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:44:02 +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 14/25] rmap: Add support for PUD sized mappings to rmap Date: Tue, 7 Jan 2025 14:42:30 +1100 Message-ID: <8830827577fec4c6c2a0135e338723a5b532a2ee.1736221254.git-series.apopple@nvidia.com> X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SY6PR01CA0141.ausprd01.prod.outlook.com (2603:10c6:10:1b9::19) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|CY5PR12MB6129:EE_ X-MS-Office365-Filtering-Correlation-Id: ddfaeeb1-0c05-4c75-fb1f-08dd2ecd869a 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: EBVqDZIWexmsgwnO/0LmdNnwDJer48d0TZugSt3bcE/NzqfklBhHr3/oybEouurf5mQ9gczU3c5Ez9wT4lJ9ZPi8fHVE9clPLBhBYRW7+qiT2ZoVUe9co8B7MkzcMuA6BnrbN+ZjQhpw+WQxifmiFn2X1e1XirxX+qhGBbsZtYawYXtAyr+9x3daHOBWPxd/1IR2Z9GRsP+B4vQTHSajGjTRXCT/nj1NYNXQ1X4rljQGYzh2jvXso+vKczj/Yg40YNrifZrKDqeQCC9ThUPwdjJZXQjsj44kzr+cri8RG3yYsdMJ551LsbAmSqnPyh+2NdDHzk5faZoZx9wbbyuulj3YkZ7s6ojU2U36aM3k86m2c+HI/mv9J6QLu6Fm8yGgOC8y6uZtEu7bfuIlcI/vZPWPhQgfspAQNPl9+IgO6kQV9cXdn/HErkl7d9/ChXFxpIYr9s0drlL4mWurN6ZgBgRfxhwWwYHqELTb9u1m67in/t7tG0/s7jKXJcx28WDlMedSJ3ZRV4Qi+8uAxln3jUmg/1xMe/HLJHljJsSAaX+uGIt7+y5DSfAJOBvyDc7akVx/rT7+xHf/DnxqiI9h4c7K5QSg9wI93jPjdSZmrw21UeU9frbJusaffmV8DCYWKvJgZC2PJSoS5DplseEZaAgn5fgZaFK114rWdMSyz+uGTNfd5QoUEQwM3uTsCZrMTt/gF7Wn28Ge97aiJIRtHD/Lwdi9ibKNxFYRAjr5Y12edGUo1L7BekuiYydcYq5HDWvgLdXDg1TjVXlmTZpqQf2a3x28kIr6XNz7WXjWyDlpSZ3vLnsPb7vJfXqL9lo40Dl9QEXsd7yuyx1uwky3oS7a14QMnJ9aGKKHVaRu55HgVPln+x9slg9mVJ9AlqVhfjtbNBIF8ziKVIMVLrZsWyrKf7CYAmP9tTgtqTERKphJSztRIWNxKWX0TZykiPpPDzZRXrjc08L+mpGlpMOza32irNroOvjC9PIQ11pR4Y1YJGjmvKU1mDG+QX8SckbGRCL84AQDMVtH2SaMW9e5qStd7Be9YA7aQ++D6DO04vo9V6m7Pgg4eVZGOB7R+5uWPVL1W9hHctLt2EmvjX1EmPdCqdonCAyn5V2AyPBE3j45tx8VD21H2syPRKDQr0zpwRiUcmnnD42Mn80jUcb+JfQYltJ98lBkiHC1G1r2Xqm83gIIYd1kf/YNgKzg0XyRgsvfdI1XwUSuuNHYhsMXb20Txpp9Vt6Wk/EabKSI+UFB8J1Y6QKVfQlLnmTB+xEAGFOiNlClIhtMYLs6k38MSXUyZv7m4xtMDDtXHx8EdbJ2YWCJlOVlP2Tt6quk9UvgbkLfjYYgJcVu5Z5a/RkVlfTw92nwTv8gGDidM8/6uPqcprFRTfkLY2Ss5l4+bl3s 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: XTDa4xkd3PSNoom+fDhSZ6W7jKK+uo2HTBsWz7tJ/nBewvJchICVWT2TGnZNx1m2790y+cK615Z3D2iwryFSFG2qHKng2OHSj0MuGanAiLm1ts36vqAH9JC3wVLsKkTm6znLlqeI/DjK2i1PJKgExqs7WyY1o2wm1mVgI1Kc6hz46O9kJUV6U9ip7kscv9/A4svqDyDaUyykdZdywGlerS5tSmBMzKNrc1vvsXK4FeF80Ng1B7knENsZyGfTUquGEb8f1YhxPMdKkjbHPVNifV036n1+GCTYzNUm48pqcGpgKMVOJhIEobSbx1RrxPtIbm6AdEpHHfjFYbtnvHNFLJEam0rjdW5XQnH/Q+mMqb7xGONSDs2WLuEAIXCvBGeCOIrjZWTsGL4FWYbD4YRVsv5UJ9KrNXVXBZ8uaoEQaqUCordWA4qYa4t3MUxqOlsv2mKyEwsvo/i2TEm2JU7ZebSqC8014AiKSnE3iDz8/WNDYCyhx0fybDYOlmUNQQIkH2JoIbybGMXKVK/1xBa97rYvgRq6HHnuLaro1/lLw17e7bn73g2qBmVEgssjF5VA2Z7GbhBF4pNzAlxhQ1mKj9uvIjjcAkG6PZquYVehvUa+LjeC+ud+yi4JoYlPdOH8oro+jGO1s9823T1L4HH6JVp8OSNZA12qOF0msUtsVj7QCULLAVZ/EA9Dv1+MyveNJcnCFT8VTuDk+8NWu40/bYcpRy+5MhW43BgRupoOJjS8+MfFzJucK/AIX9Ti/PwXmB8D5dfjRZFIyhH+WoGsIlr1KZCez8gHR+ZNtQOhmjOogFPyZbx/WvvSUpg2jqafa9gTyzj6p312vHcIUBwoL0atOZouTwSCNgNmSV7PvK/sB/0Y/3QKZSet2PYovb6HFhWsitoC2fPFRPqAy3Wv/S1pCZSN3GZ2PKwPnp4O05962EgREpmoJIshVsbE8UsaJvu21bp6fQu5C1eHZGzFkcAY8LA+f/58l1UqK/o+VQkRQ+u6Sme2T2E4ldGXwoyscvxtWKZ2qf707URblICX4hnNTnt2lHpW+xWEYbB9WJOPl5OV93wWxQi0QIPflzMS43Sy2B7KzgFspJpcDO0I+mSG6w2vnhS2In6pew4L6cZ/aeMd5PSv/ARci7eRDe3exTptObBFaHXep63xCOFXvy1NdhW0KXaGSYjPEvYrtH+c61mvSKDwzYo3eFA1PPDD1Q9ukGlvOaq5TxGc8bOJSsxnhC2fr6Ak+4iQSzw4KCiWYfXmprN/yxs+mVEnyoi+38zVIC7Nc7qYy7FfPFTfvJ+bzAm1h/+bVkczeoYss4J2jDdTAXbXcUr0yuZkyG1hFsO3YOLKdn2+g3Q6GN2yX5fqD3x0mJolKi3MaKT/Fpsq9OsuI3/FuARhXGRVR0j2/lnRpaDNxWZgF/8/ur2ZsD48dhG5CQOrDsRUVu9dZMlpFMWNs9EbioM8HWcHH0D/gp6Tmljf5b1V2tjSQqWHKrSSTYcEYEDFPzFp2GB90d16faCbt3YoObtSIIlsTlfaoi0ih6QD/AQnpCUI5T0ezwxGApib22yGFVGkgrZVMrLaDFwM9T9DtgUwotj2JJ6d X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: ddfaeeb1-0c05-4c75-fb1f-08dd2ecd869a 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:44:02.1306 (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: xQ/l8VTxwG1IBft2XAQ2vlGtRPHkc55A01S7qGijRRqQZv77Re3PLXKRjml2FEBwvQZIhjT4ZLafc5ZAN+aNGA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY5PR12MB6129 X-Rspamd-Server: rspam10 X-Rspamd-Queue-Id: EAC701A0017 X-Stat-Signature: je9m4x65d6nnepioxz56dg5eh33hz5pd X-Rspam-User: X-HE-Tag: 1736221519-746489 X-HE-Meta: U2FsdGVkX1+5DWT3J8dPMI7+p1OTJEJ15oEKbInfJl5iUcs26HhGfh57F95uHshLp6yzEI9lu4gffseo1b5tdq1WHP+1B3LvmUwPy2pUw91Jaes/8Yb7IBTatzdg+O++xjekdtmDzERqw91wnoUsJ5WFp50U//pAStAHRxiuDhXyTWm9OJyUVVoXfGFX/hSWuSmYPw7BAPgSTWdoPB8xpCAlbc/zY64HD4fwRlaRnQaOMkOT3A8QVZwRvuZFfId7wIMnrRSykNCuAWgY0Ql47qdaH8fYbOzU9hnm9tax9Hth/5lXGfVs+hopws3r3j0ellrpQ9rlSaXfwchNNsiXAlVCWFeaqGggf6508V0wzRRpApE1C9kMXqpzCaR80gCSK32NZp/47e92mYzgYiKXfQNXaPClPAEjlBhCtx6rKrspbkx58lmX0soT4+85BRbW7tfIMZNNm6tX19XlexxsFeRSsJgcm776iH+y04D9i352ZKHLfIUrPFryKFn6boqwuGG9Oav85UPBAZr0pC3fmKAN6DVcpz+3gqd6wXzw0TgDmntuqPmwoMXN2kYEjRKA5LXi9O5TkhzFk3lYHH2GZyAmaZ7+hGB37TjkKZV+wFE4MmqQTjgzksrPAXB9b7LgRrFVkcalOADb5NoDbeW65LrbWa0z6oP+tfDyTxfbj+K4gdyikkd8har6cMN7BHl7UW4Q5Gmv6VI105HFhg5dOdbN67Ql9RNgOigZOWyLpLnuNdCvOnweALZIsJ1uNcvMOUGD0vdEKfOCVYbPat6qQVWfTb8EFOGJG9LpCNofxq46TaGwylYfZKCxNp7UufTWUZodB+qJffuBkvHKee6u9nCO091mkhUx153L0MGGvjy6Gqw1epfHL3DqOSi8pMFZOKvbQpfCUaBuSUxI5iPA8UxLH2ZOJ5HCZwLDHHTcrYgwYlEEJFbOBcEAsp+tBtV/64LKCUjJewWIYd0iyLT SSNjrIEh +lQbeSjLAq98na9xh2N1S2idQ/jDHvUitVNj1/fXtVp/qLv7dlXwP6Ovs0F/VSnjpm5JS9+xaH5/F8PIYuPHIWzs0b0aJqDzZW0EgHGLTgcucoW1suxDGRQZ79hMhQ/zvqIjA0WvbLAqY5dQ4IeLv0JwxfXAlAtxmNnwxaexkPnIDxC0/EQmkaaBGpVnnt3wxssgabBsu5Ah0gQNnvRAI9h2UH7GugKpW2jwSGke/giv8OBww8eGDRDBob4sGqLLDWs7JMijdLh53TcujvkNyvY5zEhZErdOBdUJcVtH5vY9LJPVT7sWSw1NFml967wchBnZ4gA6RhwweHwdRecrxhXhH/Rkiz0x0L3f//Kb6DI56LcXZNVqOfNlYdAGkhjmfoHjieZ31TFFmbuIpGbojaqULYcKE5yNxTOlF 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: List-Subscribe: List-Unsubscribe: The rmap doesn't currently support adding a PUD mapping of a folio. This patch adds support for entire PUD mappings of folios, primarily to allow for more standard refcounting of device DAX folios. Currently DAX is the only user of this and it doesn't require support for partially mapped PUD-sized folios so we don't support for that for now. Signed-off-by: Alistair Popple Acked-by: David Hildenbrand --- Changes for v5: - Fixed accounting as suggested by David. Changes for v4: - New for v4, split out rmap changes as suggested by David. --- include/linux/rmap.h | 15 ++++++++++- mm/rmap.c | 65 ++++++++++++++++++++++++++++++++++++++++++--- 2 files changed, 76 insertions(+), 4 deletions(-) diff --git a/include/linux/rmap.h b/include/linux/rmap.h index 683a040..7043914 100644 --- a/include/linux/rmap.h +++ b/include/linux/rmap.h @@ -192,6 +192,7 @@ typedef int __bitwise rmap_t; enum rmap_level { RMAP_LEVEL_PTE = 0, RMAP_LEVEL_PMD, + RMAP_LEVEL_PUD, }; static inline void __folio_rmap_sanity_checks(const struct folio *folio, @@ -228,6 +229,14 @@ static inline void __folio_rmap_sanity_checks(const struct folio *folio, VM_WARN_ON_FOLIO(folio_nr_pages(folio) != HPAGE_PMD_NR, folio); VM_WARN_ON_FOLIO(nr_pages != HPAGE_PMD_NR, folio); break; + case RMAP_LEVEL_PUD: + /* + * Assume that we are creating * a single "entire" mapping of the + * folio. + */ + VM_WARN_ON_FOLIO(folio_nr_pages(folio) != HPAGE_PUD_NR, folio); + VM_WARN_ON_FOLIO(nr_pages != HPAGE_PUD_NR, folio); + break; default: VM_WARN_ON_ONCE(true); } @@ -251,12 +260,16 @@ void folio_add_file_rmap_ptes(struct folio *, struct page *, int nr_pages, folio_add_file_rmap_ptes(folio, page, 1, vma) void folio_add_file_rmap_pmd(struct folio *, struct page *, struct vm_area_struct *); +void folio_add_file_rmap_pud(struct folio *, struct page *, + struct vm_area_struct *); void folio_remove_rmap_ptes(struct folio *, struct page *, int nr_pages, struct vm_area_struct *); #define folio_remove_rmap_pte(folio, page, vma) \ folio_remove_rmap_ptes(folio, page, 1, vma) void folio_remove_rmap_pmd(struct folio *, struct page *, struct vm_area_struct *); +void folio_remove_rmap_pud(struct folio *, struct page *, + struct vm_area_struct *); void hugetlb_add_anon_rmap(struct folio *, struct vm_area_struct *, unsigned long address, rmap_t flags); @@ -341,6 +354,7 @@ static __always_inline void __folio_dup_file_rmap(struct folio *folio, atomic_add(orig_nr_pages, &folio->_large_mapcount); break; case RMAP_LEVEL_PMD: + case RMAP_LEVEL_PUD: atomic_inc(&folio->_entire_mapcount); atomic_inc(&folio->_large_mapcount); break; @@ -437,6 +451,7 @@ static __always_inline int __folio_try_dup_anon_rmap(struct folio *folio, atomic_add(orig_nr_pages, &folio->_large_mapcount); break; case RMAP_LEVEL_PMD: + case RMAP_LEVEL_PUD: if (PageAnonExclusive(page)) { if (unlikely(maybe_pinned)) return -EBUSY; diff --git a/mm/rmap.c b/mm/rmap.c index c6c4d4e..227c60e 100644 --- a/mm/rmap.c +++ b/mm/rmap.c @@ -1187,12 +1187,19 @@ static __always_inline unsigned int __folio_add_rmap(struct folio *folio, atomic_add(orig_nr_pages, &folio->_large_mapcount); break; case RMAP_LEVEL_PMD: + case RMAP_LEVEL_PUD: first = atomic_inc_and_test(&folio->_entire_mapcount); if (first) { nr = atomic_add_return_relaxed(ENTIRELY_MAPPED, mapped); if (likely(nr < ENTIRELY_MAPPED + ENTIRELY_MAPPED)) { - *nr_pmdmapped = folio_nr_pages(folio); - nr = *nr_pmdmapped - (nr & FOLIO_PAGES_MAPPED); + nr_pages = folio_nr_pages(folio); + /* + * We only track PMD mappings of PMD-sized + * folios separately. + */ + if (level == RMAP_LEVEL_PMD) + *nr_pmdmapped = nr_pages; + nr = nr_pages - (nr & FOLIO_PAGES_MAPPED); /* Raced ahead of a remove and another add? */ if (unlikely(nr < 0)) nr = 0; @@ -1338,6 +1345,13 @@ static __always_inline void __folio_add_anon_rmap(struct folio *folio, case RMAP_LEVEL_PMD: SetPageAnonExclusive(page); break; + case RMAP_LEVEL_PUD: + /* + * Keep the compiler happy, we don't support anonymous + * PUD mappings. + */ + WARN_ON_ONCE(1); + break; } } for (i = 0; i < nr_pages; i++) { @@ -1531,6 +1545,26 @@ void folio_add_file_rmap_pmd(struct folio *folio, struct page *page, #endif } +/** + * folio_add_file_rmap_pud - add a PUD mapping to a page range of a folio + * @folio: The folio to add the mapping to + * @page: The first page to add + * @vma: The vm area in which the mapping is added + * + * The page range of the folio is defined by [page, page + HPAGE_PUD_NR) + * + * The caller needs to hold the page table lock. + */ +void folio_add_file_rmap_pud(struct folio *folio, struct page *page, + struct vm_area_struct *vma) +{ +#ifdef CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD + __folio_add_file_rmap(folio, page, HPAGE_PUD_NR, vma, RMAP_LEVEL_PUD); +#else + WARN_ON_ONCE(true); +#endif +} + static __always_inline void __folio_remove_rmap(struct folio *folio, struct page *page, int nr_pages, struct vm_area_struct *vma, enum rmap_level level) @@ -1560,13 +1594,16 @@ static __always_inline void __folio_remove_rmap(struct folio *folio, partially_mapped = nr && atomic_read(mapped); break; case RMAP_LEVEL_PMD: + case RMAP_LEVEL_PUD: atomic_dec(&folio->_large_mapcount); last = atomic_add_negative(-1, &folio->_entire_mapcount); if (last) { nr = atomic_sub_return_relaxed(ENTIRELY_MAPPED, mapped); if (likely(nr < ENTIRELY_MAPPED)) { - nr_pmdmapped = folio_nr_pages(folio); - nr = nr_pmdmapped - (nr & FOLIO_PAGES_MAPPED); + nr_pages = folio_nr_pages(folio); + if (level == RMAP_LEVEL_PMD) + nr_pmdmapped = nr_pages; + nr = nr_pages - (nr & FOLIO_PAGES_MAPPED); /* Raced ahead of another remove and an add? */ if (unlikely(nr < 0)) nr = 0; @@ -1640,6 +1677,26 @@ void folio_remove_rmap_pmd(struct folio *folio, struct page *page, #endif } +/** + * folio_remove_rmap_pud - remove a PUD mapping from a page range of a folio + * @folio: The folio to remove the mapping from + * @page: The first page to remove + * @vma: The vm area from which the mapping is removed + * + * The page range of the folio is defined by [page, page + HPAGE_PUD_NR) + * + * The caller needs to hold the page table lock. + */ +void folio_remove_rmap_pud(struct folio *folio, struct page *page, + struct vm_area_struct *vma) +{ +#ifdef CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD + __folio_remove_rmap(folio, page, HPAGE_PUD_NR, vma, RMAP_LEVEL_PUD); +#else + WARN_ON_ONCE(true); +#endif +} + /* * @arg: enum ttu_flags will be passed to this argument */