From patchwork Fri Jan 10 06:00:38 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13933695 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 ECD15E77188 for ; Fri, 10 Jan 2025 06:02:18 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 7E87E6B00A1; Fri, 10 Jan 2025 01:02:18 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 7989E6B00A2; Fri, 10 Jan 2025 01:02:18 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 5C4AE6B00A3; Fri, 10 Jan 2025 01:02:18 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0010.hostedemail.com [216.40.44.10]) by kanga.kvack.org (Postfix) with ESMTP id A006D6B00A1 for ; Fri, 10 Jan 2025 01:02:17 -0500 (EST) Received: from smtpin15.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id 5DE6D1207F7 for ; Fri, 10 Jan 2025 06:02:17 +0000 (UTC) X-FDA: 82990497114.15.0EE5ADA Received: from NAM11-CO1-obe.outbound.protection.outlook.com (mail-co1nam11on2044.outbound.protection.outlook.com [40.107.220.44]) by imf09.hostedemail.com (Postfix) with ESMTP id 7E40314000A for ; Fri, 10 Jan 2025 06:02:14 +0000 (UTC) Authentication-Results: imf09.hostedemail.com; dkim=pass header.d=Nvidia.com header.s=selector2 header.b="AqfVdM/m"; spf=pass (imf09.hostedemail.com: domain of apopple@nvidia.com designates 40.107.220.44 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=1736488934; 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=QaSh+cBcmD4fAyVgZBd8ptmSZOPC9ILTc9cpqUKZh8s=; b=2U0VwZHGAybA7BJgpy/FLtCYJFx6qBesDxPihucddwhiliDk95bXs6dmGXNq7lJkiBtz5+ SVXAKzDY+MA0ZtOlcLRiY3IChiVd2efzU1wGhNQmn2OGBJsBPqIrYiO4Uik1/LngkPQOF3 HKbHOwcRqd1mrt54A31BMcVbGikRU14= ARC-Authentication-Results: i=2; imf09.hostedemail.com; dkim=pass header.d=Nvidia.com header.s=selector2 header.b="AqfVdM/m"; spf=pass (imf09.hostedemail.com: domain of apopple@nvidia.com designates 40.107.220.44 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=2; s=arc-20220608; d=hostedemail.com; t=1736488934; a=rsa-sha256; cv=pass; b=xvZ/SuMdC7QwSJGMOY4mgnlOVeE7V9WA8mzXwjbUD7BDbkNoIQZWpEwJJhlexxjDaOeHv7 DftGg+NLgJ8GA0h9yMvXzCWaxdpHPbsdZLCWOxzaJkYKLnZ4W4iSDy9HZafow7O0oA/2hx ReEeABkIj1XweA4SsmPXfAcA56m056o= ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=BjBF8ito/6q38FAFc8vOMCYrexzqUL0ZDtxLBj6y5T+pBOZx81ISvM8Rg2J2gSufssmCsnbMnKUICUg5SbosFmtnBGD984B4ZIWWokPMYMdY+PhPRsyznuk9XbUACxhsYILilrW4HotnTNzArW4kmryaXA/yukMJ8kXjw5ZwC156LcslqSF+B+7nhoEXW1KBtahbPvsSuPVFz+5xfKg4z9NK703GvhXQlwuK9tySQY08lybPm0Uu9p+KLsWJICxOmu8P+x911n1yAHV3pqf1P/64n10d+nwRnwxuxmBk4yRCNSWO3WmWfXI8d8E1cA9x770NKc7uFcokiu9C1ZsRcQ== 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=QaSh+cBcmD4fAyVgZBd8ptmSZOPC9ILTc9cpqUKZh8s=; b=nS0cyd/qcr7b7UtW2mzo+nw3yr79hmAEOl7Wttjg2EUat5NUPedXSip3DL/aRJr+0Xl7gU2GODCF6RHKDkIlXBnxLNI4rokJ6ezlGtYDw9rlj3vA/Ekcg/4JJJTFac6O0Ea7hzytFCuuV6DjAaDXbkY3CUKwccEjHgFh94pMpNxJ1hCV18rk3afNx/VH6srzdnqWJRPJEW9mEgU8pyzs/dJZBURJ/Es5vYw9QNOjMG7d/S2ql/2oGOSxqDAW9m+6H9mFrJrSVGFxBYYjuDU21Hv6dyvMi0INpg2fy2pgGfDHdulyrtPKVzjHHpIWLZtWEE0IvME6qzf/Poa0wpc46g== 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=QaSh+cBcmD4fAyVgZBd8ptmSZOPC9ILTc9cpqUKZh8s=; b=AqfVdM/mgvGt5dI+ySgrmOU67rk9XK3lN0fnv0zhGkNFxHkpoIOd/lAmAAfal6fDuL8RDpDziIXb0qPyHFruTPBA/LJ97zk0VfflhkCuOXnLF0NKeiKnuZA1Do34vEpeCTjOZ/htQkMKdSFp931LiKA5oqulWDZeMx28aRKyiRmwNpY6cz2SLwQbT7riRlzFQPangSodNTbN46jE2iLQ//3uHRfNdxeeEDA2eoOqhGNn2jjCIwTeYsGbihDf/6uUShhokWbuyqK06u+yNxf1RJfa+lcANxtBYzB8i3p11p9RcUyyxpsUjusgkAhYocqMGNFQ2+0LXjg63rKUFtit/A== Received: from DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) by BY5PR12MB4132.namprd12.prod.outlook.com (2603:10b6:a03:209::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.10; Fri, 10 Jan 2025 06:02:11 +0000 Received: from DS0PR12MB7726.namprd12.prod.outlook.com ([fe80::953f:2f80:90c5:67fe]) by DS0PR12MB7726.namprd12.prod.outlook.com ([fe80::953f:2f80:90c5:67fe%7]) with mapi id 15.20.8335.011; Fri, 10 Jan 2025 06:02:11 +0000 From: Alistair Popple To: akpm@linux-foundation.org, dan.j.williams@intel.com, linux-mm@kvack.org Cc: alison.schofield@intel.com, 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, chenhuacai@kernel.org, kernel@xen0n.name, loongarch@lists.linux.dev Subject: [PATCH v6 10/26] mm/mm_init: Move p2pdma page refcount initialisation to p2pdma Date: Fri, 10 Jan 2025 17:00:38 +1100 Message-ID: <4f3fa1bb9cf4402d6131d0902472d8e9bae52f88.1736488799.git-series.apopple@nvidia.com> X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SYCPR01CA0022.ausprd01.prod.outlook.com (2603:10c6:10:31::34) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|BY5PR12MB4132:EE_ X-MS-Office365-Filtering-Correlation-Id: e59be270-d62b-45f9-3ed8-08dd313c52dd X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|376014|7416014|366016; X-Microsoft-Antispam-Message-Info: sd2dONtYCdATHIVY5dhEKQslrq1sx4o5Esyp+n24WLRDVY1kW3TPb+hauDrLvBrlFqE9FcP7mm3Xwt/Qg88Ump+oye675Lx/XL7twjbYUJ6yk3aEXtVlX7zL75a06cF26UUivGfB1I9hXJhMrTJCPMUVbuN6o4WIHKmVnB5HcMayGSPg7hCrRobK1s3Bzx9sZziWnMAKlWNfs51gTFVL4p4C10zD62KswPIHu/V21FAVsmHPacq/KqyyZFOf5YDtpGynvJsrvgH1frHrF0UpSdMLNCnWgXN2R4m6GLKDdpZ2jqJICm21QSoOaztib9TQ50XBrhFDCS6+FOXmaCHg90DBDHbwM/h+0amXbGSbnMci7fxTvieDu5NGzL/Y2PMeYZHA/o7FPdxbQhXbDMh0NPuoyzd6SWaA1i438j5kNaT/eO4Cspy+7uXBZCB0/XNTs7zd9kYaUxWJ9CuzSHm0qNHSkktEtGQOEAstYuSUghsF66LEsJOHN29x3F+9OAcZBEVrFJbLdmu74eZRr3poH/u/yis51dPJ38oPHaW7bRO/LPjUZvVqabHMhOi+el5WCq2CB11dbZXy//ES9tudC2fFrdOQLZNtqRTFi8kfGxMs93dYPg2F2nD+GPDjx0qQwhBcRoYZXZeN3DtztQcc6BpjSzIZ/iaJfqa8XkdyTDMAbFrv+pX1IfX5HuOefwM/gsqnUUXyQDi650gleviss7VEjrbhL+NjvldzRz4EU32JwBiLuySL1lfRQIfDYChI4vQrAIeADA71hehi++ipPGr6eMHRpahTBX1fISaTvWtKCVW579Gtt0ZMRj99+ov2ZM7hNaMvxwvswzws2m3AmGsvt3e/bd50WfQ2u+KZQ93dDZhvkdNhDd2hSKyUv2HYxKdAdH/xgGXzo0kcJw/67Qj1prx50j77gJ9JeU8HuS+w6gnVyrmN30/RiPlQa/bz2vGZI8TSatXDmTq/PYaiN6+YUcjeTL4bQlqkojM1lr8Lfy4y4AhWgXWxT9RHMeokHjemdsHPmV2bJenmgHyefQ2ku8j1qMUOOywA2TZvYjsUU3uCbHCxLS9xLT/sMlYx+w1QXO3UTCHcT+USBtjBnkxaBKLwX1Dkx9eKr9i8Y5v+OHgDzVJAVV2NN9jNkOUMNOTGT0qJqzob/TInhHpUA2OadmBIBNlZKBoENlLNjy9i31nuye97QX2U7i0hCJtoBQPSkMbvw8JCxUES3l0gs6kdFr9Cd7XJGou9DpcDt3rM9gdE9Be0Pvo4G0pdHuLil6OVHsFPTg0JRO5jAzmNAET9YQakoqkQWkPnEFYDtwhf880NOcznnf33px9TxrbU22s5GywOYLesK+vJRmJxci8KrF3MlKOg9ArWjdsrk25UwKnQm2WrUQqXzVrjtG0q 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)(1800799024)(376014)(7416014)(366016);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: reMOE8NY8LL0fIfZs4nKfQbGc0q1CNeITk3A9ALc8ZyuXgwXpukZQ322sPS/Czs51R8iZK7XbrWh12XEop5QQkUl66sS9qkLgDaSpNSHgpbTDnMn+DKS977A0UK0RR98Clqm1dboxrgSybFsPHZTSYWC5DJtvGI+AL4LHEjrnfT+0Is6vwDN/F/GjAgOhb/B6sY3qgzYgc3Q4fCPCysYkIlzwyHOrmLI48awG7hpqeOTDRHOObXvS8dLPIGjSLkNmMnFF2MvEk+lz8adwvBSIDKBrXhEDSvwxdVWdzSA34pSy61JsDdMshjoxhRnNRs/c88msuOF0bsP96nmxl2WMr2SCiCh0RUJyKZsyLS9KliTsgHZ5un1MkBaxD4ZD6DncLx8lRHpjuDoZiidlvVySOYM0GNmcKFYrP6+b3spQF+5oPtrsSQPoFE/B2eKYL247JAN4teebECKdzBGSg1T0iCLYVEmZk97rBTcb5BXtR0Y8zKmGj0h2QxI4p1O8pUHCw+aif3PXG2klhBrID3Uwj/PabhSKD9t0nnsQBIwWmqPcPMLFq0ByFWmLg2hCaceUgWY7sUFbTrVcoOkJ3tmFyCmhWwfjxT2Ps9uZoXGid/aTFqjXtSNyU7jfRq1H+SDm/TzxrA8OZe2UztRUpQFrybOaY251Wfu83cU3ycieyrPf6RSC9VTiFQk+s29mvdnU83TsBKD6T9sNfYoBARsmmIfGjEpwv002cqE6cxTDXsmH6urrUq8T+5pq+hrX1CFNFAovW8EyTLQw3+fFmA1pNb0QDSxxcFMub3EsyG/ix/6F4xXyly0HFi6rxiTKv11H0UqTgotq74Zctq5jaxSKOaQ4IWjV18EuFaKCikuJ9U/r4btCk5G7QuUNk23WO/ElmVqyf+caPf/NLQ5v7QRJOMfrOm/6jnmV/L7uTL92HLxJnkwp+2ImkEFbHInkOSNM7AdDBISYKcNKN0JcFg+OA9LoUMIAXtHwno4DCwLSMhrITkuAxeXBDMKLtF8kgoILiYRLcYR3m6fD7pGMngX4HqixR5GDlKtkZKuEAh6TfZnobYhpm3alZavjc4O+3nNwVs1vep/TCoJmtPd28yP/cetAGKeEQwrqD7ECuNqLjzEhFhqLjK9VgwtTq3ycGOJTRIriOEr9MBIvWtn5K1FtuTAI5O4yJOQmdrWJ5duKNMenb46y7eE/ohzrRGDCz3GOASacOjZRhT7g1zArPsF5CFwzeV0hSKg67fnr1HkRzDAX+I3cgy6Wjp08iTMW41hQbqTdLVYJ37FRIMEP0Se6HwMc2hXmxXJAy00QGI6IOEaCqQ1djY/P57iH0fvq6sUOxiLF+J/qAZbNI8+s450veTHElwqDqqsGezO6hGV+WswfsvOqd8+RbD3TZBO8Syq716jwrBj+tfIrJcjvun8/yJFmPiNy9PU5q6FpoYFcZdzUuBuwcf5rnqB2rPU812R4ttkqOoPNTbEPAFy5XVFEL+zyTjl+pl952KBpEOySMvZBpVXXQkJZwqwR6LayTVfXlpwj5KSA1XNci9jl0LbX2oxKA9KUby3T5xJT+KmODwZlbFhhFXqbVk+TmFOj5RZ X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: e59be270-d62b-45f9-3ed8-08dd313c52dd X-MS-Exchange-CrossTenant-AuthSource: DS0PR12MB7726.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Jan 2025 06:02:11.7446 (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: 17h6UKIZ1wuaFhVYIXwCyHIA48WBjjIJaLai5rmBjMdZkwR5VKql9ezlTbqLAHdaAG+nUwZWhoat+zIEi7ClEA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY5PR12MB4132 X-Rspamd-Server: rspam05 X-Stat-Signature: m5hw4w9168tkidf9sskmac4b3hrqys9u X-Rspamd-Queue-Id: 7E40314000A X-Rspam-User: X-HE-Tag: 1736488934-169432 X-HE-Meta: U2FsdGVkX1/mjU3t27b9r34rzaoi1rdLzVmx3Ov8nKGA0VgXotQS2F4yNIxqlxtWHhu9L/tdQXeaxiK4KGPwPfT0qS0VLcgdYNtVZnXHKRetX2AboUk9BzbZ32RAlPSD75gjfd7xKktrlMGPcgzU/x/4kp2O5Rx9gQ3tVjV3bOfyPg8Mzb4L2yf0DJMQJBV8KEQIkxFn8eQOmj7cvb0OMuONCyDVe9p94h7miwbVb7JvMbbDPbpLkwO91o72Kuiyz/VBfdZBFoSFhP9yqI8yqOd7FdRa/rusKkl/5BnVzZYqw5MhTlNdVRih3Hzj8Gzn4xgIQ2w8InHrdl3jQnr4AIsTOLaienikhy5juSVLXg1Xh7PSGzA4ldSQTcpiFzdTVtVxAowrl7qkNk+ZYDeIvUvwHH9dunz2P4RjRMd1o9tmK/GZfxoJdNBU/TkpyH7SyNJHoBSH1VSTQSKTs7Bsf5spMedB/oWTGHSmrylf+WjPwyvud3FP5jGHmRoGXB1jSEZfezjI1cBYftdEYrfVghsjM4YNE9cd5gUj1bzSdHopmNo6bngAOoKj0HPGBqcmtzmP4dDkec/qxjIF0iDZHFFcEDs3mLiR0cDixkRVlkGc0w0VMVwQRyuH1Fy5pTlEq1Gbriy8wWPNB2E/4VrzZUtCcIhzM4gqlGBeTwnOWu4aZJeJyeXbu/Zo/p0/QCs3oXy5KKK0C2iMc3L+yk0rMwhvHbMIQYSz/meuI54nEn0ZzOKAr++HdJs3VLGhvQs5+PuzsSlUJ5qVT4Z3dPDFL3q6NC7mBqNoQ1shGHS0xiDxcvO4Pe9JtTnspJIGChboURD6YQ6Y7FCJAgYDkiky/h9IkAzItiKBjEmeiN2ina8hxjwarCwB1gYoiVouT/okk3jOC949G7JfQAeSXmpdGju/95jcAAdN51XjyGW9oVj4qiVYunGeiv4096lUZ+bzh1vdzy3GZ5YgQ0z/aTI 6jLLpBBS zjGxIqgEkeiV433zuvxBUWTFEBa+IpyOuR/9pZj1KbMd2jjANwVjRuzDlQG8YrmEp3u4EDI2lFSteLKyUzrcsTwi96Ulw/HRKh++Sp8FUSlNYdTWgR+OKAD8Yogk4WxlZgKSHHcLA95HdGpedLzq6XZ22BZJEH2lOcQL2HsSqeMmgHwJ8QNoC3SaG9t/69sl+9NB6vzLuVw0Idx4Yv+nZyJw+TZiaSWO21pGfghSi2PoH0xHuAgNy1ID60f0ITKipiTIM699SJBrq7oXwShQE7/xg9YZL92juq4BZIUd+NJXGcs/XEcIdtprQazX1+yOPHTky9MaZUc8N+9d+C5OLL4KGmBOFl8y1DWoydfPSpVcpF+bOQUrgH3Lml8IbWcqVWVD0GJH64U1+uiiDNqrRJIt4yQ7R1C998dRCnG5NbBuDU6TMBSOcei7YqkVZXfAlqqqIQvFtxWdqe2RzF+t6GYk0YtKboqM8Gtq8/s6Wt8Se66CfHqIPM20e1frVc/lEnmsnkzWpnSlI+YlJ7GvHkOY+qqfswSQG+ymBDAdTP0aSUGK564PTX6TOmQ== 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: Currently ZONE_DEVICE page reference counts are initialised by core memory management code in __init_zone_device_page() as part of the memremap() call which driver modules make to obtain ZONE_DEVICE pages. This initialises page refcounts to 1 before returning them to the driver. This was presumably done because it drivers had a reference of sorts on the page. It also ensured the page could always be mapped with vm_insert_page() for example and would never get freed (ie. have a zero refcount), freeing drivers of manipulating page reference counts. However it complicates figuring out whether or not a page is free from the mm perspective because it is no longer possible to just look at the refcount. Instead the page type must be known and if GUP is used a secondary pgmap reference is also sometimes needed. To simplify this it is desirable to remove the page reference count for the driver, so core mm can just use the refcount without having to account for page type or do other types of tracking. This is possible because drivers can always assume the page is valid as core kernel will never offline or remove the struct page. This means it is now up to drivers to initialise the page refcount as required. P2PDMA uses vm_insert_page() to map the page, and that requires a non-zero reference count when initialising the page so set that when the page is first mapped. Signed-off-by: Alistair Popple Reviewed-by: Dan Williams --- Changes since v2: - Initialise the page refcount for all pages covered by the kaddr --- drivers/pci/p2pdma.c | 13 +++++++++++-- mm/memremap.c | 17 +++++++++++++---- mm/mm_init.c | 22 ++++++++++++++++++---- 3 files changed, 42 insertions(+), 10 deletions(-) diff --git a/drivers/pci/p2pdma.c b/drivers/pci/p2pdma.c index 0cb7e0a..04773a8 100644 --- a/drivers/pci/p2pdma.c +++ b/drivers/pci/p2pdma.c @@ -140,13 +140,22 @@ static int p2pmem_alloc_mmap(struct file *filp, struct kobject *kobj, rcu_read_unlock(); for (vaddr = vma->vm_start; vaddr < vma->vm_end; vaddr += PAGE_SIZE) { - ret = vm_insert_page(vma, vaddr, virt_to_page(kaddr)); + struct page *page = virt_to_page(kaddr); + + /* + * Initialise the refcount for the freshly allocated page. As + * we have just allocated the page no one else should be + * using it. + */ + VM_WARN_ON_ONCE_PAGE(!page_ref_count(page), page); + set_page_count(page, 1); + ret = vm_insert_page(vma, vaddr, page); if (ret) { gen_pool_free(p2pdma->pool, (uintptr_t)kaddr, len); return ret; } percpu_ref_get(ref); - put_page(virt_to_page(kaddr)); + put_page(page); kaddr += PAGE_SIZE; len -= PAGE_SIZE; } diff --git a/mm/memremap.c b/mm/memremap.c index 40d4547..07bbe0e 100644 --- a/mm/memremap.c +++ b/mm/memremap.c @@ -488,15 +488,24 @@ void free_zone_device_folio(struct folio *folio) folio->mapping = NULL; folio->page.pgmap->ops->page_free(folio_page(folio, 0)); - if (folio->page.pgmap->type != MEMORY_DEVICE_PRIVATE && - folio->page.pgmap->type != MEMORY_DEVICE_COHERENT) + switch (folio->page.pgmap->type) { + case MEMORY_DEVICE_PRIVATE: + case MEMORY_DEVICE_COHERENT: + put_dev_pagemap(folio->page.pgmap); + break; + + case MEMORY_DEVICE_FS_DAX: + case MEMORY_DEVICE_GENERIC: /* * Reset the refcount to 1 to prepare for handing out the page * again. */ folio_set_count(folio, 1); - else - put_dev_pagemap(folio->page.pgmap); + break; + + case MEMORY_DEVICE_PCI_P2PDMA: + break; + } } void zone_device_page_init(struct page *page) diff --git a/mm/mm_init.c b/mm/mm_init.c index 24b68b4..f021e63 100644 --- a/mm/mm_init.c +++ b/mm/mm_init.c @@ -1017,12 +1017,26 @@ static void __ref __init_zone_device_page(struct page *page, unsigned long pfn, } /* - * ZONE_DEVICE pages are released directly to the driver page allocator - * which will set the page count to 1 when allocating the page. + * ZONE_DEVICE pages other than MEMORY_TYPE_GENERIC and + * MEMORY_TYPE_FS_DAX pages are released directly to the driver page + * allocator which will set the page count to 1 when allocating the + * page. + * + * MEMORY_TYPE_GENERIC and MEMORY_TYPE_FS_DAX pages automatically have + * their refcount reset to one whenever they are freed (ie. after + * their refcount drops to 0). */ - if (pgmap->type == MEMORY_DEVICE_PRIVATE || - pgmap->type == MEMORY_DEVICE_COHERENT) + switch (pgmap->type) { + case MEMORY_DEVICE_PRIVATE: + case MEMORY_DEVICE_COHERENT: + case MEMORY_DEVICE_PCI_P2PDMA: set_page_count(page, 0); + break; + + case MEMORY_DEVICE_FS_DAX: + case MEMORY_DEVICE_GENERIC: + break; + } } /*