From patchwork Mon Jan 20 01:29:10 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bernd Schubert X-Patchwork-Id: 13944648 Received: from outbound-ip168b.ess.barracuda.com (outbound-ip168b.ess.barracuda.com [209.222.82.102]) (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 C135B28373; Mon, 20 Jan 2025 01:29:26 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=209.222.82.102 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1737336577; cv=fail; b=kszvhQcjdEOzOT1HhPfTJyy8d7mYaFKE2dCffyf71D0WG3focoNCQbOKEDeEjGBJzKjhhNDhovudLpj2cPWDtkTStFA8MDOjfpQqS5LumI9wJWG/pDbt1drerrZ9W0+eSjSIk/rMI0XRdyGmmF/m2N+Za6LPMAVPp9Wj6PInhp0= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1737336577; c=relaxed/simple; bh=3i8xm5Y1fqUWaEUFdAiYLVi+P0PPRqb1MIt8B8j7Nfo=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=ZqOd+i6VOgdawwgeJ9vG8djYoKar6P1Gy8oB/kTNkpfPZw4hXQPTAqYLE3RjySwuhW0peJuDqfBhgo4vEptG39FmJWcsEAdbiE+IsooqmejmE4utCGRL0OHsazGQ8Wgf4/ZWYuze8ByHsgDYjx5Bb15bgHb/9DouR5Q47vjOruk= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=ddn.com; spf=pass smtp.mailfrom=ddn.com; dkim=pass (1024-bit key) header.d=ddn.com header.i=@ddn.com header.b=bei9kF7T; arc=fail smtp.client-ip=209.222.82.102 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=ddn.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ddn.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=ddn.com header.i=@ddn.com header.b="bei9kF7T" Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10lp2049.outbound.protection.outlook.com [104.47.58.49]) by mx-outbound23-227.us-east-2b.ess.aws.cudaops.com (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Mon, 20 Jan 2025 01:29:21 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=Hl1L/nJ8yd4hVntdmikrzXwqig9CcbAuLMahxocr7IIElG1DEhPuB30T9SHuUK1W9J7eY4VaYoopMGSbXvmZfleWpYvNAfdSBFoCLx9xEo7j4xbesLot8SeKLNkX6WspGNBSPpdgk3JXrn6d+52r7noX0wFes65GODzQmuKrYPlkuek11CxbUFQbV++Y/SWR0dd3SGOOJZfuWFKnPh7Wcx1bq2JgsCjK+ebnCkLD4izPSo9q/fTdl78VdbYFkiMokdP9zmIumzjBBexIX79Hp5CXlxv2vFCRkmiEdyL9zi/2rNklCglw20+zDlA+uI9MI3li/INWZVoWbS0D4rB28g== 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=PFYAXuUB0Ed7tRwQ8bNK4SgdfVSspLgCn1I1pYG92o4=; b=QGFnh0RNTQYk+kG4QNC65jVYqSqDxckBAYRBKG57KYr0AolMUZQq88KjN39Z3vPq+yorXWjDTmsNN/ocWb2kavPaL9lrT/OsI9XZrx0pUvmZPOak0uWPTS6rqMiPCERo0gx2LjXp147HBuqLWCSqZ0HEcoMjv27OwyPbwEr0VbvOZJ+tXDNRTsF4MyUCxPF9rgJ0Zkw4EQihLtZ1mds1xLcR3QtPbi8EPPiaBTMI4QUZzx9CRPksLdt8smK6G9t5/nCDfc4EZ4OnbS85Z2QUmT4oYyBTk69QGr1QmTMZsGqS0GAWGhFFtZ+671f2DXLpr5hltLvtIN1OSU5i3C852Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 50.222.100.11) smtp.rcpttodomain=bsbernd.com smtp.mailfrom=ddn.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=ddn.com; dkim=none (message not signed); arc=none (0) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ddn.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=PFYAXuUB0Ed7tRwQ8bNK4SgdfVSspLgCn1I1pYG92o4=; b=bei9kF7T2mqY/a7qPYYPIrq9a4ypdsNtFqrWf6ERKfAAphbwO7gNK/+JS46URyM0A9p3qNb3QW1lTUmUe+HAdqa8z+YMGLcq/zLkfnAqNnU9XBrDnc/oa5F/tBbkZzsKFK+VQl85CnkukcNexkycMjrXwwxizZ3Nd9rQ7cjaDiA= Received: from SJ0P220CA0030.NAMP220.PROD.OUTLOOK.COM (2603:10b6:a03:41b::6) by SA1PR19MB7016.namprd19.prod.outlook.com (2603:10b6:806:2bb::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8356.21; Mon, 20 Jan 2025 01:29:19 +0000 Received: from SJ1PEPF000023D1.namprd02.prod.outlook.com (2603:10b6:a03:41b:cafe::4a) by SJ0P220CA0030.outlook.office365.com (2603:10b6:a03:41b::6) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.20.8356.21 via Frontend Transport; Mon, 20 Jan 2025 01:29:19 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 50.222.100.11) smtp.mailfrom=ddn.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=ddn.com; Received-SPF: Pass (protection.outlook.com: domain of ddn.com designates 50.222.100.11 as permitted sender) receiver=protection.outlook.com; client-ip=50.222.100.11; helo=uww-mrp-01.datadirectnet.com; pr=C Received: from uww-mrp-01.datadirectnet.com (50.222.100.11) by SJ1PEPF000023D1.mail.protection.outlook.com (10.167.244.7) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.20.8377.8 via Frontend Transport; Mon, 20 Jan 2025 01:29:19 +0000 Received: from localhost (unknown [10.68.0.8]) by uww-mrp-01.datadirectnet.com (Postfix) with ESMTP id 744194D; Mon, 20 Jan 2025 01:29:18 +0000 (UTC) From: Bernd Schubert Date: Mon, 20 Jan 2025 02:29:10 +0100 Subject: [PATCH v10 17/17] fuse: enable fuse-over-io-uring Precedence: bulk X-Mailing-List: linux-fsdevel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Message-Id: <20250120-fuse-uring-for-6-10-rfc4-v10-17-ca7c5d1007c0@ddn.com> References: <20250120-fuse-uring-for-6-10-rfc4-v10-0-ca7c5d1007c0@ddn.com> In-Reply-To: <20250120-fuse-uring-for-6-10-rfc4-v10-0-ca7c5d1007c0@ddn.com> To: Miklos Szeredi Cc: Jens Axboe , Pavel Begunkov , linux-fsdevel@vger.kernel.org, io-uring@vger.kernel.org, Joanne Koong , Josef Bacik , Amir Goldstein , Ming Lei , David Wei , bernd@bsbernd.com, Luis Henriques , Bernd Schubert X-Mailer: b4 0.15-dev-2a633 X-Developer-Signature: v=1; a=ed25519-sha256; t=1737336541; l=1431; i=bschubert@ddn.com; s=20240529; h=from:subject:message-id; bh=3i8xm5Y1fqUWaEUFdAiYLVi+P0PPRqb1MIt8B8j7Nfo=; b=gHAv4MjTHqnhDovphFybSS2DIk+wpRCpWGUTqJvWdg+Z0k5N6U7st1qrAD4CUd6/IF1Iml3UB bH8TOJvq0HIBOiIFGBkL5NQ1YR3JPSqdcogjtCwcx6/f4/DPMySADvV X-Developer-Key: i=bschubert@ddn.com; a=ed25519; pk=EZVU4bq64+flgoWFCVQoj0URAs3Urjno+1fIq9ZJx8Y= X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ1PEPF000023D1:EE_|SA1PR19MB7016:EE_ X-MS-Office365-Filtering-Correlation-Id: 106a37e5-22dd-4179-cde7-08dd38f1dc5c X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|376014|7416014|1800799024|36860700013|82310400026; X-Microsoft-Antispam-Message-Info: =?utf-8?q?qR48b2dltNR1uHYCOxsCJsFKsAlelyL?= =?utf-8?q?ga2imfvncKPZR9eQfxSBTiFdr178dBRouTJL50rv7apHM+5NPiohun4w2pxsnPerF?= =?utf-8?q?mWnvzoqODhvcDeE9kIaOLc2qrYUNsX0x6w+zBPJdio9zb+1+h34CLZ6xJ1hRpkykk?= =?utf-8?q?DAhkG2BWdwMb1/e8DQd8F6McVoTbYtphUxQmr5OlDbbv3A0D+lMoGlVKZCQU4XEdy?= =?utf-8?q?orkkYEHsGOYpS/P2cr3Nc68X1UvWhqORI1Mr5Ch6GDs0PmnhXryxiCKgZYVTprD3J?= =?utf-8?q?mhuN5PAtlzK7DFgS30h7zB53nLiqsIuoi6+1U4ft7s3NQ5bwTxktlqTn+dDXysKMI?= =?utf-8?q?JtCobTZo6rVwvEXXDAHk7I0Dz2Ff0MKZrHuUVarrZUJy2GqEFSO/zG4yW2QKrQO4P?= =?utf-8?q?9ubf2AdkFH0JJf1agR/oueNAlZ95GaWl0yYSztHWhvAl6mBA6yjfqPycfqDX3F705?= =?utf-8?q?VHDG5uoQC64jl3nKZSrdv5RoKq3mDgdhhZb7bRr30332baqMGGqdZXGtcnP5pbgaJ?= =?utf-8?q?h3EAgWNozV5S0LBn0G6Pu1HPFve4jLHe1lpYuo42SILe0C3J36JY9o7rd+U+TcNMf?= =?utf-8?q?t2WTZcWTPziI3wsUiwd7M5NMUqk0wb4ZehVkx6B9gwLn8souUnElUvgZubONaBNws?= =?utf-8?q?zfIK3ClHRKRk9tpydLX69SCma8qt5xND40LrZncwQsGPxS3xCqDfLIWGq4Wl8brnS?= =?utf-8?q?hXEEO7UyE7FWNksjy3rSJZhIxLlLXpiMHIJ6TU3PWgXgqstv7xJd1yBJi27VPcfkU?= =?utf-8?q?AhiyanjUaOBsCJt/6IfC8xZS2/TibxPV50L4cUDWo5/xJ7wGs4v34Kp2xB3VO4VIt?= =?utf-8?q?n8dtvUDW0azoQYDya1U+8hREn+/HWZy8itUnwqglQ9gsTckQbRERmQwe4eCos+BGq?= =?utf-8?q?tQs1Sa2699y2URNiORfmi0I5Gr5eZgc9K+xnlm+fdHNjOPBjHRZbFqtzI6MD+jetE?= =?utf-8?q?m20FHenffAdMXzncf6UVTyb+10/BZaXdV0MPQQoUfIMcocSPSWi6PMy63AmsVdMFf?= =?utf-8?q?oR8cwaSoJmx4vMm6i7CiItqvlYIu7A+lMv3VsqasDVNSTbK1dwX8Wah6b5SAtdkvD?= =?utf-8?q?MvO7STrg4GQjNwtviMEOinLS99q7qNc68W9DdsI7oNxH+L7FCVN8VztDLz9UPcTfE?= =?utf-8?q?IlV6rRGzEaD0LcEg3H/TKyco8bMNQrKPwCTfOe9nICV/S2tj5v8HDKESmqYplxGgo?= =?utf-8?q?3uZWr4aXw629CqbPvLIK56Pqu08pLb5e87Tn/MSY7PeomFiz5biqleOBNsFtPuNG/?= =?utf-8?q?IcUuisVex1z6PiN7dMdEu2qeeBLaba5TV4CcBI16/Cgezdn2014IHbr17AKImi7sn?= =?utf-8?q?0JnRmbnSpGK9yniNIlUuC4eGmAUkieJr1NVjrVJdwWRu9Sh/i+J1GaQX/H856Bvnr?= =?utf-8?q?ZZmCWiiCAwxLTtg0GzbBrm+6qxDFfv/VQuwAio6bWbCkR/os5T1S74=3D?= X-Forefront-Antispam-Report: CIP:50.222.100.11;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:uww-mrp-01.datadirectnet.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(376014)(7416014)(1800799024)(36860700013)(82310400026);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-ExternalHop-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-ExternalHop-MessageData-0: 0kPftMEWdgXbKgOSZjrrWe0RY7PaevnWONivFXYcCIFEe8QLHH8wMExPq0AdDZqBtEdvLETqvwdAz+UMC2P6YrglhUVffqTwSkboqxoRQ2yEcj/axIqJUxW/FX9Sq/vIZ9HqzvIbUeoUCAt9c1q1Sqn1W0ZO72+KOEAhpXwOQnr/oyR3BBUdUEaReM41UWtUo4ptcQ2mUAGEcXdRF57JHZHmXm0ropdgp4NMZvnJIzhrk60/Kn4YJicIjaJcSm66PqNVbqhg/dVv3qqDl3e2clCWGAXbl2x10cE3rutscT2F3Av7Jm44ubQRebEAnSzPJAu5oKRHFAfvYLBJLkDk6E/ZtHUlkDb4MvGeV2k+pBFScVcHicc8DRVby5LVPBDlvmNuzhJEXYO5pHgBs8HJG0erQs132MTYmrT0Db9cBSzJKFNETyKxfj//vkN7smQlNofLyvp4yvto/EpbZnITVn9PL85jQ5cLQukN1WI2y4Nm3pxQLq+TzVqKcOcqLZmHHPYNdeKYtxJeXVEv1tvA4JuAMUBijdoo6IUD9hNPNY+aUJ73q8QtJduLcCFAfvNCDF0JPWD0FNAcXwBLPYp3qvOv3WmCcLeREZQ++GmAHeN7jRTJuSe3PPBsIxDkmosE4uqtMDcdnrqvItDqY7+zWw== X-OriginatorOrg: ddn.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 20 Jan 2025 01:29:19.0728 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 106a37e5-22dd-4179-cde7-08dd38f1dc5c X-MS-Exchange-CrossTenant-Id: 753b6e26-6fd3-43e6-8248-3f1735d59bb4 X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=753b6e26-6fd3-43e6-8248-3f1735d59bb4;Ip=[50.222.100.11];Helo=[uww-mrp-01.datadirectnet.com] X-MS-Exchange-CrossTenant-AuthSource: SJ1PEPF000023D1.namprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR19MB7016 X-BESS-ID: 1737336561-106115-13451-11026-1 X-BESS-VER: 2019.1_20250117.1903 X-BESS-Apparent-Source-IP: 104.47.58.49 X-BESS-Parts: H4sIAAAAAAACA4uuVkqtKFGyUioBkjpK+cVKVobGloZAVgZQ0MjM1NzQxMIgxS TR0NTC2NwozSLRMMXcNMksMTXZ3NxYqTYWAO6m12JBAAAA X-BESS-Outbound-Spam-Score: 0.20 X-BESS-Outbound-Spam-Report: Code version 3.2, rules version 3.2.2.261928 [from cloudscan13-194.us-east-2a.ess.aws.cudaops.com] Rule breakdown below pts rule name description ---- ---------------------- -------------------------------- 0.00 BSF_BESS_OUTBOUND META: BESS Outbound 0.20 BSF_SC7_SA298e META: Custom Rule SA298e X-BESS-Outbound-Spam-Status: SCORE=0.20 using account:ESS124931 scores of KILL_LEVEL=7.0 tests=BSF_BESS_OUTBOUND, BSF_SC7_SA298e X-BESS-BRTS-Status: 1 All required parts are handled now, fuse-io-uring can be enabled. Signed-off-by: Bernd Schubert Reviewed-by: Pavel Begunkov # io_uring --- fs/fuse/dev.c | 3 +++ fs/fuse/dev_uring.c | 3 +-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/fs/fuse/dev.c b/fs/fuse/dev.c index f002e8a096f97ba8b6e039309292942995c901c5..5b5f789b37eb68811832d905ca05b59a0d5a2b2a 100644 --- a/fs/fuse/dev.c +++ b/fs/fuse/dev.c @@ -2493,6 +2493,9 @@ const struct file_operations fuse_dev_operations = { .fasync = fuse_dev_fasync, .unlocked_ioctl = fuse_dev_ioctl, .compat_ioctl = compat_ptr_ioctl, +#ifdef CONFIG_FUSE_IO_URING + .uring_cmd = fuse_uring_cmd, +#endif }; EXPORT_SYMBOL_GPL(fuse_dev_operations); diff --git a/fs/fuse/dev_uring.c b/fs/fuse/dev_uring.c index 1249c7fd4d63692413d103e72eaa5e502188d3bc..5f10f3880d5a4869d8a040567025c60e75d962c6 100644 --- a/fs/fuse/dev_uring.c +++ b/fs/fuse/dev_uring.c @@ -1084,8 +1084,7 @@ static int fuse_uring_register(struct io_uring_cmd *cmd, * Entry function from io_uring to handle the given passthrough command * (op code IORING_OP_URING_CMD) */ -int __maybe_unused fuse_uring_cmd(struct io_uring_cmd *cmd, - unsigned int issue_flags) +int fuse_uring_cmd(struct io_uring_cmd *cmd, unsigned int issue_flags) { struct fuse_dev *fud; struct fuse_conn *fc;