From patchwork Wed Jan 8 01:18:45 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13929869 Received: from NAM02-SN1-obe.outbound.protection.outlook.com (mail-sn1nam02on2064.outbound.protection.outlook.com [40.107.96.64]) (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 4D77B4CB5B; Wed, 8 Jan 2025 01:19:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.96.64 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299142; cv=fail; b=g/WMYDdhoHNahtmhR/VnDdU8b0q0gmew+fzQgkt9chDCuZs9tn1AQlRIieZayP2ic3k/I7iLQscWKyzdzk0HyCr3a51SL+zrSifbWcLf1j+VUTrOCP196IVAVbEhiMbgv15ysPVf2psLDtsNXyoeQl4wjAUOKLIex6r6aRoiclQ= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299142; c=relaxed/simple; bh=qt4hCXyqduC3y5OrxbXoOU7Rz+/tpTczboDXe1dcLW8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=KaJlvwyztn7d6Sgdot9UwBkgKFA3DpNXNTRWSR2weuYQq6qwHCQib1dZt3tvrnQzmfCi2v7YOKBYPwJEI7qVznrG3V8NXNxvhG+Gdl0aADhAunp15jcxjjxc8nf6CGTPwID2dYwmjVNlEmnguPkifpxgOS50CUY0VsCybcr22pY= 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=VArJqSwG; arc=fail smtp.client-ip=40.107.96.64 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="VArJqSwG" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=CRlM5CFaJXfSyui47/Ebh1Q/q2ez9pijNuOJOycaoyAllbn7eg101qWZw/pQrTGhX1WylDIQwT8F2pxyz8QKyJxINKXzE3Tk/DAz2i/i1+UWuGpQMdQ0LOQmwnXGlABOERVsHrAeWO4OKI2Rpp0MK9GS0sIlrUqgLjeoCDaOqIoigob+PHDfev2iZl4du66SvddhZPmpr+ec0oVKq0BMiIRr8o9w88muETgMo/3wnY4F67Me6eAUvXdTZ4IwZPKPSJh95mH6/FDzPlrBBMd43/F1asu4kq4zJs1ImYLxW17vkLwtNdvo/tjnerys7sGISWTkVHyYNuxffY1/rgW66g== 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=d5kaGBwLUPzP7+vVwbP5LA/mDb/TH68zjJSuMHcLH/4=; b=YMNWa3aRN7woO2h2QDvq7lU39AFBFg8khu1kTUNbz1Bks/GvuYAVEJQs+Bagp378tmgLwK5ICnvz9MJStnjFu+1vZz9GKCmvMIoQq51FFPwcKS10/hULXWH2r7FlNC4WyrCMJYLGWjZHsW8WFA2lPyJvVP0uTmAe/2WIhW7JA9aP2krJjRYionflvo4j0kr4FCn6QSRL2Y80cJYZwL3WsWmXIt70K3OHqFVhN7xd+9OhukQAZnIYWQpBW2c/5HX0YusnFgG9ivOgE8lZxlckt0gjyATQCzk3RUELQ30fplKGtwtNV2on7qzqnpV8YikYPx8U1jMqNXVO5i/SA/YiZQ== 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=d5kaGBwLUPzP7+vVwbP5LA/mDb/TH68zjJSuMHcLH/4=; b=VArJqSwGgmHaKo+vu/rt4juvgsaUoomjYstwrM8B66EhXiewzGw1vgoUGHyjoBP/WneQ+TK3BBkuWDZg1qaaJUkJ7b6Bcx/ysyRWprIwA3qQFQj/hrcsOHSgJfWGh+uJFMzXc7JMiRQ5rxozIxo063RPflGyNFOqvQQDak8DS/T9W9y9vOhRXnzshVMAg7BuKmsra8oAHsUClpZ8/miJ0UpIHAtUqBZda4aoDR+j1WyDspWnZA8kVBPanLVZyUW33kNNHhr15O5eq1ijAxiuoYkcuMYR9AtyT2mISbGC0ZdvBKO2CpZlw2tlc7EmmpkJRdw+Mr4gQtjd67KKPe0AUA== 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 LV8PR12MB9264.namprd12.prod.outlook.com (2603:10b6:408:1e8::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.10; Wed, 8 Jan 2025 01:18:58 +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; Wed, 8 Jan 2025 01:18:58 +0000 From: Alistair Popple To: akpm@linux-foundation.org, linux-mm@kvack.org Cc: Alistair Popple , gerald.schaefer@linux.ibm.com, dan.j.williams@intel.com, jgg@ziepe.ca, willy@infradead.org, david@redhat.com, linux-kernel@vger.kernel.org, nvdimm@lists.linux.dev, linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, jhubbard@nvidia.com, hch@lst.de Subject: [RFC 1/4] mm: Remove PFN_MAP, PFN_SG_CHAIN and PFN_SG_LAST Date: Wed, 8 Jan 2025 12:18:45 +1100 Message-ID: <106d22a58b4971a2e41ca65d9ceb30ed81fcf727.1736299058.git-series.apopple@nvidia.com> X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SY5P300CA0006.AUSP300.PROD.OUTLOOK.COM (2603:10c6:10:1fb::15) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) Precedence: bulk X-Mailing-List: linux-xfs@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|LV8PR12MB9264:EE_ X-MS-Office365-Filtering-Correlation-Id: 08592ede-7695-4d52-1c33-08dd2f826d9b X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014; X-Microsoft-Antispam-Message-Info: TCIn4n1t+r5D43/TIEOfbhp5zwDqxsT2y2CqYQCZ6SeDB9oEaFgLZyL9skhAlbYyFJ9X7X4jMw5C4m0LVAyyg3jT7TjIdNR10M0d6Lz5O3c185DIwzaazOLS/sOf4l/U23dCPuCSVbHfVVroEHAK6yOu7moHJVrQJagZHTbnNfkY6CQxhXLKJ/9gWO3/mdldd8+XOwS0jH9BhqLEBzjCx10sQPH9ut7vDOe3Y7kwafGv+EIhk9ev6CPvAlRCRogvGRe5fXf4EyNHpRk95kBrbddc9YX56vh3oAljmbSz8bDF2cxFwt8liSbt6i5s+iZR07ap6btg9JJZDyDz0vmrGdVURiuN8H3O3ECjFJcdryeAeg2/WD1E/vJlauF1DnoyMQFPo3PJ26OBQLmmql7STTvxcoSERweOJQdmpO/YzNZzVLFv7+/GLbpSu1kcXC7orftaMfKIvHikuYQfGeSGGEMy4t0u+oeZbw5MMMt9ugRYKypSPXAXqpI/z6DnBFCf9IkSQA0MvL1sCWp4nQXIcbtgvNb4X7lr1PV9gVaW3Ngd8XjgjRJ4ceXbFOXXzPPfpgJG2c/0E+sKf95Lb3s7VTDqikXjgOJYAHRMFJzz0NmkZJyITM6h3P14gN+FXzzrhBl3gLBHd1fmkI1RcvLv0KvuXZrqfpLMpd1/T6F+VLT7kfP0z4ycHMo1/JWrTz0usumdV/Zkq034Jb6qVRwaBeKwK7xN64cdmlFpABzqtBVykR3v6ddu5eBHwWh2U0yBWwgJyrRNnPsASsqzndsuj5H3KCE/cdtW0QEFj8aqjjMlTmtui0Fb6oQ4SIzE5vTTH8esrR/+IYsMzC/JUEKgYGw9NszBuU3cUXPah98xqe4SkxKXF+iJ7RgdMO4CLdBV6dgN8tKtKqZ1w12++9KCXkFVQDOvyc6+GcoALW+VKplHp+xRTQ2aFyCXbQnUhHDTRvvHpZykuZho9lCBKknY0fXBqsNVTzLRwQJB9MO2b1e9tBpEyplttFeN0Vw0LbSdpeHkyPsR/2kACcLwAepJAJ74MPBX3TEd5dI5i2ksEuqpeXxogI/uaKgQQDtQYw+GkJO6Tq26RjGXwiXGpjAFRpnalXeF56F44RbuwrbqPWdP11u0FJrZ7k0+EqAzxkU5Bkt2eDkuLhExi1TvjlASNCTkknC5TGEHCsvCpc8ICqChCFoSyZirHwmqPRX6pLMvh+a3N5E76otWa6X+52ntQ/owtxVICrbxjSHF5HyvjibYltyBiy88KQWge7R0KoKcKS+05cB6m/bZUFnwxjeEa3d1PwHMn2RmadzCggYyuBSaNVzsZxCSHpIuTYG5FGXLLap+bbGUYC3ALU424jMNkHSH4cqS/Yl2/6IyMcCfr53BXyckT7vmRsB5OvIIuXYZ 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)(366016)(1800799024)(7416014)(376014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: d0vA05v9TUtw22ces5pGb6AqUi/GIVeGbJ0+CJzQfBLSi9t/RX9k/W0a46CflVHfRgmc50DI8my3t9JHTyNp3zonkNw7SWmcX7iWd9rWKlNp8HO9jBdRSZBLUhZdzDOg+V0f+eRPw8ZfEqfrzAfqHituxq8vX6rDBzohIYSXUNEcNVJ5T0+bSclrzUsETz2Mn8ffaA3aXrPQWl++jYd8+tPsqqm+o8eO2vZN8glTlpQiU5wuW319PJpNe7cEspeJ3sNxo1iEA63nFXbODJZgmJg478hat7SMYJzJiwj5Xg3isRtbWg0NyYmIT43UK+/WgiT0+QG9IeKqvRJjxLWygpK6BRlCEEqFTSM7usWTgdBNbYlIrcjiNHP2sqy3YUYLFiytrhOXO3KUiZqz0zpjz4AQXV/JSjMQEfMWQMhReCkmYC3kh1JIrzaPWmFR5NDZTJr8lnsnrNIhKRgc3q/4e+98m/MgECYJ+fpQBf/22UyWCLFK7foLQp7FiEi5Aw3cThLo/EUr0YjiRas3aDXAfFAv+roTMmqP6MSHAdxZInFL7VEFuCHLzbFcsfQh3/S63Ndi0247zRBhpy6D2+6EqVwh5pUDhn9kSsnRIo8xJDwG94X1k70WpINBHQzBrWRlGzaLyZjDKKOVPjk/VCyDeO3tXV3RbJA1xwFetBNNhQ0JEmgtvZVsgXrbsD75LsCDzdDoNWnx7E2320Edt+n6eYM0f2ue4a+ce3w5rpSOkmgbK/zxMkW6nz+FItj9ayNuxt69q+bM7rUT1JVDrehQxOh7YIkZf0SBHl/BXRQl4CqrExhd98lLE3n7sEkV0vZ1swpq8j7GxxBFHq9NS+74OYFtNF7IiUunkRPYiAH9AZiM4pugvQTIASbzp559c9YIg9ncDuRcsvXzWRK+2fIGgXA4vOMH/T5AtpFOEFodfM0rYl0PeNrvgjICJdjq9vJZXKtnwRBJlg9U8o6gxqJWeG2jx51txeMIOb5bbSB8C1dgCQxPqFXvMbuIc4WHUn0ByFgpMp87cBf9Ib3pgs7N9QF1RIBQr4+H5z9ut0+xgNfKQxp0S+tLohXZrF8Bff2zms1cwni1vrpA6al3GA8noWFZP8CTmTzPy0r00mLZe4tolhSL25W8+tx4EkSgTGcYRJFapXskSGH11mWUcCRJSLvAQQprB8s0MkmuxVv+w1sG3L5aDrdNE8V/oXgBf7J2n8YBkakY06cqmFFLCXr8ONsQv2QQZYWGP228ojkz+ibyu0O5kX4mCbEtFLTYqo88UASjqr6jaLB1DesIaWuNIWe33+yemRTEg1g08Fi9p7VSEWQ11cI0E8FP5331SRBQaPubk0L5pCmiIrvn9M7OpNol8zt5F8YS5huaKxADw4Lr2HWTcMACiPgorZHAR28V2V4W2jkIk9adle2xgROLXfY+DLook3E01izs+Ff8JlECWeOn3rn/AtkpXamzTQc/R+0mTVchyKn9UhknIOrEQDXSNZFP/lZstL9LhG4pwXY9ctpfk6xGr1tdHbAhFFjExDOh+JsiPcth6XXOErkQ8ZXC/IY+aoYbuiJ5E5xxRAFBotvzcp/+zgaAb077po+f X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: 08592ede-7695-4d52-1c33-08dd2f826d9b X-MS-Exchange-CrossTenant-AuthSource: DS0PR12MB7726.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Jan 2025 01:18:58.8625 (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: nD7ZH6upB4AcUY2XJzfFyiyxaWrvaCXxpFc7mThyUvtpuSzNTlh8V19k/bRndA3xzYyWMyOOIY3KTsOUC9ljag== X-MS-Exchange-Transport-CrossTenantHeadersStamped: LV8PR12MB9264 The PFN_MAP flag is no longer used for anything, so remove it. The PFN_SG_CHAIN and PFN_SG_LAST flags never appear to have been used so also remove them. Signed-off-by: Alistair Popple Reviewed-by: Christoph Hellwig --- include/linux/pfn_t.h | 10 ++-------- tools/testing/nvdimm/test/iomap.c | 4 ---- 2 files changed, 2 insertions(+), 12 deletions(-) diff --git a/include/linux/pfn_t.h b/include/linux/pfn_t.h index 76e519b..75bb77c 100644 --- a/include/linux/pfn_t.h +++ b/include/linux/pfn_t.h @@ -11,16 +11,10 @@ * PFN_MAP - pfn has a dynamic page mapping established by a device driver */ #define PFN_FLAGS_MASK (((u64) (~PAGE_MASK)) << (BITS_PER_LONG_LONG - PAGE_SHIFT)) -#define PFN_SG_CHAIN (1ULL << (BITS_PER_LONG_LONG - 1)) -#define PFN_SG_LAST (1ULL << (BITS_PER_LONG_LONG - 2)) #define PFN_DEV (1ULL << (BITS_PER_LONG_LONG - 3)) -#define PFN_MAP (1ULL << (BITS_PER_LONG_LONG - 4)) #define PFN_FLAGS_TRACE \ - { PFN_SG_CHAIN, "SG_CHAIN" }, \ - { PFN_SG_LAST, "SG_LAST" }, \ - { PFN_DEV, "DEV" }, \ - { PFN_MAP, "MAP" } + { PFN_DEV, "DEV" } static inline pfn_t __pfn_to_pfn_t(unsigned long pfn, u64 flags) { @@ -42,7 +36,7 @@ static inline pfn_t phys_to_pfn_t(phys_addr_t addr, u64 flags) static inline bool pfn_t_has_page(pfn_t pfn) { - return (pfn.val & PFN_MAP) == PFN_MAP || (pfn.val & PFN_DEV) == 0; + return (pfn.val & PFN_DEV) == 0; } static inline unsigned long pfn_t_to_pfn(pfn_t pfn) diff --git a/tools/testing/nvdimm/test/iomap.c b/tools/testing/nvdimm/test/iomap.c index e431372..ddceb04 100644 --- a/tools/testing/nvdimm/test/iomap.c +++ b/tools/testing/nvdimm/test/iomap.c @@ -137,10 +137,6 @@ EXPORT_SYMBOL_GPL(__wrap_devm_memremap_pages); pfn_t __wrap_phys_to_pfn_t(phys_addr_t addr, unsigned long flags) { - struct nfit_test_resource *nfit_res = get_nfit_res(addr); - - if (nfit_res) - flags &= ~PFN_MAP; return phys_to_pfn_t(addr, flags); } EXPORT_SYMBOL(__wrap_phys_to_pfn_t); From patchwork Wed Jan 8 01:18:46 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13929870 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2068.outbound.protection.outlook.com [40.107.92.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 C9F3A1632D9; Wed, 8 Jan 2025 01:19:05 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.92.68 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299148; cv=fail; b=ZoLL7q8w2PeilOw2zLY3QS5//UoYxWT43uI88xkcIIIvvguA7mp9CNXzdApLOTdzD5pdmpgm+83GWVnVLEWXiVlkALgNoeJ8rCKApShJ9gYqVvFU9YECv44e/9g0wepE2L78HLEAVXPE4+c1pw0YqyRI3XBVFTlPTFG06BWxQhU= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299148; c=relaxed/simple; bh=75Ce30FGfNJrM0eiz1RHVabriSb0VSXPdz0dgwAb5nM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=inZfOVKof0qrhKd0I6V0fllWpJlLn3SGAeXwaGSSIjPf9IkCDj7jhpq77EYLImz+HWYYpXG9aH8Lk+yVAjNUWILgBMC1w8228Lc6mOgfZwwn396LR/PMHW64V4EdvbzqyadQY7cJ2cNjqiXR0ZYn57uNdxKp4oIysliZE3LhyUM= 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=gIsBKjYq; arc=fail smtp.client-ip=40.107.92.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="gIsBKjYq" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=QNEZPhsHsQ3ALz4Afw2q3CUqUPPU4qdQTcgPOysgJiYIoCa4Omz//Pbd6/TDuMvusAWkTuSnGI8g+KlBZ6O1luiIiV98nEUgOQCYDJ+2pvErzJJxEnio2cTQaJWc+8Vputq7iaySl7ia934e8MU5Qa3WSD6Uk5nkcBsQmPEA6bA8jaOcLio5imNFj5ISBpIr2Srm3Qxlc/IP7MeVQOsDuxSDlGJLXHMJHst3Oz94pMpLDZIfNcKxsYTXFw6DcnMl0nQb++BviDYY0dPP8DHrZhJ6im4FFJRstpQWf8rgIg7xrfU/X/QJrt2mTsGYgJSyFc7UK8R1rNT53Owv95b66w== 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=kRqSdjQXKAmEy86FYwkJXmEjCcJmPiE6SGAqo2GzlFU=; b=lerrEDDrRO0VXMDIonjz306DigLI7CusDolXbwlhBYreEJdN2ws1qggCdaxt0frhxtL2aFxsn/f1fnj+ctM0zPVDbjAAjHRk8UZYu77LY+6KJo0V0qKTHexNQPVWWpFsRzfE7/96pqjX1FMW32e6PoRYweBpGqGjEvQMuvr4Zt6y+mVr+hVP+2H50tzUUGi8MT3e6cmJdWkz6I0YDBuzccE9jVbPuFsh/m4Oc1/Iq4Q1Hps+UERLtYHSm4sOFaGKVVH0s/GUJJqhmC1QuNxhfd+8VwOQm0EUZKSxE9zmijM50YIDNpXHsxfCbkyhKgURQeNhMiI+TvlRhb76K2F7eQ== 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=kRqSdjQXKAmEy86FYwkJXmEjCcJmPiE6SGAqo2GzlFU=; b=gIsBKjYqfJve1HzLIhuGVgQ7m1E2RE0EWgpeGYCQldCT/UMUuw+OetFAXm58bS+z1D2cvUMqdFtctaG2cwOh6cGxLZn5vcpAilnWq0T2g8FmBAYXayaG6u/htXiX3nb9aKiYKl7j4JcRmazruaiHjMpUYPppvy/MjEa1NslR1x4Tz8fojpQhKE7nKQgdHglTzMH+h0YtpJ2rGGx62Fsm2ue9wx69yY2cMwZMe6ns9wrvVAlSbTJpye8iOFp5gb1ZyBwZn65GgKgGPuGK7mwspHme+rYeh+hxIjD8Nehoz9WAksl6YJntk9+Ve7jwUrQrcj3R7d/Rq+pR3RL4HwAZbQ== 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 LV8PR12MB9264.namprd12.prod.outlook.com (2603:10b6:408:1e8::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.10; Wed, 8 Jan 2025 01:19:03 +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; Wed, 8 Jan 2025 01:19:03 +0000 From: Alistair Popple To: akpm@linux-foundation.org, linux-mm@kvack.org Cc: Alistair Popple , gerald.schaefer@linux.ibm.com, dan.j.williams@intel.com, jgg@ziepe.ca, willy@infradead.org, david@redhat.com, linux-kernel@vger.kernel.org, nvdimm@lists.linux.dev, linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, jhubbard@nvidia.com, hch@lst.de Subject: [RFC 2/4] mm: Remove uses of PFN_DEV Date: Wed, 8 Jan 2025 12:18:46 +1100 Message-ID: X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SYCPR01CA0026.ausprd01.prod.outlook.com (2603:10c6:10:e::14) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) Precedence: bulk X-Mailing-List: linux-xfs@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|LV8PR12MB9264:EE_ X-MS-Office365-Filtering-Correlation-Id: ad2d3d9c-6c5f-4c5f-719f-08dd2f827038 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014; X-Microsoft-Antispam-Message-Info: YSlSZpw7NBsHuPp26qOPAsJ85rxwkoTIwfK9zIoz/hR+mm4v/V9LyLuiqwpswaSU36FZSXaM5XIUaREiK0vS/DlUoLxgzVQjBJoROGKA+fgPk9aIquQUxf3ZNakkRiSXUA/RBmi8pk74jVv6m+E/lcUBq+YKN4ixPEkO5B2643OuTxnHaGgXqAhtyYI8qPbvqmQDqtjDZeMEk9Jub7vwhBYPdWexSmntCievQU/nms3ih9s7nZ1ARdqr/xE9k7SMfgk/yHh/uqs08kcdJmlMbDXwbPLxpKrkM+QUtkhgHBgnlX4HCqpPFGCyuFHskPm/GqeaANHOzx4q1gQmZcF02bGlJ/cwMekqHFVqgH88yilBvvTu0JG/9kQqwea+fzK65PXie3qdl8T2expJdCGRVSq99v8NuGDcW1HoXMvq6UGMmN6rzbRu7FhULv3BtJexJcw9uaBxbA/t9p4RjFUQVCdVv0+ldTe++zMaYBFbUrLOBob7SMClDqa5gH87vTi6fz8oJKL4X8cMTR/8wmZ305i8c0xwZQpvBEn00Tre0OCjRQHRiL0EkGBLO4Vv0II3h3iqidSxe9yJuwcTMp4l5UVK+WQUIhUgWvQ40bDYeFQZ9NJBYys8RP7eB0P6E3+4Gni2vWLmyTAYwew5gbiFj5uR9viwuG7jUQ0DdP9T8dWzcMfr6lgErnloXNvTNtxOTYer3m60QcC6gaB+1N/5wMZNbj5snsUlN8BrwBvAGLRkHpfKUnNXqnxuDQSY4HnVF/Il6HA1MylpY5wzz0BrLjzHw7nHbNn26iWjJG6X0qoX4yS55vx5amrYCp62TMcK0mG93GYHguh0Dnk2ZoFyQtMaj9gEuSU+d6AXoFucAPBmu3NBZQbNIQj/nYGYjuOJiCn5wEJLhL5NINjrvh1GPwoc9/1AKdyZf+EcPS1X9XDgNLiF/gxwHCbUGWwRy50XQukyy7tjr/2ud0M+9q9lOm1s8cmbTtsxhRv9AwVKdyOkCpVvPyLtZXmxHXEVpxsO+VpgXCUpURKD6P7YkwALv1YonYP63OQxWqim05P/b6peumxAp0auMK5kjGqWkz6azRwN9GCbgJZNMpj3/5+WXkivq2MkggE62YfdZZaVrrrf4c7Is5GQUAxWVgw7nLodywhxIN7hf8m0J4jaB24bhZM0SN4VIV0o0CtgkATm3b2LiEOyxu5E8KTwSt10XniRwt6k4ah3cihk35EHPjtxHg4Zp0JUkHGMnwyRwpzHpmUIuJ++9OAnfMNPIZ2ewjaq+eDxFTmt94WjsP65seCK7N5N+iCDUeKgOXdCJeYfb7PpE10I2c3ZUWzQfyylw6clL/q+y5KCa8Mm2GJVaPeoLc2p9t7/ReRb6s7+bobNYiw/16CczaLxbcsKzJIqY+Qz 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)(366016)(1800799024)(7416014)(376014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: hixDBosmGcX7THMod8B9tK+eZvfOzRs0oLff00ATGOV1D8iC/HA9fMOQes/HgQgVtoDA3gcKRofLOj0nIS+V/BP5JjqzgOLASrYT6cv8ST4XrLY+PfxbpgUzqaM/ZQ6/q9ZaBxaf4b3Vtd+zcdqpl4ZhKtJd4rzSSlVBlFjIY7FrAhkXeyvlLighW8Sa4+cJ2G32XCF+oBu2kn82qB5eB8XtMozGB0rgCiq2nX+QADHQGfQvgKKfsU4oX+krVhYPyWceivN6uGKwlnruB4tSw2VT2c/mR4DFHajHqxmwsBBx3zO5T+OzFuBYANhrmvY0naRe2fUZq4dzsUYY1FkMV2RLmgzC0jXYSP1/fEjA6GIil9R7repmyOCnLn9ugm8n5pPnbTwhO9iZd/0sOPQVVv1j39jKxoIWTLznTLuyiY/2FdfA8GHJvD30I7WfSOXz9YWshuySzen4xuhHiljxaI1lztBhlvRoJM8T4n8RCC4RV3khf9i0OUrqfeQEv0lhwiqc2bmq3hWMD5tYD0LeaJGEUONlb1YwcaL40cw+hTR+pkRfFD2QObzPBYsLB2s4uz7W40botvV8PE1eojluVPaivnoEjeaV4FMke9/KHvfBH9APezf6q8Hd/jL4GZat1zwsCr5kd9lQLVO8xTtomgtU8XU7hUn1A2cFkeFVJ8WTbgTbKe9V0MQ4fAvIDVRHvPJhrm+fJOL0nzOArPBnZG7mNgHiDj06Hg4bMEQaPLqn7mcAj/O64ImqyuZZ115D9+mq4F7qvGXz00g0q49OZia7/dguNdvIVEOqudf+lsh3ubgj6aMvJjUCcuih/3rWgDU0f00KOX2edsebykzAIjYe42IKZ0YjeAh0GkczAlM7lawDKj2M1jb8xMzljvLBAqcOr/v/MZB+6YN3iTbB7bQbmN9QytH/8Y4hjkxWVfIgJA6CGzG1W7NYiSjQUhEMcacymF4M/GE3AIfLFcgsV+D0cWPE+SFpSngMlUr7C5kJMI9mW+1Fj1w4GWSAnHxvekjXs7d41eSGgL+LxMQBw+pVzu0HFScGfKPfe7FMguYRFFoBQ7i0K3Ajoj6Kh8YPBmAuv/tgJnvTQkWsPhOuSbEAFnPu2TFHuABZXtTyDP+0G4dJNdz6RBTr8jDGLypyvdjngfnwlGIuFwoZogfeNY7M9LMwhG0U5wEOk8J1N/wK07cErYqRPXB6HK5aYZh7l7TUUaHxSvz1ay9xzn/pTVSp3xlsIP6R0YxZA5pC+7Wgiz3b8DLL1hyWnHS0uGw5pc89MiQuvz2aI2/hSk7cud74RhEB3GZlNUZ0w61iuW2tbxUlUbmj4wI2R/4SQYErfUPVy5t+kPAYb1gS3eIvTNETjeKvS0uvRz0tzf+cc2HtSvGvgGhurliC2rU9pJ4QCSshoDAYZDDYRkxO0v5XAF6r9lTyawYCS6CjJ+tbn1hbgdCiAiu93pVh6xBGFuVQvaxFnoIl6AI27h/jRuf5L5VzntISTveGgphks/t48keMah5+GA27dvUAp/wZrb2eef5KC2PO18ZFztq9Zc2OC+wZW8KZG5Co4Y3qwQwkJ5nSjH5fwIASczpW665CTHUQ X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: ad2d3d9c-6c5f-4c5f-719f-08dd2f827038 X-MS-Exchange-CrossTenant-AuthSource: DS0PR12MB7726.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Jan 2025 01:19:03.2756 (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: TV/7+YD7wHy7iQEtRxK5X4XmrQf7o0+mQxrpg5AXOZKcwsFvbJmTObBSKazPkIjLJkcADDDcfhPyRKoF+cKBsw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: LV8PR12MB9264 PFN_DEV is used by callers of dax_direct_access() to figure out if the returned PFN is associated with a page or not. However all DAX PFNs now require an assoicated ZONE_DEVICE page so can assume a page exists. Other users of PFN_DEV were setting it before calling vmf_insert_mixed(). This is unnecessary as it is no longer checked, instead relying on pfn_valid() to determine if there is an associated page or not. Signed-off-by: Alistair Popple Reviewed-by: Christoph Hellwig --- drivers/gpu/drm/gma500/fbdev.c | 2 +- drivers/gpu/drm/omapdrm/omap_gem.c | 5 ++--- drivers/s390/block/dcssblk.c | 3 +-- drivers/vfio/pci/vfio_pci_core.c | 6 ++---- fs/cramfs/inode.c | 2 +- include/linux/pfn_t.h | 4 +--- mm/memory.c | 4 ++-- 7 files changed, 10 insertions(+), 16 deletions(-) diff --git a/drivers/gpu/drm/gma500/fbdev.c b/drivers/gpu/drm/gma500/fbdev.c index 8edefea..109efdc 100644 --- a/drivers/gpu/drm/gma500/fbdev.c +++ b/drivers/gpu/drm/gma500/fbdev.c @@ -33,7 +33,7 @@ static vm_fault_t psb_fbdev_vm_fault(struct vm_fault *vmf) vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); for (i = 0; i < page_num; ++i) { - err = vmf_insert_mixed(vma, address, __pfn_to_pfn_t(pfn, PFN_DEV)); + err = vmf_insert_mixed(vma, address, __pfn_to_pfn_t(pfn, 0)); if (unlikely(err & VM_FAULT_ERROR)) break; address += PAGE_SIZE; diff --git a/drivers/gpu/drm/omapdrm/omap_gem.c b/drivers/gpu/drm/omapdrm/omap_gem.c index b9c67e4..9df05b2 100644 --- a/drivers/gpu/drm/omapdrm/omap_gem.c +++ b/drivers/gpu/drm/omapdrm/omap_gem.c @@ -371,8 +371,7 @@ static vm_fault_t omap_gem_fault_1d(struct drm_gem_object *obj, VERB("Inserting %p pfn %lx, pa %lx", (void *)vmf->address, pfn, pfn << PAGE_SHIFT); - return vmf_insert_mixed(vma, vmf->address, - __pfn_to_pfn_t(pfn, PFN_DEV)); + return vmf_insert_mixed(vma, vmf->address, __pfn_to_pfn_t(pfn, 0)); } /* Special handling for the case of faulting in 2d tiled buffers */ @@ -468,7 +467,7 @@ static vm_fault_t omap_gem_fault_2d(struct drm_gem_object *obj, for (i = n; i > 0; i--) { ret = vmf_insert_mixed(vma, - vaddr, __pfn_to_pfn_t(pfn, PFN_DEV)); + vaddr, __pfn_to_pfn_t(pfn, 0)); if (ret & VM_FAULT_ERROR) break; pfn += priv->usergart[fmt].stride_pfn; diff --git a/drivers/s390/block/dcssblk.c b/drivers/s390/block/dcssblk.c index 1ffc86e..8a0d590 100644 --- a/drivers/s390/block/dcssblk.c +++ b/drivers/s390/block/dcssblk.c @@ -924,8 +924,7 @@ __dcssblk_direct_access(struct dcssblk_dev_info *dev_info, pgoff_t pgoff, if (kaddr) *kaddr = __va(dev_info->start + offset); if (pfn) - *pfn = __pfn_to_pfn_t(PFN_DOWN(dev_info->start + offset), - PFN_DEV); + *pfn = __pfn_to_pfn_t(PFN_DOWN(dev_info->start + offset), 0); return (dev_sz - offset) / PAGE_SIZE; } diff --git a/drivers/vfio/pci/vfio_pci_core.c b/drivers/vfio/pci/vfio_pci_core.c index 90240c8..e6b6c01 100644 --- a/drivers/vfio/pci/vfio_pci_core.c +++ b/drivers/vfio/pci/vfio_pci_core.c @@ -1680,14 +1680,12 @@ static vm_fault_t vfio_pci_mmap_huge_fault(struct vm_fault *vmf, break; #ifdef CONFIG_ARCH_SUPPORTS_PMD_PFNMAP case PMD_ORDER: - ret = vmf_insert_pfn_pmd(vmf, __pfn_to_pfn_t(pfn + pgoff, - PFN_DEV), false); + ret = vmf_insert_pfn_pmd(vmf, __pfn_to_pfn_t(pfn + pgoff, 0), false); break; #endif #ifdef CONFIG_ARCH_SUPPORTS_PUD_PFNMAP case PUD_ORDER: - ret = vmf_insert_pfn_pud(vmf, __pfn_to_pfn_t(pfn + pgoff, - PFN_DEV), false); + ret = vmf_insert_pfn_pud(vmf, __pfn_to_pfn_t(pfn + pgoff, 0), false); break; #endif default: diff --git a/fs/cramfs/inode.c b/fs/cramfs/inode.c index b84d174..820a664 100644 --- a/fs/cramfs/inode.c +++ b/fs/cramfs/inode.c @@ -412,7 +412,7 @@ static int cramfs_physmem_mmap(struct file *file, struct vm_area_struct *vma) for (i = 0; i < pages && !ret; i++) { vm_fault_t vmf; unsigned long off = i * PAGE_SIZE; - pfn_t pfn = phys_to_pfn_t(address + off, PFN_DEV); + pfn_t pfn = phys_to_pfn_t(address + off, 0); vmf = vmf_insert_mixed(vma, vma->vm_start + off, pfn); if (vmf & VM_FAULT_ERROR) ret = vm_fault_to_errno(vmf, 0); diff --git a/include/linux/pfn_t.h b/include/linux/pfn_t.h index 75bb77c..034b5b0 100644 --- a/include/linux/pfn_t.h +++ b/include/linux/pfn_t.h @@ -11,10 +11,8 @@ * PFN_MAP - pfn has a dynamic page mapping established by a device driver */ #define PFN_FLAGS_MASK (((u64) (~PAGE_MASK)) << (BITS_PER_LONG_LONG - PAGE_SHIFT)) -#define PFN_DEV (1ULL << (BITS_PER_LONG_LONG - 3)) -#define PFN_FLAGS_TRACE \ - { PFN_DEV, "DEV" } +#define PFN_FLAGS_TRACE { } static inline pfn_t __pfn_to_pfn_t(unsigned long pfn, u64 flags) { diff --git a/mm/memory.c b/mm/memory.c index e1d647c..5f7a441 100644 --- a/mm/memory.c +++ b/mm/memory.c @@ -2510,9 +2510,9 @@ vm_fault_t vmf_insert_pfn_prot(struct vm_area_struct *vma, unsigned long addr, if (!pfn_modify_allowed(pfn, pgprot)) return VM_FAULT_SIGBUS; - track_pfn_insert(vma, &pgprot, __pfn_to_pfn_t(pfn, PFN_DEV)); + track_pfn_insert(vma, &pgprot, __pfn_to_pfn_t(pfn, 0)); - return insert_pfn(vma, addr, __pfn_to_pfn_t(pfn, PFN_DEV), pgprot, + return insert_pfn(vma, addr, __pfn_to_pfn_t(pfn, 0), pgprot, false); } EXPORT_SYMBOL(vmf_insert_pfn_prot); From patchwork Wed Jan 8 01:18:47 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13929871 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2042.outbound.protection.outlook.com [40.107.92.42]) (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 69B1516DC3C; Wed, 8 Jan 2025 01:19:11 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.92.42 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299155; cv=fail; b=liYBkwUoCv9odt/8hkZE+45fko5zMGgwG827SFZEnm7Xk9FrXPvbAdGNGf8YyjFanXF6vMTdTyLX71Rp0V89f4Bq8ecp39xkq8p+Aj/BEI86JuKFffTSDCu38fSJ8JlQqpcLCfiyDYE9ZLiXzQU6y5e5vkBI1dhB8LNZk7ZHX3c= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299155; c=relaxed/simple; bh=imEXYo6PWRqWt0YG56xUfgOPkM1B/wjcCocENvTCP78=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=s++dfQf7BobK38tivhW3UIx2Gu+THK5IbUaBQ79+5PwihpuDfLrIbXfZaizGboxupKHz60k7Kkw1mYstUsNrfHOocY5RWDPw/BCZsXCCthD0luOPMzeCwR/vfYvb9/EZ3E+uynPnAfjrzHtqf4atF6f1bALKj1Aw1K1dA2aKu/E= 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=dsdTE+UC; arc=fail smtp.client-ip=40.107.92.42 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="dsdTE+UC" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=t5gbEK9MYXULwWb00s6PsQFGKEuMcawpjFevKpVe6lHK7VH927OE+naTYUQD97hcB2PEi7CjIKYl0yJdcC4SFp04c1G8SFEWPN+dZ2Zr8xh6NBiNfrlTeSs6tEGH2ldbL8yaD1WFMunXuNPZwGLSFkXAAGhd1UywqkhWKfE64gzlDGJET3tsqOLeYPlWFEW1xtRK/3g4JPdbf7ywFt8dWLSUoSZDD/oQQx7CJmOUP52QM/9V6Zcy5W47Sst4UT8jTNfv7wYygjurFiA22Pnq4/fHFfTDdgOBGucGdib/yiY1EW4M2tawCI6zVbmTzPGbxWcdGR13vLaDev7cd1UQiA== 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=+01YGYbvYAUwfwnW+mka5lXzZERWKQeBE7YO9Hkv9Xo=; b=BHG/srZSRQYFNrk6yh2Yzx7yzj6JnTnj0WvAwKsMdMkO8YU60JRvxBjzftOsICLZxLxEcbTA3cHJAfQitJM6s1RmsaOXLNDBeL74vXyINm1RWYfvEMuttPiP4tdoLRDysGz3lQUebUIi000zdp5K29siEypuuzNKTJt/seWXOGeevC6VT9+S9no8aIVdy0nTXKBUSPmiIIVnT16V0HU/omBe8+UR7Y+jkocPE/U0eWcTrn1+HP8lq9DpY8T21ZtBr6Kvcb8T7qrIRfkZYwmQUlCnACBTGT/sRZASokTAh7IOA6rgySQrJ6cWyUbXJYfq5EHOkSEHsEA9O+CPNG76Sg== 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=+01YGYbvYAUwfwnW+mka5lXzZERWKQeBE7YO9Hkv9Xo=; b=dsdTE+UCvgBClkKWDoTov7OgFjbv2zKsbrBkn4Lu8tUO7/pp7knuXkK5KT9gbfi3KFCN+XgxDDklU1pezOxP+L4HXYKO2kpkVUEoNiceJfcfC7w91ouBqrwRKaKhwo7XSv4twJmUHp6eB++/+TwjEplub/FQ38EXv5+WyXGH157LgsVnTmlbdmHOu7OYCAU9+RxeKJ92s0KxiZlA+rzCsQ4qSVpvXz66mq6qCuvq/MDp9zfURs5uNUeF7v3r0FSpxWmcxcWT0IQe8OX2DPy5qwzNcvCMU6RClYY+9mkVlfM+eQ/lcGn3h9jnuPPOoDyds81XvYUlmF23pqJfiBwu0w== 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 LV8PR12MB9264.namprd12.prod.outlook.com (2603:10b6:408:1e8::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.10; Wed, 8 Jan 2025 01:19:08 +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; Wed, 8 Jan 2025 01:19:08 +0000 From: Alistair Popple To: akpm@linux-foundation.org, linux-mm@kvack.org Cc: Alistair Popple , gerald.schaefer@linux.ibm.com, dan.j.williams@intel.com, jgg@ziepe.ca, willy@infradead.org, david@redhat.com, linux-kernel@vger.kernel.org, nvdimm@lists.linux.dev, linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, jhubbard@nvidia.com, hch@lst.de Subject: [RFC 3/4] mm: Remove callers of pfn_t functionality Date: Wed, 8 Jan 2025 12:18:47 +1100 Message-ID: X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SY5P282CA0054.AUSP282.PROD.OUTLOOK.COM (2603:10c6:10:20a::13) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) Precedence: bulk X-Mailing-List: linux-xfs@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|LV8PR12MB9264:EE_ X-MS-Office365-Filtering-Correlation-Id: f816cf25-bc39-4e5e-ad65-08dd2f827303 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014; X-Microsoft-Antispam-Message-Info: 5lyaNY0gDcgLitbeTg8D2pBOaLj1xng53Qtssswr7WO+WMc4AfKxmfXdtpHJyh9rj9DXky8n6mRks6uL+nnByZiW05RBvQVQJe3zMOe8XIdXpONzfPdUXL4Vu/IvUPsIedqxPg2Po4JwNPVMuPxnwUr+1eI/3QqYCzqC8nZHdFqga5sdTtyJ/Xy702XYmpg9yqceYvaPBNWvHU3YGPy1aEqpp51MsiV02XdhTMgkWcz5vJM8Wd4Y93zZ4S/vQnAKjML4fhhF9L/WtUAtG01mv4PyrRYh8ZP8EpCivcfPy37ql24qVwsYrBif1rwgQtxZu6sCoEqQxk6aFsU2eqLXuRNot3Z2x6HfDvDz/Hnr5Lfb4ECj3fJG+qnNmw5A0dmfTX7KfCf/HfF2mvAnQ1XLMoIUkK6HuXna7dfSrLscvmfdaJw9pdAUlpZIBqL6v5ahwy+a8Go8iKWqx+1KYYMFHgMieRE+Zawge07oAbcJhHdCVQphYAvbX8ODasOnZK8JPTFqMY/C4qtyoPalnXraS3nuTHkOwmYg1+FUHRP6d6oh/xEK/TVW5T55dsXWUxqrywngv6/RO8FIzYYOdlfM62oxX0c8kSz+fd3Lz6io+O9j3OzWwajGgLjh5Hzs4lEg8YI4WDPwio1dZLeU5xUldRcNzvOMSdOzH3dRnm0i74fAvofZWWBp3UU+Fwn2ZgK3x2wpmd+u3VS4KUY+Edzbye1SZ6fgMAsWqh6Az7g+NPbqsf3C33NEFP0NgN0EqiTiojWbzfVfwPvZU8Hf46qtjsTF44mNLjbRzq9Rf1yXsvufX+FkQ3XEBG3+XYBX8keu5wklO3eo3pSDol5M/c7hgOCbhzbAoS1UHnjLeNCybGPtroU3/BnTqvAiT/jzbW3NmL+Xjzz9My5qjqJ6lCmgzuqU4wgZCeIriowxtw1VzPX4xfT2ZW5WfOyxfJBkuLH1wtlqW1kuHCOt7mWViLw8Nl6asuMp5hpUcIPikjvNtJu5sWuVW+Cf+CdH9mKu/bUQi0XHJuCZAj5p6uUaYksY8RxsKboa7dX5C/OLuur69FiapSCTJZrYhoynPsqLupQ0VXaJPaoipNgQ5RUanc6rHswMj1I3Bq0+ieNW6D+4F/1sdPMvtY9fxUZ8Q763aiRDOSef7dvc9wHsKI0EqK8WbOvpmQgESWTPMLG2NjFQMlS0rYdCTmeRSVbD3zx9w/tyHaDr+6wqEr7JeAijvEzEAsWL+/sVHjejNJX7NCrc71HoSo2heTTwKpRD62nfo47bqazIEIl30eehogrvt83nSnJYw0A4cGPlYe6b1a2LzmkYo8v3xm/k/cysSRcqnhC5U28eNjYtv1YfJvoR08xDxDgsAhATcBUTmL7RC2wswmnjtlZVUjwtz1vgcRF5zw6N 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)(366016)(1800799024)(7416014)(376014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 4LU1riJOOrqfUdktp1u5lXDp5JFJq7UId/18BAhmWWHU9YxNRA6fVZwPabMvxxcPw+fDlUbtfF2qGzTDii+hXjtXUiKF5bq8BBTR2Ic6e0dt8XzuMDVQvgfxLeQA+LTxvh/O2ji0KyHQKK0qy3sy5t60NzskDUYGbVgg4W8hkHBtfP/oRfUGo+rCHqzEWmwL10GYmauN027G+oUBvKdUKuFgXnvz3U19otxYNNcyjSUX9HzzxaqdSL+OMoo9qBX/AdbhTRRO0xmSxltmIlBPKYcm8x+PZ4R55jXMmrf9CY/kAeS7aA36znm1n3WoknlcjEGWTDiRU22h7nHiuo4KbzhZwxSTsR0A0CGTNUx7fVQYRO31bn+qRChQEeYlSD5fM0UG0JNhfwX1uS6w9cqlbhxtkVvno798wNexOyaWsC4bAQOTkXmFBnXIe6Rl4KvI1mu2asrb4Z/EnT84a3AGDBUYq4BOmGJnwjZmmL7flOBGfavfGddnWFhQ/A2mYGHv8zkCg9cqxXx5LRJHt3Q22LwSCi6s18dyrsq8y58pvREg8XuqOrlQyMVMH0xf9nb0oxg4rq6sHJHoHdqg0rwKKz0XzlkJ429J2zAb1X5bitLT2waBEDUw7E+SSXVFiL9mLbzHOfSUIKPCn09B/bPuQveJneZfiVF1RluUPLyJsn/c1i5Jq7XO73DQsm2Zv4T3Cqp13oyPlZUEEZuXqheCagIkA1sYMODpnsPpwA8xZYCS1pk/+Xb6KMxCONEvSerRYlz4bkF/V5keVIIKwho0lt0/+VycTxLqfu9dkjrIQEWWEQGmCuhd4JOMgaEknWLa4QsYVeUG9ZPBNASS9JIQeJrD8DOGA9DIsSR7RLZZZHxTijhHG7SIS1RRKUJNdue4iPl1ii4Pl+95gHCs9gPaALYxIwcTtXbmqulXfgtdgp//UTA7Lu+h1xNmPqui3H4bpXCY7bsosc4EsfrtYjTxzl8FU3n5+r2cL6uREBOmoFZm3InLe0slLszuxYXRTX/eqR/DOvt27fnZx2Vwjwn3lGnGj0gdrT0Avannfuf0NDZCu4yN2lYM7Eig0Zx6bKk5BvU22OlJwzkISBzMl4dqUBUS+v+NawsPmqX6HAGNEX4yf2Np5nByr8bY0UGfAC/dL5y7uBpRqFavERGYs11gwlnLXQexNKO6CxWrW9Shkb+C4SkWtj58BZZVNLMn4j5+IYVMoeTYfG5wYPtXGBZcgDfFFQhKUexUDt3Xath3BhfJ0BZybzuqfWFfMxOoEGWfyrvOIjHLGBbGIw9ZWBoI/bBvqc5qIpLgqvHUDgkVMH7Y3aMUSJz5ZABEA1UTO62SNBz15HjQERQTJU0h91G4VG2SoFNik25k1dbO9E9qHAG4K9JTPYrTSf+Eo0NfiRjRuEt5jQSlGmBx59NG8Y3nDvSHJv+CpsibFgj/GjXUo03wDglkQocR2PkOISxZ7d0B75UwTS5gZrFTIWd4OrdG5x05AUgntEj2Lm07gAJMeIILpuPmb2UabqGKSL5n94/9ed5hjYSzOxbNh29ghTOvXZbOqr5egIRxMnCzjSVLQjdhiUEm6vLQWnl3AJppYB9y X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: f816cf25-bc39-4e5e-ad65-08dd2f827303 X-MS-Exchange-CrossTenant-AuthSource: DS0PR12MB7726.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Jan 2025 01:19:08.1343 (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: nBoH0MyYkI3+SzWKmaFje8Nf0UlcCZGnLgXfpr0NNPrNE8X9PvXCZYVIaUQA+V4cTBjDPsg5ddcy2TuzyXYgfQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: LV8PR12MB9264 All PFN_* pfn_t flags have been removed. Therefore there is no longer a need for the pfn_t type and all uses can be replaced with normal pfns. Signed-off-by: Alistair Popple Reviewed-by: Christoph Hellwig --- I'm guessing people will want this split up into several patches for merging/review. If so I will do that once the pre-requisite series have landed in Linus tree and we've decided if this RFC is worthwhile. --- arch/x86/mm/pat/memtype.c | 6 +-- drivers/dax/device.c | 23 ++++++------- drivers/dax/hmem/hmem.c | 1 +- drivers/dax/kmem.c | 1 +- drivers/dax/pmem.c | 1 +- drivers/dax/super.c | 3 +-- drivers/gpu/drm/exynos/exynos_drm_gem.c | 1 +- drivers/gpu/drm/gma500/fbdev.c | 3 +-- drivers/gpu/drm/i915/gem/i915_gem_mman.c | 1 +- drivers/gpu/drm/msm/msm_gem.c | 1 +- drivers/gpu/drm/omapdrm/omap_gem.c | 6 +-- drivers/gpu/drm/v3d/v3d_bo.c | 1 +- drivers/md/dm-linear.c | 2 +- drivers/md/dm-log-writes.c | 2 +- drivers/md/dm-stripe.c | 2 +- drivers/md/dm-target.c | 2 +- drivers/md/dm-writecache.c | 9 ++--- drivers/md/dm.c | 2 +- drivers/nvdimm/pmem.c | 8 +--- drivers/nvdimm/pmem.h | 4 +-- drivers/s390/block/dcssblk.c | 9 ++--- drivers/vfio/pci/vfio_pci_core.c | 5 +-- fs/cramfs/inode.c | 4 +-- fs/dax.c | 45 ++++++++++++------------- fs/ext4/file.c | 2 +- fs/fuse/dax.c | 3 +-- fs/fuse/virtio_fs.c | 5 +-- fs/xfs/xfs_file.c | 2 +- include/linux/dax.h | 8 ++-- include/linux/device-mapper.h | 2 +- include/linux/huge_mm.h | 4 +- include/linux/mm.h | 4 +- include/linux/pgtable.h | 4 +- include/trace/events/fs_dax.h | 6 +-- mm/debug_vm_pgtable.c | 1 +- mm/huge_memory.c | 23 ++++++------- mm/memory.c | 32 ++++++++---------- mm/memremap.c | 1 +- mm/migrate.c | 1 +- tools/testing/nvdimm/pmem-dax.c | 6 +-- tools/testing/nvdimm/test/iomap.c | 7 +---- 41 files changed, 108 insertions(+), 145 deletions(-) diff --git a/arch/x86/mm/pat/memtype.c b/arch/x86/mm/pat/memtype.c index feb8cc6..508f807 100644 --- a/arch/x86/mm/pat/memtype.c +++ b/arch/x86/mm/pat/memtype.c @@ -36,7 +36,6 @@ #include #include #include -#include #include #include #include @@ -1053,7 +1052,8 @@ int track_pfn_remap(struct vm_area_struct *vma, pgprot_t *prot, return 0; } -void track_pfn_insert(struct vm_area_struct *vma, pgprot_t *prot, pfn_t pfn) +void track_pfn_insert(struct vm_area_struct *vma, pgprot_t *prot, + unsigned long pfn) { enum page_cache_mode pcm; @@ -1061,7 +1061,7 @@ void track_pfn_insert(struct vm_area_struct *vma, pgprot_t *prot, pfn_t pfn) return; /* Set prot based on lookup */ - pcm = lookup_memtype(pfn_t_to_phys(pfn)); + pcm = lookup_memtype(PFN_PHYS(pfn)); *prot = __pgprot((pgprot_val(*prot) & (~_PAGE_CACHE_MASK)) | cachemode2protval(pcm)); } diff --git a/drivers/dax/device.c b/drivers/dax/device.c index fd22dbf..37ffb2f 100644 --- a/drivers/dax/device.c +++ b/drivers/dax/device.c @@ -4,7 +4,6 @@ #include #include #include -#include #include #include #include @@ -73,7 +72,7 @@ __weak phys_addr_t dax_pgoff_to_phys(struct dev_dax *dev_dax, pgoff_t pgoff, return -1; } -static void dax_set_mapping(struct vm_fault *vmf, pfn_t pfn, +static void dax_set_mapping(struct vm_fault *vmf, unsigned long pfn, unsigned long fault_size) { unsigned long i, nr_pages = fault_size / PAGE_SIZE; @@ -89,7 +88,7 @@ static void dax_set_mapping(struct vm_fault *vmf, pfn_t pfn, ALIGN_DOWN(vmf->address, fault_size)); for (i = 0; i < nr_pages; i++) { - struct page *page = pfn_to_page(pfn_t_to_pfn(pfn) + i); + struct page *page = pfn_to_page(pfn + i); page = compound_head(page); if (page->mapping) @@ -105,7 +104,7 @@ static vm_fault_t __dev_dax_pte_fault(struct dev_dax *dev_dax, { struct device *dev = &dev_dax->dev; phys_addr_t phys; - pfn_t pfn; + unsigned long pfn; unsigned int fault_size = PAGE_SIZE; if (check_vma(dev_dax, vmf->vma, __func__)) @@ -126,11 +125,11 @@ static vm_fault_t __dev_dax_pte_fault(struct dev_dax *dev_dax, return VM_FAULT_SIGBUS; } - pfn = phys_to_pfn_t(phys, 0); + pfn = PHYS_PFN(phys); dax_set_mapping(vmf, pfn, fault_size); - return vmf_insert_page_mkwrite(vmf, pfn_t_to_page(pfn), + return vmf_insert_page_mkwrite(vmf, pfn_to_page(pfn), vmf->flags & FAULT_FLAG_WRITE); } @@ -141,7 +140,7 @@ static vm_fault_t __dev_dax_pmd_fault(struct dev_dax *dev_dax, struct device *dev = &dev_dax->dev; phys_addr_t phys; pgoff_t pgoff; - pfn_t pfn; + unsigned long pfn; unsigned int fault_size = PMD_SIZE; if (check_vma(dev_dax, vmf->vma, __func__)) @@ -170,11 +169,11 @@ static vm_fault_t __dev_dax_pmd_fault(struct dev_dax *dev_dax, return VM_FAULT_SIGBUS; } - pfn = phys_to_pfn_t(phys, 0); + pfn = PHYS_PFN(phys); dax_set_mapping(vmf, pfn, fault_size); - return vmf_insert_folio_pmd(vmf, page_folio(pfn_t_to_page(pfn)), + return vmf_insert_folio_pmd(vmf, page_folio(pfn_to_page(pfn)), vmf->flags & FAULT_FLAG_WRITE); } @@ -186,7 +185,7 @@ static vm_fault_t __dev_dax_pud_fault(struct dev_dax *dev_dax, struct device *dev = &dev_dax->dev; phys_addr_t phys; pgoff_t pgoff; - pfn_t pfn; + unsigned long pfn; unsigned int fault_size = PUD_SIZE; @@ -216,11 +215,11 @@ static vm_fault_t __dev_dax_pud_fault(struct dev_dax *dev_dax, return VM_FAULT_SIGBUS; } - pfn = phys_to_pfn_t(phys, 0); + pfn = PHYS_PFN(phys); dax_set_mapping(vmf, pfn, fault_size); - return vmf_insert_folio_pud(vmf, page_folio(pfn_t_to_page(pfn)), + return vmf_insert_folio_pud(vmf, page_folio(pfn_to_page(pfn)), vmf->flags & FAULT_FLAG_WRITE); } #else diff --git a/drivers/dax/hmem/hmem.c b/drivers/dax/hmem/hmem.c index 5e7c53f..c18451a 100644 --- a/drivers/dax/hmem/hmem.c +++ b/drivers/dax/hmem/hmem.c @@ -2,7 +2,6 @@ #include #include #include -#include #include #include "../bus.h" diff --git a/drivers/dax/kmem.c b/drivers/dax/kmem.c index e97d47f..87b5321 100644 --- a/drivers/dax/kmem.c +++ b/drivers/dax/kmem.c @@ -5,7 +5,6 @@ #include #include #include -#include #include #include #include diff --git a/drivers/dax/pmem.c b/drivers/dax/pmem.c index c8ebf4e..bee9306 100644 --- a/drivers/dax/pmem.c +++ b/drivers/dax/pmem.c @@ -2,7 +2,6 @@ /* Copyright(c) 2016 - 2018 Intel Corporation. All rights reserved. */ #include #include -#include #include "../nvdimm/pfn.h" #include "../nvdimm/nd.h" #include "bus.h" diff --git a/drivers/dax/super.c b/drivers/dax/super.c index e16d1d4..54c480e 100644 --- a/drivers/dax/super.c +++ b/drivers/dax/super.c @@ -7,7 +7,6 @@ #include #include #include -#include #include #include #include @@ -148,7 +147,7 @@ enum dax_device_flags { * pages accessible at the device relative @pgoff. */ long dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, - enum dax_access_mode mode, void **kaddr, pfn_t *pfn) + enum dax_access_mode mode, void **kaddr, unsigned long *pfn) { long avail; diff --git a/drivers/gpu/drm/exynos/exynos_drm_gem.c b/drivers/gpu/drm/exynos/exynos_drm_gem.c index 4787fee..84b2172 100644 --- a/drivers/gpu/drm/exynos/exynos_drm_gem.c +++ b/drivers/gpu/drm/exynos/exynos_drm_gem.c @@ -7,7 +7,6 @@ #include -#include #include #include diff --git a/drivers/gpu/drm/gma500/fbdev.c b/drivers/gpu/drm/gma500/fbdev.c index 109efdc..68b825f 100644 --- a/drivers/gpu/drm/gma500/fbdev.c +++ b/drivers/gpu/drm/gma500/fbdev.c @@ -6,7 +6,6 @@ **************************************************************************/ #include -#include #include #include @@ -33,7 +32,7 @@ static vm_fault_t psb_fbdev_vm_fault(struct vm_fault *vmf) vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); for (i = 0; i < page_num; ++i) { - err = vmf_insert_mixed(vma, address, __pfn_to_pfn_t(pfn, 0)); + err = vmf_insert_mixed(vma, address, pfn); if (unlikely(err & VM_FAULT_ERROR)) break; address += PAGE_SIZE; diff --git a/drivers/gpu/drm/i915/gem/i915_gem_mman.c b/drivers/gpu/drm/i915/gem/i915_gem_mman.c index 21274aa..d6ac557 100644 --- a/drivers/gpu/drm/i915/gem/i915_gem_mman.c +++ b/drivers/gpu/drm/i915/gem/i915_gem_mman.c @@ -6,7 +6,6 @@ #include #include -#include #include #include diff --git a/drivers/gpu/drm/msm/msm_gem.c b/drivers/gpu/drm/msm/msm_gem.c index ebc9ba6..1c27500 100644 --- a/drivers/gpu/drm/msm/msm_gem.c +++ b/drivers/gpu/drm/msm/msm_gem.c @@ -9,7 +9,6 @@ #include #include #include -#include #include #include diff --git a/drivers/gpu/drm/omapdrm/omap_gem.c b/drivers/gpu/drm/omapdrm/omap_gem.c index 9df05b2..381552b 100644 --- a/drivers/gpu/drm/omapdrm/omap_gem.c +++ b/drivers/gpu/drm/omapdrm/omap_gem.c @@ -8,7 +8,6 @@ #include #include #include -#include #include #include @@ -371,7 +370,7 @@ static vm_fault_t omap_gem_fault_1d(struct drm_gem_object *obj, VERB("Inserting %p pfn %lx, pa %lx", (void *)vmf->address, pfn, pfn << PAGE_SHIFT); - return vmf_insert_mixed(vma, vmf->address, __pfn_to_pfn_t(pfn, 0)); + return vmf_insert_mixed(vma, vmf->address, pfn); } /* Special handling for the case of faulting in 2d tiled buffers */ @@ -466,8 +465,7 @@ static vm_fault_t omap_gem_fault_2d(struct drm_gem_object *obj, pfn, pfn << PAGE_SHIFT); for (i = n; i > 0; i--) { - ret = vmf_insert_mixed(vma, - vaddr, __pfn_to_pfn_t(pfn, 0)); + ret = vmf_insert_mixed(vma, vaddr, pfn); if (ret & VM_FAULT_ERROR) break; pfn += priv->usergart[fmt].stride_pfn; diff --git a/drivers/gpu/drm/v3d/v3d_bo.c b/drivers/gpu/drm/v3d/v3d_bo.c index bb78155..c41476d 100644 --- a/drivers/gpu/drm/v3d/v3d_bo.c +++ b/drivers/gpu/drm/v3d/v3d_bo.c @@ -16,7 +16,6 @@ */ #include -#include #include #include "v3d_drv.h" diff --git a/drivers/md/dm-linear.c b/drivers/md/dm-linear.c index 49fb0f6..ba676e3 100644 --- a/drivers/md/dm-linear.c +++ b/drivers/md/dm-linear.c @@ -168,7 +168,7 @@ static struct dax_device *linear_dax_pgoff(struct dm_target *ti, pgoff_t *pgoff) static long linear_dax_direct_access(struct dm_target *ti, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { struct dax_device *dax_dev = linear_dax_pgoff(ti, &pgoff); diff --git a/drivers/md/dm-log-writes.c b/drivers/md/dm-log-writes.c index 8d7df83..4c6aed7 100644 --- a/drivers/md/dm-log-writes.c +++ b/drivers/md/dm-log-writes.c @@ -891,7 +891,7 @@ static struct dax_device *log_writes_dax_pgoff(struct dm_target *ti, static long log_writes_dax_direct_access(struct dm_target *ti, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { struct dax_device *dax_dev = log_writes_dax_pgoff(ti, &pgoff); diff --git a/drivers/md/dm-stripe.c b/drivers/md/dm-stripe.c index 4112071..5804bf2 100644 --- a/drivers/md/dm-stripe.c +++ b/drivers/md/dm-stripe.c @@ -316,7 +316,7 @@ static struct dax_device *stripe_dax_pgoff(struct dm_target *ti, pgoff_t *pgoff) static long stripe_dax_direct_access(struct dm_target *ti, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { struct dax_device *dax_dev = stripe_dax_pgoff(ti, &pgoff); diff --git a/drivers/md/dm-target.c b/drivers/md/dm-target.c index 652627a..2af5a95 100644 --- a/drivers/md/dm-target.c +++ b/drivers/md/dm-target.c @@ -255,7 +255,7 @@ static void io_err_io_hints(struct dm_target *ti, struct queue_limits *limits) static long io_err_dax_direct_access(struct dm_target *ti, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { return -EIO; } diff --git a/drivers/md/dm-writecache.c b/drivers/md/dm-writecache.c index 7ce8847..27d240d 100644 --- a/drivers/md/dm-writecache.c +++ b/drivers/md/dm-writecache.c @@ -13,7 +13,6 @@ #include #include #include -#include #include #include #include "dm-io-tracker.h" @@ -256,7 +255,7 @@ static int persistent_memory_claim(struct dm_writecache *wc) int r; loff_t s; long p, da; - pfn_t pfn; + unsigned long pfn; int id; struct page **pages; sector_t offset; @@ -290,7 +289,7 @@ static int persistent_memory_claim(struct dm_writecache *wc) r = da; goto err2; } - if (!pfn_t_has_page(pfn)) { + if (!pfn_valid(pfn)) { wc->memory_map = NULL; r = -EOPNOTSUPP; goto err2; @@ -314,12 +313,12 @@ static int persistent_memory_claim(struct dm_writecache *wc) r = daa ? daa : -EINVAL; goto err3; } - if (!pfn_t_has_page(pfn)) { + if (!pfn_valid(pfn)) { r = -EOPNOTSUPP; goto err3; } while (daa-- && i < p) { - pages[i++] = pfn_t_to_page(pfn); + pages[i++] = pfn_to_page(pfn); pfn.val++; if (!(i & 15)) cond_resched(); diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 12ecf07..eb68926 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -1232,7 +1232,7 @@ static struct dm_target *dm_dax_get_live_target(struct mapped_device *md, static long dm_dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { struct mapped_device *md = dax_get_private(dax_dev); sector_t sector = pgoff * PAGE_SECTORS; diff --git a/drivers/nvdimm/pmem.c b/drivers/nvdimm/pmem.c index 785b2d2..ae4f5a4 100644 --- a/drivers/nvdimm/pmem.c +++ b/drivers/nvdimm/pmem.c @@ -20,7 +20,6 @@ #include #include #include -#include #include #include #include @@ -242,7 +241,7 @@ static void pmem_submit_bio(struct bio *bio) /* see "strong" declaration in tools/testing/nvdimm/pmem-dax.c */ __weak long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { resource_size_t offset = PFN_PHYS(pgoff) + pmem->data_offset; sector_t sector = PFN_PHYS(pgoff) >> SECTOR_SHIFT; @@ -254,7 +253,7 @@ __weak long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff, if (kaddr) *kaddr = pmem->virt_addr + offset; if (pfn) - *pfn = phys_to_pfn_t(pmem->phys_addr + offset, pmem->pfn_flags); + *pfn = PHYS_PFN(pmem->phys_addr + offset); if (bb->count && badblocks_check(bb, sector, num, &first_bad, &num_bad)) { @@ -303,7 +302,7 @@ static int pmem_dax_zero_page_range(struct dax_device *dax_dev, pgoff_t pgoff, static long pmem_dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, - void **kaddr, pfn_t *pfn) + void **kaddr, unsigned long *pfn) { struct pmem_device *pmem = dax_get_private(dax_dev); @@ -513,7 +512,6 @@ static int pmem_attach_disk(struct device *dev, pmem->disk = disk; pmem->pgmap.owner = pmem; - pmem->pfn_flags = 0; if (is_nd_pfn(dev)) { pmem->pgmap.type = MEMORY_DEVICE_FS_DAX; pmem->pgmap.ops = &fsdax_pagemap_ops; diff --git a/drivers/nvdimm/pmem.h b/drivers/nvdimm/pmem.h index 392b0b3..a48509f 100644 --- a/drivers/nvdimm/pmem.h +++ b/drivers/nvdimm/pmem.h @@ -5,7 +5,6 @@ #include #include #include -#include #include enum dax_access_mode; @@ -16,7 +15,6 @@ struct pmem_device { phys_addr_t phys_addr; /* when non-zero this device is hosting a 'pfn' instance */ phys_addr_t data_offset; - u64 pfn_flags; void *virt_addr; /* immutable base size of the namespace */ size_t size; @@ -31,7 +29,7 @@ struct pmem_device { long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn); + unsigned long *pfn); #ifdef CONFIG_MEMORY_FAILURE static inline bool test_and_clear_pmem_poison(struct page *page) diff --git a/drivers/s390/block/dcssblk.c b/drivers/s390/block/dcssblk.c index 8a0d590..3e01c10 100644 --- a/drivers/s390/block/dcssblk.c +++ b/drivers/s390/block/dcssblk.c @@ -17,7 +17,6 @@ #include #include #include -#include #include #include #include @@ -33,7 +32,7 @@ static void dcssblk_release(struct gendisk *disk); static void dcssblk_submit_bio(struct bio *bio); static long dcssblk_dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn); + unsigned long *pfn); static char dcssblk_segments[DCSSBLK_PARM_LEN] = "\0"; @@ -915,7 +914,7 @@ dcssblk_submit_bio(struct bio *bio) static long __dcssblk_direct_access(struct dcssblk_dev_info *dev_info, pgoff_t pgoff, - long nr_pages, void **kaddr, pfn_t *pfn) + long nr_pages, void **kaddr, unsigned long *pfn) { resource_size_t offset = pgoff * PAGE_SIZE; unsigned long dev_sz; @@ -924,7 +923,7 @@ __dcssblk_direct_access(struct dcssblk_dev_info *dev_info, pgoff_t pgoff, if (kaddr) *kaddr = __va(dev_info->start + offset); if (pfn) - *pfn = __pfn_to_pfn_t(PFN_DOWN(dev_info->start + offset), 0); + *pfn = PFN_DOWN(dev_info->start + offset); return (dev_sz - offset) / PAGE_SIZE; } @@ -932,7 +931,7 @@ __dcssblk_direct_access(struct dcssblk_dev_info *dev_info, pgoff_t pgoff, static long dcssblk_dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { struct dcssblk_dev_info *dev_info = dax_get_private(dax_dev); diff --git a/drivers/vfio/pci/vfio_pci_core.c b/drivers/vfio/pci/vfio_pci_core.c index e6b6c01..2dfc3fe 100644 --- a/drivers/vfio/pci/vfio_pci_core.c +++ b/drivers/vfio/pci/vfio_pci_core.c @@ -20,7 +20,6 @@ #include #include #include -#include #include #include #include @@ -1680,12 +1679,12 @@ static vm_fault_t vfio_pci_mmap_huge_fault(struct vm_fault *vmf, break; #ifdef CONFIG_ARCH_SUPPORTS_PMD_PFNMAP case PMD_ORDER: - ret = vmf_insert_pfn_pmd(vmf, __pfn_to_pfn_t(pfn + pgoff, 0), false); + ret = vmf_insert_pfn_pmd(vmf, pfn + pgoff, false); break; #endif #ifdef CONFIG_ARCH_SUPPORTS_PUD_PFNMAP case PUD_ORDER: - ret = vmf_insert_pfn_pud(vmf, __pfn_to_pfn_t(pfn + pgoff, 0), false); + ret = vmf_insert_pfn_pud(vmf, pfn + pgoff, false); break; #endif default: diff --git a/fs/cramfs/inode.c b/fs/cramfs/inode.c index 820a664..3358bc6 100644 --- a/fs/cramfs/inode.c +++ b/fs/cramfs/inode.c @@ -17,7 +17,6 @@ #include #include #include -#include #include #include #include @@ -412,8 +411,7 @@ static int cramfs_physmem_mmap(struct file *file, struct vm_area_struct *vma) for (i = 0; i < pages && !ret; i++) { vm_fault_t vmf; unsigned long off = i * PAGE_SIZE; - pfn_t pfn = phys_to_pfn_t(address + off, 0); - vmf = vmf_insert_mixed(vma, vma->vm_start + off, pfn); + vmf = vmf_insert_mixed(vma, vma->vm_start + off, address + off); if (vmf & VM_FAULT_ERROR) ret = vm_fault_to_errno(vmf, 0); } diff --git a/fs/dax.c b/fs/dax.c index 3cc5b73..d13aa95 100644 --- a/fs/dax.c +++ b/fs/dax.c @@ -20,7 +20,6 @@ #include #include #include -#include #include #include #include @@ -76,9 +75,9 @@ static struct folio *dax_to_folio(void *entry) return page_folio(pfn_to_page(dax_to_pfn(entry))); } -static void *dax_make_entry(pfn_t pfn, unsigned long flags) +static void *dax_make_entry(unsigned long pfn, unsigned long flags) { - return xa_mk_value(flags | (pfn_t_to_pfn(pfn) << DAX_SHIFT)); + return xa_mk_value(flags | (pfn << DAX_SHIFT)); } static bool dax_is_locked(void *entry) @@ -708,7 +707,7 @@ static void *grab_mapping_entry(struct xa_state *xas, if (order > 0) flags |= DAX_PMD; - entry = dax_make_entry(pfn_to_pfn_t(0), flags); + entry = dax_make_entry(0, flags); dax_lock_entry(xas, entry); if (xas_error(xas)) goto out_unlock; @@ -1031,7 +1030,7 @@ static bool dax_fault_is_synchronous(const struct iomap_iter *iter, * appropriate. */ static void *dax_insert_entry(struct xa_state *xas, struct vm_fault *vmf, - const struct iomap_iter *iter, void *entry, pfn_t pfn, + const struct iomap_iter *iter, void *entry, unsigned long pfn, unsigned long flags) { struct address_space *mapping = vmf->vma->vm_file->f_mapping; @@ -1230,7 +1229,7 @@ int dax_writeback_mapping_range(struct address_space *mapping, EXPORT_SYMBOL_GPL(dax_writeback_mapping_range); static int dax_iomap_direct_access(const struct iomap *iomap, loff_t pos, - size_t size, void **kaddr, pfn_t *pfnp) + size_t size, void **kaddr, unsigned long *pfnp) { pgoff_t pgoff = dax_iomap_pgoff(iomap, pos); int id, rc = 0; @@ -1248,7 +1247,7 @@ static int dax_iomap_direct_access(const struct iomap *iomap, loff_t pos, rc = -EINVAL; if (PFN_PHYS(length) < size) goto out; - if (pfn_t_to_pfn(*pfnp) & (PHYS_PFN(size)-1)) + if (*pfnp & (PHYS_PFN(size)-1)) goto out; rc = 0; @@ -1352,12 +1351,12 @@ static vm_fault_t dax_load_hole(struct xa_state *xas, struct vm_fault *vmf, { struct inode *inode = iter->inode; unsigned long vaddr = vmf->address; - pfn_t pfn = pfn_to_pfn_t(my_zero_pfn(vaddr)); + unsigned long pfn = my_zero_pfn(vaddr); vm_fault_t ret; *entry = dax_insert_entry(xas, vmf, iter, *entry, pfn, DAX_ZERO_PAGE); - ret = vmf_insert_page_mkwrite(vmf, pfn_t_to_page(pfn), false); + ret = vmf_insert_page_mkwrite(vmf, pfn_to_page(pfn), false); trace_dax_load_hole(inode, vmf, ret); return ret; } @@ -1374,14 +1373,14 @@ static vm_fault_t dax_pmd_load_hole(struct xa_state *xas, struct vm_fault *vmf, struct folio *zero_folio; spinlock_t *ptl; pmd_t pmd_entry; - pfn_t pfn; + unsigned long pfn; zero_folio = mm_get_huge_zero_folio(vmf->vma->vm_mm); if (unlikely(!zero_folio)) goto fallback; - pfn = page_to_pfn_t(&zero_folio->page); + pfn = page_to_pfn(&zero_folio->page); *entry = dax_insert_entry(xas, vmf, iter, *entry, pfn, DAX_PMD | DAX_ZERO_PAGE); @@ -1771,7 +1770,7 @@ static vm_fault_t dax_fault_return(int error) * insertion for now and return the pfn so that caller can insert it after the * fsync is done. */ -static vm_fault_t dax_fault_synchronous_pfnp(pfn_t *pfnp, pfn_t pfn) +static vm_fault_t dax_fault_synchronous_pfnp(unsigned long *pfnp, unsigned long pfn) { if (WARN_ON_ONCE(!pfnp)) return VM_FAULT_SIGBUS; @@ -1819,7 +1818,7 @@ static vm_fault_t dax_fault_cow_page(struct vm_fault *vmf, * @pmd: distinguish whether it is a pmd fault */ static vm_fault_t dax_fault_iter(struct vm_fault *vmf, - const struct iomap_iter *iter, pfn_t *pfnp, + const struct iomap_iter *iter, unsigned long *pfnp, struct xa_state *xas, void **entry, bool pmd) { const struct iomap *iomap = &iter->iomap; @@ -1830,7 +1829,7 @@ static vm_fault_t dax_fault_iter(struct vm_fault *vmf, unsigned long entry_flags = pmd ? DAX_PMD : 0; struct folio *folio; int ret, err = 0; - pfn_t pfn; + unsigned long pfn; void *kaddr; if (!pmd && vmf->cow_page) @@ -1867,15 +1866,15 @@ static vm_fault_t dax_fault_iter(struct vm_fault *vmf, folio_ref_inc(folio); if (pmd) - ret = vmf_insert_folio_pmd(vmf, pfn_folio(pfn_t_to_pfn(pfn)), write); + ret = vmf_insert_folio_pmd(vmf, pfn_folio(pfn), write); else - ret = vmf_insert_page_mkwrite(vmf, pfn_t_to_page(pfn), write); + ret = vmf_insert_page_mkwrite(vmf, pfn_to_page(pfn), write); folio_put(folio); return ret; } -static vm_fault_t dax_iomap_pte_fault(struct vm_fault *vmf, pfn_t *pfnp, +static vm_fault_t dax_iomap_pte_fault(struct vm_fault *vmf, unsigned long *pfnp, int *iomap_errp, const struct iomap_ops *ops) { struct address_space *mapping = vmf->vma->vm_file->f_mapping; @@ -1985,7 +1984,7 @@ static bool dax_fault_check_fallback(struct vm_fault *vmf, struct xa_state *xas, return false; } -static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, pfn_t *pfnp, +static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, unsigned long *pfnp, const struct iomap_ops *ops) { struct address_space *mapping = vmf->vma->vm_file->f_mapping; @@ -2064,7 +2063,7 @@ static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, pfn_t *pfnp, return ret; } #else -static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, pfn_t *pfnp, +static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, unsigned long *pfnp, const struct iomap_ops *ops) { return VM_FAULT_FALLBACK; @@ -2085,7 +2084,7 @@ static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, pfn_t *pfnp, * successfully. */ vm_fault_t dax_iomap_fault(struct vm_fault *vmf, unsigned int order, - pfn_t *pfnp, int *iomap_errp, const struct iomap_ops *ops) + unsigned long *pfnp, int *iomap_errp, const struct iomap_ops *ops) { if (order == 0) return dax_iomap_pte_fault(vmf, pfnp, iomap_errp, ops); @@ -2106,7 +2105,7 @@ EXPORT_SYMBOL_GPL(dax_iomap_fault); * for an mmaped DAX file. It also marks the page cache entry as dirty. */ static vm_fault_t -dax_insert_pfn_mkwrite(struct vm_fault *vmf, pfn_t pfn, unsigned int order) +dax_insert_pfn_mkwrite(struct vm_fault *vmf, unsigned long pfn, unsigned int order) { struct address_space *mapping = vmf->vma->vm_file->f_mapping; XA_STATE_ORDER(xas, &mapping->i_pages, vmf->pgoff, order); @@ -2128,7 +2127,7 @@ dax_insert_pfn_mkwrite(struct vm_fault *vmf, pfn_t pfn, unsigned int order) xas_set_mark(&xas, PAGECACHE_TAG_DIRTY); dax_lock_entry(&xas, entry); xas_unlock_irq(&xas); - folio = pfn_folio(pfn_t_to_pfn(pfn)); + folio = pfn_folio(pfn); folio_ref_inc(folio); if (order == 0) ret = vmf_insert_page_mkwrite(vmf, &folio->page, true); @@ -2155,7 +2154,7 @@ dax_insert_pfn_mkwrite(struct vm_fault *vmf, pfn_t pfn, unsigned int order) * table entry. */ vm_fault_t dax_finish_sync_fault(struct vm_fault *vmf, unsigned int order, - pfn_t pfn) + unsigned long pfn) { int err; loff_t start = ((loff_t)vmf->pgoff) << PAGE_SHIFT; diff --git a/fs/ext4/file.c b/fs/ext4/file.c index a520514..608dcbb 100644 --- a/fs/ext4/file.c +++ b/fs/ext4/file.c @@ -741,7 +741,7 @@ static vm_fault_t ext4_dax_huge_fault(struct vm_fault *vmf, unsigned int order) bool write = (vmf->flags & FAULT_FLAG_WRITE) && (vmf->vma->vm_flags & VM_SHARED); struct address_space *mapping = vmf->vma->vm_file->f_mapping; - pfn_t pfn; + unsigned long pfn; if (write) { sb_start_pagefault(sb); diff --git a/fs/fuse/dax.c b/fs/fuse/dax.c index 48d0652..8fb4843 100644 --- a/fs/fuse/dax.c +++ b/fs/fuse/dax.c @@ -10,7 +10,6 @@ #include #include #include -#include #include #include @@ -763,7 +762,7 @@ static vm_fault_t __fuse_dax_fault(struct vm_fault *vmf, unsigned int order, vm_fault_t ret; struct inode *inode = file_inode(vmf->vma->vm_file); struct super_block *sb = inode->i_sb; - pfn_t pfn; + unsigned long pfn; int error = 0; struct fuse_conn *fc = get_fuse_conn(inode); struct fuse_conn_dax *fcd = fc->dax; diff --git a/fs/fuse/virtio_fs.c b/fs/fuse/virtio_fs.c index 2c7b24c..d0b6612 100644 --- a/fs/fuse/virtio_fs.c +++ b/fs/fuse/virtio_fs.c @@ -9,7 +9,6 @@ #include #include #include -#include #include #include #include @@ -1008,7 +1007,7 @@ static void virtio_fs_cleanup_vqs(struct virtio_device *vdev) */ static long virtio_fs_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, - void **kaddr, pfn_t *pfn) + void **kaddr, unsigned long *pfn) { struct virtio_fs *fs = dax_get_private(dax_dev); phys_addr_t offset = PFN_PHYS(pgoff); @@ -1017,7 +1016,7 @@ static long virtio_fs_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, if (kaddr) *kaddr = fs->window_kaddr + offset; if (pfn) - *pfn = phys_to_pfn_t(fs->window_phys_addr + offset, 0); + *pfn = fs->window_phys_addr + offset; return nr_pages > max_nr_pages ? max_nr_pages : nr_pages; } diff --git a/fs/xfs/xfs_file.c b/fs/xfs/xfs_file.c index f7a7d89..e80b817 100644 --- a/fs/xfs/xfs_file.c +++ b/fs/xfs/xfs_file.c @@ -1426,7 +1426,7 @@ xfs_dax_fault_locked( bool write_fault) { vm_fault_t ret; - pfn_t pfn; + unsigned long pfn; if (!IS_ENABLED(CONFIG_FS_DAX)) { ASSERT(0); diff --git a/include/linux/dax.h b/include/linux/dax.h index dbefea1..95e53ed 100644 --- a/include/linux/dax.h +++ b/include/linux/dax.h @@ -26,7 +26,7 @@ struct dax_operations { * number of pages available for DAX at that pfn. */ long (*direct_access)(struct dax_device *, pgoff_t, long, - enum dax_access_mode, void **, pfn_t *); + enum dax_access_mode, void **, unsigned long *); /* zero_page_range: required operation. Zero page range */ int (*zero_page_range)(struct dax_device *, pgoff_t, size_t); /* @@ -249,7 +249,7 @@ static inline void dax_break_mapping_uninterruptible(struct inode *inode, bool dax_alive(struct dax_device *dax_dev); void *dax_get_private(struct dax_device *dax_dev); long dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff, long nr_pages, - enum dax_access_mode mode, void **kaddr, pfn_t *pfn); + enum dax_access_mode mode, void **kaddr, unsigned long *pfn); size_t dax_copy_from_iter(struct dax_device *dax_dev, pgoff_t pgoff, void *addr, size_t bytes, struct iov_iter *i); size_t dax_copy_to_iter(struct dax_device *dax_dev, pgoff_t pgoff, void *addr, @@ -263,9 +263,9 @@ void dax_flush(struct dax_device *dax_dev, void *addr, size_t size); ssize_t dax_iomap_rw(struct kiocb *iocb, struct iov_iter *iter, const struct iomap_ops *ops); vm_fault_t dax_iomap_fault(struct vm_fault *vmf, unsigned int order, - pfn_t *pfnp, int *errp, const struct iomap_ops *ops); + unsigned long *pfnp, int *errp, const struct iomap_ops *ops); vm_fault_t dax_finish_sync_fault(struct vm_fault *vmf, - unsigned int order, pfn_t pfn); + unsigned int order, unsigned long pfn); int dax_delete_mapping_entry(struct address_space *mapping, pgoff_t index); void dax_delete_mapping_range(struct address_space *mapping, loff_t start, loff_t end); diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h index 8321f65..d2ed4e9 100644 --- a/include/linux/device-mapper.h +++ b/include/linux/device-mapper.h @@ -149,7 +149,7 @@ typedef int (*dm_busy_fn) (struct dm_target *ti); */ typedef long (*dm_dax_direct_access_fn) (struct dm_target *ti, pgoff_t pgoff, long nr_pages, enum dax_access_mode node, void **kaddr, - pfn_t *pfn); + unsigned long *pfn); typedef int (*dm_dax_zero_page_range_fn)(struct dm_target *ti, pgoff_t pgoff, size_t nr_pages); diff --git a/include/linux/huge_mm.h b/include/linux/huge_mm.h index 9cb5227..65a5f00 100644 --- a/include/linux/huge_mm.h +++ b/include/linux/huge_mm.h @@ -37,8 +37,8 @@ int change_huge_pmd(struct mmu_gather *tlb, struct vm_area_struct *vma, pmd_t *pmd, unsigned long addr, pgprot_t newprot, unsigned long cp_flags); -vm_fault_t vmf_insert_pfn_pmd(struct vm_fault *vmf, pfn_t pfn, bool write); -vm_fault_t vmf_insert_pfn_pud(struct vm_fault *vmf, pfn_t pfn, bool write); +vm_fault_t vmf_insert_pfn_pmd(struct vm_fault *vmf, unsigned long pfn, bool write); +vm_fault_t vmf_insert_pfn_pud(struct vm_fault *vmf, unsigned long pfn, bool write); vm_fault_t vmf_insert_folio_pmd(struct vm_fault *vmf, struct folio *folio, bool write); vm_fault_t vmf_insert_folio_pud(struct vm_fault *vmf, struct folio *folio, bool write); diff --git a/include/linux/mm.h b/include/linux/mm.h index 23c4e9b..08c40da 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -3601,9 +3601,9 @@ vm_fault_t vmf_insert_pfn(struct vm_area_struct *vma, unsigned long addr, vm_fault_t vmf_insert_pfn_prot(struct vm_area_struct *vma, unsigned long addr, unsigned long pfn, pgprot_t pgprot); vm_fault_t vmf_insert_mixed(struct vm_area_struct *vma, unsigned long addr, - pfn_t pfn); + unsigned long pfn); vm_fault_t vmf_insert_mixed_mkwrite(struct vm_area_struct *vma, - unsigned long addr, pfn_t pfn); + unsigned long addr, unsigned long pfn); int vm_iomap_memory(struct vm_area_struct *vma, phys_addr_t start, unsigned long len); static inline vm_fault_t vmf_insert_page(struct vm_area_struct *vma, diff --git a/include/linux/pgtable.h b/include/linux/pgtable.h index 1c377de..e57bfb6 100644 --- a/include/linux/pgtable.h +++ b/include/linux/pgtable.h @@ -1503,7 +1503,7 @@ static inline int track_pfn_remap(struct vm_area_struct *vma, pgprot_t *prot, * by vmf_insert_pfn(). */ static inline void track_pfn_insert(struct vm_area_struct *vma, pgprot_t *prot, - pfn_t pfn) + unsigned long pfn) { } @@ -1539,7 +1539,7 @@ extern int track_pfn_remap(struct vm_area_struct *vma, pgprot_t *prot, unsigned long pfn, unsigned long addr, unsigned long size); extern void track_pfn_insert(struct vm_area_struct *vma, pgprot_t *prot, - pfn_t pfn); + unsigned long pfn); extern int track_pfn_copy(struct vm_area_struct *vma); extern void untrack_pfn(struct vm_area_struct *vma, unsigned long pfn, unsigned long size, bool mm_wr_locked); diff --git a/include/trace/events/fs_dax.h b/include/trace/events/fs_dax.h index 86fe6ae..e188c71 100644 --- a/include/trace/events/fs_dax.h +++ b/include/trace/events/fs_dax.h @@ -127,7 +127,7 @@ DECLARE_EVENT_CLASS(dax_pmd_insert_mapping_class, __entry->radix_entry = radix_entry; ), TP_printk("dev %d:%d ino %#lx %s %s address %#lx length %#lx " - "pfn %#llx %s radix_entry %#lx", + "pfn %#llx radix_entry %#lx", MAJOR(__entry->dev), MINOR(__entry->dev), __entry->ino, @@ -135,9 +135,7 @@ DECLARE_EVENT_CLASS(dax_pmd_insert_mapping_class, __entry->write ? "write" : "read", __entry->address, __entry->length, - __entry->pfn_val & ~PFN_FLAGS_MASK, - __print_flags_u64(__entry->pfn_val & PFN_FLAGS_MASK, "|", - PFN_FLAGS_TRACE), + __entry->pfn_val, (unsigned long)__entry->radix_entry ) ) diff --git a/mm/debug_vm_pgtable.c b/mm/debug_vm_pgtable.c index cf5ff92..a0e5d01 100644 --- a/mm/debug_vm_pgtable.c +++ b/mm/debug_vm_pgtable.c @@ -20,7 +20,6 @@ #include #include #include -#include #include #include #include diff --git a/mm/huge_memory.c b/mm/huge_memory.c index 5e42a60..3626bf3 100644 --- a/mm/huge_memory.c +++ b/mm/huge_memory.c @@ -22,7 +22,6 @@ #include #include #include -#include #include #include #include @@ -1376,7 +1375,7 @@ vm_fault_t do_huge_pmd_anonymous_page(struct vm_fault *vmf) } static void insert_pfn_pmd(struct vm_area_struct *vma, unsigned long addr, - pmd_t *pmd, pfn_t pfn, pgprot_t prot, bool write, + pmd_t *pmd, unsigned long pfn, pgprot_t prot, bool write, pgtable_t pgtable) { struct mm_struct *mm = vma->vm_mm; @@ -1384,7 +1383,7 @@ static void insert_pfn_pmd(struct vm_area_struct *vma, unsigned long addr, if (!pmd_none(*pmd)) { if (write) { - if (pmd_pfn(*pmd) != pfn_t_to_pfn(pfn)) { + if (pmd_pfn(*pmd) != pfn) { WARN_ON_ONCE(!is_huge_zero_pmd(*pmd)); return; } @@ -1397,7 +1396,7 @@ static void insert_pfn_pmd(struct vm_area_struct *vma, unsigned long addr, return; } - entry = pmd_mkhuge(pfn_t_pmd(pfn, prot)); + entry = pmd_mkhuge(pfn_pmd(pfn, prot)); entry = pmd_mkspecial(entry); if (write) { entry = pmd_mkyoung(pmd_mkdirty(entry)); @@ -1424,7 +1423,8 @@ static void insert_pfn_pmd(struct vm_area_struct *vma, unsigned long addr, * * Return: vm_fault_t value. */ -vm_fault_t vmf_insert_pfn_pmd(struct vm_fault *vmf, pfn_t pfn, bool write) +vm_fault_t vmf_insert_pfn_pmd(struct vm_fault *vmf, unsigned long pfn, + bool write) { unsigned long addr = vmf->address & PMD_MASK; struct vm_area_struct *vma = vmf->vma; @@ -1487,7 +1487,7 @@ vm_fault_t vmf_insert_folio_pmd(struct vm_fault *vmf, struct folio *folio, bool folio_add_file_rmap_pmd(folio, &folio->page, vma); add_mm_counter(mm, mm_counter_file(folio), HPAGE_PMD_NR); } - insert_pfn_pmd(vma, addr, vmf->pmd, pfn_to_pfn_t(folio_pfn(folio)), + insert_pfn_pmd(vma, addr, vmf->pmd, folio_pfn(folio), vma->vm_page_prot, write, pgtable); spin_unlock(ptl); if (pgtable) @@ -1506,7 +1506,7 @@ static pud_t maybe_pud_mkwrite(pud_t pud, struct vm_area_struct *vma) } static void insert_pfn_pud(struct vm_area_struct *vma, unsigned long addr, - pud_t *pud, pfn_t pfn, bool write) + pud_t *pud, unsigned long pfn, bool write) { struct mm_struct *mm = vma->vm_mm; pgprot_t prot = vma->vm_page_prot; @@ -1514,7 +1514,7 @@ static void insert_pfn_pud(struct vm_area_struct *vma, unsigned long addr, if (!pud_none(*pud)) { if (write) { - if (WARN_ON_ONCE(pud_pfn(*pud) != pfn_t_to_pfn(pfn))) + if (WARN_ON_ONCE(pud_pfn(*pud) != pfn)) return; entry = pud_mkyoung(*pud); entry = maybe_pud_mkwrite(pud_mkdirty(entry), vma); @@ -1524,7 +1524,7 @@ static void insert_pfn_pud(struct vm_area_struct *vma, unsigned long addr, return; } - entry = pud_mkhuge(pfn_t_pud(pfn, prot)); + entry = pud_mkhuge(pfn_pud(pfn, prot)); entry = pud_mkspecial(entry); if (write) { entry = pud_mkyoung(pud_mkdirty(entry)); @@ -1544,7 +1544,8 @@ static void insert_pfn_pud(struct vm_area_struct *vma, unsigned long addr, * * Return: vm_fault_t value. */ -vm_fault_t vmf_insert_pfn_pud(struct vm_fault *vmf, pfn_t pfn, bool write) +vm_fault_t vmf_insert_pfn_pud(struct vm_fault *vmf, unsigned long pfn, + bool write) { unsigned long addr = vmf->address & PUD_MASK; struct vm_area_struct *vma = vmf->vma; @@ -1601,7 +1602,7 @@ vm_fault_t vmf_insert_folio_pud(struct vm_fault *vmf, struct folio *folio, bool folio_add_file_rmap_pud(folio, &folio->page, vma); add_mm_counter(mm, mm_counter_file(folio), HPAGE_PUD_NR); } - insert_pfn_pud(vma, addr, vmf->pud, pfn_to_pfn_t(folio_pfn(folio)), write); + insert_pfn_pud(vma, addr, vmf->pud, folio_pfn(folio), write); spin_unlock(ptl); return VM_FAULT_NOPAGE; diff --git a/mm/memory.c b/mm/memory.c index 5f7a441..fef28de 100644 --- a/mm/memory.c +++ b/mm/memory.c @@ -57,7 +57,6 @@ #include #include #include -#include #include #include #include @@ -2406,7 +2405,7 @@ int vm_map_pages_zero(struct vm_area_struct *vma, struct page **pages, EXPORT_SYMBOL(vm_map_pages_zero); static vm_fault_t insert_pfn(struct vm_area_struct *vma, unsigned long addr, - pfn_t pfn, pgprot_t prot, bool mkwrite) + unsigned long pfn, pgprot_t prot, bool mkwrite) { struct mm_struct *mm = vma->vm_mm; pte_t *pte, entry; @@ -2428,7 +2427,7 @@ static vm_fault_t insert_pfn(struct vm_area_struct *vma, unsigned long addr, * allocation and mapping invalidation so just skip the * update. */ - if (pte_pfn(entry) != pfn_t_to_pfn(pfn)) { + if (pte_pfn(entry) != pfn) { WARN_ON_ONCE(!is_zero_pfn(pte_pfn(entry))); goto out_unlock; } @@ -2441,7 +2440,7 @@ static vm_fault_t insert_pfn(struct vm_area_struct *vma, unsigned long addr, } /* Ok, finally just insert the thing.. */ - entry = pte_mkspecial(pfn_t_pte(pfn, prot)); + entry = pte_mkspecial(pfn_pte(pfn, prot)); if (mkwrite) { entry = pte_mkyoung(entry); @@ -2510,10 +2509,9 @@ vm_fault_t vmf_insert_pfn_prot(struct vm_area_struct *vma, unsigned long addr, if (!pfn_modify_allowed(pfn, pgprot)) return VM_FAULT_SIGBUS; - track_pfn_insert(vma, &pgprot, __pfn_to_pfn_t(pfn, 0)); + track_pfn_insert(vma, &pgprot, pfn); - return insert_pfn(vma, addr, __pfn_to_pfn_t(pfn, 0), pgprot, - false); + return insert_pfn(vma, addr, pfn, pgprot, false); } EXPORT_SYMBOL(vmf_insert_pfn_prot); @@ -2544,21 +2542,21 @@ vm_fault_t vmf_insert_pfn(struct vm_area_struct *vma, unsigned long addr, } EXPORT_SYMBOL(vmf_insert_pfn); -static bool vm_mixed_ok(struct vm_area_struct *vma, pfn_t pfn, bool mkwrite) +static bool vm_mixed_ok(struct vm_area_struct *vma, unsigned long pfn, bool mkwrite) { - if (unlikely(is_zero_pfn(pfn_t_to_pfn(pfn))) && + if (unlikely(is_zero_pfn(pfn)) && (mkwrite || !vm_mixed_zeropage_allowed(vma))) return false; /* these checks mirror the abort conditions in vm_normal_page */ if (vma->vm_flags & VM_MIXEDMAP) return true; - if (is_zero_pfn(pfn_t_to_pfn(pfn))) + if (is_zero_pfn(pfn)) return true; return false; } static vm_fault_t __vm_insert_mixed(struct vm_area_struct *vma, - unsigned long addr, pfn_t pfn, bool mkwrite) + unsigned long addr, unsigned long pfn, bool mkwrite) { pgprot_t pgprot = vma->vm_page_prot; int err; @@ -2571,7 +2569,7 @@ static vm_fault_t __vm_insert_mixed(struct vm_area_struct *vma, track_pfn_insert(vma, &pgprot, pfn); - if (!pfn_modify_allowed(pfn_t_to_pfn(pfn), pgprot)) + if (!pfn_modify_allowed(pfn, pgprot)) return VM_FAULT_SIGBUS; /* @@ -2581,7 +2579,7 @@ static vm_fault_t __vm_insert_mixed(struct vm_area_struct *vma, * than insert_pfn). If a zero_pfn were inserted into a VM_MIXEDMAP * without pte special, it would there be refcounted as a normal page. */ - if (!IS_ENABLED(CONFIG_ARCH_HAS_PTE_SPECIAL) && pfn_t_valid(pfn)) { + if (!IS_ENABLED(CONFIG_ARCH_HAS_PTE_SPECIAL) && pfn_valid(pfn)) { struct page *page; /* @@ -2589,7 +2587,7 @@ static vm_fault_t __vm_insert_mixed(struct vm_area_struct *vma, * regardless of whether the caller specified flags that * result in pfn_t_has_page() == false. */ - page = pfn_to_page(pfn_t_to_pfn(pfn)); + page = pfn_to_page(pfn); err = insert_page(vma, addr, page, pgprot, mkwrite); } else { return insert_pfn(vma, addr, pfn, pgprot, mkwrite); @@ -2615,7 +2613,7 @@ vm_fault_t vmf_insert_page_mkwrite(struct vm_fault *vmf, struct page *page, if (addr < vma->vm_start || addr >= vma->vm_end) return VM_FAULT_SIGBUS; - track_pfn_insert(vma, &pgprot, pfn_to_pfn_t(pfn)); + track_pfn_insert(vma, &pgprot, pfn); if (!pfn_modify_allowed(pfn, pgprot)) return VM_FAULT_SIGBUS; @@ -2640,7 +2638,7 @@ vm_fault_t vmf_insert_page_mkwrite(struct vm_fault *vmf, struct page *page, EXPORT_SYMBOL_GPL(vmf_insert_page_mkwrite); vm_fault_t vmf_insert_mixed(struct vm_area_struct *vma, unsigned long addr, - pfn_t pfn) + unsigned long pfn) { return __vm_insert_mixed(vma, addr, pfn, false); } @@ -2652,7 +2650,7 @@ EXPORT_SYMBOL(vmf_insert_mixed); * the same entry was actually inserted. */ vm_fault_t vmf_insert_mixed_mkwrite(struct vm_area_struct *vma, - unsigned long addr, pfn_t pfn) + unsigned long addr, unsigned long pfn) { return __vm_insert_mixed(vma, addr, pfn, true); } diff --git a/mm/memremap.c b/mm/memremap.c index 6c13e72..0f007f4 100644 --- a/mm/memremap.c +++ b/mm/memremap.c @@ -5,7 +5,6 @@ #include #include #include -#include #include #include #include diff --git a/mm/migrate.c b/mm/migrate.c index caadbe3..532591c 100644 --- a/mm/migrate.c +++ b/mm/migrate.c @@ -35,7 +35,6 @@ #include #include #include -#include #include #include #include diff --git a/tools/testing/nvdimm/pmem-dax.c b/tools/testing/nvdimm/pmem-dax.c index c1ec099..05e763a 100644 --- a/tools/testing/nvdimm/pmem-dax.c +++ b/tools/testing/nvdimm/pmem-dax.c @@ -10,7 +10,7 @@ long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff, long nr_pages, enum dax_access_mode mode, void **kaddr, - pfn_t *pfn) + unsigned long *pfn) { resource_size_t offset = PFN_PHYS(pgoff) + pmem->data_offset; @@ -29,7 +29,7 @@ long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff, *kaddr = pmem->virt_addr + offset; page = vmalloc_to_page(pmem->virt_addr + offset); if (pfn) - *pfn = page_to_pfn_t(page); + *pfn = page_to_pfn(page); pr_debug_ratelimited("%s: pmem: %p pgoff: %#lx pfn: %#lx\n", __func__, pmem, pgoff, page_to_pfn(page)); @@ -39,7 +39,7 @@ long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff, if (kaddr) *kaddr = pmem->virt_addr + offset; if (pfn) - *pfn = phys_to_pfn_t(pmem->phys_addr + offset, pmem->pfn_flags); + *pfn = PHYS_PFN(pmem->phys_addr + offset); /* * If badblocks are present, limit known good range to the diff --git a/tools/testing/nvdimm/test/iomap.c b/tools/testing/nvdimm/test/iomap.c index ddceb04..f7e7bfe 100644 --- a/tools/testing/nvdimm/test/iomap.c +++ b/tools/testing/nvdimm/test/iomap.c @@ -8,7 +8,6 @@ #include #include #include -#include #include #include #include @@ -135,12 +134,6 @@ void *__wrap_devm_memremap_pages(struct device *dev, struct dev_pagemap *pgmap) } EXPORT_SYMBOL_GPL(__wrap_devm_memremap_pages); -pfn_t __wrap_phys_to_pfn_t(phys_addr_t addr, unsigned long flags) -{ - return phys_to_pfn_t(addr, flags); -} -EXPORT_SYMBOL(__wrap_phys_to_pfn_t); - void *__wrap_memremap(resource_size_t offset, size_t size, unsigned long flags) { From patchwork Wed Jan 8 01:18:48 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alistair Popple X-Patchwork-Id: 13929872 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2042.outbound.protection.outlook.com [40.107.92.42]) (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 D121214F104; Wed, 8 Jan 2025 01:19:15 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.92.42 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299157; cv=fail; b=ddU94L6BaKNnjeq3QU7QwhEHxTqil8+b1ieZh3P8zBl2uPar2zkiybem4JCB8YYkwFLKs2rX+ENUCcbqzsxbYN7uEIOq4mLldayEG7peNUI6uQ3dlr65CxFHa0+lB/CyIbvxXXbyiwwXzX5NG9EspRmF1FHe/dR4n4nlTLxWc1A= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736299157; c=relaxed/simple; bh=ujzx/WQRsMF0eBSC+IyKU+sEkbLBLr3cEoVBSozwfdA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=D2jyQ0HEl0OSBc0YWJPoqXmWQAkrdCBCFCiYJ5wHYf9F6s4TshxNqWPxqntErY5H8tCNRSz61yFCKHPv1/SneIRzSnZ2IB7VKIkkn8d2DGtoXgn4M4uBmdkP7b2NecYMQ1FwEv240o/2ZtG4sihATu0S5yx7q0bNXLv7cXnBdYY= 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=YwIQxUwH; arc=fail smtp.client-ip=40.107.92.42 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="YwIQxUwH" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=Wp0IYMuq113HJfM3u+GwGRShS/gQwJd+qbo5zLZ7HeMPOTlamkrKWRJP/6o4JB6Akqbpejl6wqOqs4RVS1ZJ75lE+LjrTdBlYI0KWKRcNbgin7jRLgl4E2hYsT5ZpxsQgGGwcNXqe9hLyCMF0kBXNw6UL4P4IvUo6KqSOnhru1Fg18ZiNmWEaVdneLPi+Ot1D+0GieYiRtCNFXOYWuQQW2N71eiba2Ub1w5r/ZSOjWj5OTFSvXPQqgGUtmGbrYbxq9Yesh8kuEkySd4CklhQJ6eU6eV7Nba+q4rPyZ8XkjJG1MJQGqbOATqjJPKG8ZOhAxg2U6SRU7MenE1Z6yfMcQ== 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=L7lvzuDdKfKSwlcRCTo250cbJaCJWsopJVFrrMGY2rM=; b=Cckqo3qRIKBBS81qajSbEuwrxhSuhruFkUAFTgNTJRg95bIaRb0pgesf+MGF4890a8AJAHyOr9FggTZlRoADVuIr8PIZa7qtMMsQwyR9/W/V+QLU43XMwfW4+cXU/ljlh2FWTN1TljCUAWbjDSCTHFDM5fOzujILZZuQJFmNF+xq2fIoBnMGI+y3eEIHjBwU34o8sf0IOjdUsssu8nsQD5BRgmB94Krd3JYNM1hU6M2h219UgCc5zC0zPUY3+pnUrxXKQUOC2KmkjBFEfR/HTzXlInUNl3/n2Bz8Nf6YKJSIY2mKuIOhN1kE5m5MiSE/yZdyS5KUIiJpbrdLcPs3kg== 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=L7lvzuDdKfKSwlcRCTo250cbJaCJWsopJVFrrMGY2rM=; b=YwIQxUwHG3CWHg1I6n1C6VBSh+sEdB0MQH1pIMOJtyYrQaNihDeX36YbvLuruDA1Ad1pBrKVnJ25LUrPfhDCzE9BjIFxv3z3ggtlDHxqb5S5F8sYsi7qBqIFqWorhgIDoAngJreCCozvvmVVphjDVOUw2H31EurWYTv5gPKL40EyQmCN+17ncuMRWfMTYf7etivBYidrqjqiKSgN18FCx64qDr5h8nUeras4vUwuOMDwd65OtMgts1CeHoo2GMEBGjuNReHx+eyU8YXL7zcnXbj1fg1xqVdtHFAckHH+B28w5YkbNO7Kmw2KF7HbstRmMzMSzweC5ljjYBqkKCyXgQ== 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 LV8PR12MB9264.namprd12.prod.outlook.com (2603:10b6:408:1e8::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.10; Wed, 8 Jan 2025 01:19:12 +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; Wed, 8 Jan 2025 01:19:12 +0000 From: Alistair Popple To: akpm@linux-foundation.org, linux-mm@kvack.org Cc: Alistair Popple , gerald.schaefer@linux.ibm.com, dan.j.williams@intel.com, jgg@ziepe.ca, willy@infradead.org, david@redhat.com, linux-kernel@vger.kernel.org, nvdimm@lists.linux.dev, linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, jhubbard@nvidia.com, hch@lst.de Subject: [RFC 4/4] mm: Remove include/linux/pfn_t.h Date: Wed, 8 Jan 2025 12:18:48 +1100 Message-ID: <34dfcab0f529cb32b59e70c8bce132a9d82dc3f0.1736299058.git-series.apopple@nvidia.com> X-Mailer: git-send-email 2.45.2 In-Reply-To: References: X-ClientProxiedBy: SY6PR01CA0044.ausprd01.prod.outlook.com (2603:10c6:10:e9::13) To DS0PR12MB7726.namprd12.prod.outlook.com (2603:10b6:8:130::6) Precedence: bulk X-Mailing-List: linux-xfs@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS0PR12MB7726:EE_|LV8PR12MB9264:EE_ X-MS-Office365-Filtering-Correlation-Id: 88b9d458-6a30-4e49-1007-08dd2f8275c6 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014; X-Microsoft-Antispam-Message-Info: /PJ8zAXQoXAEVx0fHIyn22W8LcqWnECQ9D+LlVAvqgL+1ScDpXV0BITSzD89LGWjpet3VvidtIUtCnnSj9ZOEdNhjDuSFklrkamlZDlwprCoC2f0wzX1Ckg/yw4uIzdiwXvxkxIJhnf4lnvggxHSzuvb4Tt33TliBsQkRSB8qE3dfkvoAcjRsglJ8ONRO1Bqz+UDmyrnyGzfFwFm+CiaiIftZTMSY0xYwbWZABGYuwchEZQUh1TgBGD6+SnVxMjNyhklDrJGuUowMcdSG4kWHby1A7pP9Pp0ITRauEqZyfNPopYUluV0BrJKXRiqBlf+1sDsABU0f8FUCSZynNG1fq6To6SxyRUwlmNOP0tAsJWHE7CcTbnI0QK0EBGXvKqd6DFrRsGJOwMe204qNo795ebvJYdZesZ1+NqeQmB5eaJIQXah5UezKC2yXlB+ah2J2qIh+JU4ZPeOVT0Y5o1WvdiTYfISalUvRYmn2uX0pGPc0TPi65BgpYHuJ+MxwCUOBugqZYBQfx+ePz8csRfHBnmyU5CJtSBNelskF5zYWdlIelYwFwtHL73HqBh41mzA47wVOV6nIHz7GEFm/4Mb7UI4/Vbh2gLPHi2iN071gZgKi4u9CD5w1nIc+kClNIq8OC9Uxa6HK3jD9SMGMdqjR3nW6tPh6JwwjMrgr21TJMapCORuOdS0qECMRJAvl2ibXKgcsngkIeK8YCYzUQCLQxfhZOgn2yzS3EIQ4mFwdyJbwCWJDjGRxl1rsfd63oyZ4T1GcuowcLsZwvcjqkjzF5GAdAFbpWnfx70n8xgSFLCLmwHW1UEEgEn4MbqLc8I/cKLlYdXA1JV6cJKP7Ek5NG67FcTBBQZ/J51N60lnno5o3SkKaFhJLwySNC6PxerGZhP9u95s/iXw6xf/fxNW9ZLjYeU6v1SFwv2QsIZeOZgOp48HyrtV/3Svr6F9SIi2s0+IzItrik4qBESKWQrVrtsEP4JKS1GT3YZA633DeRlsBWX3ToPoflwvaWsBSw78fxXogbzVX9e5yqE9T9YzAdN251zI4dogjGyxhOYi6/lLcRccwHdwXOCFco/io7pAHDZ+IwPoNpwyYJJL94KgoZ7itCWQ8Xf8giFrQsa5Be7DWbXsMCSOCI4HcaV6dbK3XtlqTqWdz2AmXvOuOSd94hlcf6qaMSjGTKDJQ9ZL8r99m3SgRjYGCG96iODmp+pAFgEvBcdA16cUU6zM+4xzUuNlYaoxOHFfy5uj4laiXoNh31UsOWobV9PsrhaDhuJZikV9qFLdRTlOGNH3T5Q8ALvYzKh2voiB2i0R4RR5wPkbRVuklE0UGDH1ux1q1fz2CyZyOlRhwSarvu2Sx9MxXpHD+HDrfWXoF88rP5PPskdEr9RK6mZpbA7jh3HCJ7A0 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)(366016)(1800799024)(7416014)(376014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: c0HUy9jjvJ696px+5rATlcFiIxXIsVfGjzh2iPW2YiMGT98Y0UKCb+Xx9G8DsO9vLIU2Ka+PM+9bOn8YBb9SJTQqNpfpE30HzaC+U2ofsXmnEvFhYGAxGpZTyFwt+WFgJuKy9tcN0wK8PSkGx2NXdvrxFOFzJprtaAwvy+dXNAyUMafiCrkpwaEmsXZKwLvRbzYMzXse+Hh3usxofi+oN/5TGWH8LXk4VK4LYjcvJrgoDNajzHC3DuM/2KzZAgy3ClEM3pNJZWB/PBddonzRGSzmgGtPjiCnXZKe3hJTZcEy4wuAqiiRM8E+TKxJbbtzFhCtJNKzQw0SKTgRXI0iOuxXheieMiMyGwm4HAFkP9SL/Q6W8+gkIaYG1SA/vdXE5TJf0PkimsusvgaeH1quh0zuykQdYm6EIrU6HpqkKSjtFNRI9KeMsUSHWtIVokrZM3c4WbvzqHPU4i14tYfvoD/uhk8F9HCqUTzLocp9Q28DpzSKAuVu0Qk67kgt5a/I1x6eHlIsXdOtEwgMatc8oY5JhwvY0PBeW8dzL6bvtcTLiAccVQK5jAgL1QddbjvW+wfpzpa87XIL/btkHL88LLmgY6NM9TSesbHlfRNk7wjqQ8HQhzVHE6wQ0oOQIeCrqa7Gnak81IMeuXs2RLGmVgoiw7XO+z59kiXt9ljqBjnFeGiDZO8Czmf2f2fxEfVVm1c8G2P7yMiNxgAm3QydX9L3KB99V+dyccnX0ZONFZAjNAxP/ZwhgPPBr/DNstKLpF7bMTdcfncpSC8kQ7UTZfRE5JSdKPGkdsvexIQcqZi5KQt/NiEKMaIyERndt7CB1UNzwICC4QM+2uTGcUTTBrT7BLcWRW77/wB4BlhZeJj+0KEQjHnW+QMZnUY8yeYovp0UI0MnGIbThj3Mmjgovv7qva6DV8e5z5DjURjeWaHUm2uWIHLGlnpTITTgiA4jCzGn1dPgWIidYwSWdfpQgWwaX9OjVYKK4kt28YHy0uIMBcHEph0eOMXVhuInjfTbL+KZKsPEigZxRlvdIBS4hUkJp4zWIxKvdYAtjA+5XBRcZ2LU/KqhXMKeEOrvwUrBehyIzx0w4idVUnFHbzwPe20vJuJpPi4G7eHron3ngIwVOqWyoEY0UvCLzc6Ql350JLo7RzBWsZGlT7raooRjHnR7pRxxSu97h7CXwud1A+EXa8mrTV8183klexpIteAy30ZMb3ZyntVSed7MAI/+trzQRfAkGh6d0u/lzNtIqWbBupWWLujb8SN41VH7c7NDI69Ghfsxe2mJEX7IOpbzbAiPpfGsGnIsI7eMK6PMLXljWYG+jtQgG3QbItXSG3w3KDTvZoU5Epq6nOZLCNpBhfF8fhhP3mv0SOsvmDgzpbM3ZFHrfm2u8P4Jv44++7VYpCCsbcFkMxaM7SuhSUtO+L7RDagw6iK7WUMV6/h/UuWHEfjogYJEB1LOm0+rWez6RUh+WIzp7PeKFGaDLk4sx0fPyACFhYmmcj/5DbQXBXeese1RBSBKSnpeYu7i/WfZRXMp7qxr/MWK+gTgPByz5Wv35M/TPS31mWz3K+u0ya1QLfKm4zsHJ7Cs0ERy+rUd X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-Network-Message-Id: 88b9d458-6a30-4e49-1007-08dd2f8275c6 X-MS-Exchange-CrossTenant-AuthSource: DS0PR12MB7726.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Jan 2025 01:19:12.7505 (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: LUH/Z+Wbrezqahemi0tVm1WzeHRHDvkkVhS5F6k/dZ6bDukB8MVf+5Hmgm9gmh3TypX3kfDvaWBDMMHDufS2fg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: LV8PR12MB9264 None of the functionality in pfn_t.h is required so delete it. Signed-off-by: Alistair Popple Reviewed-by: Christoph Hellwig --- include/linux/pfn.h | 10 +----- include/linux/pfn_t.h | 88 +-------------------------------------------- 2 files changed, 98 deletions(-) delete mode 100644 include/linux/pfn_t.h diff --git a/include/linux/pfn.h b/include/linux/pfn.h index 14bc053..f4a74d1 100644 --- a/include/linux/pfn.h +++ b/include/linux/pfn.h @@ -5,16 +5,6 @@ #ifndef __ASSEMBLY__ #include -/* - * pfn_t: encapsulates a page-frame number that is optionally backed - * by memmap (struct page). Whether a pfn_t has a 'struct page' - * backing is indicated by flags in the high bits of the value. - */ -typedef struct { - u64 val; -} pfn_t; -#endif - #define PFN_ALIGN(x) (((unsigned long)(x) + (PAGE_SIZE - 1)) & PAGE_MASK) #define PFN_UP(x) (((x) + PAGE_SIZE-1) >> PAGE_SHIFT) #define PFN_DOWN(x) ((x) >> PAGE_SHIFT) diff --git a/include/linux/pfn_t.h b/include/linux/pfn_t.h deleted file mode 100644 index 034b5b0..0000000 --- a/include/linux/pfn_t.h +++ /dev/null @@ -1,88 +0,0 @@ -/* SPDX-License-Identifier: GPL-2.0 */ -#ifndef _LINUX_PFN_T_H_ -#define _LINUX_PFN_T_H_ -#include - -/* - * PFN_FLAGS_MASK - mask of all the possible valid pfn_t flags - * PFN_SG_CHAIN - pfn is a pointer to the next scatterlist entry - * PFN_SG_LAST - pfn references a page and is the last scatterlist entry - * PFN_DEV - pfn is not covered by system memmap by default - * PFN_MAP - pfn has a dynamic page mapping established by a device driver - */ -#define PFN_FLAGS_MASK (((u64) (~PAGE_MASK)) << (BITS_PER_LONG_LONG - PAGE_SHIFT)) - -#define PFN_FLAGS_TRACE { } - -static inline pfn_t __pfn_to_pfn_t(unsigned long pfn, u64 flags) -{ - pfn_t pfn_t = { .val = pfn | (flags & PFN_FLAGS_MASK), }; - - return pfn_t; -} - -/* a default pfn to pfn_t conversion assumes that @pfn is pfn_valid() */ -static inline pfn_t pfn_to_pfn_t(unsigned long pfn) -{ - return __pfn_to_pfn_t(pfn, 0); -} - -static inline pfn_t phys_to_pfn_t(phys_addr_t addr, u64 flags) -{ - return __pfn_to_pfn_t(addr >> PAGE_SHIFT, flags); -} - -static inline bool pfn_t_has_page(pfn_t pfn) -{ - return (pfn.val & PFN_DEV) == 0; -} - -static inline unsigned long pfn_t_to_pfn(pfn_t pfn) -{ - return pfn.val & ~PFN_FLAGS_MASK; -} - -static inline struct page *pfn_t_to_page(pfn_t pfn) -{ - if (pfn_t_has_page(pfn)) - return pfn_to_page(pfn_t_to_pfn(pfn)); - return NULL; -} - -static inline phys_addr_t pfn_t_to_phys(pfn_t pfn) -{ - return PFN_PHYS(pfn_t_to_pfn(pfn)); -} - -static inline pfn_t page_to_pfn_t(struct page *page) -{ - return pfn_to_pfn_t(page_to_pfn(page)); -} - -static inline int pfn_t_valid(pfn_t pfn) -{ - return pfn_valid(pfn_t_to_pfn(pfn)); -} - -#ifdef CONFIG_MMU -static inline pte_t pfn_t_pte(pfn_t pfn, pgprot_t pgprot) -{ - return pfn_pte(pfn_t_to_pfn(pfn), pgprot); -} -#endif - -#ifdef CONFIG_TRANSPARENT_HUGEPAGE -static inline pmd_t pfn_t_pmd(pfn_t pfn, pgprot_t pgprot) -{ - return pfn_pmd(pfn_t_to_pfn(pfn), pgprot); -} - -#ifdef CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD -static inline pud_t pfn_t_pud(pfn_t pfn, pgprot_t pgprot) -{ - return pfn_pud(pfn_t_to_pfn(pfn), pgprot); -} -#endif -#endif - -#endif /* _LINUX_PFN_T_H_ */