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]) by smtp.lore.kernel.org (Postfix) with ESMTP id 96823C3ABB2 for ; Wed, 28 May 2025 11:03:32 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 353E26B0092; Wed, 28 May 2025 07:03:32 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 32AE56B0095; Wed, 28 May 2025 07:03:32 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 1F2F96B0096; Wed, 28 May 2025 07:03:32 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id F25166B0092 for ; Wed, 28 May 2025 07:03:31 -0400 (EDT) Received: from smtpin18.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id 7DE975BA18 for ; Wed, 28 May 2025 11:03:31 +0000 (UTC) X-FDA: 83492030622.18.FB3DA15 Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.10]) by imf06.hostedemail.com (Postfix) with ESMTP id D57E0180012 for ; Wed, 28 May 2025 11:03:27 +0000 (UTC) Authentication-Results: imf06.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=Ha+mBi5a; spf=pass (imf06.hostedemail.com: domain of yan.y.zhao@intel.com designates 192.198.163.10 as permitted sender) smtp.mailfrom=yan.y.zhao@intel.com; arc=reject ("signature check failed: fail, {[1] = sig:microsoft.com:reject}"); dmarc=pass (policy=none) header.from=intel.com ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1748430208; h=from:from:sender:reply-to: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: in-reply-to:in-reply-to:references:references:dkim-signature; bh=AlV3SwneMAMeJkpoN2FgHwuGWMdHEU5cixO/XjrZ4Io=; b=mDwPfNrDTPaFwjN73f5+XpiCLYBhF72ttFxQyv63nJ+gITQjZKUr8BoC0i13CSIUYKopgV zQqkeHkrkirdZG9TnpZGjoBDM+xIuwKKf0IzU4rB+IWKorM7AdW/H+hgYPaGc0XUqSZDVE 1yO2QcsjYT2tZQsEfFw6mq7UaYauym8= ARC-Authentication-Results: i=2; imf06.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=Ha+mBi5a; spf=pass (imf06.hostedemail.com: domain of yan.y.zhao@intel.com designates 192.198.163.10 as permitted sender) smtp.mailfrom=yan.y.zhao@intel.com; arc=reject ("signature check failed: fail, {[1] = sig:microsoft.com:reject}"); dmarc=pass (policy=none) header.from=intel.com ARC-Seal: i=2; s=arc-20220608; d=hostedemail.com; t=1748430208; a=rsa-sha256; cv=fail; b=bBY7UuEJn5fcPE7Q27gWhjyxRzQ0w4atvf9Qndoi6KaX6dw4UL9IBzZHpXfOLRUt3JwnH7 CJlUlyNEIBPhJcVNt8L38GKj9zxRQI3H6h+NzqIRHAvcS9rRs3ZXntWTQBbCDnNrzuenTi 9jb6CTSAtxWn/A+/higBfxBvwnDEObw= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1748430208; x=1779966208; h=date:from:to:cc:subject:message-id:reply-to:references: in-reply-to:mime-version; bh=WZR7tQB1LJhu+9v91I9pG3/hzweDs1StmtZ78yVTjUg=; b=Ha+mBi5a8Xj+kIaKm8012XvGwGFxcbyGmThV02AinmlXfIAt/8fYtfQp h/45uW9AMghXmpWV4vA7w6N3pgOJJX3EaL+C2OjJ2xRCxhVJLEnwkAdCV 3Mq7nablrjXCLhTfZL2yWrc14uPHLCMaoy3vrxX8FFjQkRFeygEiKqHTy 0Cn7ImZjSHm2OZFQH2eg2q/jKbXT3IBrXjnptojNLgI9CK7uRXLfghktd MZtmoD+7r47BybWpQ1wayh/0sR2O812gf95SI+8QgHJj1m1BaHjL/AFwe a1uCmVltKE7JnXeNP/tnFXeK6BJrcJmOpPI8i0bb5uklKtTivs8dTE4MO g==; X-CSE-ConnectionGUID: 4hat6sutRxyywd8++t35Kw== X-CSE-MsgGUID: aUF3leOcRcW06wVMFUDRiA== X-IronPort-AV: E=McAfee;i="6700,10204,11446"; a="61799455" X-IronPort-AV: E=Sophos;i="6.15,320,1739865600"; d="scan'208";a="61799455" Received: from fmviesa003.fm.intel.com ([10.60.135.143]) by fmvoesa104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 May 2025 04:03:21 -0700 X-CSE-ConnectionGUID: QKHVld68T8mlxmv0Ig/K4Q== X-CSE-MsgGUID: T/mZ1PGzRBiv8IYA6XWpXQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.15,320,1739865600"; d="scan'208";a="147093876" Received: from orsmsx901.amr.corp.intel.com ([10.22.229.23]) by fmviesa003.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 May 2025 04:03:18 -0700 Received: from ORSMSX901.amr.corp.intel.com (10.22.229.23) by ORSMSX901.amr.corp.intel.com (10.22.229.23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.25; Wed, 28 May 2025 04:03:17 -0700 Received: from orsedg603.ED.cps.intel.com (10.7.248.4) by ORSMSX901.amr.corp.intel.com (10.22.229.23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.25 via Frontend Transport; Wed, 28 May 2025 04:03:17 -0700 Received: from NAM02-BN1-obe.outbound.protection.outlook.com (40.107.212.74) by edgegateway.intel.com (134.134.137.100) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.55; Wed, 28 May 2025 04:03:15 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=NSYYbcAlptDE6DqIARhFDifGX6QKW4hzXPdONNXJQPt+WXH98WYxk7ncWlQhwDbULSBGUt8cHOohCqUt3ECxqrNnX8KQh+XBHXoRy6QNBcV4F8vyG5xyIVmWd/4yjBF1+dKCI3uLqkSEqSsVczOm0vYFh2p2rpOACu8hvxmUERsJdRa5h4WPdpY67OmbyOgJiuT4QTksGzDxdXE8lVi+/WADn7kb+ZqT9XAf93jggTpe33XYcZ9gpbM7Q4HFLsD92CvCST3M7fW+FxEggZStb1kc+ki/uLndWrFHnunbkGAGmQIIrHbt7Eeeo+fbIaT9ntT3WWheBTH1MAVRvxXQOg== 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=AlV3SwneMAMeJkpoN2FgHwuGWMdHEU5cixO/XjrZ4Io=; b=X6fr0tABz2YjajZMENkgzSpKd9Z13Im3NbOu85mBokk8xuw5qumnub7rObis6gkCjYpy+QZYf1wPkrxhgex2h3WnPmSTKYRECtyM42OfNAXtaX0W6NlpKigOnoe14iBQkkO6A2z/aFaFs3ljcvONOjUAA4BXvqVFxkBDv7IXKY3NG+IDRDm70gpl0YIWbAnNcTjAnCb8VWROkVpMiOruNay+XRCnzx3DpAduw5RU18nhrilxHc2+cvhh4dsYw3K7p6XjY1okZLn+kWHVE5e3e+jDUWdli/sMPOm5ihjvDSYDKfgGAxb2TR9cGo+S6f4Fjxqdx/mvhvp2O4F2Q+o5aA== 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 DS7PR11MB5966.namprd11.prod.outlook.com (2603:10b6:8:71::6) by SA3PR11MB8003.namprd11.prod.outlook.com (2603:10b6:806:2f7::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8746.29; Wed, 28 May 2025 11:02:53 +0000 Received: from DS7PR11MB5966.namprd11.prod.outlook.com ([fe80::e971:d8f4:66c4:12ca]) by DS7PR11MB5966.namprd11.prod.outlook.com ([fe80::e971:d8f4:66c4:12ca%2]) with mapi id 15.20.8769.021; Wed, 28 May 2025 11:02:52 +0000 Date: Wed, 28 May 2025 19:00:16 +0800 From: Yan Zhao To: Ackerley Tng CC: , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , Subject: Re: [RFC PATCH v2 39/51] KVM: guest_memfd: Merge and truncate on fallocate(PUNCH_HOLE) Message-ID: Reply-To: Yan Zhao References: <625bd9c98ad4fd49d7df678f0186129226f77d7d.1747264138.git.ackerleytng@google.com> Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <625bd9c98ad4fd49d7df678f0186129226f77d7d.1747264138.git.ackerleytng@google.com> X-ClientProxiedBy: SI2PR02CA0047.apcprd02.prod.outlook.com (2603:1096:4:196::14) To DS7PR11MB5966.namprd11.prod.outlook.com (2603:10b6:8:71::6) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DS7PR11MB5966:EE_|SA3PR11MB8003:EE_ X-MS-Office365-Filtering-Correlation-Id: 207562ac-6671-4df0-f705-08dd9dd7312f X-LD-Processed: 46c98d88-e344-4ed4-8496-4ed7712e255d,ExtAddr X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|7416014|1800799024|376014|7053199007; X-Microsoft-Antispam-Message-Info: =?us-ascii?Q?2ZMw3ii39VTNkSGTXs3sSel+Qums+SII0Th57ehA5kG5KuZeoYKazvstQnAZ?= =?us-ascii?Q?hE4PquOhtlLDqfLx03p/bMHFQeOMj54a88iyspxKmWVq5M6fOencQgN11+tX?= =?us-ascii?Q?knk9PXV+rB9nHtGkus+IzDdKb4vfVu2DOPRQ8Zcyjr+Lrwxz7V558SyPTmzT?= =?us-ascii?Q?WtM113rDtTZL/FKsxx/WoLsiXaFsHBMZ+Gd1ppKbup2QkQLLgqwiGNNms4I9?= =?us-ascii?Q?hwBuO3za3FV9qCBLfa/8RrZ2Vqi9B/4XuoEpc+cszVEUS6ufJdcQndepKe7g?= =?us-ascii?Q?pOhWhR9/ElcnbTSpXYWO8qp+G4cKVRLbORs6MZbvn5wUW4GVMhDqM0RlzezA?= =?us-ascii?Q?//bcLel0PM2dDSwfWy172J6KUNyTxe2bAXFEZfRoUWKvluEUjqz/R2KJlAod?= =?us-ascii?Q?c74Sfw/ss5Kohw6eZM6OazHtQLSmx2M3HiEcwAT5tyC58doU1XoTFIeiCFQc?= =?us-ascii?Q?dvNmfNkSb7IWSTgv+B6uo2LwYqCyYEdGM9RrCxT9q8sS25HfzUuUZ6b81LSm?= =?us-ascii?Q?GXSQoXl1ddCLbe4tIqFpRttHT2rut05r3+KAU6RrglIhtiKZ5nUdfZ5mjREW?= =?us-ascii?Q?zJpAkfxcRmMGid27wgEcXOCS/2r459f2WOAoWnn3FcwObjrhpWOl6EvK64bC?= =?us-ascii?Q?EwNX3F3fTbsxdBUjoCzCGgJHnIGHzfl3TNnQ2q6Yd92JkE5C8cz9CvTKtFxZ?= =?us-ascii?Q?SBR6pFO5yy9yTLBenEWMQGzdxRbl4kkA9TFC6bHRjplIelrpR41XKJkJAt3G?= =?us-ascii?Q?cVKFlZw/zNtVirWL13GuYCJD9IWkRJTJC4VMCrkcXeFkr3mkm2Z2qNzce4Ip?= =?us-ascii?Q?56+hv1qRmXhZm6erjnDHQHBBuB5yW69kvAZKJThGZaaBTtHVGjjhqxDI09br?= =?us-ascii?Q?EKo7YwAH2p7uAThq7Qe1g8Appns7YytewxSSq/AEHEcq+cZLHW2Qc0U5Mk+p?= =?us-ascii?Q?pO8YFRJxvv2dZBGa4fE35hk/QrOzSlRu3Sj954atLYhEWil0rcJEw7s+Zwrz?= =?us-ascii?Q?TgbS4q/lkPy70bjxo0Sh2AODDhoID5RKN2FPF4H3EPFsNYxM1aW1Iv73CjF5?= =?us-ascii?Q?sqU4/UhyOiiqPYBSWIry1Qe+n6czhb2tUZfvRs8tje+fH/0ZbYU6FYyyaTsm?= =?us-ascii?Q?U+mZxpW+hNNe99mLuJEKJNs23iCaU5PQBjLwmt92BiEohHLB1S5u816SBBPs?= =?us-ascii?Q?kce5Cx5k4BypV1r0+zOr7tht0d9uqOc1+MOzAUNtv8gMnpDyUB7ikv5nXuJJ?= =?us-ascii?Q?vZKm3+b6cV3jb4ZnUOBdsYUSrcx8F+QqIEbTwFeOmIdyUlefjDol/wwjPTdp?= =?us-ascii?Q?El398ycOSkqXgW72CFGDPhP6kdMmdzXrwfSnB5H6rV71d0fbqtUOmAne7Byk?= =?us-ascii?Q?DE1bXXoK0YQSlwy5avkABL3Xg9Zpi0GzS+1uvYboa9pfdOYyc3oScoa+32Jf?= =?us-ascii?Q?O4cpSJlfST4=3D?= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:DS7PR11MB5966.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(7416014)(1800799024)(376014)(7053199007);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?wMxOB19zsH9AAl2ev6Mg7pdDeY9RbsFBveq742egFeC50R8OhVHu3itmKonm?= =?us-ascii?Q?ZuwGEJYo+SXu1AHBBOWBiCXkuJe36tisaqNrDSO3w5ZThwdMoC/8dsC/FQRx?= =?us-ascii?Q?YHCJ9A/GlSqk1NtG1SRBTPHe3erAt6HM8k+fDt3L+o5yrpHSgGa+HoyAUc44?= =?us-ascii?Q?f1cMkEoNu3JJELJmQC7/o6xrkgtvEBSPp+RVwssnMZeG2Ho/YOVcD/s9isd8?= =?us-ascii?Q?rqlzCL6mzADKcU2CUCkHK0DF5jg5uixKxPuA2k8hkmNWeBOV45sD4xT+kTUT?= =?us-ascii?Q?jnAxmImgsXT8HJ80CcH/rgFZzCls90xnCTV6sdJprJBgmi0bchgo2+8N6JLR?= =?us-ascii?Q?nhJRFTu6f5MrhhZ37rg6Kl86bRlWfwTukHqAZJoXH1fzLbD1h7+rPQqxpOEr?= =?us-ascii?Q?3dMi3Lma5nbXfqsNrjSjNyMdJazcKo7ai8WusMOrZaqALxwplZNCxjjBJCSd?= =?us-ascii?Q?lKAJorJjJUkyS5bFGgEHigznPZjHDF80ESZG652XlzQSiBwxAUGVaoCLLJDz?= =?us-ascii?Q?FjDYD5PF/IO842Y2nzhTT63cJUWdRU5B/JmgkzYDKTQlbAWTgmhwRdr/xHVd?= =?us-ascii?Q?7/TXyFBvddHLXi6xd1Z5OvnVhGa4B0MwAsAOn1i/Jrqa7/KO3y49pYn3Uyab?= =?us-ascii?Q?O7/zE58M8tZwwXmdSrGt1+dQwwBgKAXxq8Qm71rCZFnovY1ltSOlQuVdIEDw?= =?us-ascii?Q?thbTc+VUNjZsM61PC92ZcRv4Kfri5ttilvEdbO4HU5LN0FuKP3k93YM5mx3W?= =?us-ascii?Q?7iEkp2KoMoTkzdiGwnFS6CnQ78gBrVUnbhC/LvGDx19/TZsoY4z5X08IqwjG?= =?us-ascii?Q?cTgfto/cNxHN7AIgCapynn8wQysyGja94Ry7fSlSU2xR5GfNIJlHUOtf9Yak?= =?us-ascii?Q?c0/BnFr1fdF+FuZFtScFFW368qdw8uaEJhN32Fwi/3NeKNY7emx/LiyoQ4Nn?= =?us-ascii?Q?+XbTPzm3x5601fJbmcaGHh5ZREARwT3dtB47IDRncG/tVvNgB+PYKod1edy0?= =?us-ascii?Q?O+rkl3xMJTPh6gRWbBgt8GIE9bmNfel/S5gJ8jV8aU21ML5Aky9l7oXhNVcX?= =?us-ascii?Q?O1il04yYXZTHMGxG35t1aSSzjqi43ZKiW8PvVoqUE/70snbCEQN1RLFaHSJ1?= =?us-ascii?Q?ZrHRt5aslFiGPRB1qw2OfyBHj9Tjf8bL4vOMEI7xh07Tm9q2ysPPiSkCE7S0?= =?us-ascii?Q?W0lCMBlX3uxVQj89ZNZUAmgfQ3Osro3F/S7A3l3dEn5uRG/UG3MQJWEZPONs?= =?us-ascii?Q?xQG+baVYhOkzGZka+WGwMhFaZ11pnm2+ijXSAfwWsfrL94+0ewT7AxQ7N2+Q?= =?us-ascii?Q?SDBUqEVgn7s1jRJP9D9YsuNGXxoHwLT/c9e0aJ4fyQmv4abzeNqprc+hFPcT?= =?us-ascii?Q?z0PPXYKCKMkjMHNLpl9Kxfl7Lhf8WWQO8K24oXTc1bSfwm6Aziabh7vX2USC?= =?us-ascii?Q?fbXZHMBc5dpnCVW9QK33BcNXKnlRoNo93JNtN7h1yEFbnKkmi0hRxXdiQTJc?= =?us-ascii?Q?hEpCVHVoFUw6i0zFYdMgASHw1pP+wLTTyzOsnfJSBLzLbhWna2k036vdRypU?= =?us-ascii?Q?KzU1NHNocTBTclJ+kUu6RsbOuWjxCNXm9pcx5fb1?= X-MS-Exchange-CrossTenant-Network-Message-Id: 207562ac-6671-4df0-f705-08dd9dd7312f X-MS-Exchange-CrossTenant-AuthSource: DS7PR11MB5966.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2025 11:02:52.7711 (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: IAO8Bda1XHgMPuulh5JFrdZHRHWvWKsy8K49DJ62da8wSvUXpnzkcvqMVmnptqe+2MSae2tCT9fdKT9pun2b7w== X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA3PR11MB8003 X-OriginatorOrg: intel.com X-Rspam-User: X-Rspamd-Queue-Id: D57E0180012 X-Rspamd-Server: rspam09 X-Stat-Signature: gbhww7gktxsftpcbj4aj5bdqzzz1xfnp X-HE-Tag: 1748430207-773554 X-HE-Meta: U2FsdGVkX1+9boyamYzSfm9hEMMGDsQ1M2u/tv0L3MUxALKNgXwrSGDhbgY4lGu6j708aFT/NjQbC93VvoSS8PSndXkx9ewmW1adNHy8UoIe60uUKNlF1B03qEV7JtPVckVItUMHNepTp/PeZzHwFlLLOuEU+7JcamUEEsyJuP9ZUAwNPA/hg1Hg7QDQ66bnVb0J8zGPcy5SW+oDZGhHbOdGKUCYmlyS0XeeYO346FnCeQF/heQdSi2HXqsoUDnXRti/aXjd+ZEY6k7akf9WdG2InBWtGnAR2ukGDGBE35Y4ReaAOXbDLdy4vxk9TTRR5GTqGVTtWv3Ei0PWa82hE5PIyynaux/oiG33+6JkWR4zAzdyjXTMgin46xymMCaMpGRBANcIpqzGw2uL6QbLQfxoczUYosFoq7JW+Rh4jh2KYDk9Z3aWtNnxkTe4I6XAG37KLCwhMvIxTZs1a/YjL/CrT0fVevgH4UgpMFoJ09/NO5STmCde5ilsYpcWvghjgzCv7zoyiDyb3SYv1g7aTTQdImK8ZRC0uI/eMIryA+p0bfwYCktbSggMrGB1YPZKvV0ND2CQ8DZ3OicDWt3UNph/AAVY1minr8QE9N/X/lACzqJloPIPom42aSMNj20MinA/mHIUAoilNJZyhUglgObfvGYObvvqJLUlCBLO2gjKhxmP4+nwRZSZ59iooyh5Nx8pDOMo2G63zWTLMK/9e9G9xMqM0fnLOzdOuUWfGI1ipJu8GbMx8wqi7A0cH/96o63TVyVQ4gj7AdUtkceX9OjoYYcEZjbpQILOWDNysFp63lzKR9BxSeZORAmI1V9ix16rTuXjn/Bgp+evWnyK8SGYaf4sktBmuK+d1eOILcLdcCnEt/h5Dffq6cukFcEePiyb7qy3gCj1AehW1vuf6+HMFvCn19XLUuRlAICA4vsG+Q1GZctEsFjIKIB60r4ubJja9th4IEfpe+mXqhx 8Jqmqz5t 0+Mc3EYB3+GVvrKPHwnN5uDEArHUiiZMabvyhOTdsTF5snfdV/bwMEKHM9PWydnIhAxeY2OSjLRwP36qa1w5HQW4xQxHuxyXQgoBM/ojPAjLJ20iRAjCFvvmKX2pgdgnWrpU3CYp10m8o5jgZJHWhh1/qxTSSRkMTNHqRN4GxK7Qc8LHPLeJEO7pXeBhU7JEIfNNtCGnILOKQLbq1CuKW1E1tInImgwVSWRhLqgTleT5jYQdcsBvnfYn1wmO2TS8IeZCzmivk9Fl2vdiXZ7Z2YL8qS+6IQt78Dko78/IRSN787EYaiQKJBzN9F5fyO2uGZkvIqLMGeLpTyxyn65ocqCLaW/fw1gN1TfRnQ6dM3HPzQQHIet9ZJxC6Cq6bRfEXzZvlbm2tcqvGMWkD1v/22BH419sKs983hrPHaTPYszMTGLA+z4tD1FVISENi3NueMvevaa9Qq18HXcLURUxS94GjudX5F0plBxgF51QmyBoQ55lTIJkfFkPJGLFGNHJgakoRruScYVV+Zgb/SQlqvqssvjaBeXj6TwlVFtPUHfT6lAZEmerMthvcXLj5RfU+ndOC34UZmM7bjX9JqEzwCwQMZpi4iCzdjU+u1qcsJ8k0IaE5t879gsAMXyb7vcVm/XkUuP/bw+k65EqFLDUJg+xRGdjAwRjpOmse2dCsteczTpMD0oEySol30n059X8XAeyH3unvOUyqqneip9mXXMancdXPInnpCggMwFW6OA75hkYFahHJRudkQ63Axxyy4e20QbDku+YR+0Q= 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, May 14, 2025 at 04:42:18PM -0700, Ackerley Tng wrote: > Merge and truncate on fallocate(PUNCH_HOLE), but if the file is being > closed, defer merging to folio_put() callback. > > Change-Id: Iae26987756e70c83f3b121edbc0ed0bc105eec0d > Signed-off-by: Ackerley Tng > --- > virt/kvm/guest_memfd.c | 76 +++++++++++++++++++++++++++++++++++++----- > 1 file changed, 68 insertions(+), 8 deletions(-) > > diff --git a/virt/kvm/guest_memfd.c b/virt/kvm/guest_memfd.c > index cb426c1dfef8..04b1513c2998 100644 > --- a/virt/kvm/guest_memfd.c > +++ b/virt/kvm/guest_memfd.c > @@ -859,6 +859,35 @@ static int kvm_gmem_restructure_folios_in_range(struct inode *inode, > return ret; > } > > +static long kvm_gmem_merge_truncate_indices(struct inode *inode, pgoff_t index, > + size_t nr_pages) > +{ > + struct folio *f; > + pgoff_t unused; > + long num_freed; > + > + unmap_mapping_pages(inode->i_mapping, index, nr_pages, false); > + > + if (!kvm_gmem_has_safe_refcount(inode->i_mapping, index, nr_pages, &unused)) Why is kvm_gmem_has_safe_refcount() checked here, but not in kvm_gmem_zero_range() within kvm_gmem_truncate_inode_range() in patch 33? > + return -EAGAIN; > + Rather than merging the folios, could we simply call kvm_gmem_truncate_indices() instead? num_freed = kvm_gmem_truncate_indices(inode->i_mapping, index, nr_pages); return num_freed; > + f = filemap_get_folio(inode->i_mapping, index); > + if (IS_ERR(f)) > + return 0; > + > + /* Leave just filemap's refcounts on the folio. */ > + folio_put(f); > + > + WARN_ON(kvm_gmem_merge_folio_in_filemap(inode, f)); > + > + num_freed = folio_nr_pages(f); > + folio_lock(f); > + truncate_inode_folio(inode->i_mapping, f); > + folio_unlock(f); > + > + return num_freed; > +} > + > #else > > static inline int kvm_gmem_try_split_folio_in_filemap(struct inode *inode, > @@ -874,6 +903,12 @@ static int kvm_gmem_restructure_folios_in_range(struct inode *inode, > return 0; > } > > +static long kvm_gmem_merge_truncate_indices(struct inode *inode, pgoff_t index, > + size_t nr_pages) > +{ > + return 0; > +} > + > #endif > > #else > @@ -1182,8 +1217,10 @@ static long kvm_gmem_truncate_indices(struct address_space *mapping, > * > * Removes folios beginning @index for @nr_pages from filemap in @inode, updates > * inode metadata. > + * > + * Return: 0 on success and negative error otherwise. > */ > -static void kvm_gmem_truncate_inode_aligned_pages(struct inode *inode, > +static long kvm_gmem_truncate_inode_aligned_pages(struct inode *inode, > pgoff_t index, > size_t nr_pages) > { > @@ -1191,19 +1228,34 @@ static void kvm_gmem_truncate_inode_aligned_pages(struct inode *inode, > long num_freed; > pgoff_t idx; > void *priv; > + long ret; > > priv = kvm_gmem_allocator_private(inode); > nr_per_huge_page = kvm_gmem_allocator_ops(inode)->nr_pages_in_folio(priv); > > + ret = 0; > num_freed = 0; > for (idx = index; idx < index + nr_pages; idx += nr_per_huge_page) { > - num_freed += kvm_gmem_truncate_indices( > - inode->i_mapping, idx, nr_per_huge_page); > + if (mapping_exiting(inode->i_mapping) || > + !kvm_gmem_has_some_shared(inode, idx, nr_per_huge_page)) { > + num_freed += kvm_gmem_truncate_indices( > + inode->i_mapping, idx, nr_per_huge_page); > + } else { > + ret = kvm_gmem_merge_truncate_indices(inode, idx, > + nr_per_huge_page); > + if (ret < 0) > + break; > + > + num_freed += ret; > + ret = 0; > + } > } > > spin_lock(&inode->i_lock); > inode->i_blocks -= (num_freed << PAGE_SHIFT) / 512; > spin_unlock(&inode->i_lock); > + > + return ret; > } > > /** > @@ -1252,8 +1304,10 @@ static void kvm_gmem_zero_range(struct address_space *mapping, > * > * Removes full (huge)pages from the filemap and zeroing incomplete > * (huge)pages. The pages in the range may be split. > + * > + * Return: 0 on success and negative error otherwise. > */ > -static void kvm_gmem_truncate_inode_range(struct inode *inode, loff_t lstart, > +static long kvm_gmem_truncate_inode_range(struct inode *inode, loff_t lstart, > loff_t lend) > { > pgoff_t full_hpage_start; > @@ -1263,6 +1317,7 @@ static void kvm_gmem_truncate_inode_range(struct inode *inode, loff_t lstart, > pgoff_t start; > pgoff_t end; > void *priv; > + long ret; > > priv = kvm_gmem_allocator_private(inode); > nr_per_huge_page = kvm_gmem_allocator_ops(inode)->nr_pages_in_folio(priv); > @@ -1279,10 +1334,11 @@ static void kvm_gmem_truncate_inode_range(struct inode *inode, loff_t lstart, > kvm_gmem_zero_range(inode->i_mapping, start, zero_end); > } > > + ret = 0; > if (full_hpage_end > full_hpage_start) { > nr_pages = full_hpage_end - full_hpage_start; > - kvm_gmem_truncate_inode_aligned_pages(inode, full_hpage_start, > - nr_pages); > + ret = kvm_gmem_truncate_inode_aligned_pages( > + inode, full_hpage_start, nr_pages); > } > > if (end > full_hpage_end && end > full_hpage_start) { > @@ -1290,6 +1346,8 @@ static void kvm_gmem_truncate_inode_range(struct inode *inode, loff_t lstart, > > kvm_gmem_zero_range(inode->i_mapping, zero_start, end); > } > + > + return ret; > } > > static long kvm_gmem_punch_hole(struct inode *inode, loff_t offset, loff_t len) > @@ -1298,6 +1356,7 @@ static long kvm_gmem_punch_hole(struct inode *inode, loff_t offset, loff_t len) > pgoff_t start = offset >> PAGE_SHIFT; > pgoff_t end = (offset + len) >> PAGE_SHIFT; > struct kvm_gmem *gmem; > + long ret; > > /* > * Bindings must be stable across invalidation to ensure the start+end > @@ -1308,8 +1367,9 @@ static long kvm_gmem_punch_hole(struct inode *inode, loff_t offset, loff_t len) > list_for_each_entry(gmem, gmem_list, entry) > kvm_gmem_invalidate_begin_and_zap(gmem, start, end); > > + ret = 0; > if (kvm_gmem_has_custom_allocator(inode)) { > - kvm_gmem_truncate_inode_range(inode, offset, offset + len); > + ret = kvm_gmem_truncate_inode_range(inode, offset, offset + len); > } else { > /* Page size is PAGE_SIZE, so use optimized truncation function. */ > truncate_inode_pages_range(inode->i_mapping, offset, offset + len - 1); > @@ -1320,7 +1380,7 @@ static long kvm_gmem_punch_hole(struct inode *inode, loff_t offset, loff_t len) > > filemap_invalidate_unlock(inode->i_mapping); > > - return 0; > + return ret; > } > > static long kvm_gmem_allocate(struct inode *inode, loff_t offset, loff_t len) > -- > 2.49.0.1045.g170613ef41-goog >