e4fc6580b0
The beginning of a set of Rust modules that showcase how Rust modules look like and how to use the abstracted kernel features. It also includes an example of a Rust host program with several modules. These samples also double as tests in the CI. Reviewed-by: Kees Cook <keescook@chromium.org> Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Co-developed-by: Alex Gaynor <alex.gaynor@gmail.com> Signed-off-by: Alex Gaynor <alex.gaynor@gmail.com> Co-developed-by: Finn Behrens <me@kloenk.de> Signed-off-by: Finn Behrens <me@kloenk.de> Co-developed-by: Wedson Almeida Filho <wedsonaf@google.com> Signed-off-by: Wedson Almeida Filho <wedsonaf@google.com> Co-developed-by: Milan Landaverde <milan@mdaverde.com> Signed-off-by: Milan Landaverde <milan@mdaverde.com> Signed-off-by: Miguel Ojeda <ojeda@kernel.org>
39 lines
856 B
Rust
39 lines
856 B
Rust
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
//! Rust minimal sample.
|
|
|
|
use kernel::prelude::*;
|
|
|
|
module! {
|
|
type: RustMinimal,
|
|
name: b"rust_minimal",
|
|
author: b"Rust for Linux Contributors",
|
|
description: b"Rust minimal sample",
|
|
license: b"GPL",
|
|
}
|
|
|
|
struct RustMinimal {
|
|
numbers: Vec<i32>,
|
|
}
|
|
|
|
impl kernel::Module for RustMinimal {
|
|
fn init(_module: &'static ThisModule) -> Result<Self> {
|
|
pr_info!("Rust minimal sample (init)\n");
|
|
pr_info!("Am I built-in? {}\n", !cfg!(MODULE));
|
|
|
|
let mut numbers = Vec::new();
|
|
numbers.try_push(72)?;
|
|
numbers.try_push(108)?;
|
|
numbers.try_push(200)?;
|
|
|
|
Ok(RustMinimal { numbers })
|
|
}
|
|
}
|
|
|
|
impl Drop for RustMinimal {
|
|
fn drop(&mut self) {
|
|
pr_info!("My numbers are {:?}\n", self.numbers);
|
|
pr_info!("Rust minimal sample (exit)\n");
|
|
}
|
|
}
|