[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <a6346fd1-3161-4130-8121-5d0e98fd5141@gmail.com>
Date: Fri, 20 Dec 2024 08:24:45 +0100
From: Dirk Behme <dirk.behme@...il.com>
To: Danilo Krummrich <dakr@...nel.org>, gregkh@...uxfoundation.org,
rafael@...nel.org, bhelgaas@...gle.com, ojeda@...nel.org,
alex.gaynor@...il.com, boqun.feng@...il.com, gary@...yguo.net,
bjorn3_gh@...tonmail.com, benno.lossin@...ton.me, tmgross@...ch.edu,
a.hindborg@...sung.com, aliceryhl@...gle.com, airlied@...il.com,
fujita.tomonori@...il.com, lina@...hilina.net, pstanner@...hat.com,
ajanulgu@...hat.com, lyude@...hat.com, robh@...nel.org,
daniel.almeida@...labora.com, saravanak@...gle.com, dirk.behme@...bosch.com,
j@...nau.net, fabien.parent@...aro.org, chrisi.schrefl@...il.com,
paulmck@...nel.org
Cc: rust-for-linux@...r.kernel.org, linux-kernel@...r.kernel.org,
linux-pci@...r.kernel.org, devicetree@...r.kernel.org, rcu@...r.kernel.org
Subject: Re: [PATCH v7 00/16] Device / Driver PCI / Platform Rust abstractions
On 19.12.24 18:04, Danilo Krummrich wrote:
> This patch series implements the necessary Rust abstractions to implement
> device drivers in Rust.
>
> This includes some basic generalizations for driver registration, handling of ID
> tables, MMIO operations and device resource handling.
>
> Those generalizations are used to implement device driver support for two
> busses, the PCI and platform bus (with OF IDs) in order to provide some evidence
> that the generalizations work as intended.
>
> The patch series also includes two patches adding two driver samples, one PCI
> driver and one platform driver.
>
> The PCI bits are motivated by the Nova driver project [1], but are used by at
> least one more OOT driver (rnvme [2]).
>
> The platform bits, besides adding some more evidence to the base abstractions,
> are required by a few more OOT drivers aiming at going upstream, i.e. rvkms [3],
> cpufreq-dt [4], asahi [5] and the i2c work from Fabien [6].
>
> The patches of this series can also be [7], [8] and [9].
>
> Changes in v7:
> ==============
> - Revocable:
> - replace `compare_exchange` with `swap`
>
> - Driver:
> - fix warning when CONFIG_OF=n
>
> - I/O:
> - remove unnecessary return statement in rust_helper_iounmap()
> - fix cast in doctest for `bindings::ioremap`
>
> - Devres:
> - fix cast in doctest for `bindings::ioremap`
>
> - PCI:
> - remove `Deref` of `pci::DeviceId`
> - rename `DeviceId` constructors
> - `new` -> `from_id`
> - `with_class -> `from_class`
>
> - MISC:
> - use `kernel::ffi::c_*` instead of `core::ffi::c_*`
> - rebase onto latest rust-next (0c5928deada15a8d075516e6e0d9ee19011bb000)
Not sure if resending is required, but after a quick retest the
Tested-by from v6 still stands:
Tested-by: Dirk Behme <dirk.behme@...bosch.com>
Thanks
Dirk
Powered by blists - more mailing lists