Re: [PATCH] rust: prelude: add bit function
From: Miguel Ojeda
Date: Tue Jan 30 2024 - 15:11:18 EST
Hi Christina,
Thanks for the patch! Please see below.
On Tue, Jan 30, 2024 at 8:48 PM Christina Quast
<contact@xxxxxxxxxxxxxxxxxx> wrote:
>
> In order to create masks easily, the define BIT() is used in C code.
> This commit adds the same functionality to the rust kernel.
>
> To use it, include the following into your rust file:
> use kernel::prelude::bit
This is the prelude, i.e. the point is that it does not need to be `use`d.
Did you check the `rust` branch? We had something like this there.
> diff --git a/rust/kernel/prelude.rs b/rust/kernel/prelude.rs
> index ae21600970b3..16e483de2f27 100644
> --- a/rust/kernel/prelude.rs
> +++ b/rust/kernel/prelude.rs
Please note that the prelude is meant to re-export existing
functionality elsewhere in the `kernel` crate, not to define items
there.
> +/// # Arguments
> +///
> +/// * `n` - A `u32` that specifies the bit position (zero-based index)
We don't use "Arguments"-like sections. Please see other functions'
documentation to see how we usually do it.
> +/// # Example
Please use the plural.
> +/// ```
> +/// let b = bit(2);
> +/// assert_eq!(b, 4);
The example is not closed.
> +#[inline]
> +pub const fn bit(n: u32) -> u32 {
> + 1 << n
> +}
Should it be a generic?
Cheers,
Miguel