{"id":2231897,"url":"http://patchwork.ozlabs.org/api/1.2/covers/2231897/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-pci/cover/20260501-rust_leds-v16-0-9f329fdedcd9@posteo.de/","project":{"id":28,"url":"http://patchwork.ozlabs.org/api/1.2/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,"list_archive_url":"","list_archive_url_format":"","commit_url_format":""},"msgid":"<20260501-rust_leds-v16-0-9f329fdedcd9@posteo.de>","list_archive_url":null,"date":"2026-05-01T14:36:03","name":"[v16,0/3] rust: leds: add led classdev abstractions","submitter":{"id":91819,"url":"http://patchwork.ozlabs.org/api/1.2/people/91819/?format=json","name":"Markus Probst","email":"markus.probst@posteo.de"},"mbox":"http://patchwork.ozlabs.org/project/linux-pci/cover/20260501-rust_leds-v16-0-9f329fdedcd9@posteo.de/mbox/","series":[{"id":502466,"url":"http://patchwork.ozlabs.org/api/1.2/series/502466/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-pci/list/?series=502466","date":"2026-05-01T14:36:03","name":"rust: leds: add led classdev abstractions","version":16,"mbox":"http://patchwork.ozlabs.org/series/502466/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/covers/2231897/comments/","headers":{"Return-Path":"\n <linux-pci+bounces-53577-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=A7IcVj1u;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=172.232.135.74; helo=sto.lore.kernel.org;\n envelope-from=linux-pci+bounces-53577-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=\"A7IcVj1u\"","smtp.subspace.kernel.org;\n arc=none smtp.client-ip=185.67.36.66","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 sto.lore.kernel.org (sto.lore.kernel.org [172.232.135.74])\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 4g6YWd5Q9Vz1yJv\n\tfor <incoming@patchwork.ozlabs.org>; Sat, 02 May 2026 00:36:29 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sto.lore.kernel.org (Postfix) with ESMTP id 6081C3010B11\n\tfor <incoming@patchwork.ozlabs.org>; Fri,  1 May 2026 14:36:18 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id BFE293CCFCF;\n\tFri,  1 May 2026 14:36:12 +0000 (UTC)","from mout02.posteo.de (mout02.posteo.de [185.67.36.66])\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 920943CB2D5\n\tfor <linux-pci@vger.kernel.org>; Fri,  1 May 2026 14:36:10 +0000 (UTC)","from submission (posteo.de [185.67.36.169])\n\tby mout02.posteo.de (Postfix) with ESMTPS id 23C6B240104\n\tfor <linux-pci@vger.kernel.org>; Fri,  1 May 2026 16:36:04 +0200 (CEST)","from customer (localhost [127.0.0.1])\n\tby submission (posteo.de) with ESMTPSA id 4g6YW52rfqz9rxG;\n\tFri,  1 May 2026 16:36:01 +0200 (CEST)"],"ARC-Seal":"i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1777646172; cv=none;\n b=i2RRjjcm096m2/uK8SgQ70uEJ/YGQzcLfQU1ZNiV6Zn1ahlgTINGE0yzybW6BoTy/tzAZH5zt+SYJqEUprV4PBFSoS1vZTVzAApeOYFRmevEuJ9ncZA4zeR82BowYThhEw2lFMuQgF8Z4VG6aTQNKiqrt4XTZHu/u8cxIL438Vc=","ARC-Message-Signature":"i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1777646172; c=relaxed/simple;\n\tbh=Nk/J+onhYrChM8tIM4QeicPhZIUu6perTJpYx7cQuLY=;\n\th=From:Subject:Date:Message-Id:MIME-Version:Content-Type:To:Cc;\n b=fWDhE4AmHeNFAY0usIrPkqfFBhRFSU7jAa8wRT2SFfu+0bxDcbDZbXv28Xf6mzeCY7IvDbB64G06xLsJ6be1AHIX5WnXw0x7Fnn6i4Znj0jY8evxWfVAEd2iI6g/+ur2zywkUfGXPcdpBaF5T6/mMATn2xwjZ5Dkx4URfI9angw=","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=A7IcVj1u; arc=none smtp.client-ip=185.67.36.66","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=posteo.de; s=2017;\n\tt=1777646164; bh=TrvtOs20QI5YY1jv367GyhlDu/j/xvPk2ICRP6Yo18w=;\n\th=From:Subject:Date:Message-Id:MIME-Version:Content-Type:\n\t Content-Transfer-Encoding:To:Cc:Autocrypt:OpenPGP:From;\n\tb=A7IcVj1u6JJPnjCKhvoJdcb7IF7gtL8aRwalT4Z1gIBX3U+X0uUuLQZa+2/DdbyJD\n\t lT6jqdfTpSwSn9rAFjszuKDohbQU88v0pkkdlNC94lr0YD1+WM066K7NMDONUBRaDi\n\t iDd9zCu6pf5FYDFcFSda+GJ9OHjSS8vCIJM9SW4tryk63ffDp+4L+eUcVLkb383VOp\n\t PZTrU0vtY5v9JXAdAF8oJpy+uwk6nnKX9o7X9+tAEiix4YzSmUJKgOhs3OpQ1lSIcL\n\t Ngf6UehChc8IrbM/Wm1ca8+zig6iqvNUPn0lyrWpaPMcx39Gbq9USopCX0QsJoE17D\n\t 8AbukjJK0bs2A==","From":"Markus Probst <markus.probst@posteo.de>","Subject":"[PATCH v16 0/3] rust: leds: add led classdev abstractions","Date":"Fri, 01 May 2026 14:36:03 +0000","Message-Id":"<20260501-rust_leds-v16-0-9f329fdedcd9@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=H4sIACK69GkC/2XS3WrDIBQH8FcpXi/FYzx+9GrvMcaIelyFtek0D\n Rul7z7bUpIsN4KH8/sfRS+sUE5U2G5zYZnGVFJ/rBtQLxvm993xk5oUaoEJLhAAZJPPZfj4olC\n azqKN2ouoo2W1/5Qppp972Nt73e9TGfr8e88eza36TMFZymga3gTbSYgtIrbm9dSXgfptIHZLG\n e1c2rm0VRrlAUMHlqv2vwT+pIoDV3MKvFriHaCSxshoVxYmW5eFhWrRYABvHAnuV1bMrV5YUW0\n MDsFI0E7jyraTbcXiutBWK6BDaz06EWBl5WSlWM6V1cooHWjCgKBWFud2ORertZqsdkKTc4szX\n x8Pn+n7XD/P8Hh95rpCje8PhzTsNqPeQpM91ObrH51CRrxxAgAA","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=4810;\n i=markus.probst@posteo.de; h=from:subject:message-id;\n bh=Nk/J+onhYrChM8tIM4QeicPhZIUu6perTJpYx7cQuLY=;\n b=owEBiQJ2/ZANAwAIATR2H/jnrUPSAcsmYgBp9LpQbrgbgI5CNX5CHhFYz+Po+naAHCmZCChIj\n sQhQUYdlZCJAk8EAAEIADkWIQSCdBjE9KxY53IwxHM0dh/4561D0gUCafS6UBsUgAAAAAAEAA5t\n YW51MiwyLjUrMS4xMiwyLDIACgkQNHYf+OetQ9KNnw//ThFaa+mk3pmy/8F+fZ/I9Ml+j2tBT7c\n NqZ7d3IrULcBOalgF3n4g/HcUNuJmSkdjMPm+vV3Sfz8v+TV9asxOzhOoRB2/aRGnp4gbl0kq1M\n 3K5PcGkNUxiw3OTGNjwWjKz0Fqhb5u9GQdEJhP4lyp1yXrBVEHMcwik4qHj2v/U+mYfRIQaK0EV\n Uj/5/YNtf35CtzUdj3l+/SV1PPL7QBcoLDpbWhw+r5TgLHSj9oYp+JWXvPUNxsX5f4OjiEVET6X\n pf5nwdE7kJ5GviX36wGRgPe0oJ81sPNuhdDrPkeVBzolGVTX9mYpIvHctiVRJHbFf5Rsr1A7XwD\n 4mqXNsxOWU62fFcCTiA03NJ5fySnodE3eV4CH9Vb/gEvCSqDzKz21SclqB/MZnQpCFm9WNmHylG\n e3UtAGe0LV1Kz9i1Pg7hAvaDNeYJtkpbX2Ypb7iWt0VKBTEGuSvDsJTj1Y6GAlAEZy9dDIK7Sgc\n efIXWCNifvZD0xH8Z9VKXzfuPO+i3yDD6p/CIfH2N0tM6eXQIrT81QO/YVraYLLs9XFEs2hYopd\n Hahq894Cffx48fkM6YyUR9zKPHsci0L8dHS1o3MSuxcC3H5mNuif9cWKrYae5nlAuxx/F5RAd7x\n mZZbqZpMs+cwtOXEE/HMAnrwb22oTMXE9cvuUpbO/SeFEgftKtPg=","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 v15:\n* fix issues reported by Sashiko bot:\n  * fix returning error not possible on `brightness_get` callback\n\nChanges since v14:\n* fix issues reported by Sashiko bot:\n  * add missing inlines\n  * add missing Sync trait bound\n  * fix vertical import layout for public export of private types\n  * fix potential memory leak, if a multicolor led device with over\n    `u32::MAX` subleds is registered\n* remove default_trigger option\n* fix missing CAST doc\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              | 351 ++++++++++++++++++++++++++++++++++\n rust/kernel/led/multicolor.rs   | 405 ++++++++++++++++++++++++++++++++++++++++\n rust/kernel/led/normal.rs       | 238 +++++++++++++++++++++++\n rust/kernel/lib.rs              |   1 +\n 6 files changed, 1004 insertions(+)\n---\nbase-commit: 5e9b7d093f3f77cb0af4409559e3d139babfb443\nchange-id: 20251114-rust_leds-a959f7c2f7f9"}