From c9c23a0bce748d0d2de2d941f304b52c4048d9e0 Mon Sep 17 00:00:00 2001 From: Miguel Ojeda Date: Fri, 16 Feb 2024 22:15:55 +0100 Subject: [PATCH] Add "Rust reference drivers" page Signed-off-by: Miguel Ojeda --- SUMMARY.md | 1 + src/Contributing.md | 2 ++ src/Rust-reference-drivers.md | 40 +++++++++++++++++++++++++++++++++++ 3 files changed, 43 insertions(+) create mode 100644 src/Rust-reference-drivers.md diff --git a/SUMMARY.md b/SUMMARY.md index 57a4691..69baee1 100644 --- a/SUMMARY.md +++ b/SUMMARY.md @@ -5,6 +5,7 @@ - [Contact](Contact.md) - [Contributing](Contributing.md) - [Branches](Branches.md) + - [Rust reference drivers](Rust-reference-drivers.md) - [Rust version policy](Rust-version-policy.md) - [Unstable features](Unstable-features.md) - [Backporting and stable/LTS releases](Backporting-and-stable-LTS-releases.md) diff --git a/src/Contributing.md b/src/Contributing.md index 4e147bc..4510cba 100644 --- a/src/Contributing.md +++ b/src/Contributing.md @@ -78,6 +78,8 @@ For new abstractions and modules, and especially for those that require new kern - As early as possible, please get in touch with the maintainers of the relevant subsystem in order to make them aware of the work you are doing or planning to do. That way, they can give you input and feedback on the process. Please feel free to Cc the Rust maintainers too. + - Consider whether a [Rust reference driver](Rust-reference-drivers.md) could be a good idea to bootstrap Rust into the subsystem. + - When you are getting closer to patch submission, please consider sending an RFC series first, especially if it is a major contribution, or if it is a long patch series, or if you require a lot of prerequisite patches (e.g. for abstractions of other subsystems) that are not yet upstreamed. The RFC can be based on top of a branch placed somewhere else that contains the prerequisite patches, so that the RFC patches themselves do not cover those, and therefore is focused on the parts that the maintainers will eventually review. diff --git a/src/Rust-reference-drivers.md b/src/Rust-reference-drivers.md new file mode 100644 index 0000000..1465dfa --- /dev/null +++ b/src/Rust-reference-drivers.md @@ -0,0 +1,40 @@ +# Rust reference drivers + +Some kernel subsystems maintainers are open to the idea of experimenting with Rust, but they may want to start simple with a driver they are familiar with. But such a driver would violate the "no duplicate drivers" rule. + +Similarly, external people have expressed an interest in writing Rust drivers, but given the required abstractions are not there, they may decide to wait. But if nobody writes a first use case, the abstractions cannot be merged without breaking the "no code without an +expected in-tree user" rule. + +[Rust reference drivers](https://lore.kernel.org/all/CANiq72=99VFE=Ve5MNM9ZuSe9M-JSH1evk6pABNSEnNjK7aXYA@mail.gmail.com/) are a solution to these deadlocks: they are drivers that subsystem maintainers are allowed to introduce in their subsystem without dropping the existing C driver. This allows maintainers: + + 1. To bootstrap abstractions for new drivers, i.e. not the "duplicate"/"rewritten" one, but future new drivers that would use those abstractions; while avoiding breaking the "no dead code" rule. + + 2. To serve as a reference for existing C maintainers on how such drivers would look like in Rust, as "live" documentation, e.g. like how [LWN featured a 1:1 comparison](https://lwn.net/Articles/863459/) between a C and Rust driver. And it has to be buildable at all times. + + 3. To use all the in-tree kernel infrastructure and to prepare their subsystem for Rust over time, e.g. setting up tests and CI. + + 4. To learn over time, especially for subsystems that have several maintainers where not everybody may have time for it at a given moment. Reading Rust patches from time to time for APIs one is familiar with can help a lot. + + 5. And, most importantly, to evaluate if the effort is worth it for their subsystem. For instance, maintainers may ask themselves: + + - "How much can we write in safe code?" + + - "How many issues has the reference driver had over time vs. the C one? Did Rust help prevent some?" + + - "How hard is it to maintain the Rust side? Do we have enough resources in our subsystem?" + + - etc. + +A "Rust reference driver" does not necessarily need to be considered a real driver, e.g. it could be behind `EXPERT`, be tagged `(EXPERIMENTAL)`, staging... + +The first driver that took advantage of this framework was [`drivers/net/phy/ax88796b_rust.rs`](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/net/phy/ax88796b_rust.rs?h=v6.8-rc1), which was [merged for v6.8](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/drivers/net/phy/ax88796b_rust.rs?h=v6.8-rc1&id=cbe0e415089636170aa6eb540ca4af5dc9842a6): + +```kconfig +config AX88796B_RUST_PHY + bool "Rust reference driver for Asix PHYs" + depends on RUST_PHYLIB_ABSTRACTIONS && AX88796B_PHY + help + Uses the Rust reference driver for Asix PHYs (ax88796b_rust.ko). + The features are equivalent. It supports the Asix Electronics PHY + found in the X-Surf 100 AX88796B package. +```