// SPDX-License-Identifier: GPL-2.0 //! Crate for all kernel procedural macros. mod helpers; mod module; use proc_macro::TokenStream; /// Declares a kernel module. /// /// The `type` argument should be a type which implements the [`Module`] /// trait. Also accepts various forms of kernel metadata. /// /// C header: [`include/linux/moduleparam.h`](../../../include/linux/moduleparam.h) /// /// [`Module`]: ../kernel/trait.Module.html /// /// # Examples /// /// ```ignore /// use kernel::prelude::*; /// /// module!{ /// type: MyModule, /// name: b"my_kernel_module", /// author: b"Rust for Linux Contributors", /// description: b"My very own kernel module!", /// license: b"GPL", /// params: { /// my_i32: i32 { /// default: 42, /// permissions: 0o000, /// description: b"Example of i32", /// }, /// writeable_i32: i32 { /// default: 42, /// permissions: 0o644, /// description: b"Example of i32", /// }, /// }, /// } /// /// struct MyModule; /// /// impl kernel::Module for MyModule { /// fn init() -> Result { /// // If the parameter is writeable, then the kparam lock must be /// // taken to read the parameter: /// { /// let lock = THIS_MODULE.kernel_param_lock(); /// pr_info!("i32 param is: {}\n", writeable_i32.read(&lock)); /// } /// // If the parameter is read only, it can be read without locking /// // the kernel parameters: /// pr_info!("i32 param is: {}\n", my_i32.read()); /// Ok(Self) /// } /// } /// ``` /// /// # Supported argument types /// - `type`: type which implements the [`Module`] trait (required). /// - `name`: byte array of the name of the kernel module (required). /// - `author`: byte array of the author of the kernel module. /// - `description`: byte array of the description of the kernel module. /// - `license`: byte array of the license of the kernel module (required). /// - `alias`: byte array of alias name of the kernel module. #[proc_macro] pub fn module(ts: TokenStream) -> TokenStream { module::module(ts) }