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 gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 9A029CD6E5F for ; Sun, 31 May 2026 14:00:10 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 56468112B85; Sun, 31 May 2026 13:59:51 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; secure) header.d=posteo.de header.i=@posteo.de header.b="CmAwHLWU"; dkim-atps=neutral Received: from mout02.posteo.de (mout02.posteo.de [185.67.36.66]) by gabe.freedesktop.org (Postfix) with ESMTPS id 61A5E112942 for ; Sat, 30 May 2026 17:36:45 +0000 (UTC) Received: from submission (posteo.de [185.67.36.169]) by mout02.posteo.de (Postfix) with ESMTPS id 6E805240103 for ; Sat, 30 May 2026 19:36:43 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=posteo.de; s=2017; t=1780162603; bh=2e2O/8b5NRtHio85i8yYWzntgvUhu+5ong2pxaqR0kw=; h=From:Subject:Date:Message-Id:MIME-Version:Content-Type: Content-Transfer-Encoding:To:Cc:Autocrypt:OpenPGP:From; b=CmAwHLWUA99yF1UYjDxjd2nJSt5X3jYJM/q5CdMzXwstNMQbIyAFt21ioigwU9Hqv sF+Y2LI4/DERx5IboegAbakJ89UBCWHPrDNuh/X8ekTnPtLOezsp/Qyd5V6f73zbJl m+/UCWJrr7FGvp1GhwGc7SaYzRQ8OYkfymmgaWbn9pFLFBsTgbh3kGX9ImlN8LBh5R 2KOrZ1KoVwBRQLbleJdyYSWAcnp32wkGwVoFq4msNEvK/bqTdvtsVLCiBQjfmuN270 ebww60Te4aDYhcCzOl022nf7GX4IMgn3z/TUxd+7xw+vdyzOdkMbgjAwtz7d9KxpOq /KVXKNnjyKa9Q== Received: from customer (localhost [127.0.0.1]) by submission (posteo.de) with ESMTPSA id 4gSS882hfKz6twx; Sat, 30 May 2026 19:36:40 +0200 (CEST) From: Markus Probst Subject: [PATCH v9 0/3] rust: add basic serial device bus abstractions Date: Sat, 30 May 2026 17:36:42 +0000 Message-Id: <20260530-rust_serdev-v9-0-f8b5fccb49c3@posteo.de> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-B4-Tracking: v=1; b=H4sIAAEgG2oC/43SwU7kMAwG4FcZ9bytYidO4jnxHqsVSlsXKnamk JQKhHh3PDMgpmUPe4oc6fsVx36riuRRSrXfvVVZlrGM01EL/rWruvt0vJN67LWu0CABQqjzc5l vFfWy1CLkIgibSF2l4jHLML6c037/0fp+LPOUX8/hC5xuP3PQrHIWqE0tznlHwQePcPM4lVmmp pfqlLPgl/XGGr+2eLLcom0dtki0tfbKgl1bq7bjZNOA4IYwbK37tg5gbZ3a6EjYm857DFtLV3b bL6mlILFNhoAHu7X+2q7/fPFqIdjAsSeB9MOGa8trG9SaPnIXGFrq4tbGb0t28+aoFhPTAH1CT Kt+3y/Dz/L0rBs0XzagOkgp6bxB+90lU7sldMY0lrVgX0Pdp4d88yD5KH+bKd+d1uinQ9KTERp A5zn+L7MGLAbrG4scyfG/XZuK1N10OIzzfreERufckfb0/gGITJKrHQMAAA== X-Change-ID: 20251217-rust_serdev-ee5481e9085c To: Rob Herring , Greg Kroah-Hartman , Jiri Slaby , Miguel Ojeda , Gary Guo , =?utf-8?q?Bj=C3=B6rn_Roy_Baron?= , Benno Lossin , Andreas Hindborg , Alice Ryhl , Trevor Gross , Danilo Krummrich , Kari Argillander , "Rafael J. Wysocki" , Viresh Kumar , Boqun Feng , David Airlie , Simona Vetter , Boqun Feng Cc: linux-serial@vger.kernel.org, linux-kernel@vger.kernel.org, rust-for-linux@vger.kernel.org, linux-pm@vger.kernel.org, driver-core@lists.linux.dev, dri-devel@lists.freedesktop.org, Markus Probst X-Developer-Signature: v=1; a=openpgp-sha256; l=5698; i=markus.probst@posteo.de; h=from:subject:message-id; bh=kRO4NH3VMxsI9hmNuUJEFuA+TdZxr2QG4aut3DO0ULk=; b=owEBiQJ2/ZANAwAIATR2H/jnrUPSAcsmYgBqGyAnvlACq3CZi+ZGChqDAcrBCXcRktDhYI/aj B75iuEPoyuJAk8EAAEIADkWIQSCdBjE9KxY53IwxHM0dh/4561D0gUCahsgJxsUgAAAAAAEAA5t YW51MiwyLjUrMS4xMiwyLDIACgkQNHYf+OetQ9IjQRAAvA3qj9+STtwINeUuarKni9DmixDYAnq Dc7Xh/hpbZx3c7RbJSNSdBUGZBSdRH5hDhqMlHsByAiKYCgf/rumim6TPaSNGtHlN6tW/QQ8lDP eXroE+v8iQkDwAzZy9xRCY8MZLJ9zREaQgve1b5s0dylOsJRrDdTJGJni3LmH2ycT4/vd+BV9JJ KczQdrgP8wisg4JdUrwXNxmsdmXPYLNIg4kgi6kA932vszm5ur2SBGAJKEjF3WNNVPUXZMBw6Af S9xvF4ZmpD4Mio+ebkucLpltmqNIMYjA3IwQytrCI/L+NAWCJSpc+xa6hE1+kpDRyIxwnXrTjQY oo4Bf/HaOYV34DKjUvgocsZbdGEpXGq0Q6/ITtfVeByNJIDmJeJundN/7vAM671kVx+UbCaCtYa b71niUAtpNFKwpHJg0Bwm6mGXaljctoKUxIgncUUlXdiIrwVxG4UpKqK55t4grN1RTG/MGDuK+i PjoC6+oH/DCDEo9kNL31sUgbwyjzE9CHuoPKiBjtjo30llmHHNu2EcsXjZheRR1tXq1mHwgn8Fw ORW7G4SUPdqMEl2iGBZ1tXTwJy3zVACsoY7B5Y2+WjUogU5EUNWn6M82SeqQfVO93Xr1Wica1sE KDoND5XNYdYqPrHMp5PLXBgNH9i7UPm4DXl632nywyNFSm17+A6w= X-Developer-Key: i=markus.probst@posteo.de; a=openpgp; fpr=827418C4F4AC58E77230C47334761FF8E7AD43D2 Autocrypt: addr=markus.probst@posteo.de; prefer-encrypt=mutual; keydata=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 aBeNN4ijKZchBXHPgVx+YtWRHfcm4l8= OpenPGP: url=https://posteo.de/keys/markus.probst@posteo.de.asc; preference=encrypt X-Mailman-Approved-At: Sun, 31 May 2026 13:58:31 +0000 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" This patch series adds the serdev device bus rust abstraction into the kernel. This abstraction will be used by a driver, which targets the MCU devices in Synology devices. Kari Argillander also messaged me, stating that he wants to write a watchdog driver with this abstraction (needing initial device data). This series depends on [1] and [2]. [1] https://lore.kernel.org/rust-for-linux/20260525202921.124698-1-dakr@kernel.org/ [2] https://lore.kernel.org/rust-for-linux/20260530132736.3298549-1-dakr@kernel.org/ Signed-off-by: Markus Probst --- Changes in v9: - make use of BoundInternal - use PrivateData wrapper and drop rust_private_data field - use non-devm version of serdev_device_open - Link to v8: https://patch.msgid.link/20260530-rust_serdev-v8-0-2a95f1da22a7@posteo.de Changes in v8: - adapted to driver-lifetime v5 patch series - add MAINTAINERS file patch - Link to v7: https://patch.msgid.link/20260429-rust_serdev-v7-0-0d89c791b5c8@posteo.de Changes in v7: - adapted to driver-lifetime patch series - Link to v6: https://patch.msgid.link/20260427-rust_serdev-v6-0-173798d5e1a3@posteo.de Changes in v6: - rebased onto v7.1-rc1 - Link to v5: https://patch.msgid.link/20260420-rust_serdev-v5-0-57e8ba0519f3@posteo.de Changes in v5: - fix typo in documentation - Link to v4: https://lore.kernel.org/r/20260411-rust_serdev-v4-0-845e960c6627@posteo.de Changes in v4: - fixed not selecting rust serdev abstraction in sample - Link to v3: https://lore.kernel.org/r/20260313-rust_serdev-v3-0-c9a3af214f7f@posteo.de Changes in v3: - fix vertical import style - add Kconfig entry for the rust abstraction - fix documentation in include/linux/serdev.h - rename private_data to rust_private_data - fix `complete_all` <-> `wait_for_completion` typo - move drvdata_borrow call after the completion - Link to v2: https://lore.kernel.org/r/20260306-rust_serdev-v2-0-e9b23b42b255@posteo.de Changes in v2: - fix documentation in `serdev::Driver::write` and `serdev::Driver::write_all` - remove use of `dev_info` in probe from the sample - remove `properties_parse` from the sample - add optional `baudrate` property to the sample - remove 1. patch - remove `TryFrom<&device::Device> for &serdev::Device` implementation - fix import style - add patch to return reference in `devres::register` to fix safety issue - add patch to add private data to serdev_device, to fix `Device.drvdata()` from failing - simplify abstraction by removing ability to receive the initial transmission. It may be added later in a separate patch series if needed. - Link to v1: https://lore.kernel.org/r/20251220-rust_serdev-v1-0-e44645767621@posteo.de --- Markus Probst (3): rust: add basic serial device bus abstractions samples: rust: add Rust serial device bus sample device driver MAINTAINERS: serdev: Add self for serdev MAINTAINERS | 5 +- drivers/tty/serdev/Kconfig | 7 + rust/bindings/bindings_helper.h | 1 + rust/helpers/helpers.c | 1 + rust/helpers/serdev.c | 22 ++ rust/kernel/lib.rs | 2 + rust/kernel/serdev.rs | 574 +++++++++++++++++++++++++++++++++++++ samples/rust/Kconfig | 11 + samples/rust/Makefile | 1 + samples/rust/rust_driver_serdev.rs | 91 ++++++ 10 files changed, 714 insertions(+), 1 deletion(-) --- base-commit: 9e171fc1d7d7ab847a750c03571c87ac3c17bd84 change-id: 20251217-rust_serdev-ee5481e9085c prerequisite-message-id: 20260505152400.3905096-1-dakr@kernel.org prerequisite-patch-id: d2aebf69b153c039bbed1d0ed26906708fd22534 prerequisite-patch-id: 84b28da2f5de20fc1785095c647b2ffc35d969a5 prerequisite-patch-id: 67318671a5eed5fb4ad23a450f1cf0e442bf8ca2 prerequisite-message-id: 20260525202921.124698-1-dakr@kernel.org prerequisite-patch-id: b84db329d4372a175cb8d49e4e88c3eecf7eb228 prerequisite-patch-id: 2c30303f409cc8288cc87e241920219f5ddd8390 prerequisite-patch-id: 4e4f0ad370d763ad00b0f75b91fa216f2cc95953 prerequisite-patch-id: 5bcd6b37f3498feebda275dfef78136eba34004e prerequisite-patch-id: 872b0982f3e5e7d1698d9df3b325e4cd27b27789 prerequisite-patch-id: 3a3c7749e017d9335f58497404d1350e96caf471 prerequisite-patch-id: 3526c9154f581497a11465b936d83ef61a875454 prerequisite-patch-id: 65d8c757b52475c2acc7d22ddc92cd3f0152b55d prerequisite-patch-id: 4bd31f1414d5248dc080884caadf5f21684a8427 prerequisite-patch-id: 7beadbb0da3e589ed86d12f512d1c83427dd82b4 prerequisite-patch-id: 12cd0f67ffd27347f90c065db491945908206b7f prerequisite-patch-id: 4642e31f66331f6c3b579377111ea733dbb3a11c prerequisite-patch-id: 52d67b40b4396c741e2222d6a5bc7927abcb77aa prerequisite-patch-id: 74ca82ff26cf9c7a993757c87db8be62006e820f prerequisite-patch-id: 466fb9fa7febbffd8ef51b311c7d9893c11fc0f0 prerequisite-patch-id: e515cd98b06e26721cbbe6a4fbacd251d0073b63 prerequisite-patch-id: 8dc8e75d9f6499a554ef7e474bbacdbf3660a9f2 prerequisite-patch-id: 5fdb9f71dca2f44dd293760a60db125b770f1f55 prerequisite-patch-id: c766a24c2d5064f5ec09daada0b8e8fba862d3aa prerequisite-patch-id: b768f6456d35fa7a80c015e34bbdba6082dbd593 prerequisite-patch-id: 6a8b17234f12f7084e6e2ce843a7031b0a891ce4 prerequisite-patch-id: 98b2deb9e60c1f28f90c5ee34fd608aaa9fd9420 prerequisite-patch-id: 774b29be66e641ee50cedb4704cf49d8b9fabf50 prerequisite-patch-id: cf95dc936cfc4b3a7a363435a51a48d9009645b3 prerequisite-message-id: 20260530132736.3298549-1-dakr@kernel.org prerequisite-patch-id: 310c6bee038ca3909a8e5e58ec12b74f7189b869 prerequisite-patch-id: 92812c3d42b29504838e6dc66c307ff5c035bb5e