{"id":2229074,"url":"http://patchwork.ozlabs.org/api/1.1/covers/2229074/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-pci/cover/20260427-rust_leds-v14-0-4f4b17e5d516@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":"<20260427-rust_leds-v14-0-4f4b17e5d516@posteo.de>","date":"2026-04-27T17:59:42","name":"[v14,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/20260427-rust_leds-v14-0-4f4b17e5d516@posteo.de/mbox/","series":[{"id":501701,"url":"http://patchwork.ozlabs.org/api/1.1/series/501701/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-pci/list/?series=501701","date":"2026-04-27T17:59:48","name":"rust: leds: add led classdev abstractions","version":14,"mbox":"http://patchwork.ozlabs.org/series/501701/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/covers/2229074/comments/","headers":{"Return-Path":"\n <linux-pci+bounces-53238-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=oewXj96A;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=2600:3c0a:e001:db::12fc:5321; helo=sea.lore.kernel.org;\n envelope-from=linux-pci+bounces-53238-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=\"oewXj96A\"","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 sea.lore.kernel.org (sea.lore.kernel.org\n [IPv6:2600:3c0a:e001:db::12fc:5321])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4g4BNN5ZjBz1yHv\n\tfor <incoming@patchwork.ozlabs.org>; Tue, 28 Apr 2026 04:07:00 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sea.lore.kernel.org (Postfix) with ESMTP id DC6BE3164A3F\n\tfor <incoming@patchwork.ozlabs.org>; Mon, 27 Apr 2026 18:01:29 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id D4B353EB813;\n\tMon, 27 Apr 2026 17:59:47 +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 8F5AA3EBF37\n\tfor <linux-pci@vger.kernel.org>; Mon, 27 Apr 2026 17:59:44 +0000 (UTC)","from submission (posteo.de [185.67.36.169])\n\tby mout01.posteo.de (Postfix) with ESMTPS id 19155240027\n\tfor <linux-pci@vger.kernel.org>; Mon, 27 Apr 2026 19:59:43 +0200 (CEST)","from customer (localhost [127.0.0.1])\n\tby submission (posteo.de) with ESMTPSA id 4g4BCv5Wysz9rxS;\n\tMon, 27 Apr 2026 19:59:39 +0200 (CEST)"],"ARC-Seal":"i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1777312787; cv=none;\n b=LH4111ffOb8sFRqmyaQOKkdQNgrMlE0EMeDGea757Z/DZw9bsNnCtaGsHCkdqQhRSY8KAzl8tJCUpmRyCP4ZM/LJpemtlINA9uB2J50GzDm7uJkFi7IrSOspGS7BPDJwFfv6GoMAhwQ2jHAl/FgP8300rA3ynNr1NQLhxer3BR0=","ARC-Message-Signature":"i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1777312787; c=relaxed/simple;\n\tbh=1FxTiyEveIK25RSRnGUxeXnSKqLuzc8pb+/y+E8RvrQ=;\n\th=From:Subject:Date:Message-Id:MIME-Version:Content-Type:To:Cc;\n b=QJTydDPJP4XX3TSzUzQpCVS7A9x69Q1e922xk/DyQ6IDuzOAOQKAsT2GsqvIA9djo8Ubatb/GH57gLqeNRNFG0S/hCg6rd2ji4vmp89Ix2giBpcgYuxxM6MaxJjnEsO1YIMwhOfOn2sCxNy1xZt9fen1BJwkrD93rBSa8JzxZAI=","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=oewXj96A; 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=1777312783; bh=9GkKoo4K3wAZMxNnmcP2i/6Czl8Ff03bFuwovnivRhE=;\n\th=From:Subject:Date:Message-Id:MIME-Version:Content-Type:\n\t Content-Transfer-Encoding:To:Cc:Autocrypt:OpenPGP:From;\n\tb=oewXj96AS2/14gVvaKPnWsEHP1A28PevVquomdx7eEuHPQLSCW410OM6yDMx/obQW\n\t QiaknPAwfuujBHj1KEE9l7XpxuU78jsFbbUZX4bJQlV9rH27qIm4A6sYy8ru9UW5gN\n\t xZnPwloB4A12EgC0RN/7CEqqL3Fr6U4r6xezPMSI0jUfrj4IaJYLAwPxc0qoFN8Z0y\n\t UMW5Yxu8KD9yv3f2/4Sib0yZwjp/19K85LQhU84/Qb300mNOpfDhEiCjeu4MLKTHP3\n\t z9XJWZNxgRVGd9m7285X0p9TkmxUBUVH+dS7MO9F3HuAV3Py7sz/rPjhCdKTU9cL/C\n\t PHr81Fx2bhUdg==","From":"Markus Probst <markus.probst@posteo.de>","Subject":"[PATCH v14 0/3] rust: leds: add led classdev abstractions","Date":"Mon, 27 Apr 2026 17:59:42 +0000","Message-Id":"<20260427-rust_leds-v14-0-4f4b17e5d516@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","X-B4-Tracking":"v=1; b=H4sIAASk72kC/2XR3WoDIRAF4FdZvK7BUWfVXPU9SimuP43QZFPdL\n C0h716TEOJ2b4QZ5jsg50xKyCkUsu3OJIc5lTQe6gDypSNuZw+fgSZfF4QzjgAgaT6V6eMr+EK\n tQROV41FFQ+r9MYeYfm5hb+913qUyjfn3lj3r6/aRgk3KrCmj3lgJUSCi0K/HsUxh3PhArimza\n aVppalS9w7QWzCsF/8lsAftGbC+pcCqDcwC9lJrGc3KwtPWZ2GhWtTowekhcOZWlrdWLSyvNvo\n BQUtQg8KVFU8r+OK7IKrlYNEYhwP30NrLvYAcvk+1xOneAhlsCdSN+32att2sNkCzg3p8+QOp7\n SSS+QEAAA==","X-Change-ID":"20251114-rust_leds-a959f7c2f7f9","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=4333;\n i=markus.probst@posteo.de; h=from:subject:message-id;\n bh=1FxTiyEveIK25RSRnGUxeXnSKqLuzc8pb+/y+E8RvrQ=;\n b=owEBiQJ2/ZANAwAIATR2H/jnrUPSAcsmYgBp76QLZsmGK5Y6cYLO5ayvyNzxbAhUHHyyGdHjc\n LnITRpmg8eJAk8EAAEIADkWIQSCdBjE9KxY53IwxHM0dh/4561D0gUCae+kCxsUgAAAAAAEAA5t\n YW51MiwyLjUrMS4xMiwyLDIACgkQNHYf+OetQ9JiKA//XQ5R/Eb+YlERdbz84G8mnFwne4fitRm\n i6Y5SFWLq+d9CdASroZkytu0x4+4RtqhYTJ8QEZLexqubEmEGxrWvTNYppgLANUzod14MfnRaRJ\n RZjVsRV39OxuxDk8H6UB/adkxrcB7kHqmvAr0I9zMGW9fea/vmyyVOKEKmTUk9HCpJdnDR808lJ\n zwQDAKQcxU2Hi3bhwaI8yvmLAGsdvV8rzFKrIXy15MKryJhZGAcwOY5HTyu4uoudLOg0nHCg2j/\n 6DjmRSczRSaLiocW4skR6hh8LjvAXxCEneb/nb/p9/CmmJ/bmvpB9uuBDs5HFzM/lJ2P6oZYzTy\n u0q/UO1m1VifRLJaBVVfW0LZEmqzHGFRo56cBjtLrPfg5KIrDBTf29trzrft42yo6xHWpIDrB4o\n aUZbXtCCN4Bf2JG81PH3d731VuPGsUaMYr0NuvF+Q4JQ63Tg8YgdqUkwqra4joEMoyjD6EgKbhp\n /imfUc3R8xszrUji48pdFdJmCtChJyo8mYxT18i1q+BIJ4unrEF86e5yRKEAlFnO27WtdCFJvqQ\n LuuOnPJiwGPbYipi5fnlb73wTLzZRceNA1sp/Q2+nHshSf/9XE7D8mcH0dczr7y/95WXYiU260J\n H7Wcu/ItlPjpmjv/HitOgMIC5syy40mhKZUOezIp+t8NP2HEE974=","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 v13:\n* rebased onto v7.1-rc1\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              | 356 ++++++++++++++++++++++++++++++++++++\n rust/kernel/led/multicolor.rs   | 387 ++++++++++++++++++++++++++++++++++++++++\n rust/kernel/led/normal.rs       | 231 ++++++++++++++++++++++++\n rust/kernel/lib.rs              |   1 +\n 6 files changed, 984 insertions(+)\n---\nbase-commit: 5e9b7d093f3f77cb0af4409559e3d139babfb443\nchange-id: 20251114-rust_leds-a959f7c2f7f9"}