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 90B2EE77188 for ; Wed, 8 Jan 2025 22:30:50 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id F09F06B007B; Wed, 8 Jan 2025 17:30:49 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id EB9A56B0083; Wed, 8 Jan 2025 17:30:49 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id D0BA36B0085; Wed, 8 Jan 2025 17:30:49 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id 737EE6B007B for ; Wed, 8 Jan 2025 17:30:49 -0500 (EST) Received: from smtpin11.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id F049D461FD for ; Wed, 8 Jan 2025 22:30:48 +0000 (UTC) X-FDA: 82985730576.11.DD7300D Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.15]) by imf10.hostedemail.com (Postfix) with ESMTP id AEFD9C001F for ; Wed, 8 Jan 2025 22:30:44 +0000 (UTC) Authentication-Results: imf10.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=JyUZgVtR; spf=pass (imf10.hostedemail.com: domain of dan.j.williams@intel.com designates 198.175.65.15 as permitted sender) smtp.mailfrom=dan.j.williams@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=1736375445; 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: in-reply-to:in-reply-to:references:references:dkim-signature; bh=ykbBEGif4XNRDhG36JaAk+Vmea7aHk59vZUxCFqzNI4=; b=cRbn/YSq/leQ3ewPI/edOxJ6GAKMOhSqiboDbphfcCpvO9Z4KsbTNttr9YPxox2/lRVIot zoeDrIDDKmSLzd8RKstkULnF7/jm7uXmWgggRreJpqVuM5FSYAX8tJSHIy+oDwGISoiHd/ zJ8dkxDOq/5q33i7vPeuKtacgjYAM18= ARC-Authentication-Results: i=2; imf10.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=JyUZgVtR; spf=pass (imf10.hostedemail.com: domain of dan.j.williams@intel.com designates 198.175.65.15 as permitted sender) smtp.mailfrom=dan.j.williams@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=1736375445; a=rsa-sha256; cv=fail; b=FnXUnrjnVc9mILR5zmCXhk2qmoVJcFEQ5JhvTbCH7qm0ZuqQ5w7aDglGqVV5IGpwB8aTiL 8YIK27FT0r+Q6Usd3d8ecBYJzhl5ZnQNdpkXSFHcEq/ehiLFkfJ2uJjWp73P/tPF2yLXf1 GsSWec/d0fR/eVv/+9MgZXojU+zUznk= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1736375445; x=1767911445; h=date:from:to:cc:subject:message-id:references: in-reply-to:mime-version; bh=aHQnTe84JFR6oZp9hU+QpGxeaw/PYiqXZ2FmrWnqA6o=; b=JyUZgVtRadRRJTZdtljSV0uoVIGiVHKMJN9MPXiXrdnwFHjk0SrPX/Ik HgTM5hkK4n5AufloHSutMv3guEKAbpfI/yzJ3ROswzD9Cnva+/Mypyz1g S2V/UHtFJKkvGHXubDCZibNKsrNfi/7A4buWQ7ntsf/PEgEcO30Q32pAv 6YFoz/k4ElWSMROzwnCi/PynjoPl2oYasPIMA5OyD1dvDDWRMAMMnWUjo z2GueKecImfB/x9aBNeRhg2Xr/IwtZWZZBnUB9MQpyU2F9XzktmwxmR12 FJpnOQILHHxWd9VFaiTsgLYZgbDNpFqVt2Gh2kMj7bi3zxmqni/x5lxKh w==; X-CSE-ConnectionGUID: ivhzfYjzTX2/nwqePAaJQA== X-CSE-MsgGUID: j793jphiQh2OAqCfQgRZgw== X-IronPort-AV: E=McAfee;i="6700,10204,11309"; a="40300350" X-IronPort-AV: E=Sophos;i="6.12,299,1728975600"; d="scan'208";a="40300350" Received: from fmviesa003.fm.intel.com ([10.60.135.143]) by orvoesa107.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 08 Jan 2025 14:30:43 -0800 X-CSE-ConnectionGUID: 5X6oa+mkRIaQmI64WVqIaQ== X-CSE-MsgGUID: Uj4C2n0ET6+Mr7aVXAIM9g== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.12,224,1728975600"; d="scan'208";a="107268706" Received: from orsmsx603.amr.corp.intel.com ([10.22.229.16]) by fmviesa003.fm.intel.com with ESMTP/TLS/AES256-GCM-SHA384; 08 Jan 2025 14:30:40 -0800 Received: from orsmsx601.amr.corp.intel.com (10.22.229.14) by ORSMSX603.amr.corp.intel.com (10.22.229.16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.44; Wed, 8 Jan 2025 14:30:37 -0800 Received: from orsedg603.ED.cps.intel.com (10.7.248.4) by orsmsx601.amr.corp.intel.com (10.22.229.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.44 via Frontend Transport; Wed, 8 Jan 2025 14:30:37 -0800 Received: from NAM10-MW2-obe.outbound.protection.outlook.com (104.47.55.45) 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.44; Wed, 8 Jan 2025 14:30:34 -0800 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=yx7YXyGCcdxcX1cblNhA1RKtw6xJlCvdCpFeqelJ2E8oVIBVEncQXrRet6GNAU4rzOdskSN0D+zn4c9RYIr+z3bXAYaNoSe3nT3HYVwcTjVWjCJaGfUB/Jm5etT7jJ9U22g3P4NIv8Qd1qBq21XK6HSx7rAIiorDKTMcPAHLe/6lGLeo0dWePAB4utN1b47dM0diTs6Oqmu/nvy+jU0X3q2LrnFr8vC87GFQFvCvEo5wS6rwlbxvxIS+xF7GF/u8fEu6dUUh17fWLO6qtpHcQQq0/MCtEsUEJ/KCH3Au3zrR1KOr2f6dEF9h7hq6OoK/THpxFFIRh+ouibqj5EsnmQ== 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=ykbBEGif4XNRDhG36JaAk+Vmea7aHk59vZUxCFqzNI4=; b=vPnQHM6YQMC1jmjLoWlo3bsw8prvRawBlQNwiqrjHRacyJUz1Q03MAgk8WO+bQy0oniGXfAHGLMD1m/i/9wAA+ugrI8ZhdhNqLHnvBuMFVZ/8/lCaxcMLC1fHOOHnfvGOUI0F+HFRhOXU03yqH+GZTy3Nr/HPxEFqEydHQrJ86Cmx+tJjeQjDFmPR2JO2lFrAqj7o4/ZFG17VpTj4qRj3ms3tm5uGE8JBTds16jJDyZWpxEjeM6Judr6D9K9b0E2syRFqONjzFGUy3NHDJjxixwQ2T27WCO8zrww2PAmGLsAWAdiCq5BMLUb/UTNSdjuNiLHFk6tKVi/TU9T3HO0Hw== 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 PH8PR11MB8107.namprd11.prod.outlook.com (2603:10b6:510:256::6) by IA1PR11MB6515.namprd11.prod.outlook.com (2603:10b6:208:3a1::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8314.18; Wed, 8 Jan 2025 22:30:28 +0000 Received: from PH8PR11MB8107.namprd11.prod.outlook.com ([fe80::6b05:74cf:a304:ecd8]) by PH8PR11MB8107.namprd11.prod.outlook.com ([fe80::6b05:74cf:a304:ecd8%4]) with mapi id 15.20.8314.015; Wed, 8 Jan 2025 22:30:28 +0000 Date: Wed, 8 Jan 2025 14:30:24 -0800 From: Dan Williams To: Alistair Popple , , , CC: Alistair Popple , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , Vivek Goyal Subject: Re: [PATCH v5 01/25] fuse: Fix dax truncate/punch_hole fault path Message-ID: <677efc80b6fcd_f58f2943@dwillia2-xfh.jf.intel.com.notmuch> References: Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: X-ClientProxiedBy: MW4PR03CA0332.namprd03.prod.outlook.com (2603:10b6:303:dc::7) To PH8PR11MB8107.namprd11.prod.outlook.com (2603:10b6:510:256::6) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PH8PR11MB8107:EE_|IA1PR11MB6515:EE_ X-MS-Office365-Filtering-Correlation-Id: 21ff0cda-5c21-4626-b66d-08dd30340ded X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|376014|1800799024|7416014|366016|7053199007; X-Microsoft-Antispam-Message-Info: =?us-ascii?Q?rrljhjsUxLjzj4KWSbEbkQLiccfve+AQymkydoNzBI0QwfqNlkKmNJw2TBO7?= =?us-ascii?Q?YDFBnAQxMVBsyigzG47Q5j5mwjrtt8cXlkBnqM9Eq2qJKGwVF1m1lbtCaga+?= =?us-ascii?Q?dtwxClhRT2xH42VG5BJ0zBCNjM0zyAk+2rxDNi0bEe1SvS0fRW1W3Rl9Rwxg?= =?us-ascii?Q?pDwyfd66gTv5T+bb9nj7QJ9M4ecLAYsf064aMt/MfhrlC5Xn62VQJtgL2FH1?= =?us-ascii?Q?N2YzsBrPH8siikCGa9eCK7D3wcvM9Q08jUsKr00fCwkGfdtPAR1I4+WDtEDt?= =?us-ascii?Q?p+Zd7+WGo90PQ769Z9T6xS4AXZdVnHK37a21hqXxBoXu9HTpa6VT+zt1Q/zG?= =?us-ascii?Q?htTx72Yt172RrMapx335QXSDRmtZ1tVZWmUk95jApBqHzkbbkMK51iczcaIK?= =?us-ascii?Q?hWFQ3Jvdy0vgZtLy/nE0qV3syJv0kIQTCjSwhWSWLDQdlgfGdQxKlCC5jMig?= =?us-ascii?Q?9/PLeizF0scssDywqYoip7WUURZC4ipD3P31/iGZvseXknsT/onKWLsKLuPn?= =?us-ascii?Q?q0G+AqxPiDo5uutCji8xxOuLo6SC5FZi8wi3v6pQ+nJkoZ+Kc/YlIKkx+Zd6?= =?us-ascii?Q?gvX1VthdrFBihE6KNBXlZqi/9dsRCWMEA5BX5Kq24BtILwrhmK6w6MLVIBe7?= =?us-ascii?Q?S0wNQQPwPUhhrakvnaXMPZpg0TGiat8OVbDY78cam+mFa7YTNQwKDmF3/PcE?= =?us-ascii?Q?wekfLc0QpBKqyS3I34ARiHF9ibRvXMc97imLpEydCkAaybHNkN4n2CwD6nL8?= =?us-ascii?Q?B+fqpLiLRhULXgpBooAdS6VvPJymLXwfi1dMJtmrzTbd+ejqKmW8I6fFR1La?= =?us-ascii?Q?OMPkVCGYNH1HuwxGl8SCS0JEZYUa8b2pQHBUhIs8/8z0Zq2pxvPdoc7uBK2k?= =?us-ascii?Q?wlLbwYmxFfsvFmN1cGmLZ2bgA+y+2oS0liJrGCHxvxxvE/7KSbaCs5ueyXqe?= =?us-ascii?Q?nzoHwBwHAMVUKwcB2teVypx9G5GGnTK8MH5qvj7HJmlcwgQ/7L0ob6ckKzw5?= =?us-ascii?Q?Wk+NEIGUR+wRj62XcCJUMxLEk1BxZo9T6uABDZedBMB0PxuKlCCQbNhQS+ec?= =?us-ascii?Q?Vm1LYxkHTUhkIr7VMnlshOgjhpoo39BS2htt0qIDp/7eslTY0ZPWbXKWOaiO?= =?us-ascii?Q?gyfHH4vi3sfOz36B7ko2Uyvm3EMouXEllhQHUw6WHWZ3EJtn6i9h2t37wdes?= =?us-ascii?Q?Yro/hSoQKuPuQa7XDbSjMfPqu+Al2db38SBkF4QHVokgiqepbSssAwM6aCTq?= =?us-ascii?Q?sDU1WdFzDU0j2yNjfnTTusKz/Jjskm3NSdkZRtAia8kMIr9cyqEIRGeoBT3C?= =?us-ascii?Q?eDxKkGlQ8SLSMVhygXXYnRJRSXehc+pW8FNKHufSS3HY3kUE+nuk13pz4WA2?= =?us-ascii?Q?9R69AkPVlbNfvVCj6XRVAC64ZfFT?= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PH8PR11MB8107.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(7416014)(366016)(7053199007);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?5tGta5OLXNlbNl50woCwhOcXDX2iNsQkX3YmX9Hm92VPmiZvsYfI5XuKnabg?= =?us-ascii?Q?vYLrs+yRzPNPNBWen7qVv82Leh8rgcT/WFMnLBnh/7lCPjkvig0rnazCuNBS?= =?us-ascii?Q?yZlVbYTM2tqqX05CfVosbtvuibNjXQMui8qek5HwKQVj91D14UVP9AbOakxk?= =?us-ascii?Q?ZAMLjlqXNFXNg4EkLSf256lDDPRRikF4ssFCNS63/m5fgMJy1yPQG7w402l5?= =?us-ascii?Q?5Nu7ABu2T5zclbMgc/zYDK+ixJmWv2pLcxESHcbndJLHHfWK/xiN3gEsfN22?= =?us-ascii?Q?xZ1Bfeby5j3likcqkiUM2pPNDxmdfWK6Dw8tgGZMrIS8/xPYkIrjPkQ9Io0t?= =?us-ascii?Q?AsToB9Z6P+jydyKFs9XmwbraRD1ohNX9YZwkOvb+YSnVwlZSa6m5pZWsQU5y?= =?us-ascii?Q?kqeEPfDHmpaHR96TvyiSXqEtNkilUUQy7Fyl1TFIgIzY9SaN7fCdhoxkjZEF?= =?us-ascii?Q?4TZhUe7xZle8DkfXhVoSLJscWaRmpQHCQ7AyAfxCMytdi4DDPFLuvYckoS7N?= =?us-ascii?Q?3bO5J57Vol7/4blZEMKT40bv1JRzSbE1SRmSjQru8IoihMudmLHc1pnKaXln?= =?us-ascii?Q?kXVv9vkqWahKmg7sM427VkVtIC+CRSc9WmDCWidnUo6uvmPe3Hiwsj6pYyI0?= =?us-ascii?Q?hg54s6fokLRhvFM0NI7QPb7zdl5Wm8YjiXInbEidK7QszmDImCbZBCEXyS6Y?= =?us-ascii?Q?NXnWkEZFh2hwA5AQnogl+WlezYhlCQmrr8yzxgaX9wWm0Gmk1fd108PJXMvq?= =?us-ascii?Q?PUXkLjGUipJzIXj3dQOmDamlwPQq58FKvuxkJWCMOZaQ1Mna1o7ARO+trugs?= =?us-ascii?Q?dDehAfMHMVHJjCVWXqgXjlF6kItfkUvNVDZMSYNZqCMZVd/LTzbIERXqZsgR?= =?us-ascii?Q?Xjl7eJ0Ds5KhQ8IabuqEah6fghYIyAQgc4PjlC0sO02MW07cR1uZtkcCjy6m?= =?us-ascii?Q?JQjHnXLgeJdWsxpj/xwGqqG7HGeCtTydVNXyHyNkkFoDkCTed+FJzffzWt73?= =?us-ascii?Q?HK4FEhAcDMLgR7c3JLciOlUyJdqJJ7NxvHF6PEHFlq+CNd8IW/kXrz09swPn?= =?us-ascii?Q?1gEMbDrBmChpUTnW29mhswa+uY7wmf1x+ycBNNTLt9pc8VyZnqc4QnCCB5tH?= =?us-ascii?Q?/XIatV9hdjUUp+Rhbu/Po68oeDqOxaVc7GaSlzG5QO4IVzWNXXsppp+D1SYo?= =?us-ascii?Q?KmyBKLG+63fKJ5ryw6qYnj5c3DHaZ9te7rzmV9CDky6yyVVMxxKZU9cbx8zE?= =?us-ascii?Q?NvlS/WzaBujQYmisuOvHuzFMqbU30MdYZCfwEUf4vHmyqarV4226zXR9z34V?= =?us-ascii?Q?rLNo97mqRrNq99YgLiQGX6Mnud66tUWEokJfq+rOxux6325Fh/iFPUUmEtJm?= =?us-ascii?Q?g5QofYaA2B69SKfsWzaJkrqpXcQZOMMosaPvxB65MI+TAqwZzzV8dgJ+CfQJ?= =?us-ascii?Q?JNd4yPNpVmcyzq1t3Qf9Ckv6VC0LKEm3f4ayahS6ve6wUU0gFhUcERQZ7XUr?= =?us-ascii?Q?YCghrU3f1y2ObkdOpmGj3h3CeSCW/kOmwqjW7XM72e9hs93ka68Zf+/OtT7I?= =?us-ascii?Q?OGaxK16T1M63xWdaSqx/i59sI7z3bqnG8h0N52zZILO8gfOzHvdo+xSroqvR?= =?us-ascii?Q?gg=3D=3D?= X-MS-Exchange-CrossTenant-Network-Message-Id: 21ff0cda-5c21-4626-b66d-08dd30340ded X-MS-Exchange-CrossTenant-AuthSource: PH8PR11MB8107.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Jan 2025 22:30:28.8270 (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: WXBrvEC26o3punw0zuXc9hlZo6someai3quhvrBBab3FtfppVB9ajG6Xp5k89RrIfhrm+p3eAkZOq1Mi5T1U6b3vEWmdBhCXT+PhVLdS5us= X-MS-Exchange-Transport-CrossTenantHeadersStamped: IA1PR11MB6515 X-OriginatorOrg: intel.com X-Rspamd-Queue-Id: AEFD9C001F X-Rspamd-Server: rspam12 X-Stat-Signature: bskc996pt5t6gsjx17rbesnqijfqob5r X-Rspam-User: X-HE-Tag: 1736375444-986666 X-HE-Meta: U2FsdGVkX184iCUmZozjcuWu0IDsNFPmN7o4qWbmQhj9NuA05FWO1rTdV3DbQXVfDmBHfcZ1Kyk6fypCj3d0cKw/O32TsMdUjdQDddknF3FqSfjY/fO3HBDJdmooBK9xFuv7tZy9WvDHUWY2twJY1AAIsYDjAwYRJqdEs4vFymFudkrOzb/X9lToi09oSMCbZlnDhi/mhRBwrBE5gSLRqEFHM8/7K9QFrEqwfUvFcccpBZVJyzkvZUSuIGpyan4/HfOeq7pU8zMpe+wDi8Cy3RCGUR+Oihworhu/JsUWuhjK7eDylbaqLLR3wYcB+VMdthF8CAQCysaOElVI52MXoQ+3i9MOqAdv6jiXVQYL2U0DP4EAu0aAAaSiDbE10c8Mn2sMbLPv3/1YARrh2qfI/CNOmdREIyCXHvwAbohdVQ2JWTQdZq6MyMxuSwjTcwiVsmk4SuO+mvFzSJF5taktRmP9oSDhHxPn+H115tLZ0rzIfg8QcwO/mHNb95wT4ybNOAJzmBq9y1crvbDWpV23MFjdqtJW/ZvDfApAHpumi2ZCNXlyHheJEE6vzKrpiqVMtc7RNkxOP5fYOof0G44uakeq3QjqOMHbzAq5WO72ciuVnmMGKXnMNZdYo7sTACqWjjG2JDRcp97pMzfMUIQmWNgJ2RQ4oJjeherg70VNPy7oMoVfcphqE50pf9f4vtAaxmE4QWv0stzgymZ6rpVc6HjF/isSYmaX2JGQbzmsDUJLjuANB9fQfehWqibY3pkavkNHu7tkDcSLXcEVDtNRezzN38uyl9LGAel2JmTGHIvOKf98Pw7W62Vogao5kwkduZbslsdWtt33bD9+uBeMgLqCqJDEIoWwTmPwO+hTYG+7L74zGcPdVfkb83LudBCZJQ41A8v8Km5xC10+6WI9p3PJI6TmHgGtGenukMRYt11mpkShW6F2pxNXnOfREgWYw6jGVDsFzvW2Tp8l4p8 J03Qh9HZ 6oDC3uv1j6Di7pA9QgfigLVChQQN+OapxYKtm75XI9STW6bUHudl21XkaWMr/bBvtmDHdOweP4TnYnVIfWbAxhQKNO82ZBdgWddh6FSK1Ih8sRwK/FeRc/kZZ5MIkXh0zl9i4Cvz5qcw0o9FqremCKkZIeKHTu+3hu7Z3jbWhZFf/zyqsLsrXpfVfCiG9SkmwHS4iKihi9EqIhi8IePZAcHO+4kKXQ5AtHnAhSI3eYkkgATCAHrMO74oMpbJiGwn6KNlQh/paOCq8Z7+76W7/ypV46zcUFyU/BCnVnD90XuQBWtLuuPjsDYxHhpJIyfxVHR42EIkzmHdZOI0dXvNl0hjmw2znSlqDxbcfA9bFPzwNrDYtmE4yt1mU3vfWWR5ffqhJDXVRC1R8laeTLhwIf+yRFpyKyccmg8RwPngOYsc9qOM9OWDxEW2F+KgYY9DQ/B1UoyKFKXdk/Rfg/AbvTfjd3ZxGL6F/WkzsqT+C7C3vAu5dA6+pUrUFVLAZctAjM4FQFS0VNtq4HsHJI+yobe1FNeYn5rhdOp5PTe0NhpVkrj83YVaZbnMZRkHa97MbAj8JdvYkFujDI+c= 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: Alistair Popple wrote: > FS DAX requires file systems to call into the DAX layout prior to > unlinking inodes to ensure there is no ongoing DMA or other remote > access to the direct mapped page. The fuse file system implements > fuse_dax_break_layouts() to do this which includes a comment > indicating that passing dmap_end == 0 leads to unmapping of the whole > file. > > However this is not true - passing dmap_end == 0 will not unmap > anything before dmap_start, and further more > dax_layout_busy_page_range() will not scan any of the range to see if > there maybe ongoing DMA access to the range. It would be useful to clarify that this is bug was found by inspection and that there are no known end user reports of trouble but that the failure more would look like random fs corruption. The window is hard to hit because a block needs to be truncated, reallocated to a file, and written to before stale DMA could corrupt it. So that may contribute to the fact that fuse-dax users have not reported an issue since v5.10. > Fix this by checking for dmap_end == 0 in fuse_dax_break_layouts() and > pass the entire file range to dax_layout_busy_page_range(). That's not what this patch does, maybe a rebase error that pushed the @dmap_end fixup after the call to dax_layout_busy_page_range? However, I don't think this is quite the right fix, more below... > Signed-off-by: Alistair Popple > Fixes: 6ae330cad6ef ("virtiofs: serialize truncate/punch_hole and dax fault path") > Cc: Vivek Goyal > > --- > > I am not at all familiar with the fuse file system driver so I have no > idea if the comment is relevant or not and whether the documented > behaviour for dmap_end == 0 is ever relied upon. However this seemed > like the safest fix unless someone more familiar with fuse can confirm > that dmap_end == 0 is never used. It is used in several places and has been wrong since day one. I believe the original commit simply misunderstood that dax_layout_busy_page_range() semantics are analogous to invalidate_inode_pages2_range() semantics in terms of what @start and @end mean. You can add: Co-developed-by: Dan Williams Signed-off-by: Dan Williams ...if you end up doing a resend, or I will add it on applying to nvdimm.git if the rebase does not end up being too prickly. -- 8< -- diff --git a/fs/fuse/dax.c b/fs/fuse/dax.c index c5d1feaa239c..455c4a16080b 100644 --- a/fs/fuse/dax.c +++ b/fs/fuse/dax.c @@ -681,7 +681,6 @@ static int __fuse_dax_break_layouts(struct inode *inode, bool *retry, 0, 0, fuse_wait_dax_page(inode)); } -/* dmap_end == 0 leads to unmapping of whole file */ int fuse_dax_break_layouts(struct inode *inode, u64 dmap_start, u64 dmap_end) { @@ -693,10 +692,6 @@ int fuse_dax_break_layouts(struct inode *inode, u64 dmap_start, ret = __fuse_dax_break_layouts(inode, &retry, dmap_start, dmap_end); } while (ret == 0 && retry); - if (!dmap_end) { - dmap_start = 0; - dmap_end = LLONG_MAX; - } return ret; } diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index 0b2f8567ca30..bc6c8936c529 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -1936,7 +1936,7 @@ int fuse_do_setattr(struct mnt_idmap *idmap, struct dentry *dentry, if (FUSE_IS_DAX(inode) && is_truncate) { filemap_invalidate_lock(mapping); fault_blocked = true; - err = fuse_dax_break_layouts(inode, 0, 0); + err = fuse_dax_break_layouts(inode, 0, -1); if (err) { filemap_invalidate_unlock(mapping); return err; diff --git a/fs/fuse/file.c b/fs/fuse/file.c index 082ee374f694..cef7a8f75821 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c @@ -253,7 +253,7 @@ static int fuse_open(struct inode *inode, struct file *file) if (dax_truncate) { filemap_invalidate_lock(inode->i_mapping); - err = fuse_dax_break_layouts(inode, 0, 0); + err = fuse_dax_break_layouts(inode, 0, -1); if (err) goto out_inode_unlock; } @@ -2890,7 +2890,7 @@ static long fuse_file_fallocate(struct file *file, int mode, loff_t offset, inode_lock(inode); if (block_faults) { filemap_invalidate_lock(inode->i_mapping); - err = fuse_dax_break_layouts(inode, 0, 0); + err = fuse_dax_break_layouts(inode, 0, -1); if (err) goto out; }