[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250321145906.3163-1-dakr@kernel.org>
Date: Fri, 21 Mar 2025 15:57:55 +0100
From: Danilo Krummrich <dakr@...nel.org>
To: bhelgaas@...gle.com,
gregkh@...uxfoundation.org,
rafael@...nel.org,
ojeda@...nel.org,
alex.gaynor@...il.com,
boqun.feng@...il.com,
gary@...yguo.net,
bjorn3_gh@...tonmail.com,
benno.lossin@...ton.me,
a.hindborg@...nel.org,
aliceryhl@...gle.com,
tmgross@...ch.edu
Cc: linux-pci@...r.kernel.org,
rust-for-linux@...r.kernel.org,
linux-kernel@...r.kernel.org,
Danilo Krummrich <dakr@...nel.org>
Subject: [PATCH v3 0/3] Implement TryFrom<&Device> for bus specific devices
This series provides a mechanism to safely convert a struct device into its
corresponding bus specific device instance, if any.
In C a generic struct device is typically converted to a specific bus device
with container_of(). This requires the caller to know whether the generic struct
device is indeed embedded within the expected bus specific device type.
In Rust we can do the same thing by implementing the TryFrom trait, e.g.
impl TryFrom<&Device> for pci::Device
This is a safe operation, since we can check whether dev->bus equals the the
expected struct bus_type.
A branch containing the patches can be found in [1].
This is needed for the auxiliary bus abstractions and connecting nova-core with
nova-drm. [2]
[1] https://web.git.kernel.org/pub/scm/linux/kernel/git/dakr/linux.git/log/?h=rust/device
[2] https://gitlab.freedesktop.org/drm/nova/-/tree/staging/nova-drm
Changes in v3:
- drop patch to add Device::parent(), will make it crate private and part of
the auxbus series
- safety comment: clarify that a device' bus type is guaranteed to be set
correctly by the corresponding C code
Changes in v2:
- s/unsafe { *self.as_raw() }.parent/unsafe { (*self.as_raw()).parent }/
- expand safety comment on Device::bus_type_raw()
Danilo Krummrich (3):
rust: device: implement bus_type_raw()
rust: pci: impl TryFrom<&Device> for &pci::Device
rust: platform: impl TryFrom<&Device> for &platform::Device
rust/kernel/device.rs | 9 +++++++++
rust/kernel/pci.rs | 22 ++++++++++++++++++++--
rust/kernel/platform.rs | 22 ++++++++++++++++++++--
3 files changed, 49 insertions(+), 4 deletions(-)
base-commit: 51d0de7596a458096756c895cfed6bc4a7ecac10
--
2.48.1
Powered by blists - more mailing lists