Bitfield Struct

Crate API

Procedural macro for bitfields that allows specifying bitfields as structs. As this library provides a procedural macro, it has no runtime dependencies and works for no-std.

Usage

Add this to your Cargo.toml:

toml [dependencies] bitfield-struct = "0.1"

Example

```rust

[bitfield(u64)]

struct PageTableEntry { /// defaults to 32 bits for u32 addr: u32,

/// public field -> public accessor functions
#[bits(12)]
pub size: usize,

/// padding: No accessor functions are generated for fields beginning with `_`.
#[bits(6)]
_p: u8,

/// interpreted as 1 bit flag
present: bool,

/// sign extend for signed integers
#[bits(13)]
negative: i16,

} ```

The macro generates three accessor functions for each field. Each accessor also inherits the documentation of its field.

The signatures for addr, for example, are:

```rust // generated struct struct PageTableEntry(u64); impl PageTableEntry { const fn new() -> Self { /* ... */ }

const fn with_addr(self, value: u32) -> Self { /* ... */ }
const fn addr(&self) -> u32 { /* ... */ }
fn set_addr(&mut self, value: u32) { /* ... */ }

// other fields ...

} // generated trait implementations impl From for PageTableEntry { /* ... / } impl From for u64 { / ... / } impl Debug for PageTableEntry { / ... */ } ```

This generated bitfield can then be used as follows.

```rust let mut pte = PageTableEntry::new() .withaddr(3 << 31) .withsize(2) .withpresent(false) .withnegative(-3);

println!("{pte:?}"); assert!(pte.addr() == 3 << 31);

pte.set_size(1);

let value: u64 = pte.into(); println!("{value:b}"); ```