{"id":2222421,"url":"http://patchwork.ozlabs.org/api/1.1/covers/2222421/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-pci/cover/20260411-rust_leds-v13-0-1208a2821deb@posteo.de/","project":{"id":28,"url":"http://patchwork.ozlabs.org/api/1.1/projects/28/?format=json","name":"Linux PCI development","link_name":"linux-pci","list_id":"linux-pci.vger.kernel.org","list_email":"linux-pci@vger.kernel.org","web_url":null,"scm_url":null,"webscm_url":null},"msgid":"<20260411-rust_leds-v13-0-1208a2821deb@posteo.de>","date":"2026-04-11T15:07:19","name":"[RESEND,v13,0/3] rust: leds: add led classdev abstractions","submitter":{"id":91819,"url":"http://patchwork.ozlabs.org/api/1.1/people/91819/?format=json","name":"Markus Probst","email":"markus.probst@posteo.de"},"mbox":"http://patchwork.ozlabs.org/project/linux-pci/cover/20260411-rust_leds-v13-0-1208a2821deb@posteo.de/mbox/","series":[{"id":499561,"url":"http://patchwork.ozlabs.org/api/1.1/series/499561/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-pci/list/?series=499561","date":"2026-04-11T15:07:19","name":"rust: leds: add led classdev abstractions","version":13,"mbox":"http://patchwork.ozlabs.org/series/499561/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/covers/2222421/comments/","headers":{"Return-Path":"\n <linux-pci+bounces-52396-incoming=patchwork.ozlabs.org@vger.kernel.org>","X-Original-To":["incoming@patchwork.ozlabs.org","linux-pci@vger.kernel.org"],"Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n secure) header.d=posteo.de header.i=@posteo.de header.a=rsa-sha256\n header.s=2017 header.b=NlxIbs/s;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=104.64.211.4; helo=sin.lore.kernel.org;\n envelope-from=linux-pci+bounces-52396-incoming=patchwork.ozlabs.org@vger.kernel.org;\n receiver=patchwork.ozlabs.org)","smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=posteo.de header.i=@posteo.de\n header.b=\"NlxIbs/s\"","smtp.subspace.kernel.org;\n arc=none smtp.client-ip=185.67.36.65","smtp.subspace.kernel.org;\n dmarc=pass (p=none dis=none) header.from=posteo.de","smtp.subspace.kernel.org;\n spf=pass smtp.mailfrom=posteo.de"],"Received":["from sin.lore.kernel.org (sin.lore.kernel.org [104.64.211.4])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519 server-signature ECDSA (secp384r1) server-digest SHA384)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4ftH8x0HMNz1y2d\n\tfor <incoming@patchwork.ozlabs.org>; Sun, 12 Apr 2026 01:07:44 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sin.lore.kernel.org (Postfix) with ESMTP id 556873013C4A\n\tfor <incoming@patchwork.ozlabs.org>; Sat, 11 Apr 2026 15:07:41 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id F12FD39183B;\n\tSat, 11 Apr 2026 15:07:33 +0000 (UTC)","from mout01.posteo.de (mout01.posteo.de [185.67.36.65])\n\t(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby smtp.subspace.kernel.org (Postfix) with ESMTPS id 67D95391512\n\tfor <linux-pci@vger.kernel.org>; Sat, 11 Apr 2026 15:07:28 +0000 (UTC)","from submission (posteo.de [185.67.36.169])\n\tby mout01.posteo.de (Postfix) with ESMTPS id 92962240029\n\tfor <linux-pci@vger.kernel.org>; Sat, 11 Apr 2026 17:07:20 +0200 (CEST)","from customer (localhost [127.0.0.1])\n\tby submission (posteo.de) with ESMTPSA id 4ftH8P5HGLz9rxN;\n\tSat, 11 Apr 2026 17:07:17 +0200 (CEST)"],"ARC-Seal":"i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1775920053; cv=none;\n b=kXkjwubXOJ0LlVcBk/nEl6OXdBjBpV2XyEwOefruZEWv09IL8otfzGmQwyNL5eH6CqwrALCdduyAylnjkNnyXmt+ScntLe2BhRYcZeWk849EMRoVPSo1VvXfS4aEi2nFg3KWoRE89twEoEA2uTwX6uTipPvCMwie5f75Z9O/qb8=","ARC-Message-Signature":"i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1775920053; c=relaxed/simple;\n\tbh=aSElWiw4h2ooJZhNAvX7pVieluBonHEoG3ZjWqXCLyQ=;\n\th=From:Subject:Date:Message-Id:MIME-Version:Content-Type:To:Cc;\n b=vB/YX3f4VcRp+mdnrLvv74OofIOKTFVxXnDXZroxFZNKz+AMuHP4m5iConBs6RXMzyzij3F/+o86teGU9X3X6fcbw1uC5P2bMP2dL51IumdywErzee3eSytPUeOF/AMTeBTWZHUaoKcxpkTa1QqHFaSMYSz99Wsq23Z7RHe7f00=","ARC-Authentication-Results":"i=1; smtp.subspace.kernel.org;\n dmarc=pass (p=none dis=none) header.from=posteo.de;\n spf=pass smtp.mailfrom=posteo.de;\n dkim=pass (2048-bit key) header.d=posteo.de header.i=@posteo.de\n header.b=NlxIbs/s; arc=none smtp.client-ip=185.67.36.65","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=posteo.de; s=2017;\n\tt=1775920040; bh=AKeaelIp43hYcyaGqJchu1HqXII0FyMzIfWKdgfDUvs=;\n\th=From:Subject:Date:Message-Id:MIME-Version:Content-Type:\n\t Content-Transfer-Encoding:To:Cc:Autocrypt:OpenPGP:From;\n\tb=NlxIbs/sdpRawva92Z6p1kRnJWaCQ4nNWbpr6jpgedP3NZdnK/s5mjsm5MYaCeBtS\n\t Ap1IY9OTB0FwNKLxUt5x8uqQVD611wY3u9PvENHEzkTEWanBqkN1/hAKgO5RfrGHc3\n\t h+T3YfuyMfyA3tgyf+hW4kj7zXw+6Nid1GbmisrfTtKuwBNt2IJCq4VAfQT8xaXjRF\n\t eOikzizCwm3gD//l94Mb3vK5wvqYZBSbEP/afOr398xv3A5nRdWSvz/6wTimnz3fNF\n\t FI/FMqUs48VxPToAYA/+AgEaNUunbRCH4zdlV7AXHaPyKBnnq1o17cbgdgIkDl6rrx\n\t 2GkBUOmtaGaZQ==","From":"Markus Probst <markus.probst@posteo.de>","Subject":"[PATCH RESEND v13 0/3] rust: leds: add led classdev abstractions","Date":"Sat, 11 Apr 2026 15:07:19 +0000","Message-Id":"<20260411-rust_leds-v13-0-1208a2821deb@posteo.de>","Precedence":"bulk","X-Mailing-List":"linux-pci@vger.kernel.org","List-Id":"<linux-pci.vger.kernel.org>","List-Subscribe":"<mailto:linux-pci+subscribe@vger.kernel.org>","List-Unsubscribe":"<mailto:linux-pci+unsubscribe@vger.kernel.org>","MIME-Version":"1.0","Content-Type":"text/plain; charset=\"utf-8\"","Content-Transfer-Encoding":"8bit","To":"Lee Jones <lee@kernel.org>, Pavel Machek <pavel@kernel.org>,\n  Greg Kroah-Hartman <gregkh@linuxfoundation.org>,\n  Dave Ertman <david.m.ertman@intel.com>, Ira Weiny <ira.weiny@intel.com>,\n  Leon Romanovsky <leon@kernel.org>, Miguel Ojeda <ojeda@kernel.org>,\n  Alex Gaynor <alex.gaynor@gmail.com>, Gary Guo <gary@garyguo.net>,\n\t=?utf-8?q?Bj=C3=B6rn_Roy_Baron?= <bjorn3_gh@protonmail.com>,\n  Benno Lossin <lossin@kernel.org>, Andreas Hindborg <a.hindborg@kernel.org>,\n  Alice Ryhl <aliceryhl@google.com>, Trevor Gross <tmgross@umich.edu>,\n  Danilo Krummrich <dakr@kernel.org>, \"Rafael J. Wysocki\" <rafael@kernel.org>,\n  Bjorn Helgaas <bhelgaas@google.com>,\n =?utf-8?q?Krzysztof_Wilczy=C5=84ski?= <kwilczynski@kernel.org>,\n  Boqun Feng <boqun@kernel.org>, Boqun Feng <boqun@kernel.org>","Cc":"rust-for-linux@vger.kernel.org, linux-leds@vger.kernel.org,\n linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org,\n Markus Probst <markus.probst@posteo.de>","X-Developer-Signature":"v=1; a=openpgp-sha256; l=5220;\n i=markus.probst@posteo.de; h=from:subject:message-id;\n bh=aSElWiw4h2ooJZhNAvX7pVieluBonHEoG3ZjWqXCLyQ=;\n b=owEBiQJ2/ZANAwAIATR2H/jnrUPSAcsmYgBp2mOly2O+JIvaKyh756oGFeStP186MMW+l9y1U\n hNh0iqkMH6JAk8EAAEIADkWIQSCdBjE9KxY53IwxHM0dh/4561D0gUCadpjpRsUgAAAAAAEAA5t\n YW51MiwyLjUrMS4xMiwyLDIACgkQNHYf+OetQ9KLuA//Wp/POu2iGYvSwIV+r71Py4srijDV+tu\n MsoTe4bNNIyxutvYuoFJ3LepGt++7JW9IwDPmqJGNcQGy9iBcbD6BUlQy2/QCWndGn2Ur9jFAGK\n sO6FyqBlSHrA3qlCK9l7RGjc42qjdHmB0flM4dYxFUaZjGXVVRbUncUJd42pFbMdiNrBLaOkZD7\n oO2I8W+EaQjtaC4AMKfSC2Yfms62WOPHvtxAPWu1Ot9fKMwxbh/LwUXCq6sPpb3US6FwKCOaPQ3\n guSvsjBY9f02xDuOslHno7qdzFc1YG4sXAGNV6bWddJ/VonRYb/QuHhO+Px3FKG134j9c2C+yvY\n 2ehwiVQFPocfwF0mnayQJP9rImxfhMuVUyBj6vTXlv7KkYsZypu23ZRDp61tL9cXcZFDZ8KQ74A\n Pw+ZsWrBv9RD1GQvJJW6+0eXbtC60jf3UpnOoavIKoZDngCy3XPgt94WjcWdmo24PhQBfIB2Zyk\n XGDQCIFjtlZNWf/EHEFiS567zXDMQHmkRwuWrHm78CF2BUlKQK4kb/O3d0KkmlKu0EFPGlo7HOm\n SGBSIhDN4mUWfo/NbLXG/SuH92lAfAcdNqLK9j1m2I7vu/VDT/0DUhyEpcykM8Xt58jFmjzR27v\n mZApR7eqhiBZpyaye263C1JpcFN9NJNRkbupLz0rtEFjQpS+5pck=","X-Developer-Key":"i=markus.probst@posteo.de; a=openpgp;\n fpr=827418C4F4AC58E77230C47334761FF8E7AD43D2","Autocrypt":"addr=markus.probst@posteo.de; prefer-encrypt=mutual;\n  keydata=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\n  aBeNN4ijKZchBXHPgVx+YtWRHfcm4l8=","OpenPGP":"url=https://posteo.de/keys/markus.probst@posteo.de.asc;\n preference=encrypt"},"content":"This patch series has previously been contained in\nhttps://lore.kernel.org/rust-for-linux/20251008181027.662616-1-markus.probst@posteo.de/T/#t\nwhich added a rust written led driver for a microcontroller via i2c.\n\nAs the reading and writing to the i2c client via the register!\nmacro has not been implemented yet [1], the patch series will only\ncontain the additional abstractions required.\n\n[1] https://lore.kernel.org/rust-for-linux/DDDS2V0V2NVJ.16ZKXCKUA1HUV@kernel.org/\n\nThe following changes were made:\n* add basic led classdev abstractions to register and unregister leds\n\n* add basic led classdev abstractions to register and unregister\n  multicolor leds\n\nChanges since v12:\n* add `led::DeviceBuilder::name()` and `DeviceBuilderState'\n* add `led::Color::as_c_str`\n\nChanges since v11:\n* use `led::DeviceBuilder` instead of `led::InitData`\n* use static_assert instead of const { assert!(...) }\n* restructured patches to avoid moving `led::Device` from\n  rust/kernel/led.rs to rust/kernel/led/normal.rs in the 2. patch\n\nChanges since v10:\n* allow in-place initialization of `LedOps`\n* run rustfmt for code inside `try_pin_init!`\n\nChanges since v9:\n* add missing periods in documentation\n* duplicate `led::Device` and `led::Adapter` instead of using a complex\n  trait\n* fix imports not using prelude\n* adapt to CStr change\n* documented `led::Color::Multi` and `led::Color::Rgb`\n\nChanges since v8:\n* accept `Option<ARef<Fwnode>>` in `led::InitData::fwnode()`\n* make functions in `MultiColorSubLed` const\n* drop the \"rust: Add trait to convert a device reference to a bus\n  device reference\" patch, as it has been picked into driver-core\n\nChanges since v7:\n* adjusted import style\n* added classdev parameter to callback functions in `LedOps`\n* implement `led::Color`\n* extend `led::InitData` with\n  - initial_brightness\n  - default_trigger\n  - default_color\n* split generic and normal led classdev abstractions up (see patch 3/4)\n* add multicolor led class device abstractions (see patch 4/4)\n* added MAINTAINERS entry\n\nChanges since v6:\n* fixed typos\n* improved documentation\n\nChanges since v5:\n* rename `IntoBusDevice` trait into `AsBusDevice`\n* fix documentation about `LedOps::BLOCKING`\n* removed dependency on i2c bindings\n* added `AsBusDevice` implementation for `platform::Device`\n* removed `device::Device` fallback implementation\n* document that `AsBusDevice` must not be used by drivers and is\n  intended for bus and class device abstractions only.\n\nChanges since v4:\n* add abstraction to convert a device reference to a bus device\n  reference\n* require the bus device as parent device and provide it in class device\n  callbacks\n* remove Pin<Vec<_>> abstraction (as not relevant for the led\n  abstractions)\n* fixed formatting in `led::Device::new`\n* fixed `LedOps::BLOCKING` did the inverse effect\n\nChanges since v3:\n* fixed kunit tests failing because of example in documentation\n\nChanges since v2:\n* return `Devres` on `led::Device` creation\n* replace KBox<T> with T in struct definition\n* increment and decrement reference-count of fwnode\n* make a device parent mandatory for led classdev creation\n* rename `led::Handler` to `led::LedOps`\n* add optional `brightness_get` function to `led::LedOps`\n* use `#[vtable]` instead of `const BLINK: bool`\n* use `Opaque::cast_from` instead of casting a pointer\n* improve documentation\n* improve support for older rust versions\n* use `&Device<Bound>` for parent\n\nChanges since v1:\n* fixed typos noticed by Onur Özkan\n\nSigned-off-by: Markus Probst <markus.probst@posteo.de>\n---\nMarkus Probst (3):\n      rust: leds: add basic led classdev abstractions\n      rust: leds: add Mode trait\n      rust: leds: add multicolor classdev abstractions\n\n MAINTAINERS                     |   8 +\n rust/bindings/bindings_helper.h |   1 +\n rust/kernel/led.rs              | 358 +++++++++++++++++++++++++++++++++++++\n rust/kernel/led/multicolor.rs   | 387 ++++++++++++++++++++++++++++++++++++++++\n rust/kernel/led/normal.rs       | 231 ++++++++++++++++++++++++\n rust/kernel/lib.rs              |   1 +\n 6 files changed, 986 insertions(+)\n---\nbase-commit: d1d81e9d1a4dd846aee9ae77ff9ecc2800d72148\nchange-id: 20251114-rust_leds-a959f7c2f7f9\n-----BEGIN PGP SIGNATURE-----\n\niQJPBAABCAA5FiEEgnQYxPSsWOdyMMRzNHYf+OetQ9IFAmnJX+IbFIAAAAAABAAO\nbWFudTIsMi41KzEuMTEsMiwyAAoJEDR2H/jnrUPSKfEQAIr+nl9WCSty+mWQlJqB\nD9B4+xLku25rFvvSCv/j7vEtL0VF5Rk5GJKFOhEEYg642WR6Os+VuTNnEOVAWTbK\nqNfDNOP9hrn75anyf1HEOduwdsW9sTafrfF8gq36y80q0zVNWqD2SbYJ1A+Ri2Hw\nuvJATuDnxMyBL7lAIPhshPjDHjO9wO7qiW6wSVY0RydD21tQZJkag3vg9gUG0Od7\nv5DtM57QNf5h/7GXmC0oZ07h3Ua5ZSFNFrHBDm7MAt7YU8TllQcD1sL7f7OhcFDh\nLzsQYm+A+VNQ9bL4/SdBeKGug7bEFshJywowdp6noRNJPR1Y2lCy1i3D85PnlM+j\nh/NuFg6nUb1NupcB4J+ibzx/eL+80ablZDAqq5OKiskvDxiiTrQw4kC1TGlh+3rL\ntFqqynKTU40N31nXRPHTG3bIfZsb3GHvXxEkJ1s1ufKKhk9WZKhCDOuSdduYrZX7\n50kR5ptLn3YysJr1JTtt7xgT0ToSaxbre8ZWEKLCG8j8t2ONFDdJSskci+1VOUm3\nFCkRLKILcnqFrQv7vnIa2tK6Xlg6jwcGQaVDB6KUIImGp8FatM0R6qP0iKM535+L\nqAeYagvMjTUgwZXLIuUhwHWVk+1V54VjLlmBx6xfJ0a3MlfmtgdalruWfRAItSCq\nZjXW80wg0v3k/fsCPU5J+hY1\n=OlH0\n-----END PGP SIGNATURE-----"}