From mboxrd@z Thu Jan 1 00:00:00 1970 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]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id C1DF3D3CCAF for ; Thu, 15 Jan 2026 06:18:49 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 06B596B0089; Thu, 15 Jan 2026 01:18:49 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 0186B6B008A; Thu, 15 Jan 2026 01:18:48 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id E13646B008C; Thu, 15 Jan 2026 01:18:48 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id CCB566B0089 for ; Thu, 15 Jan 2026 01:18:48 -0500 (EST) Received: from smtpin25.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay09.hostedemail.com (Postfix) with ESMTP id 5C765898AC for ; Thu, 15 Jan 2026 06:18:48 +0000 (UTC) X-FDA: 84333194736.25.A4A8B13 Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.12]) by imf13.hostedemail.com (Postfix) with ESMTP id 8416520003 for ; Thu, 15 Jan 2026 06:18:44 +0000 (UTC) Authentication-Results: imf13.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=LGJH9RTP; dmarc=pass (policy=none) header.from=intel.com; arc=reject ("signature check failed: fail, {[1] = sig:microsoft.com:reject}"); spf=pass (imf13.hostedemail.com: domain of matthew.brost@intel.com designates 198.175.65.12 as permitted sender) smtp.mailfrom=matthew.brost@intel.com ARC-Seal: i=2; s=arc-20220608; d=hostedemail.com; t=1768457925; a=rsa-sha256; cv=fail; b=lTg0Hde8Loxu8cvCjQwfC90G/WCaHR9o3PItxi6ev8pRsp3DkqTMzpN3xDOb5im6hq3yC9 muzrLTY62uW/LS+nbJhyI8ZubgkITmn5LMUpmyRsaxCmbklhGIoZfM8ynKtLHo6THEKONq BN/NticveMWzbCVnokMIYVC7tfbUjAo= ARC-Authentication-Results: i=2; imf13.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=LGJH9RTP; dmarc=pass (policy=none) header.from=intel.com; arc=reject ("signature check failed: fail, {[1] = sig:microsoft.com:reject}"); spf=pass (imf13.hostedemail.com: domain of matthew.brost@intel.com designates 198.175.65.12 as permitted sender) smtp.mailfrom=matthew.brost@intel.com ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1768457925; 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=HbHItWup/RRXoaCY27KPQ7sJiy4jTLj9qx0rPveuAHE=; b=u/ACDHXHMYaOmkEPuRj2+hsujoby0RxcSOP8nwhTba1fyg58HZvnSBCV3nQq7RHZcuuhqG gebd65OcDsLiyzXp1CYXPFFrhSALl7UhpT9qw50p3jYBNEU5OysOaIrnY9K9G0tqCUeZSL DQhi2+f1TSo1FkRa7VXbZCldS8yc228= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1768457924; x=1799993924; h=date:from:to:cc:subject:message-id:references: content-transfer-encoding:in-reply-to:mime-version; bh=C1wwCFKEbd7oq7gtV7p+/p8SbsD1zFTs3eVDEgo0m9k=; b=LGJH9RTP566VwHFeFl2Ors0ksQukgFV+d3sU4OrtID3sZC7AxQQ2MaD8 opD/vd9jf7emT4x/Sp2VASZI0zWNT93IftIVFxj56Y3eZF8BWL/Wgqogs UAG8H8ha5Zo9kYHMLTDuu6FEfwWI0aEmqPTS0PegsSxQNlZLZ3/pQEHQz 9IRPO8eHpwhfx2FutHDyJBl082keUV2Vc2NaIMOzy0yjLq5ApoBrdMvrG jsXWmJl/SRem8yyH8FuuR4spyNsr5JvF5dxZwtoUonbj4o9AZVxdTMNew Lox9iktfYV597WBAun+U/MEDdovUzyge0FDL/284tVMiWMCU2pBcsn03j w==; X-CSE-ConnectionGUID: Quh7jytVSQyivc6wcEszug== X-CSE-MsgGUID: tn3w/5hiTDerS9RLckJwmQ== X-IronPort-AV: E=McAfee;i="6800,10657,11671"; a="81206838" X-IronPort-AV: E=Sophos;i="6.21,226,1763452800"; d="scan'208";a="81206838" Received: from fmviesa002.fm.intel.com ([10.60.135.142]) by orvoesa104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 14 Jan 2026 22:18:42 -0800 X-CSE-ConnectionGUID: aV59PU2vRVSgwdJIWEBZEg== X-CSE-MsgGUID: JUy+odj0ThiQ46um/JADHQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.21,226,1763452800"; d="scan'208";a="227962956" Received: from fmsmsx902.amr.corp.intel.com ([10.18.126.91]) by fmviesa002.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 14 Jan 2026 22:18:42 -0800 Received: from FMSMSX902.amr.corp.intel.com (10.18.126.91) by fmsmsx902.amr.corp.intel.com (10.18.126.91) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.29; Wed, 14 Jan 2026 22:18:41 -0800 Received: from fmsedg903.ED.cps.intel.com (10.1.192.145) by FMSMSX902.amr.corp.intel.com (10.18.126.91) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.29 via Frontend Transport; Wed, 14 Jan 2026 22:18:41 -0800 Received: from BL0PR03CU003.outbound.protection.outlook.com (52.101.53.18) by edgegateway.intel.com (192.55.55.83) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.29; Wed, 14 Jan 2026 22:18:40 -0800 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=hvLfDfUejTmdxCRYsLWeZ3tHhYRa+iHhp/i6p7bbgVlCF6nxwVq3d9L206LL/CafKRnIkev/XGrgXxdpBrGPbWF7PYymYf4sAVqwjkRq/11Z8fm30ek8moJMegcZbCRtUBdGKfxpwsfk47NM9EEvt4L4OcWH3PCo8GhIdkJd2oCWxZtmZa2DeWM4V/v3bWIdaQiUiFS8oMSRZntSvLq63d8ivZP+0ZfUF9CNqjHjgDEKxC0LyHHOBiWA1VeTm0n2AGMY995Nhy39LIQAutjBkmZr7JIlyQG2ch00jc5PJg6sqiN2p8wEzgdwWzK17soH48movV0rj3F6BzfYPNE9JA== 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=HbHItWup/RRXoaCY27KPQ7sJiy4jTLj9qx0rPveuAHE=; b=KOXIIiwMz3PFQucckSlAwWnvQTakhewknWYgVnaLqb5f3/XMhn//LWOWJ/GPQ3uf28aaYcve02W5/acsV6pJD4uAPD/CXiFlxhmGNLCFCf3HhkkKmz/6H0tM2rTaDpwANkXrnlI3B2I4c7o94h4sVQ5GXUWEzCLbh2X2jQcxBKfJEPglvT73FFGu13KcA3z0flh92bpYNjO6Lrbqf6kmWp2/kY0brQHslJUbBQLuMl5fT17qgF5x7VZ93GzaLOBgdwyEcSaRuvwYyHm89M6beQahPO74N5goZnK2+6ld5Paely/uW1NrsR6P/sxy7uT0rW6FJD6K1Rp1g1VoX9pGIg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=intel.com; dmarc=pass action=none header.from=intel.com; dkim=pass header.d=intel.com; arc=none Received: from PH7PR11MB6522.namprd11.prod.outlook.com (2603:10b6:510:212::12) by CY5PR11MB6344.namprd11.prod.outlook.com (2603:10b6:930:3b::6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9520.5; Thu, 15 Jan 2026 06:18:33 +0000 Received: from PH7PR11MB6522.namprd11.prod.outlook.com ([fe80::9e94:e21f:e11a:332]) by PH7PR11MB6522.namprd11.prod.outlook.com ([fe80::9e94:e21f:e11a:332%7]) with mapi id 15.20.9456.015; Thu, 15 Jan 2026 06:18:33 +0000 Date: Wed, 14 Jan 2026 22:18:30 -0800 From: Matthew Brost To: Alistair Popple CC: Francois Dugast , , , Zi Yan , adhavan Srinivasan , Nicholas Piggin , Michael Ellerman , "Christophe Leroy (CS GROUP)" , Felix Kuehling , Alex Deucher , Christian =?iso-8859-1?Q?K=F6nig?= , David Airlie , Simona Vetter , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , Lyude Paul , Danilo Krummrich , "David Hildenbrand" , Oscar Salvador , "Andrew Morton" , Jason Gunthorpe , "Leon Romanovsky" , Lorenzo Stoakes , "Liam R . Howlett" , Vlastimil Babka , Mike Rapoport , Suren Baghdasaryan , Michal Hocko , Balbir Singh , , , , , , , Subject: Re: [PATCH v5 1/5] mm/zone_device: Reinitialize large zone device private folios Message-ID: References: <20260114192111.1267147-1-francois.dugast@intel.com> <20260114192111.1267147-2-francois.dugast@intel.com> <6spceodgfobizdaziju4yvvfydwvvik2wjyoyfuglozq533rgl@vmkotau3m3kw> Content-Type: text/plain; charset="utf-8" Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-ClientProxiedBy: BYAPR07CA0102.namprd07.prod.outlook.com (2603:10b6:a03:12b::43) To PH7PR11MB6522.namprd11.prod.outlook.com (2603:10b6:510:212::12) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PH7PR11MB6522:EE_|CY5PR11MB6344:EE_ X-MS-Office365-Filtering-Correlation-Id: 6557f931-04eb-4354-f428-08de53fde8e5 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|376014|7416014|366016|7053199007; X-Microsoft-Antispam-Message-Info: =?utf-8?B?a2JtS3NNQ0RRbDJwQmhxYVVKWjN6WW1mQkN5MlpBMzZoMStaL0cySnl4Y3Ri?= =?utf-8?B?dk1McldsdVZxVmx5WWZLTlBCUERVU0dIZ2c4TnFpcElvcUJWc21QZHFicnFC?= =?utf-8?B?M0pPelZveWVxWjRMVHJRc3doczhVUVkrcThqVzlwbmNEQ2NBMVphQncxYTFl?= =?utf-8?B?bnA3ZUZPQ0k3UmlpcDdpZVh1NDJzNEN1OGRlRlNlRUtBY2IxUUpEZDZVME92?= =?utf-8?B?OEcxOXhpTnR3TURZazJnYjZEcEFjZFNUdU9VbTNhakluYWVnWjQ1OGcrSVQz?= =?utf-8?B?bGdRN29RYzM0Q0JzSUt1bXBOcG83aUIzNE9XK3loUGNSMExLM1FOOUttcWk3?= =?utf-8?B?MnZTZ3FuMlZrMkE0cStFeGsvUEowdFIxM2MzaGttMzR6VjIxeFIxVC93dWxZ?= =?utf-8?B?SlJSVkZRZUdKM0lvZHJHbDBOaXFjSVJhNWtPTWhHTURBbkdJb3UreU13RHZs?= =?utf-8?B?TVp2eWdTMWZGNVJVamtzdlVjZGQwRU1Tb0doYktUL0xpemhNSkkwTk9hWENk?= =?utf-8?B?L1dKeGN2K3o1WlprYUtDbzEwajZZdEFHWmxYZXVEemFBUVNYQmZlWC92UVhJ?= =?utf-8?B?bnk2N2dVS3hOYzZIZmMvSXZCK21KV2lFVXB4akhXQmYzaUtqSEE3UUlzUzBn?= =?utf-8?B?eUo4UmNQZkhWQzJ1YWk2T1dmMlVCVVZxdGVrdldQNmNpNjJBd3EzanI5T0li?= =?utf-8?B?cXBlakl2MjQ4QTZMcVIwS0JEZUxiaGs3S0FyVm51U04rYmlDczVUUm1Nd1JN?= =?utf-8?B?ZVNEMVZaVEFlU1pDeXpvMWRpS3lMbHZBdVVYLzlTdGttSlR6UjRBQjBlYWdV?= =?utf-8?B?MUd3czk5aGxpTFBaTTdqZmxqZ0xpRE1aa0c4aHJUb0FOQTgzQU5XOXhDWHRj?= =?utf-8?B?VmljTjFhdVpzRlFUekhSRFFrdTcxbHhSSHBEL0thbDlQRFl1cEREZVJ3aXVa?= =?utf-8?B?MCszay9yUXBnUXAyTjJjTUNURHRkZGsyZ0dQOFJaTnJUS1FUcnU4ZFBuWnRx?= =?utf-8?B?WXFvTURpOU1wVmxqMDFvOTE4UW1pMUxWeHdnK0REVk8wcVVlMkhSVlVYU3BI?= =?utf-8?B?SzVNNkNJREZFaGtjVFJpaVhKUFRYVUticlprcVVHb1FDUmI1bmtOVUZSaG54?= =?utf-8?B?OFFRQ2VQT3VDUng2UEZtTWRlWE5jb29NeFZjOXFJV2FVYVc4ZFMzWElUdnRp?= =?utf-8?B?blVrZzVhcmdoWGlhelNaYlpiU1Qyb0Nmb2QxRU5SQkV0aVdHUU95QXFmY2J4?= =?utf-8?B?ZG1HMUdoQW1idko1ZEl0RHlJWUFNc3lIRitBUkRYbkVvK3pXN05kVDdoMnlF?= =?utf-8?B?WTMvTk9tNUFLRFJ2RDNEZ1Z5QWExd3V2OHhKWlpLMjY3ZTVWOTAwS2NZOG91?= =?utf-8?B?N0NwMFpjaGhIT2VjeUZmTHFnVGlFUmo4L25XcUdPQ3hzWk1ZY1J5WEwxTWhF?= =?utf-8?B?V2RubnJ6MXU0MnpwMHVJR2FqZUVwbjc5TzhXTkR2RStjOEdrMEJQTDg0YnRl?= =?utf-8?B?dDFSNmh3S1IzYW9uUkl2dSs0VnhmT3Nmc21wenZPUHNEWmdrYVNLSEtYTEY0?= =?utf-8?B?cTZmU21rWGRzN21pMUdqU0kwNE1CNjAwSlNVWjFlV1N3ZDIyanVJL0tpWHpy?= =?utf-8?B?Q25jSDhjRWkzZFBjVzkyYktpY2h1SEUxcmJGWFh1dSsrbXp3eEZWcm81blgr?= =?utf-8?B?dnE5UU5nQmJpQXFaRkVmSmx4eTE2dHIxU2RteXNCVlByb0FQRTBOMXVwQUtU?= =?utf-8?B?WHM5bXZ0dUFGc1VwU3lIM0ozcndQYkd0VHZwdGxDbmhRUDA0dnBBTlhCN1Zu?= =?utf-8?B?MUhxeEswekg4VHRoV24vS0ZDczhGUWZHQjQySmZqRndCVXJ3M3BQb084K0VD?= =?utf-8?B?YU9pNVhlVGdnemMycTZXbUtxcU1EWnRIOVlTRFEvMklta2JvL1QwblF3czdS?= =?utf-8?B?VEc1aTh6RFBKTDdheW9VZEFSa3g4cG9PekExaG5aMHN0M3NvUzFlQWIvOFI5?= =?utf-8?B?bzdRZjZxVTlGTjJJTE1BWkhDSmRqTjd3QjZOYUJYTXd6d1k4NU1QcWdxVDda?= =?utf-8?Q?YaVxUF?= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PH7PR11MB6522.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(376014)(7416014)(366016)(7053199007);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?YW15MXg2emZoYXFNc1FjRWpuSE9ueTZ0QXRWOCtjSFpyaVU4V3FMTmtOVVJI?= =?utf-8?B?QjZ2YmZCY2Y3RXhkK1NMQ3VnSDFPUWtOQ0NvMEdPVmF3QjhIaVNQSklwQUl3?= =?utf-8?B?NWQ5RlRncWxEVjA3MnErWitRUGJhbmNMNkdqWWRtWCt3cE56cVB4UFNjbFFI?= =?utf-8?B?TnkrelRJaHNOUEtIb2JFVmhXcnV5TzROVnBRbmo2YXhTL2d3Ym9YZi81T24x?= =?utf-8?B?b1dHVW1qdjY5NytOK3BjVGkydXB4NlN1OU0wTG1RM29WSHZlcDR3bHlDWGRD?= =?utf-8?B?ckQvZmQrU2tFdno4QS83ZGNYZXYza1g5Q1Q1MnlLbUVwdU8wR1RkdEM3MGhG?= =?utf-8?B?WTZjOHZGT3B3UVAwTndmRjJwVitMMWZySEwzNFRTMjlFWE83TzVXTnM0cmky?= =?utf-8?B?K1ZxcktPK3JtYWx3Ni80ckdYSGJFYVFnZGNnM3lURXlNRVFvMFVGUG9iUm9R?= =?utf-8?B?M0RsWGg4TWVvekhiRXNLaGpPZXNqTkJCZ2NZMEdQU3dQNmt1VmFqekpRQ1BG?= =?utf-8?B?d0hXamp1REFXbVV2NEMvckhmdk52WmdqV2F1ZGU3dzRNRE5DMEpVTEd0d0pX?= =?utf-8?B?UVhaeWJUUnZqczUrL1JpNnd4Ui90UjZ0cXhYMnNSNUNVWmlReGtjaVExbjhr?= =?utf-8?B?OFJ1ZW9ieEZFWGFTWnhGb1dkUVlyWENMUkdEWHhIQkl6SkpVbjBrRDk3L1Z6?= =?utf-8?B?bXp6VFJ2d2I5TllMSUhQSXRleVE2NjBpNlZHRHVxUUdlNFpNUEdrS0x2RzV1?= =?utf-8?B?ZnZkQXVpckZJTVN1MWg2czVVWVRPZGxDaWZQV0haL0dnRTBHbTFhUllpaEN3?= =?utf-8?B?SzFoZG96d0t6dkZqZDgrdDJJQ2V0a3gyL3E5ODJnbmVpOFhyYkxvYTgrczlp?= =?utf-8?B?dlZIMk4yYjArcXRvNFBIRWQzK3g4ckxaejFWc05WYllGMTY1NkFXOElNS3lG?= =?utf-8?B?Z2o1UE95OHhMTUNaNWkrNTd3MHoxZnpsT2lHclI4aktNWEVhTEhaZ3YxUkwx?= =?utf-8?B?dWE0T0pBQWJaaWFzeDdWZGxibVphZVphNDZhN3VvT3NrMWhUendYUEc3Tm5p?= =?utf-8?B?dGU5U2VaUi9SdkY1NmRVcWNSTkdkTTFzeGFMVkxxY3RPY2dwSEtTK0NpWGlP?= =?utf-8?B?STVQQWFNaUVKYW1SaTB3Mi85NHoweU9DSW1WOHJ0bW9BckxQMEpRKzIrZi9q?= =?utf-8?B?dDdqcTdKTm1xOCt3TjZQMGNTTUdIV0hEZjREMWN3SVl2RmVxZUFUZXI0UkJr?= =?utf-8?B?WUsrZkQ5R054YTh6WmhxRWgycWV3MzBZZmxCektlZHR2cjlnb2JDU3V6ZzBF?= =?utf-8?B?aklrZmhGN1dQTzdxbWd0TnR6OUUraHIyL1Q0eDZXSTNmWk5YekJSV3IxRWZS?= =?utf-8?B?RUJxODA2SVVUOHJ0N3RJZSs3TzliQkg2dVIzZ0dHemVUeVB1TzM4UzVMbi9l?= =?utf-8?B?aXlLVjVWTWJCN2JPV21nZ2MrY2FKSzlPaUtmTW5yRHB0RVJ3L3JXaHVqdFlr?= =?utf-8?B?WkJnQ2lJL210TEZ2S3hWbjQ4V3BUTlpBQkl4QS9vazN4ZlVTYjRuMVpDV0Vm?= =?utf-8?B?T2ZVd1dLYS9DV05IMEJwYjdiUkUvTzBud1F5SXh5ZUdzRGpwL09tenpyUE1S?= =?utf-8?B?bHFpTVJldzRlSmk1UVFhQzJqeVMxYkxVbFZYZzQvWUtQbTkzeWJFSWpHUFI1?= =?utf-8?B?TzdxdlQ3MkxQMlhUZ0lmWnhTaHY5bUZoU1BBODB5UDZxM2FQVWw1M2JMUEEz?= =?utf-8?B?VUZQNVU5ajRMRDdoZ054ZjVnMENCenFobERFK0MyUUlXR2FzR1F2T3hhdFNH?= =?utf-8?B?VUNCeGRYWFFpL0N4UGRxMDhwTUw2NTRyZWJVU0FpUjU5MUlCUUFvSU9pSnUz?= =?utf-8?B?UXRDc1dWL0pUZk1QNnBLTWZEOUVjRGczN3ZiL1R0dGQ0ZytSRU9hUWptQzNr?= =?utf-8?B?MEJNUVM1bWc2aHNWZzc5ZlFBbCtiRS9SSnE1YXREWkp2Zk92MEJJYnZWazBM?= =?utf-8?B?WE1iVXVocWJhR0xvWDZrVGx2WGxUZGV2RWdZSmJBZWxyUXR4WVEyejdUN2JJ?= =?utf-8?B?NXBBTUo1a3ZKandJNkVHK1NWbThpOGVrUU5uZ3BISC9iU3UyU2dHVzlKbVFJ?= =?utf-8?B?ZlBJMzdscGxIY2ppT1V1ZkNRT2dHbWRla3JhWnMydDRpNThWbFZsUVdsclV4?= =?utf-8?B?MFlKZTRTd1BQUzdPakJXRld1TndXMXZFdS9uaXJ1L1hRMHl4Y3VKWW15dlJO?= =?utf-8?B?bjZZa2h0bzcrZk1Dajh4akxPdkN4bHVDSmpIZkdlUU0zRjVzY1V6L1ZaMkJX?= =?utf-8?B?N2VVUTUxMHd2eXVJRHlxUTJ3amwva1VrUy9tYzk0eEpsOFllaUo3K21FbGI1?= =?utf-8?Q?8wODi/HwlPjsd+i8=3D?= X-MS-Exchange-CrossTenant-Network-Message-Id: 6557f931-04eb-4354-f428-08de53fde8e5 X-MS-Exchange-CrossTenant-AuthSource: PH7PR11MB6522.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Jan 2026 06:18:33.3998 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 46c98d88-e344-4ed4-8496-4ed7712e255d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: aF2PulZYF12FOyeTecPzHCdLaFGGKWI4ziRnUmbrDKEBXsd8X2k198meu1m3YiEWXQW8BV0CZhdrE96MIv71AQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY5PR11MB6344 X-OriginatorOrg: intel.com X-Rspam-User: X-Stat-Signature: k4hzru3h3o6ji6zia7c1w4iyusba3xwo X-Rspamd-Server: rspam09 X-Rspamd-Queue-Id: 8416520003 X-HE-Tag: 1768457924-425176 X-HE-Meta: U2FsdGVkX1/3Abt/OqbEENIpyAaiKv66aSMwB5qfupQg9jPIRI43bivSIpO+WpjYvbDYVSEjxHGFlkx3Yifsf6tc3sUWLi6vdj3U45jKySvfNegMt1zZ5iTNm9qu56Qnk/0izJa8VinLhVSRITxdsVrNxayETad0aN67hFDC+Esm3ska0Lx1lBO7KnGYJnsBv4j/hX5xQw2MdanIEvNyGnt6jvJ3hxYUQ/lNd+KCr7zloyfiYBHUjfkMxZYYYoEAVhV1foUZZg4GEF2c2HzC9Z1SZfj2bRjrNqpaUs6d9eDJgVvi4TYB29bCQmCA9jq1pX55UycYmarNGvxjeqvOJJt+pKUsYJKxFyywZA4BltlxZ2IjxDu8l5vHNkizl5G1jLSiCBBT4APqC0m7ItAXfq093olUpgiQpuVxPEl47sHpo28pJZY06MUMgigyaTpbbArJf97mcMhvekAS6VFehCeSm7spH8e2GVengkuM3R0LQ9/yw3v631TtJ5PwLpLLyHVUB8Fir/NUtJG26/1w3/XKLHuD4X6AbNkCChuk8ImTQW5S18zaWYUWL4faneTGMCp1WrDf9VztwF7tyNwicYCySztEZp57jVtnCNWR7hGWDeKfhTxnHT97dzsh+72GujhCXQyfmzhS5YTrpN2dLmkTaagI95ZsiO/nEYPpgkBC2LladTWJyK149LKypo6rzvZSd1mEL+nXxOqHXqSW5nOV50KqSptV6lbL6HH3UqJBEpT2WogIwCsfXAQgo8rVh/6ffq3heDKqdFJtMvYJOzU3AhUohiz5iDTvlRZ5WThhIzXsFG1V6n0SeXx5Auj3lW6rsO3m/JRBup9M0VZpRnGp5yHUygU8trbA3WwMn1f0fEfsWHUycxGgMEOq/pqk4/gPxnkAKJQk2OwHHs5Ikm7RLEONoGw4C4Kga7Dp58m8/VQb7TiuyLwJ/EL+W3JxkBU+WwfCnINOUwnQx0e Uz2x74eR e8/Y4CAKFtCZ1oGS+f3X6BPtAWik74y9ekuGPf3QWsF0WaQNfWoh9mC8nNEcyjK8OOAKOqOPDpo1WIeMeEa6SZIzpQPogoMNJyl7u+I1CP9m9oK5DSMpxdwcRO8wUe+R58izwmIJQz4/FX4f0DJqVhlRfg1JkwwLD8spPMQ940dzdAypckrP8ZxfEFNIdz3L95o/JippUaB/Ew4nGqJ2MXVkz/rMcUI+Lxlpo9pfpuc+zwb17Wvaq+M+/oh6LChKy+hClNYfkvgEWQvCeJVpoVoJG/FYNoGbAnXlN+R9lYAWwXfPnwEBUrziiBPt25vw2cdRe7k52O9Y45RIUDOxaqcRg+AYblJydngpDK0iGm7b0wpqjOEvFgnmGy6hFU4Y5bZCOxlTkrtVZ/r/Gmf+BiCAzgLygtN9I4T5B3FL/ZTCmgOSbAYHggdKkSh/cvnaVCsd6KJRILO15yUL2MVnq2Nuyvvev++jAM32AMw4ZBYMeN1luFsj07fr3tC9UbSgFEobbHDQ0S5iIBv6XFupAeSJc6MiTYDTU7cEWML3gjEpKOOIxz5x25vdRjcTCgQpfwFs0m6rrHyjuZ4TatqQTs3IP9VriFR8fRAdZ+uJivP01+0megGIly5dfnvxBwPs6BeussX15O92GKlMqRdDvtBqGZ96cCVGkWEXXtuq/S2FijsArj4ah9GGppVvnpMz4tU/PkVLDnoyR7iLw6lG2SBIy6ObgEh0PrPX1j4mC2zeGTSwNMABTly//XjHXWKOV+Nlv9ysmPM79c69te+6WiHZiR/3bciFXDv4/5AzMZddVo8OJ0VuCk5vP3d9T+D60KVgmniFXdX0+c1Dt4VsN2Zz1YWXE/neuV+WfYErrElzArmBQsRLhmSqBn106ODty3miGFiHv2VG4EsDswn/Lo46r0GOHyMh7K6yyQznixqVj7atyigsBugGxO2h9P4eDW7HpFiV7oQYe+XmHUaRr5Yv0Js7n vEgAnqsX bt+hlUYCDy8Nx4jzc9W7Tz8B/1s2jm3xRcBNlw3sMM7YGmoSP3Q2rvBu6Na5ydLMXqC30PvK2BkEaGGMBC5BkJD3/nLC+Mz/7fzTsTNMVA2BgIXFthjXg7Zn+MFmjq+zueswyK7xk5JaSMcqhINc3dPk7JvKM3MsIH9REEmzzt0JD4uW8TaWeq95RYFxYrMB/i2I092q8es= 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: On Wed, Jan 14, 2026 at 09:57:31PM -0800, Matthew Brost wrote: > On Thu, Jan 15, 2026 at 04:27:26PM +1100, Alistair Popple wrote: > > On 2026-01-15 at 06:19 +1100, Francois Dugast wrote... > > > From: Matthew Brost > > > > > > Reinitialize metadata for large zone device private folios in > > > zone_device_page_init prior to creating a higher-order zone device > > > private folio. This step is necessary when the folio’s order changes > > > dynamically between zone_device_page_init calls to avoid building a > > > corrupt folio. As part of the metadata reinitialization, the dev_pagemap > > > must be passed in from the caller because the pgmap stored in the folio > > > page may have been overwritten with a compound head. > > > > Thanks for fixing, a couple of minor comments below. > > > > > Cc: Zi Yan > > > Cc: Alistair Popple > > > Cc: adhavan Srinivasan > > > Cc: Nicholas Piggin > > > Cc: Michael Ellerman > > > Cc: "Christophe Leroy (CS GROUP)" > > > Cc: Felix Kuehling > > > Cc: Alex Deucher > > > Cc: "Christian König" > > > Cc: David Airlie > > > Cc: Simona Vetter > > > Cc: Maarten Lankhorst > > > Cc: Maxime Ripard > > > Cc: Thomas Zimmermann > > > Cc: Lyude Paul > > > Cc: Danilo Krummrich > > > Cc: David Hildenbrand > > > Cc: Oscar Salvador > > > Cc: Andrew Morton > > > Cc: Jason Gunthorpe > > > Cc: Leon Romanovsky > > > Cc: Lorenzo Stoakes > > > Cc: Liam R. Howlett > > > Cc: Vlastimil Babka > > > Cc: Mike Rapoport > > > Cc: Suren Baghdasaryan > > > Cc: Michal Hocko > > > Cc: Balbir Singh > > > Cc: linuxppc-dev@lists.ozlabs.org > > > Cc: kvm@vger.kernel.org > > > Cc: linux-kernel@vger.kernel.org > > > Cc: amd-gfx@lists.freedesktop.org > > > Cc: dri-devel@lists.freedesktop.org > > > Cc: nouveau@lists.freedesktop.org > > > Cc: linux-mm@kvack.org > > > Cc: linux-cxl@vger.kernel.org > > > Fixes: d245f9b4ab80 ("mm/zone_device: support large zone device private folios") > > > Signed-off-by: Matthew Brost > > > Signed-off-by: Francois Dugast > > > --- > > > arch/powerpc/kvm/book3s_hv_uvmem.c | 2 +- > > > drivers/gpu/drm/amd/amdkfd/kfd_migrate.c | 2 +- > > > drivers/gpu/drm/drm_pagemap.c | 2 +- > > > drivers/gpu/drm/nouveau/nouveau_dmem.c | 2 +- > > > include/linux/memremap.h | 9 ++++++--- > > > lib/test_hmm.c | 4 +++- > > > mm/memremap.c | 20 +++++++++++++++++++- > > > 7 files changed, 32 insertions(+), 9 deletions(-) > > > > > > diff --git a/arch/powerpc/kvm/book3s_hv_uvmem.c b/arch/powerpc/kvm/book3s_hv_uvmem.c > > > index e5000bef90f2..7cf9310de0ec 100644 > > > --- a/arch/powerpc/kvm/book3s_hv_uvmem.c > > > +++ b/arch/powerpc/kvm/book3s_hv_uvmem.c > > > @@ -723,7 +723,7 @@ static struct page *kvmppc_uvmem_get_page(unsigned long gpa, struct kvm *kvm) > > > > > > dpage = pfn_to_page(uvmem_pfn); > > > dpage->zone_device_data = pvt; > > > - zone_device_page_init(dpage, 0); > > > + zone_device_page_init(dpage, &kvmppc_uvmem_pgmap, 0); > > > return dpage; > > > out_clear: > > > spin_lock(&kvmppc_uvmem_bitmap_lock); > > > diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_migrate.c b/drivers/gpu/drm/amd/amdkfd/kfd_migrate.c > > > index af53e796ea1b..6ada7b4af7c6 100644 > > > --- a/drivers/gpu/drm/amd/amdkfd/kfd_migrate.c > > > +++ b/drivers/gpu/drm/amd/amdkfd/kfd_migrate.c > > > @@ -217,7 +217,7 @@ svm_migrate_get_vram_page(struct svm_range *prange, unsigned long pfn) > > > page = pfn_to_page(pfn); > > > svm_range_bo_ref(prange->svm_bo); > > > page->zone_device_data = prange->svm_bo; > > > - zone_device_page_init(page, 0); > > > + zone_device_page_init(page, page_pgmap(page), 0); > > > } > > > > > > static void > > > diff --git a/drivers/gpu/drm/drm_pagemap.c b/drivers/gpu/drm/drm_pagemap.c > > > index 03ee39a761a4..c497726b0147 100644 > > > --- a/drivers/gpu/drm/drm_pagemap.c > > > +++ b/drivers/gpu/drm/drm_pagemap.c > > > @@ -201,7 +201,7 @@ static void drm_pagemap_get_devmem_page(struct page *page, > > > struct drm_pagemap_zdd *zdd) > > > { > > > page->zone_device_data = drm_pagemap_zdd_get(zdd); > > > - zone_device_page_init(page, 0); > > > + zone_device_page_init(page, zdd->dpagemap->pagemap, 0); > > > } > > > > > > /** > > > diff --git a/drivers/gpu/drm/nouveau/nouveau_dmem.c b/drivers/gpu/drm/nouveau/nouveau_dmem.c > > > index 58071652679d..3d8031296eed 100644 > > > --- a/drivers/gpu/drm/nouveau/nouveau_dmem.c > > > +++ b/drivers/gpu/drm/nouveau/nouveau_dmem.c > > > @@ -425,7 +425,7 @@ nouveau_dmem_page_alloc_locked(struct nouveau_drm *drm, bool is_large) > > > order = ilog2(DMEM_CHUNK_NPAGES); > > > } > > > > > > - zone_device_folio_init(folio, order); > > > + zone_device_folio_init(folio, page_pgmap(folio_page(folio, 0)), order); > > > return page; > > > } > > > > > > diff --git a/include/linux/memremap.h b/include/linux/memremap.h > > > index 713ec0435b48..e3c2ccf872a8 100644 > > > --- a/include/linux/memremap.h > > > +++ b/include/linux/memremap.h > > > @@ -224,7 +224,8 @@ static inline bool is_fsdax_page(const struct page *page) > > > } > > > > > > #ifdef CONFIG_ZONE_DEVICE > > > -void zone_device_page_init(struct page *page, unsigned int order); > > > +void zone_device_page_init(struct page *page, struct dev_pagemap *pgmap, > > > + unsigned int order); > > > void *memremap_pages(struct dev_pagemap *pgmap, int nid); > > > void memunmap_pages(struct dev_pagemap *pgmap); > > > void *devm_memremap_pages(struct device *dev, struct dev_pagemap *pgmap); > > > @@ -234,9 +235,11 @@ bool pgmap_pfn_valid(struct dev_pagemap *pgmap, unsigned long pfn); > > > > > > unsigned long memremap_compat_align(void); > > > > > > -static inline void zone_device_folio_init(struct folio *folio, unsigned int order) > > > +static inline void zone_device_folio_init(struct folio *folio, > > > + struct dev_pagemap *pgmap, > > > + unsigned int order) > > > { > > > - zone_device_page_init(&folio->page, order); > > > + zone_device_page_init(&folio->page, pgmap, order); > > > if (order) > > > folio_set_large_rmappable(folio); > > > } > > > diff --git a/lib/test_hmm.c b/lib/test_hmm.c > > > index 8af169d3873a..455a6862ae50 100644 > > > --- a/lib/test_hmm.c > > > +++ b/lib/test_hmm.c > > > @@ -662,7 +662,9 @@ static struct page *dmirror_devmem_alloc_page(struct dmirror *dmirror, > > > goto error; > > > } > > > > > > - zone_device_folio_init(page_folio(dpage), order); > > > + zone_device_folio_init(page_folio(dpage), > > > + page_pgmap(folio_page(page_folio(dpage), 0)), > > > + order); > > > dpage->zone_device_data = rpage; > > > return dpage; > > > > > > diff --git a/mm/memremap.c b/mm/memremap.c > > > index 63c6ab4fdf08..6f46ab14662b 100644 > > > --- a/mm/memremap.c > > > +++ b/mm/memremap.c > > > @@ -477,10 +477,28 @@ void free_zone_device_folio(struct folio *folio) > > > } > > > } > > > > > > -void zone_device_page_init(struct page *page, unsigned int order) > > > +void zone_device_page_init(struct page *page, struct dev_pagemap *pgmap, > > > + unsigned int order) > > > { > > > + struct page *new_page = page; > > > + unsigned int i; > > > + > > > VM_WARN_ON_ONCE(order > MAX_ORDER_NR_PAGES); > > > > > > + for (i = 0; i < (1UL << order); ++i, ++new_page) { > > > + struct folio *new_folio = (struct folio *)new_page; > > > + > > > + new_page->flags.f &= ~0xffUL; /* Clear possible order, page head */ > > > > This seems odd to me, mainly due to the "magic" number. Why not just clear > > the flags entirely? Or at least explicitly just clear the flags you care about > > which would remove the need for the comment and should let you use the proper > > PageFlag functions. > > > > I'm copying this from folio_reset_order [1]. My paranoia about touching > anything related to struct page is high, so I did the same thing > folio_reset_order does here. > > [1] https://elixir.bootlin.com/linux/v6.18.5/source/include/linux/mm.h#L1075 > This immediately hangs my first SVM test... diff --git a/mm/memremap.c b/mm/memremap.c index 6f46ab14662b..ef8c56876cf5 100644 --- a/mm/memremap.c +++ b/mm/memremap.c @@ -488,7 +488,7 @@ void zone_device_page_init(struct page *page, struct dev_pagemap *pgmap, for (i = 0; i < (1UL << order); ++i, ++new_page) { struct folio *new_folio = (struct folio *)new_page; - new_page->flags.f &= ~0xffUL; /* Clear possible order, page head */ + new_page->flags.f = 0; #ifdef NR_PAGES_IN_LARGE_FOLIO ((struct folio *)(new_page - 1))->_nr_pages = 0; #endif I can walk through exactly which flags need to be cleared, but my feeling is that likely any flag that the order field overloads and can possibly encode should be cleared—so bits 0–7 based on the existing code. How about in a follow-up we normalize setting / clearing the order flag field with a #define and an inline helper? Matt > > > +#ifdef NR_PAGES_IN_LARGE_FOLIO > > > + ((struct folio *)(new_page - 1))->_nr_pages = 0; > > > +#endif > > > + new_folio->mapping = NULL; > > > + new_folio->pgmap = pgmap; /* Also clear compound head */ > > > + new_folio->share = 0; /* fsdax only, unused for device private */ > > > > It would be nice if the FS DAX code actually used this as well. Is there a > > reason that change was dropped from the series? > > > > I don't have a test platform for FS DAX. In prior revisions, I was just > moving existing FS DAX code to a helper, which I felt confident about. > > This revision is slightly different, and I don't feel comfortable > modifying FS DAX code without a test platform. I agree we should update > FS DAX, but that should be done in a follow-up with coordinated testing. > > Matt > > > > + VM_WARN_ON_FOLIO(folio_ref_count(new_folio), new_folio); > > > + VM_WARN_ON_FOLIO(!folio_is_zone_device(new_folio), new_folio); > > > + } > > > + > > > /* > > > * Drivers shouldn't be allocating pages after calling > > > * memunmap_pages(). > > > -- > > > 2.43.0 > > >