Received: by 2002:a05:7412:bbc7:b0:fc:a2b0:25d7 with SMTP id kh7csp519089rdb; Thu, 1 Feb 2024 16:06:22 -0800 (PST) X-Google-Smtp-Source: AGHT+IFU6EG10l4TrckpbDT0Igl7iL0ONQhxFztQnUrOB+xHB2I3DjqvG/uTjXgich2IWdgSf/xn X-Received: by 2002:ac8:5842:0:b0:42b:ff40:b678 with SMTP id h2-20020ac85842000000b0042bff40b678mr1824247qth.53.1706832382630; Thu, 01 Feb 2024 16:06:22 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1706832382; cv=pass; d=google.com; s=arc-20160816; b=U5nGyYUitW3uYLt25F12t0CoxyDoz8lSuc23nwyBtCNhyjnF1R+9g1XDstVrqpkcr9 x5s7MD7EyYppUGB2d6ufVbM3eOdAM7LxhcrkJLJNWyoWqBvNLzI6xdUhW1yiH1PYQGzK lPd0FCyuDk6bKCuKHWoiLT2rGf3oI9LWZ2BxpHvBw82okQj5LIeaVrWhcUPM2BgvrebL KuJQTpbLLNY2onf91ILXQw9uq9GF0Ba+MfMvz+ZZeBcv4hDUKB3DUfZGwgdTa5y5qz4F ccLP3FPUjcLTHJghFA//ZSm2Li83/L+0dmhQbk9QeWvzi/ehP1LxxtDGZderdoJMU3/4 k5BA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=cc:to:content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:from; bh=jyWkrNdUOkE+1zDdBBqwMZkzNA67Wgmp6qPM6FegogU=; fh=SOhmqV7daNJpKwNSKAhzcb5KvbSuTA5Kd03VTP6I0YY=; b=ZI1gjC5mb/xOhZ0w3RyvHjV3TjfT0eUOWuT1CwXSJuorJcw/pbKQ55nKadh451VO+g wO2zhECO3d0UltY14OWlFmyD6HPEDvlVKxPoJI8PObehQNf2pJjuugx+QB0Cpu7an6ws oxDYikRGybqhdZKDA4icPtK+xZeJZrvEV24A53K8fd3FtBO8UOTWKAQs+Ava1/pHe075 0lbrEcK2OxWAMKfeDdZOyOBpVTrEoUAg2tqBHEkIcXpqJ4cXljcP8aYv2RAnzVxzVmGu VEprJlliw0XTy+7PsB6hSWPgHzppXmXIzJtHUC6WAx0O/xgacMyBfQ4bnB+nadbT5E94 Xc3w==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=pengutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-49017-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-49017-linux.lists.archive=gmail.com@vger.kernel.org" X-Forwarded-Encrypted: i=1; AJvYcCXNQwlpOWqCaRWJcvSvavwCv5o5t2mdVSTRQs0xIcNlN5FwYJqhL5n7oE9995+Q7RTeL7cKiK/peIFtKmJXS08utY3RWVKbmOt5IB+2dQ== Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id l9-20020a05622a050900b0042bfe3917casi678589qtx.711.2024.02.01.16.06.22 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 01 Feb 2024 16:06:22 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-49017-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=pengutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-49017-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-49017-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 3E0A01C23C1B for ; Fri, 2 Feb 2024 00:06:22 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id BA5FF4684; Fri, 2 Feb 2024 00:05:38 +0000 (UTC) Received: from metis.whiteo.stw.pengutronix.de (metis.whiteo.stw.pengutronix.de [185.203.201.7]) (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 465AA1FBE for ; Fri, 2 Feb 2024 00:05:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=185.203.201.7 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706832338; cv=none; b=nOnecD1y8llpvex3L6Xacax6h3vU3oMOkSBNtv0yLVQ16QFRhkqhNiS+0+l4xHpVZylhF1ZfMbEoto02kXTSXApR58vudau4X5zfc85pOmm84hXWwWAciGIG5D+NdRlCERQ7V5kSllYQWNo9/PuNEamNUCtbhgFpL2iQtHfB0Kg= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706832338; c=relaxed/simple; bh=IdiYYWpzmr9RPusGSBqszbMgZq+ap0BptPduyKLTtUQ=; h=From:Subject:Date:Message-Id:MIME-Version:Content-Type:To:Cc; b=YWvYR98h0JekOvBniZwSXaMgOmsrFaz0gLi40m4eAGwvc6Ap8q19q2OvLKZVdRm8q5mUrss8uX6fgzf9Tu3TGx8F5FNd36zW2ly4dikeZ3iYdbaKkSCm/HWPFElUlglguIJHc+9XIFJqdryTy37NDqeUWTCJEKOHl3eeDgDZITg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=pengutronix.de; spf=pass smtp.mailfrom=pengutronix.de; arc=none smtp.client-ip=185.203.201.7 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=pengutronix.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=pengutronix.de Received: from drehscheibe.grey.stw.pengutronix.de ([2a0a:edc0:0:c01:1d::a2]) by metis.whiteo.stw.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1rVh3Z-0000cz-Rd; Fri, 02 Feb 2024 01:05:21 +0100 Received: from [2a0a:edc0:0:1101:1d::ac] (helo=dude04.red.stw.pengutronix.de) by drehscheibe.grey.stw.pengutronix.de with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1rVh3W-003xQ5-2P; Fri, 02 Feb 2024 01:05:18 +0100 Received: from localhost ([::1] helo=dude04.red.stw.pengutronix.de) by dude04.red.stw.pengutronix.de with esmtp (Exim 4.96) (envelope-from ) id 1rVh3V-00AFlM-1h; Fri, 02 Feb 2024 01:05:18 +0100 From: Michael Grzeschik Subject: [PATCH v2 0/4] usb: gadget: 9pfs transport Date: Fri, 02 Feb 2024 01:05:09 +0100 Message-Id: <20240116-ml-topic-u9p-v2-0-b46cbf592962@pengutronix.de> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-B4-Tracking: v=1; b=H4sIALUxvGUC/3WNyw6DIBBFf6Vh3amAj2pX/Y/GBeKokygQUGNj/ Pei+y7Pzbk5OwvoCQN73XbmcaVA1kSQ9xvTgzI9ArWRmeQy40IUMI0wW0calspBWeXymeUpx0a weGlUQGi8Mno4T9M4jcllJ9E+Beexo+3qferIA4XZ+u+VX8W5/imtAjiottQpL7pKZfh2aPpl9 tbQ9miR1cdx/AAoAvyKzgAAAA== To: Eric Van Hensbergen , Latchesar Ionkov , Dominique Martinet , Christian Schoenebeck , Jonathan Corbet , Greg Kroah-Hartman Cc: v9fs@lists.linux.dev, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-usb@vger.kernel.org, kernel@pengutronix.de, Michael Grzeschik X-Mailer: b4 0.12.0 X-Developer-Signature: v=1; a=openpgp-sha256; l=4125; i=m.grzeschik@pengutronix.de; h=from:subject:message-id; bh=IdiYYWpzmr9RPusGSBqszbMgZq+ap0BptPduyKLTtUQ=; b=owEBbQKS/ZANAwAKAb9pWET5cfSrAcsmYgBlvDG3xC0tz0b2twuAdUyIaYaJ4coWj3Icx3NeB ifEniisW+2JAjMEAAEKAB0WIQQV2+2Fpbqd6fvv0Gi/aVhE+XH0qwUCZbwxtwAKCRC/aVhE+XH0 q/VwEAClVZxlYo9pt5R9IA48qsaUIdVtnj9CEnWtFWRUZPbZvJWnrdkHIB315nssDgIJtxBaACf IodfZ0EyaqO4CTxGmw92QO+h9awNG3YztU3BCQMeUEn0KGaejkDgApCZt/pjlIQMkspKyxw01D6 FHCPEvvw5y840MEN0Vxe4OLfwTUCNroyRHf8kXoeTjY7Vu+KQ/ZOU4a8tWVG5HBEg74iGQ/l/3B V7irmYXy1ji6T9y+o9eyN8Q8uYEU6b1SBVEkNVopW3qJ119xVKqj29t+EENLL9Fktt0607xYLip 3iCwXi7CRM7xawRMaKaXq1nxW2fH57cL6XxXnlDTKDf3vy2GShwKFenCSKttmaWLEwMZTlJdrzR 8HrHBvAIBWAVhH4ijtkTYPeTui4AIHT8G3X/f2WFSf2ORj/XaP7/3hYvLto23Z5SSkydA9DRYNB oDfKemkAfpocnon4LUML3rSgtUtcR1vqtVKXObidbloxFZdnSijb41ygpgVg/zo35pdlzucFnqG gJcQGHfayZ1l/6u66p+gkauKYB+EmPZLdKRHoN5SRA/TT+2VtFdM5AIgveXCjGmXWIvmdcuIo8m 2z+x4YbEGlJKRQ0fD9lFukcFSEjrpQq28bQOLNibrmKXn78DLUcGKsdt73vMAQsVDWoob3CgjQa f995mmHE7u1FQKg== X-Developer-Key: i=m.grzeschik@pengutronix.de; a=openpgp; fpr=957BC452CE953D7EA60CF4FC0BE9E3157A1E2C64 X-SA-Exim-Connect-IP: 2a0a:edc0:0:c01:1d::a2 X-SA-Exim-Mail-From: m.grzeschik@pengutronix.de X-SA-Exim-Scanned: No (on metis.whiteo.stw.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org This series is adding support to mount usb hostside exported 9pfs filesystems via the usb gadget interface. It also includes a simple tool (p9_fwd.py) to translate an tcp 9pfs transport and reuse it via the usb interface. +--------------------------+ | +--------------------------+ | 9PFS mounting client | | | 9PFS exporting server | SW | | | | | | (this:trans_usbg) | | |(e.g. diod or nfs-ganesha)| +-------------^------------+ | +-------------^------------+ | | | | | +------v------+ | | | p9_fwd.py | | | +------^------+ | | | ------------------|------------------------------------|------------- | | | +-------------v------------+ | +-------------v------------+ | | | | | HW | USB Device Controller <---------> USB Host Controller | | | | | | +--------------------------+ | +--------------------------+ The USB host exports a filesystem, while the gadget on the USB device side makes it mountable. Diod (9pfs server) and the forwarder are on the development host, where the root filesystem is actually stored. The gadget is initialized during boot (or later) on the embedded board. Then the forwarder will find it on the USB bus and start forwarding requests. In this case the 9p requests come from the device and are handled by the host. The reason is that USB device ports are normally not available on PCs, so a connection in the other direction would not work. One use-case is to use it as an alternative to NFS root booting during the development of embedded Linux devices. Signed-off-by: Michael Grzeschik --- Changes in v2: - improved the commit messages - introduced an patch to move the header u_f.h to include/linux/usb to compile usb gadget functions treewide - moved usbg gadget function to net/9p/ - adderessed several comments in function driver, like the cleanup path and kbuild errors - improved the documentation in Documentation/filesystems/9p.rst - Link to v1: https://lore.kernel.org/r/20240116-ml-topic-u9p-v1-0-ad8c306f9a4e@pengutronix.de --- Michael Grzeschik (4): usb: gadget: function: move u_f.h to include/linux/usb/ net/9p/usbg: Add new usb gadget function transport usb: gadget: legacy: add 9pfs multi gadget tools: usb: p9_fwd: add usb gadget packet forwarder script Documentation/filesystems/9p.rst | 47 ++ drivers/usb/gadget/configfs.c | 2 +- drivers/usb/gadget/function/f_fs.c | 2 +- drivers/usb/gadget/function/f_hid.c | 2 +- drivers/usb/gadget/function/f_loopback.c | 2 +- drivers/usb/gadget/function/f_midi.c | 2 +- drivers/usb/gadget/function/f_midi2.c | 2 +- drivers/usb/gadget/function/f_sourcesink.c | 2 +- drivers/usb/gadget/legacy/9pfs.c | 268 ++++++++ drivers/usb/gadget/legacy/Kconfig | 16 + drivers/usb/gadget/legacy/Makefile | 2 + drivers/usb/gadget/u_f.c | 2 +- {drivers/usb/gadget => include/linux/usb}/u_f.h | 0 net/9p/Kconfig | 6 + net/9p/Makefile | 4 + net/9p/trans_usbg.c | 871 ++++++++++++++++++++++++ tools/usb/p9_fwd.py | 194 ++++++ 17 files changed, 1416 insertions(+), 8 deletions(-) --- base-commit: 41bccc98fb7931d63d03f326a746ac4d429c1dd3 change-id: 20240116-ml-topic-u9p-895274530eb1 Best regards, -- Michael Grzeschik